@oxyhq/services 6.9.43 → 6.9.45

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (205) hide show
  1. package/lib/commonjs/index.js +9 -0
  2. package/lib/commonjs/index.js.map +1 -1
  3. package/lib/commonjs/ui/components/ActingAsBanner.js +143 -0
  4. package/lib/commonjs/ui/components/ActingAsBanner.js.map +1 -0
  5. package/lib/commonjs/ui/components/OxyPayButton.js +4 -2
  6. package/lib/commonjs/ui/components/OxyPayButton.js.map +1 -1
  7. package/lib/commonjs/ui/components/OxySignInButton.js +83 -82
  8. package/lib/commonjs/ui/components/OxySignInButton.js.map +1 -1
  9. package/lib/commonjs/ui/components/SettingRow.js +11 -5
  10. package/lib/commonjs/ui/components/SettingRow.js.map +1 -1
  11. package/lib/commonjs/ui/components/fileManagement/FileDetailsModal.js +76 -121
  12. package/lib/commonjs/ui/components/fileManagement/FileDetailsModal.js.map +1 -1
  13. package/lib/commonjs/ui/components/fileManagement/UploadPreview.js +32 -18
  14. package/lib/commonjs/ui/components/fileManagement/UploadPreview.js.map +1 -1
  15. package/lib/commonjs/ui/components/icon/OxyIcon.js +5 -4
  16. package/lib/commonjs/ui/components/icon/OxyIcon.js.map +1 -1
  17. package/lib/commonjs/ui/components/internal/GroupedPillButtons.js +11 -9
  18. package/lib/commonjs/ui/components/internal/GroupedPillButtons.js.map +1 -1
  19. package/lib/commonjs/ui/components/internal/PinInput.js +3 -2
  20. package/lib/commonjs/ui/components/internal/PinInput.js.map +1 -1
  21. package/lib/commonjs/ui/components/modals/DeleteAccountModal.js +83 -219
  22. package/lib/commonjs/ui/components/modals/DeleteAccountModal.js.map +1 -1
  23. package/lib/commonjs/ui/constants/theme.js +2 -2
  24. package/lib/commonjs/ui/constants/theme.js.map +1 -1
  25. package/lib/commonjs/ui/context/OxyContext.js +78 -3
  26. package/lib/commonjs/ui/context/OxyContext.js.map +1 -1
  27. package/lib/commonjs/ui/navigation/routes.js +3 -2
  28. package/lib/commonjs/ui/navigation/routes.js.map +1 -1
  29. package/lib/commonjs/ui/screens/AccountCenterScreen.js +33 -11
  30. package/lib/commonjs/ui/screens/AccountCenterScreen.js.map +1 -1
  31. package/lib/commonjs/ui/screens/AccountOverviewScreen.js +70 -79
  32. package/lib/commonjs/ui/screens/AccountOverviewScreen.js.map +1 -1
  33. package/lib/commonjs/ui/screens/AccountSettingsScreen.js +22 -10
  34. package/lib/commonjs/ui/screens/AccountSettingsScreen.js.map +1 -1
  35. package/lib/commonjs/ui/screens/AccountSwitcherScreen.js +376 -82
  36. package/lib/commonjs/ui/screens/AccountSwitcherScreen.js.map +1 -1
  37. package/lib/commonjs/ui/screens/AccountVerificationScreen.js +21 -9
  38. package/lib/commonjs/ui/screens/AccountVerificationScreen.js.map +1 -1
  39. package/lib/commonjs/ui/screens/CreateManagedAccountScreen.js +346 -0
  40. package/lib/commonjs/ui/screens/CreateManagedAccountScreen.js.map +1 -0
  41. package/lib/commonjs/ui/screens/FileManagementScreen.js +83 -50
  42. package/lib/commonjs/ui/screens/FileManagementScreen.js.map +1 -1
  43. package/lib/commonjs/ui/screens/HistoryViewScreen.js +80 -101
  44. package/lib/commonjs/ui/screens/HistoryViewScreen.js.map +1 -1
  45. package/lib/commonjs/ui/screens/PremiumSubscriptionScreen.js +66 -93
  46. package/lib/commonjs/ui/screens/PremiumSubscriptionScreen.js.map +1 -1
  47. package/lib/commonjs/ui/screens/SessionManagementScreen.js +101 -66
  48. package/lib/commonjs/ui/screens/SessionManagementScreen.js.map +1 -1
  49. package/lib/commonjs/ui/utils/fileManagement.js +0 -21
  50. package/lib/commonjs/ui/utils/fileManagement.js.map +1 -1
  51. package/lib/module/index.js +3 -0
  52. package/lib/module/index.js.map +1 -1
  53. package/lib/module/ui/components/ActingAsBanner.js +140 -0
  54. package/lib/module/ui/components/ActingAsBanner.js.map +1 -0
  55. package/lib/module/ui/components/OxyPayButton.js +4 -2
  56. package/lib/module/ui/components/OxyPayButton.js.map +1 -1
  57. package/lib/module/ui/components/OxySignInButton.js +84 -83
  58. package/lib/module/ui/components/OxySignInButton.js.map +1 -1
  59. package/lib/module/ui/components/SettingRow.js +11 -5
  60. package/lib/module/ui/components/SettingRow.js.map +1 -1
  61. package/lib/module/ui/components/fileManagement/FileDetailsModal.js +76 -122
  62. package/lib/module/ui/components/fileManagement/FileDetailsModal.js.map +1 -1
  63. package/lib/module/ui/components/fileManagement/UploadPreview.js +32 -19
  64. package/lib/module/ui/components/fileManagement/UploadPreview.js.map +1 -1
  65. package/lib/module/ui/components/icon/OxyIcon.js +5 -4
  66. package/lib/module/ui/components/icon/OxyIcon.js.map +1 -1
  67. package/lib/module/ui/components/internal/GroupedPillButtons.js +11 -9
  68. package/lib/module/ui/components/internal/GroupedPillButtons.js.map +1 -1
  69. package/lib/module/ui/components/internal/PinInput.js +3 -2
  70. package/lib/module/ui/components/internal/PinInput.js.map +1 -1
  71. package/lib/module/ui/components/modals/DeleteAccountModal.js +83 -220
  72. package/lib/module/ui/components/modals/DeleteAccountModal.js.map +1 -1
  73. package/lib/module/ui/constants/theme.js +2 -2
  74. package/lib/module/ui/constants/theme.js.map +1 -1
  75. package/lib/module/ui/context/OxyContext.js +78 -3
  76. package/lib/module/ui/context/OxyContext.js.map +1 -1
  77. package/lib/module/ui/navigation/routes.js +3 -2
  78. package/lib/module/ui/navigation/routes.js.map +1 -1
  79. package/lib/module/ui/screens/AccountCenterScreen.js +32 -11
  80. package/lib/module/ui/screens/AccountCenterScreen.js.map +1 -1
  81. package/lib/module/ui/screens/AccountOverviewScreen.js +71 -80
  82. package/lib/module/ui/screens/AccountOverviewScreen.js.map +1 -1
  83. package/lib/module/ui/screens/AccountSettingsScreen.js +22 -10
  84. package/lib/module/ui/screens/AccountSettingsScreen.js.map +1 -1
  85. package/lib/module/ui/screens/AccountSwitcherScreen.js +375 -82
  86. package/lib/module/ui/screens/AccountSwitcherScreen.js.map +1 -1
  87. package/lib/module/ui/screens/AccountVerificationScreen.js +22 -10
  88. package/lib/module/ui/screens/AccountVerificationScreen.js.map +1 -1
  89. package/lib/module/ui/screens/CreateManagedAccountScreen.js +342 -0
  90. package/lib/module/ui/screens/CreateManagedAccountScreen.js.map +1 -0
  91. package/lib/module/ui/screens/FileManagementScreen.js +85 -52
  92. package/lib/module/ui/screens/FileManagementScreen.js.map +1 -1
  93. package/lib/module/ui/screens/HistoryViewScreen.js +80 -101
  94. package/lib/module/ui/screens/HistoryViewScreen.js.map +1 -1
  95. package/lib/module/ui/screens/PremiumSubscriptionScreen.js +66 -94
  96. package/lib/module/ui/screens/PremiumSubscriptionScreen.js.map +1 -1
  97. package/lib/module/ui/screens/SessionManagementScreen.js +101 -67
  98. package/lib/module/ui/screens/SessionManagementScreen.js.map +1 -1
  99. package/lib/module/ui/utils/fileManagement.js +0 -20
  100. package/lib/module/ui/utils/fileManagement.js.map +1 -1
  101. package/lib/typescript/commonjs/index.d.ts +1 -0
  102. package/lib/typescript/commonjs/index.d.ts.map +1 -1
  103. package/lib/typescript/commonjs/ui/components/ActingAsBanner.d.ts +4 -0
  104. package/lib/typescript/commonjs/ui/components/ActingAsBanner.d.ts.map +1 -0
  105. package/lib/typescript/commonjs/ui/components/OxyPayButton.d.ts.map +1 -1
  106. package/lib/typescript/commonjs/ui/components/OxySignInButton.d.ts +0 -1
  107. package/lib/typescript/commonjs/ui/components/OxySignInButton.d.ts.map +1 -1
  108. package/lib/typescript/commonjs/ui/components/SettingRow.d.ts +2 -2
  109. package/lib/typescript/commonjs/ui/components/SettingRow.d.ts.map +1 -1
  110. package/lib/typescript/commonjs/ui/components/fileManagement/FileDetailsModal.d.ts +3 -4
  111. package/lib/typescript/commonjs/ui/components/fileManagement/FileDetailsModal.d.ts.map +1 -1
  112. package/lib/typescript/commonjs/ui/components/fileManagement/UploadPreview.d.ts +2 -3
  113. package/lib/typescript/commonjs/ui/components/fileManagement/UploadPreview.d.ts.map +1 -1
  114. package/lib/typescript/commonjs/ui/components/icon/OxyIcon.d.ts.map +1 -1
  115. package/lib/typescript/commonjs/ui/components/internal/GroupedPillButtons.d.ts.map +1 -1
  116. package/lib/typescript/commonjs/ui/components/internal/PinInput.d.ts.map +1 -1
  117. package/lib/typescript/commonjs/ui/components/modals/DeleteAccountModal.d.ts +2 -2
  118. package/lib/typescript/commonjs/ui/components/modals/DeleteAccountModal.d.ts.map +1 -1
  119. package/lib/typescript/commonjs/ui/context/OxyContext.d.ts +6 -0
  120. package/lib/typescript/commonjs/ui/context/OxyContext.d.ts.map +1 -1
  121. package/lib/typescript/commonjs/ui/navigation/routes.d.ts +1 -1
  122. package/lib/typescript/commonjs/ui/navigation/routes.d.ts.map +1 -1
  123. package/lib/typescript/commonjs/ui/screens/AccountCenterScreen.d.ts.map +1 -1
  124. package/lib/typescript/commonjs/ui/screens/AccountOverviewScreen.d.ts.map +1 -1
  125. package/lib/typescript/commonjs/ui/screens/AccountSettingsScreen.d.ts.map +1 -1
  126. package/lib/typescript/commonjs/ui/screens/AccountSwitcherScreen.d.ts.map +1 -1
  127. package/lib/typescript/commonjs/ui/screens/AccountVerificationScreen.d.ts.map +1 -1
  128. package/lib/typescript/commonjs/ui/screens/CreateManagedAccountScreen.d.ts +5 -0
  129. package/lib/typescript/commonjs/ui/screens/CreateManagedAccountScreen.d.ts.map +1 -0
  130. package/lib/typescript/commonjs/ui/screens/FileManagementScreen.d.ts.map +1 -1
  131. package/lib/typescript/commonjs/ui/screens/HistoryViewScreen.d.ts.map +1 -1
  132. package/lib/typescript/commonjs/ui/screens/PremiumSubscriptionScreen.d.ts.map +1 -1
  133. package/lib/typescript/commonjs/ui/screens/SessionManagementScreen.d.ts.map +1 -1
  134. package/lib/typescript/commonjs/ui/utils/fileManagement.d.ts +0 -4
  135. package/lib/typescript/commonjs/ui/utils/fileManagement.d.ts.map +1 -1
  136. package/lib/typescript/module/index.d.ts +1 -0
  137. package/lib/typescript/module/index.d.ts.map +1 -1
  138. package/lib/typescript/module/ui/components/ActingAsBanner.d.ts +4 -0
  139. package/lib/typescript/module/ui/components/ActingAsBanner.d.ts.map +1 -0
  140. package/lib/typescript/module/ui/components/OxyPayButton.d.ts.map +1 -1
  141. package/lib/typescript/module/ui/components/OxySignInButton.d.ts +0 -1
  142. package/lib/typescript/module/ui/components/OxySignInButton.d.ts.map +1 -1
  143. package/lib/typescript/module/ui/components/SettingRow.d.ts +2 -2
  144. package/lib/typescript/module/ui/components/SettingRow.d.ts.map +1 -1
  145. package/lib/typescript/module/ui/components/fileManagement/FileDetailsModal.d.ts +3 -4
  146. package/lib/typescript/module/ui/components/fileManagement/FileDetailsModal.d.ts.map +1 -1
  147. package/lib/typescript/module/ui/components/fileManagement/UploadPreview.d.ts +2 -3
  148. package/lib/typescript/module/ui/components/fileManagement/UploadPreview.d.ts.map +1 -1
  149. package/lib/typescript/module/ui/components/icon/OxyIcon.d.ts.map +1 -1
  150. package/lib/typescript/module/ui/components/internal/GroupedPillButtons.d.ts.map +1 -1
  151. package/lib/typescript/module/ui/components/internal/PinInput.d.ts.map +1 -1
  152. package/lib/typescript/module/ui/components/modals/DeleteAccountModal.d.ts +2 -2
  153. package/lib/typescript/module/ui/components/modals/DeleteAccountModal.d.ts.map +1 -1
  154. package/lib/typescript/module/ui/context/OxyContext.d.ts +6 -0
  155. package/lib/typescript/module/ui/context/OxyContext.d.ts.map +1 -1
  156. package/lib/typescript/module/ui/navigation/routes.d.ts +1 -1
  157. package/lib/typescript/module/ui/navigation/routes.d.ts.map +1 -1
  158. package/lib/typescript/module/ui/screens/AccountCenterScreen.d.ts.map +1 -1
  159. package/lib/typescript/module/ui/screens/AccountOverviewScreen.d.ts.map +1 -1
  160. package/lib/typescript/module/ui/screens/AccountSettingsScreen.d.ts.map +1 -1
  161. package/lib/typescript/module/ui/screens/AccountSwitcherScreen.d.ts.map +1 -1
  162. package/lib/typescript/module/ui/screens/AccountVerificationScreen.d.ts.map +1 -1
  163. package/lib/typescript/module/ui/screens/CreateManagedAccountScreen.d.ts +5 -0
  164. package/lib/typescript/module/ui/screens/CreateManagedAccountScreen.d.ts.map +1 -0
  165. package/lib/typescript/module/ui/screens/FileManagementScreen.d.ts.map +1 -1
  166. package/lib/typescript/module/ui/screens/HistoryViewScreen.d.ts.map +1 -1
  167. package/lib/typescript/module/ui/screens/PremiumSubscriptionScreen.d.ts.map +1 -1
  168. package/lib/typescript/module/ui/screens/SessionManagementScreen.d.ts.map +1 -1
  169. package/lib/typescript/module/ui/utils/fileManagement.d.ts +0 -4
  170. package/lib/typescript/module/ui/utils/fileManagement.d.ts.map +1 -1
  171. package/package.json +2 -2
  172. package/src/index.ts +3 -0
  173. package/src/ui/components/ActingAsBanner.tsx +135 -0
  174. package/src/ui/components/OxyPayButton.tsx +5 -3
  175. package/src/ui/components/OxySignInButton.tsx +82 -81
  176. package/src/ui/components/SettingRow.tsx +14 -7
  177. package/src/ui/components/fileManagement/FileDetailsModal.tsx +69 -99
  178. package/src/ui/components/fileManagement/UploadPreview.tsx +58 -46
  179. package/src/ui/components/icon/OxyIcon.tsx +5 -4
  180. package/src/ui/components/internal/GroupedPillButtons.tsx +15 -12
  181. package/src/ui/components/internal/PinInput.tsx +4 -3
  182. package/src/ui/components/modals/DeleteAccountModal.tsx +79 -221
  183. package/src/ui/constants/theme.ts +2 -2
  184. package/src/ui/context/OxyContext.tsx +85 -0
  185. package/src/ui/navigation/routes.ts +3 -1
  186. package/src/ui/screens/AccountCenterScreen.tsx +40 -122
  187. package/src/ui/screens/AccountOverviewScreen.tsx +63 -98
  188. package/src/ui/screens/AccountSettingsScreen.tsx +21 -7
  189. package/src/ui/screens/AccountSwitcherScreen.tsx +344 -87
  190. package/src/ui/screens/AccountVerificationScreen.tsx +24 -16
  191. package/src/ui/screens/CreateManagedAccountScreen.tsx +338 -0
  192. package/src/ui/screens/FileManagementScreen.tsx +62 -54
  193. package/src/ui/screens/HistoryViewScreen.tsx +57 -204
  194. package/src/ui/screens/PremiumSubscriptionScreen.tsx +73 -93
  195. package/src/ui/screens/SessionManagementScreen.tsx +101 -73
  196. package/src/ui/utils/fileManagement.ts +0 -30
  197. package/lib/commonjs/ui/utils/confirmAction.js +0 -28
  198. package/lib/commonjs/ui/utils/confirmAction.js.map +0 -1
  199. package/lib/module/ui/utils/confirmAction.js +0 -25
  200. package/lib/module/ui/utils/confirmAction.js.map +0 -1
  201. package/lib/typescript/commonjs/ui/utils/confirmAction.d.ts +0 -7
  202. package/lib/typescript/commonjs/ui/utils/confirmAction.d.ts.map +0 -1
  203. package/lib/typescript/module/ui/utils/confirmAction.d.ts +0 -7
  204. package/lib/typescript/module/ui/utils/confirmAction.d.ts.map +0 -1
  205. package/src/ui/utils/confirmAction.ts +0 -23
@@ -1,138 +1,108 @@
1
1
  import type React from 'react';
2
- import { View, Text, TouchableOpacity, Modal, ScrollView } from 'react-native';
2
+ import { View, Text } from 'react-native';
3
3
  import { Ionicons } from '@expo/vector-icons';
4
+ import * as Dialog from '@oxyhq/bloom/dialog';
5
+ import type { DialogControlProps } from '@oxyhq/bloom/dialog';
6
+ import * as Prompt from '@oxyhq/bloom/prompt';
4
7
  import { useTheme } from '@oxyhq/bloom/theme';
5
8
  import type { FileMetadata } from '@oxyhq/core';
6
9
  import { formatFileSize, getFileIcon } from '../../utils/fileManagement';
7
10
  import { fileManagementStyles } from './styles';
8
11
 
9
12
  interface FileDetailsModalProps {
10
- visible: boolean;
13
+ control: DialogControlProps;
11
14
  file: FileMetadata | null;
12
- onClose: () => void;
13
15
  onDownload: (fileId: string, filename: string) => void;
14
16
  onDelete: (fileId: string, filename: string) => void;
15
17
  isOwner: boolean;
16
- /** @deprecated No longer used. Colors are sourced from useTheme() internally. */
17
- themeStyles?: unknown;
18
+ onClose?: () => void;
18
19
  }
19
20
 
20
21
  export const FileDetailsModal: React.FC<FileDetailsModalProps> = ({
21
- visible,
22
+ control,
22
23
  file,
23
- onClose,
24
24
  onDownload,
25
25
  onDelete,
26
26
  isOwner,
27
+ onClose,
27
28
  }) => {
28
29
  const { colors } = useTheme();
29
30
 
30
31
  if (!file) return null;
31
32
 
32
33
  return (
33
- <Modal
34
- visible={visible}
35
- animationType="slide"
36
- presentationStyle="pageSheet"
37
- onRequestClose={onClose}
38
- >
39
- <View style={[fileManagementStyles.modalContainer, { backgroundColor: colors.background }]}>
40
- <View className="border-b border-border" style={fileManagementStyles.modalHeader}>
41
- <TouchableOpacity
42
- style={fileManagementStyles.modalCloseButton}
43
- onPress={onClose}
44
- >
45
- <Ionicons name="close" size={24} color={colors.text} />
46
- </TouchableOpacity>
47
- <Text className="text-foreground" style={fileManagementStyles.modalTitle}>File Details</Text>
48
- <View style={fileManagementStyles.modalPlaceholder} />
49
- </View>
34
+ <Dialog.Outer control={control} onClose={onClose}>
35
+ <Dialog.Handle />
36
+ <Dialog.ScrollableInner label="File Details">
37
+ <View className="bg-secondary border-border" style={fileManagementStyles.fileDetailCard}>
38
+ <View style={fileManagementStyles.fileDetailIcon}>
39
+ <Ionicons
40
+ name={getFileIcon(file.contentType) as React.ComponentProps<typeof Ionicons>['name']}
41
+ size={64}
42
+ color={colors.primary}
43
+ />
44
+ </View>
50
45
 
51
- <ScrollView style={fileManagementStyles.modalContent}>
52
- <View className="bg-secondary border-border" style={fileManagementStyles.fileDetailCard}>
53
- <View style={fileManagementStyles.fileDetailIcon}>
54
- <Ionicons
55
- name={getFileIcon(file.contentType) as React.ComponentProps<typeof Ionicons>['name']}
56
- size={64}
57
- color={colors.primary}
58
- />
59
- </View>
46
+ <Text className="text-foreground" style={fileManagementStyles.fileDetailName}>
47
+ {file.filename}
48
+ </Text>
60
49
 
61
- <Text className="text-foreground" style={fileManagementStyles.fileDetailName}>
62
- {file.filename}
63
- </Text>
50
+ <View style={fileManagementStyles.fileDetailInfo}>
51
+ <View style={fileManagementStyles.detailRow}>
52
+ <Text className="text-muted-foreground" style={fileManagementStyles.detailLabel}>
53
+ Size:
54
+ </Text>
55
+ <Text className="text-foreground" style={fileManagementStyles.detailValue}>
56
+ {formatFileSize(file.length)}
57
+ </Text>
58
+ </View>
64
59
 
65
- <View style={fileManagementStyles.fileDetailInfo}>
66
- <View style={fileManagementStyles.detailRow}>
67
- <Text className="text-muted-foreground" style={fileManagementStyles.detailLabel}>
68
- Size:
69
- </Text>
70
- <Text className="text-foreground" style={fileManagementStyles.detailValue}>
71
- {formatFileSize(file.length)}
72
- </Text>
73
- </View>
60
+ <View style={fileManagementStyles.detailRow}>
61
+ <Text className="text-muted-foreground" style={fileManagementStyles.detailLabel}>
62
+ Type:
63
+ </Text>
64
+ <Text className="text-foreground" style={fileManagementStyles.detailValue}>
65
+ {file.contentType}
66
+ </Text>
67
+ </View>
74
68
 
75
- <View style={fileManagementStyles.detailRow}>
76
- <Text className="text-muted-foreground" style={fileManagementStyles.detailLabel}>
77
- Type:
78
- </Text>
79
- <Text className="text-foreground" style={fileManagementStyles.detailValue}>
80
- {file.contentType}
81
- </Text>
82
- </View>
69
+ <View style={fileManagementStyles.detailRow}>
70
+ <Text className="text-muted-foreground" style={fileManagementStyles.detailLabel}>
71
+ Uploaded:
72
+ </Text>
73
+ <Text className="text-foreground" style={fileManagementStyles.detailValue}>
74
+ {new Date(file.uploadDate).toLocaleString()}
75
+ </Text>
76
+ </View>
83
77
 
78
+ {file.metadata?.description && (
84
79
  <View style={fileManagementStyles.detailRow}>
85
80
  <Text className="text-muted-foreground" style={fileManagementStyles.detailLabel}>
86
- Uploaded:
81
+ Description:
87
82
  </Text>
88
83
  <Text className="text-foreground" style={fileManagementStyles.detailValue}>
89
- {new Date(file.uploadDate).toLocaleString()}
84
+ {file.metadata.description}
90
85
  </Text>
91
86
  </View>
92
-
93
- {file.metadata?.description && (
94
- <View style={fileManagementStyles.detailRow}>
95
- <Text className="text-muted-foreground" style={fileManagementStyles.detailLabel}>
96
- Description:
97
- </Text>
98
- <Text className="text-foreground" style={fileManagementStyles.detailValue}>
99
- {file.metadata.description}
100
- </Text>
101
- </View>
102
- )}
103
- </View>
104
-
105
- <View style={fileManagementStyles.modalActions}>
106
- <TouchableOpacity
107
- className="bg-primary"
108
- style={fileManagementStyles.modalActionButton}
109
- onPress={() => {
110
- onDownload(file.id, file.filename);
111
- onClose();
112
- }}
113
- >
114
- <Ionicons name="download" size={20} color="#FFFFFF" />
115
- <Text style={fileManagementStyles.modalActionText}>Download</Text>
116
- </TouchableOpacity>
117
-
118
- {isOwner && (
119
- <TouchableOpacity
120
- className="bg-destructive"
121
- style={fileManagementStyles.modalActionButton}
122
- onPress={() => {
123
- onClose();
124
- onDelete(file.id, file.filename);
125
- }}
126
- >
127
- <Ionicons name="trash" size={20} color="#FFFFFF" />
128
- <Text style={fileManagementStyles.modalActionText}>Delete</Text>
129
- </TouchableOpacity>
130
- )}
131
- </View>
87
+ )}
132
88
  </View>
133
- </ScrollView>
134
- </View>
135
- </Modal>
89
+
90
+ <Prompt.Actions>
91
+ <Prompt.Action
92
+ onPress={() => onDownload(file.id, file.filename)}
93
+ cta="Download"
94
+ color="primary"
95
+ />
96
+ {isOwner && (
97
+ <Prompt.Action
98
+ onPress={() => onDelete(file.id, file.filename)}
99
+ cta="Delete"
100
+ color="negative"
101
+ />
102
+ )}
103
+ </Prompt.Actions>
104
+ </View>
105
+ </Dialog.ScrollableInner>
106
+ </Dialog.Outer>
136
107
  );
137
108
  };
138
-
@@ -1,7 +1,10 @@
1
1
  import type React from 'react';
2
- import { View, Text, TouchableOpacity, Modal, ScrollView } from 'react-native';
2
+ import { View, Text, TouchableOpacity, ScrollView } from 'react-native';
3
3
  import { Image as ExpoImage } from 'expo-image';
4
4
  import { Ionicons } from '@expo/vector-icons';
5
+ import * as Dialog from '@oxyhq/bloom/dialog';
6
+ import type { DialogControlProps } from '@oxyhq/bloom/dialog';
7
+ import * as Prompt from '@oxyhq/bloom/prompt';
5
8
  import { useTheme } from '@oxyhq/bloom/theme';
6
9
  import { formatFileSize, getFileIcon } from '../../utils/fileManagement';
7
10
  import { fileManagementStyles } from './styles';
@@ -15,14 +18,12 @@ interface PendingFile {
15
18
  }
16
19
 
17
20
  interface UploadPreviewProps {
18
- visible: boolean;
21
+ control?: DialogControlProps;
19
22
  pendingFiles: PendingFile[];
20
23
  onConfirm: () => void;
21
24
  onCancel: () => void;
22
25
  onRemoveFile: (index: number) => void;
23
- inline?: boolean; // New prop to support inline rendering without Modal
24
- /** @deprecated No longer used. Colors are sourced from useTheme() internally. */
25
- themeStyles?: unknown;
26
+ inline?: boolean;
26
27
  }
27
28
 
28
29
  const UploadPreviewContent: React.FC<{
@@ -30,11 +31,13 @@ const UploadPreviewContent: React.FC<{
30
31
  onConfirm: () => void;
31
32
  onCancel: () => void;
32
33
  onRemoveFile: (index: number) => void;
34
+ showActions?: boolean;
33
35
  }> = ({
34
36
  pendingFiles,
35
37
  onConfirm,
36
38
  onCancel,
37
39
  onRemoveFile,
40
+ showActions = true,
38
41
  }) => {
39
42
  const { colors, isDark } = useTheme();
40
43
  const totalSize = pendingFiles.reduce((sum, f) => sum + f.size, 0);
@@ -66,7 +69,7 @@ const UploadPreviewContent: React.FC<{
66
69
  contentFit="cover"
67
70
  />
68
71
  ) : (
69
- <View style={[fileManagementStyles.uploadPreviewIconContainer, { backgroundColor: isDark ? '#333333' : '#F0F0F0' }]}>
72
+ <View style={[fileManagementStyles.uploadPreviewIconContainer, { backgroundColor: colors.backgroundSecondary }]}>
70
73
  <Ionicons
71
74
  name={getFileIcon(pendingFile.type) as React.ComponentProps<typeof Ionicons>['name']}
72
75
  size={32}
@@ -102,44 +105,45 @@ const UploadPreviewContent: React.FC<{
102
105
  {formatFileSize(totalSize)}
103
106
  </Text>
104
107
  </View>
105
- <View style={fileManagementStyles.uploadPreviewActions}>
106
- <TouchableOpacity
107
- className="border-border"
108
- style={[
109
- fileManagementStyles.uploadPreviewCancelButton,
110
- { backgroundColor: 'transparent' }
111
- ]}
112
- onPress={onCancel}
113
- >
114
- <Text className="text-foreground" style={fileManagementStyles.uploadPreviewCancelText}>
115
- Cancel
116
- </Text>
117
- </TouchableOpacity>
118
- <TouchableOpacity
119
- className="bg-primary"
120
- style={fileManagementStyles.uploadPreviewConfirmButton}
121
- onPress={onConfirm}
122
- >
123
- <Ionicons name="cloud-upload" size={20} color="#FFFFFF" />
124
- <Text style={fileManagementStyles.uploadPreviewConfirmText}>Upload</Text>
125
- </TouchableOpacity>
126
- </View>
108
+ {showActions && (
109
+ <View style={fileManagementStyles.uploadPreviewActions}>
110
+ <TouchableOpacity
111
+ className="border-border"
112
+ style={[
113
+ fileManagementStyles.uploadPreviewCancelButton,
114
+ { backgroundColor: 'transparent' }
115
+ ]}
116
+ onPress={onCancel}
117
+ >
118
+ <Text className="text-foreground" style={fileManagementStyles.uploadPreviewCancelText}>
119
+ Cancel
120
+ </Text>
121
+ </TouchableOpacity>
122
+ <TouchableOpacity
123
+ className="bg-primary"
124
+ style={fileManagementStyles.uploadPreviewConfirmButton}
125
+ onPress={onConfirm}
126
+ >
127
+ <Ionicons name="cloud-upload" size={20} color="#FFFFFF" />
128
+ <Text style={fileManagementStyles.uploadPreviewConfirmText}>Upload</Text>
129
+ </TouchableOpacity>
130
+ </View>
131
+ )}
127
132
  </View>
128
133
  </View>
129
134
  );
130
135
  };
131
136
 
132
137
  export const UploadPreview: React.FC<UploadPreviewProps> = ({
133
- visible,
138
+ control,
134
139
  pendingFiles,
135
140
  onConfirm,
136
141
  onCancel,
137
142
  onRemoveFile,
138
143
  inline = false,
139
144
  }) => {
140
- // If inline mode, render content directly without Modal
145
+ // Inline mode: render content directly without Dialog
141
146
  if (inline) {
142
- if (!visible) return null;
143
147
  return (
144
148
  <UploadPreviewContent
145
149
  pendingFiles={pendingFiles}
@@ -150,21 +154,29 @@ export const UploadPreview: React.FC<UploadPreviewProps> = ({
150
154
  );
151
155
  }
152
156
 
153
- // Default: render with Modal (for backward compatibility)
157
+ // Dialog mode: requires control prop
158
+ if (!control) return null;
159
+
154
160
  return (
155
- <Modal
156
- visible={visible}
157
- animationType="slide"
158
- presentationStyle="pageSheet"
159
- onRequestClose={onCancel}
160
- >
161
- <UploadPreviewContent
162
- pendingFiles={pendingFiles}
163
- onConfirm={onConfirm}
164
- onCancel={onCancel}
165
- onRemoveFile={onRemoveFile}
166
- />
167
- </Modal>
161
+ <Dialog.Outer control={control} onClose={onCancel}>
162
+ <Dialog.Handle />
163
+ <Dialog.ScrollableInner label="Review Files">
164
+ <UploadPreviewContent
165
+ pendingFiles={pendingFiles}
166
+ onConfirm={onConfirm}
167
+ onCancel={onCancel}
168
+ onRemoveFile={onRemoveFile}
169
+ showActions={false}
170
+ />
171
+ <Prompt.Actions>
172
+ <Prompt.Action
173
+ onPress={onConfirm}
174
+ cta="Upload"
175
+ color="primary"
176
+ />
177
+ <Prompt.Cancel cta="Cancel" />
178
+ </Prompt.Actions>
179
+ </Dialog.ScrollableInner>
180
+ </Dialog.Outer>
168
181
  );
169
182
  };
170
-
@@ -1,6 +1,6 @@
1
1
  import type React from 'react';
2
- import { Platform, type StyleProp, type TextStyle } from 'react-native';
3
2
  import { Ionicons } from '@expo/vector-icons';
3
+ import { useTheme } from '@oxyhq/bloom/theme';
4
4
 
5
5
  export interface IconProps {
6
6
  name: string;
@@ -12,16 +12,17 @@ export interface IconProps {
12
12
  const OxyIcon: React.FC<IconProps> = ({
13
13
  name,
14
14
  size = 24,
15
- color = '#000',
15
+ color,
16
16
  style
17
17
  }) => {
18
- // Icon name is already properly typed as IoniconsGlyphs
18
+ const theme = useTheme();
19
+ const resolvedColor = color ?? theme.colors.icon;
19
20
 
20
21
  return (
21
22
  <Ionicons
22
23
  name={name as React.ComponentProps<typeof Ionicons>['name']}
23
24
  size={size}
24
- color={color}
25
+ color={resolvedColor}
25
26
  style={style}
26
27
  />
27
28
  );
@@ -1,6 +1,7 @@
1
1
  import type React from 'react';
2
2
  import { View, TouchableOpacity, Text, ActivityIndicator, StyleSheet, Platform } from 'react-native';
3
3
  import { Ionicons } from '@expo/vector-icons';
4
+ import { useTheme } from '@oxyhq/bloom/theme';
4
5
 
5
6
  type IoniconsName = React.ComponentProps<typeof Ionicons>['name'];
6
7
 
@@ -32,6 +33,8 @@ const GroupedPillButtons: React.FC<GroupedPillButtonsProps> = ({
32
33
  colors,
33
34
  gap = 8,
34
35
  }) => {
36
+ const theme = useTheme();
37
+
35
38
  const getButtonStyle = (button: ButtonConfig, index: number, totalButtons: number) => {
36
39
  const baseStyle = {
37
40
  flexDirection: 'row' as const,
@@ -87,16 +90,16 @@ const GroupedPillButtons: React.FC<GroupedPillButtonsProps> = ({
87
90
 
88
91
  switch (button.variant) {
89
92
  case 'primary':
90
- backgroundColor = isDisabled ? '#CCCCCC' : colors.primary;
91
- borderColor = isDisabled ? '#CCCCCC' : colors.primary;
93
+ backgroundColor = isDisabled ? theme.colors.borderLight : colors.primary;
94
+ borderColor = isDisabled ? theme.colors.borderLight : colors.primary;
92
95
  break;
93
96
  case 'secondary':
94
- backgroundColor = isDisabled ? '#CCCCCC' : (colors.secondary || colors.primary);
95
- borderColor = isDisabled ? '#CCCCCC' : (colors.secondary || colors.primary);
97
+ backgroundColor = isDisabled ? theme.colors.borderLight : (colors.secondary || colors.primary);
98
+ borderColor = isDisabled ? theme.colors.borderLight : (colors.secondary || colors.primary);
96
99
  break;
97
100
  default:
98
101
  backgroundColor = 'transparent';
99
- borderColor = isDisabled ? '#CCCCCC' : colors.border;
102
+ borderColor = isDisabled ? theme.colors.borderLight : colors.border;
100
103
  break;
101
104
  }
102
105
 
@@ -119,14 +122,14 @@ const GroupedPillButtons: React.FC<GroupedPillButtonsProps> = ({
119
122
 
120
123
  const isDisabled = button.disabled || button.loading;
121
124
  let textColor = colors.text;
122
-
125
+
123
126
  switch (button.variant) {
124
127
  case 'primary':
125
128
  case 'secondary':
126
- textColor = isDisabled ? '#999999' : '#FFFFFF';
129
+ textColor = isDisabled ? theme.colors.textTertiary : '#FFFFFF';
127
130
  break;
128
131
  default:
129
- textColor = isDisabled ? '#999999' : colors.text;
132
+ textColor = isDisabled ? theme.colors.textTertiary : colors.text;
130
133
  break;
131
134
  }
132
135
 
@@ -139,13 +142,13 @@ const GroupedPillButtons: React.FC<GroupedPillButtonsProps> = ({
139
142
 
140
143
  const getIconColor = (button: ButtonConfig, colors: GroupedPillButtonColors) => {
141
144
  const isDisabled = button.disabled || button.loading;
142
-
145
+
143
146
  switch (button.variant) {
144
147
  case 'primary':
145
148
  case 'secondary':
146
- return isDisabled ? '#999999' : '#FFFFFF';
149
+ return isDisabled ? theme.colors.textTertiary : '#FFFFFF';
147
150
  default:
148
- return isDisabled ? '#999999' : colors.text;
151
+ return isDisabled ? theme.colors.textTertiary : colors.text;
149
152
  }
150
153
  };
151
154
 
@@ -247,4 +250,4 @@ const styles = StyleSheet.create({
247
250
  },
248
251
  });
249
252
 
250
- export default GroupedPillButtons;
253
+ export default GroupedPillButtons;
@@ -1,5 +1,6 @@
1
1
  import React, { useRef, forwardRef, useImperativeHandle } from 'react';
2
2
  import { View, TextInput, StyleSheet, Platform, type NativeSyntheticEvent, type TextInputKeyPressEventData } from 'react-native';
3
+ import { useTheme } from '@oxyhq/bloom/theme';
3
4
 
4
5
  interface PinInputColors {
5
6
  primary: string;
@@ -24,6 +25,7 @@ export interface PinInputHandle {
24
25
  }
25
26
 
26
27
  const PinInput = forwardRef<PinInputHandle, PinInputProps>(({ value, onChange, length = 6, disabled, autoFocus, colors }, ref) => {
28
+ const theme = useTheme();
27
29
  const inputs = useRef<Array<TextInput | null>>([]);
28
30
 
29
31
  useImperativeHandle(ref, () => ({
@@ -66,7 +68,7 @@ const PinInput = forwardRef<PinInputHandle, PinInputProps>(({ value, onChange, l
66
68
  ref={(ref) => { inputs.current[idx] = ref; }}
67
69
  style={[
68
70
  styles.pinInput,
69
- { borderColor: colors.primary, color: colors.text, backgroundColor: colors.inputBackground },
71
+ { borderColor: colors.primary, color: colors.text, backgroundColor: colors.inputBackground || theme.colors.backgroundSecondary },
70
72
  value[idx] ? { borderWidth: 2 } : { borderWidth: 1 },
71
73
  ]}
72
74
  value={value[idx] || ''}
@@ -100,7 +102,6 @@ const styles = StyleSheet.create({
100
102
  borderWidth: 1,
101
103
  fontSize: 28,
102
104
  fontWeight: '600',
103
- backgroundColor: '#F5F5F5',
104
105
  textAlign: 'center',
105
106
  marginHorizontal: 2,
106
107
  ...Platform.select({
@@ -118,4 +119,4 @@ const styles = StyleSheet.create({
118
119
  },
119
120
  });
120
121
 
121
- export default PinInput;
122
+ export default PinInput;