/** * Copyright (c) Facebook, Inc. and its affiliates. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. * * @flow strict-local * @format */ 'use strict'; const Animated = require('Animated'); const Easing = require('Easing'); const React = require('React'); const StyleSheet = require('StyleSheet'); const Text = require('Text'); const YellowBoxImageSource = require('YellowBoxImageSource'); const YellowBoxPressable = require('YellowBoxPressable'); const YellowBoxStyle = require('YellowBoxStyle'); import type {CompositeAnimation} from 'AnimatedImplementation'; import type AnimatedInterpolation from 'AnimatedInterpolation'; import type {PressEvent} from 'CoreEventTypes'; type Props = $ReadOnly<{| onPress?: ?(event: PressEvent) => void, status: 'COMPLETE' | 'FAILED' | 'NONE' | 'PENDING', |}>; type State = {| animation: ?CompositeAnimation, rotate: ?AnimatedInterpolation, |}; class YellowBoxInspectorSourceMapStatus extends React.Component { state = { animation: null, rotate: null, }; render(): React.Node { let image; switch (this.props.status) { case 'COMPLETE': image = YellowBoxImageSource.check; break; case 'FAILED': image = YellowBoxImageSource.alertTriangle; break; case 'PENDING': image = YellowBoxImageSource.loader; break; } return image == null ? null : ( Source Map ); } componentDidMount(): void { this._updateAnimation(); } componentDidUpdate(): void { this._updateAnimation(); } componentWillUnmount(): void { if (this.state.animation != null) { this.state.animation.stop(); } } _updateAnimation(): void { if (this.props.status === 'PENDING') { if (this.state.animation == null) { const animated = new Animated.Value(0); const animation = Animated.loop( Animated.timing(animated, { duration: 2000, easing: Easing.linear, toValue: 1, useNativeDriver: true, }), ); this.setState( { animation, rotate: animated.interpolate({ inputRange: [0, 1], outputRange: ['0deg', '360deg'], }), }, () => { animation.start(); }, ); } } else { if (this.state.animation != null) { this.state.animation.stop(); this.setState({ animation: null, rotate: null, }); } } } } const styles = StyleSheet.create({ root: { alignItems: 'center', borderRadius: 12, flexDirection: 'row', height: 24, paddingHorizontal: 8, }, pending: { backgroundColor: YellowBoxStyle.getTextColor(0.6), }, image: { marginEnd: 4, tintColor: YellowBoxStyle.getBackgroundColor(1), }, text: { color: YellowBoxStyle.getBackgroundColor(1), fontSize: 12, includeFontPadding: false, lineHeight: 16, }, }); module.exports = YellowBoxInspectorSourceMapStatus;