signal-desktop/ts/components/CallingAudioIndicator.stories.tsx

54 lines
1.3 KiB
TypeScript
Raw Normal View History

2022-05-19 03:28:51 +00:00
// Copyright 2022 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
2022-05-23 22:00:01 +00:00
import React, { useState, useEffect } from 'react';
2022-05-19 03:28:51 +00:00
import { storiesOf } from '@storybook/react';
2022-05-23 22:00:01 +00:00
import { boolean } from '@storybook/addon-knobs';
2022-05-19 03:28:51 +00:00
import { CallingAudioIndicator } from './CallingAudioIndicator';
2022-05-23 22:00:01 +00:00
import { AUDIO_LEVEL_INTERVAL_MS } from '../calling/constants';
2022-05-19 03:28:51 +00:00
const story = storiesOf('Components/CallingAudioIndicator', module);
2022-05-23 22:00:01 +00:00
story.add('Extreme', () => {
const [audioLevel, setAudioLevel] = useState(1);
useEffect(() => {
const timer = setTimeout(() => {
setAudioLevel(1 - audioLevel);
}, 2 * AUDIO_LEVEL_INTERVAL_MS);
return () => {
clearTimeout(timer);
};
}, [audioLevel, setAudioLevel]);
return (
<CallingAudioIndicator
hasAudio={boolean('hasAudio', true)}
audioLevel={audioLevel}
/>
);
});
story.add('Random', () => {
const [audioLevel, setAudioLevel] = useState(1);
useEffect(() => {
const timer = setTimeout(() => {
setAudioLevel(Math.random());
}, AUDIO_LEVEL_INTERVAL_MS);
return () => {
clearTimeout(timer);
};
}, [audioLevel, setAudioLevel]);
return (
<CallingAudioIndicator
hasAudio={boolean('hasAudio', true)}
audioLevel={audioLevel}
/>
);
});