@jobber/components-native 0.76.0 → 0.76.1-JOB-116234-314c5ff.22

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 (338) 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 +32 -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 +15 -20
  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 +5 -0
  127. package/dist/src/utils/meta/meta.json +1 -0
  128. package/dist/tsconfig.tsbuildinfo +1 -1
  129. package/dist/types/src/ActionItem/ActionItem.style.d.ts +1 -1
  130. package/dist/types/src/ActionItem/components/ActionItemContainer.style.d.ts +1 -1
  131. package/dist/types/src/AtlantisThemeContext/AtlantisThemeContext.d.ts +3 -0
  132. package/dist/types/src/AtlantisThemeContext/buildThemedStyles.d.ts +32 -0
  133. package/dist/types/src/AtlantisThemeContext/index.d.ts +3 -0
  134. package/dist/types/src/AtlantisThemeContext/types.d.ts +27 -0
  135. package/dist/types/src/Banner/Banner.style.d.ts +1 -1
  136. package/dist/types/src/Banner/components/BannerIcon/BannerIcon.style.d.ts +1 -1
  137. package/dist/types/src/BottomSheet/BottomSheet.style.d.ts +1 -1
  138. package/dist/types/src/BottomSheet/components/BottomSheetOption/BottomSheetOption.styles.d.ts +1 -1
  139. package/dist/types/src/Button/Button.d.ts +1 -1
  140. package/dist/types/src/Button/Button.style.d.ts +1 -2
  141. package/dist/types/src/ButtonGroup/ButtonGroup.style.d.ts +1 -1
  142. package/dist/types/src/Card/Card.style.d.ts +1 -1
  143. package/dist/types/src/Card/components/InternalCardHeader.style.d.ts +1 -1
  144. package/dist/types/src/Checkbox/Checkbox.style.d.ts +1 -1
  145. package/dist/types/src/Checkbox/CheckboxGroup.style.d.ts +1 -1
  146. package/dist/types/src/Chip/Chip.style.d.ts +1 -1
  147. package/dist/types/src/Content/ContentHorizontal.style.d.ts +1 -1
  148. package/dist/types/src/Content/ContentSpaceAround.style.d.ts +1 -1
  149. package/dist/types/src/Content/ContentVertical.style.d.ts +1 -1
  150. package/dist/types/src/ContentOverlay/ContentOverlay.style.d.ts +1 -1
  151. package/dist/types/src/Disclosure/Disclosure.style.d.ts +1 -1
  152. package/dist/types/src/Divider/DividerHorizontal.style.d.ts +1 -1
  153. package/dist/types/src/Divider/DividerVertical.style.d.ts +1 -1
  154. package/dist/types/src/EmptyState/EmptyState.style.d.ts +1 -1
  155. package/dist/types/src/ErrorMessageWrapper/ErrorMessageWrapper.style.d.ts +1 -1
  156. package/dist/types/src/Flex/Flex.gap.styles.d.ts +2 -0
  157. package/dist/types/src/Flex/Flex.styles.d.ts +0 -1
  158. package/dist/types/src/Form/Form.style.d.ts +1 -1
  159. package/dist/types/src/Form/components/FormActionBar/FormActionBar.style.d.ts +1 -1
  160. package/dist/types/src/Form/components/FormBody/FormBody.style.d.ts +1 -1
  161. package/dist/types/src/Form/components/FormMask/FormMask.style.d.ts +1 -1
  162. package/dist/types/src/Form/components/FormMessage/components/InternalFormMessage/InternalFormMessage.style.d.ts +1 -1
  163. package/dist/types/src/FormatFile/FormatFile.style.d.ts +1 -1
  164. package/dist/types/src/FormatFile/components/ErrorIcon/ErrorIcon.style.d.ts +1 -1
  165. package/dist/types/src/FormatFile/components/FileView/FileView.style.d.ts +1 -1
  166. package/dist/types/src/FormatFile/components/MediaView/MediaView.style.d.ts +1 -1
  167. package/dist/types/src/FormatFile/components/ProgressBar/ProgressBar.style.d.ts +1 -1
  168. package/dist/types/src/Glimmer/Glimmer.d.ts +4 -4
  169. package/dist/types/src/Glimmer/Glimmer.shape.style.d.ts +1 -1
  170. package/dist/types/src/Glimmer/Glimmer.size.style.d.ts +1 -1
  171. package/dist/types/src/Glimmer/Glimmer.style.d.ts +1 -1
  172. package/dist/types/src/IconButton/IconButton.style.d.ts +1 -1
  173. package/dist/types/src/InputFieldWrapper/CommonInputStyles.style.d.ts +9 -32
  174. package/dist/types/src/InputFieldWrapper/InputFieldWrapper.style.d.ts +2 -16
  175. package/dist/types/src/InputFieldWrapper/components/ClearAction/ClearAction.style.d.ts +1 -1
  176. package/dist/types/src/InputFieldWrapper/index.d.ts +1 -1
  177. package/dist/types/src/InputPressable/InputPressable.style.d.ts +1 -1
  178. package/dist/types/src/InputText/InputText.style.d.ts +1 -1
  179. package/dist/types/src/InputText/context/InputAccessoriesProvider.style.d.ts +1 -1
  180. package/dist/types/src/Menu/Menu.style.d.ts +1 -1
  181. package/dist/types/src/Menu/components/MenuOption/MenuOption.style.d.ts +1 -1
  182. package/dist/types/src/Menu/components/Overlay/Overlay.style.d.ts +6 -6
  183. package/dist/types/src/Menu/utils.d.ts +2 -1
  184. package/dist/types/src/ProgressBar/ProgressBar.style.d.ts +1 -1
  185. package/dist/types/src/Select/Select.style.d.ts +2 -30
  186. package/dist/types/src/Select/components/SelectDefaultPicker/SelectDefaultPicker.style.d.ts +1 -1
  187. package/dist/types/src/Select/components/SelectPressable/SelectPressable.style.d.ts +1 -1
  188. package/dist/types/src/StatusLabel/StatusLabel.style.d.ts +1 -1
  189. package/dist/types/src/Switch/Switch.styles.d.ts +1 -1
  190. package/dist/types/src/Text/Text.d.ts +1 -1
  191. package/dist/types/src/TextList/TextList.style.d.ts +1 -1
  192. package/dist/types/src/ThumbnailList/ThumbnailList.style.d.ts +1 -1
  193. package/dist/types/src/Toast/Toast.styles.d.ts +1 -1
  194. package/dist/types/src/Typography/Typography.style.d.ts +6 -10
  195. package/dist/types/src/Typography/index.d.ts +1 -0
  196. package/dist/types/src/index.d.ts +1 -0
  197. package/dist/types/src/utils/design/index.d.ts +5 -0
  198. package/package.json +2 -2
  199. package/src/ActionItem/ActionItem.style.ts +23 -22
  200. package/src/ActionItem/ActionItem.tsx +3 -1
  201. package/src/ActionItem/ActionItemGroup.tsx +3 -1
  202. package/src/ActionItem/components/ActionItemContainer.style.ts +12 -11
  203. package/src/ActionItem/components/ActionItemContainer.tsx +5 -2
  204. package/src/ActivityIndicator/ActivityIndicator.tsx +3 -1
  205. package/src/AtlantisThemeContext/AtlantisThemeContext.test.tsx +106 -0
  206. package/src/AtlantisThemeContext/AtlantisThemeContext.tsx +56 -0
  207. package/src/AtlantisThemeContext/buildThemedStyles.test.tsx +83 -0
  208. package/src/AtlantisThemeContext/buildThemedStyles.ts +43 -0
  209. package/src/AtlantisThemeContext/index.ts +10 -0
  210. package/src/AtlantisThemeContext/types.ts +33 -0
  211. package/src/AutoLink/AutoLink.tsx +2 -1
  212. package/src/Banner/Banner.style.ts +34 -33
  213. package/src/Banner/Banner.tsx +6 -2
  214. package/src/Banner/components/BannerIcon/BannerIcon.style.ts +17 -16
  215. package/src/Banner/components/BannerIcon/BannerIcon.tsx +3 -1
  216. package/src/BottomSheet/BottomSheet.style.ts +32 -29
  217. package/src/BottomSheet/BottomSheet.tsx +21 -5
  218. package/src/BottomSheet/components/BottomSheetOption/BottomSheetOption.styles.ts +18 -17
  219. package/src/BottomSheet/components/BottomSheetOption/BottomSheetOption.tsx +2 -1
  220. package/src/Button/Button.style.ts +119 -120
  221. package/src/Button/Button.tsx +8 -4
  222. package/src/ButtonGroup/ButtonGroup.style.ts +18 -17
  223. package/src/ButtonGroup/ButtonGroup.tsx +2 -1
  224. package/src/Card/Card.style.ts +46 -45
  225. package/src/Card/Card.tsx +8 -3
  226. package/src/Card/components/InternalCardHeader.style.ts +16 -15
  227. package/src/Card/components/InternalCardHeader.tsx +3 -1
  228. package/src/Checkbox/Checkbox.style.ts +32 -29
  229. package/src/Checkbox/Checkbox.tsx +6 -2
  230. package/src/Checkbox/CheckboxGroup.style.ts +14 -13
  231. package/src/Checkbox/CheckboxGroup.tsx +3 -1
  232. package/src/Chip/Chip.style.ts +33 -31
  233. package/src/Chip/Chip.tsx +6 -4
  234. package/src/Content/Content.test.tsx +14 -4
  235. package/src/Content/Content.tsx +8 -4
  236. package/src/Content/ContentHorizontal.style.ts +38 -37
  237. package/src/Content/ContentSpaceAround.style.ts +22 -21
  238. package/src/Content/ContentVertical.style.ts +38 -37
  239. package/src/ContentOverlay/ContentOverlay.style.ts +58 -56
  240. package/src/ContentOverlay/ContentOverlay.tsx +5 -2
  241. package/src/Disclosure/Disclosure.style.ts +21 -20
  242. package/src/Disclosure/Disclosure.tsx +18 -7
  243. package/src/Divider/Divider.test.tsx +11 -3
  244. package/src/Divider/Divider.tsx +5 -2
  245. package/src/Divider/DividerHorizontal.style.ts +23 -22
  246. package/src/Divider/DividerVertical.style.ts +26 -25
  247. package/src/EmptyState/EmptyState.style.ts +8 -7
  248. package/src/EmptyState/EmptyState.tsx +3 -1
  249. package/src/ErrorMessageWrapper/ErrorMessageWrapper.style.ts +31 -30
  250. package/src/ErrorMessageWrapper/ErrorMessageWrapper.tsx +7 -6
  251. package/src/Flex/Flex.gap.styles.tsx +14 -0
  252. package/src/Flex/Flex.styles.tsx +1 -13
  253. package/src/Flex/Flex.tsx +3 -2
  254. package/src/Form/Form.style.ts +33 -32
  255. package/src/Form/Form.tsx +3 -1
  256. package/src/Form/components/FormActionBar/FormActionBar.style.ts +10 -9
  257. package/src/Form/components/FormActionBar/FormActionBar.tsx +3 -1
  258. package/src/Form/components/FormBody/FormBody.style.ts +26 -25
  259. package/src/Form/components/FormBody/FormBody.tsx +2 -1
  260. package/src/Form/components/FormMask/FormMask.style.tsx +15 -14
  261. package/src/Form/components/FormMask/FormMask.tsx +2 -1
  262. package/src/Form/components/FormMessage/components/InternalFormMessage/InternalFormMessage.style.ts +17 -16
  263. package/src/Form/components/FormMessage/components/InternalFormMessage/InternalFormMessage.tsx +2 -1
  264. package/src/FormatFile/FormatFile.style.ts +16 -15
  265. package/src/FormatFile/FormatFile.tsx +3 -1
  266. package/src/FormatFile/components/ErrorIcon/ErrorIcon.style.ts +10 -9
  267. package/src/FormatFile/components/ErrorIcon/ErrorIcon.tsx +3 -1
  268. package/src/FormatFile/components/FileView/FileView.style.ts +64 -63
  269. package/src/FormatFile/components/FileView/FileView.tsx +3 -1
  270. package/src/FormatFile/components/MediaView/MediaView.style.ts +27 -26
  271. package/src/FormatFile/components/MediaView/MediaView.tsx +15 -3
  272. package/src/FormatFile/components/ProgressBar/ProgressBar.style.tsx +15 -14
  273. package/src/FormatFile/components/ProgressBar/ProgressBar.tsx +3 -1
  274. package/src/Glimmer/Glimmer.shape.style.ts +16 -15
  275. package/src/Glimmer/Glimmer.size.style.ts +9 -8
  276. package/src/Glimmer/Glimmer.style.ts +21 -19
  277. package/src/Glimmer/Glimmer.tsx +9 -5
  278. package/src/IconButton/IconButton.style.ts +10 -9
  279. package/src/IconButton/IconButton.tsx +3 -1
  280. package/src/InputFieldWrapper/CommonInputStyles.style.ts +31 -5
  281. package/src/InputFieldWrapper/InputFieldWrapper.style.ts +144 -139
  282. package/src/InputFieldWrapper/InputFieldWrapper.test.tsx +24 -5
  283. package/src/InputFieldWrapper/InputFieldWrapper.tsx +5 -2
  284. package/src/InputFieldWrapper/components/ClearAction/ClearAction.style.ts +25 -24
  285. package/src/InputFieldWrapper/components/ClearAction/ClearAction.tsx +2 -1
  286. package/src/InputFieldWrapper/components/Prefix/Prefix.test.tsx +21 -3
  287. package/src/InputFieldWrapper/components/Prefix/Prefix.tsx +9 -3
  288. package/src/InputFieldWrapper/components/Suffix/Suffix.tsx +7 -2
  289. package/src/InputFieldWrapper/index.ts +1 -1
  290. package/src/InputPressable/InputPressable.style.ts +23 -22
  291. package/src/InputPressable/InputPressable.tsx +5 -2
  292. package/src/InputText/InputText.style.ts +24 -23
  293. package/src/InputText/InputText.test.tsx +11 -1
  294. package/src/InputText/InputText.tsx +5 -2
  295. package/src/InputText/context/InputAccessoriesProvider.style.tsx +21 -19
  296. package/src/InputText/context/InputAccessoriesProvider.tsx +3 -1
  297. package/src/Menu/Menu.style.ts +13 -12
  298. package/src/Menu/Menu.test.tsx +1 -1
  299. package/src/Menu/Menu.tsx +9 -4
  300. package/src/Menu/components/MenuOption/MenuOption.style.tsx +10 -9
  301. package/src/Menu/components/MenuOption/MenuOption.tsx +4 -2
  302. package/src/Menu/components/Overlay/Overlay.style.ts +15 -9
  303. package/src/Menu/components/Overlay/Overlay.tsx +3 -1
  304. package/src/Menu/utils.ts +2 -1
  305. package/src/ProgressBar/ProgressBar.style.ts +36 -35
  306. package/src/ProgressBar/ProgressBar.test.tsx +6 -20
  307. package/src/ProgressBar/ProgressBar.tsx +4 -2
  308. package/src/ProgressBar/ProgressBarInner.tsx +2 -1
  309. package/src/ProgressBar/ProgressBarStepped.tsx +10 -2
  310. package/src/Select/Select.style.ts +44 -43
  311. package/src/Select/Select.tsx +2 -1
  312. package/src/Select/components/SelectDefaultPicker/SelectDefaultPicker.ios.tsx +2 -1
  313. package/src/Select/components/SelectDefaultPicker/SelectDefaultPicker.style.ts +32 -28
  314. package/src/Select/components/SelectDefaultPicker/SelectDefaultPicker.tsx +4 -2
  315. package/src/Select/components/SelectPressable/SelectPressable.style.ts +7 -6
  316. package/src/Select/components/SelectPressable/SelectPressable.tsx +2 -2
  317. package/src/StatusLabel/StatusLabel.style.ts +29 -29
  318. package/src/StatusLabel/StatusLabel.tsx +9 -4
  319. package/src/Switch/Switch.styles.ts +20 -19
  320. package/src/Switch/Switch.tsx +2 -1
  321. package/src/Switch/components/BaseSwitch/BaseSwitch.tsx +3 -1
  322. package/src/Text/Text.test.tsx +1 -1
  323. package/src/Text/Text.tsx +1 -1
  324. package/src/TextList/TextList.style.ts +16 -15
  325. package/src/TextList/TextList.tsx +3 -1
  326. package/src/ThumbnailList/ThumbnailList.style.ts +49 -48
  327. package/src/ThumbnailList/ThumbnailList.tsx +2 -1
  328. package/src/Toast/Toast.styles.ts +30 -29
  329. package/src/Toast/Toast.tsx +10 -6
  330. package/src/Typography/Typography.style.ts +25 -22
  331. package/src/Typography/Typography.tsx +3 -1
  332. package/src/Typography/index.ts +1 -0
  333. package/src/index.ts +1 -0
  334. package/src/utils/design/index.ts +5 -0
  335. package/src/utils/meta/meta.json +1 -0
  336. package/dist/src/InputText/context/InputAccessory.style.js +0 -16
  337. package/dist/types/src/InputText/context/InputAccessory.style.d.ts +0 -14
  338. package/src/InputText/context/InputAccessory.style.ts +0 -17
@@ -1,21 +1,22 @@
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
- marginTop: tokens["space-base"],
7
- marginBottom: tokens["space-base"],
8
- },
9
- row: {
10
- flexDirection: "row",
11
- width: "100%",
12
- },
13
- label: {
14
- flex: 1,
15
- justifyContent: "center",
16
- marginRight: tokens["space-small"],
17
- },
18
- description: {
19
- marginTop: tokens["space-smaller"],
20
- },
3
+ export const useStyles = buildThemedStyles(tokens => {
4
+ return {
5
+ container: {
6
+ marginTop: tokens["space-base"],
7
+ marginBottom: tokens["space-base"],
8
+ },
9
+ row: {
10
+ flexDirection: "row",
11
+ width: "100%",
12
+ },
13
+ label: {
14
+ flex: 1,
15
+ justifyContent: "center",
16
+ marginRight: tokens["space-small"],
17
+ },
18
+ description: {
19
+ marginTop: tokens["space-smaller"],
20
+ },
21
+ };
21
22
  });
@@ -2,7 +2,7 @@ import React, { useState } from "react";
2
2
  import { View } from "react-native";
3
3
  import { XOR } from "ts-xor";
4
4
  import { BaseSwitch, BaseSwitchProps } from "./components/BaseSwitch";
5
- import { styles } from "./Switch.styles";
5
+ import { useStyles } from "./Switch.styles";
6
6
  import { Text } from "../Text";
7
7
 
8
8
  interface WithLabelProps extends BaseSwitchProps {
@@ -26,6 +26,7 @@ export function Switch(props: SwitchProps): JSX.Element {
26
26
  };
27
27
 
28
28
  const [labelWidth, setLabelWidth] = useState<number | undefined>();
29
+ const styles = useStyles();
29
30
 
30
31
  return (
31
32
  <View style={styles.container}>
@@ -2,7 +2,7 @@ import React from "react";
2
2
  import { Platform } from "react-native";
3
3
  import { Switch } from "react-native-gesture-handler";
4
4
  import { useFormController } from "../../../hooks";
5
- import { tokens } from "../../../utils/design";
5
+ import { useAtlantisTheme } from "../../../AtlantisThemeContext";
6
6
 
7
7
  export interface BaseSwitchProps {
8
8
  /**
@@ -51,6 +51,8 @@ export function BaseSwitch({
51
51
 
52
52
  const internalValue = value ?? field.value;
53
53
 
54
+ const { tokens } = useAtlantisTheme();
55
+
54
56
  function getThumbColor() {
55
57
  if (Platform.OS === "android") {
56
58
  if (disabled) {
@@ -1,7 +1,7 @@
1
1
  import React from "react";
2
2
  import { render } from "@testing-library/react-native";
3
- import { tokens } from "@jobber/design";
4
3
  import { Text } from ".";
4
+ import { tokens } from "../utils/design";
5
5
 
6
6
  it("renders text with no additional props", () => {
7
7
  const text = render(<Text>Test Text</Text>);
package/src/Text/Text.tsx CHANGED
@@ -90,7 +90,7 @@ export interface TextProps
90
90
  /**
91
91
  * **Use at your own risk:** Custom style for specific elements. This should only be used as a
92
92
  * **last resort**. Using this may result in unexpected side effects.
93
- * More information [here](https://atlantis.getjobber.com/storybook/?path=/docs/guides-customizing-components--docs#unsafe_-props).
93
+ * More information in the [Customizing components Guide](https://atlantis.getjobber.com/guides/customizing-components).
94
94
  */
95
95
  readonly UNSAFE_style?: TypographyUnsafeStyle;
96
96
  }
@@ -1,17 +1,18 @@
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
- details: {
6
- width: "100%",
7
- flexDirection: "column",
8
- },
9
- detail: {
10
- flexDirection: "row",
11
- paddingLeft: tokens["space-small"],
12
- },
13
- detailText: {
14
- paddingLeft: tokens["space-small"],
15
- flex: 1,
16
- },
3
+ export const useStyles = buildThemedStyles(tokens => {
4
+ return {
5
+ details: {
6
+ width: "100%",
7
+ flexDirection: "column",
8
+ },
9
+ detail: {
10
+ flexDirection: "row",
11
+ paddingLeft: tokens["space-small"],
12
+ },
13
+ detailText: {
14
+ paddingLeft: tokens["space-small"],
15
+ flex: 1,
16
+ },
17
+ };
17
18
  });
@@ -1,6 +1,6 @@
1
1
  import React from "react";
2
2
  import { View } from "react-native";
3
- import { styles } from "./TextList.style";
3
+ import { useStyles } from "./TextList.style";
4
4
  import { Content, Spacing } from "../Content";
5
5
  import { Text, TextLevel } from "../Text";
6
6
 
@@ -43,6 +43,8 @@ export function TextList({
43
43
  level = "text",
44
44
  spacing = "none",
45
45
  }: TextListProps): JSX.Element {
46
+ const styles = useStyles();
47
+
46
48
  return (
47
49
  <>
48
50
  {items && (
@@ -1,50 +1,51 @@
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
- list: {
6
- display: "flex",
7
- flexDirection: "row",
8
- flexWrap: "wrap",
9
- maxHeight: (tokens["space-extravagant"] + tokens["space-smaller"]) * 2,
10
- overflow: "hidden",
11
- marginTop: tokens["space-smaller"],
12
- },
13
- maxDimensionsForThreeRows: {
14
- maxHeight: (tokens["space-extravagant"] + tokens["space-smaller"]) * 3,
15
- },
16
- thumbnail: {
17
- width: tokens["space-extravagant"],
18
- height: tokens["space-extravagant"],
19
- marginRight: tokens["space-smaller"],
20
- marginBottom: tokens["space-smaller"],
21
- borderRadius: tokens["radius-base"],
22
- borderColor: tokens["color-border"],
23
- borderWidth: tokens["border-base"],
24
- },
25
- centerThumbnailImage: {
26
- display: "flex",
27
- alignItems: "center",
28
- justifyContent: "center",
29
- },
30
- dimensionsThumbnailImage: {
31
- width: tokens["space-extravagant"],
32
- height: tokens["space-extravagant"],
33
- },
34
- thumbnailName: {
35
- position: "absolute",
36
- right: 0,
37
- bottom: 0,
38
- left: 0,
39
- paddingHorizontal: tokens["space-smaller"],
40
- paddingVertical: tokens["space-smallest"],
41
- borderTopColor: tokens["color-border"],
42
- borderTopWidth: tokens["space-minuscule"],
43
- },
44
- thumbnailIcon: {
45
- top: tokens["space-smaller"],
46
- display: "flex",
47
- alignItems: "center",
48
- justifyContent: "center",
49
- },
3
+ export const useStyles = buildThemedStyles(tokens => {
4
+ return {
5
+ list: {
6
+ display: "flex",
7
+ flexDirection: "row",
8
+ flexWrap: "wrap",
9
+ maxHeight: (tokens["space-extravagant"] + tokens["space-smaller"]) * 2,
10
+ overflow: "hidden",
11
+ marginTop: tokens["space-smaller"],
12
+ },
13
+ maxDimensionsForThreeRows: {
14
+ maxHeight: (tokens["space-extravagant"] + tokens["space-smaller"]) * 3,
15
+ },
16
+ thumbnail: {
17
+ width: tokens["space-extravagant"],
18
+ height: tokens["space-extravagant"],
19
+ marginRight: tokens["space-smaller"],
20
+ marginBottom: tokens["space-smaller"],
21
+ borderRadius: tokens["radius-base"],
22
+ borderColor: tokens["color-border"],
23
+ borderWidth: tokens["border-base"],
24
+ },
25
+ centerThumbnailImage: {
26
+ display: "flex",
27
+ alignItems: "center",
28
+ justifyContent: "center",
29
+ },
30
+ dimensionsThumbnailImage: {
31
+ width: tokens["space-extravagant"],
32
+ height: tokens["space-extravagant"],
33
+ },
34
+ thumbnailName: {
35
+ position: "absolute",
36
+ right: 0,
37
+ bottom: 0,
38
+ left: 0,
39
+ paddingHorizontal: tokens["space-smaller"],
40
+ paddingVertical: tokens["space-smallest"],
41
+ borderTopColor: tokens["color-border"],
42
+ borderTopWidth: tokens["space-minuscule"],
43
+ },
44
+ thumbnailIcon: {
45
+ top: tokens["space-smaller"],
46
+ display: "flex",
47
+ alignItems: "center",
48
+ justifyContent: "center",
49
+ },
50
+ };
50
51
  });
@@ -2,7 +2,7 @@ import React from "react";
2
2
  import { View } from "react-native";
3
3
  import isNil from "lodash/isNil";
4
4
  import { RowCount, ThumbnailListProps } from "./types";
5
- import { styles } from "./ThumbnailList.style";
5
+ import { useStyles } from "./ThumbnailList.style";
6
6
  import { File, FormatFile } from "../FormatFile";
7
7
 
8
8
  function isImage(file: File) {
@@ -26,6 +26,7 @@ export function ThumbnailList({
26
26
  createThumbnail,
27
27
  }: ThumbnailListProps): JSX.Element {
28
28
  const imageList = filterImages(files);
29
+ const styles = useStyles();
29
30
 
30
31
  return (
31
32
  <View
@@ -1,31 +1,32 @@
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
- flexDirection: "row",
7
- paddingHorizontal: tokens["space-base"],
8
- paddingBottom: tokens["space-base"],
9
- },
10
- toast: {
11
- flexDirection: "row",
12
- justifyContent: "space-between",
13
- width: "100%",
14
- maxWidth: 540,
15
- paddingVertical: tokens["space-small"],
16
- backgroundColor: tokens["color-blue"],
17
- borderRadius: 6,
18
- shadowOffset: { width: 0, height: 0 },
19
- shadowOpacity: 0.1,
20
- shadowRadius: 6,
21
- },
22
- toastMessage: {
23
- justifyContent: "center",
24
- paddingLeft: tokens["space-base"],
25
- paddingVertical: tokens["space-small"],
26
- flexShrink: 1,
27
- },
28
- toastIcon: {
29
- justifyContent: "center",
30
- },
3
+ export const useStyles = buildThemedStyles(tokens => {
4
+ return {
5
+ container: {
6
+ flexDirection: "row",
7
+ paddingHorizontal: tokens["space-base"],
8
+ paddingBottom: tokens["space-base"],
9
+ },
10
+ toast: {
11
+ flexDirection: "row",
12
+ justifyContent: "space-between",
13
+ width: "100%",
14
+ maxWidth: 540,
15
+ paddingVertical: tokens["space-small"],
16
+ backgroundColor: tokens["color-blue"],
17
+ borderRadius: 6,
18
+ shadowOffset: { width: 0, height: 0 },
19
+ shadowOpacity: 0.1,
20
+ shadowRadius: 6,
21
+ },
22
+ toastMessage: {
23
+ justifyContent: "center",
24
+ paddingLeft: tokens["space-base"],
25
+ paddingVertical: tokens["space-small"],
26
+ flexShrink: 1,
27
+ },
28
+ toastIcon: {
29
+ justifyContent: "center",
30
+ },
31
+ };
31
32
  });
@@ -6,11 +6,12 @@ import Toast, {
6
6
  } from "react-native-toast-message";
7
7
  import { AccessibilityInfo, TouchableOpacity, View } from "react-native";
8
8
  import { useSafeAreaInsets } from "react-native-safe-area-context";
9
- import { styles } from "./Toast.styles";
10
- import { tokens } from "../utils/design";
9
+ import { useStyles } from "./Toast.styles";
11
10
  import { Text } from "../Text";
12
11
  import { IconButton } from "../IconButton";
13
12
  import { useAtlantisI18n } from "../hooks/useAtlantisI18n";
13
+ import { useAtlantisTheme } from "../AtlantisThemeContext";
14
+ import { tokens as staticTokens } from "../utils/design";
14
15
 
15
16
  const MAX_TOAST_MESSAGE_LENGTH = 60;
16
17
  const ANNOUNCEMENT_DELAY = 100;
@@ -18,7 +19,9 @@ const ANNOUNCEMENT_DELAY = 100;
18
19
  function DefaultToast({ text1 }: ToastConfigParams<string>): JSX.Element {
19
20
  const { bottom } = useSafeAreaInsets();
20
21
  const { t } = useAtlantisI18n();
22
+ const styles = useStyles();
21
23
  const toastContainerStyles = [styles.container, { paddingBottom: bottom }];
24
+ const { tokens } = useAtlantisTheme();
22
25
 
23
26
  return (
24
27
  <View style={toastContainerStyles}>
@@ -113,12 +116,13 @@ export function showToast({
113
116
  }
114
117
 
115
118
  function getBottomTabsOffset(bottomTabsVisible: boolean) {
116
- const navBarHeight = tokens["space-largest"] + tokens["space-small"];
117
- const navBarBorderTopWidth = tokens["space-minuscule"];
119
+ const navBarHeight =
120
+ staticTokens["space-largest"] + staticTokens["space-small"];
121
+ const navBarBorderTopWidth = staticTokens["space-minuscule"];
118
122
 
119
123
  if (bottomTabsVisible) {
120
- return navBarHeight + navBarBorderTopWidth + tokens["space-base"];
124
+ return navBarHeight + navBarBorderTopWidth + staticTokens["space-base"];
121
125
  }
122
126
 
123
- return tokens["space-base"];
127
+ return staticTokens["space-base"];
124
128
  }
@@ -1,15 +1,20 @@
1
1
  import { Platform, StyleSheet, TextStyle } from "react-native";
2
2
  import { webFonts } from "./webFonts";
3
- import { tokens } from "../utils/design";
4
-
5
- const extravagantLineHeight = tokens["typography--lineHeight-extravagant"];
6
- const jumboLineHeight = tokens["typography--lineHeight-jumbo"];
7
- const largestLineHeight = tokens["typography--lineHeight-largest"];
8
- const largerLineHeight = tokens["typography--lineHeight-larger"];
9
- const largeLineHeight = tokens["typography--lineHeight-large"];
10
- const baseLineHeight = tokens["typography--lineHeight-base"];
11
- const tightLineHeight = tokens["typography--lineHeight-tight"];
12
- const minusculeLineHeight = tokens["typography--lineHeight-minuscule"];
3
+ import { tokens as staticTokens } from "../utils/design";
4
+ import {
5
+ AtlantisThemeContextValue,
6
+ buildThemedStyles,
7
+ } from "../AtlantisThemeContext";
8
+
9
+ const extravagantLineHeight =
10
+ staticTokens["typography--lineHeight-extravagant"];
11
+ const jumboLineHeight = staticTokens["typography--lineHeight-jumbo"];
12
+ const largestLineHeight = staticTokens["typography--lineHeight-largest"];
13
+ const largerLineHeight = staticTokens["typography--lineHeight-larger"];
14
+ const largeLineHeight = staticTokens["typography--lineHeight-large"];
15
+ const baseLineHeight = staticTokens["typography--lineHeight-base"];
16
+ const tightLineHeight = staticTokens["typography--lineHeight-tight"];
17
+ const minusculeLineHeight = staticTokens["typography--lineHeight-minuscule"];
13
18
 
14
19
  const deviceFonts = {
15
20
  baseRegularRegular: {
@@ -79,7 +84,9 @@ const fonts = Platform.select({
79
84
  /**
80
85
  * Reusable typography tokens to ensure consistency for any client facing texts.
81
86
  */
82
- export const typographyTokens: { [index: string]: TextStyle } = {
87
+ export const createTypographyTokens = (
88
+ tokens: AtlantisThemeContextValue["tokens"] | typeof staticTokens,
89
+ ): { [index: string]: TextStyle } => ({
83
90
  // This follows a pattern of
84
91
  // { fontFamily }{ fontStyle }{ fontWeight }
85
92
  ...fonts,
@@ -610,17 +617,13 @@ export const typographyTokens: { [index: string]: TextStyle } = {
610
617
  strikeThrough: {
611
618
  textDecorationLine: "line-through",
612
619
  },
613
- };
620
+ });
614
621
 
615
622
  /**
616
- * `StyleSheet` for Typography.tsx.
617
- *
618
- * If you find yourself needing to use what's inside this object on files other
619
- * than `<Typography />`, please import from `@jobber/components-native` instead.
620
- *
621
- * ```
622
- * import { typographyStyles } from "@jobber/components-native"
623
- * ```
623
+ * @deprecated Use useCommonInputStyles instead
624
624
  */
625
- export const typographyStyles: { [index: string]: TextStyle } =
626
- StyleSheet.create(typographyTokens);
625
+ export const typographyStyles: Record<string, TextStyle> = StyleSheet.create(
626
+ createTypographyTokens(staticTokens),
627
+ );
628
+
629
+ export const useTypographyStyles = buildThemedStyles(createTypographyTokens);
@@ -11,8 +11,8 @@ import {
11
11
  } from "react-native";
12
12
  import { TypographyGestureDetector } from "./TypographyGestureDetector";
13
13
  import { typographyStyles as styles } from "./Typography.style";
14
- import { tokens } from "../utils/design";
15
14
  import { capitalize } from "../utils/intl";
15
+ import { useAtlantisTheme } from "../AtlantisThemeContext";
16
16
 
17
17
  export interface TypographyProps<T extends FontFamily>
18
18
  extends Pick<TextProps, "selectable"> {
@@ -198,6 +198,8 @@ function InternalTypography<T extends FontFamily = "base">({
198
198
  }
199
199
  : { accessibilityRole };
200
200
 
201
+ const { tokens } = useAtlantisTheme();
202
+
201
203
  return (
202
204
  <TypographyGestureDetector>
203
205
  <Text
@@ -18,5 +18,6 @@ export type {
18
18
  TypographyProps,
19
19
  TruncateLength,
20
20
  } from "./Typography";
21
+ export { useTypographyStyles } from "./Typography.style";
21
22
  export { typographyStyles } from "./Typography.style";
22
23
  export { TypographyGestureDetector } from "./TypographyGestureDetector";
package/src/index.ts CHANGED
@@ -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";
@@ -1,6 +1,11 @@
1
1
  import { Platform } from "react-native";
2
2
  import { androidTokens, iosTokens } from "@jobber/design";
3
3
 
4
+ /**
5
+ * These design tokens don't react to theme changes. Only use these if you need to access
6
+ * tokens that are not affected by the current theme, otherwise you should be using our
7
+ * useAtlantisTheme() hook to access the current theme's tokens.
8
+ */
4
9
  export const tokens: typeof iosTokens = Platform.select({
5
10
  ios: () => iosTokens,
6
11
  android: () => androidTokens,
@@ -8,6 +8,7 @@
8
8
  "AtlantisContext.Provider",
9
9
  "AtlantisFormContext.Consumer",
10
10
  "AtlantisFormContext.Provider",
11
+ "AtlantisThemeContextProvider",
11
12
  "AutoLink",
12
13
  "Banner",
13
14
  "BottomSheet",
@@ -1,16 +0,0 @@
1
- import { StyleSheet } from "react-native";
2
- import { tokens } from "../../utils/design";
3
- export const styles = StyleSheet.create({
4
- container: {
5
- flexDirection: "row",
6
- justifyContent: "space-between",
7
- alignItems: "center",
8
- paddingHorizontal: tokens["space-small"],
9
- backgroundColor: tokens["color-surface--background"],
10
- borderTopWidth: tokens["space-minuscule"],
11
- borderTopColor: tokens["color-border"],
12
- },
13
- buttonContainer: {
14
- flexDirection: "row",
15
- },
16
- });
@@ -1,14 +0,0 @@
1
- export declare const styles: {
2
- container: {
3
- flexDirection: "row";
4
- justifyContent: "space-between";
5
- alignItems: "center";
6
- paddingHorizontal: number;
7
- backgroundColor: string;
8
- borderTopWidth: number;
9
- borderTopColor: string;
10
- };
11
- buttonContainer: {
12
- flexDirection: "row";
13
- };
14
- };
@@ -1,17 +0,0 @@
1
- import { StyleSheet } from "react-native";
2
- import { tokens } from "../../utils/design";
3
-
4
- export const styles = StyleSheet.create({
5
- container: {
6
- flexDirection: "row",
7
- justifyContent: "space-between",
8
- alignItems: "center",
9
- paddingHorizontal: tokens["space-small"],
10
- backgroundColor: tokens["color-surface--background"],
11
- borderTopWidth: tokens["space-minuscule"],
12
- borderTopColor: tokens["color-border"],
13
- },
14
- buttonContainer: {
15
- flexDirection: "row",
16
- },
17
- });