@audira/carbon-react-native 1.0.0-beta.7 → 1.0.0-beta.8

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 (460) hide show
  1. package/lib/commonjs/components/modal/Modal.js +19 -15
  2. package/lib/commonjs/components/modal/Modal.js.map +1 -1
  3. package/lib/module/components/modal/Modal.js +19 -15
  4. package/lib/module/components/modal/Modal.js.map +1 -1
  5. package/lib/typescript/commonjs/components/modal/Modal.d.ts.map +1 -1
  6. package/lib/typescript/module/components/modal/Modal.d.ts.map +1 -1
  7. package/lib/typescript/tsconfig.tsbuildinfo +1 -1
  8. package/package.json +2 -1
  9. package/src/_internal/contexts/button-group/ButtonGroupContext.ts +25 -0
  10. package/src/_internal/contexts/button-group/index.tsx +1 -0
  11. package/src/_internal/contexts/global-config/GlobalConfigContext.ts +30 -0
  12. package/src/_internal/contexts/global-config/index.ts +1 -0
  13. package/src/_internal/contexts/index.ts +3 -0
  14. package/src/_internal/contexts/modal/ModalContext.ts +15 -0
  15. package/src/_internal/contexts/modal/index.ts +1 -0
  16. package/src/_internal/globals/breakpoint/index.ts +13 -0
  17. package/src/_internal/globals/color-scheme/index.ts +13 -0
  18. package/src/_internal/globals/index.ts +7 -0
  19. package/src/_internal/helpers/index.ts +5 -0
  20. package/src/_internal/helpers/math/clamp.ts +3 -0
  21. package/src/_internal/helpers/math/index.ts +1 -0
  22. package/src/_internal/providers/breakpoint/BreakpointProvider.tsx +42 -0
  23. package/src/_internal/providers/breakpoint/BreakpointProviderProps.ts +3 -0
  24. package/src/_internal/providers/breakpoint/index.tsx +2 -0
  25. package/src/_internal/providers/global-config/GlobalConfigProvider.tsx +30 -0
  26. package/src/_internal/providers/global-config/GlobalConfigProviderProps.ts +7 -0
  27. package/src/_internal/providers/global-config/index.tsx +2 -0
  28. package/src/_internal/providers/index.ts +3 -0
  29. package/src/_internal/providers/theme/ThemeProvider.tsx +45 -0
  30. package/src/_internal/providers/theme/ThemeProviderProps.ts +8 -0
  31. package/src/_internal/providers/theme/index.tsx +2 -0
  32. package/src/_internal/style-sheets/common-style-sheet.ts +24 -0
  33. package/src/_internal/style-sheets/flex-style-sheet.ts +84 -0
  34. package/src/_internal/style-sheets/index.ts +3 -0
  35. package/src/_internal/style-sheets/text-style-sheet.ts +62 -0
  36. package/src/carbon-react-native/CarbonReactNative.tsx +41 -0
  37. package/src/carbon-react-native/CarbonReactNativeProps.ts +7 -0
  38. package/src/carbon-react-native/index.tsx +2 -0
  39. package/src/carbon-style-sheet/breakpoint.ts +16 -0
  40. package/src/carbon-style-sheet/color.ts +13 -0
  41. package/src/carbon-style-sheet/create.ts +232 -0
  42. package/src/carbon-style-sheet/index.tsx +51 -0
  43. package/src/carbon-style-sheet/use.tsx +16 -0
  44. package/src/components/accordion/Accordion.tsx +132 -0
  45. package/src/components/accordion/AccordionHeaderProps.ts +17 -0
  46. package/src/components/accordion/AccordionItemProps.ts +24 -0
  47. package/src/components/accordion/AccordionItemRef.ts +10 -0
  48. package/src/components/accordion/AccordionProps.ts +19 -0
  49. package/src/components/accordion/AccordionRef.ts +6 -0
  50. package/src/components/accordion/AccordionSize.ts +4 -0
  51. package/src/components/accordion/_Header.tsx +201 -0
  52. package/src/components/accordion/_HeaderBorder.tsx +75 -0
  53. package/src/components/accordion/_Item.tsx +175 -0
  54. package/src/components/accordion/_ItemRefBase.ts +7 -0
  55. package/src/components/accordion/_chevron/Chevron.tsx +97 -0
  56. package/src/components/accordion/_chevron/ChevronProps.ts +10 -0
  57. package/src/components/accordion/_chevron/index.ts +2 -0
  58. package/src/components/accordion/_context.ts +20 -0
  59. package/src/components/accordion/_motion.ts +27 -0
  60. package/src/components/accordion/_styles.ts +24 -0
  61. package/src/components/accordion/index.tsx +7 -0
  62. package/src/components/button/Size.ts +7 -0
  63. package/src/components/button/base/Base.tsx +328 -0
  64. package/src/components/button/base/BaseProps.ts +60 -0
  65. package/src/components/button/base/BaseRef.ts +6 -0
  66. package/src/components/button/base/index.tsx +3 -0
  67. package/src/components/button/base-color/BaseColor.tsx +289 -0
  68. package/src/components/button/base-color/BaseColorProps.ts +32 -0
  69. package/src/components/button/base-color/BaseColorRef.ts +6 -0
  70. package/src/components/button/base-color/BaseColorState.ts +6 -0
  71. package/src/components/button/base-color/index.tsx +4 -0
  72. package/src/components/button/ghost/Ghost.tsx +165 -0
  73. package/src/components/button/ghost/GhostProps.ts +10 -0
  74. package/src/components/button/ghost/GhostRef.ts +6 -0
  75. package/src/components/button/ghost/index.tsx +3 -0
  76. package/src/components/button/ghost-danger/GhostDanger.tsx +165 -0
  77. package/src/components/button/ghost-danger/GhostDangerProps.ts +10 -0
  78. package/src/components/button/ghost-danger/GhostDangerRef.ts +6 -0
  79. package/src/components/button/ghost-danger/index.tsx +3 -0
  80. package/src/components/button/ghost-icon/GhostIcon.tsx +127 -0
  81. package/src/components/button/ghost-icon/GhostIconProps.ts +17 -0
  82. package/src/components/button/ghost-icon/GhostIconRef.ts +6 -0
  83. package/src/components/button/ghost-icon/index.tsx +3 -0
  84. package/src/components/button/index.tsx +11 -0
  85. package/src/components/button/primary/Primary.tsx +140 -0
  86. package/src/components/button/primary/PrimaryProps.ts +11 -0
  87. package/src/components/button/primary/PrimaryRef.ts +6 -0
  88. package/src/components/button/primary/index.tsx +3 -0
  89. package/src/components/button/primary-danger/PrimaryDanger.tsx +140 -0
  90. package/src/components/button/primary-danger/PrimaryDangerProps.ts +12 -0
  91. package/src/components/button/primary-danger/PrimaryDangerRef.ts +6 -0
  92. package/src/components/button/primary-danger/index.tsx +3 -0
  93. package/src/components/button/secondary/Secondary.tsx +140 -0
  94. package/src/components/button/secondary/SecondaryProps.ts +12 -0
  95. package/src/components/button/secondary/SecondaryRef.ts +6 -0
  96. package/src/components/button/secondary/index.tsx +3 -0
  97. package/src/components/button/tertiary/Tertiary.tsx +157 -0
  98. package/src/components/button/tertiary/TertiaryProps.ts +12 -0
  99. package/src/components/button/tertiary/TertiaryRef.ts +6 -0
  100. package/src/components/button/tertiary/index.tsx +3 -0
  101. package/src/components/button/tertiary-danger/TertiaryDanger.tsx +157 -0
  102. package/src/components/button/tertiary-danger/TertiaryDangerProps.ts +12 -0
  103. package/src/components/button/tertiary-danger/TertiaryDangerRef.ts +6 -0
  104. package/src/components/button/tertiary-danger/index.tsx +3 -0
  105. package/src/components/button-group/ButtonGroup.tsx +145 -0
  106. package/src/components/button-group/ButtonGroupProps.ts +37 -0
  107. package/src/components/button-group/ButtonGroupRef.ts +6 -0
  108. package/src/components/button-group/index.tsx +3 -0
  109. package/src/components/checkbox/Checkbox.tsx +221 -0
  110. package/src/components/checkbox/CheckboxProps.ts +39 -0
  111. package/src/components/checkbox/CheckboxRef.ts +10 -0
  112. package/src/components/checkbox/_RefBase.ts +11 -0
  113. package/src/components/checkbox/index.tsx +3 -0
  114. package/src/components/checkbox-group/CheckboxGroup.tsx +227 -0
  115. package/src/components/checkbox-group/CheckboxGroupHelperTextMode.ts +4 -0
  116. package/src/components/checkbox-group/CheckboxGroupProps.ts +28 -0
  117. package/src/components/checkbox-group/CheckboxGroupRef.ts +6 -0
  118. package/src/components/checkbox-group/index.tsx +4 -0
  119. package/src/components/checkbox-input/CheckboxInput.tsx +340 -0
  120. package/src/components/checkbox-input/CheckboxInputInteractiveState.ts +6 -0
  121. package/src/components/checkbox-input/CheckboxInputProps.ts +25 -0
  122. package/src/components/checkbox-input/CheckboxInputRef.ts +11 -0
  123. package/src/components/checkbox-input/CheckboxInputValue.ts +6 -0
  124. package/src/components/checkbox-input/_RefBase.ts +11 -0
  125. package/src/components/checkbox-input/index.tsx +5 -0
  126. package/src/components/collapsible/Collapsible.tsx +274 -0
  127. package/src/components/collapsible/CollapsibleProps.ts +17 -0
  128. package/src/components/collapsible/CollapsibleRef.ts +11 -0
  129. package/src/components/collapsible/_RefBase.ts +6 -0
  130. package/src/components/collapsible/index.ts +3 -0
  131. package/src/components/form-helper-text/FormHelperText.tsx +109 -0
  132. package/src/components/form-helper-text/FormHelperTextProps.ts +15 -0
  133. package/src/components/form-helper-text/FormHelperTextRef.ts +6 -0
  134. package/src/components/form-helper-text/index.tsx +3 -0
  135. package/src/components/form-label/FormLabel.tsx +85 -0
  136. package/src/components/form-label/FormLabelProps.ts +17 -0
  137. package/src/components/form-label/FormLabelRef.ts +6 -0
  138. package/src/components/form-label/index.tsx +3 -0
  139. package/src/components/icon/Icon.tsx +48 -0
  140. package/src/components/icon/IconProps.ts +11 -0
  141. package/src/components/icon/index.tsx +2 -0
  142. package/src/components/index.tsx +35 -0
  143. package/src/components/inline-loading/InlineLoading.tsx +144 -0
  144. package/src/components/inline-loading/InlineLoadingProps.ts +24 -0
  145. package/src/components/inline-loading/InlineLoadingRef.ts +6 -0
  146. package/src/components/inline-loading/InlineLoadingState.ts +5 -0
  147. package/src/components/inline-loading/index.tsx +4 -0
  148. package/src/components/layer/Layer.tsx +87 -0
  149. package/src/components/layer/LayerContext.ts +9 -0
  150. package/src/components/layer/LayerProps.ts +16 -0
  151. package/src/components/layer/LayerRef.ts +6 -0
  152. package/src/components/layer/index.tsx +4 -0
  153. package/src/components/loading/Loading.tsx +116 -0
  154. package/src/components/loading/LoadingProps.ts +14 -0
  155. package/src/components/loading/LoadingRef.ts +4 -0
  156. package/src/components/loading/LoadingType.ts +3 -0
  157. package/src/components/loading/_circular-progress/CircularProgress.tsx +113 -0
  158. package/src/components/loading/_circular-progress/CircularProgressProps.ts +18 -0
  159. package/src/components/loading/_circular-progress/index.ts +2 -0
  160. package/src/components/loading/_map-circle-background-color.ts +26 -0
  161. package/src/components/loading/_map-circle-stroke-color.ts +13 -0
  162. package/src/components/loading/index.ts +4 -0
  163. package/src/components/modal/Modal.tsx +397 -0
  164. package/src/components/modal/ModalProps.ts +24 -0
  165. package/src/components/modal/ModalRef.ts +6 -0
  166. package/src/components/modal/ModalSize.ts +5 -0
  167. package/src/components/modal/index.tsx +4 -0
  168. package/src/components/modal-content/ModalContent.tsx +182 -0
  169. package/src/components/modal-content/ModalContentProps.ts +7 -0
  170. package/src/components/modal-content/ModalContentRef.ts +6 -0
  171. package/src/components/modal-content/index.tsx +3 -0
  172. package/src/components/notification/NotificationColor.ts +3 -0
  173. package/src/components/notification/_VariantContextProvider.tsx +39 -0
  174. package/src/components/notification/_status-hooks/_base/UseBaseData.ts +11 -0
  175. package/src/components/notification/_status-hooks/_base/UseBaseProps.ts +21 -0
  176. package/src/components/notification/_status-hooks/_base/index.tsx +3 -0
  177. package/src/components/notification/_status-hooks/_base/useBase.tsx +77 -0
  178. package/src/components/notification/_status-hooks/error/UseErrorData.ts +11 -0
  179. package/src/components/notification/_status-hooks/error/UseErrorProps.ts +8 -0
  180. package/src/components/notification/_status-hooks/error/index.tsx +3 -0
  181. package/src/components/notification/_status-hooks/error/useError.tsx +122 -0
  182. package/src/components/notification/_status-hooks/index.tsx +4 -0
  183. package/src/components/notification/_status-hooks/informational/UseInformationalData.ts +11 -0
  184. package/src/components/notification/_status-hooks/informational/UseInformationalProps.ts +8 -0
  185. package/src/components/notification/_status-hooks/informational/index.tsx +3 -0
  186. package/src/components/notification/_status-hooks/informational/useInformational.tsx +122 -0
  187. package/src/components/notification/_status-hooks/success/UseSuccessData.ts +11 -0
  188. package/src/components/notification/_status-hooks/success/UseSuccessProps.ts +8 -0
  189. package/src/components/notification/_status-hooks/success/index.tsx +3 -0
  190. package/src/components/notification/_status-hooks/success/useSuccess.tsx +122 -0
  191. package/src/components/notification/_status-hooks/warning/UseWarningData.ts +11 -0
  192. package/src/components/notification/_status-hooks/warning/UseWarningProps.ts +8 -0
  193. package/src/components/notification/_status-hooks/warning/index.tsx +3 -0
  194. package/src/components/notification/_status-hooks/warning/useWarning.tsx +122 -0
  195. package/src/components/notification/_variant-context.ts +15 -0
  196. package/src/components/notification/_variants/_ButtonGhost.tsx +73 -0
  197. package/src/components/notification/_variants/_ButtonTertiary.tsx +73 -0
  198. package/src/components/notification/_variants/actionable/ActionableVariant.tsx +70 -0
  199. package/src/components/notification/_variants/actionable/ActionableVariantProps.ts +46 -0
  200. package/src/components/notification/_variants/actionable/ActionableVariantRef.ts +6 -0
  201. package/src/components/notification/_variants/actionable/index.tsx +3 -0
  202. package/src/components/notification/_variants/actionable-inline/ActionableInlineVariant.tsx +70 -0
  203. package/src/components/notification/_variants/actionable-inline/ActionableInlineVariantProps.ts +46 -0
  204. package/src/components/notification/_variants/actionable-inline/ActionableInlineVariantRef.ts +6 -0
  205. package/src/components/notification/_variants/actionable-inline/index.tsx +3 -0
  206. package/src/components/notification/_variants/callout/CalloutVariant.tsx +59 -0
  207. package/src/components/notification/_variants/callout/CalloutVariantProps.ts +26 -0
  208. package/src/components/notification/_variants/callout/CalloutVariantRef.ts +6 -0
  209. package/src/components/notification/_variants/callout/index.tsx +3 -0
  210. package/src/components/notification/_variants/callout-inline/CalloutInlineVariant.tsx +59 -0
  211. package/src/components/notification/_variants/callout-inline/CalloutInlineVariantProps.ts +26 -0
  212. package/src/components/notification/_variants/callout-inline/CalloutInlineVariantRef.ts +6 -0
  213. package/src/components/notification/_variants/callout-inline/index.tsx +3 -0
  214. package/src/components/notification/_variants/index.tsx +5 -0
  215. package/src/components/notification/_variants/toast/ToastVariant.tsx +115 -0
  216. package/src/components/notification/_variants/toast/ToastVariantProps.ts +30 -0
  217. package/src/components/notification/_variants/toast/ToastVariantRef.ts +6 -0
  218. package/src/components/notification/_variants/toast/index.tsx +3 -0
  219. package/src/components/notification/actionable/error/Error.tsx +78 -0
  220. package/src/components/notification/actionable/error/ErrorProps.ts +14 -0
  221. package/src/components/notification/actionable/error/ErrorRef.ts +6 -0
  222. package/src/components/notification/actionable/error/index.tsx +3 -0
  223. package/src/components/notification/actionable/index.tsx +4 -0
  224. package/src/components/notification/actionable/informational/Informational.tsx +78 -0
  225. package/src/components/notification/actionable/informational/InformationalProps.ts +14 -0
  226. package/src/components/notification/actionable/informational/InformationalRef.ts +6 -0
  227. package/src/components/notification/actionable/informational/index.tsx +3 -0
  228. package/src/components/notification/actionable/success/Success.tsx +78 -0
  229. package/src/components/notification/actionable/success/SuccessProps.ts +14 -0
  230. package/src/components/notification/actionable/success/SuccessRef.ts +6 -0
  231. package/src/components/notification/actionable/success/index.tsx +3 -0
  232. package/src/components/notification/actionable/warning/Warning.tsx +78 -0
  233. package/src/components/notification/actionable/warning/WarningProps.ts +14 -0
  234. package/src/components/notification/actionable/warning/WarningRef.ts +6 -0
  235. package/src/components/notification/actionable/warning/index.tsx +3 -0
  236. package/src/components/notification/actionable-inline/error/Error.tsx +77 -0
  237. package/src/components/notification/actionable-inline/error/ErrorProps.ts +14 -0
  238. package/src/components/notification/actionable-inline/error/ErrorRef.ts +6 -0
  239. package/src/components/notification/actionable-inline/error/index.tsx +3 -0
  240. package/src/components/notification/actionable-inline/index.tsx +4 -0
  241. package/src/components/notification/actionable-inline/informational/Informational.tsx +77 -0
  242. package/src/components/notification/actionable-inline/informational/InformationalProps.ts +14 -0
  243. package/src/components/notification/actionable-inline/informational/InformationalRef.ts +6 -0
  244. package/src/components/notification/actionable-inline/informational/index.tsx +3 -0
  245. package/src/components/notification/actionable-inline/success/Success.tsx +77 -0
  246. package/src/components/notification/actionable-inline/success/SuccessProps.ts +14 -0
  247. package/src/components/notification/actionable-inline/success/SuccessRef.ts +6 -0
  248. package/src/components/notification/actionable-inline/success/index.tsx +3 -0
  249. package/src/components/notification/actionable-inline/warning/Warning.tsx +77 -0
  250. package/src/components/notification/actionable-inline/warning/WarningProps.ts +14 -0
  251. package/src/components/notification/actionable-inline/warning/WarningRef.ts +6 -0
  252. package/src/components/notification/actionable-inline/warning/index.tsx +3 -0
  253. package/src/components/notification/base/Base.tsx +292 -0
  254. package/src/components/notification/base/BaseProps.ts +59 -0
  255. package/src/components/notification/base/BaseRef.ts +6 -0
  256. package/src/components/notification/base/index.tsx +3 -0
  257. package/src/components/notification/callout/error/Error.tsx +78 -0
  258. package/src/components/notification/callout/error/ErrorProps.ts +14 -0
  259. package/src/components/notification/callout/error/ErrorRef.ts +6 -0
  260. package/src/components/notification/callout/error/index.tsx +3 -0
  261. package/src/components/notification/callout/index.tsx +4 -0
  262. package/src/components/notification/callout/informational/Informational.tsx +78 -0
  263. package/src/components/notification/callout/informational/InformationalProps.ts +14 -0
  264. package/src/components/notification/callout/informational/InformationalRef.ts +6 -0
  265. package/src/components/notification/callout/informational/index.tsx +3 -0
  266. package/src/components/notification/callout/success/Success.tsx +78 -0
  267. package/src/components/notification/callout/success/SuccessProps.ts +14 -0
  268. package/src/components/notification/callout/success/SuccessRef.ts +6 -0
  269. package/src/components/notification/callout/success/index.tsx +3 -0
  270. package/src/components/notification/callout/warning/Warning.tsx +78 -0
  271. package/src/components/notification/callout/warning/WarningProps.ts +14 -0
  272. package/src/components/notification/callout/warning/WarningRef.ts +6 -0
  273. package/src/components/notification/callout/warning/index.tsx +3 -0
  274. package/src/components/notification/callout-inline/error/Error.tsx +77 -0
  275. package/src/components/notification/callout-inline/error/ErrorProps.ts +14 -0
  276. package/src/components/notification/callout-inline/error/ErrorRef.ts +6 -0
  277. package/src/components/notification/callout-inline/error/index.tsx +3 -0
  278. package/src/components/notification/callout-inline/index.tsx +4 -0
  279. package/src/components/notification/callout-inline/informational/Informational.tsx +77 -0
  280. package/src/components/notification/callout-inline/informational/InformationalProps.ts +14 -0
  281. package/src/components/notification/callout-inline/informational/InformationalRef.ts +6 -0
  282. package/src/components/notification/callout-inline/informational/index.tsx +3 -0
  283. package/src/components/notification/callout-inline/success/Success.tsx +77 -0
  284. package/src/components/notification/callout-inline/success/SuccessProps.ts +14 -0
  285. package/src/components/notification/callout-inline/success/SuccessRef.ts +6 -0
  286. package/src/components/notification/callout-inline/success/index.tsx +3 -0
  287. package/src/components/notification/callout-inline/warning/Warning.tsx +77 -0
  288. package/src/components/notification/callout-inline/warning/WarningProps.ts +14 -0
  289. package/src/components/notification/callout-inline/warning/WarningRef.ts +6 -0
  290. package/src/components/notification/callout-inline/warning/index.tsx +3 -0
  291. package/src/components/notification/index.tsx +18 -0
  292. package/src/components/notification/subtitle/Subtitle.tsx +75 -0
  293. package/src/components/notification/subtitle/SubtitleProps.ts +6 -0
  294. package/src/components/notification/subtitle/SubtitleRef.ts +6 -0
  295. package/src/components/notification/subtitle/index.tsx +3 -0
  296. package/src/components/notification/subtitle-link/SubtitleLink.tsx +74 -0
  297. package/src/components/notification/subtitle-link/SubtitleLinkProps.ts +6 -0
  298. package/src/components/notification/subtitle-link/SubtitleLinkRef.ts +6 -0
  299. package/src/components/notification/subtitle-link/index.tsx +3 -0
  300. package/src/components/notification/toast/error/Error.tsx +78 -0
  301. package/src/components/notification/toast/error/ErrorProps.ts +14 -0
  302. package/src/components/notification/toast/error/ErrorRef.ts +6 -0
  303. package/src/components/notification/toast/error/index.tsx +3 -0
  304. package/src/components/notification/toast/index.tsx +4 -0
  305. package/src/components/notification/toast/informational/Informational.tsx +78 -0
  306. package/src/components/notification/toast/informational/InformationalProps.ts +14 -0
  307. package/src/components/notification/toast/informational/InformationalRef.ts +6 -0
  308. package/src/components/notification/toast/informational/index.tsx +3 -0
  309. package/src/components/notification/toast/success/Success.tsx +78 -0
  310. package/src/components/notification/toast/success/SuccessProps.ts +14 -0
  311. package/src/components/notification/toast/success/SuccessRef.ts +6 -0
  312. package/src/components/notification/toast/success/index.tsx +3 -0
  313. package/src/components/notification/toast/warning/Warning.tsx +78 -0
  314. package/src/components/notification/toast/warning/WarningProps.ts +14 -0
  315. package/src/components/notification/toast/warning/WarningRef.ts +6 -0
  316. package/src/components/notification/toast/warning/index.tsx +3 -0
  317. package/src/components/radio-button/RadioButton.tsx +216 -0
  318. package/src/components/radio-button/RadioButtonProps.ts +44 -0
  319. package/src/components/radio-button/RadioButtonRef.ts +10 -0
  320. package/src/components/radio-button/_RefBase.ts +11 -0
  321. package/src/components/radio-button/index.tsx +3 -0
  322. package/src/components/radio-button-group/RadioButtonGroup.tsx +246 -0
  323. package/src/components/radio-button-group/RadioButtonGroupHelperTextMode.ts +4 -0
  324. package/src/components/radio-button-group/RadioButtonGroupItemProps.ts +10 -0
  325. package/src/components/radio-button-group/RadioButtonGroupItemRef.ts +6 -0
  326. package/src/components/radio-button-group/RadioButtonGroupProps.ts +35 -0
  327. package/src/components/radio-button-group/RadioButtonGroupRef.ts +10 -0
  328. package/src/components/radio-button-group/_Item.tsx +101 -0
  329. package/src/components/radio-button-group/_RefBase.ts +11 -0
  330. package/src/components/radio-button-group/_item-context.tsx +18 -0
  331. package/src/components/radio-button-group/index.tsx +6 -0
  332. package/src/components/radio-button-input/RadioButtonInput.tsx +295 -0
  333. package/src/components/radio-button-input/RadioButtonInputInteractiveState.ts +6 -0
  334. package/src/components/radio-button-input/RadioButtonInputProps.ts +25 -0
  335. package/src/components/radio-button-input/RadioButtonInputRef.ts +10 -0
  336. package/src/components/radio-button-input/_RefBase.ts +7 -0
  337. package/src/components/radio-button-input/index.tsx +4 -0
  338. package/src/components/switch/Switch.tsx +487 -0
  339. package/src/components/switch/SwitchProps.ts +38 -0
  340. package/src/components/switch/SwitchRef.ts +10 -0
  341. package/src/components/switch/SwitchSize.ts +4 -0
  342. package/src/components/switch/SwitchState.ts +4 -0
  343. package/src/components/switch/_RefBase.ts +7 -0
  344. package/src/components/switch/index.ts +5 -0
  345. package/src/components/text/Text.tsx +171 -0
  346. package/src/components/text/TextProps.ts +20 -0
  347. package/src/components/text/TextRef.ts +6 -0
  348. package/src/components/text/index.ts +3 -0
  349. package/src/components/text-area/TextArea.tsx +266 -0
  350. package/src/components/text-area/TextAreaProps.ts +13 -0
  351. package/src/components/text-area/TextAreaRef.ts +10 -0
  352. package/src/components/text-area/_TextAreaRefBase.ts +7 -0
  353. package/src/components/text-area/index.tsx +3 -0
  354. package/src/components/text-area-field/TextAreaField.tsx +75 -0
  355. package/src/components/text-area-field/TextAreaFieldInteractiveState.ts +5 -0
  356. package/src/components/text-area-field/TextAreaFieldProps.ts +6 -0
  357. package/src/components/text-area-field/TextAreaFieldRef.ts +6 -0
  358. package/src/components/text-area-field/index.tsx +4 -0
  359. package/src/components/text-area-fluid/TextAreaFluid.tsx +157 -0
  360. package/src/components/text-area-fluid/TextAreaFluidProps.ts +13 -0
  361. package/src/components/text-area-fluid/TextAreaFluidRef.ts +6 -0
  362. package/src/components/text-area-fluid/index.tsx +3 -0
  363. package/src/components/text-input/TextInput.tsx +270 -0
  364. package/src/components/text-input/TextInputProps.ts +13 -0
  365. package/src/components/text-input/TextInputRef.ts +10 -0
  366. package/src/components/text-input/TextInputSize.ts +5 -0
  367. package/src/components/text-input/_TextInputRefBase.ts +7 -0
  368. package/src/components/text-input/index.ts +4 -0
  369. package/src/components/text-input-field/TextInputField.tsx +435 -0
  370. package/src/components/text-input-field/TextInputFieldInteractiveState.ts +6 -0
  371. package/src/components/text-input-field/TextInputFieldProps.ts +31 -0
  372. package/src/components/text-input-field/TextInputFieldRef.ts +8 -0
  373. package/src/components/text-input-field/TextInputFieldSize.ts +4 -0
  374. package/src/components/text-input-field/_rn-text-input/RNTextInput.tsx +161 -0
  375. package/src/components/text-input-field/_rn-text-input/RNTextInputProps.ts +11 -0
  376. package/src/components/text-input-field/_rn-text-input/RNTextInputRef.ts +6 -0
  377. package/src/components/text-input-field/_rn-text-input/index.ts +3 -0
  378. package/src/components/text-input-field/index.tsx +5 -0
  379. package/src/components/text-input-fluid/TextInputFluid.tsx +166 -0
  380. package/src/components/text-input-fluid/TextInputFluidProps.ts +14 -0
  381. package/src/components/text-input-fluid/TextInputFluidRef.ts +6 -0
  382. package/src/components/text-input-fluid/index.tsx +3 -0
  383. package/src/components/toggle/State.ts +5 -0
  384. package/src/components/toggle/base/Base.tsx +302 -0
  385. package/src/components/toggle/base/BaseProps.ts +54 -0
  386. package/src/components/toggle/base/BaseRef.ts +10 -0
  387. package/src/components/toggle/base/_RefBase.ts +11 -0
  388. package/src/components/toggle/base/index.tsx +3 -0
  389. package/src/components/toggle/default/Default.tsx +38 -0
  390. package/src/components/toggle/default/DefaultProps.ts +9 -0
  391. package/src/components/toggle/default/DefaultRef.ts +6 -0
  392. package/src/components/toggle/default/index.tsx +3 -0
  393. package/src/components/toggle/index.tsx +4 -0
  394. package/src/components/toggle/small/Small.tsx +38 -0
  395. package/src/components/toggle/small/SmallProps.ts +7 -0
  396. package/src/components/toggle/small/SmallRef.ts +6 -0
  397. package/src/components/toggle/small/index.tsx +3 -0
  398. package/src/const/dialog-animation-configs/carbon-react.ts +53 -0
  399. package/src/const/dialog-animation-configs/fade-bottom-up-2.ts +36 -0
  400. package/src/const/dialog-animation-configs/fade-bottom-up.ts +36 -0
  401. package/src/const/dialog-animation-configs/index.ts +3 -0
  402. package/src/const/index.ts +5 -0
  403. package/src/contexts/breakpoint/BreakpointContext.ts +19 -0
  404. package/src/contexts/breakpoint/index.ts +1 -0
  405. package/src/contexts/dialog/DialogContext.ts +27 -0
  406. package/src/contexts/dialog/DialogData.ts +27 -0
  407. package/src/contexts/dialog/DialogType.ts +7 -0
  408. package/src/contexts/dialog/index.ts +2 -0
  409. package/src/contexts/index.ts +4 -0
  410. package/src/contexts/theme/ThemeContext.ts +24 -0
  411. package/src/contexts/theme/index.ts +1 -0
  412. package/src/contexts/toast/ToastContext.ts +24 -0
  413. package/src/contexts/toast/ToastContextShowConfig.ts +6 -0
  414. package/src/contexts/toast/index.ts +2 -0
  415. package/src/helpers/breakpoint/get-token.ts +20 -0
  416. package/src/helpers/breakpoint/index.ts +1 -0
  417. package/src/helpers/color/get-color-scheme.ts +19 -0
  418. package/src/helpers/color/get-color-token.ts +23 -0
  419. package/src/helpers/color/hex-to-rgba.ts +11 -0
  420. package/src/helpers/color/index.ts +3 -0
  421. package/src/helpers/index.ts +7 -0
  422. package/src/hooks/breakpoint/index.tsx +1 -0
  423. package/src/hooks/breakpoint/use.tsx +30 -0
  424. package/src/hooks/index.tsx +9 -0
  425. package/src/index.ts +9 -0
  426. package/src/providers/dialog/DialogProvider.tsx +122 -0
  427. package/src/providers/dialog/DialogProviderAnimationConfig.ts +49 -0
  428. package/src/providers/dialog/DialogProviderProps.ts +28 -0
  429. package/src/providers/dialog/DialogProviderRef.ts +6 -0
  430. package/src/providers/dialog/_controller/Controller.tsx +223 -0
  431. package/src/providers/dialog/_controller/ControllerProps.ts +11 -0
  432. package/src/providers/dialog/_controller/ControllerRef.ts +6 -0
  433. package/src/providers/dialog/_controller/_modal/Modal.tsx +148 -0
  434. package/src/providers/dialog/_controller/_modal/ModalProps.ts +11 -0
  435. package/src/providers/dialog/_controller/_modal/ModalRef.ts +8 -0
  436. package/src/providers/dialog/_controller/_modal/_Interpolation.ts +9 -0
  437. package/src/providers/dialog/_controller/_modal/index.ts +3 -0
  438. package/src/providers/dialog/_controller/_overlay/Overlay.tsx +132 -0
  439. package/src/providers/dialog/_controller/_overlay/OverlayProps.ts +9 -0
  440. package/src/providers/dialog/_controller/_overlay/OverlayRef.ts +10 -0
  441. package/src/providers/dialog/_controller/_overlay/_OverlayRefBase.ts +3 -0
  442. package/src/providers/dialog/_controller/_overlay/index.ts +3 -0
  443. package/src/providers/dialog/_controller/index.ts +3 -0
  444. package/src/providers/dialog/index.ts +4 -0
  445. package/src/providers/index.ts +2 -0
  446. package/src/providers/toast/ToastProvider.tsx +73 -0
  447. package/src/providers/toast/ToastProviderProps.ts +3 -0
  448. package/src/providers/toast/ToastRef.ts +6 -0
  449. package/src/providers/toast/_overlay/Overlay.tsx +208 -0
  450. package/src/providers/toast/_overlay/OverlayRef.ts +6 -0
  451. package/src/providers/toast/_overlay/_component-wrapper/ComponentWrapper.tsx +168 -0
  452. package/src/providers/toast/_overlay/_component-wrapper/ComponentWrapperProps.ts +8 -0
  453. package/src/providers/toast/_overlay/_component-wrapper/ComponentWrapperRef.ts +6 -0
  454. package/src/providers/toast/_overlay/_component-wrapper/index.ts +3 -0
  455. package/src/providers/toast/_overlay/index.ts +2 -0
  456. package/src/providers/toast/index.tsx +3 -0
  457. package/src/types/index.ts +7 -0
  458. package/src/types/shared.ts +1 -0
  459. package/src/types/theme/ColorScheme.ts +1 -0
  460. package/src/types/theme/index.ts +1 -0
@@ -0,0 +1,435 @@
1
+ import {
2
+ forwardRef,
3
+ useContext,
4
+ useImperativeHandle,
5
+ useRef,
6
+ } from "react"
7
+
8
+ import {
9
+ Animated,
10
+ Easing,
11
+ StyleSheet,
12
+ TextInput,
13
+ type View,
14
+ type ViewStyle,
15
+ } from "react-native"
16
+
17
+ import {
18
+ Color,
19
+ Motion,
20
+ Spacing,
21
+ type ColorLayerLevel,
22
+ } from "@audira/carbon-react-native-elements"
23
+
24
+ import IconWarningAltFilled from "@carbon/icons/svg/32/warning--alt--filled.svg"
25
+ import IconWarningFilled from "@carbon/icons/svg/32/warning--filled.svg"
26
+
27
+ import {
28
+ CarbonStyleSheet,
29
+ } from "../../carbon-style-sheet"
30
+
31
+ import {
32
+ ThemeContext,
33
+ } from "../../contexts"
34
+
35
+ import type {
36
+ ThemeType,
37
+ } from "../../types"
38
+
39
+ import {
40
+ LayerContext,
41
+ } from "../layer"
42
+
43
+ import type {
44
+ TextInputFieldProps,
45
+ } from "./TextInputFieldProps"
46
+
47
+ import type {
48
+ TextInputFieldRef,
49
+ } from "./TextInputFieldRef"
50
+
51
+ import type {
52
+ TextInputFieldSize,
53
+ } from "./TextInputFieldSize"
54
+
55
+ import {
56
+ RNTextInput,
57
+ } from "./_rn-text-input"
58
+
59
+ export const TextInputField = forwardRef<TextInputFieldRef, TextInputFieldProps>(
60
+ function TextInputField(
61
+ {
62
+ size = "medium",
63
+ interactiveState = "normal",
64
+ hideInteractiveStateIcon,
65
+ blockStartNode,
66
+ blockEndNode,
67
+ style,
68
+ textInputStyle,
69
+
70
+ // hoist TextInputProps of React Native
71
+ allowFontScaling,
72
+ autoCapitalize,
73
+ autoComplete,
74
+ autoCorrect,
75
+ autoFocus,
76
+ blurOnSubmit,
77
+ submitBehavior,
78
+ caretHidden,
79
+ contextMenuHidden,
80
+ defaultValue,
81
+ value,
82
+ editable,
83
+ keyboardType,
84
+ inputMode,
85
+ maxLength,
86
+ multiline,
87
+ onBlur: onBlurProp,
88
+ onChange,
89
+ onChangeText,
90
+ onContentSizeChange,
91
+ onEndEditing,
92
+ onPress,
93
+ onPressIn,
94
+ onPressOut,
95
+ onFocus: onFocusProp,
96
+ onSelectionChange,
97
+ onSubmitEditing,
98
+ onScroll,
99
+ onKeyPress,
100
+ placeholder,
101
+ placeholderTextColor,
102
+ readOnly,
103
+ returnKeyType,
104
+ enterKeyHint,
105
+ secureTextEntry,
106
+ selectTextOnFocus,
107
+ selection,
108
+ selectionColor,
109
+ textAlign,
110
+ inputAccessoryViewID,
111
+ inputAccessoryViewButtonLabel,
112
+ maxFontSizeMultiplier,
113
+ // -----
114
+
115
+ // hoist TextInputAndroidProps
116
+ cursorColor,
117
+ selectionHandleColor,
118
+ importantForAutofill,
119
+ disableFullscreenUI,
120
+ inlineImageLeft,
121
+ inlineImagePadding,
122
+ numberOfLines,
123
+ returnKeyLabel,
124
+ textBreakStrategy,
125
+ underlineColorAndroid,
126
+ textAlignVertical,
127
+ showSoftInputOnFocus,
128
+ verticalAlign,
129
+ // -----
130
+
131
+ // hoist TextInputIOSProps
132
+ disableKeyboardShortcuts,
133
+ clearButtonMode,
134
+ clearTextOnFocus,
135
+ dataDetectorTypes,
136
+ enablesReturnKeyAutomatically,
137
+ keyboardAppearance,
138
+ passwordRules,
139
+ rejectResponderTermination,
140
+ selectionState,
141
+ spellCheck,
142
+ textContentType,
143
+ scrollEnabled,
144
+ lineBreakStrategyIOS,
145
+ lineBreakModeIOS,
146
+ smartInsertDelete,
147
+ // -----
148
+
149
+ ...viewProps
150
+ },
151
+ ref,
152
+ ) {
153
+
154
+ const
155
+ themeContext =
156
+ useContext(ThemeContext),
157
+
158
+ layerContextLevel =
159
+ useContext(LayerContext),
160
+
161
+ viewRef =
162
+ useRef<View>(null),
163
+
164
+ textInputRef =
165
+ useRef<TextInput>(null),
166
+ /**
167
+ * 0 = Blurred
168
+ * 1 = Focused
169
+ */
170
+ focusAnimatedValue =
171
+ useRef(new Animated.Value(0)),
172
+
173
+ focusHandler: TextInputFieldProps["onFocus"] =
174
+ event => {
175
+ Animated
176
+ .timing(
177
+ focusAnimatedValue.current,
178
+ {
179
+ toValue: 1,
180
+ ...timingConfig,
181
+ },
182
+ )
183
+ .start()
184
+ onFocusProp?.(event)
185
+ },
186
+
187
+ blurHandler: TextInputFieldProps["onBlur"] =
188
+ event => {
189
+ Animated
190
+ .timing(
191
+ focusAnimatedValue.current,
192
+ {
193
+ toValue: 0,
194
+ ...timingConfig,
195
+ },
196
+ )
197
+ .start()
198
+ onBlurProp?.(event)
199
+ }
200
+
201
+ useImperativeHandle(ref, () => {
202
+ return Object.assign(
203
+ viewRef.current ?? {
204
+ } as View,
205
+ {
206
+ get textInput() {
207
+ return textInputRef.current ?? undefined
208
+ },
209
+ },
210
+ )
211
+ }, [])
212
+
213
+ return (
214
+ <Animated.View
215
+ ref={ ref }
216
+ { ...viewProps }
217
+ style={ [
218
+ styleSheet.textInputField,
219
+ carbonStyleSheet.textInputField,
220
+ textInputFieldSizeStyleSheet[size],
221
+ textInputFieldByLayerStyleSheet[layerContextLevel],
222
+ interactiveState === "invalid"
223
+ ? carbonStyleSheet.invalidOutlineColor
224
+ : {
225
+ outlineColor: focusAnimatedValue.current.interpolate({
226
+ inputRange: [0, 1],
227
+ outputRange: ["transparent", mapOutlineColorFocus[themeContext.colorScheme]],
228
+ }),
229
+ },
230
+ style,
231
+ ] }
232
+ >
233
+ { blockStartNode }
234
+
235
+ <RNTextInput
236
+ ref={ textInputRef }
237
+ interactiveState={ interactiveState }
238
+ style={ textInputStyle }
239
+
240
+ allowFontScaling={ allowFontScaling }
241
+ autoCapitalize={ autoCapitalize }
242
+ autoComplete={ autoComplete }
243
+ autoCorrect={ autoCorrect }
244
+ autoFocus={ autoFocus }
245
+ blurOnSubmit={ blurOnSubmit }
246
+ submitBehavior={ submitBehavior }
247
+ caretHidden={ caretHidden }
248
+ contextMenuHidden={ contextMenuHidden }
249
+ defaultValue={ defaultValue }
250
+ value={ value }
251
+ editable={ interactiveState === "disabled" || interactiveState === "read_only" ? false : editable }
252
+ keyboardType={ keyboardType }
253
+ inputMode={ inputMode }
254
+ maxLength={ maxLength }
255
+ multiline={ multiline }
256
+ onBlur={ blurHandler }
257
+ onChange={ onChange }
258
+ onChangeText={ onChangeText }
259
+ onContentSizeChange={ onContentSizeChange }
260
+ onEndEditing={ onEndEditing }
261
+ onPress={ onPress }
262
+ onPressIn={ onPressIn }
263
+ onPressOut={ onPressOut }
264
+ onFocus={ focusHandler }
265
+ onSelectionChange={ onSelectionChange }
266
+ onSubmitEditing={ onSubmitEditing }
267
+ onScroll={ onScroll }
268
+ onKeyPress={ onKeyPress }
269
+ placeholder={ placeholder }
270
+ placeholderTextColor={ placeholderTextColor }
271
+ readOnly={ readOnly }
272
+ returnKeyType={ returnKeyType }
273
+ enterKeyHint={ enterKeyHint }
274
+ secureTextEntry={ secureTextEntry }
275
+ selectTextOnFocus={ selectTextOnFocus }
276
+ selection={ selection }
277
+ selectionColor={ selectionColor }
278
+ textAlign={ textAlign }
279
+ inputAccessoryViewID={ inputAccessoryViewID }
280
+ inputAccessoryViewButtonLabel={ inputAccessoryViewButtonLabel }
281
+ maxFontSizeMultiplier={ maxFontSizeMultiplier }
282
+
283
+ cursorColor={ cursorColor }
284
+ selectionHandleColor={ selectionHandleColor }
285
+ importantForAutofill={ importantForAutofill }
286
+ disableFullscreenUI={ disableFullscreenUI }
287
+ inlineImageLeft={ inlineImageLeft }
288
+ inlineImagePadding={ inlineImagePadding }
289
+ numberOfLines={ numberOfLines }
290
+ returnKeyLabel={ returnKeyLabel }
291
+ textBreakStrategy={ textBreakStrategy }
292
+ underlineColorAndroid={ underlineColorAndroid }
293
+ textAlignVertical={ textAlignVertical }
294
+ showSoftInputOnFocus={ showSoftInputOnFocus }
295
+ verticalAlign={ verticalAlign }
296
+
297
+ disableKeyboardShortcuts={ disableKeyboardShortcuts }
298
+ clearButtonMode={ clearButtonMode }
299
+ clearTextOnFocus={ clearTextOnFocus }
300
+ dataDetectorTypes={ dataDetectorTypes }
301
+ enablesReturnKeyAutomatically={ enablesReturnKeyAutomatically }
302
+ keyboardAppearance={ keyboardAppearance }
303
+ passwordRules={ passwordRules }
304
+ rejectResponderTermination={ rejectResponderTermination }
305
+ selectionState={ selectionState }
306
+ spellCheck={ spellCheck }
307
+ textContentType={ textContentType }
308
+ scrollEnabled={ scrollEnabled }
309
+ lineBreakStrategyIOS={ lineBreakStrategyIOS }
310
+ lineBreakModeIOS={ lineBreakModeIOS }
311
+ smartInsertDelete={ smartInsertDelete }
312
+ />
313
+
314
+ { !hideInteractiveStateIcon && interactiveState === "invalid" ? (
315
+ <IconWarningFilled
316
+ width={ 16 }
317
+ height={ 16 }
318
+ fill={ mapIconInvalidColor[themeContext.colorScheme] }
319
+ style={ [
320
+ styleSheet.icon,
321
+ iconBySizeStyleSheet[size],
322
+ ] }
323
+ />
324
+ ) : !hideInteractiveStateIcon && interactiveState === "warning" ? (
325
+ <IconWarningAltFilled
326
+ width={ 16 }
327
+ height={ 16 }
328
+ fill={ mapIconWarningColor[themeContext.colorScheme] }
329
+ style={ [
330
+ styleSheet.icon,
331
+ iconBySizeStyleSheet[size],
332
+ ] }
333
+ />
334
+ ) : undefined }
335
+
336
+ { blockEndNode }
337
+ </Animated.View>
338
+ )
339
+
340
+ },
341
+ )
342
+
343
+ const
344
+ styleSheet =
345
+ StyleSheet.create({
346
+ textInputField: {
347
+ outlineWidth: 2,
348
+ outlineOffset: -2,
349
+ outlineStyle: "solid",
350
+ },
351
+ icon: {
352
+ pointerEvents: "none",
353
+ position: "absolute",
354
+ right: Spacing.spacing_05,
355
+ },
356
+ }),
357
+
358
+ textInputFieldSizeStyleSheet =
359
+ StyleSheet.create<Record<TextInputFieldSize, ViewStyle>>({
360
+ small: {
361
+ height: 32,
362
+ },
363
+ medium: {
364
+ height: 40,
365
+ },
366
+ large: {
367
+ height: 48,
368
+ },
369
+ }),
370
+
371
+ iconBySizeStyleSheet =
372
+ StyleSheet.create<Record<TextInputFieldSize, ViewStyle>>({
373
+ small: {
374
+ top: 32 / 2 - 8,
375
+ },
376
+ medium: {
377
+ top: 40 / 2 - 8,
378
+ },
379
+ large: {
380
+ top: 48 / 2 - 8,
381
+ },
382
+ }),
383
+
384
+ carbonStyleSheet =
385
+ CarbonStyleSheet.create({
386
+ textInputField: {
387
+ backgroundColor: CarbonStyleSheet.color.field_02,
388
+ },
389
+ invalidOutlineColor: {
390
+ outlineColor: CarbonStyleSheet.color.support_error,
391
+ },
392
+ }),
393
+
394
+ textInputFieldByLayerStyleSheet =
395
+ CarbonStyleSheet.create<Record<ColorLayerLevel, ViewStyle>>({
396
+ 1: {
397
+ backgroundColor: CarbonStyleSheet.color.field_01,
398
+ },
399
+ 2: {
400
+ backgroundColor: CarbonStyleSheet.color.field_02,
401
+ },
402
+ 3: {
403
+ backgroundColor: CarbonStyleSheet.color.field_03,
404
+ },
405
+ }),
406
+
407
+ mapIconInvalidColor: Record<ThemeType.ColorScheme, string> =
408
+ {
409
+ gray_10: Color.Token.gray_10.support_error,
410
+ gray_100: Color.Token.gray_100.support_error,
411
+ },
412
+
413
+ mapIconWarningColor: Record<ThemeType.ColorScheme, string> =
414
+ {
415
+ gray_10: Color.Token.gray_10.support_warning,
416
+ gray_100: Color.Token.gray_100.support_warning,
417
+ },
418
+
419
+ mapOutlineColorFocus: Record<ThemeType.ColorScheme, string> =
420
+ {
421
+ gray_10: Color.Token.gray_10.focus,
422
+ gray_100: Color.Token.gray_100.focus,
423
+ },
424
+
425
+ timingConfig =
426
+ {
427
+ duration: Motion.Duration.fast_01,
428
+ easing: Easing.bezier(
429
+ Motion.Easing.standard.productive.x1,
430
+ Motion.Easing.standard.productive.y1,
431
+ Motion.Easing.standard.productive.x2,
432
+ Motion.Easing.standard.productive.y2,
433
+ ),
434
+ useNativeDriver: false, // outlineColor doesn't support native driver
435
+ } as const satisfies Omit<Animated.TimingAnimationConfig, "toValue">
@@ -0,0 +1,6 @@
1
+ export type TextInputFieldInteractiveState =
2
+ | "normal"
3
+ | "disabled"
4
+ | "invalid"
5
+ | "read_only"
6
+ | "warning"
@@ -0,0 +1,31 @@
1
+ import type {
2
+ TextInputProps,
3
+ ViewProps,
4
+ } from "react-native"
5
+
6
+ import type {
7
+ TextInputFieldInteractiveState,
8
+ } from "./TextInputFieldInteractiveState"
9
+
10
+ import type {
11
+ TextInputFieldSize,
12
+ } from "./TextInputFieldSize"
13
+
14
+ export interface TextInputFieldProps extends Omit<TextInputProps, "style"> {
15
+ /**
16
+ * @default 'medium'
17
+ */
18
+ size?: TextInputFieldSize,
19
+ /**
20
+ * @default 'normal'
21
+ */
22
+ interactiveState?: TextInputFieldInteractiveState,
23
+ hideInteractiveStateIcon?: boolean,
24
+ blockStartNode?: React.ReactNode,
25
+ blockEndNode?: React.ReactNode,
26
+ style?: ViewProps["style"],
27
+ /**
28
+ * The actual style prop of RN's TextInput
29
+ */
30
+ textInputStyle?: TextInputProps["style"],
31
+ }
@@ -0,0 +1,8 @@
1
+ import type {
2
+ TextInput,
3
+ View,
4
+ } from "react-native"
5
+
6
+ export interface TextInputFieldRef extends View {
7
+ readonly textInput?: TextInput,
8
+ }
@@ -0,0 +1,4 @@
1
+ export type TextInputFieldSize =
2
+ | "small"
3
+ | "medium"
4
+ | "large"
@@ -0,0 +1,161 @@
1
+ import {
2
+ forwardRef,
3
+ useContext,
4
+ } from "react"
5
+
6
+ import {
7
+ Platform,
8
+ StyleSheet,
9
+ TextInput,
10
+ type TextStyle,
11
+ } from "react-native"
12
+
13
+ import {
14
+ Color,
15
+ Spacing,
16
+ Typography,
17
+ } from "@audira/carbon-react-native-elements"
18
+
19
+ import {
20
+ GlobalConfigContext,
21
+ } from "../../../_internal/contexts"
22
+
23
+ import {
24
+ CommonStyleSheet,
25
+ } from "../../../_internal/style-sheets"
26
+
27
+ import {
28
+ ThemeContext,
29
+ } from "../../../contexts"
30
+
31
+ import type {
32
+ ThemeType,
33
+ } from "../../../types"
34
+
35
+ import type {
36
+ TextInputFieldInteractiveState,
37
+ } from "../TextInputFieldInteractiveState"
38
+
39
+ import type {
40
+ RNTextInputProps,
41
+ } from "./RNTextInputProps"
42
+
43
+ import type {
44
+ RNTextInputRef,
45
+ } from "./RNTextInputRef"
46
+
47
+ export const RNTextInput = forwardRef<RNTextInputRef, RNTextInputProps>(
48
+ function RNTextInput(
49
+ {
50
+ interactiveState,
51
+ editable,
52
+ style,
53
+ placeholderTextColor,
54
+ dir,
55
+ ...props
56
+ },
57
+ ref,
58
+ ) {
59
+
60
+ const
61
+ themeContext =
62
+ useContext(ThemeContext),
63
+
64
+ globalConfigContext =
65
+ useContext(GlobalConfigContext)
66
+
67
+ return (
68
+ <TextInput
69
+ ref={ ref }
70
+ { ...props }
71
+ editable={ interactiveState === "disabled" || interactiveState === "read_only" ? false : editable }
72
+ placeholderTextColor={ placeholderTextColor ?? mapPlaceholderTextColor[themeContext.colorScheme] }
73
+ dir={ dir ?? globalConfigContext.rtl ? "rtl" : undefined }
74
+ style={ [
75
+ styleSheet.rnTextInput as unknown as never, // FIXME: i don't know the correct type
76
+ mapStateStyleSheet[themeContext.colorScheme][interactiveState],
77
+ globalConfigContext.rtl ? CommonStyleSheet.rtl : undefined,
78
+ style,
79
+ ] }
80
+ />
81
+ )
82
+
83
+ },
84
+ )
85
+
86
+ const
87
+ styleSheet =
88
+ StyleSheet.create({
89
+ rnTextInput: {
90
+ flexGrow: 1,
91
+ paddingLeft: Spacing.spacing_05,
92
+ paddingRight: Spacing.spacing_05,
93
+ backgroundColor: "transparent",
94
+ borderBottomWidth: StyleSheet.hairlineWidth,
95
+ borderStyle: "solid",
96
+ fontFamily: "IBMPlexSans-Regular",
97
+ fontSize: Typography.TypeSets.body_compact_01.fontSize,
98
+ lineHeight: Typography.TypeSets.body_compact_01.lineHeight,
99
+ ...Platform.select({
100
+ web: {
101
+ outlineStyle: "none",
102
+ },
103
+ }),
104
+ },
105
+ }),
106
+
107
+ /**
108
+ * The text color in the TextInput is not reactive with the `CarbonStyleSheet.create()`. So i have to map it manually.
109
+ */
110
+ stateStyleSheet =
111
+ StyleSheet.create<Record<`${ThemeType.ColorScheme}__${Exclude<TextInputFieldInteractiveState, "invalid" | "warning">}`, TextStyle>>({
112
+ gray_10__normal: {
113
+ color: Color.Token.gray_10.text_primary,
114
+ borderBlockEndColor: Color.Token.gray_10.border_strong_01,
115
+ },
116
+ gray_10__disabled: {
117
+ color: Color.Token.gray_10.text_disabled,
118
+ borderBlockEndColor: "transparent",
119
+ },
120
+ gray_10__read_only: {
121
+ color: Color.Token.gray_10.text_primary,
122
+ borderBlockEndColor: Color.Token.gray_10.border_subtle_00,
123
+ },
124
+
125
+ gray_100__normal: {
126
+ color: Color.Token.gray_100.text_primary,
127
+ borderBlockEndColor: Color.Token.gray_100.border_strong_01,
128
+ },
129
+ gray_100__disabled: {
130
+ color: Color.Token.gray_100.text_disabled,
131
+ borderBlockEndColor: "transparent",
132
+ },
133
+ gray_100__read_only: {
134
+ color: Color.Token.gray_100.text_primary,
135
+ borderBlockEndColor: Color.Token.gray_100.border_subtle_00,
136
+ },
137
+ }),
138
+
139
+ mapPlaceholderTextColor: Record<ThemeType.ColorScheme, string> =
140
+ {
141
+ gray_10: Color.Token.gray_10.text_placeholder,
142
+ gray_100: Color.Token.gray_100.text_placeholder,
143
+ },
144
+
145
+ mapStateStyleSheet: Record<ThemeType.ColorScheme, Record<TextInputFieldInteractiveState, TextStyle>> =
146
+ {
147
+ gray_10: {
148
+ normal: stateStyleSheet.gray_10__normal,
149
+ disabled: stateStyleSheet.gray_10__disabled,
150
+ read_only: stateStyleSheet.gray_10__read_only,
151
+ invalid: stateStyleSheet.gray_10__normal,
152
+ warning: stateStyleSheet.gray_10__normal,
153
+ },
154
+ gray_100: {
155
+ normal: stateStyleSheet.gray_100__normal,
156
+ disabled: stateStyleSheet.gray_100__disabled,
157
+ read_only: stateStyleSheet.gray_100__read_only,
158
+ invalid: stateStyleSheet.gray_100__normal,
159
+ warning: stateStyleSheet.gray_100__normal,
160
+ },
161
+ }
@@ -0,0 +1,11 @@
1
+ import type {
2
+ TextInputProps,
3
+ } from "react-native"
4
+
5
+ import type {
6
+ TextInputFieldInteractiveState,
7
+ } from "../TextInputFieldInteractiveState"
8
+
9
+ export interface RNTextInputProps extends TextInputProps {
10
+ interactiveState: TextInputFieldInteractiveState,
11
+ }
@@ -0,0 +1,6 @@
1
+ import type {
2
+ TextInput,
3
+ } from "react-native"
4
+
5
+ export interface RNTextInputRef extends TextInput {
6
+ }
@@ -0,0 +1,3 @@
1
+ export * from "./RNTextInput"
2
+ export type * from "./RNTextInputProps"
3
+ export type * from "./RNTextInputRef"
@@ -0,0 +1,5 @@
1
+ export * from "./TextInputField"
2
+ export type * from "./TextInputFieldInteractiveState"
3
+ export type * from "./TextInputFieldProps"
4
+ export type * from "./TextInputFieldRef"
5
+ export type * from "./TextInputFieldSize"