@jobber/components-native 0.76.0 → 0.76.1-JOB-116234-d279b0f.20

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 (330) hide show
  1. package/dist/package.json +2 -2
  2. package/dist/src/ActionItem/ActionItem.js +2 -1
  3. package/dist/src/ActionItem/ActionItem.style.js +23 -22
  4. package/dist/src/ActionItem/ActionItemGroup.js +2 -1
  5. package/dist/src/ActionItem/components/ActionItemContainer.js +4 -2
  6. package/dist/src/ActionItem/components/ActionItemContainer.style.js +12 -11
  7. package/dist/src/ActivityIndicator/ActivityIndicator.js +2 -1
  8. package/dist/src/AtlantisThemeContext/AtlantisThemeContext.js +43 -0
  9. package/dist/src/AtlantisThemeContext/buildThemedStyles.js +38 -0
  10. package/dist/src/AtlantisThemeContext/index.js +2 -0
  11. package/dist/src/AtlantisThemeContext/types.js +1 -0
  12. package/dist/src/AutoLink/AutoLink.js +2 -1
  13. package/dist/src/Banner/Banner.js +4 -3
  14. package/dist/src/Banner/Banner.style.js +34 -33
  15. package/dist/src/Banner/components/BannerIcon/BannerIcon.js +2 -1
  16. package/dist/src/Banner/components/BannerIcon/BannerIcon.style.js +17 -16
  17. package/dist/src/BottomSheet/BottomSheet.js +8 -7
  18. package/dist/src/BottomSheet/BottomSheet.style.js +28 -25
  19. package/dist/src/BottomSheet/components/BottomSheetOption/BottomSheetOption.js +2 -1
  20. package/dist/src/BottomSheet/components/BottomSheetOption/BottomSheetOption.styles.js +18 -17
  21. package/dist/src/Button/Button.js +6 -4
  22. package/dist/src/Button/Button.style.js +97 -95
  23. package/dist/src/ButtonGroup/ButtonGroup.js +2 -1
  24. package/dist/src/ButtonGroup/ButtonGroup.style.js +18 -17
  25. package/dist/src/Card/Card.js +4 -3
  26. package/dist/src/Card/Card.style.js +31 -30
  27. package/dist/src/Card/components/InternalCardHeader.js +2 -1
  28. package/dist/src/Card/components/InternalCardHeader.style.js +16 -15
  29. package/dist/src/Checkbox/Checkbox.js +4 -2
  30. package/dist/src/Checkbox/Checkbox.style.js +31 -29
  31. package/dist/src/Checkbox/CheckboxGroup.js +2 -1
  32. package/dist/src/Checkbox/CheckboxGroup.style.js +14 -13
  33. package/dist/src/Chip/Chip.js +5 -3
  34. package/dist/src/Chip/Chip.style.js +33 -31
  35. package/dist/src/Content/Content.js +7 -4
  36. package/dist/src/Content/ContentHorizontal.style.js +30 -29
  37. package/dist/src/Content/ContentSpaceAround.style.js +22 -21
  38. package/dist/src/Content/ContentVertical.style.js +30 -29
  39. package/dist/src/ContentOverlay/ContentOverlay.js +4 -2
  40. package/dist/src/ContentOverlay/ContentOverlay.style.js +56 -54
  41. package/dist/src/Disclosure/Disclosure.js +10 -7
  42. package/dist/src/Disclosure/Disclosure.style.js +21 -20
  43. package/dist/src/Divider/Divider.js +4 -2
  44. package/dist/src/Divider/DividerHorizontal.style.js +23 -22
  45. package/dist/src/Divider/DividerVertical.style.js +26 -25
  46. package/dist/src/EmptyState/EmptyState.js +2 -1
  47. package/dist/src/EmptyState/EmptyState.style.js +8 -7
  48. package/dist/src/ErrorMessageWrapper/ErrorMessageWrapper.js +6 -5
  49. package/dist/src/ErrorMessageWrapper/ErrorMessageWrapper.style.js +31 -30
  50. package/dist/src/Flex/Flex.gap.styles.js +9 -0
  51. package/dist/src/Flex/Flex.js +3 -2
  52. package/dist/src/Flex/Flex.styles.js +0 -9
  53. package/dist/src/Form/Form.js +2 -1
  54. package/dist/src/Form/Form.style.js +33 -32
  55. package/dist/src/Form/components/FormActionBar/FormActionBar.js +2 -1
  56. package/dist/src/Form/components/FormActionBar/FormActionBar.style.js +5 -4
  57. package/dist/src/Form/components/FormBody/FormBody.js +2 -1
  58. package/dist/src/Form/components/FormBody/FormBody.style.js +26 -25
  59. package/dist/src/Form/components/FormMask/FormMask.js +2 -1
  60. package/dist/src/Form/components/FormMask/FormMask.style.js +15 -14
  61. package/dist/src/Form/components/FormMessage/components/InternalFormMessage/InternalFormMessage.js +2 -1
  62. package/dist/src/Form/components/FormMessage/components/InternalFormMessage/InternalFormMessage.style.js +17 -16
  63. package/dist/src/FormatFile/FormatFile.js +2 -1
  64. package/dist/src/FormatFile/FormatFile.style.js +16 -15
  65. package/dist/src/FormatFile/components/ErrorIcon/ErrorIcon.js +2 -1
  66. package/dist/src/FormatFile/components/ErrorIcon/ErrorIcon.style.js +10 -9
  67. package/dist/src/FormatFile/components/FileView/FileView.js +2 -1
  68. package/dist/src/FormatFile/components/FileView/FileView.style.js +64 -63
  69. package/dist/src/FormatFile/components/MediaView/MediaView.js +8 -7
  70. package/dist/src/FormatFile/components/MediaView/MediaView.style.js +27 -26
  71. package/dist/src/FormatFile/components/ProgressBar/ProgressBar.js +2 -1
  72. package/dist/src/FormatFile/components/ProgressBar/ProgressBar.style.js +15 -14
  73. package/dist/src/Glimmer/Glimmer.js +6 -3
  74. package/dist/src/Glimmer/Glimmer.shape.style.js +16 -15
  75. package/dist/src/Glimmer/Glimmer.size.style.js +9 -8
  76. package/dist/src/Glimmer/Glimmer.style.js +21 -19
  77. package/dist/src/IconButton/IconButton.js +2 -1
  78. package/dist/src/IconButton/IconButton.style.js +10 -9
  79. package/dist/src/InputFieldWrapper/CommonInputStyles.style.js +13 -3
  80. package/dist/src/InputFieldWrapper/InputFieldWrapper.js +4 -2
  81. package/dist/src/InputFieldWrapper/InputFieldWrapper.style.js +122 -117
  82. package/dist/src/InputFieldWrapper/components/ClearAction/ClearAction.js +2 -1
  83. package/dist/src/InputFieldWrapper/components/ClearAction/ClearAction.style.js +25 -24
  84. package/dist/src/InputFieldWrapper/components/Prefix/Prefix.js +7 -3
  85. package/dist/src/InputFieldWrapper/components/Suffix/Suffix.js +5 -2
  86. package/dist/src/InputFieldWrapper/index.js +1 -1
  87. package/dist/src/InputPressable/InputPressable.js +4 -2
  88. package/dist/src/InputPressable/InputPressable.style.js +22 -21
  89. package/dist/src/InputText/InputText.js +4 -2
  90. package/dist/src/InputText/InputText.style.js +22 -21
  91. package/dist/src/InputText/context/InputAccessoriesProvider.js +2 -1
  92. package/dist/src/InputText/context/InputAccessoriesProvider.style.js +21 -19
  93. package/dist/src/Menu/Menu.js +6 -4
  94. package/dist/src/Menu/Menu.style.js +5 -4
  95. package/dist/src/Menu/components/MenuOption/MenuOption.js +4 -2
  96. package/dist/src/Menu/components/MenuOption/MenuOption.style.js +10 -9
  97. package/dist/src/Menu/components/Overlay/Overlay.js +2 -1
  98. package/dist/src/Menu/components/Overlay/Overlay.style.js +15 -4
  99. package/dist/src/Menu/utils.js +1 -2
  100. package/dist/src/ProgressBar/ProgressBar.js +4 -2
  101. package/dist/src/ProgressBar/ProgressBar.style.js +36 -35
  102. package/dist/src/ProgressBar/ProgressBarInner.js +2 -1
  103. package/dist/src/ProgressBar/ProgressBarStepped.js +7 -2
  104. package/dist/src/Select/Select.js +2 -1
  105. package/dist/src/Select/Select.style.js +43 -43
  106. package/dist/src/Select/components/SelectDefaultPicker/SelectDefaultPicker.ios.js +2 -1
  107. package/dist/src/Select/components/SelectDefaultPicker/SelectDefaultPicker.js +4 -2
  108. package/dist/src/Select/components/SelectDefaultPicker/SelectDefaultPicker.style.js +32 -28
  109. package/dist/src/Select/components/SelectPressable/SelectPressable.js +2 -1
  110. package/dist/src/Select/components/SelectPressable/SelectPressable.style.js +7 -6
  111. package/dist/src/StatusLabel/StatusLabel.js +6 -4
  112. package/dist/src/StatusLabel/StatusLabel.style.js +28 -28
  113. package/dist/src/Switch/Switch.js +2 -1
  114. package/dist/src/Switch/Switch.styles.js +20 -19
  115. package/dist/src/Switch/components/BaseSwitch/BaseSwitch.js +2 -1
  116. package/dist/src/TextList/TextList.js +2 -1
  117. package/dist/src/TextList/TextList.style.js +16 -15
  118. package/dist/src/ThumbnailList/ThumbnailList.js +2 -1
  119. package/dist/src/ThumbnailList/ThumbnailList.style.js +49 -48
  120. package/dist/src/Toast/Toast.js +9 -6
  121. package/dist/src/Toast/Toast.styles.js +30 -29
  122. package/dist/src/Typography/Typography.js +2 -1
  123. package/dist/src/Typography/Typography.style.js +14 -12
  124. package/dist/src/Typography/index.js +1 -0
  125. package/dist/src/index.js +1 -0
  126. package/dist/src/utils/design/index.js +2 -0
  127. package/dist/tsconfig.tsbuildinfo +1 -1
  128. package/dist/types/src/ActionItem/ActionItem.style.d.ts +1 -1
  129. package/dist/types/src/ActionItem/components/ActionItemContainer.style.d.ts +1 -1
  130. package/dist/types/src/AtlantisThemeContext/AtlantisThemeContext.d.ts +3 -0
  131. package/dist/types/src/AtlantisThemeContext/buildThemedStyles.d.ts +32 -0
  132. package/dist/types/src/AtlantisThemeContext/index.d.ts +3 -0
  133. package/dist/types/src/AtlantisThemeContext/types.d.ts +24 -0
  134. package/dist/types/src/Banner/Banner.style.d.ts +1 -1
  135. package/dist/types/src/Banner/components/BannerIcon/BannerIcon.style.d.ts +1 -1
  136. package/dist/types/src/BottomSheet/BottomSheet.style.d.ts +1 -1
  137. package/dist/types/src/BottomSheet/components/BottomSheetOption/BottomSheetOption.styles.d.ts +1 -1
  138. package/dist/types/src/Button/Button.style.d.ts +1 -2
  139. package/dist/types/src/ButtonGroup/ButtonGroup.style.d.ts +1 -1
  140. package/dist/types/src/Card/Card.style.d.ts +1 -1
  141. package/dist/types/src/Card/components/InternalCardHeader.style.d.ts +1 -1
  142. package/dist/types/src/Checkbox/Checkbox.style.d.ts +1 -1
  143. package/dist/types/src/Checkbox/CheckboxGroup.style.d.ts +1 -1
  144. package/dist/types/src/Chip/Chip.style.d.ts +1 -1
  145. package/dist/types/src/Content/ContentHorizontal.style.d.ts +1 -1
  146. package/dist/types/src/Content/ContentSpaceAround.style.d.ts +1 -1
  147. package/dist/types/src/Content/ContentVertical.style.d.ts +1 -1
  148. package/dist/types/src/ContentOverlay/ContentOverlay.style.d.ts +1 -1
  149. package/dist/types/src/Disclosure/Disclosure.style.d.ts +1 -1
  150. package/dist/types/src/Divider/DividerHorizontal.style.d.ts +1 -1
  151. package/dist/types/src/Divider/DividerVertical.style.d.ts +1 -1
  152. package/dist/types/src/EmptyState/EmptyState.style.d.ts +1 -1
  153. package/dist/types/src/ErrorMessageWrapper/ErrorMessageWrapper.style.d.ts +1 -1
  154. package/dist/types/src/Flex/Flex.gap.styles.d.ts +2 -0
  155. package/dist/types/src/Flex/Flex.styles.d.ts +0 -1
  156. package/dist/types/src/Form/Form.style.d.ts +1 -1
  157. package/dist/types/src/Form/components/FormActionBar/FormActionBar.style.d.ts +1 -1
  158. package/dist/types/src/Form/components/FormBody/FormBody.style.d.ts +1 -1
  159. package/dist/types/src/Form/components/FormMask/FormMask.style.d.ts +1 -1
  160. package/dist/types/src/Form/components/FormMessage/components/InternalFormMessage/InternalFormMessage.style.d.ts +1 -1
  161. package/dist/types/src/FormatFile/FormatFile.style.d.ts +1 -1
  162. package/dist/types/src/FormatFile/components/ErrorIcon/ErrorIcon.style.d.ts +1 -1
  163. package/dist/types/src/FormatFile/components/FileView/FileView.style.d.ts +1 -1
  164. package/dist/types/src/FormatFile/components/MediaView/MediaView.style.d.ts +1 -1
  165. package/dist/types/src/FormatFile/components/ProgressBar/ProgressBar.style.d.ts +1 -1
  166. package/dist/types/src/Glimmer/Glimmer.d.ts +4 -4
  167. package/dist/types/src/Glimmer/Glimmer.shape.style.d.ts +1 -1
  168. package/dist/types/src/Glimmer/Glimmer.size.style.d.ts +1 -1
  169. package/dist/types/src/Glimmer/Glimmer.style.d.ts +1 -1
  170. package/dist/types/src/IconButton/IconButton.style.d.ts +1 -1
  171. package/dist/types/src/InputFieldWrapper/CommonInputStyles.style.d.ts +9 -32
  172. package/dist/types/src/InputFieldWrapper/InputFieldWrapper.style.d.ts +2 -16
  173. package/dist/types/src/InputFieldWrapper/components/ClearAction/ClearAction.style.d.ts +1 -1
  174. package/dist/types/src/InputFieldWrapper/index.d.ts +1 -1
  175. package/dist/types/src/InputPressable/InputPressable.style.d.ts +1 -1
  176. package/dist/types/src/InputText/InputText.style.d.ts +1 -1
  177. package/dist/types/src/InputText/context/InputAccessoriesProvider.style.d.ts +1 -1
  178. package/dist/types/src/Menu/Menu.style.d.ts +1 -1
  179. package/dist/types/src/Menu/components/MenuOption/MenuOption.style.d.ts +1 -1
  180. package/dist/types/src/Menu/components/Overlay/Overlay.style.d.ts +6 -6
  181. package/dist/types/src/Menu/utils.d.ts +2 -1
  182. package/dist/types/src/ProgressBar/ProgressBar.style.d.ts +1 -1
  183. package/dist/types/src/Select/Select.style.d.ts +2 -30
  184. package/dist/types/src/Select/components/SelectDefaultPicker/SelectDefaultPicker.style.d.ts +1 -1
  185. package/dist/types/src/Select/components/SelectPressable/SelectPressable.style.d.ts +1 -1
  186. package/dist/types/src/StatusLabel/StatusLabel.style.d.ts +1 -1
  187. package/dist/types/src/Switch/Switch.styles.d.ts +1 -1
  188. package/dist/types/src/TextList/TextList.style.d.ts +1 -1
  189. package/dist/types/src/ThumbnailList/ThumbnailList.style.d.ts +1 -1
  190. package/dist/types/src/Toast/Toast.styles.d.ts +1 -1
  191. package/dist/types/src/Typography/Typography.style.d.ts +5 -2
  192. package/dist/types/src/Typography/index.d.ts +1 -0
  193. package/dist/types/src/index.d.ts +1 -0
  194. package/package.json +2 -2
  195. package/src/ActionItem/ActionItem.style.ts +23 -22
  196. package/src/ActionItem/ActionItem.tsx +3 -1
  197. package/src/ActionItem/ActionItemGroup.tsx +3 -1
  198. package/src/ActionItem/components/ActionItemContainer.style.ts +12 -11
  199. package/src/ActionItem/components/ActionItemContainer.tsx +5 -2
  200. package/src/ActivityIndicator/ActivityIndicator.tsx +3 -1
  201. package/src/AtlantisThemeContext/AtlantisThemeContext.tsx +98 -0
  202. package/src/AtlantisThemeContext/buildThemedStyles.ts +43 -0
  203. package/src/AtlantisThemeContext/index.ts +10 -0
  204. package/src/AtlantisThemeContext/types.ts +29 -0
  205. package/src/AutoLink/AutoLink.tsx +2 -1
  206. package/src/Banner/Banner.style.ts +34 -33
  207. package/src/Banner/Banner.tsx +6 -2
  208. package/src/Banner/components/BannerIcon/BannerIcon.style.ts +17 -16
  209. package/src/Banner/components/BannerIcon/BannerIcon.tsx +3 -1
  210. package/src/BottomSheet/BottomSheet.style.ts +32 -29
  211. package/src/BottomSheet/BottomSheet.tsx +21 -5
  212. package/src/BottomSheet/components/BottomSheetOption/BottomSheetOption.styles.ts +18 -17
  213. package/src/BottomSheet/components/BottomSheetOption/BottomSheetOption.tsx +2 -1
  214. package/src/Button/Button.style.ts +119 -120
  215. package/src/Button/Button.tsx +7 -3
  216. package/src/ButtonGroup/ButtonGroup.style.ts +18 -17
  217. package/src/ButtonGroup/ButtonGroup.tsx +2 -1
  218. package/src/Card/Card.style.ts +46 -45
  219. package/src/Card/Card.tsx +8 -3
  220. package/src/Card/components/InternalCardHeader.style.ts +16 -15
  221. package/src/Card/components/InternalCardHeader.tsx +3 -1
  222. package/src/Checkbox/Checkbox.style.ts +32 -29
  223. package/src/Checkbox/Checkbox.tsx +6 -2
  224. package/src/Checkbox/CheckboxGroup.style.ts +14 -13
  225. package/src/Checkbox/CheckboxGroup.tsx +3 -1
  226. package/src/Chip/Chip.style.ts +33 -31
  227. package/src/Chip/Chip.tsx +6 -4
  228. package/src/Content/Content.test.tsx +14 -4
  229. package/src/Content/Content.tsx +8 -4
  230. package/src/Content/ContentHorizontal.style.ts +38 -37
  231. package/src/Content/ContentSpaceAround.style.ts +22 -21
  232. package/src/Content/ContentVertical.style.ts +38 -37
  233. package/src/ContentOverlay/ContentOverlay.style.ts +58 -56
  234. package/src/ContentOverlay/ContentOverlay.tsx +5 -2
  235. package/src/Disclosure/Disclosure.style.ts +21 -20
  236. package/src/Disclosure/Disclosure.tsx +18 -7
  237. package/src/Divider/Divider.test.tsx +11 -3
  238. package/src/Divider/Divider.tsx +5 -2
  239. package/src/Divider/DividerHorizontal.style.ts +23 -22
  240. package/src/Divider/DividerVertical.style.ts +26 -25
  241. package/src/EmptyState/EmptyState.style.ts +8 -7
  242. package/src/EmptyState/EmptyState.tsx +3 -1
  243. package/src/ErrorMessageWrapper/ErrorMessageWrapper.style.ts +31 -30
  244. package/src/ErrorMessageWrapper/ErrorMessageWrapper.tsx +7 -6
  245. package/src/Flex/Flex.gap.styles.tsx +14 -0
  246. package/src/Flex/Flex.styles.tsx +1 -13
  247. package/src/Flex/Flex.tsx +3 -2
  248. package/src/Form/Form.style.ts +33 -32
  249. package/src/Form/Form.tsx +3 -1
  250. package/src/Form/components/FormActionBar/FormActionBar.style.ts +10 -9
  251. package/src/Form/components/FormActionBar/FormActionBar.tsx +3 -1
  252. package/src/Form/components/FormBody/FormBody.style.ts +26 -25
  253. package/src/Form/components/FormBody/FormBody.tsx +2 -1
  254. package/src/Form/components/FormMask/FormMask.style.tsx +15 -14
  255. package/src/Form/components/FormMask/FormMask.tsx +2 -1
  256. package/src/Form/components/FormMessage/components/InternalFormMessage/InternalFormMessage.style.ts +17 -16
  257. package/src/Form/components/FormMessage/components/InternalFormMessage/InternalFormMessage.tsx +2 -1
  258. package/src/FormatFile/FormatFile.style.ts +16 -15
  259. package/src/FormatFile/FormatFile.tsx +3 -1
  260. package/src/FormatFile/components/ErrorIcon/ErrorIcon.style.ts +10 -9
  261. package/src/FormatFile/components/ErrorIcon/ErrorIcon.tsx +3 -1
  262. package/src/FormatFile/components/FileView/FileView.style.ts +64 -63
  263. package/src/FormatFile/components/FileView/FileView.tsx +3 -1
  264. package/src/FormatFile/components/MediaView/MediaView.style.ts +27 -26
  265. package/src/FormatFile/components/MediaView/MediaView.tsx +15 -3
  266. package/src/FormatFile/components/ProgressBar/ProgressBar.style.tsx +15 -14
  267. package/src/FormatFile/components/ProgressBar/ProgressBar.tsx +3 -1
  268. package/src/Glimmer/Glimmer.shape.style.ts +16 -15
  269. package/src/Glimmer/Glimmer.size.style.ts +9 -8
  270. package/src/Glimmer/Glimmer.style.ts +21 -19
  271. package/src/Glimmer/Glimmer.tsx +9 -5
  272. package/src/IconButton/IconButton.style.ts +10 -9
  273. package/src/IconButton/IconButton.tsx +3 -1
  274. package/src/InputFieldWrapper/CommonInputStyles.style.ts +31 -5
  275. package/src/InputFieldWrapper/InputFieldWrapper.style.ts +144 -139
  276. package/src/InputFieldWrapper/InputFieldWrapper.test.tsx +24 -5
  277. package/src/InputFieldWrapper/InputFieldWrapper.tsx +5 -2
  278. package/src/InputFieldWrapper/components/ClearAction/ClearAction.style.ts +25 -24
  279. package/src/InputFieldWrapper/components/ClearAction/ClearAction.tsx +2 -1
  280. package/src/InputFieldWrapper/components/Prefix/Prefix.test.tsx +21 -3
  281. package/src/InputFieldWrapper/components/Prefix/Prefix.tsx +9 -3
  282. package/src/InputFieldWrapper/components/Suffix/Suffix.tsx +7 -2
  283. package/src/InputFieldWrapper/index.ts +1 -1
  284. package/src/InputPressable/InputPressable.style.ts +23 -22
  285. package/src/InputPressable/InputPressable.tsx +5 -2
  286. package/src/InputText/InputText.style.ts +24 -23
  287. package/src/InputText/InputText.test.tsx +11 -1
  288. package/src/InputText/InputText.tsx +5 -2
  289. package/src/InputText/context/InputAccessoriesProvider.style.tsx +21 -19
  290. package/src/InputText/context/InputAccessoriesProvider.tsx +3 -1
  291. package/src/Menu/Menu.style.ts +13 -12
  292. package/src/Menu/Menu.test.tsx +1 -1
  293. package/src/Menu/Menu.tsx +9 -4
  294. package/src/Menu/components/MenuOption/MenuOption.style.tsx +10 -9
  295. package/src/Menu/components/MenuOption/MenuOption.tsx +4 -2
  296. package/src/Menu/components/Overlay/Overlay.style.ts +15 -9
  297. package/src/Menu/components/Overlay/Overlay.tsx +3 -1
  298. package/src/Menu/utils.ts +2 -1
  299. package/src/ProgressBar/ProgressBar.style.ts +36 -35
  300. package/src/ProgressBar/ProgressBar.test.tsx +6 -20
  301. package/src/ProgressBar/ProgressBar.tsx +4 -2
  302. package/src/ProgressBar/ProgressBarInner.tsx +2 -1
  303. package/src/ProgressBar/ProgressBarStepped.tsx +10 -2
  304. package/src/Select/Select.style.ts +44 -43
  305. package/src/Select/Select.tsx +2 -1
  306. package/src/Select/components/SelectDefaultPicker/SelectDefaultPicker.ios.tsx +2 -1
  307. package/src/Select/components/SelectDefaultPicker/SelectDefaultPicker.style.ts +32 -28
  308. package/src/Select/components/SelectDefaultPicker/SelectDefaultPicker.tsx +4 -2
  309. package/src/Select/components/SelectPressable/SelectPressable.style.ts +7 -6
  310. package/src/Select/components/SelectPressable/SelectPressable.tsx +2 -2
  311. package/src/StatusLabel/StatusLabel.style.ts +29 -29
  312. package/src/StatusLabel/StatusLabel.tsx +9 -4
  313. package/src/Switch/Switch.styles.ts +20 -19
  314. package/src/Switch/Switch.tsx +2 -1
  315. package/src/Switch/components/BaseSwitch/BaseSwitch.tsx +3 -1
  316. package/src/Text/Text.test.tsx +1 -1
  317. package/src/TextList/TextList.style.ts +16 -15
  318. package/src/TextList/TextList.tsx +3 -1
  319. package/src/ThumbnailList/ThumbnailList.style.ts +49 -48
  320. package/src/ThumbnailList/ThumbnailList.tsx +2 -1
  321. package/src/Toast/Toast.styles.ts +30 -29
  322. package/src/Toast/Toast.tsx +10 -6
  323. package/src/Typography/Typography.style.ts +24 -14
  324. package/src/Typography/Typography.tsx +3 -1
  325. package/src/Typography/index.ts +1 -0
  326. package/src/index.ts +1 -0
  327. package/src/utils/design/index.ts +2 -0
  328. package/dist/src/InputText/context/InputAccessory.style.js +0 -16
  329. package/dist/types/src/InputText/context/InputAccessory.style.d.ts +0 -14
  330. package/src/InputText/context/InputAccessory.style.ts +0 -17
@@ -1,4 +1,5 @@
1
1
  export { Typography } from "./Typography";
2
2
  export type { FontFamily, FontStyle, FontWeight, BaseWeight, DisplayWeight, BaseStyle, DisplayStyle, TextColor, TextTransform, TextSize, TextAlign, LineHeight, LetterSpacing, TextAccessibilityRole, TextVariation, TypographyProps, TruncateLength, } from "./Typography";
3
+ export { useTypographyStyles } from "./Typography.style";
3
4
  export { typographyStyles } from "./Typography.style";
4
5
  export { TypographyGestureDetector } from "./TypographyGestureDetector";
@@ -2,6 +2,7 @@ export * from "./ActionItem";
2
2
  export * from "./ActionLabel";
3
3
  export * from "./ActivityIndicator";
4
4
  export * from "./AtlantisContext";
5
+ export * from "./AtlantisThemeContext";
5
6
  export * from "./AutoLink";
6
7
  export * from "./Banner";
7
8
  export * from "./BottomSheet";
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@jobber/components-native",
3
- "version": "0.76.0",
3
+ "version": "0.76.1-JOB-116234-d279b0f.20+d279b0fd",
4
4
  "license": "MIT",
5
5
  "description": "React Native implementation of Atlantis",
6
6
  "repository": {
@@ -80,5 +80,5 @@
80
80
  "react-native-safe-area-context": "^4.5.2",
81
81
  "react-native-svg": ">=12.0.0"
82
82
  },
83
- "gitHead": "3dbb361d102c6ae833d1dce373125b7bf68508c0"
83
+ "gitHead": "d279b0fddc435572c48dff35f02db80ee4ca3ee7"
84
84
  }
@@ -1,29 +1,30 @@
1
- import { StyleSheet } from "react-native";
2
- import { tokens } from "../utils/design";
1
+ import { buildThemedStyles } from "../AtlantisThemeContext";
3
2
 
4
- export const styles = StyleSheet.create({
5
- actionItemHorizontalOffset: {
6
- paddingHorizontal: tokens["space-base"],
7
- },
3
+ export const useStyles = buildThemedStyles(tokens => {
4
+ return {
5
+ actionItemHorizontalOffset: {
6
+ paddingHorizontal: tokens["space-base"],
7
+ },
8
8
 
9
- icon: {
10
- justifyContent: "flex-start",
11
- paddingRight: tokens["space-small"],
12
- },
9
+ icon: {
10
+ justifyContent: "flex-start",
11
+ paddingRight: tokens["space-small"],
12
+ },
13
13
 
14
- titlePadding: {
15
- paddingBottom: tokens["space-smaller"],
16
- },
14
+ titlePadding: {
15
+ paddingBottom: tokens["space-smaller"],
16
+ },
17
17
 
18
- content: {
19
- flex: 1,
20
- },
18
+ content: {
19
+ flex: 1,
20
+ },
21
21
 
22
- offsetForIcons: {
23
- paddingTop: tokens["space-smallest"],
24
- },
22
+ offsetForIcons: {
23
+ paddingTop: tokens["space-smallest"],
24
+ },
25
25
 
26
- actionIcon: {
27
- paddingLeft: tokens["space-small"],
28
- },
26
+ actionIcon: {
27
+ paddingLeft: tokens["space-small"],
28
+ },
29
+ };
29
30
  });
@@ -1,7 +1,7 @@
1
1
  import React, { ReactNode } from "react";
2
2
  import { View } from "react-native";
3
3
  import { IconColorNames, IconNames } from "@jobber/design";
4
- import { styles } from "./ActionItem.style";
4
+ import { useStyles } from "./ActionItem.style";
5
5
  import { ActionItemContainer } from "./components/ActionItemContainer";
6
6
  import { Typography } from "../Typography";
7
7
  import { Icon } from "../Icon";
@@ -65,6 +65,8 @@ export function ActionItem({
65
65
  justifyContent: actionIconAlignment,
66
66
  };
67
67
 
68
+ const styles = useStyles();
69
+
68
70
  const addIconOffset = icon || onPress ? styles.offsetForIcons : undefined;
69
71
  const titlePadding = children ? styles.titlePadding : undefined;
70
72
 
@@ -1,7 +1,7 @@
1
1
  import React, { ReactElement } from "react";
2
2
  import { View } from "react-native";
3
3
  import { ActionItem, ActionItemProps } from "./ActionItem";
4
- import { styles } from "./ActionItem.style";
4
+ import { useStyles } from "./ActionItem.style";
5
5
  import { Divider } from "../Divider";
6
6
 
7
7
  export type ActionItemElement =
@@ -30,6 +30,8 @@ function renderChildren(children: ActionItemElement | ActionItemElement[]) {
30
30
  return childArray.map((child, index) => {
31
31
  const isSubsequentChild = index !== 0;
32
32
 
33
+ const styles = useStyles();
34
+
33
35
  return (
34
36
  <View key={index}>
35
37
  {isSubsequentChild && (
@@ -1,14 +1,15 @@
1
- import { StyleSheet } from "react-native";
2
- import { tokens } from "../../utils/design";
1
+ import { buildThemedStyles } from "../../AtlantisThemeContext";
3
2
 
4
- export const styles = StyleSheet.create({
5
- container: {
6
- width: "100%",
7
- flexDirection: "row",
8
- paddingVertical: tokens["space-base"],
9
- },
3
+ export const useStyles = buildThemedStyles(tokens => {
4
+ return {
5
+ container: {
6
+ width: "100%",
7
+ flexDirection: "row",
8
+ paddingVertical: tokens["space-base"],
9
+ },
10
10
 
11
- pressed: {
12
- opacity: tokens["opacity-pressed"],
13
- },
11
+ pressed: {
12
+ opacity: tokens["opacity-pressed"],
13
+ },
14
+ };
14
15
  });
@@ -1,7 +1,7 @@
1
1
  import React, { ReactNode } from "react";
2
2
  import { Pressable, View } from "react-native";
3
- import { styles } from "./ActionItemContainer.style";
4
- import { styles as actionItemStyles } from "../ActionItem.style";
3
+ import { useStyles } from "./ActionItemContainer.style";
4
+ import { useStyles as useActionItemStyles } from "../ActionItem.style";
5
5
 
6
6
  interface ActionItemContainerProps {
7
7
  readonly children: ReactNode;
@@ -16,6 +16,9 @@ export function ActionItemContainer({
16
16
  children,
17
17
  testID,
18
18
  }: ActionItemContainerProps): JSX.Element {
19
+ const styles = useStyles();
20
+ const actionItemStyles = useActionItemStyles();
21
+
19
22
  if (onPress) {
20
23
  return (
21
24
  <Pressable
@@ -1,10 +1,12 @@
1
1
  import React from "react";
2
2
  import { ActivityIndicator, ActivityIndicatorProps } from "react-native";
3
- import { tokens } from "../utils/design";
3
+ import { useAtlantisTheme } from "../AtlantisThemeContext";
4
4
 
5
5
  export function JobberActivityIndicator(
6
6
  props: ActivityIndicatorProps,
7
7
  ): JSX.Element {
8
+ const { tokens } = useAtlantisTheme();
9
+
8
10
  return (
9
11
  <ActivityIndicator
10
12
  {...props}
@@ -0,0 +1,98 @@
1
+ import { androidTokens, darkTokens, iosTokens } from "@jobber/design";
2
+ import React, {
3
+ PropsWithChildren,
4
+ createContext,
5
+ useContext,
6
+ useState,
7
+ } from "react";
8
+ import merge from "lodash/merge";
9
+ import { Platform } from "react-native";
10
+ import {
11
+ AtlantisThemeContextProviderProps,
12
+ AtlantisThemeContextValue,
13
+ Theme,
14
+ } from "./types";
15
+
16
+ const lightTokens = Platform.select({
17
+ ios: () => iosTokens,
18
+ android: () => androidTokens,
19
+ default: () => androidTokens,
20
+ })();
21
+
22
+ const completeDarkTokens = merge({}, lightTokens, darkTokens);
23
+
24
+ const AtlantisThemeContext = createContext<AtlantisThemeContextValue>({
25
+ theme: "light",
26
+ tokens: lightTokens,
27
+ });
28
+
29
+ export function AtlantisThemeContextProvider({
30
+ children,
31
+ dangerouslyOverrideTheme,
32
+ }: AtlantisThemeContextProviderProps) {
33
+ if (dangerouslyOverrideTheme) {
34
+ return (
35
+ <InternalStaticThemeProvider
36
+ dangerouslyOverrideTheme={dangerouslyOverrideTheme}
37
+ >
38
+ {children}
39
+ </InternalStaticThemeProvider>
40
+ );
41
+ }
42
+
43
+ return (
44
+ <InternalDynamicThemeProvider>{children}</InternalDynamicThemeProvider>
45
+ );
46
+ }
47
+
48
+ function InternalDynamicThemeProvider({ children }: PropsWithChildren) {
49
+ // TODO: check initial theme from local/device storage?
50
+ // const initialTheme: Theme = (globalThis.document.documentElement.dataset.theme as Theme) ?? "light";
51
+ const initialTheme: Theme = "light";
52
+
53
+ const [internalTheme] = useState<Theme>(initialTheme);
54
+ const currentTokens =
55
+ internalTheme === "dark" ? completeDarkTokens : lightTokens;
56
+
57
+ // TODO: listen for global theme update -> setInternalTheme
58
+ // See web's AtlantisThemeContext for an example of how it does this.
59
+
60
+ return (
61
+ <AtlantisThemeContext.Provider
62
+ value={{
63
+ theme: internalTheme,
64
+ tokens: currentTokens,
65
+ }}
66
+ >
67
+ {children}
68
+ </AtlantisThemeContext.Provider>
69
+ );
70
+ }
71
+
72
+ function InternalStaticThemeProvider({
73
+ dangerouslyOverrideTheme,
74
+ children,
75
+ }: Required<
76
+ Pick<
77
+ AtlantisThemeContextProviderProps,
78
+ "dangerouslyOverrideTheme" | "children"
79
+ >
80
+ >) {
81
+ const currentTokens =
82
+ dangerouslyOverrideTheme === "dark" ? completeDarkTokens : lightTokens;
83
+
84
+ return (
85
+ <AtlantisThemeContext.Provider
86
+ value={{
87
+ theme: dangerouslyOverrideTheme,
88
+ tokens: currentTokens,
89
+ }}
90
+ >
91
+ {children}
92
+ </AtlantisThemeContext.Provider>
93
+ );
94
+ }
95
+
96
+ export function useAtlantisTheme() {
97
+ return useContext(AtlantisThemeContext);
98
+ }
@@ -0,0 +1,43 @@
1
+ import { StyleSheet } from "react-native";
2
+ import { useMemo } from "react";
3
+ import { AtlantisThemeContextValue } from "./types";
4
+ import { useAtlantisTheme } from "./AtlantisThemeContext";
5
+
6
+ /**
7
+ * Creates a hook that generates themed styles using the current theme tokens.
8
+ * The hook will automatically update the styles when the theme changes.
9
+ *
10
+ * @example
11
+ * ```tsx
12
+ * const useStyles = buildThemedStyles(tokens => ({
13
+ * container: {
14
+ * backgroundColor: tokens["color-surface"],
15
+ * padding: tokens["space-base"],
16
+ * },
17
+ * }));
18
+ *
19
+ * function MyComponent() {
20
+ * const styles = useStyles();
21
+ * return <View style={styles.container} />;
22
+ * }
23
+ * ```
24
+ *
25
+ * @param styleFactory - A function that receives theme tokens and returns a style object
26
+ * @returns A hook function that returns the created styles
27
+ *
28
+ * @note
29
+ * - Styles are memoized and only recalculated when tokens change
30
+ * - Use this for components that need to respond to theme changes
31
+ * - The returned styles are created using StyleSheet.create()
32
+ *
33
+ * @see Related functions: {@link useAtlantisTheme}
34
+ */
35
+ export function buildThemedStyles<
36
+ T extends Parameters<typeof StyleSheet.create>[0],
37
+ >(styleFactory: (tokens: AtlantisThemeContextValue["tokens"]) => T) {
38
+ return function useStyles() {
39
+ const { tokens } = useAtlantisTheme();
40
+
41
+ return useMemo(() => StyleSheet.create(styleFactory(tokens)), [tokens]);
42
+ };
43
+ }
@@ -0,0 +1,10 @@
1
+ export {
2
+ AtlantisThemeContextProvider,
3
+ useAtlantisTheme,
4
+ } from "./AtlantisThemeContext";
5
+ export {
6
+ Theme,
7
+ AtlantisThemeContextProviderProps,
8
+ AtlantisThemeContextValue,
9
+ } from "./types";
10
+ export { buildThemedStyles } from "./buildThemedStyles";
@@ -0,0 +1,29 @@
1
+ import { iosTokens } from "@jobber/design";
2
+ import { PropsWithChildren } from "react";
3
+
4
+ export interface AtlantisThemeContextValue {
5
+ /**
6
+ * The theme of the application.
7
+ */
8
+ readonly theme: Theme;
9
+
10
+ /**
11
+ * The design tokens for the current theme.
12
+ */
13
+ readonly tokens: typeof iosTokens;
14
+ }
15
+
16
+ export interface AtlantisThemeContextProviderProps extends PropsWithChildren {
17
+ /**
18
+ * The children to render.
19
+ */
20
+ readonly children: React.ReactNode;
21
+
22
+ /**
23
+ * Force the theme for this provider to always be the same as the provided theme. Useful for sections that should remain the same theme regardless of the rest of the application's theme.
24
+ * This is dangerous because the children in this provider will not be able to change the theme.
25
+ */
26
+ readonly dangerouslyOverrideTheme?: Theme;
27
+ }
28
+
29
+ export type Theme = "light" | "dark";
@@ -4,7 +4,7 @@ import { AutoLinkProps } from "./types";
4
4
  import { ComposeTextWithLinks } from "./components";
5
5
  import { useCreateLinkedText } from "./hooks/useCreateLinkedText";
6
6
  import { TypographyGestureDetector } from "../Typography";
7
- import { tokens } from "../utils/design";
7
+ import { useAtlantisTheme } from "../AtlantisThemeContext";
8
8
 
9
9
  export function AutoLink({
10
10
  children: text = "",
@@ -13,6 +13,7 @@ export function AutoLink({
13
13
  ...rest
14
14
  }: AutoLinkProps): JSX.Element {
15
15
  const { splitText, matches } = useCreateLinkedText({ text, ...rest });
16
+ const { tokens } = useAtlantisTheme();
16
17
 
17
18
  return (
18
19
  <TypographyGestureDetector>
@@ -1,35 +1,36 @@
1
- import { StyleSheet } from "react-native";
2
- import { tokens } from "../utils/design";
1
+ import { buildThemedStyles } from "../AtlantisThemeContext";
3
2
 
4
- export const styles = StyleSheet.create({
5
- container: {
6
- width: "100%",
7
- borderColor: tokens["color-border"],
8
- borderStyle: "solid",
9
- borderBottomWidth: tokens["border-base"],
10
- backgroundColor: tokens["color-surface"],
11
- },
12
- bannerContent: {
13
- flexDirection: "row",
14
- alignItems: "flex-start",
15
- gap: tokens["space-small"] + tokens["space-smaller"],
16
- },
17
- contentContainer: {
18
- flex: 1,
19
- },
20
- childrenContainer: {
21
- marginTop: tokens["space-smallest"],
22
- },
23
- textContainer: {
24
- marginTop: tokens["space-minuscule"],
25
- },
26
- fullWidth: {
27
- width: "100%",
28
- },
29
- bannerChildrenContent: {
30
- marginBottom: tokens["space-small"],
31
- },
32
- contentSpacing: {
33
- gap: tokens["space-small"],
34
- },
3
+ export const useStyles = buildThemedStyles(tokens => {
4
+ return {
5
+ container: {
6
+ width: "100%",
7
+ borderColor: tokens["color-border"],
8
+ borderStyle: "solid",
9
+ borderBottomWidth: tokens["border-base"],
10
+ backgroundColor: tokens["color-surface"],
11
+ },
12
+ bannerContent: {
13
+ flexDirection: "row",
14
+ alignItems: "flex-start",
15
+ gap: tokens["space-small"] + tokens["space-smaller"],
16
+ },
17
+ contentContainer: {
18
+ flex: 1,
19
+ },
20
+ childrenContainer: {
21
+ marginTop: tokens["space-smallest"],
22
+ },
23
+ textContainer: {
24
+ marginTop: tokens["space-minuscule"],
25
+ },
26
+ fullWidth: {
27
+ width: "100%",
28
+ },
29
+ bannerChildrenContent: {
30
+ marginBottom: tokens["space-small"],
31
+ },
32
+ contentSpacing: {
33
+ gap: tokens["space-small"],
34
+ },
35
+ };
35
36
  });
@@ -2,7 +2,7 @@ import React, { PropsWithChildren, ReactElement } from "react";
2
2
  import { Pressable, Text as RNText, View } from "react-native";
3
3
  import { IconNames } from "@jobber/design";
4
4
  import { BannerProps, BannerTypes } from "./types";
5
- import { styles } from "./Banner.style";
5
+ import { useStyles } from "./Banner.style";
6
6
  import { BannerIcon } from "./components/BannerIcon/BannerIcon";
7
7
  import { Content } from "../Content";
8
8
  import { Text } from "../Text";
@@ -24,6 +24,8 @@ export function Banner({
24
24
  Boolean(React.Children.count(children) === 1 && !text && !details) ||
25
25
  Boolean(text && !details && !children);
26
26
 
27
+ const styles = useStyles();
28
+
27
29
  return (
28
30
  <Pressable
29
31
  style={[styles.container]}
@@ -35,7 +37,7 @@ export function Banner({
35
37
  {bannerIcon && <BannerIcon icon={bannerIcon} type={type} />}
36
38
  <View style={styles.contentContainer}>
37
39
  <View style={styles.childrenContainer}>
38
- <WrappingElement shouldFlow={shouldFlow}>
40
+ <WrappingElement shouldFlow={shouldFlow} styles={styles}>
39
41
  <BannerChildren>{children}</BannerChildren>
40
42
 
41
43
  {text && <Text level="text">{text}</Text>}
@@ -70,8 +72,10 @@ function BannerChildren({ children }: PropsWithChildren): JSX.Element {
70
72
  function WrappingElement({
71
73
  shouldFlow,
72
74
  children,
75
+ styles,
73
76
  }: PropsWithChildren<{
74
77
  readonly shouldFlow: boolean;
78
+ readonly styles: ReturnType<typeof useStyles>;
75
79
  }>): ReactElement {
76
80
  if (shouldFlow) {
77
81
  return <RNText testID="ATL-Banner-RNText">{children}</RNText>;
@@ -1,18 +1,19 @@
1
- import { StyleSheet } from "react-native";
2
- import { tokens } from "../../../utils/design";
1
+ import { buildThemedStyles } from "../../../AtlantisThemeContext";
3
2
 
4
- export const styles = StyleSheet.create({
5
- bannerIcon: {
6
- borderRadius: tokens["radius-circle"],
7
- padding: tokens["space-smaller"],
8
- },
9
- error: {
10
- backgroundColor: tokens["color-destructive"],
11
- },
12
- warning: {
13
- backgroundColor: tokens["color-warning"],
14
- },
15
- notice: {
16
- backgroundColor: tokens["color-informative"],
17
- },
3
+ export const useStyles = buildThemedStyles(tokens => {
4
+ return {
5
+ bannerIcon: {
6
+ borderRadius: tokens["radius-circle"],
7
+ padding: tokens["space-smaller"],
8
+ },
9
+ error: {
10
+ backgroundColor: tokens["color-destructive"],
11
+ },
12
+ warning: {
13
+ backgroundColor: tokens["color-warning"],
14
+ },
15
+ notice: {
16
+ backgroundColor: tokens["color-informative"],
17
+ },
18
+ };
18
19
  });
@@ -1,7 +1,7 @@
1
1
  import React from "react";
2
2
  import { IconNames } from "@jobber/design";
3
3
  import { View } from "react-native";
4
- import { styles } from "./BannerIcon.style";
4
+ import { useStyles } from "./BannerIcon.style";
5
5
  import { Icon } from "../../../Icon";
6
6
  import { BannerTypes } from "../../types";
7
7
 
@@ -11,6 +11,8 @@ export interface BannerIconProps {
11
11
  }
12
12
 
13
13
  export function BannerIcon({ icon, type }: BannerIconProps): JSX.Element {
14
+ const styles = useStyles();
15
+
14
16
  return (
15
17
  <View style={[styles.bannerIcon, styles[type]]} testID="ATL-Banner-Icon">
16
18
  <Icon name={icon} color="white" size="small" />
@@ -1,35 +1,38 @@
1
1
  import { Dimensions, StyleSheet } from "react-native";
2
- import { tokens } from "../utils/design";
2
+ import { tokens as staticTokens } from "../utils/design";
3
+ import { buildThemedStyles } from "../AtlantisThemeContext";
3
4
 
4
5
  const { height } = Dimensions.get("window");
5
- const modalBorderRadius = tokens["radius-larger"];
6
+ const modalBorderRadius = staticTokens["radius-larger"];
6
7
 
7
- export const styles = StyleSheet.create({
8
- overlayModalize: {
9
- backgroundColor: "transparent",
10
- },
8
+ export const useStyles = buildThemedStyles(tokens => {
9
+ return {
10
+ overlayModalize: {
11
+ backgroundColor: "transparent",
12
+ },
11
13
 
12
- overlay: {
13
- ...StyleSheet.absoluteFillObject,
14
- backgroundColor: tokens["color-overlay"],
15
- height,
16
- },
17
- modal: {
18
- borderTopLeftRadius: modalBorderRadius,
19
- borderTopRightRadius: modalBorderRadius,
20
- paddingTop: tokens["space-small"],
21
- },
22
- children: {
23
- paddingBottom: tokens["space-small"],
24
- },
25
- header: {
26
- paddingHorizontal: tokens["space-base"],
27
- paddingTop: tokens["space-small"],
28
- paddingBottom: tokens["space-base"],
29
- },
30
- footerDivider: {
31
- marginHorizontal: tokens["space-base"],
32
- marginTop: tokens["space-small"],
33
- marginBottom: tokens["space-smaller"],
34
- },
14
+ overlay: {
15
+ ...StyleSheet.absoluteFillObject,
16
+ backgroundColor: tokens["color-overlay"],
17
+ height,
18
+ },
19
+ modal: {
20
+ borderTopLeftRadius: modalBorderRadius,
21
+ borderTopRightRadius: modalBorderRadius,
22
+ paddingTop: tokens["space-small"],
23
+ },
24
+ children: {
25
+ paddingBottom: tokens["space-small"],
26
+ },
27
+ header: {
28
+ paddingHorizontal: tokens["space-base"],
29
+ paddingTop: tokens["space-small"],
30
+ paddingBottom: tokens["space-base"],
31
+ },
32
+ footerDivider: {
33
+ marginHorizontal: tokens["space-base"],
34
+ marginTop: tokens["space-small"],
35
+ marginBottom: tokens["space-smaller"],
36
+ },
37
+ };
35
38
  });