about summary refs log tree commit diff
path: root/src/view/com/util/EmptyState.tsx
diff options
context:
space:
mode:
authorPaul Frazee <pfrazee@gmail.com>2022-11-15 10:54:43 -0600
committerPaul Frazee <pfrazee@gmail.com>2022-11-15 10:54:43 -0600
commite470e3933b923abfeed4eb8c3bd0cf0b32b0232d (patch)
tree261a3a3cc552b421e0016b1c70ed17e8cf654a2d /src/view/com/util/EmptyState.tsx
parentfb3a43c216a884f7185c53cba6e210d6659448d1 (diff)
downloadvoidsky-e470e3933b923abfeed4eb8c3bd0cf0b32b0232d.tar.zst
Improve empty states
Diffstat (limited to 'src/view/com/util/EmptyState.tsx')
-rw-r--r--src/view/com/util/EmptyState.tsx50
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,
+  },
+})