@app-studio/web 0.1.0

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 (546) hide show
  1. package/LICENSE +448 -0
  2. package/README.md +50 -0
  3. package/dist/App.d.ts +3 -0
  4. package/dist/components/Button/Button/Button.props.d.ts +77 -0
  5. package/dist/components/Button/Button/Button.state.d.ts +5 -0
  6. package/dist/components/Button/Button/Button.style.d.ts +5 -0
  7. package/dist/components/Button/Button/Button.view.d.ts +4 -0
  8. package/dist/components/Button/Button.d.ts +6 -0
  9. package/dist/components/Button/examples/AutoFocusButton.d.ts +2 -0
  10. package/dist/components/Button/examples/BorderedButtons.d.ts +2 -0
  11. package/dist/components/Button/examples/ColoredButtons.d.ts +2 -0
  12. package/dist/components/Button/examples/DefaultButton.d.ts +2 -0
  13. package/dist/components/Button/examples/DisabledButton.d.ts +2 -0
  14. package/dist/components/Button/examples/IconButtons.d.ts +2 -0
  15. package/dist/components/Button/examples/LoadingButtons.d.ts +2 -0
  16. package/dist/components/Button/examples/ShadowButton.d.ts +2 -0
  17. package/dist/components/Button/examples/SizeButtons.d.ts +2 -0
  18. package/dist/components/Button/examples/VariantButtons.d.ts +2 -0
  19. package/dist/components/Button/examples/index.d.ts +9 -0
  20. package/dist/components/Form/Checkbox/Checkbox/Checkbox.props.d.ts +97 -0
  21. package/dist/components/Form/Checkbox/Checkbox/Checkbox.state.d.ts +8 -0
  22. package/dist/components/Form/Checkbox/Checkbox/Checkbox.style.d.ts +4 -0
  23. package/dist/components/Form/Checkbox/Checkbox/Checkbox.view.d.ts +4 -0
  24. package/dist/components/Form/Checkbox/Checkbox.d.ts +6 -0
  25. package/dist/components/Form/Checkbox/examples/ColorScheme.d.ts +2 -0
  26. package/dist/components/Form/Checkbox/examples/Default.d.ts +2 -0
  27. package/dist/components/Form/Checkbox/examples/DisabledInput.d.ts +2 -0
  28. package/dist/components/Form/Checkbox/examples/ErrorCheckbox.d.ts +2 -0
  29. package/dist/components/Form/Checkbox/examples/FormCheckout.d.ts +2 -0
  30. package/dist/components/Form/Checkbox/examples/IconCheckbox.d.ts +2 -0
  31. package/dist/components/Form/Checkbox/examples/IndeterminateCheckbox.d.ts +2 -0
  32. package/dist/components/Form/Checkbox/examples/ReadOnlyInput.d.ts +2 -0
  33. package/dist/components/Form/Checkbox/examples/Shadow.d.ts +2 -0
  34. package/dist/components/Form/Checkbox/examples/SizeInput.d.ts +2 -0
  35. package/dist/components/Form/Checkbox/examples/StylesInput.d.ts +2 -0
  36. package/dist/components/Form/Checkbox/examples/index.d.ts +11 -0
  37. package/dist/components/Form/CountryPicker/CountryPicker/CountryPicker.props.d.ts +173 -0
  38. package/dist/components/Form/CountryPicker/CountryPicker/CountryPicker.state.d.ts +15 -0
  39. package/dist/components/Form/CountryPicker/CountryPicker/CountryPicker.style.d.ts +3 -0
  40. package/dist/components/Form/CountryPicker/CountryPicker/CountryPicker.view.d.ts +6 -0
  41. package/dist/components/Form/CountryPicker/CountryPicker.d.ts +6 -0
  42. package/dist/components/Form/CountryPicker/examples/Color.d.ts +2 -0
  43. package/dist/components/Form/CountryPicker/examples/Default.d.ts +2 -0
  44. package/dist/components/Form/CountryPicker/examples/Disabled.d.ts +2 -0
  45. package/dist/components/Form/CountryPicker/examples/Error.d.ts +2 -0
  46. package/dist/components/Form/CountryPicker/examples/Form.d.ts +2 -0
  47. package/dist/components/Form/CountryPicker/examples/Formik.d.ts +2 -0
  48. package/dist/components/Form/CountryPicker/examples/HelperText.d.ts +2 -0
  49. package/dist/components/Form/CountryPicker/examples/ReadOnlyInput.d.ts +2 -0
  50. package/dist/components/Form/CountryPicker/examples/Shadow.d.ts +2 -0
  51. package/dist/components/Form/CountryPicker/examples/Shape.d.ts +2 -0
  52. package/dist/components/Form/CountryPicker/examples/SizeInput.d.ts +2 -0
  53. package/dist/components/Form/CountryPicker/examples/StylesInput.d.ts +2 -0
  54. package/dist/components/Form/CountryPicker/examples/Variant.d.ts +2 -0
  55. package/dist/components/Form/CountryPicker/examples/index.d.ts +12 -0
  56. package/dist/components/Form/DatePicker/DatePicker/DatePicker.props.d.ts +103 -0
  57. package/dist/components/Form/DatePicker/DatePicker/DatePicker.state.d.ts +9 -0
  58. package/dist/components/Form/DatePicker/DatePicker/DatePicker.style.d.ts +3 -0
  59. package/dist/components/Form/DatePicker/DatePicker/DatePicker.view.d.ts +4 -0
  60. package/dist/components/Form/DatePicker/DatePicker.d.ts +6 -0
  61. package/dist/components/Form/DatePicker/examples/ColorScheme.d.ts +2 -0
  62. package/dist/components/Form/DatePicker/examples/Default.d.ts +2 -0
  63. package/dist/components/Form/DatePicker/examples/DisabledInput.d.ts +2 -0
  64. package/dist/components/Form/DatePicker/examples/ErrorCheckbox.d.ts +2 -0
  65. package/dist/components/Form/DatePicker/examples/FormCheckout.d.ts +2 -0
  66. package/dist/components/Form/DatePicker/examples/Formik.d.ts +2 -0
  67. package/dist/components/Form/DatePicker/examples/ReadOnlyInput.d.ts +2 -0
  68. package/dist/components/Form/DatePicker/examples/Shadow.d.ts +2 -0
  69. package/dist/components/Form/DatePicker/examples/SizeInput.d.ts +2 -0
  70. package/dist/components/Form/DatePicker/examples/StylesInput.d.ts +2 -0
  71. package/dist/components/Form/DatePicker/examples/helperTextDatePicker.d.ts +2 -0
  72. package/dist/components/Form/DatePicker/examples/index.d.ts +11 -0
  73. package/dist/components/Form/Label/Label/Label.props.d.ts +36 -0
  74. package/dist/components/Form/Label/Label/Label.style.d.ts +2 -0
  75. package/dist/components/Form/Label/Label/Label.type.d.ts +3 -0
  76. package/dist/components/Form/Label/Label/Label.view.d.ts +4 -0
  77. package/dist/components/Form/Label/Label.d.ts +3 -0
  78. package/dist/components/Form/Password/Password/Password.props.d.ts +34 -0
  79. package/dist/components/Form/Password/Password/Password.state.d.ts +5 -0
  80. package/dist/components/Form/Password/Password/Password.view.d.ts +4 -0
  81. package/dist/components/Form/Password/Password.d.ts +6 -0
  82. package/dist/components/Form/Password/example/Default.d.ts +2 -0
  83. package/dist/components/Form/Password/example/DisabledInput.d.ts +2 -0
  84. package/dist/components/Form/Password/example/ErrorInput.d.ts +2 -0
  85. package/dist/components/Form/Password/example/FormikErrorInput.d.ts +2 -0
  86. package/dist/components/Form/Password/example/FormikHelperText.d.ts +2 -0
  87. package/dist/components/Form/Password/example/HelperText.d.ts +2 -0
  88. package/dist/components/Form/Select/Select/Select.props.d.ts +234 -0
  89. package/dist/components/Form/Select/Select/Select.state.d.ts +16 -0
  90. package/dist/components/Form/Select/Select/Select.style.d.ts +4 -0
  91. package/dist/components/Form/Select/Select/Select.view.d.ts +5 -0
  92. package/dist/components/Form/Select/Select.d.ts +6 -0
  93. package/dist/components/Form/Select/examples/Color.d.ts +2 -0
  94. package/dist/components/Form/Select/examples/Default.d.ts +2 -0
  95. package/dist/components/Form/Select/examples/Disabled.d.ts +2 -0
  96. package/dist/components/Form/Select/examples/Error.d.ts +2 -0
  97. package/dist/components/Form/Select/examples/Form.d.ts +2 -0
  98. package/dist/components/Form/Select/examples/Formik.d.ts +2 -0
  99. package/dist/components/Form/Select/examples/HelperText.d.ts +2 -0
  100. package/dist/components/Form/Select/examples/Multiple.d.ts +2 -0
  101. package/dist/components/Form/Select/examples/ReadOnlyInput.d.ts +2 -0
  102. package/dist/components/Form/Select/examples/Shadow.d.ts +2 -0
  103. package/dist/components/Form/Select/examples/SizeInput.d.ts +2 -0
  104. package/dist/components/Form/Select/examples/StylesInput.d.ts +2 -0
  105. package/dist/components/Form/Switch/Switch/Switch.props.d.ts +72 -0
  106. package/dist/components/Form/Switch/Switch/Switch.state.d.ts +8 -0
  107. package/dist/components/Form/Switch/Switch/Switch.style.d.ts +5 -0
  108. package/dist/components/Form/Switch/Switch/Switch.view.d.ts +4 -0
  109. package/dist/components/Form/Switch/Switch.d.ts +3 -0
  110. package/dist/components/Form/Switch/examples/ChildSwitch.d.ts +2 -0
  111. package/dist/components/Form/Switch/examples/ColorScheme.d.ts +2 -0
  112. package/dist/components/Form/Switch/examples/Default.d.ts +2 -0
  113. package/dist/components/Form/Switch/examples/DisabledInput.d.ts +2 -0
  114. package/dist/components/Form/Switch/examples/FormSwitch.d.ts +2 -0
  115. package/dist/components/Form/Switch/examples/Formik.d.ts +2 -0
  116. package/dist/components/Form/Switch/examples/ReadOnlyInput.d.ts +2 -0
  117. package/dist/components/Form/Switch/examples/Shadow.d.ts +2 -0
  118. package/dist/components/Form/Switch/examples/SizeInput.d.ts +2 -0
  119. package/dist/components/Form/Switch/examples/StylesInput.d.ts +2 -0
  120. package/dist/components/Form/TextArea/TextArea/TextArea.props.d.ts +144 -0
  121. package/dist/components/Form/TextArea/TextArea/TextArea.state.d.ts +12 -0
  122. package/dist/components/Form/TextArea/TextArea/TextArea.type.d.ts +11 -0
  123. package/dist/components/Form/TextArea/TextArea/TextArea.view.d.ts +4 -0
  124. package/dist/components/Form/TextArea/TextArea.d.ts +6 -0
  125. package/dist/components/Form/TextArea/examples/ColorScheme.d.ts +2 -0
  126. package/dist/components/Form/TextArea/examples/Default.d.ts +2 -0
  127. package/dist/components/Form/TextArea/examples/DisabledInput.d.ts +2 -0
  128. package/dist/components/Form/TextArea/examples/ErrorInput.d.ts +2 -0
  129. package/dist/components/Form/TextArea/examples/FormikErrorInput.d.ts +2 -0
  130. package/dist/components/Form/TextArea/examples/FormikHelperText.d.ts +2 -0
  131. package/dist/components/Form/TextArea/examples/HelperText.d.ts +2 -0
  132. package/dist/components/Form/TextArea/examples/LabelInput.d.ts +2 -0
  133. package/dist/components/Form/TextArea/examples/MaxRowCol.d.ts +2 -0
  134. package/dist/components/Form/TextArea/examples/Placeholder.d.ts +2 -0
  135. package/dist/components/Form/TextArea/examples/ReadOnlyInput.d.ts +2 -0
  136. package/dist/components/Form/TextArea/examples/ShadowArea.d.ts +2 -0
  137. package/dist/components/Form/TextArea/examples/ShapeInput.d.ts +2 -0
  138. package/dist/components/Form/TextArea/examples/SizeInput.d.ts +2 -0
  139. package/dist/components/Form/TextArea/examples/StylesInput.d.ts +2 -0
  140. package/dist/components/Form/TextArea/examples/VariantsInputs.d.ts +2 -0
  141. package/dist/components/Form/TextArea/examples/index.d.ts +15 -0
  142. package/dist/components/Form/TextField/TextField/TextField.props.d.ts +124 -0
  143. package/dist/components/Form/TextField/TextField/TextField.state.d.ts +12 -0
  144. package/dist/components/Form/TextField/TextField/TextField.view.d.ts +4 -0
  145. package/dist/components/Form/TextField/TextField.d.ts +6 -0
  146. package/dist/components/Form/TextField/examples/ClearInput.d.ts +2 -0
  147. package/dist/components/Form/TextField/examples/ColorScheme.d.ts +2 -0
  148. package/dist/components/Form/TextField/examples/Default.d.ts +2 -0
  149. package/dist/components/Form/TextField/examples/DisabledInput.d.ts +2 -0
  150. package/dist/components/Form/TextField/examples/ErrorInput.d.ts +2 -0
  151. package/dist/components/Form/TextField/examples/FormikErrorInput.d.ts +2 -0
  152. package/dist/components/Form/TextField/examples/FormikHelperText.d.ts +2 -0
  153. package/dist/components/Form/TextField/examples/HelperText.d.ts +2 -0
  154. package/dist/components/Form/TextField/examples/LabelInput.d.ts +2 -0
  155. package/dist/components/Form/TextField/examples/LeftChild.d.ts +2 -0
  156. package/dist/components/Form/TextField/examples/Placeholder.d.ts +2 -0
  157. package/dist/components/Form/TextField/examples/ReadOnlyInput.d.ts +2 -0
  158. package/dist/components/Form/TextField/examples/RightChild.d.ts +2 -0
  159. package/dist/components/Form/TextField/examples/ShapeInput.d.ts +2 -0
  160. package/dist/components/Form/TextField/examples/SizeInput.d.ts +2 -0
  161. package/dist/components/Form/TextField/examples/StylesInput.d.ts +2 -0
  162. package/dist/components/Form/TextField/examples/VariantsInputs.d.ts +2 -0
  163. package/dist/components/Form/TextField/examples/index.d.ts +17 -0
  164. package/dist/components/Layout/Center/Center/Center.props.d.ts +16 -0
  165. package/dist/components/Layout/Center/Center/Center.view.d.ts +4 -0
  166. package/dist/components/Layout/Center/Center.d.ts +3 -0
  167. package/dist/components/Layout/Horizontal/Horizontal/Horizontal.props.d.ts +24 -0
  168. package/dist/components/Layout/Horizontal/Horizontal/Horizontal.view.d.ts +4 -0
  169. package/dist/components/Layout/Horizontal/Horizontal.d.ts +3 -0
  170. package/dist/components/Layout/Horizontal/examples/Default.d.ts +2 -0
  171. package/dist/components/Layout/Horizontal/examples/Justify.d.ts +2 -0
  172. package/dist/components/Layout/Horizontal/examples/Reversed.d.ts +2 -0
  173. package/dist/components/Layout/Horizontal/examples/Wrap.d.ts +2 -0
  174. package/dist/components/Layout/Horizontal/examples/index.d.ts +4 -0
  175. package/dist/components/Layout/Input/FieldContainer/FieldContainer/FieldContainer.props.d.ts +24 -0
  176. package/dist/components/Layout/Input/FieldContainer/FieldContainer.d.ts +3 -0
  177. package/dist/components/Layout/Input/FieldContent/FieldContent/FieldContent.props.d.ts +74 -0
  178. package/dist/components/Layout/Input/FieldContent/FieldContent.d.ts +3 -0
  179. package/dist/components/Layout/Input/FieldIcons/FieldIcons/FieldIcons.props.d.ts +11 -0
  180. package/dist/components/Layout/Input/FieldIcons/FieldIcons.d.ts +3 -0
  181. package/dist/components/Layout/Input/FieldLabel/FieldLabel/FieldLabel.props.d.ts +30 -0
  182. package/dist/components/Layout/Input/FieldLabel/FieldLabel.d.ts +3 -0
  183. package/dist/components/Layout/Input/FieldLayout/FieldLayout/FieldLayout.props.d.ts +28 -0
  184. package/dist/components/Layout/Input/FieldLayout/FieldLayout.d.ts +3 -0
  185. package/dist/components/Layout/Input/FieldWrapper/FieldWrapper.d.ts +3 -0
  186. package/dist/components/Layout/Input/FieldWrapper/FieldWrapper.props.d.ts +11 -0
  187. package/dist/components/Layout/Input/HelperText/HelperText.d.ts +3 -0
  188. package/dist/components/Layout/Input/HelperText/HelperText.props.d.ts +20 -0
  189. package/dist/components/Layout/Input/index.d.ts +7 -0
  190. package/dist/components/Layout/Vertical/Vertical/Vertical.props.d.ts +24 -0
  191. package/dist/components/Layout/Vertical/Vertical/Vertical.type.d.ts +2 -0
  192. package/dist/components/Layout/Vertical/Vertical/Vertical.view.d.ts +4 -0
  193. package/dist/components/Layout/Vertical/Vertical.d.ts +3 -0
  194. package/dist/components/Layout/Vertical/examples/Default.d.ts +2 -0
  195. package/dist/components/Layout/Vertical/examples/Justify.d.ts +2 -0
  196. package/dist/components/Layout/Vertical/examples/Reversed.d.ts +2 -0
  197. package/dist/components/Layout/Vertical/examples/Wrap.d.ts +2 -0
  198. package/dist/components/Layout/Vertical/examples/index.d.ts +5 -0
  199. package/dist/components/Layout/View/View.d.ts +2 -0
  200. package/dist/components/Layout/configs/Input.style.d.ts +16 -0
  201. package/dist/components/Layout/configs/Input.type.d.ts +12 -0
  202. package/dist/components/Link/Link/Link.props.d.ts +47 -0
  203. package/dist/components/Link/Link/Link.state.d.ts +5 -0
  204. package/dist/components/Link/Link/Link.style.d.ts +2 -0
  205. package/dist/components/Link/Link/Link.view.d.ts +4 -0
  206. package/dist/components/Link/Link.d.ts +6 -0
  207. package/dist/components/Link/examples/Default.d.ts +2 -0
  208. package/dist/components/Link/examples/IsExternal.d.ts +2 -0
  209. package/dist/components/Link/examples/Underline.d.ts +2 -0
  210. package/dist/components/Loader/Loader/Loader.props.d.ts +93 -0
  211. package/dist/components/Loader/Loader/Loader.style.d.ts +4 -0
  212. package/dist/components/Loader/Loader/Loader.view.d.ts +4 -0
  213. package/dist/components/Loader/Loader.d.ts +6 -0
  214. package/dist/components/Loader/examples/ColorLoader.d.ts +2 -0
  215. package/dist/components/Loader/examples/DefaultLoader.d.ts +2 -0
  216. package/dist/components/Loader/examples/PositionLoader.d.ts +2 -0
  217. package/dist/components/Loader/examples/SizeLoader.d.ts +2 -0
  218. package/dist/components/Loader/examples/SpeedLoader.d.ts +2 -0
  219. package/dist/components/Loader/examples/TextLoader.d.ts +2 -0
  220. package/dist/components/Loader/examples/VariantLoader.d.ts +2 -0
  221. package/dist/components/Loader/examples/index.d.ts +7 -0
  222. package/dist/components/Modal/Examples/BlurModal.d.ts +2 -0
  223. package/dist/components/Modal/Examples/CloseButtonModal.d.ts +2 -0
  224. package/dist/components/Modal/Examples/DefaultModal.d.ts +2 -0
  225. package/dist/components/Modal/Examples/FullScreenModal.d.ts +2 -0
  226. package/dist/components/Modal/Examples/ModalPosition.d.ts +2 -0
  227. package/dist/components/Modal/Examples/PreventCloseModal.d.ts +2 -0
  228. package/dist/components/Modal/Examples/ScrollModal.d.ts +2 -0
  229. package/dist/components/Modal/Examples/ShadowModal.d.ts +2 -0
  230. package/dist/components/Modal/Examples/VariantModal.d.ts +2 -0
  231. package/dist/components/Modal/Examples/index.d.ts +9 -0
  232. package/dist/components/Modal/Modal/Modal.props.d.ts +178 -0
  233. package/dist/components/Modal/Modal/Modal.style.d.ts +5 -0
  234. package/dist/components/Modal/Modal/Modal.view.d.ts +7 -0
  235. package/dist/components/Modal/Modal.d.ts +6 -0
  236. package/dist/components/Svg/ArrowDown.d.ts +8 -0
  237. package/dist/components/Svg/ArrowUp.d.ts +8 -0
  238. package/dist/components/Svg/Check.d.ts +8 -0
  239. package/dist/components/Svg/Close.d.ts +8 -0
  240. package/dist/components/Svg/CloseEye.d.ts +8 -0
  241. package/dist/components/Svg/DustBin.d.ts +7 -0
  242. package/dist/components/Svg/Edit.d.ts +8 -0
  243. package/dist/components/Svg/ExternalLink.d.ts +8 -0
  244. package/dist/components/Svg/Indeterminate.d.ts +8 -0
  245. package/dist/components/Svg/OpenEye.d.ts +8 -0
  246. package/dist/components/Svg/Profile.d.ts +8 -0
  247. package/dist/components/Svg/RightArrow.d.ts +8 -0
  248. package/dist/components/Svg/index.d.ts +12 -0
  249. package/dist/components/Text/Text/Text.props.d.ts +77 -0
  250. package/dist/components/Text/Text/Text.style.d.ts +2 -0
  251. package/dist/components/Text/Text/Text.view.d.ts +4 -0
  252. package/dist/components/Text/Text.d.ts +6 -0
  253. package/dist/components/Wrapper.d.ts +6 -0
  254. package/dist/components/index.d.ts +18 -0
  255. package/dist/index.d.ts +1 -0
  256. package/dist/index.js +8 -0
  257. package/dist/web.cjs.development.js +27 -0
  258. package/dist/web.cjs.development.js.map +1 -0
  259. package/dist/web.cjs.production.min.js +2 -0
  260. package/dist/web.cjs.production.min.js.map +1 -0
  261. package/dist/web.esm.js +23 -0
  262. package/dist/web.esm.js.map +1 -0
  263. package/package.json +153 -0
  264. package/src/components/Button/Button/Button.props.ts +79 -0
  265. package/src/components/Button/Button/Button.state.ts +7 -0
  266. package/src/components/Button/Button/Button.style.ts +95 -0
  267. package/src/components/Button/Button/Button.type.d.ts +11 -0
  268. package/src/components/Button/Button/Button.view.tsx +116 -0
  269. package/src/components/Button/Button.md +165 -0
  270. package/src/components/Button/Button.tsx +24 -0
  271. package/src/components/Button/examples/AutoFocusButton.tsx +13 -0
  272. package/src/components/Button/examples/BorderedButtons.tsx +14 -0
  273. package/src/components/Button/examples/ColoredButtons.tsx +12 -0
  274. package/src/components/Button/examples/DefaultButton.tsx +4 -0
  275. package/src/components/Button/examples/DisabledButton.tsx +13 -0
  276. package/src/components/Button/examples/IconButtons.tsx +23 -0
  277. package/src/components/Button/examples/LoadingButtons.tsx +28 -0
  278. package/src/components/Button/examples/ShadowButton.tsx +6 -0
  279. package/src/components/Button/examples/SizeButtons.tsx +16 -0
  280. package/src/components/Button/examples/VariantButtons.tsx +20 -0
  281. package/src/components/Button/examples/index.ts +9 -0
  282. package/src/components/Form/Checkbox/Checkbox/Checkbox.props.ts +118 -0
  283. package/src/components/Form/Checkbox/Checkbox/Checkbox.state.ts +15 -0
  284. package/src/components/Form/Checkbox/Checkbox/Checkbox.style.ts +29 -0
  285. package/src/components/Form/Checkbox/Checkbox/Checkbox.type.d.ts +8 -0
  286. package/src/components/Form/Checkbox/Checkbox/Checkbox.view.tsx +98 -0
  287. package/src/components/Form/Checkbox/Checkbox.md +128 -0
  288. package/src/components/Form/Checkbox/Checkbox.tsx +15 -0
  289. package/src/components/Form/Checkbox/examples/ColorScheme.tsx +12 -0
  290. package/src/components/Form/Checkbox/examples/Default.tsx +5 -0
  291. package/src/components/Form/Checkbox/examples/DisabledInput.tsx +5 -0
  292. package/src/components/Form/Checkbox/examples/ErrorCheckbox.tsx +5 -0
  293. package/src/components/Form/Checkbox/examples/FormCheckout.tsx +46 -0
  294. package/src/components/Form/Checkbox/examples/IconCheckbox.tsx +8 -0
  295. package/src/components/Form/Checkbox/examples/IndeterminateCheckbox.tsx +5 -0
  296. package/src/components/Form/Checkbox/examples/ReadOnlyInput.tsx +5 -0
  297. package/src/components/Form/Checkbox/examples/Shadow.tsx +11 -0
  298. package/src/components/Form/Checkbox/examples/SizeInput.tsx +18 -0
  299. package/src/components/Form/Checkbox/examples/StylesInput.tsx +22 -0
  300. package/src/components/Form/Checkbox/examples/index.ts +11 -0
  301. package/src/components/Form/CountryPicker/CountryPicker/CountryPicker.props.ts +187 -0
  302. package/src/components/Form/CountryPicker/CountryPicker/CountryPicker.state.ts +28 -0
  303. package/src/components/Form/CountryPicker/CountryPicker/CountryPicker.style.ts +17 -0
  304. package/src/components/Form/CountryPicker/CountryPicker/CountryPicker.type.d.ts +22 -0
  305. package/src/components/Form/CountryPicker/CountryPicker/CountryPicker.view.tsx +234 -0
  306. package/src/components/Form/CountryPicker/CountryPicker.md +206 -0
  307. package/src/components/Form/CountryPicker/CountryPicker.tsx +16 -0
  308. package/src/components/Form/CountryPicker/countries.json +1453 -0
  309. package/src/components/Form/CountryPicker/examples/Color.tsx +12 -0
  310. package/src/components/Form/CountryPicker/examples/Default.tsx +4 -0
  311. package/src/components/Form/CountryPicker/examples/Disabled.tsx +5 -0
  312. package/src/components/Form/CountryPicker/examples/Error.tsx +4 -0
  313. package/src/components/Form/CountryPicker/examples/Form.tsx +23 -0
  314. package/src/components/Form/CountryPicker/examples/Formik.tsx +39 -0
  315. package/src/components/Form/CountryPicker/examples/HelperText.tsx +5 -0
  316. package/src/components/Form/CountryPicker/examples/ReadOnlyInput.tsx +5 -0
  317. package/src/components/Form/CountryPicker/examples/Shadow.tsx +4 -0
  318. package/src/components/Form/CountryPicker/examples/Shape.tsx +13 -0
  319. package/src/components/Form/CountryPicker/examples/SizeInput.tsx +16 -0
  320. package/src/components/Form/CountryPicker/examples/StylesInput.tsx +19 -0
  321. package/src/components/Form/CountryPicker/examples/Variant.tsx +13 -0
  322. package/src/components/Form/CountryPicker/examples/index.ts +12 -0
  323. package/src/components/Form/CountryPicker/styles.css +7 -0
  324. package/src/components/Form/DatePicker/DatePicker/DatePicker.props.ts +113 -0
  325. package/src/components/Form/DatePicker/DatePicker/DatePicker.state.ts +17 -0
  326. package/src/components/Form/DatePicker/DatePicker/DatePicker.style.ts +17 -0
  327. package/src/components/Form/DatePicker/DatePicker/DatePicker.type.d.ts +15 -0
  328. package/src/components/Form/DatePicker/DatePicker/DatePicker.view.tsx +118 -0
  329. package/src/components/Form/DatePicker/DatePicker.md +115 -0
  330. package/src/components/Form/DatePicker/DatePicker.tsx +15 -0
  331. package/src/components/Form/DatePicker/examples/ColorScheme.tsx +12 -0
  332. package/src/components/Form/DatePicker/examples/Default.tsx +4 -0
  333. package/src/components/Form/DatePicker/examples/DisabledInput.tsx +5 -0
  334. package/src/components/Form/DatePicker/examples/ErrorCheckbox.tsx +4 -0
  335. package/src/components/Form/DatePicker/examples/FormCheckout.tsx +23 -0
  336. package/src/components/Form/DatePicker/examples/Formik.tsx +35 -0
  337. package/src/components/Form/DatePicker/examples/ReadOnlyInput.tsx +5 -0
  338. package/src/components/Form/DatePicker/examples/Shadow.tsx +10 -0
  339. package/src/components/Form/DatePicker/examples/SizeInput.tsx +16 -0
  340. package/src/components/Form/DatePicker/examples/StylesInput.tsx +14 -0
  341. package/src/components/Form/DatePicker/examples/helperTextDatePicker.tsx +6 -0
  342. package/src/components/Form/DatePicker/examples/index.ts +11 -0
  343. package/src/components/Form/Label/Label/Label.props.ts +36 -0
  344. package/src/components/Form/Label/Label/Label.style.ts +35 -0
  345. package/src/components/Form/Label/Label/Label.type.ts +14 -0
  346. package/src/components/Form/Label/Label/Label.view.tsx +35 -0
  347. package/src/components/Form/Label/Label.tsx +8 -0
  348. package/src/components/Form/Password/Password/Password.props.ts +36 -0
  349. package/src/components/Form/Password/Password/Password.state.ts +6 -0
  350. package/src/components/Form/Password/Password/Password.type.d.ts +14 -0
  351. package/src/components/Form/Password/Password/Password.view.tsx +32 -0
  352. package/src/components/Form/Password/Password.md +108 -0
  353. package/src/components/Form/Password/Password.tsx +15 -0
  354. package/src/components/Form/Password/example/Default.tsx +9 -0
  355. package/src/components/Form/Password/example/DisabledInput.tsx +17 -0
  356. package/src/components/Form/Password/example/ErrorInput.tsx +66 -0
  357. package/src/components/Form/Password/example/FormikErrorInput.tsx +61 -0
  358. package/src/components/Form/Password/example/FormikHelperText.tsx +65 -0
  359. package/src/components/Form/Password/example/HelperText.tsx +65 -0
  360. package/src/components/Form/Select/Select/Select.props.ts +262 -0
  361. package/src/components/Form/Select/Select/Select.state.ts +19 -0
  362. package/src/components/Form/Select/Select/Select.style.ts +19 -0
  363. package/src/components/Form/Select/Select/Select.type.d.ts +15 -0
  364. package/src/components/Form/Select/Select/Select.view.tsx +342 -0
  365. package/src/components/Form/Select/Select.md +165 -0
  366. package/src/components/Form/Select/Select.tsx +16 -0
  367. package/src/components/Form/Select/examples/Color.tsx +12 -0
  368. package/src/components/Form/Select/examples/Default.tsx +4 -0
  369. package/src/components/Form/Select/examples/Disabled.tsx +5 -0
  370. package/src/components/Form/Select/examples/Error.tsx +4 -0
  371. package/src/components/Form/Select/examples/Form.tsx +23 -0
  372. package/src/components/Form/Select/examples/Formik.tsx +41 -0
  373. package/src/components/Form/Select/examples/HelperText.tsx +7 -0
  374. package/src/components/Form/Select/examples/Multiple.tsx +6 -0
  375. package/src/components/Form/Select/examples/ReadOnlyInput.tsx +5 -0
  376. package/src/components/Form/Select/examples/Shadow.tsx +11 -0
  377. package/src/components/Form/Select/examples/SizeInput.tsx +16 -0
  378. package/src/components/Form/Select/examples/StylesInput.tsx +15 -0
  379. package/src/components/Form/Switch/Switch/Switch.props.ts +91 -0
  380. package/src/components/Form/Switch/Switch/Switch.state.ts +11 -0
  381. package/src/components/Form/Switch/Switch/Switch.style.ts +72 -0
  382. package/src/components/Form/Switch/Switch/Switch.type.d.ts +6 -0
  383. package/src/components/Form/Switch/Switch/Switch.view.tsx +78 -0
  384. package/src/components/Form/Switch/Switch.md +148 -0
  385. package/src/components/Form/Switch/Switch.tsx +12 -0
  386. package/src/components/Form/Switch/examples/ChildSwitch.tsx +20 -0
  387. package/src/components/Form/Switch/examples/ColorScheme.tsx +5 -0
  388. package/src/components/Form/Switch/examples/Default.tsx +4 -0
  389. package/src/components/Form/Switch/examples/DisabledInput.tsx +7 -0
  390. package/src/components/Form/Switch/examples/FormSwitch.tsx +22 -0
  391. package/src/components/Form/Switch/examples/Formik.tsx +30 -0
  392. package/src/components/Form/Switch/examples/ReadOnlyInput.tsx +7 -0
  393. package/src/components/Form/Switch/examples/Shadow.tsx +11 -0
  394. package/src/components/Form/Switch/examples/SizeInput.tsx +21 -0
  395. package/src/components/Form/Switch/examples/StylesInput.tsx +34 -0
  396. package/src/components/Form/TextArea/TextArea/TextArea.props.ts +154 -0
  397. package/src/components/Form/TextArea/TextArea/TextArea.state.ts +21 -0
  398. package/src/components/Form/TextArea/TextArea/TextArea.type.ts +15 -0
  399. package/src/components/Form/TextArea/TextArea/TextArea.view.tsx +143 -0
  400. package/src/components/Form/TextArea/TextArea.md +169 -0
  401. package/src/components/Form/TextArea/TextArea.tsx +15 -0
  402. package/src/components/Form/TextArea/examples/ColorScheme.tsx +13 -0
  403. package/src/components/Form/TextArea/examples/Default.tsx +5 -0
  404. package/src/components/Form/TextArea/examples/DisabledInput.tsx +7 -0
  405. package/src/components/Form/TextArea/examples/ErrorInput.tsx +50 -0
  406. package/src/components/Form/TextArea/examples/FormikErrorInput.tsx +52 -0
  407. package/src/components/Form/TextArea/examples/FormikHelperText.tsx +51 -0
  408. package/src/components/Form/TextArea/examples/HelperText.tsx +49 -0
  409. package/src/components/Form/TextArea/examples/LabelInput.tsx +23 -0
  410. package/src/components/Form/TextArea/examples/MaxRowCol.tsx +7 -0
  411. package/src/components/Form/TextArea/examples/Placeholder.tsx +23 -0
  412. package/src/components/Form/TextArea/examples/ReadOnlyInput.tsx +7 -0
  413. package/src/components/Form/TextArea/examples/ShadowArea.tsx +28 -0
  414. package/src/components/Form/TextArea/examples/ShapeInput.tsx +15 -0
  415. package/src/components/Form/TextArea/examples/SizeInput.tsx +16 -0
  416. package/src/components/Form/TextArea/examples/StylesInput.tsx +34 -0
  417. package/src/components/Form/TextArea/examples/VariantsInputs.tsx +15 -0
  418. package/src/components/Form/TextArea/examples/index.ts +15 -0
  419. package/src/components/Form/TextArea/styles.css +7 -0
  420. package/src/components/Form/TextField/TextField/TextField.props.ts +134 -0
  421. package/src/components/Form/TextField/TextField/TextField.state.ts +21 -0
  422. package/src/components/Form/TextField/TextField/TextField.type.d.ts +15 -0
  423. package/src/components/Form/TextField/TextField/TextField.view.tsx +170 -0
  424. package/src/components/Form/TextField/TextField.md +193 -0
  425. package/src/components/Form/TextField/TextField.tsx +14 -0
  426. package/src/components/Form/TextField/examples/ClearInput.tsx +13 -0
  427. package/src/components/Form/TextField/examples/ColorScheme.tsx +13 -0
  428. package/src/components/Form/TextField/examples/Default.tsx +23 -0
  429. package/src/components/Form/TextField/examples/DisabledInput.tsx +7 -0
  430. package/src/components/Form/TextField/examples/ErrorInput.tsx +74 -0
  431. package/src/components/Form/TextField/examples/FormikErrorInput.tsx +76 -0
  432. package/src/components/Form/TextField/examples/FormikHelperText.tsx +62 -0
  433. package/src/components/Form/TextField/examples/HelperText.tsx +60 -0
  434. package/src/components/Form/TextField/examples/LabelInput.tsx +23 -0
  435. package/src/components/Form/TextField/examples/LeftChild.tsx +8 -0
  436. package/src/components/Form/TextField/examples/Placeholder.tsx +23 -0
  437. package/src/components/Form/TextField/examples/ReadOnlyInput.tsx +7 -0
  438. package/src/components/Form/TextField/examples/RightChild.tsx +8 -0
  439. package/src/components/Form/TextField/examples/ShapeInput.tsx +15 -0
  440. package/src/components/Form/TextField/examples/SizeInput.tsx +16 -0
  441. package/src/components/Form/TextField/examples/StylesInput.tsx +35 -0
  442. package/src/components/Form/TextField/examples/VariantsInputs.tsx +15 -0
  443. package/src/components/Form/TextField/examples/index.ts +17 -0
  444. package/src/components/Form/TextField/styles.css +7 -0
  445. package/src/components/Layout/Center/Center/Center.props.ts +18 -0
  446. package/src/components/Layout/Center/Center/Center.view.tsx +12 -0
  447. package/src/components/Layout/Center/Center.md +17 -0
  448. package/src/components/Layout/Center/Center.tsx +11 -0
  449. package/src/components/Layout/Horizontal/Horizontal/Horizontal.props.ts +26 -0
  450. package/src/components/Layout/Horizontal/Horizontal/Horizontal.view.tsx +24 -0
  451. package/src/components/Layout/Horizontal/Horizontal.md +107 -0
  452. package/src/components/Layout/Horizontal/Horizontal.tsx +11 -0
  453. package/src/components/Layout/Horizontal/examples/Default.tsx +11 -0
  454. package/src/components/Layout/Horizontal/examples/Justify.tsx +25 -0
  455. package/src/components/Layout/Horizontal/examples/Reversed.tsx +11 -0
  456. package/src/components/Layout/Horizontal/examples/Wrap.tsx +29 -0
  457. package/src/components/Layout/Horizontal/examples/index.ts +4 -0
  458. package/src/components/Layout/Input/FieldContainer/FieldContainer/FieldContainer.props.ts +25 -0
  459. package/src/components/Layout/Input/FieldContainer/FieldContainer.tsx +17 -0
  460. package/src/components/Layout/Input/FieldContent/FieldContent/FieldContent.props.ts +75 -0
  461. package/src/components/Layout/Input/FieldContent/FieldContent.tsx +55 -0
  462. package/src/components/Layout/Input/FieldIcons/FieldIcons/FieldIcons.props.ts +12 -0
  463. package/src/components/Layout/Input/FieldIcons/FieldIcons.tsx +19 -0
  464. package/src/components/Layout/Input/FieldLabel/FieldLabel/FieldLabel.props.ts +31 -0
  465. package/src/components/Layout/Input/FieldLabel/FieldLabel.tsx +30 -0
  466. package/src/components/Layout/Input/FieldLayout/FieldLayout/FieldLayout.props.ts +29 -0
  467. package/src/components/Layout/Input/FieldLayout/FieldLayout.tsx +33 -0
  468. package/src/components/Layout/Input/FieldWrapper/FieldWrapper.props.ts +12 -0
  469. package/src/components/Layout/Input/FieldWrapper/FieldWrapper.tsx +11 -0
  470. package/src/components/Layout/Input/HelperText/HelperText.props.ts +21 -0
  471. package/src/components/Layout/Input/HelperText/HelperText.tsx +22 -0
  472. package/src/components/Layout/Input/index.ts +7 -0
  473. package/src/components/Layout/Vertical/Vertical/Vertical.props.ts +26 -0
  474. package/src/components/Layout/Vertical/Vertical/Vertical.type.ts +3 -0
  475. package/src/components/Layout/Vertical/Vertical/Vertical.view.tsx +23 -0
  476. package/src/components/Layout/Vertical/Vertical.md +120 -0
  477. package/src/components/Layout/Vertical/Vertical.tsx +12 -0
  478. package/src/components/Layout/Vertical/examples/Default.tsx +11 -0
  479. package/src/components/Layout/Vertical/examples/Justify.tsx +26 -0
  480. package/src/components/Layout/Vertical/examples/Reversed.tsx +11 -0
  481. package/src/components/Layout/Vertical/examples/Wrap.tsx +30 -0
  482. package/src/components/Layout/Vertical/examples/index.tsx +5 -0
  483. package/src/components/Layout/View/View.tsx +2 -0
  484. package/src/components/Layout/configs/Input.style.ts +45 -0
  485. package/src/components/Layout/configs/Input.type.ts +18 -0
  486. package/src/components/Link/Link/Link.props.ts +50 -0
  487. package/src/components/Link/Link/Link.state.ts +6 -0
  488. package/src/components/Link/Link/Link.style.ts +14 -0
  489. package/src/components/Link/Link/Link.type.d.ts +8 -0
  490. package/src/components/Link/Link/Link.view.tsx +44 -0
  491. package/src/components/Link/Link.md +61 -0
  492. package/src/components/Link/Link.tsx +15 -0
  493. package/src/components/Link/examples/Default.tsx +5 -0
  494. package/src/components/Link/examples/IsExternal.tsx +10 -0
  495. package/src/components/Link/examples/Underline.tsx +23 -0
  496. package/src/components/Loader/Loader/Loader.props.ts +105 -0
  497. package/src/components/Loader/Loader/Loader.style.ts +25 -0
  498. package/src/components/Loader/Loader/Loader.type.d.ts +4 -0
  499. package/src/components/Loader/Loader/Loader.view.tsx +138 -0
  500. package/src/components/Loader/Loader.md +111 -0
  501. package/src/components/Loader/Loader.tsx +11 -0
  502. package/src/components/Loader/examples/ColorLoader.tsx +13 -0
  503. package/src/components/Loader/examples/DefaultLoader.tsx +4 -0
  504. package/src/components/Loader/examples/PositionLoader.tsx +19 -0
  505. package/src/components/Loader/examples/SizeLoader.tsx +12 -0
  506. package/src/components/Loader/examples/SpeedLoader.tsx +12 -0
  507. package/src/components/Loader/examples/TextLoader.tsx +8 -0
  508. package/src/components/Loader/examples/VariantLoader.tsx +12 -0
  509. package/src/components/Loader/examples/index.ts +7 -0
  510. package/src/components/Modal/Examples/BlurModal.tsx +38 -0
  511. package/src/components/Modal/Examples/CloseButtonModal.tsx +44 -0
  512. package/src/components/Modal/Examples/DefaultModal.tsx +38 -0
  513. package/src/components/Modal/Examples/FullScreenModal.tsx +28 -0
  514. package/src/components/Modal/Examples/ModalPosition.tsx +61 -0
  515. package/src/components/Modal/Examples/PreventCloseModal.tsx +27 -0
  516. package/src/components/Modal/Examples/ScrollModal.tsx +41 -0
  517. package/src/components/Modal/Examples/ShadowModal.tsx +29 -0
  518. package/src/components/Modal/Examples/VariantModal.tsx +48 -0
  519. package/src/components/Modal/Examples/index.ts +9 -0
  520. package/src/components/Modal/Modal/Modal.props.ts +202 -0
  521. package/src/components/Modal/Modal/Modal.style.ts +23 -0
  522. package/src/components/Modal/Modal/Modal.type.d.ts +7 -0
  523. package/src/components/Modal/Modal/Modal.view.tsx +169 -0
  524. package/src/components/Modal/Modal.md +509 -0
  525. package/src/components/Modal/Modal.tsx +18 -0
  526. package/src/components/Svg/ArrowDown.tsx +32 -0
  527. package/src/components/Svg/ArrowUp.tsx +32 -0
  528. package/src/components/Svg/Check.tsx +28 -0
  529. package/src/components/Svg/Close.tsx +31 -0
  530. package/src/components/Svg/CloseEye.tsx +26 -0
  531. package/src/components/Svg/DustBin.tsx +29 -0
  532. package/src/components/Svg/Edit.tsx +34 -0
  533. package/src/components/Svg/ExternalLink.tsx +31 -0
  534. package/src/components/Svg/Indeterminate.tsx +21 -0
  535. package/src/components/Svg/OpenEye.tsx +26 -0
  536. package/src/components/Svg/Profile.tsx +40 -0
  537. package/src/components/Svg/RightArrow.tsx +44 -0
  538. package/src/components/Svg/index.tsx +12 -0
  539. package/src/components/Text/Text/Text.props.ts +84 -0
  540. package/src/components/Text/Text/Text.style.ts +34 -0
  541. package/src/components/Text/Text/Text.type.d.ts +14 -0
  542. package/src/components/Text/Text/Text.view.tsx +96 -0
  543. package/src/components/Text/Text.md +163 -0
  544. package/src/components/Text/Text.tsx +13 -0
  545. package/src/components/Wrapper.tsx +19 -0
  546. package/src/components/index.tsx +18 -0
@@ -0,0 +1,342 @@
1
+ import React, { useCallback } from 'react';
2
+ import { Element } from 'app-studio';
3
+ import {Typography} from 'app-studio';
4
+ import { Horizontal, Text } from 'src/components';
5
+ import { FieldContainer } from 'src/components/Layout/Input/FieldContainer/FieldContainer';
6
+ import { FieldContent } from 'src/components/Layout/Input/FieldContent/FieldContent';
7
+ import { FieldIcons } from 'src/components/Layout/Input/FieldIcons/FieldIcons';
8
+ import { FieldLabel } from 'src/components/Layout/Input/FieldLabel/FieldLabel';
9
+ import { FieldWrapper } from 'src/components/Layout/Input/FieldWrapper/FieldWrapper';
10
+ import { ArrowDownSvg, ArrowUpSvg, CloseSvg } from 'src/components/Svg';
11
+
12
+ import {
13
+ DropDownProps,
14
+ HiddenSelectProps,
15
+ ItemProps,
16
+ MultiSelectProps,
17
+ SelectBoxProps,
18
+ SelectViewProps,
19
+ } from './Select.props';
20
+ import { useItemState } from './Select.state';
21
+ import { IconSizes } from './Select.style';
22
+
23
+ const Item: React.FC<ItemProps> = ({ isHovered, setIsHovered, option, size = 'md', callback = () => {}, ...props }) => {
24
+ const handleOptionClick = (option: string) => callback(option);
25
+ const handleHover = () => setIsHovered(!isHovered);
26
+
27
+ return (
28
+ <Element
29
+ as="li"
30
+ margin={0}
31
+ paddingVertical={8}
32
+ paddingHorizontal={12}
33
+ listStyleType="none"
34
+ onMouseEnter={handleHover}
35
+ onMouseLeave={handleHover}
36
+ fontSize={Typography.fontSizes[size]}
37
+ onPress={() => handleOptionClick(option)}
38
+ backgroundColor={isHovered ? 'trueGray.100' : 'transparent'}
39
+ {...props}
40
+ >
41
+ {option}
42
+ </Element>
43
+ );
44
+ };
45
+
46
+ const SelectBox: React.FC<SelectBoxProps> = ({
47
+ size = 'md',
48
+ styles = { field: {}, text: {} },
49
+ selected,
50
+ isDisabled,
51
+ placeholder,
52
+ removeOption = () => {},
53
+ }) => {
54
+ const fieldStyles = {
55
+ margin: 0,
56
+ width: '95%',
57
+ heigth: '100%',
58
+ border: 'none',
59
+ paddingVertical: 8,
60
+ paddingHorizontal: 0,
61
+ fontSize: Typography.fontSizes[size],
62
+ backgroundColor: 'transparent',
63
+ color: isDisabled ? 'trueGray.600' : 'blueGray.700',
64
+ cursor: isDisabled ? 'not-allowed' : 'auto',
65
+ ...styles['field'],
66
+ ...styles['text'],
67
+ };
68
+
69
+ return (
70
+ <Text {...fieldStyles}>
71
+ {(selected === '' || (selected && selected.length === 0)) && !!placeholder ? (
72
+ placeholder
73
+ ) : (
74
+ <>
75
+ {typeof selected === 'string'
76
+ ? selected
77
+ : selected &&
78
+ selected.length > 0 && (
79
+ <Horizontal gap={6}>
80
+ {selected.map((option) => (
81
+ <MultiSelect key={option} option={option} removeOption={removeOption} />
82
+ ))}
83
+ </Horizontal>
84
+ )}
85
+ </>
86
+ )}
87
+ </Text>
88
+ );
89
+ };
90
+
91
+ const HiddenSelect: React.FC<HiddenSelectProps> = ({
92
+ id,
93
+ name,
94
+ selected,
95
+ onChange,
96
+ isMulti = false,
97
+ isDisabled = false,
98
+ isReadOnly = false,
99
+ options = [],
100
+ ...props
101
+ }) => {
102
+ const handleChange = (event: any) => {
103
+ if (onChange) onChange(event);
104
+ };
105
+ return (
106
+ <Element
107
+ id={id}
108
+ name={name}
109
+ as="select"
110
+ opacity={0}
111
+ width={0}
112
+ height={0}
113
+ position="absolute"
114
+ value={selected}
115
+ disabled={isDisabled}
116
+ readOnly={isReadOnly}
117
+ onChange={handleChange}
118
+ multiple={isMulti}
119
+ {...props}
120
+ >
121
+ {options.map((option) => {
122
+ return (
123
+ <option key={option} value={option}>
124
+ {option}
125
+ </option>
126
+ );
127
+ })}
128
+ </Element>
129
+ );
130
+ };
131
+
132
+ const DropDown: React.FC<DropDownProps> = ({ size, styles = { dropDown: {} }, options, callback = () => {} }) => {
133
+ const itemStates = useItemState();
134
+ const handleCallback = (option: string) => callback(option);
135
+ const shadow =
136
+ typeof document !== undefined
137
+ ? {
138
+ boxShadow:
139
+ 'rgba(0, 0, 0, 0.07) 0px 1px 1px, rgba(0, 0, 0, 0.07) 0px 2px 2px, rgba(0, 0, 0, 0.07) 0px 4px 4px, rgba(0, 0, 0, 0.07) 0px 8px 8px, rgba(0, 0, 0, 0.07) 0px 16px 16px',
140
+ }
141
+ : {
142
+ elevation: 2,
143
+ shadowColor: 'rgba(0, 0, 0, 0.07)',
144
+ shadowOffset: {
145
+ width: 0,
146
+ height: 1,
147
+ },
148
+ shadowOpacity: 1,
149
+ shadowRadius: 1,
150
+ };
151
+ return (
152
+ <Element
153
+ as="ul"
154
+ role="dropdown"
155
+ top="100%"
156
+ width="100%"
157
+ display="flex"
158
+ zIndex={1000}
159
+ overflowY="auto"
160
+ marginTop={5}
161
+ marginLeft={0}
162
+ marginRight={0}
163
+ marginBottom={0}
164
+ padding={0}
165
+ borderRadius={4}
166
+ position="absolute"
167
+ flexDirection="column"
168
+ backgroundColor="white"
169
+ justifyContent="space-evenly"
170
+ {...shadow}
171
+ {...styles['dropDown']}
172
+ >
173
+ {options.map((option) => (
174
+ <Item key={option} size={size} option={option} callback={handleCallback} {...itemStates} {...styles['text']} />
175
+ ))}
176
+ </Element>
177
+ );
178
+ };
179
+
180
+ export const MultiSelect: React.FC<MultiSelectProps> = ({
181
+ option,
182
+ size = 'md',
183
+ removeOption = () => {},
184
+ ...props
185
+ }) => {
186
+ const handleClick = () => removeOption(option);
187
+
188
+ return (
189
+ <Horizontal
190
+ gap={10}
191
+ padding={6}
192
+ borderRadius={4}
193
+ alignItems="center"
194
+ fontSize={Typography.fontSizes[size]}
195
+ backgroundColor="trueGray.300"
196
+ onPress={(event: any) => event.stopPropagation()}
197
+ {...props}
198
+ >
199
+ <Text size={size}>{option}</Text>
200
+ <CloseSvg role="close-button" color="inherit" size={IconSizes[size]} onClick={handleClick} />
201
+ </Horizontal>
202
+ );
203
+ };
204
+
205
+ const SelectView: React.FC<SelectViewProps> = ({
206
+ id,
207
+ name,
208
+ label,
209
+ selected,
210
+ placeholder,
211
+ helperText,
212
+ hide = false,
213
+ error = false,
214
+ isMulti = false,
215
+ isFocused = false,
216
+ isHovered = false,
217
+ isDisabled = false,
218
+ isReadOnly = false,
219
+ options = [],
220
+ shadow = {},
221
+ size = 'md',
222
+ colorScheme = 'theme.primary',
223
+ shape = 'default',
224
+ variant = 'default',
225
+ styles = {
226
+ text: {},
227
+ icon: {},
228
+ dropDown: {},
229
+ selectBox: {},
230
+ label: {},
231
+ helperText: {},
232
+ },
233
+ onChange = () => {},
234
+ setHide = () => {},
235
+ setSelected = () => {},
236
+ setIsHovered = () => {},
237
+ setIsFocused = () => {},
238
+ ...props
239
+ }) => {
240
+ const isWithLabel = !!(isFocused && label);
241
+
242
+ const handleHover = () => setIsHovered(!isHovered);
243
+ const handleFocus = () => setIsFocused(true);
244
+
245
+ const handleClick = (event: React.MouseEvent<HTMLButtonElement>) => {
246
+ event.stopPropagation();
247
+ setHide(!hide);
248
+ setIsFocused(!isFocused);
249
+ };
250
+
251
+ const handleCallback = useCallback(
252
+ (option: string) => {
253
+ setHide(!hide);
254
+ if (isMulti && Array.isArray(selected)) {
255
+ !selected.includes(option) && setSelected([...selected, option]);
256
+ } else {
257
+ setSelected(option);
258
+ }
259
+ },
260
+
261
+ [hide, isMulti, selected]
262
+ );
263
+
264
+ const handleRemoveOption = (selectedOption: string) => {
265
+ if (Array.isArray(selected) && selected.includes(selectedOption)) {
266
+ const newSelected = selected.filter((option) => option !== selectedOption);
267
+ setSelected(newSelected.length === 0 ? [] : newSelected);
268
+ }
269
+ };
270
+
271
+ return (
272
+ <FieldContainer
273
+ role="SelectBox"
274
+ helperText={helperText}
275
+ error={error}
276
+ styles={styles}
277
+ onPress={isDisabled || isReadOnly ? () => {} : handleClick}
278
+ >
279
+ <FieldContent
280
+ label={label}
281
+ size={size}
282
+ error={error}
283
+ shape={shape}
284
+ styles={styles}
285
+ shadow={shadow}
286
+ variant={variant}
287
+ value={selected}
288
+ color={colorScheme}
289
+ isHovered={isHovered}
290
+ isDisabled={isDisabled}
291
+ isReadOnly={isReadOnly}
292
+ isFocused={isFocused}
293
+ isWithLabel={isWithLabel}
294
+ colorScheme={colorScheme}
295
+ onMouseEnter={handleHover}
296
+ onMouseLeave={handleHover}
297
+ >
298
+ <FieldWrapper>
299
+ {isWithLabel && (
300
+ <FieldLabel htmlFor={id} color={colorScheme} error={error} {...styles}>
301
+ {label}
302
+ </FieldLabel>
303
+ )}
304
+ <HiddenSelect
305
+ id={id}
306
+ name={name}
307
+ options={options}
308
+ onChange={onChange}
309
+ selected={selected}
310
+ isDisabled={isDisabled}
311
+ isReadOnly={isReadOnly}
312
+ isMulti={isMulti}
313
+ onFocus={handleFocus}
314
+ {...props}
315
+ />
316
+ <SelectBox
317
+ size={size}
318
+ styles={styles}
319
+ selected={selected}
320
+ isDisabled={isDisabled}
321
+ placeholder={placeholder}
322
+ removeOption={handleRemoveOption}
323
+ />
324
+ </FieldWrapper>
325
+ <FieldIcons>
326
+ {!isReadOnly && !isDisabled && (
327
+ <>
328
+ {hide ? (
329
+ <ArrowDownSvg color="inherit" size={IconSizes[size]} style={styles.icon} />
330
+ ) : (
331
+ <ArrowUpSvg color="inherit" size={IconSizes[size]} style={styles.icon} />
332
+ )}
333
+ </>
334
+ )}
335
+ </FieldIcons>
336
+ </FieldContent>
337
+ {!hide && <DropDown size={size} styles={styles} options={options} callback={handleCallback} />}
338
+ </FieldContainer>
339
+ );
340
+ };
341
+
342
+ export default SelectView;
@@ -0,0 +1,165 @@
1
+ ### **Import**
2
+
3
+ ```tsx static
4
+ import { Select } from "app-studio";
5
+ ```
6
+
7
+ ### **Default**
8
+
9
+ ```tsx
10
+ <Select label="Select an item" options={["Item1", "Item2", "Item3"]} />
11
+ ```
12
+
13
+ ### **Disabled**
14
+
15
+ “**_isDisabled_**” makes the select field unclickable.
16
+
17
+ ```tsx
18
+ <Select isDisabled options={["Item1", "Item2", "Item3"]} />
19
+ ```
20
+
21
+ ### **IsReadOnly**
22
+
23
+ “**_isReadOnly_**” makes the field readable but not writable. Can only read the element.
24
+
25
+ ```tsx
26
+ <Select options={["Item1", "Item2", "Item3"]} isReadOnly />
27
+ ```
28
+
29
+ ### **Sizes**
30
+
31
+ “**_size_**” changes the text and icon size . It has a default value of “md”.
32
+
33
+ ```tsx
34
+ import { Vertical } from "../../Layout/Vertical/Vertical";
35
+
36
+ const options = ["Item1", "Item2", "Item3"];
37
+
38
+ <Vertical gap={10}>
39
+ <Select name="xs" size="xs" placeholder="xs" options={options} />
40
+ <Select name="sm" size="sm" placeholder="sm" options={options} />
41
+ <Select name="md" size="md" placeholder="md" options={options} />
42
+ <Select name="lg" size="lg" placeholder="lg" options={options} />
43
+ <Select name="xl" size="xl" placeholder="xl" options={options} />
44
+ </Vertical>;
45
+ ```
46
+
47
+ ### **ColorScheme**
48
+
49
+ “**_colorScheme_**” modifies the border color of the select field.
50
+
51
+ ```tsx
52
+ import { Vertical } from "../../Layout/Vertical/Vertical";
53
+
54
+ <Vertical gap={15}>
55
+ {["theme.primary", "theme.secondary", "error", "success", "warning"].map((color) => (
56
+ <Select
57
+ key={color}
58
+ options={["Item1", "Item2", "Item3"]}
59
+ colorScheme={color}
60
+ />
61
+ ))}
62
+ </Vertical>;
63
+ ```
64
+
65
+ ### **Shadow**
66
+
67
+ “**_shadow_**” adds a shadow effect to the field.
68
+
69
+ ```tsx
70
+ <Select
71
+ shadow={{
72
+ boxShadow:
73
+ "rgb(204, 219, 232) 3px 3px 6px 0px inset, rgba(255, 255, 255, 0.5) -3px -3px 6px 1px inset",
74
+ }}
75
+ options={["Item1", "Item2", "Item3"]}
76
+ />
77
+ ```
78
+
79
+ ### **Multiple**
80
+
81
+ “**_isMulti_**” indicates whether the select component allows the selection of multiple options.
82
+
83
+ ```tsx
84
+ <Select
85
+ options={["Item1", "Item2", "Item3"]}
86
+ placeholder="Select an item.."
87
+ isMulti
88
+ />
89
+ ```
90
+
91
+ ### **Error**
92
+
93
+ “**error**” indicates whether the field has an error.
94
+
95
+ ```tsx
96
+ <Select options={["Item1", "Item2", "Item3"]} error />
97
+ ```
98
+
99
+ ### **HelperText**
100
+
101
+ “**_helperText_**” provides additional information about the field.
102
+
103
+ ```tsx
104
+ <Select
105
+ options={["Item1", "Item2", "Item3"]}
106
+ helperText="select one item!"
107
+ error
108
+ />
109
+ ```
110
+
111
+ ### **Styles**
112
+
113
+ “**_styles_**” changes the style of the select field.
114
+
115
+ ```tsx
116
+ <Select
117
+ colorScheme="theme.primary"
118
+ options={["Item1", "Item2", "Item3"]}
119
+ styles={{
120
+ selectBox: { borderRadius: 10, borderColor: 'theme.primary',
121
+ borderStyle: 'solid',
122
+ borderWidth: 1, },
123
+ text: { color: "theme.primary" },
124
+ label: { fontWeight: "bold", color: "theme.primary" },
125
+ }}
126
+ />
127
+ ```
128
+
129
+ ### **Default Value**
130
+
131
+ ```tsx static
132
+ const Sizes: Record<Size, CSSProperties> = {
133
+ xs: { height: 6, width: 6 },
134
+ sm: { height: 12, width: 12 },
135
+ md: { height: 18, width: 18 },
136
+ lg: { height: 24, width: 24 },
137
+ xl: { height: 30, width: 30 },
138
+ };
139
+ ```
140
+
141
+ ```tsx static
142
+ const IconSizes: Record<Size, string> = {
143
+ xs: "8px",
144
+ sm: "10px",
145
+ md: "12px",
146
+ lg: "14px",
147
+ xl: "16px",
148
+ };
149
+ ```
150
+
151
+ ### Types
152
+
153
+ ```tsx static
154
+ type Size = "xs" | "sm" | "md" | "lg" | "xl";
155
+ ```
156
+
157
+ ```tsx static
158
+ type SelectStyles = {
159
+ box?: CSSProperties;
160
+ text?: CSSProperties;
161
+ label?: CSSProperties;
162
+ helperText?: CSSProperties;
163
+ field?: CSSProperties;
164
+ };
165
+ ```
@@ -0,0 +1,16 @@
1
+ import React from 'react';
2
+
3
+ import { SelectProps } from './Select/Select.props';
4
+ import { useSelectState } from './Select/Select.state';
5
+ import SelectView from './Select/Select.view';
6
+
7
+ const SelectComponent: React.FC<SelectProps> = (props) => {
8
+ const selectStates = useSelectState(props);
9
+ return <SelectView {...selectStates} {...props} />;
10
+ };
11
+
12
+ /**
13
+ * Select provides a dropdown list of options for the user to choose from.
14
+ */
15
+
16
+ export const Select = SelectComponent;
@@ -0,0 +1,12 @@
1
+ import React from 'react';
2
+ import { Vertical } from 'src/components/Layout/Vertical/examples';
3
+
4
+ import { Select } from '../Select';
5
+
6
+ export const ColorSelect = () => (
7
+ <Vertical gap={15}>
8
+ {['theme.primary', 'theme.secondary', 'theme.error', 'theme.success', 'theme.warning'].map((color) => (
9
+ <Select key={color} options={['Item1', 'Item2', 'Item3']} colorScheme={color} />
10
+ ))}
11
+ </Vertical>
12
+ );
@@ -0,0 +1,4 @@
1
+ import React from 'react';
2
+ import { Select } from 'src/components';
3
+
4
+ export const DefaultSelect = () => <Select options={['Item1', 'Item2', 'Item3']} label="Select an item" />;
@@ -0,0 +1,5 @@
1
+ import React from 'react';
2
+
3
+ import { Select } from '../Select';
4
+
5
+ export const DisabledSelect = () => <Select isDisabled options={['Item1', 'Item2', 'Item3']} />;
@@ -0,0 +1,4 @@
1
+ import React from 'react';
2
+ import { Select } from 'src/components';
3
+
4
+ export const ErrorSelect = () => <Select id="error" name="error" error options={['Item1', 'Item2', 'Item3']} />;
@@ -0,0 +1,23 @@
1
+ import React from 'react';
2
+ import { Button } from 'src/components';
3
+ import { Vertical } from 'src/components/Layout/Vertical/examples';
4
+
5
+ import { Select } from '../Select';
6
+
7
+ export const FormSelect = () => {
8
+ const handleSubmit = (event: any) => {
9
+ event.preventDefault();
10
+ const formData = new FormData(event.target);
11
+ alert(`You selected: ${formData.getAll('formItem')}`);
12
+ };
13
+ return (
14
+ <form onSubmit={handleSubmit}>
15
+ <Vertical gap={10} width="100%">
16
+ <Select id="formItem" name="formItem" options={['Item1', 'Item2', 'Item3']} placeholder="Select an item..." />
17
+ <Button type="submit" alignSelf="center">
18
+ Submit
19
+ </Button>
20
+ </Vertical>
21
+ </form>
22
+ );
23
+ };
@@ -0,0 +1,41 @@
1
+ import React from 'react';
2
+ import { Field, Form, Formik } from 'formik';
3
+ import { Button } from 'src/components';
4
+ import { Vertical } from 'src/components/Layout/Vertical/examples';
5
+
6
+ import { Select } from '../Select';
7
+
8
+ export const FormikSelect = () => {
9
+ const options = ['Item1', 'Item2', 'Item3'];
10
+ const initialValues = {
11
+ formik: options[0],
12
+ };
13
+
14
+ const onSubmit = (values: any) => {
15
+ alert(`${values.formik}`);
16
+ };
17
+
18
+ return (
19
+ <Formik initialValues={initialValues} onSubmit={onSubmit}>
20
+ {({ values, handleChange }) => (
21
+ <Form>
22
+ <Vertical gap={10}>
23
+ <Field
24
+ id="formik"
25
+ name="formik"
26
+ as={Select}
27
+ value={values.formik}
28
+ options={options}
29
+ onChange={handleChange}
30
+ placeholder="Select an item..."
31
+ />
32
+
33
+ <Button type="submit" alignSelf="center">
34
+ Submit
35
+ </Button>
36
+ </Vertical>
37
+ </Form>
38
+ )}
39
+ </Formik>
40
+ );
41
+ };
@@ -0,0 +1,7 @@
1
+ import React from 'react';
2
+
3
+ import { Select } from '../Select';
4
+
5
+ export const HelperTextSelect = () => (
6
+ <Select options={['Item1', 'Item2', 'Item3']} helperText="select one item!" error />
7
+ );
@@ -0,0 +1,6 @@
1
+ import React from 'react';
2
+ import { Select } from 'src/components';
3
+
4
+ export const MultiSelect = () => (
5
+ <Select options={['Item1', 'Item2', 'Item3']} placeholder="Select an item.." isMulti />
6
+ );
@@ -0,0 +1,5 @@
1
+ import React from 'react';
2
+
3
+ import { Select } from '../Select';
4
+
5
+ export const ReadOnlySelect = () => <Select options={['Item1', 'Item2', 'Item3']} isReadOnly />;
@@ -0,0 +1,11 @@
1
+ import React from 'react';
2
+ import { Select } from 'src/components';
3
+
4
+ export const ShadowSelect = () => (
5
+ <Select
6
+ shadow={{
7
+ boxShadow: 'rgb(204, 219, 232) 3px 3px 6px 0px inset, rgba(255, 255, 255, 0.5) -3px -3px 6px 1px inset',
8
+ }}
9
+ options={['Item1', 'Item2', 'Item3']}
10
+ />
11
+ );
@@ -0,0 +1,16 @@
1
+ import React from 'react';
2
+ import { Vertical } from 'src/components/Layout/Vertical/examples';
3
+
4
+ import { Select } from '../Select';
5
+
6
+ export const SizeSelect = () => {
7
+ const options = ['Item1', 'Item2', 'Item3'];
8
+ return (
9
+ <Vertical gap={10}>
10
+ <Select name="sm" size="sm" placeholder="sm" options={options} />
11
+ <Select name="md" size="md" placeholder="md" options={options} />
12
+ <Select name="lg" size="lg" placeholder="lg" options={options} />
13
+ <Select name="xl" size="xl" placeholder="xl" options={options} />
14
+ </Vertical>
15
+ );
16
+ };
@@ -0,0 +1,15 @@
1
+ import React from 'react';
2
+
3
+ import { Select } from '../Select';
4
+
5
+ export const StyledSelect = () => (
6
+ <Select
7
+ colorScheme="theme.primary"
8
+ options={['Item1', 'Item2', 'Item3']}
9
+ styles={{
10
+ selectBox: { borderRadius: 10, border: '1px solid purple' },
11
+ text: { color: 'theme.primary' },
12
+ label: { fontWeight: 'bold', color: 'theme.primary' },
13
+ }}
14
+ />
15
+ );