diff options
author | Paul Frazee <pfrazee@gmail.com> | 2022-11-15 10:54:43 -0600 |
---|---|---|
committer | Paul Frazee <pfrazee@gmail.com> | 2022-11-15 10:54:43 -0600 |
commit | e470e3933b923abfeed4eb8c3bd0cf0b32b0232d (patch) | |
tree | 261a3a3cc552b421e0016b1c70ed17e8cf654a2d /src/view/com/util/EmptyState.tsx | |
parent | fb3a43c216a884f7185c53cba6e210d6659448d1 (diff) | |
download | voidsky-e470e3933b923abfeed4eb8c3bd0cf0b32b0232d.tar.zst |
Improve empty states
Diffstat (limited to 'src/view/com/util/EmptyState.tsx')
-rw-r--r-- | src/view/com/util/EmptyState.tsx | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/src/view/com/util/EmptyState.tsx b/src/view/com/util/EmptyState.tsx new file mode 100644 index 000000000..adae9e314 --- /dev/null +++ b/src/view/com/util/EmptyState.tsx @@ -0,0 +1,50 @@ +import React from 'react' +import {StyleProp, StyleSheet, Text, View, ViewStyle} from 'react-native' +import {IconProp} from '@fortawesome/fontawesome-svg-core' +import {FontAwesomeIcon} from '@fortawesome/react-native-fontawesome' +import {UserGroupIcon} from '../../lib/icons' +import {colors} from '../../lib/styles' + +export function EmptyState({ + icon, + message, + style, +}: { + icon: IconProp | 'user-group' + message: string + style?: StyleProp<ViewStyle> +}) { + return ( + <View style={[styles.container, style]}> + <View style={styles.iconContainer}> + {icon === 'user-group' ? ( + <UserGroupIcon size="64" style={styles.icon} /> + ) : ( + <FontAwesomeIcon icon={icon} size={64} style={styles.icon} /> + )} + </View> + <Text style={styles.text}>{message}</Text> + </View> + ) +} + +const styles = StyleSheet.create({ + container: { + paddingVertical: 20, + paddingHorizontal: 36, + }, + iconContainer: { + flexDirection: 'row', + }, + icon: { + marginLeft: 'auto', + marginRight: 'auto', + color: colors.gray3, + }, + text: { + textAlign: 'center', + color: colors.gray5, + paddingTop: 16, + fontSize: 16, + }, +}) |