@elliemae/ds-form 3.5.0-rc.2 → 3.5.0-rc.5

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 (398) hide show
  1. package/dist/cjs/Checkbox/index.js +4 -1
  2. package/dist/cjs/Checkbox/index.js.map +1 -1
  3. package/dist/cjs/CheckboxGroup/DSCheckboxGroup.js +15 -8
  4. package/dist/cjs/CheckboxGroup/DSCheckboxGroup.js.map +2 -2
  5. package/dist/cjs/CheckboxGroup/defaultProps.js +4 -1
  6. package/dist/cjs/CheckboxGroup/defaultProps.js.map +1 -1
  7. package/dist/cjs/CheckboxGroup/index.js +4 -1
  8. package/dist/cjs/CheckboxGroup/index.js.map +1 -1
  9. package/dist/cjs/CheckboxGroup/props.js +12 -5
  10. package/dist/cjs/CheckboxGroup/props.js.map +2 -2
  11. package/dist/cjs/ComboBox/index.js +4 -1
  12. package/dist/cjs/ComboBox/index.js.map +1 -1
  13. package/dist/cjs/ComboBoxFreeSolo/ComboBoxFreeSolo.js +4 -1
  14. package/dist/cjs/ComboBoxFreeSolo/ComboBoxFreeSolo.js.map +2 -2
  15. package/dist/cjs/ComboBoxFreeSolo/components/MultiValueLabel.js +4 -1
  16. package/dist/cjs/ComboBoxFreeSolo/components/MultiValueLabel.js.map +2 -2
  17. package/dist/cjs/ComboBoxFreeSolo/components/MultiValueRemove.js +4 -1
  18. package/dist/cjs/ComboBoxFreeSolo/components/MultiValueRemove.js.map +2 -2
  19. package/dist/cjs/ComboBoxFreeSolo/components/SingleValue.js +4 -1
  20. package/dist/cjs/ComboBoxFreeSolo/components/SingleValue.js.map +2 -2
  21. package/dist/cjs/ComboBoxFreeSolo/components/SingleValueRemove.js +4 -1
  22. package/dist/cjs/ComboBoxFreeSolo/components/SingleValueRemove.js.map +2 -2
  23. package/dist/cjs/ComboBoxFreeSolo/index.js +4 -1
  24. package/dist/cjs/ComboBoxFreeSolo/index.js.map +1 -1
  25. package/dist/cjs/DateInput/DSDateInput.js +4 -1
  26. package/dist/cjs/DateInput/DSDateInput.js.map +2 -2
  27. package/dist/cjs/DateInput/components/DateInputImpl.js +4 -1
  28. package/dist/cjs/DateInput/components/DateInputImpl.js.map +2 -2
  29. package/dist/cjs/DateInput/components/DateInputs.js +25 -10
  30. package/dist/cjs/DateInput/components/DateInputs.js.map +2 -2
  31. package/dist/cjs/DateInput/components/utils.js +4 -1
  32. package/dist/cjs/DateInput/components/utils.js.map +2 -2
  33. package/dist/cjs/DateInput/defaultProps.js +4 -1
  34. package/dist/cjs/DateInput/defaultProps.js.map +1 -1
  35. package/dist/cjs/DateInput/index.js +4 -1
  36. package/dist/cjs/DateInput/index.js.map +1 -1
  37. package/dist/cjs/DateInput/props.js +34 -11
  38. package/dist/cjs/DateInput/props.js.map +1 -1
  39. package/dist/cjs/DateInputV2/components/DSDateInput.js +4 -1
  40. package/dist/cjs/DateInputV2/components/DSDateInput.js.map +2 -2
  41. package/dist/cjs/DateInputV2/components/DateInputs.js +16 -7
  42. package/dist/cjs/DateInputV2/components/DateInputs.js.map +2 -2
  43. package/dist/cjs/DateInputV2/components/helpers.js +4 -1
  44. package/dist/cjs/DateInputV2/components/helpers.js.map +1 -1
  45. package/dist/cjs/DateInputV2/components/props.js +28 -9
  46. package/dist/cjs/DateInputV2/components/props.js.map +1 -1
  47. package/dist/cjs/DateInputV2/components/propsTypes.js +4 -1
  48. package/dist/cjs/DateInputV2/components/propsTypes.js.map +2 -2
  49. package/dist/cjs/DateInputV2/components/styled.js +4 -1
  50. package/dist/cjs/DateInputV2/components/styled.js.map +1 -1
  51. package/dist/cjs/DateInputV2/components/utils.js +8 -2
  52. package/dist/cjs/DateInputV2/components/utils.js.map +2 -2
  53. package/dist/cjs/DateInputV2/index.js +4 -1
  54. package/dist/cjs/DateInputV2/index.js.map +1 -1
  55. package/dist/cjs/ExpandableInput/DSExpandableInput.js +4 -1
  56. package/dist/cjs/ExpandableInput/DSExpandableInput.js.map +2 -2
  57. package/dist/cjs/ExpandableInput/ExpandableInputImpl.js +4 -1
  58. package/dist/cjs/ExpandableInput/ExpandableInputImpl.js.map +2 -2
  59. package/dist/cjs/ExpandableInput/index.js +4 -1
  60. package/dist/cjs/ExpandableInput/index.js.map +1 -1
  61. package/dist/cjs/FloatingLabelInput/DSFloatingLabelInput.js +4 -1
  62. package/dist/cjs/FloatingLabelInput/DSFloatingLabelInput.js.map +2 -2
  63. package/dist/cjs/FloatingLabelInput/FloatingLabelInputImpl.js +4 -1
  64. package/dist/cjs/FloatingLabelInput/FloatingLabelInputImpl.js.map +2 -2
  65. package/dist/cjs/FloatingLabelInput/getSvgPath.js +4 -1
  66. package/dist/cjs/FloatingLabelInput/getSvgPath.js.map +1 -1
  67. package/dist/cjs/FloatingLabelInput/index.js +4 -1
  68. package/dist/cjs/FloatingLabelInput/index.js.map +1 -1
  69. package/dist/cjs/FormItem/DSFormItemLayout.js +4 -1
  70. package/dist/cjs/FormItem/DSFormItemLayout.js.map +2 -2
  71. package/dist/cjs/FormItem/Error/DSError.js +4 -1
  72. package/dist/cjs/FormItem/Error/DSError.js.map +2 -2
  73. package/dist/cjs/FormItem/Feedback.js +4 -1
  74. package/dist/cjs/FormItem/Feedback.js.map +2 -2
  75. package/dist/cjs/FormItem/Label/DSLabel.js +4 -1
  76. package/dist/cjs/FormItem/Label/DSLabel.js.map +2 -2
  77. package/dist/cjs/FormItem/Suffix/Suffix.js +4 -1
  78. package/dist/cjs/FormItem/Suffix/Suffix.js.map +1 -1
  79. package/dist/cjs/FormItem/ValidationFieldWrapper.js +4 -1
  80. package/dist/cjs/FormItem/ValidationFieldWrapper.js.map +1 -1
  81. package/dist/cjs/FormItem/defaultProps.js +4 -1
  82. package/dist/cjs/FormItem/defaultProps.js.map +1 -1
  83. package/dist/cjs/FormItem/index.js +4 -1
  84. package/dist/cjs/FormItem/index.js.map +1 -1
  85. package/dist/cjs/FormItem/props.js +10 -3
  86. package/dist/cjs/FormItem/props.js.map +1 -1
  87. package/dist/cjs/FormItem/variants.js +4 -1
  88. package/dist/cjs/FormItem/variants.js.map +1 -1
  89. package/dist/cjs/Input/DSInput.js +4 -1
  90. package/dist/cjs/Input/DSInput.js.map +1 -1
  91. package/dist/cjs/Input/InputAddonWrapper.js +4 -1
  92. package/dist/cjs/Input/InputAddonWrapper.js.map +1 -1
  93. package/dist/cjs/Input/InputImpl.js +4 -1
  94. package/dist/cjs/Input/InputImpl.js.map +1 -1
  95. package/dist/cjs/Input/index.js +4 -1
  96. package/dist/cjs/Input/index.js.map +1 -1
  97. package/dist/cjs/InputGroup/AddonWrapper.js +4 -1
  98. package/dist/cjs/InputGroup/AddonWrapper.js.map +2 -2
  99. package/dist/cjs/InputGroup/DSInputGroup.js +4 -1
  100. package/dist/cjs/InputGroup/DSInputGroup.js.map +2 -2
  101. package/dist/cjs/InputGroup/defaultProps.js +4 -1
  102. package/dist/cjs/InputGroup/defaultProps.js.map +1 -1
  103. package/dist/cjs/InputGroup/index.js +4 -1
  104. package/dist/cjs/InputGroup/index.js.map +1 -1
  105. package/dist/cjs/InputGroup/props.js +13 -4
  106. package/dist/cjs/InputGroup/props.js.map +1 -1
  107. package/dist/cjs/InputMask/DSInputMask.js +16 -6
  108. package/dist/cjs/InputMask/DSInputMask.js.map +2 -2
  109. package/dist/cjs/InputMask/DSInputMaskDeprecated.js +41 -32
  110. package/dist/cjs/InputMask/DSInputMaskDeprecated.js.map +2 -2
  111. package/dist/cjs/InputMask/InputMaskContext.js +4 -1
  112. package/dist/cjs/InputMask/InputMaskContext.js.map +2 -2
  113. package/dist/cjs/InputMask/MaskPipes.js +4 -1
  114. package/dist/cjs/InputMask/MaskPipes.js.map +1 -1
  115. package/dist/cjs/InputMask/MaskTypes.js +4 -1
  116. package/dist/cjs/InputMask/MaskTypes.js.map +1 -1
  117. package/dist/cjs/InputMask/addons/AutoCorrectedDatePipe.js +16 -4
  118. package/dist/cjs/InputMask/addons/AutoCorrectedDatePipe.js.map +1 -1
  119. package/dist/cjs/InputMask/defaultProps.js +4 -1
  120. package/dist/cjs/InputMask/defaultProps.js.map +1 -1
  121. package/dist/cjs/InputMask/index.js +4 -1
  122. package/dist/cjs/InputMask/index.js.map +1 -1
  123. package/dist/cjs/InputMask/mask_types/DateInputMask.js +51 -32
  124. package/dist/cjs/InputMask/mask_types/DateInputMask.js.map +2 -2
  125. package/dist/cjs/InputMask/mask_types/DateTimeInputMask.js +51 -32
  126. package/dist/cjs/InputMask/mask_types/DateTimeInputMask.js.map +2 -2
  127. package/dist/cjs/InputMask/mask_types/DictionaryInputMask.js +56 -33
  128. package/dist/cjs/InputMask/mask_types/DictionaryInputMask.js.map +2 -2
  129. package/dist/cjs/InputMask/mask_types/NumberInputMask.js +73 -55
  130. package/dist/cjs/InputMask/mask_types/NumberInputMask.js.map +2 -2
  131. package/dist/cjs/InputMask/mask_types/PhoneInputMask.js +51 -32
  132. package/dist/cjs/InputMask/mask_types/PhoneInputMask.js.map +2 -2
  133. package/dist/cjs/InputMask/mask_types/PhoneInternationalInputMask.js +51 -32
  134. package/dist/cjs/InputMask/mask_types/PhoneInternationalInputMask.js.map +2 -2
  135. package/dist/cjs/InputMask/mask_types/SsnInputMask.js +51 -32
  136. package/dist/cjs/InputMask/mask_types/SsnInputMask.js.map +2 -2
  137. package/dist/cjs/InputMask/mask_types/UsZipCodeInputMask.js +47 -32
  138. package/dist/cjs/InputMask/mask_types/UsZipCodeInputMask.js.map +2 -2
  139. package/dist/cjs/InputMask/mask_types/ZipCodeSearchInputMask.js +51 -32
  140. package/dist/cjs/InputMask/mask_types/ZipCodeSearchInputMask.js.map +2 -2
  141. package/dist/cjs/InputMask/mask_types/index.js +4 -1
  142. package/dist/cjs/InputMask/mask_types/index.js.map +2 -2
  143. package/dist/cjs/InputMask/props.js +65 -22
  144. package/dist/cjs/InputMask/props.js.map +1 -1
  145. package/dist/cjs/InputMask/types/index.js +4 -1
  146. package/dist/cjs/InputMask/types/index.js.map +1 -1
  147. package/dist/cjs/InputMask/utils/setCaretPosition.js +4 -1
  148. package/dist/cjs/InputMask/utils/setCaretPosition.js.map +1 -1
  149. package/dist/cjs/InputProtected/DSInputProtected.js +4 -1
  150. package/dist/cjs/InputProtected/DSInputProtected.js.map +2 -2
  151. package/dist/cjs/InputProtected/defaultProps.js +4 -1
  152. package/dist/cjs/InputProtected/defaultProps.js.map +1 -1
  153. package/dist/cjs/InputProtected/index.js +4 -1
  154. package/dist/cjs/InputProtected/index.js.map +1 -1
  155. package/dist/cjs/InputProtected/options.js +4 -1
  156. package/dist/cjs/InputProtected/options.js.map +1 -1
  157. package/dist/cjs/InputProtected/props.js +17 -6
  158. package/dist/cjs/InputProtected/props.js.map +1 -1
  159. package/dist/cjs/LargeInputText/DSLargeInputText.js +18 -6
  160. package/dist/cjs/LargeInputText/DSLargeInputText.js.map +2 -2
  161. package/dist/cjs/LargeInputText/defaultProps.js +4 -1
  162. package/dist/cjs/LargeInputText/defaultProps.js.map +1 -1
  163. package/dist/cjs/LargeInputText/index.js +4 -1
  164. package/dist/cjs/LargeInputText/index.js.map +1 -1
  165. package/dist/cjs/LargeInputText/props.js +46 -15
  166. package/dist/cjs/LargeInputText/props.js.map +1 -1
  167. package/dist/cjs/MenuItem/components/MenuItem/index.js +4 -1
  168. package/dist/cjs/MenuItem/components/MenuItem/index.js.map +1 -1
  169. package/dist/cjs/MenuItem/components/MenuItem/styled.js +4 -1
  170. package/dist/cjs/MenuItem/components/MenuItem/styled.js.map +1 -1
  171. package/dist/cjs/MenuItem/components/MultiMenuItem/MultiMenuItem.js +4 -1
  172. package/dist/cjs/MenuItem/components/MultiMenuItem/MultiMenuItem.js.map +1 -1
  173. package/dist/cjs/MenuItem/components/MultiMenuItem/styled.js +4 -1
  174. package/dist/cjs/MenuItem/components/MultiMenuItem/styled.js.map +1 -1
  175. package/dist/cjs/MenuItem/components/Section/index.js +4 -1
  176. package/dist/cjs/MenuItem/components/Section/index.js.map +1 -1
  177. package/dist/cjs/MenuItem/components/Section/props.js +4 -1
  178. package/dist/cjs/MenuItem/components/Section/props.js.map +1 -1
  179. package/dist/cjs/MenuItem/components/Section/styled.js +4 -1
  180. package/dist/cjs/MenuItem/components/Section/styled.js.map +1 -1
  181. package/dist/cjs/MenuItem/components/Separator/index.js +4 -1
  182. package/dist/cjs/MenuItem/components/Separator/index.js.map +1 -1
  183. package/dist/cjs/MenuItem/components/Separator/styled.js +4 -1
  184. package/dist/cjs/MenuItem/components/Separator/styled.js.map +1 -1
  185. package/dist/cjs/MenuItem/components/SingleMenuItem/SingleMenuItem.js +4 -1
  186. package/dist/cjs/MenuItem/components/SingleMenuItem/SingleMenuItem.js.map +1 -1
  187. package/dist/cjs/MenuItem/components/SubmenuItem/index.js +4 -1
  188. package/dist/cjs/MenuItem/components/SubmenuItem/index.js.map +1 -1
  189. package/dist/cjs/MenuItem/components/SubmenuItem/styled.js +4 -1
  190. package/dist/cjs/MenuItem/components/SubmenuItem/styled.js.map +1 -1
  191. package/dist/cjs/MenuItem/components/index.js +4 -1
  192. package/dist/cjs/MenuItem/components/index.js.map +1 -1
  193. package/dist/cjs/MenuItem/components/styled.js +4 -1
  194. package/dist/cjs/MenuItem/components/styled.js.map +1 -1
  195. package/dist/cjs/MenuItem/index.js +4 -1
  196. package/dist/cjs/MenuItem/index.js.map +1 -1
  197. package/dist/cjs/MenuItem/props.js +4 -1
  198. package/dist/cjs/MenuItem/props.js.map +1 -1
  199. package/dist/cjs/Radio/Circle.js +4 -1
  200. package/dist/cjs/Radio/Circle.js.map +2 -2
  201. package/dist/cjs/Radio/DSRadio.js +7 -2
  202. package/dist/cjs/Radio/DSRadio.js.map +2 -2
  203. package/dist/cjs/Radio/index.js +4 -1
  204. package/dist/cjs/Radio/index.js.map +1 -1
  205. package/dist/cjs/RadioGroup/DSRadioGroup.js +15 -8
  206. package/dist/cjs/RadioGroup/DSRadioGroup.js.map +2 -2
  207. package/dist/cjs/RadioGroup/defaultProps.js +4 -1
  208. package/dist/cjs/RadioGroup/defaultProps.js.map +1 -1
  209. package/dist/cjs/RadioGroup/index.js +4 -1
  210. package/dist/cjs/RadioGroup/index.js.map +1 -1
  211. package/dist/cjs/RadioGroup/props.js +4 -1
  212. package/dist/cjs/RadioGroup/props.js.map +2 -2
  213. package/dist/cjs/RequiredMark/RequiredMark.js +4 -1
  214. package/dist/cjs/RequiredMark/RequiredMark.js.map +2 -2
  215. package/dist/cjs/RequiredMark/index.js +4 -1
  216. package/dist/cjs/RequiredMark/index.js.map +1 -1
  217. package/dist/cjs/SearchBox/index.js +4 -1
  218. package/dist/cjs/SearchBox/index.js.map +1 -1
  219. package/dist/cjs/TextBox/index.js +4 -1
  220. package/dist/cjs/TextBox/index.js.map +1 -1
  221. package/dist/cjs/TimeInput/DSTimeInput.js +19 -6
  222. package/dist/cjs/TimeInput/DSTimeInput.js.map +2 -2
  223. package/dist/cjs/TimeInput/TimeInputImpl.js +7 -2
  224. package/dist/cjs/TimeInput/TimeInputImpl.js.map +2 -2
  225. package/dist/cjs/TimeInput/TimeInputs.js +15 -9
  226. package/dist/cjs/TimeInput/TimeInputs.js.map +2 -2
  227. package/dist/cjs/TimeInput/index.js +4 -1
  228. package/dist/cjs/TimeInput/index.js.map +1 -1
  229. package/dist/cjs/TimeInput/utils.js +4 -1
  230. package/dist/cjs/TimeInput/utils.js.map +2 -2
  231. package/dist/cjs/Toggle/DSToggle.js +4 -1
  232. package/dist/cjs/Toggle/DSToggle.js.map +2 -2
  233. package/dist/cjs/Toggle/DSToggleImpl.js +4 -1
  234. package/dist/cjs/Toggle/DSToggleImpl.js.map +2 -2
  235. package/dist/cjs/Toggle/DSToggleRender.js +7 -2
  236. package/dist/cjs/Toggle/DSToggleRender.js.map +2 -2
  237. package/dist/cjs/Toggle/index.js +4 -1
  238. package/dist/cjs/Toggle/index.js.map +1 -1
  239. package/dist/cjs/Toggle/props.js +4 -1
  240. package/dist/cjs/Toggle/props.js.map +2 -2
  241. package/dist/cjs/Toggle/toggleHelper.js +4 -1
  242. package/dist/cjs/Toggle/toggleHelper.js.map +1 -1
  243. package/dist/cjs/index.js +4 -1
  244. package/dist/cjs/index.js.map +1 -1
  245. package/dist/esm/Checkbox/index.js.map +1 -1
  246. package/dist/esm/CheckboxGroup/DSCheckboxGroup.js +11 -7
  247. package/dist/esm/CheckboxGroup/DSCheckboxGroup.js.map +2 -2
  248. package/dist/esm/CheckboxGroup/defaultProps.js.map +1 -1
  249. package/dist/esm/CheckboxGroup/index.js.map +1 -1
  250. package/dist/esm/CheckboxGroup/props.js +8 -4
  251. package/dist/esm/CheckboxGroup/props.js.map +1 -1
  252. package/dist/esm/ComboBox/index.js.map +1 -1
  253. package/dist/esm/ComboBoxFreeSolo/ComboBoxFreeSolo.js.map +2 -2
  254. package/dist/esm/ComboBoxFreeSolo/components/MultiValueLabel.js.map +2 -2
  255. package/dist/esm/ComboBoxFreeSolo/components/MultiValueRemove.js.map +2 -2
  256. package/dist/esm/ComboBoxFreeSolo/components/SingleValue.js.map +2 -2
  257. package/dist/esm/ComboBoxFreeSolo/components/SingleValueRemove.js.map +2 -2
  258. package/dist/esm/ComboBoxFreeSolo/index.js.map +1 -1
  259. package/dist/esm/DateInput/DSDateInput.js.map +2 -2
  260. package/dist/esm/DateInput/components/DateInputImpl.js.map +2 -2
  261. package/dist/esm/DateInput/components/DateInputs.js +21 -9
  262. package/dist/esm/DateInput/components/DateInputs.js.map +2 -2
  263. package/dist/esm/DateInput/components/utils.js.map +1 -1
  264. package/dist/esm/DateInput/defaultProps.js.map +1 -1
  265. package/dist/esm/DateInput/index.js.map +1 -1
  266. package/dist/esm/DateInput/props.js +30 -10
  267. package/dist/esm/DateInput/props.js.map +1 -1
  268. package/dist/esm/DateInputV2/components/DSDateInput.js.map +2 -2
  269. package/dist/esm/DateInputV2/components/DateInputs.js +12 -6
  270. package/dist/esm/DateInputV2/components/DateInputs.js.map +2 -2
  271. package/dist/esm/DateInputV2/components/helpers.js.map +1 -1
  272. package/dist/esm/DateInputV2/components/props.js +24 -8
  273. package/dist/esm/DateInputV2/components/props.js.map +1 -1
  274. package/dist/esm/DateInputV2/components/propsTypes.js.map +1 -1
  275. package/dist/esm/DateInputV2/components/styled.js.map +1 -1
  276. package/dist/esm/DateInputV2/components/utils.js +4 -1
  277. package/dist/esm/DateInputV2/components/utils.js.map +1 -1
  278. package/dist/esm/DateInputV2/index.js.map +1 -1
  279. package/dist/esm/ExpandableInput/DSExpandableInput.js.map +2 -2
  280. package/dist/esm/ExpandableInput/ExpandableInputImpl.js.map +2 -2
  281. package/dist/esm/ExpandableInput/index.js.map +1 -1
  282. package/dist/esm/FloatingLabelInput/DSFloatingLabelInput.js.map +2 -2
  283. package/dist/esm/FloatingLabelInput/FloatingLabelInputImpl.js.map +2 -2
  284. package/dist/esm/FloatingLabelInput/getSvgPath.js.map +1 -1
  285. package/dist/esm/FloatingLabelInput/index.js.map +1 -1
  286. package/dist/esm/FormItem/DSFormItemLayout.js.map +2 -2
  287. package/dist/esm/FormItem/Error/DSError.js.map +2 -2
  288. package/dist/esm/FormItem/Feedback.js.map +2 -2
  289. package/dist/esm/FormItem/Label/DSLabel.js.map +2 -2
  290. package/dist/esm/FormItem/Suffix/Suffix.js.map +1 -1
  291. package/dist/esm/FormItem/ValidationFieldWrapper.js.map +1 -1
  292. package/dist/esm/FormItem/defaultProps.js.map +1 -1
  293. package/dist/esm/FormItem/index.js.map +2 -2
  294. package/dist/esm/FormItem/props.js +6 -2
  295. package/dist/esm/FormItem/props.js.map +1 -1
  296. package/dist/esm/FormItem/variants.js.map +1 -1
  297. package/dist/esm/Input/DSInput.js.map +1 -1
  298. package/dist/esm/Input/InputAddonWrapper.js.map +1 -1
  299. package/dist/esm/Input/InputImpl.js.map +1 -1
  300. package/dist/esm/Input/index.js.map +2 -2
  301. package/dist/esm/InputGroup/AddonWrapper.js.map +2 -2
  302. package/dist/esm/InputGroup/DSInputGroup.js.map +2 -2
  303. package/dist/esm/InputGroup/defaultProps.js.map +1 -1
  304. package/dist/esm/InputGroup/index.js.map +2 -2
  305. package/dist/esm/InputGroup/props.js +9 -3
  306. package/dist/esm/InputGroup/props.js.map +1 -1
  307. package/dist/esm/InputMask/DSInputMask.js +12 -5
  308. package/dist/esm/InputMask/DSInputMask.js.map +2 -2
  309. package/dist/esm/InputMask/DSInputMaskDeprecated.js +37 -31
  310. package/dist/esm/InputMask/DSInputMaskDeprecated.js.map +2 -2
  311. package/dist/esm/InputMask/InputMaskContext.js.map +2 -2
  312. package/dist/esm/InputMask/MaskPipes.js.map +1 -1
  313. package/dist/esm/InputMask/MaskTypes.js.map +1 -1
  314. package/dist/esm/InputMask/addons/AutoCorrectedDatePipe.js +12 -3
  315. package/dist/esm/InputMask/addons/AutoCorrectedDatePipe.js.map +1 -1
  316. package/dist/esm/InputMask/defaultProps.js.map +1 -1
  317. package/dist/esm/InputMask/index.js.map +1 -1
  318. package/dist/esm/InputMask/mask_types/DateInputMask.js +47 -31
  319. package/dist/esm/InputMask/mask_types/DateInputMask.js.map +2 -2
  320. package/dist/esm/InputMask/mask_types/DateTimeInputMask.js +47 -31
  321. package/dist/esm/InputMask/mask_types/DateTimeInputMask.js.map +2 -2
  322. package/dist/esm/InputMask/mask_types/DictionaryInputMask.js +52 -32
  323. package/dist/esm/InputMask/mask_types/DictionaryInputMask.js.map +2 -2
  324. package/dist/esm/InputMask/mask_types/NumberInputMask.js +69 -54
  325. package/dist/esm/InputMask/mask_types/NumberInputMask.js.map +2 -2
  326. package/dist/esm/InputMask/mask_types/PhoneInputMask.js +47 -31
  327. package/dist/esm/InputMask/mask_types/PhoneInputMask.js.map +2 -2
  328. package/dist/esm/InputMask/mask_types/PhoneInternationalInputMask.js +47 -31
  329. package/dist/esm/InputMask/mask_types/PhoneInternationalInputMask.js.map +2 -2
  330. package/dist/esm/InputMask/mask_types/SsnInputMask.js +47 -31
  331. package/dist/esm/InputMask/mask_types/SsnInputMask.js.map +2 -2
  332. package/dist/esm/InputMask/mask_types/UsZipCodeInputMask.js +43 -31
  333. package/dist/esm/InputMask/mask_types/UsZipCodeInputMask.js.map +2 -2
  334. package/dist/esm/InputMask/mask_types/ZipCodeSearchInputMask.js +47 -31
  335. package/dist/esm/InputMask/mask_types/ZipCodeSearchInputMask.js.map +2 -2
  336. package/dist/esm/InputMask/mask_types/index.js.map +2 -2
  337. package/dist/esm/InputMask/props.js +61 -21
  338. package/dist/esm/InputMask/props.js.map +1 -1
  339. package/dist/esm/InputMask/types/index.js.map +1 -1
  340. package/dist/esm/InputMask/utils/setCaretPosition.js.map +1 -1
  341. package/dist/esm/InputProtected/DSInputProtected.js.map +2 -2
  342. package/dist/esm/InputProtected/defaultProps.js.map +1 -1
  343. package/dist/esm/InputProtected/index.js.map +1 -1
  344. package/dist/esm/InputProtected/options.js.map +1 -1
  345. package/dist/esm/InputProtected/props.js +13 -5
  346. package/dist/esm/InputProtected/props.js.map +1 -1
  347. package/dist/esm/LargeInputText/DSLargeInputText.js +14 -5
  348. package/dist/esm/LargeInputText/DSLargeInputText.js.map +2 -2
  349. package/dist/esm/LargeInputText/defaultProps.js.map +1 -1
  350. package/dist/esm/LargeInputText/index.js.map +2 -2
  351. package/dist/esm/LargeInputText/props.js +42 -14
  352. package/dist/esm/LargeInputText/props.js.map +1 -1
  353. package/dist/esm/MenuItem/components/MenuItem/index.js.map +1 -1
  354. package/dist/esm/MenuItem/components/MenuItem/styled.js.map +1 -1
  355. package/dist/esm/MenuItem/components/MultiMenuItem/MultiMenuItem.js.map +1 -1
  356. package/dist/esm/MenuItem/components/MultiMenuItem/styled.js.map +1 -1
  357. package/dist/esm/MenuItem/components/Section/index.js.map +1 -1
  358. package/dist/esm/MenuItem/components/Section/props.js.map +1 -1
  359. package/dist/esm/MenuItem/components/Section/styled.js.map +1 -1
  360. package/dist/esm/MenuItem/components/Separator/index.js.map +1 -1
  361. package/dist/esm/MenuItem/components/Separator/styled.js.map +1 -1
  362. package/dist/esm/MenuItem/components/SingleMenuItem/SingleMenuItem.js.map +1 -1
  363. package/dist/esm/MenuItem/components/SubmenuItem/index.js.map +1 -1
  364. package/dist/esm/MenuItem/components/SubmenuItem/styled.js.map +1 -1
  365. package/dist/esm/MenuItem/components/index.js.map +1 -1
  366. package/dist/esm/MenuItem/components/styled.js.map +1 -1
  367. package/dist/esm/MenuItem/index.js.map +1 -1
  368. package/dist/esm/MenuItem/props.js.map +1 -1
  369. package/dist/esm/Radio/Circle.js.map +2 -2
  370. package/dist/esm/Radio/DSRadio.js +3 -1
  371. package/dist/esm/Radio/DSRadio.js.map +2 -2
  372. package/dist/esm/Radio/index.js.map +1 -1
  373. package/dist/esm/RadioGroup/DSRadioGroup.js +11 -7
  374. package/dist/esm/RadioGroup/DSRadioGroup.js.map +2 -2
  375. package/dist/esm/RadioGroup/defaultProps.js.map +1 -1
  376. package/dist/esm/RadioGroup/index.js.map +1 -1
  377. package/dist/esm/RadioGroup/props.js.map +1 -1
  378. package/dist/esm/RequiredMark/RequiredMark.js.map +2 -2
  379. package/dist/esm/RequiredMark/index.js.map +1 -1
  380. package/dist/esm/SearchBox/index.js.map +1 -1
  381. package/dist/esm/TextBox/index.js.map +1 -1
  382. package/dist/esm/TimeInput/DSTimeInput.js +15 -5
  383. package/dist/esm/TimeInput/DSTimeInput.js.map +2 -2
  384. package/dist/esm/TimeInput/TimeInputImpl.js +3 -1
  385. package/dist/esm/TimeInput/TimeInputImpl.js.map +2 -2
  386. package/dist/esm/TimeInput/TimeInputs.js +11 -8
  387. package/dist/esm/TimeInput/TimeInputs.js.map +2 -2
  388. package/dist/esm/TimeInput/index.js.map +1 -1
  389. package/dist/esm/TimeInput/utils.js.map +1 -1
  390. package/dist/esm/Toggle/DSToggle.js.map +2 -2
  391. package/dist/esm/Toggle/DSToggleImpl.js.map +2 -2
  392. package/dist/esm/Toggle/DSToggleRender.js +3 -1
  393. package/dist/esm/Toggle/DSToggleRender.js.map +2 -2
  394. package/dist/esm/Toggle/index.js.map +2 -2
  395. package/dist/esm/Toggle/props.js.map +1 -1
  396. package/dist/esm/Toggle/toggleHelper.js.map +1 -1
  397. package/dist/esm/index.js.map +1 -1
  398. package/package.json +12 -12
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../../../../../scripts/build/transpile/react-shim.js", "../../../src/InputMask/MaskTypes.tsx"],
4
4
  "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "/* eslint-disable no-unused-vars */\n\nexport const MASK_TYPES = {\n DATE: 'ds-mask-date',\n DATE_DEPRECATED: [/\\d/, /\\d/, '/', /\\d/, /\\d/, '/', /\\d/, /\\d/, /\\d/, /\\d/],\n DATE_TIME: 'ds-mask-date-time',\n DATE_TIME_DEPRECATED: [\n /\\d/,\n /\\d/,\n '/',\n /\\d/,\n /\\d/,\n '/',\n /\\d/,\n /\\d/,\n /\\d/,\n /\\d/,\n ' ',\n /[0-2]/,\n /[0-9]/,\n ':',\n /[0-5]/,\n /[0-9]/,\n ],\n DICTIONARY: (props) => ({ type: 'ds-mask-dictionary', ...props }),\n PHONE: 'ds-mask-phone',\n PHONE_INTENATIONAL: 'ds-mask-phone-international',\n SSN: 'ds-mask-ssn',\n US_ZIP_CODE: 'ds-mask-us-zip-code',\n ZIP_CODE_SEARCH: 'ds-mask-zip-code-search',\n NUMBER: (props) => (_number) => ({ type: 'ds-mask-number', ...props }),\n PERCENT: (props) => (_number) => ({ type: 'ds-mask-percent', ...props }),\n};\n\nexport const maskTypes = [\n MASK_TYPES.DATE,\n MASK_TYPES.DATE_DEPRECATED,\n MASK_TYPES.DATE_TIME,\n MASK_TYPES.DATE_TIME_DEPRECATED,\n MASK_TYPES.PHONE,\n MASK_TYPES.PHONE_INTENATIONAL,\n MASK_TYPES.SSN,\n MASK_TYPES.US_ZIP_CODE,\n MASK_TYPES.NUMBER,\n MASK_TYPES.PERCENT,\n];\n"],
5
- "mappings": "AAAA;ACEO,MAAM,aAAa;AAAA,EACxB,MAAM;AAAA,EACN,iBAAiB,CAAC,MAAM,MAAM,KAAK,MAAM,MAAM,KAAK,MAAM,MAAM,MAAM,IAAI;AAAA,EAC1E,WAAW;AAAA,EACX,sBAAsB;AAAA,IACpB;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF;AAAA,EACA,YAAY,CAAC,UAAW,GAAE,MAAM,sBAAsB,GAAG,MAAM;AAAA,EAC/D,OAAO;AAAA,EACP,oBAAoB;AAAA,EACpB,KAAK;AAAA,EACL,aAAa;AAAA,EACb,iBAAiB;AAAA,EACjB,QAAQ,CAAC,UAAU,CAAC,YAAa,GAAE,MAAM,kBAAkB,GAAG,MAAM;AAAA,EACpE,SAAS,CAAC,UAAU,CAAC,YAAa,GAAE,MAAM,mBAAmB,GAAG,MAAM;AACxE;AAEO,MAAM,YAAY;AAAA,EACvB,WAAW;AAAA,EACX,WAAW;AAAA,EACX,WAAW;AAAA,EACX,WAAW;AAAA,EACX,WAAW;AAAA,EACX,WAAW;AAAA,EACX,WAAW;AAAA,EACX,WAAW;AAAA,EACX,WAAW;AAAA,EACX,WAAW;AACb;",
5
+ "mappings": "AAAA,YAAY,WAAW;ACEhB,MAAM,aAAa;AAAA,EACxB,MAAM;AAAA,EACN,iBAAiB,CAAC,MAAM,MAAM,KAAK,MAAM,MAAM,KAAK,MAAM,MAAM,MAAM,IAAI;AAAA,EAC1E,WAAW;AAAA,EACX,sBAAsB;AAAA,IACpB;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,IACA;AAAA,EACF;AAAA,EACA,YAAY,CAAC,WAAW,EAAE,MAAM,sBAAsB,GAAG,MAAM;AAAA,EAC/D,OAAO;AAAA,EACP,oBAAoB;AAAA,EACpB,KAAK;AAAA,EACL,aAAa;AAAA,EACb,iBAAiB;AAAA,EACjB,QAAQ,CAAC,UAAU,CAAC,aAAa,EAAE,MAAM,kBAAkB,GAAG,MAAM;AAAA,EACpE,SAAS,CAAC,UAAU,CAAC,aAAa,EAAE,MAAM,mBAAmB,GAAG,MAAM;AACxE;AAEO,MAAM,YAAY;AAAA,EACvB,WAAW;AAAA,EACX,WAAW;AAAA,EACX,WAAW;AAAA,EACX,WAAW;AAAA,EACX,WAAW;AAAA,EACX,WAAW;AAAA,EACX,WAAW;AAAA,EACX,WAAW;AAAA,EACX,WAAW;AAAA,EACX,WAAW;AACb;",
6
6
  "names": []
7
7
  }
@@ -26,7 +26,10 @@ const autoCorrectedDatePipe = (dateFormat = "mm dd yyyy", { minYear = 1, maxYear
26
26
  const conformedValueArr = conformedValue.split("");
27
27
  dateFormatArray.forEach((format) => {
28
28
  const position = dateFormat.indexOf(format);
29
- const maxFirstDigit = parseInt(maxValue[format].toString().substr(0, 1), 10);
29
+ const maxFirstDigit = parseInt(
30
+ maxValue[format].toString().substr(0, 1),
31
+ 10
32
+ );
30
33
  if (parseInt(conformedValueArr[position], 10) > maxFirstDigit) {
31
34
  conformedValueArr[position + 1] = conformedValueArr[position];
32
35
  conformedValueArr[position] = 0;
@@ -44,8 +47,14 @@ const autoCorrectedDatePipe = (dateFormat = "mm dd yyyy", { minYear = 1, maxYear
44
47
  }
45
48
  const maxValueForFormat = format === "dd" ? maxValueMonth[month] : maxValue[format];
46
49
  if (format === "yyyy" && (minYear !== 1 || maxYear !== 9999)) {
47
- const scopedMaxValue = parseInt(maxValue[format].toString().substring(0, textValue.length), 10);
48
- const scopedMinValue = parseInt(minValue[format].toString().substring(0, textValue.length), 10);
50
+ const scopedMaxValue = parseInt(
51
+ maxValue[format].toString().substring(0, textValue.length),
52
+ 10
53
+ );
54
+ const scopedMinValue = parseInt(
55
+ minValue[format].toString().substring(0, textValue.length),
56
+ 10
57
+ );
49
58
  return value < scopedMinValue || value > scopedMaxValue;
50
59
  }
51
60
  return value > maxValueForFormat || textValue.length === length && value < minValue[format];
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../../../../../../scripts/build/transpile/react-shim.js", "../../../../src/InputMask/addons/AutoCorrectedDatePipe.tsx"],
4
4
  "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "const maxValueMonth = [31, 31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31];\nconst formatOrder = ['yyyy', 'yy', 'mm', 'dd', 'HH', 'MM', 'SS'];\nexport const autoCorrectedDatePipe = (\n dateFormat = 'mm dd yyyy',\n { minYear = 1, maxYear = 9999 } = {},\n) => {\n const dateFormatArray = dateFormat\n .split(/[^dmyHMS]+/)\n .sort((a, b) => formatOrder.indexOf(a) - formatOrder.indexOf(b));\n return (conformedValue) => {\n const indexesOfPipedChars = [];\n const maxValue = {\n dd: 31,\n mm: 12,\n yy: 99,\n yyyy: maxYear,\n HH: 23,\n MM: 59,\n SS: 59,\n };\n const minValue = {\n dd: 1,\n mm: 1,\n yy: 0,\n yyyy: minYear,\n HH: 0,\n MM: 0,\n SS: 0,\n };\n const conformedValueArr = conformedValue.split('');\n\n // Check first digit\n dateFormatArray.forEach((format) => {\n const position = dateFormat.indexOf(format);\n const maxFirstDigit = parseInt(\n maxValue[format].toString().substr(0, 1),\n 10,\n );\n\n if (parseInt(conformedValueArr[position], 10) > maxFirstDigit) {\n conformedValueArr[position + 1] = conformedValueArr[position];\n conformedValueArr[position] = 0;\n indexesOfPipedChars.push(position);\n }\n });\n\n // Check for invalid date\n let month = 0;\n const isInvalid = dateFormatArray.some((format) => {\n const position = dateFormat.indexOf(format);\n const { length } = format;\n const textValue = conformedValue\n .substr(position, length)\n .replace(/\\D/g, '');\n const value = parseInt(textValue, 10);\n if (format === 'mm') {\n month = value || 0;\n }\n const maxValueForFormat =\n format === 'dd' ? maxValueMonth[month] : maxValue[format];\n if (format === 'yyyy' && (minYear !== 1 || maxYear !== 9999)) {\n const scopedMaxValue = parseInt(\n maxValue[format].toString().substring(0, textValue.length),\n 10,\n );\n const scopedMinValue = parseInt(\n minValue[format].toString().substring(0, textValue.length),\n 10,\n );\n return value < scopedMinValue || value > scopedMaxValue;\n }\n return (\n value > maxValueForFormat ||\n (textValue.length === length && value < minValue[format])\n );\n });\n\n return {\n value: conformedValueArr.join(''),\n valid: !isInvalid,\n indexesOfPipedChars,\n };\n };\n};\n"],
5
- "mappings": "AAAA;ACAA,MAAM,gBAAgB,CAAC,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE;AACzE,MAAM,cAAc,CAAC,QAAQ,MAAM,MAAM,MAAM,MAAM,MAAM,IAAI;AACxD,MAAM,wBAAwB,CACnC,aAAa,cACb,EAAE,UAAU,GAAG,UAAU,SAAS,CAAC,MAChC;AACH,QAAM,kBAAkB,WACrB,MAAM,YAAY,EAClB,KAAK,CAAC,GAAG,MAAM,YAAY,QAAQ,CAAC,IAAI,YAAY,QAAQ,CAAC,CAAC;AACjE,SAAO,CAAC,mBAAmB;AACzB,UAAM,sBAAsB,CAAC;AAC7B,UAAM,WAAW;AAAA,MACf,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,MAAM;AAAA,MACN,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,IAAI;AAAA,IACN;AACA,UAAM,WAAW;AAAA,MACf,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,MAAM;AAAA,MACN,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,IAAI;AAAA,IACN;AACA,UAAM,oBAAoB,eAAe,MAAM,EAAE;AAGjD,oBAAgB,QAAQ,CAAC,WAAW;AAClC,YAAM,WAAW,WAAW,QAAQ,MAAM;AAC1C,YAAM,gBAAgB,SACpB,SAAS,QAAQ,SAAS,EAAE,OAAO,GAAG,CAAC,GACvC,EACF;AAEA,UAAI,SAAS,kBAAkB,WAAW,EAAE,IAAI,eAAe;AAC7D,0BAAkB,WAAW,KAAK,kBAAkB;AACpD,0BAAkB,YAAY;AAC9B,4BAAoB,KAAK,QAAQ;AAAA,MACnC;AAAA,IACF,CAAC;AAGD,QAAI,QAAQ;AACZ,UAAM,YAAY,gBAAgB,KAAK,CAAC,WAAW;AACjD,YAAM,WAAW,WAAW,QAAQ,MAAM;AAC1C,YAAM,EAAE,WAAW;AACnB,YAAM,YAAY,eACf,OAAO,UAAU,MAAM,EACvB,QAAQ,OAAO,EAAE;AACpB,YAAM,QAAQ,SAAS,WAAW,EAAE;AACpC,UAAI,WAAW,MAAM;AACnB,gBAAQ,SAAS;AAAA,MACnB;AACA,YAAM,oBACJ,WAAW,OAAO,cAAc,SAAS,SAAS;AACpD,UAAI,WAAW,UAAW,aAAY,KAAK,YAAY,OAAO;AAC5D,cAAM,iBAAiB,SACrB,SAAS,QAAQ,SAAS,EAAE,UAAU,GAAG,UAAU,MAAM,GACzD,EACF;AACA,cAAM,iBAAiB,SACrB,SAAS,QAAQ,SAAS,EAAE,UAAU,GAAG,UAAU,MAAM,GACzD,EACF;AACA,eAAO,QAAQ,kBAAkB,QAAQ;AAAA,MAC3C;AACA,aACE,QAAQ,qBACP,UAAU,WAAW,UAAU,QAAQ,SAAS;AAAA,IAErD,CAAC;AAED,WAAO;AAAA,MACL,OAAO,kBAAkB,KAAK,EAAE;AAAA,MAChC,OAAO,CAAC;AAAA,MACR;AAAA,IACF;AAAA,EACF;AACF;",
5
+ "mappings": "AAAA,YAAY,WAAW;ACAvB,MAAM,gBAAgB,CAAC,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,IAAI,EAAE;AACzE,MAAM,cAAc,CAAC,QAAQ,MAAM,MAAM,MAAM,MAAM,MAAM,IAAI;AACxD,MAAM,wBAAwB,CACnC,aAAa,cACb,EAAE,UAAU,GAAG,UAAU,KAAK,IAAI,CAAC,MAChC;AACH,QAAM,kBAAkB,WACrB,MAAM,YAAY,EAClB,KAAK,CAAC,GAAG,MAAM,YAAY,QAAQ,CAAC,IAAI,YAAY,QAAQ,CAAC,CAAC;AACjE,SAAO,CAAC,mBAAmB;AACzB,UAAM,sBAAsB,CAAC;AAC7B,UAAM,WAAW;AAAA,MACf,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,MAAM;AAAA,MACN,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,IAAI;AAAA,IACN;AACA,UAAM,WAAW;AAAA,MACf,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,MAAM;AAAA,MACN,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,IAAI;AAAA,IACN;AACA,UAAM,oBAAoB,eAAe,MAAM,EAAE;AAGjD,oBAAgB,QAAQ,CAAC,WAAW;AAClC,YAAM,WAAW,WAAW,QAAQ,MAAM;AAC1C,YAAM,gBAAgB;AAAA,QACpB,SAAS,QAAQ,SAAS,EAAE,OAAO,GAAG,CAAC;AAAA,QACvC;AAAA,MACF;AAEA,UAAI,SAAS,kBAAkB,WAAW,EAAE,IAAI,eAAe;AAC7D,0BAAkB,WAAW,KAAK,kBAAkB;AACpD,0BAAkB,YAAY;AAC9B,4BAAoB,KAAK,QAAQ;AAAA,MACnC;AAAA,IACF,CAAC;AAGD,QAAI,QAAQ;AACZ,UAAM,YAAY,gBAAgB,KAAK,CAAC,WAAW;AACjD,YAAM,WAAW,WAAW,QAAQ,MAAM;AAC1C,YAAM,EAAE,OAAO,IAAI;AACnB,YAAM,YAAY,eACf,OAAO,UAAU,MAAM,EACvB,QAAQ,OAAO,EAAE;AACpB,YAAM,QAAQ,SAAS,WAAW,EAAE;AACpC,UAAI,WAAW,MAAM;AACnB,gBAAQ,SAAS;AAAA,MACnB;AACA,YAAM,oBACJ,WAAW,OAAO,cAAc,SAAS,SAAS;AACpD,UAAI,WAAW,WAAW,YAAY,KAAK,YAAY,OAAO;AAC5D,cAAM,iBAAiB;AAAA,UACrB,SAAS,QAAQ,SAAS,EAAE,UAAU,GAAG,UAAU,MAAM;AAAA,UACzD;AAAA,QACF;AACA,cAAM,iBAAiB;AAAA,UACrB,SAAS,QAAQ,SAAS,EAAE,UAAU,GAAG,UAAU,MAAM;AAAA,UACzD;AAAA,QACF;AACA,eAAO,QAAQ,kBAAkB,QAAQ;AAAA,MAC3C;AACA,aACE,QAAQ,qBACP,UAAU,WAAW,UAAU,QAAQ,SAAS;AAAA,IAErD,CAAC;AAED,WAAO;AAAA,MACL,OAAO,kBAAkB,KAAK,EAAE;AAAA,MAChC,OAAO,CAAC;AAAA,MACR;AAAA,IACF;AAAA,EACF;AACF;",
6
6
  "names": []
7
7
  }
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../../../../../scripts/build/transpile/react-shim.js", "../../../src/InputMask/defaultProps.tsx"],
4
4
  "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "import { MASK_TYPES } from './MaskTypes';\n\nexport const defaultProps = {\n autoFocus: false,\n style: {},\n disabled: false,\n className: '',\n name: '',\n maxLength: 255,\n minLength: 0,\n fluidWidth: false,\n onKeyDown: () => null,\n onClick: () => null,\n onChange: () => null,\n onFocus: () => null,\n onBlur: () => null,\n onPaste: () => null,\n onKeyUp: () => null,\n value: '',\n hasError: false,\n readOnly: false,\n innerRef: null,\n type: 'text',\n clearable: false,\n leftComponent: null,\n rightComponent: null,\n mask: MASK_TYPES.DATE,\n pipe: null,\n useSubfix: '',\n};\n"],
5
- "mappings": "AAAA;ACAA;AAEO,MAAM,eAAe;AAAA,EAC1B,WAAW;AAAA,EACX,OAAO,CAAC;AAAA,EACR,UAAU;AAAA,EACV,WAAW;AAAA,EACX,MAAM;AAAA,EACN,WAAW;AAAA,EACX,WAAW;AAAA,EACX,YAAY;AAAA,EACZ,WAAW,MAAM;AAAA,EACjB,SAAS,MAAM;AAAA,EACf,UAAU,MAAM;AAAA,EAChB,SAAS,MAAM;AAAA,EACf,QAAQ,MAAM;AAAA,EACd,SAAS,MAAM;AAAA,EACf,SAAS,MAAM;AAAA,EACf,OAAO;AAAA,EACP,UAAU;AAAA,EACV,UAAU;AAAA,EACV,UAAU;AAAA,EACV,MAAM;AAAA,EACN,WAAW;AAAA,EACX,eAAe;AAAA,EACf,gBAAgB;AAAA,EAChB,MAAM,WAAW;AAAA,EACjB,MAAM;AAAA,EACN,WAAW;AACb;",
5
+ "mappings": "AAAA,YAAY,WAAW;ACAvB,SAAS,kBAAkB;AAEpB,MAAM,eAAe;AAAA,EAC1B,WAAW;AAAA,EACX,OAAO,CAAC;AAAA,EACR,UAAU;AAAA,EACV,WAAW;AAAA,EACX,MAAM;AAAA,EACN,WAAW;AAAA,EACX,WAAW;AAAA,EACX,YAAY;AAAA,EACZ,WAAW,MAAM;AAAA,EACjB,SAAS,MAAM;AAAA,EACf,UAAU,MAAM;AAAA,EAChB,SAAS,MAAM;AAAA,EACf,QAAQ,MAAM;AAAA,EACd,SAAS,MAAM;AAAA,EACf,SAAS,MAAM;AAAA,EACf,OAAO;AAAA,EACP,UAAU;AAAA,EACV,UAAU;AAAA,EACV,UAAU;AAAA,EACV,MAAM;AAAA,EACN,WAAW;AAAA,EACX,eAAe;AAAA,EACf,gBAAgB;AAAA,EAChB,MAAM,WAAW;AAAA,EACjB,MAAM;AAAA,EACN,WAAW;AACb;",
6
6
  "names": []
7
7
  }
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../../../../../scripts/build/transpile/react-shim.js", "../../../src/InputMask/index.tsx"],
4
4
  "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "export * from './DSInputMask';\n"],
5
- "mappings": "AAAA;ACAA;",
5
+ "mappings": "AAAA,YAAY,WAAW;ACAvB,cAAc;",
6
6
  "names": []
7
7
  }
@@ -69,28 +69,38 @@ const DateInputMask = ({
69
69
  }) => {
70
70
  const inputRef = useRef();
71
71
  const [maskedValue, setMaskedValue] = useState(value);
72
- const conform = useCallback(({ rawValue, cursorPos, lastkeycode, shouldUpdateCursorPos = true }) => {
73
- const { nextMaskedValue, maskedPos } = conformValue(rawValue, cursorPos, lastkeycode);
74
- const event = {
75
- target: {
76
- value: nextMaskedValue,
77
- originalValue: rawValue
78
- }
79
- };
80
- if (onChange && nextMaskedValue !== maskedValue)
81
- onChange(event);
82
- setMaskedValue(nextMaskedValue);
83
- setRawValue(nextMaskedValue);
84
- if (shouldUpdateCursorPos)
85
- setCursorPosition({ current: maskedPos });
86
- }, [maskedValue, onChange]);
87
- const handleOnChange = useCallback((e) => {
88
- const { value: rawValue, selectionEnd } = e.target;
89
- setRawMask(rawValue);
90
- setRawValue(rawValue);
91
- setCursorPosition({ current: selectionEnd });
92
- setFocus(true);
93
- }, [setRawMask, setRawValue, setCursorPosition, setFocus, lastkey.code]);
72
+ const conform = useCallback(
73
+ ({ rawValue, cursorPos, lastkeycode, shouldUpdateCursorPos = true }) => {
74
+ const { nextMaskedValue, maskedPos } = conformValue(
75
+ rawValue,
76
+ cursorPos,
77
+ lastkeycode
78
+ );
79
+ const event = {
80
+ target: {
81
+ value: nextMaskedValue,
82
+ originalValue: rawValue
83
+ }
84
+ };
85
+ if (onChange && nextMaskedValue !== maskedValue)
86
+ onChange(event);
87
+ setMaskedValue(nextMaskedValue);
88
+ setRawValue(nextMaskedValue);
89
+ if (shouldUpdateCursorPos)
90
+ setCursorPosition({ current: maskedPos });
91
+ },
92
+ [maskedValue, onChange]
93
+ );
94
+ const handleOnChange = useCallback(
95
+ (e) => {
96
+ const { value: rawValue, selectionEnd } = e.target;
97
+ setRawMask(rawValue);
98
+ setRawValue(rawValue);
99
+ setCursorPosition({ current: selectionEnd });
100
+ setFocus(true);
101
+ },
102
+ [setRawMask, setRawValue, setCursorPosition, setFocus, lastkey.code]
103
+ );
94
104
  useLayoutEffect(() => {
95
105
  if (focus)
96
106
  setCaretPosition(inputRef.current, cursorPosition.current);
@@ -103,15 +113,21 @@ const DateInputMask = ({
103
113
  shouldUpdateCursorPos: focus
104
114
  });
105
115
  }, [focus, value, cursorPosition.current]);
106
- const handleKeyDown = useCallback((e) => {
107
- e.stopPropagation();
108
- setLastkey({ key: e.key, code: e.keyCode });
109
- onKeyDown(e);
110
- }, [onKeyDown]);
111
- const handleBlur = useCallback((e) => {
112
- setFocus(false);
113
- onBlur(e);
114
- }, [onBlur]);
116
+ const handleKeyDown = useCallback(
117
+ (e) => {
118
+ e.stopPropagation();
119
+ setLastkey({ key: e.key, code: e.keyCode });
120
+ onKeyDown(e);
121
+ },
122
+ [onKeyDown]
123
+ );
124
+ const handleBlur = useCallback(
125
+ (e) => {
126
+ setFocus(false);
127
+ onBlur(e);
128
+ },
129
+ [onBlur]
130
+ );
115
131
  return /* @__PURE__ */ React2.createElement(DSTextBox, {
116
132
  ...rest,
117
133
  className,
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../../../../../../scripts/build/transpile/react-shim.js", "../../../../src/InputMask/mask_types/DateInputMask.tsx"],
4
4
  "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "/* eslint-disable max-lines */\n/* eslint-disable complexity */\nimport React, { useCallback, useLayoutEffect, useRef, useState } from 'react';\nimport { PropTypes } from '@elliemae/ds-utilities';\nimport { DSTextBox } from '../../TextBox';\nimport { TCharsToAdd } from '../types';\nimport { setCaretPosition } from '../utils/setCaretPosition';\n\nconst conformValue = (\n rawValue: string,\n cursorPos: number,\n lastkeycode: number,\n) => {\n const nextMaskedValue = rawValue\n .split('')\n .filter((char) => char >= '0' && char <= '9')\n .slice(0, 8);\n\n let maskedPos = 0;\n for (let i = 0; i < cursorPos; i += 1) {\n if (nextMaskedValue[maskedPos] === rawValue[i]) maskedPos += 1;\n }\n\n // list of [string to add, position to add]\n const charactersToAdd: TCharsToAdd = [\n ['/', 2],\n ['/', 5],\n ];\n\n charactersToAdd.forEach(([chars, pos]) => {\n if (nextMaskedValue.length > pos) {\n nextMaskedValue.splice(pos, 0, chars);\n if (maskedPos >= pos) maskedPos += chars.length;\n }\n });\n\n if (lastkeycode !== 8 && maskedPos < nextMaskedValue.length) {\n charactersToAdd.forEach(([chars, pos]) => {\n if (maskedPos === pos) maskedPos += chars.length;\n });\n } else if (lastkeycode === 8 && maskedPos) {\n charactersToAdd.forEach(([chars, pos]) => {\n if (maskedPos === pos + 1) maskedPos -= chars.length;\n });\n }\n\n return { nextMaskedValue: nextMaskedValue.join(''), maskedPos };\n};\n\nconst DateInputMask = ({\n focus,\n setFocus,\n setRawMask,\n cursorPosition,\n setCursorPosition,\n lastkey,\n setLastkey,\n setRawValue,\n style,\n disabled,\n className,\n name,\n maxLength,\n minLength,\n fluidWidth,\n placeholder,\n onKeyDown,\n onClick,\n onChange,\n onFocus,\n onBlur,\n onPaste,\n onKeyUp,\n hasError,\n readOnly,\n type,\n innerRef,\n clearable = false,\n leftComponent,\n rightComponent,\n value,\n ...rest\n}) => {\n const inputRef = useRef();\n const [maskedValue, setMaskedValue] = useState(value);\n\n const conform = useCallback(\n ({ rawValue, cursorPos, lastkeycode, shouldUpdateCursorPos = true }) => {\n const { nextMaskedValue, maskedPos } = conformValue(\n rawValue,\n cursorPos,\n lastkeycode,\n );\n const event = {\n target: {\n value: nextMaskedValue,\n originalValue: rawValue,\n },\n };\n if (onChange && nextMaskedValue !== maskedValue) onChange(event);\n\n setMaskedValue(nextMaskedValue);\n setRawValue(nextMaskedValue);\n\n if (shouldUpdateCursorPos) setCursorPosition({ current: maskedPos });\n },\n [maskedValue, onChange],\n );\n\n const handleOnChange = useCallback(\n (e) => {\n const { value: rawValue, selectionEnd } = e.target;\n setRawMask(rawValue);\n setRawValue(rawValue);\n setCursorPosition({ current: selectionEnd });\n setFocus(true);\n },\n [setRawMask, setRawValue, setCursorPosition, setFocus, lastkey.code],\n );\n\n useLayoutEffect(() => {\n if (focus) setCaretPosition(inputRef.current, cursorPosition.current);\n }, [focus, cursorPosition]);\n\n useLayoutEffect(() => {\n // if the value changes, then re-conform the mask\n conform({\n rawValue: value,\n cursorPos: cursorPosition.current,\n lastkeycode: lastkey.code,\n shouldUpdateCursorPos: focus,\n });\n }, [focus, value, cursorPosition.current]);\n\n const handleKeyDown = useCallback(\n (e) => {\n e.stopPropagation();\n setLastkey({ key: e.key, code: e.keyCode });\n onKeyDown(e);\n },\n [onKeyDown],\n );\n\n const handleBlur = useCallback(\n (e) => {\n setFocus(false);\n onBlur(e);\n },\n [onBlur],\n );\n\n return (\n <DSTextBox\n {...rest}\n className={className}\n clearable={clearable}\n disabled={disabled}\n fluidWidth={fluidWidth}\n hasError={hasError}\n innerRef={(ref) => {\n inputRef.current = ref;\n if (innerRef) innerRef(ref);\n }}\n isActive={focus}\n leftComponent={leftComponent}\n maxLength={maxLength}\n minLength={minLength}\n name={name}\n onBlur={handleBlur}\n onChange={handleOnChange}\n onClick={onClick}\n onFocus={onFocus}\n onKeyDown={handleKeyDown}\n onKeyUp={onKeyUp}\n onPaste={onPaste}\n placeholder={placeholder}\n readOnly={readOnly}\n rightComponent={rightComponent}\n style={style}\n type={type}\n value={maskedValue}\n />\n );\n};\n\nexport { DateInputMask };\nexport default DateInputMask;\n"],
5
- "mappings": "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",
6
- "names": []
5
+ "mappings": "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",
6
+ "names": ["React"]
7
7
  }
@@ -75,28 +75,38 @@ const DateTimeInputMask = ({
75
75
  }) => {
76
76
  const inputRef = useRef();
77
77
  const [maskedValue, setMaskedValue] = useState(value);
78
- const conform = useCallback(({ rawValue, cursorPos, lastkeycode, shouldUpdateCursorPos = true }) => {
79
- const { nextMaskedValue, maskedPos } = conformValue(rawValue, cursorPos, lastkeycode);
80
- const event = {
81
- target: {
82
- value: nextMaskedValue,
83
- originalValue: rawValue
84
- }
85
- };
86
- if (onChange && nextMaskedValue !== maskedValue)
87
- onChange(event);
88
- setMaskedValue(nextMaskedValue);
89
- setRawValue(nextMaskedValue);
90
- if (shouldUpdateCursorPos)
91
- setCursorPosition({ current: maskedPos });
92
- }, [maskedValue, onChange]);
93
- const handleOnChange = useCallback((e) => {
94
- const { value: rawValue, selectionEnd } = e.target;
95
- setRawMask(rawValue);
96
- setRawValue(rawValue);
97
- setCursorPosition({ current: selectionEnd });
98
- setFocus(true);
99
- }, [setRawMask, setRawValue, setCursorPosition, setFocus, lastkey.code]);
78
+ const conform = useCallback(
79
+ ({ rawValue, cursorPos, lastkeycode, shouldUpdateCursorPos = true }) => {
80
+ const { nextMaskedValue, maskedPos } = conformValue(
81
+ rawValue,
82
+ cursorPos,
83
+ lastkeycode
84
+ );
85
+ const event = {
86
+ target: {
87
+ value: nextMaskedValue,
88
+ originalValue: rawValue
89
+ }
90
+ };
91
+ if (onChange && nextMaskedValue !== maskedValue)
92
+ onChange(event);
93
+ setMaskedValue(nextMaskedValue);
94
+ setRawValue(nextMaskedValue);
95
+ if (shouldUpdateCursorPos)
96
+ setCursorPosition({ current: maskedPos });
97
+ },
98
+ [maskedValue, onChange]
99
+ );
100
+ const handleOnChange = useCallback(
101
+ (e) => {
102
+ const { value: rawValue, selectionEnd } = e.target;
103
+ setRawMask(rawValue);
104
+ setRawValue(rawValue);
105
+ setCursorPosition({ current: selectionEnd });
106
+ setFocus(true);
107
+ },
108
+ [setRawMask, setRawValue, setCursorPosition, setFocus, lastkey.code]
109
+ );
100
110
  useLayoutEffect(() => {
101
111
  if (focus)
102
112
  setCaretPosition(inputRef.current, cursorPosition.current);
@@ -109,15 +119,21 @@ const DateTimeInputMask = ({
109
119
  shouldUpdateCursorPos: focus
110
120
  });
111
121
  }, [focus, value, cursorPosition.current]);
112
- const handleKeyDown = useCallback((e) => {
113
- e.stopPropagation();
114
- setLastkey({ key: e.key, code: e.keyCode });
115
- onKeyDown(e);
116
- }, [onKeyDown]);
117
- const handleBlur = useCallback((e) => {
118
- setFocus(false);
119
- onBlur(e);
120
- }, [onBlur]);
122
+ const handleKeyDown = useCallback(
123
+ (e) => {
124
+ e.stopPropagation();
125
+ setLastkey({ key: e.key, code: e.keyCode });
126
+ onKeyDown(e);
127
+ },
128
+ [onKeyDown]
129
+ );
130
+ const handleBlur = useCallback(
131
+ (e) => {
132
+ setFocus(false);
133
+ onBlur(e);
134
+ },
135
+ [onBlur]
136
+ );
121
137
  return /* @__PURE__ */ React2.createElement(DSTextBox, {
122
138
  ...rest,
123
139
  className,
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../../../../../../scripts/build/transpile/react-shim.js", "../../../../src/InputMask/mask_types/DateTimeInputMask.tsx"],
4
4
  "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "/* eslint-disable max-statements */\n/* eslint-disable max-lines */\n/* eslint-disable complexity */\nimport React, { useCallback, useLayoutEffect, useRef, useState } from 'react';\nimport { PropTypes } from '@elliemae/ds-utilities';\nimport { DSTextBox } from '../../TextBox';\nimport { TCharsToAdd } from '../types';\nimport { setCaretPosition } from '../utils/setCaretPosition';\n\nconst conformValue = (\n rawValue: string,\n cursorPos: number,\n lastkeycode: number,\n) => {\n const nextMaskedValue = rawValue\n .split('')\n .filter((char) => char >= '0' && char <= '9')\n .slice(0, 12);\n\n while (nextMaskedValue.length > 8 && !nextMaskedValue[8].match(/[0-2]/))\n nextMaskedValue.splice(8, 1);\n while (nextMaskedValue.length > 10 && !nextMaskedValue[10].match(/[0-5]/))\n nextMaskedValue.splice(10, 1);\n\n let maskedPos = 0;\n for (let i = 0; i < cursorPos; i += 1) {\n if (nextMaskedValue[maskedPos] === rawValue[i]) maskedPos += 1;\n }\n\n // list of [string to add, position to add]\n const charactersToAdd: TCharsToAdd = [\n ['/', 2],\n ['/', 5],\n [' ', 10],\n [':', 13],\n ];\n\n charactersToAdd.forEach(([chars, pos]) => {\n if (nextMaskedValue.length > pos) {\n nextMaskedValue.splice(pos, 0, chars);\n if (maskedPos >= pos) maskedPos += chars.length;\n }\n });\n\n if (lastkeycode !== 8 && maskedPos < nextMaskedValue.length) {\n charactersToAdd.forEach(([chars, pos]) => {\n if (maskedPos === pos) maskedPos += chars.length;\n });\n } else if (lastkeycode === 8 && maskedPos) {\n charactersToAdd.forEach(([chars, pos]) => {\n if (maskedPos === pos + 1) maskedPos -= chars.length;\n });\n }\n\n return { nextMaskedValue: nextMaskedValue.join(''), maskedPos };\n};\n\nconst DateTimeInputMask = ({\n focus,\n setFocus,\n setRawMask,\n cursorPosition,\n setCursorPosition,\n lastkey,\n setLastkey,\n setRawValue,\n style,\n disabled,\n className,\n name,\n maxLength,\n minLength,\n fluidWidth,\n placeholder,\n onKeyDown,\n onClick,\n onChange,\n onFocus,\n onBlur,\n onPaste,\n onKeyUp,\n hasError,\n readOnly,\n type,\n innerRef,\n clearable = false,\n leftComponent,\n rightComponent,\n value,\n ...rest\n}) => {\n const inputRef = useRef();\n const [maskedValue, setMaskedValue] = useState(value);\n\n const conform = useCallback(\n ({ rawValue, cursorPos, lastkeycode, shouldUpdateCursorPos = true }) => {\n const { nextMaskedValue, maskedPos } = conformValue(\n rawValue,\n cursorPos,\n lastkeycode,\n );\n const event = {\n target: {\n value: nextMaskedValue,\n originalValue: rawValue,\n },\n };\n if (onChange && nextMaskedValue !== maskedValue) onChange(event);\n\n setMaskedValue(nextMaskedValue);\n setRawValue(nextMaskedValue);\n\n if (shouldUpdateCursorPos) setCursorPosition({ current: maskedPos });\n },\n [maskedValue, onChange],\n );\n\n const handleOnChange = useCallback(\n (e) => {\n const { value: rawValue, selectionEnd } = e.target;\n setRawMask(rawValue);\n setRawValue(rawValue);\n setCursorPosition({ current: selectionEnd });\n setFocus(true);\n },\n [setRawMask, setRawValue, setCursorPosition, setFocus, lastkey.code],\n );\n\n useLayoutEffect(() => {\n if (focus) setCaretPosition(inputRef.current, cursorPosition.current);\n }, [focus, cursorPosition]);\n\n useLayoutEffect(() => {\n // if the value changes, then re-conform the mask\n conform({\n rawValue: value,\n cursorPos: cursorPosition.current,\n lastkeycode: lastkey.code,\n shouldUpdateCursorPos: focus,\n });\n }, [focus, value, cursorPosition.current]);\n\n const handleKeyDown = useCallback(\n (e) => {\n e.stopPropagation();\n setLastkey({ key: e.key, code: e.keyCode });\n onKeyDown(e);\n },\n [onKeyDown],\n );\n\n const handleBlur = useCallback(\n (e) => {\n setFocus(false);\n onBlur(e);\n },\n [onBlur],\n );\n\n return (\n <DSTextBox\n {...rest}\n className={className}\n clearable={clearable}\n disabled={disabled}\n fluidWidth={fluidWidth}\n hasError={hasError}\n innerRef={(ref) => {\n inputRef.current = ref;\n if (innerRef) innerRef(ref);\n }}\n isActive={focus}\n leftComponent={leftComponent}\n maxLength={maxLength}\n minLength={minLength}\n name={name}\n onBlur={handleBlur}\n onChange={handleOnChange}\n onClick={onClick}\n onFocus={onFocus}\n onKeyDown={handleKeyDown}\n onKeyUp={onKeyUp}\n onPaste={onPaste}\n placeholder={placeholder}\n readOnly={readOnly}\n rightComponent={rightComponent}\n style={style}\n type={type}\n value={maskedValue}\n />\n );\n};\n\nexport { DateTimeInputMask };\nexport default DateTimeInputMask;\n"],
5
- "mappings": "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",
6
- "names": []
5
+ "mappings": "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",
6
+ "names": ["React"]
7
7
  }
@@ -13,7 +13,9 @@ const conformValue = (rawValue, cursorPos, lastkeycode, allowedWords, ignoreCase
13
13
  let nextMaskedValue = "";
14
14
  let currentPosibleWords = allowedWords;
15
15
  for (let i = 0; i < rawValue.length; i += 1) {
16
- const matchingWords = currentPosibleWords.filter((word) => startsWith(word, nextMaskedValue + rawValue[i], ignoreCase));
16
+ const matchingWords = currentPosibleWords.filter(
17
+ (word) => startsWith(word, nextMaskedValue + rawValue[i], ignoreCase)
18
+ );
17
19
  if (matchingWords.length) {
18
20
  nextMaskedValue += rawValue[i];
19
21
  currentPosibleWords = matchingWords;
@@ -60,28 +62,40 @@ const DictionaryInputMask = ({
60
62
  }) => {
61
63
  const inputRef = useRef();
62
64
  const [maskedValue, setMaskedValue] = useState(value);
63
- const conform = useCallback(({ rawValue, cursorPos, lastkeycode, shouldUpdateCursorPos = true }) => {
64
- const { nextMaskedValue, maskedPos } = conformValue(rawValue, cursorPos, lastkeycode, allowedWords, ignoreCase);
65
- const event = {
66
- target: {
67
- value: nextMaskedValue,
68
- originalValue: rawValue
69
- }
70
- };
71
- if (onChange && nextMaskedValue !== maskedValue)
72
- onChange(event);
73
- setMaskedValue(nextMaskedValue);
74
- setRawValue(nextMaskedValue);
75
- if (shouldUpdateCursorPos)
76
- setCursorPosition({ current: maskedPos });
77
- }, [maskedValue, onChange]);
78
- const handleOnChange = useCallback((e) => {
79
- const { value: rawValue, selectionEnd } = e.target;
80
- setRawMask(rawValue);
81
- setRawValue(rawValue);
82
- setCursorPosition({ current: selectionEnd });
83
- setFocus(true);
84
- }, [setRawMask, setRawValue, setCursorPosition, setFocus, lastkey.code]);
65
+ const conform = useCallback(
66
+ ({ rawValue, cursorPos, lastkeycode, shouldUpdateCursorPos = true }) => {
67
+ const { nextMaskedValue, maskedPos } = conformValue(
68
+ rawValue,
69
+ cursorPos,
70
+ lastkeycode,
71
+ allowedWords,
72
+ ignoreCase
73
+ );
74
+ const event = {
75
+ target: {
76
+ value: nextMaskedValue,
77
+ originalValue: rawValue
78
+ }
79
+ };
80
+ if (onChange && nextMaskedValue !== maskedValue)
81
+ onChange(event);
82
+ setMaskedValue(nextMaskedValue);
83
+ setRawValue(nextMaskedValue);
84
+ if (shouldUpdateCursorPos)
85
+ setCursorPosition({ current: maskedPos });
86
+ },
87
+ [maskedValue, onChange]
88
+ );
89
+ const handleOnChange = useCallback(
90
+ (e) => {
91
+ const { value: rawValue, selectionEnd } = e.target;
92
+ setRawMask(rawValue);
93
+ setRawValue(rawValue);
94
+ setCursorPosition({ current: selectionEnd });
95
+ setFocus(true);
96
+ },
97
+ [setRawMask, setRawValue, setCursorPosition, setFocus, lastkey.code]
98
+ );
85
99
  useLayoutEffect(() => {
86
100
  if (focus)
87
101
  setCaretPosition(inputRef.current, cursorPosition.current);
@@ -94,15 +108,21 @@ const DictionaryInputMask = ({
94
108
  shouldUpdateCursorPos: focus
95
109
  });
96
110
  }, [focus, value, cursorPosition.current]);
97
- const handleKeyDown = useCallback((e) => {
98
- e.stopPropagation();
99
- setLastkey({ key: e.key, code: e.keyCode });
100
- onKeyDown(e);
101
- }, [onKeyDown]);
102
- const handleBlur = useCallback((e) => {
103
- setFocus(false);
104
- onBlur(e);
105
- }, [onBlur]);
111
+ const handleKeyDown = useCallback(
112
+ (e) => {
113
+ e.stopPropagation();
114
+ setLastkey({ key: e.key, code: e.keyCode });
115
+ onKeyDown(e);
116
+ },
117
+ [onKeyDown]
118
+ );
119
+ const handleBlur = useCallback(
120
+ (e) => {
121
+ setFocus(false);
122
+ onBlur(e);
123
+ },
124
+ [onBlur]
125
+ );
106
126
  return /* @__PURE__ */ React2.createElement(DSTextBox, {
107
127
  ...rest,
108
128
  className,
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../../../../../../scripts/build/transpile/react-shim.js", "../../../../src/InputMask/mask_types/DictionaryInputMask.tsx"],
4
4
  "sourcesContent": ["import * as React from 'react';\nexport { React };\n", "/* eslint-disable no-loop-func */\n/* eslint-disable max-params */\n/* eslint-disable max-lines */\n/* eslint-disable complexity */\nimport React, { useCallback, useLayoutEffect, useRef, useState } from 'react';\nimport { PropTypes } from '@elliemae/ds-utilities';\nimport { DSTextBox } from '../../TextBox';\nimport { setCaretPosition } from '../utils/setCaretPosition';\n\nconst startsWith = (a: string, b: string, ignoreCase: boolean): boolean => {\n if (ignoreCase) {\n a = a.toLowerCase();\n b = b.toLowerCase();\n }\n return a.startsWith(b);\n};\n\nconst conformValue = (\n rawValue: string,\n cursorPos: number,\n lastkeycode: number,\n allowedWords: string[],\n ignoreCase: boolean,\n) => {\n let nextMaskedValue = '';\n let currentPosibleWords = allowedWords;\n for (let i = 0; i < rawValue.length; i += 1) {\n const matchingWords = currentPosibleWords.filter((word) =>\n startsWith(word, nextMaskedValue + rawValue[i], ignoreCase),\n );\n if (matchingWords.length) {\n nextMaskedValue += rawValue[i];\n currentPosibleWords = matchingWords;\n }\n }\n\n return { nextMaskedValue, maskedPos: cursorPos };\n};\n\nconst DictionaryInputMask = ({\n focus,\n setFocus,\n setRawMask,\n cursorPosition,\n setCursorPosition,\n lastkey,\n setLastkey,\n setRawValue,\n allowedWords,\n ignoreCase = true,\n autoFocus,\n style,\n disabled,\n className,\n name,\n maxLength,\n minLength,\n fluidWidth,\n placeholder,\n onKeyDown,\n onClick,\n onChange,\n onFocus,\n onBlur,\n onPaste,\n onKeyUp,\n hasError,\n readOnly,\n type,\n innerRef,\n clearable = false,\n leftComponent,\n rightComponent,\n value,\n ...rest\n}) => {\n const inputRef = useRef();\n const [maskedValue, setMaskedValue] = useState(value);\n\n const conform = useCallback(\n ({ rawValue, cursorPos, lastkeycode, shouldUpdateCursorPos = true }) => {\n const { nextMaskedValue, maskedPos } = conformValue(\n rawValue,\n cursorPos,\n lastkeycode,\n allowedWords,\n ignoreCase,\n );\n const event = {\n target: {\n value: nextMaskedValue,\n originalValue: rawValue,\n },\n };\n if (onChange && nextMaskedValue !== maskedValue) onChange(event);\n\n setMaskedValue(nextMaskedValue);\n setRawValue(nextMaskedValue);\n\n if (shouldUpdateCursorPos) setCursorPosition({ current: maskedPos });\n },\n [maskedValue, onChange],\n );\n\n const handleOnChange = useCallback(\n (e) => {\n const { value: rawValue, selectionEnd } = e.target;\n setRawMask(rawValue);\n setRawValue(rawValue);\n setCursorPosition({ current: selectionEnd });\n setFocus(true);\n },\n [setRawMask, setRawValue, setCursorPosition, setFocus, lastkey.code],\n );\n\n useLayoutEffect(() => {\n if (focus) setCaretPosition(inputRef.current, cursorPosition.current);\n }, [focus, cursorPosition]);\n\n useLayoutEffect(() => {\n // if the value changes, then re-conform the mask\n conform({\n rawValue: value,\n cursorPos: cursorPosition.current,\n lastkeycode: lastkey.code,\n shouldUpdateCursorPos: focus,\n });\n }, [focus, value, cursorPosition.current]);\n\n const handleKeyDown = useCallback(\n (e) => {\n e.stopPropagation();\n setLastkey({ key: e.key, code: e.keyCode });\n onKeyDown(e);\n },\n [onKeyDown],\n );\n\n const handleBlur = useCallback(\n (e) => {\n setFocus(false);\n onBlur(e);\n },\n [onBlur],\n );\n\n return (\n <DSTextBox\n {...rest}\n className={className}\n clearable={clearable}\n disabled={disabled}\n fluidWidth={fluidWidth}\n hasError={hasError}\n innerRef={(ref) => {\n inputRef.current = ref;\n if (innerRef) innerRef(ref);\n }}\n isActive={focus}\n leftComponent={leftComponent}\n maxLength={maxLength}\n minLength={minLength}\n name={name}\n onBlur={handleBlur}\n onChange={handleOnChange}\n onClick={onClick}\n onFocus={onFocus}\n onKeyDown={handleKeyDown}\n onKeyUp={onKeyUp}\n onPaste={onPaste}\n placeholder={placeholder}\n readOnly={readOnly}\n rightComponent={rightComponent}\n style={style}\n type={type}\n value={maskedValue}\n />\n );\n};\n\nexport { DictionaryInputMask };\nexport default DictionaryInputMask;\n"],
5
- "mappings": "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",
6
- "names": []
5
+ "mappings": "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",
6
+ "names": ["React"]
7
7
  }
@@ -21,7 +21,10 @@ const conformValue = (prevRawValue, prevCursorPos, lastkeycode, {
21
21
  const suffixIndex = prevRawValue.lastIndexOf(suffix);
22
22
  const negativeIndex = prevRawValue.indexOf("-");
23
23
  const cursorPos = prevCursorPos - (prefixIndex === -1 ? 0 : prefixIndex + prefix.length);
24
- const rawValue = prevRawValue.substring(prefixIndex === -1 ? 0 : prefixIndex + prefix.length, suffixIndex === -1 ? prevRawValue.length : suffixIndex);
24
+ const rawValue = prevRawValue.substring(
25
+ prefixIndex === -1 ? 0 : prefixIndex + prefix.length,
26
+ suffixIndex === -1 ? prevRawValue.length : suffixIndex
27
+ );
25
28
  const filteredRawValue = rawValue.split("").filter((char) => char >= "0" && char <= "9" || char === decimalSymbol || char === "-");
26
29
  let isNegative = allowNegative && negativeIndex !== -1 && (prefixIndex === -1 || negativeIndex < prefixIndex);
27
30
  let integer = "";
@@ -139,41 +142,47 @@ const NumberInputMask = ({
139
142
  }) => {
140
143
  const inputRef = useRef();
141
144
  const [maskedValue, setMaskedValue] = useState(value);
142
- const conform = useCallback(({ rawValue, cursorPos, lastkeycode, shouldUpdateCursorPos = true, shouldCompleteDecimals = false }) => {
143
- const { nextMaskedValue, maskedPos } = conformValue(rawValue, cursorPos, lastkeycode, {
144
- prefix,
145
- suffix,
146
- includeThousandsSeparator,
147
- thousandsSeparatorSymbol,
148
- allowDecimal,
149
- decimalSymbol,
150
- decimalLimit,
151
- requireDecimal,
152
- allowNegative,
153
- allowLeadingZeroes,
154
- integerLimit,
155
- shouldCompleteDecimals
156
- });
157
- const event = {
158
- target: {
159
- value: nextMaskedValue,
160
- originalValue: rawValue
161
- }
162
- };
163
- if (onChange && nextMaskedValue !== maskedValue)
164
- onChange(event);
165
- setMaskedValue(nextMaskedValue);
166
- setRawValue(nextMaskedValue);
167
- if (shouldUpdateCursorPos)
168
- setCursorPosition({ current: maskedPos });
169
- }, [maskedValue, onChange]);
170
- const handleOnChange = useCallback((e) => {
171
- const { value: rawValue, selectionEnd } = e.target;
172
- setRawMask(rawValue);
173
- setRawValue(rawValue);
174
- setCursorPosition({ current: selectionEnd });
175
- setFocus(true);
176
- }, [setRawMask, setRawValue, setCursorPosition, setFocus, lastkey.code]);
145
+ const conform = useCallback(
146
+ ({ rawValue, cursorPos, lastkeycode, shouldUpdateCursorPos = true, shouldCompleteDecimals = false }) => {
147
+ const { nextMaskedValue, maskedPos } = conformValue(rawValue, cursorPos, lastkeycode, {
148
+ prefix,
149
+ suffix,
150
+ includeThousandsSeparator,
151
+ thousandsSeparatorSymbol,
152
+ allowDecimal,
153
+ decimalSymbol,
154
+ decimalLimit,
155
+ requireDecimal,
156
+ allowNegative,
157
+ allowLeadingZeroes,
158
+ integerLimit,
159
+ shouldCompleteDecimals
160
+ });
161
+ const event = {
162
+ target: {
163
+ value: nextMaskedValue,
164
+ originalValue: rawValue
165
+ }
166
+ };
167
+ if (onChange && nextMaskedValue !== maskedValue)
168
+ onChange(event);
169
+ setMaskedValue(nextMaskedValue);
170
+ setRawValue(nextMaskedValue);
171
+ if (shouldUpdateCursorPos)
172
+ setCursorPosition({ current: maskedPos });
173
+ },
174
+ [maskedValue, onChange]
175
+ );
176
+ const handleOnChange = useCallback(
177
+ (e) => {
178
+ const { value: rawValue, selectionEnd } = e.target;
179
+ setRawMask(rawValue);
180
+ setRawValue(rawValue);
181
+ setCursorPosition({ current: selectionEnd });
182
+ setFocus(true);
183
+ },
184
+ [setRawMask, setRawValue, setCursorPosition, setFocus, lastkey.code]
185
+ );
177
186
  useLayoutEffect(() => {
178
187
  if (focus)
179
188
  setCaretPosition(inputRef.current, cursorPosition.current);
@@ -186,24 +195,30 @@ const NumberInputMask = ({
186
195
  shouldUpdateCursorPos: focus
187
196
  });
188
197
  }, [focus, value, cursorPosition.current]);
189
- const handleKeyDown = useCallback((e) => {
190
- e.stopPropagation();
191
- setLastkey({ key: e.key, code: e.keyCode });
192
- onKeyDown(e);
193
- }, [onKeyDown]);
194
- const handleBlur = useCallback((e) => {
195
- setFocus(false);
196
- onBlur(e);
197
- if (requireDecimal && maskedValue !== "") {
198
- conform({
199
- rawValue: maskedValue,
200
- cursorPos: 0,
201
- lastkey: 0,
202
- shouldUpdateCursorPos: 0,
203
- shouldCompleteDecimals: true
204
- });
205
- }
206
- }, [maskedValue, requireDecimal, suffix, decimalLimit, onBlur]);
198
+ const handleKeyDown = useCallback(
199
+ (e) => {
200
+ e.stopPropagation();
201
+ setLastkey({ key: e.key, code: e.keyCode });
202
+ onKeyDown(e);
203
+ },
204
+ [onKeyDown]
205
+ );
206
+ const handleBlur = useCallback(
207
+ (e) => {
208
+ setFocus(false);
209
+ onBlur(e);
210
+ if (requireDecimal && maskedValue !== "") {
211
+ conform({
212
+ rawValue: maskedValue,
213
+ cursorPos: 0,
214
+ lastkey: 0,
215
+ shouldUpdateCursorPos: 0,
216
+ shouldCompleteDecimals: true
217
+ });
218
+ }
219
+ },
220
+ [maskedValue, requireDecimal, suffix, decimalLimit, onBlur]
221
+ );
207
222
  return /* @__PURE__ */ React2.createElement(DSTextBox, {
208
223
  ...rest,
209
224
  className,