2021-04-21 06:30:21 +03:00
|
|
|
/*
|
|
|
|
Copyright 2021 The Matrix.org Foundation C.I.C.
|
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
import React from "react";
|
2021-06-22 00:18:34 +03:00
|
|
|
import { replaceableComponent } from "../../../utils/replaceableComponent";
|
|
|
|
import { arraySeed, arrayTrimFill } from "../../../utils/arrays";
|
2021-04-21 06:30:21 +03:00
|
|
|
import Waveform from "./Waveform";
|
2021-06-22 00:18:34 +03:00
|
|
|
import { Playback, PLAYBACK_WAVEFORM_SAMPLES } from "../../../voice/Playback";
|
|
|
|
import { percentageOf } from "../../../utils/numbers";
|
2021-04-28 05:27:36 +03:00
|
|
|
|
|
|
|
interface IProps {
|
|
|
|
playback: Playback;
|
|
|
|
}
|
|
|
|
|
|
|
|
interface IState {
|
|
|
|
heights: number[];
|
2021-04-28 07:59:16 +03:00
|
|
|
progress: number;
|
2021-04-28 05:27:36 +03:00
|
|
|
}
|
2021-04-21 06:30:21 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* A waveform which shows the waveform of a previously recorded recording
|
|
|
|
*/
|
2021-06-22 00:18:34 +03:00
|
|
|
@replaceableComponent("views.audio_messages.PlaybackWaveform")
|
2021-04-28 05:27:36 +03:00
|
|
|
export default class PlaybackWaveform extends React.PureComponent<IProps, IState> {
|
2021-04-21 06:30:21 +03:00
|
|
|
public constructor(props) {
|
|
|
|
super(props);
|
|
|
|
|
2021-04-28 07:59:16 +03:00
|
|
|
this.state = {
|
|
|
|
heights: this.toHeights(this.props.playback.waveform),
|
|
|
|
progress: 0, // default no progress
|
|
|
|
};
|
2021-04-28 05:27:36 +03:00
|
|
|
|
|
|
|
this.props.playback.waveformData.onUpdate(this.onWaveformUpdate);
|
2021-04-28 07:59:16 +03:00
|
|
|
this.props.playback.clockInfo.liveData.onUpdate(this.onTimeUpdate);
|
2021-04-28 05:27:36 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
private toHeights(waveform: number[]) {
|
|
|
|
const seed = arraySeed(0, PLAYBACK_WAVEFORM_SAMPLES);
|
|
|
|
return arrayTrimFill(waveform, PLAYBACK_WAVEFORM_SAMPLES, seed);
|
2021-04-21 06:30:21 +03:00
|
|
|
}
|
|
|
|
|
2021-04-28 05:27:36 +03:00
|
|
|
private onWaveformUpdate = (waveform: number[]) => {
|
2021-06-29 15:11:58 +03:00
|
|
|
this.setState({ heights: this.toHeights(waveform) });
|
2021-04-28 05:27:36 +03:00
|
|
|
};
|
|
|
|
|
2021-04-28 07:59:16 +03:00
|
|
|
private onTimeUpdate = (time: number[]) => {
|
2021-05-14 07:35:43 +03:00
|
|
|
// Track percentages to a general precision to avoid over-waking the component.
|
|
|
|
const progress = Number(percentageOf(time[0], 0, time[1]).toFixed(3));
|
2021-06-29 15:11:58 +03:00
|
|
|
this.setState({ progress });
|
2021-04-28 07:59:16 +03:00
|
|
|
};
|
|
|
|
|
2021-04-21 06:30:21 +03:00
|
|
|
public render() {
|
2021-04-28 07:59:16 +03:00
|
|
|
return <Waveform relHeights={this.state.heights} progress={this.state.progress} />;
|
2021-04-21 06:30:21 +03:00
|
|
|
}
|
|
|
|
}
|