forkad från vergnet/application-amicale
		
	Added icon animations
This commit is contained in:
		
							förälder
							
								
									b336c95f20
								
							
						
					
					
						incheckning
						96394972eb
					
				
					 1 ändrade filer med 29 tillägg och 10 borttagningar
				
			
		|  | @ -1,9 +1,10 @@ | ||||||
| import * as React from 'react'; | import * as React from 'react'; | ||||||
| import {Avatar, List, ProgressBar, Surface, Text, withTheme} from 'react-native-paper'; | import {ActivityIndicator, Avatar, List, ProgressBar, Surface, Text, withTheme} from 'react-native-paper'; | ||||||
| import {StyleSheet, View} from "react-native"; | import {StyleSheet, View} from "react-native"; | ||||||
| import ProxiwashConstants from "../../constants/ProxiwashConstants"; | import ProxiwashConstants from "../../constants/ProxiwashConstants"; | ||||||
| import i18n from "i18n-js"; | import i18n from "i18n-js"; | ||||||
| import AprilFoolsManager from "../../managers/AprilFoolsManager"; | import AprilFoolsManager from "../../managers/AprilFoolsManager"; | ||||||
|  | import * as Animatable from "react-native-animatable"; | ||||||
| 
 | 
 | ||||||
| type Props = { | type Props = { | ||||||
|     item: Object, |     item: Object, | ||||||
|  | @ -13,6 +14,9 @@ type Props = { | ||||||
|     height: number, |     height: number, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | const AnimatedIcon = Animatable.createAnimatableComponent(Avatar.Icon); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| /** | /** | ||||||
|  * Component used to display a proxiwash item, showing machine progression and state |  * Component used to display a proxiwash item, showing machine progression and state | ||||||
|  */ |  */ | ||||||
|  | @ -83,14 +87,21 @@ class ProxiwashListItem extends React.Component<Props> { | ||||||
|             : 1; |             : 1; | ||||||
| 
 | 
 | ||||||
|         const icon = props.isWatched |         const icon = props.isWatched | ||||||
|             ? <Avatar.Icon |             ? <AnimatedIcon | ||||||
|                 icon={'bell-ring'} |                 icon={'bell-ring'} | ||||||
|                 size={45} |                 animation={"rubberBand"} | ||||||
|  |                 useNativeDriver | ||||||
|  |                 size={50} | ||||||
|                 color={colors.primary} |                 color={colors.primary} | ||||||
|                 style={styles.icon} |                 style={styles.icon} | ||||||
|             /> |             /> | ||||||
|             : <Avatar.Icon |             : <AnimatedIcon | ||||||
|                 icon={props.isDryer ? 'tumble-dryer' : 'washing-machine'} |                 icon={props.isDryer ? 'tumble-dryer' : 'washing-machine'} | ||||||
|  |                 animation={isRunning ? "flash" : undefined} | ||||||
|  |                 iterationCount={"infinite"} | ||||||
|  |                 easing={"linear"} | ||||||
|  |                 duration={2000} | ||||||
|  |                 useNativeDriver | ||||||
|                 size={40} |                 size={40} | ||||||
|                 color={colors.text} |                 color={colors.text} | ||||||
|                 style={styles.icon} |                 style={styles.icon} | ||||||
|  | @ -136,12 +147,20 @@ class ProxiwashListItem extends React.Component<Props> { | ||||||
|                                 </Text> |                                 </Text> | ||||||
|                             </View> |                             </View> | ||||||
|                             <View style={{justifyContent: 'center',}}> |                             <View style={{justifyContent: 'center',}}> | ||||||
|                                 <Avatar.Icon |                                 { | ||||||
|  |                                     isRunning | ||||||
|  |                                         ? <ActivityIndicator | ||||||
|  |                                             animating={true} | ||||||
|  |                                             size={'small'} | ||||||
|  |                                             style={{marginLeft: 10}}/> | ||||||
|  |                                         : <Avatar.Icon | ||||||
|                                             icon={stateIcon} |                                             icon={stateIcon} | ||||||
|                                             color={colors.text} |                                             color={colors.text} | ||||||
|                                             size={30} |                                             size={30} | ||||||
|                                             style={styles.icon} |                                             style={styles.icon} | ||||||
|                                         /> |                                         /> | ||||||
|  |                                 } | ||||||
|  | 
 | ||||||
|                             </View> |                             </View> | ||||||
|                         </View>)} |                         </View>)} | ||||||
|                 /> |                 /> | ||||||
|  |  | ||||||
		Laddar…
	
		Referens i nytt ärende