carbon-react 111.12.3 → 111.12.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 (913) hide show
  1. package/esm/__internal__/DeprecationWarning.js +2 -0
  2. package/esm/__internal__/character-count/character-count.component.js +2 -0
  3. package/esm/__internal__/checkable-input/checkable-input.component.js +5 -0
  4. package/esm/__internal__/checkable-input/hidden-checkable-input.component.js +11 -0
  5. package/esm/__internal__/field-help/field-help.component.js +2 -0
  6. package/esm/__internal__/fieldset/fieldset.component.js +3 -0
  7. package/esm/__internal__/focus-trap/focus-trap-utils.js +25 -6
  8. package/esm/__internal__/focus-trap/focus-trap.component.js +17 -7
  9. package/esm/__internal__/form-field/form-field.component.js +5 -0
  10. package/esm/__internal__/full-screen-heading/full-screen-heading.component.js +1 -0
  11. package/esm/__internal__/input/input-presentation.component.js +5 -0
  12. package/esm/__internal__/input/input-presentation.style.js +5 -0
  13. package/esm/__internal__/input/input.component.js +25 -2
  14. package/esm/__internal__/input-behaviour/input-behaviour.component.js +3 -2
  15. package/esm/__internal__/input-behaviour/input-group-behaviour.component.js +2 -0
  16. package/esm/__internal__/input-behaviour/useInputBehaviour.js +4 -2
  17. package/esm/__internal__/input-icon-toggle/input-icon-toggle.component.js +5 -0
  18. package/esm/__internal__/input-icon-toggle/input-icon-toggle.style.js +1 -0
  19. package/esm/__internal__/label/label.component.js +10 -0
  20. package/esm/__internal__/popover/popover.component.js +11 -0
  21. package/esm/__internal__/radio-button-mapper/index.d.ts +2 -2
  22. package/esm/__internal__/radio-button-mapper/radio-button-mapper.component.d.ts +29 -0
  23. package/esm/__internal__/radio-button-mapper/radio-button-mapper.component.js +25 -21
  24. package/esm/__internal__/sticky-footer/sticky-footer.component.js +5 -0
  25. package/esm/__internal__/utils/helpers/browser-type-check/index.js +1 -0
  26. package/esm/__internal__/utils/helpers/events/composedPath.js +4 -1
  27. package/esm/__internal__/utils/helpers/events/events.js +16 -1
  28. package/esm/__internal__/utils/helpers/guid/index.js +1 -0
  29. package/esm/__internal__/utils/helpers/tags/tags-specs/tags-specs.js +3 -2
  30. package/esm/__internal__/utils/helpers/tags/tags.js +4 -0
  31. package/esm/__internal__/utils/logger/index.js +1 -1
  32. package/esm/__internal__/validation-message/validation-message.component.js +2 -0
  33. package/esm/__internal__/validations/validation-icon.component.js +8 -0
  34. package/esm/__spec_helper__/enzyme-snapshot-helper.js +5 -0
  35. package/esm/__spec_helper__/expect.js +5 -2
  36. package/esm/__spec_helper__/mock-match-media.js +3 -0
  37. package/esm/__spec_helper__/mock-resize-observer.js +2 -0
  38. package/esm/__spec_helper__/test-utils.js +62 -27
  39. package/esm/components/accordion/accordion-group/accordion-group.component.js +9 -0
  40. package/esm/components/accordion/accordion.component.js +7 -0
  41. package/esm/components/action-popover/action-popover-item/action-popover-item.component.js +21 -2
  42. package/esm/components/action-popover/action-popover-menu/action-popover-menu.component.js +7 -2
  43. package/esm/components/action-popover/action-popover-menu-button/action-popover-menu-button.component.js +3 -0
  44. package/esm/components/action-popover/action-popover.component.js +19 -4
  45. package/esm/components/advanced-color-picker/advanced-color-picker.component.js +19 -0
  46. package/esm/components/alert/alert.component.js +3 -0
  47. package/esm/components/anchor-navigation/anchor-navigation.component.js +14 -5
  48. package/esm/components/badge/badge.component.js +2 -0
  49. package/esm/components/batch-selection/batch-selection.component.js +6 -0
  50. package/esm/components/box/box.config.js +1 -0
  51. package/esm/components/button/button-types.style.js +2 -0
  52. package/esm/components/button/button.component.js +12 -0
  53. package/esm/components/button/button.style.js +8 -0
  54. package/esm/components/button-bar/button-bar.component.js +8 -2
  55. package/esm/components/button-toggle/button-toggle-icon.component.js +2 -0
  56. package/esm/components/button-toggle/button-toggle-input.component.js +6 -0
  57. package/esm/components/button-toggle/button-toggle.component.js +6 -0
  58. package/esm/components/button-toggle-group/button-toggle-group.component.js +3 -0
  59. package/esm/components/carbon-provider/carbon-provider.component.js +2 -0
  60. package/esm/components/carbon-provider/top-modal-context.js +7 -3
  61. package/esm/components/card/card-column/card-column.component.js +2 -0
  62. package/esm/components/card/card-footer/card-footer.component.js +3 -0
  63. package/esm/components/card/card-row/card-row.component.js +3 -0
  64. package/esm/components/card/card.component.js +8 -0
  65. package/esm/components/carousel/carousel.component.js +15 -0
  66. package/esm/components/carousel/slide/slide.component.js +3 -0
  67. package/esm/components/carousel/slide/slide.style.js +1 -2
  68. package/esm/components/checkbox/checkbox-group.component.js +3 -0
  69. package/esm/components/checkbox/checkbox-svg.component.js +2 -0
  70. package/esm/components/checkbox/checkbox.component.js +7 -0
  71. package/esm/components/checkbox/checkbox.style.d.ts +1 -1
  72. package/esm/components/confirm/confirm.component.js +38 -0
  73. package/esm/components/content/content.component.js +3 -0
  74. package/esm/components/date/__internal__/date-formats/index.js +19 -6
  75. package/esm/components/date/__internal__/date-picker/date-picker.component.js +15 -2
  76. package/esm/components/date/__internal__/date-picker/day-picker.style.js +7 -3
  77. package/esm/components/date/__internal__/navbar/navbar.component.js +2 -0
  78. package/esm/components/date/__internal__/utils.js +31 -1
  79. package/esm/components/date/__internal__/weekday/weekday.component.js +3 -0
  80. package/esm/components/date/date.component.js +54 -10
  81. package/esm/components/date-range/date-range.component.js +46 -14
  82. package/esm/components/decimal/decimal.component.js +29 -4
  83. package/esm/components/definition-list/dd.component.js +3 -0
  84. package/esm/components/definition-list/dl.component.js +8 -0
  85. package/esm/components/definition-list/dt.component.js +3 -0
  86. package/esm/components/detail/detail.component.js +8 -2
  87. package/esm/components/dialog/dialog.component.js +14 -0
  88. package/esm/components/dialog/dialog.style.js +2 -0
  89. package/esm/components/dialog-full-screen/dialog-full-screen.component.js +25 -0
  90. package/esm/components/dismissible-box/dismissible-box.component.js +3 -0
  91. package/esm/components/draggable/draggable-container.component.js +16 -4
  92. package/esm/components/draggable/draggable-item.component.js +11 -2
  93. package/esm/components/drawer/drawer.component.js +16 -0
  94. package/esm/components/drawer/drawer.style.js +7 -0
  95. package/esm/components/duelling-picklist/duelling-picklist.component.js +14 -2
  96. package/esm/components/duelling-picklist/picklist/picklist.component.js +7 -0
  97. package/esm/components/duelling-picklist/picklist-divider/picklist-divider.component.js +3 -0
  98. package/esm/components/duelling-picklist/picklist-group/picklist-group.component.js +7 -0
  99. package/esm/components/duelling-picklist/picklist-item/picklist-item.component.js +14 -0
  100. package/esm/components/duelling-picklist/picklist-placeholder/picklist-placeholder.component.js +2 -0
  101. package/esm/components/fieldset/fieldset.component.js +4 -0
  102. package/esm/components/flat-table/flat-table-body/flat-table-body.component.js +1 -0
  103. package/esm/components/flat-table/flat-table-body-draggable/flat-table-body-draggable.component.js +13 -0
  104. package/esm/components/flat-table/flat-table-cell/flat-table-cell.component.js +18 -0
  105. package/esm/components/flat-table/flat-table-checkbox/flat-table-checkbox.component.js +15 -0
  106. package/esm/components/flat-table/flat-table-head/flat-table-head.component.js +8 -4
  107. package/esm/components/flat-table/flat-table-header/flat-table-header-utils.js +4 -1
  108. package/esm/components/flat-table/flat-table-header/flat-table-header.component.js +13 -0
  109. package/esm/components/flat-table/flat-table-row/__internal__/flat-table-row-draggable.component.js +9 -0
  110. package/esm/components/flat-table/flat-table-row/flat-table-row.component.js +35 -0
  111. package/esm/components/flat-table/flat-table-row/flat-table-row.style.js +11 -2
  112. package/esm/components/flat-table/flat-table-row-header/flat-table-row-header.component.js +15 -0
  113. package/esm/components/flat-table/flat-table.component.js +20 -2
  114. package/esm/components/flat-table/flat-table.style.js +3 -0
  115. package/esm/components/flat-table/sort/sort.component.js +7 -0
  116. package/esm/components/form/__internal__/form-summary.component.js +7 -0
  117. package/esm/components/form/form.component.js +3 -0
  118. package/esm/components/form/form.style.js +3 -2
  119. package/esm/components/global-header/global-header.component.js +6 -1
  120. package/esm/components/grid/grid-container/grid-container.component.js +6 -0
  121. package/esm/components/grid/grid-item/grid-item.component.js +6 -0
  122. package/esm/components/grid/grid-item/grid-item.style.js +14 -0
  123. package/esm/components/grouped-character/grouped-character.component.js +21 -3
  124. package/esm/components/heading/heading.component.js +9 -2
  125. package/esm/components/help/help.component.js +8 -0
  126. package/esm/components/hr/hr.component.js +5 -0
  127. package/esm/components/i18n-provider/i18n-provider.component.js +2 -0
  128. package/esm/components/icon/icon-unicodes.js +1 -2
  129. package/esm/components/icon/icon.component.js +12 -1
  130. package/esm/components/icon/icon.style.js +6 -0
  131. package/esm/components/icon-button/icon-button.component.js +4 -0
  132. package/esm/components/image/image.component.js +3 -0
  133. package/esm/components/image/image.style.js +1 -2
  134. package/esm/components/inline-inputs/inline-inputs.component.js +6 -0
  135. package/esm/components/link/link.component.js +12 -3
  136. package/esm/components/link/link.style.js +4 -0
  137. package/esm/components/link-preview/__internal__/placeholder.component.js +2 -0
  138. package/esm/components/link-preview/link-preview.component.js +7 -0
  139. package/esm/components/loader/loader-square.style.js +6 -0
  140. package/esm/components/loader/loader.component.js +3 -0
  141. package/esm/components/loader-bar/loader-bar.component.js +3 -0
  142. package/esm/components/loader-bar/loader-bar.style.js +4 -0
  143. package/esm/components/menu/__internal__/keyboard-navigation/index.js +9 -0
  144. package/esm/components/menu/__internal__/spec-helper/index.js +2 -0
  145. package/esm/components/menu/__internal__/submenu/submenu.component.js +59 -7
  146. package/esm/components/menu/menu-full-screen/menu-full-screen.component.js +8 -0
  147. package/esm/components/menu/menu-item/menu-item.component.js +35 -0
  148. package/esm/components/menu/menu-segment-title/menu-segment-title.component.js +1 -0
  149. package/esm/components/menu/menu.component.js +8 -0
  150. package/esm/components/menu/menu.context.js +3 -1
  151. package/esm/components/menu/scrollable-block/scrollable-block.component.js +9 -0
  152. package/esm/components/message/message-content/message-content.component.js +2 -0
  153. package/esm/components/message/message.component.js +5 -0
  154. package/esm/components/message/type-icon/type-icon.component.js +2 -0
  155. package/esm/components/modal/__internal__/modal-manager.js +24 -0
  156. package/esm/components/modal/modal.component.js +6 -0
  157. package/esm/components/multi-action-button/multi-action-button.component.js +20 -3
  158. package/esm/components/navigation-bar/navigation-bar.component.js +3 -0
  159. package/esm/components/note/note.component.js +10 -1
  160. package/esm/components/number/number.component.js +9 -2
  161. package/esm/components/numeral-date/numeral-date.component.js +22 -9
  162. package/esm/components/pager/__internal__/pager-navigation-link.component.js +11 -0
  163. package/esm/components/pager/__internal__/pager-navigation.component.js +22 -0
  164. package/esm/components/pager/pager.component.js +29 -0
  165. package/esm/components/pages/page/page.component.js +3 -0
  166. package/esm/components/pages/pages.component.js +14 -4
  167. package/esm/components/pill/pill.component.js +3 -0
  168. package/esm/components/pill/pill.style.js +4 -0
  169. package/esm/components/pod/pod.component.js +40 -4
  170. package/esm/components/pod/pod.style.js +8 -6
  171. package/esm/components/popover-container/popover-container.component.js +14 -2
  172. package/esm/components/popover-container/popover-container.style.js +3 -0
  173. package/esm/components/portal/portal.js +14 -2
  174. package/esm/components/portrait/portrait-gravatar.component.js +4 -0
  175. package/esm/components/portrait/portrait-initials.component.js +12 -10
  176. package/esm/components/portrait/portrait.component.js +10 -0
  177. package/esm/components/portrait/portrait.style.js +10 -3
  178. package/esm/components/preview/__internal__/preview-placeholder.component.js +3 -0
  179. package/esm/components/preview/preview.component.js +7 -0
  180. package/esm/components/preview/preview.style.js +1 -2
  181. package/esm/components/profile/profile.component.js +8 -0
  182. package/esm/components/progress-tracker/progress-tracker.component.js +24 -2
  183. package/esm/components/progress-tracker/progress-tracker.style.js +5 -0
  184. package/esm/components/radio-button/index.d.ts +4 -6
  185. package/esm/components/radio-button/index.js +2 -2
  186. package/esm/components/radio-button/radio-button-group.component.d.ts +42 -0
  187. package/esm/components/radio-button/radio-button-group.component.js +187 -48
  188. package/esm/components/radio-button/radio-button-group.style.d.ts +5 -0
  189. package/esm/components/radio-button/radio-button-svg.component.d.ts +3 -0
  190. package/esm/components/radio-button/radio-button-svg.component.js +3 -0
  191. package/esm/components/radio-button/radio-button.component.d.ts +28 -0
  192. package/esm/components/radio-button/radio-button.component.js +532 -84
  193. package/esm/components/radio-button/radio-button.style.d.ts +5 -0
  194. package/esm/components/search/search.component.js +21 -2
  195. package/esm/components/select/__internal__/select-text/select-text.component.js +13 -0
  196. package/esm/components/select/filterable-select/filterable-select.component.js +73 -8
  197. package/esm/components/select/list-action-button/list-action-button.component.js +4 -0
  198. package/esm/components/select/multi-select/multi-select.component.js +81 -15
  199. package/esm/components/select/option/option.component.js +12 -0
  200. package/esm/components/select/option-group-header/option-group-header.component.js +3 -0
  201. package/esm/components/select/option-row/option-row.component.js +9 -0
  202. package/esm/components/select/select-list/select-list.component.js +45 -2
  203. package/esm/components/select/select-list/select-list.style.js +1 -2
  204. package/esm/components/select/select-list/update-list-scroll.js +3 -0
  205. package/esm/components/select/select-textbox/select-textbox.component.js +41 -2
  206. package/esm/components/select/simple-select/simple-select.component.js +60 -2
  207. package/esm/components/select/utils/get-next-child-by-text.js +8 -0
  208. package/esm/components/select/utils/get-next-index-by-key.js +13 -0
  209. package/esm/components/select/utils/highlight-part-of-text.js +7 -0
  210. package/esm/components/select/utils/is-expected-option.js +4 -0
  211. package/esm/components/select/utils/is-expected-value.js +1 -0
  212. package/esm/components/select/utils/with-filter.hoc.js +29 -3
  213. package/esm/components/settings-row/settings-row.component.js +10 -2
  214. package/esm/components/show-edit-pod/show-edit-pod.component.js +43 -6
  215. package/esm/components/sidebar/__internal__/sidebar-header/sidebar-header.component.js +2 -0
  216. package/esm/components/sidebar/sidebar.component.js +4 -3
  217. package/esm/components/simple-color-picker/color-sample-box/color-sample-box.component.js +5 -1
  218. package/esm/components/simple-color-picker/simple-color/simple-color.component.js +7 -0
  219. package/esm/components/simple-color-picker/simple-color-picker.component.js +41 -8
  220. package/esm/components/simple-color-picker/simple-color-picker.style.js +2 -0
  221. package/esm/components/simple-color-picker/tick-icon/tick-icon.style.js +6 -4
  222. package/esm/components/split-button/split-button.component.js +20 -1
  223. package/esm/components/step-sequence/step-sequence-item/step-sequence-item.component.js +9 -0
  224. package/esm/components/step-sequence/step-sequence.component.js +3 -0
  225. package/esm/components/switch/__internal__/switch-slider.component.js +2 -0
  226. package/esm/components/switch/switch.component.js +7 -0
  227. package/esm/components/tabs/__internal__/tab-title/tab-title.component.js +19 -8
  228. package/esm/components/tabs/__internal__/tabs-header/tabs-header.component.js +2 -0
  229. package/esm/components/tabs/__internal__/tabs-header/tabs-header.style.js +3 -0
  230. package/esm/components/tabs/tab/tab.component.js +24 -8
  231. package/esm/components/tabs/tabs.component.js +54 -24
  232. package/esm/components/text-editor/__internal__/decorators/link-decorator.js +10 -10
  233. package/esm/components/text-editor/__internal__/editor-counter/editor-counter.component.js +6 -0
  234. package/esm/components/text-editor/__internal__/editor-link/editor-link.component.js +7 -2
  235. package/esm/components/text-editor/__internal__/label-wrapper/label-wrapper.component.js +3 -0
  236. package/esm/components/text-editor/__internal__/toolbar/toolbar-button/toolbar-button.component.js +6 -0
  237. package/esm/components/text-editor/__internal__/toolbar/toolbar.component.js +10 -0
  238. package/esm/components/text-editor/__internal__/utils/utils.js +21 -9
  239. package/esm/components/text-editor/text-editor.component.js +53 -22
  240. package/esm/components/textarea/textarea.component.js +50 -6
  241. package/esm/components/textbox/textbox.component.js +9 -2
  242. package/esm/components/tile/tile-footer/tile-footer.component.js +5 -2
  243. package/esm/components/tile/tile.component.js +10 -0
  244. package/esm/components/tile-select/__internal__/accordion/accordion.component.js +2 -0
  245. package/esm/components/tile-select/tile-select-group.component.js +16 -2
  246. package/esm/components/tile-select/tile-select.component.js +33 -4
  247. package/esm/components/toast/toast.component.js +18 -0
  248. package/esm/components/tooltip/tooltip-pointer.style.js +2 -0
  249. package/esm/components/tooltip/tooltip.component.js +3 -0
  250. package/esm/components/tooltip/tooltip.style.js +6 -0
  251. package/esm/components/typography/list.component.js +7 -0
  252. package/esm/components/typography/typography.component.js +28 -0
  253. package/esm/components/vertical-divider/vertical-divider.component.js +3 -0
  254. package/esm/hooks/__internal__/useCharacterCount/useCharacterCount.js +4 -0
  255. package/esm/hooks/__internal__/useClickAwayListener/useClickAwayListener.js +2 -3
  256. package/esm/hooks/__internal__/useFloating/useFloating.js +6 -0
  257. package/esm/hooks/__internal__/useIsStickyFooterForm/useIsStickyFooterForm.js +1 -0
  258. package/esm/hooks/__internal__/useMenuKeyboardNavigation/useMenuKeyboardNavigation.js +16 -2
  259. package/esm/hooks/__internal__/useModalManager/useModalManager.js +4 -0
  260. package/esm/hooks/__internal__/useResizeObserver/useResizeObserver.js +8 -3
  261. package/esm/hooks/__internal__/useScrollBlock/scroll-block-manager.js +16 -6
  262. package/esm/hooks/__internal__/useScrollBlock/useScrollBlock.js +15 -11
  263. package/esm/hooks/useMediaQuery/useMediaQuery.js +2 -0
  264. package/esm/locales/en-gb.js +8 -1
  265. package/esm/locales/pl-pl.js +8 -1
  266. package/esm/style/design-tokens/carbon-scoped-tokens-provider/carbon-scoped-tokens-provider.component.js +0 -1
  267. package/esm/style/design-tokens/debug-theme.util.js +9 -5
  268. package/esm/style/design-tokens/generate-css-variables.util.js +0 -1
  269. package/esm/style/palette/index.js +6 -2
  270. package/esm/style/themes/aegean/aegean-theme.config.js +3 -0
  271. package/esm/style/themes/base/base-theme.config.js +4 -2
  272. package/esm/style/themes/base/index.js +2 -4
  273. package/esm/style/themes/mint/mint-theme.config.js +3 -0
  274. package/esm/style/themes/sage/index.js +2 -4
  275. package/esm/style/themes/test-utils.js +4 -4
  276. package/esm/style/utils/add-hex-symbols.js +1 -0
  277. package/esm/style/utils/at-opacity.js +1 -0
  278. package/esm/style/utils/color.js +8 -3
  279. package/esm/style/utils/filter-out-styled-system-spacing-props.js +2 -0
  280. package/esm/style/utils/filter-styled-system-padding-props.js +1 -2
  281. package/esm/style/utils/form-style-utils.js +12 -0
  282. package/esm/style/utils/get-color-value.js +1 -0
  283. package/esm/style/utils/get-rgb-values.js +1 -1
  284. package/esm/style/utils/merge-deep.js +6 -1
  285. package/esm/style/utils/mix.js +7 -1
  286. package/esm/style/utils/width.js +0 -1
  287. package/lib/__internal__/DeprecationWarning.js +5 -0
  288. package/lib/__internal__/character-count/character-count.component.js +6 -0
  289. package/lib/__internal__/character-count/character-count.style.js +6 -0
  290. package/lib/__internal__/character-count/index.js +2 -0
  291. package/lib/__internal__/checkable-input/checkable-input-svg-wrapper.style.js +3 -0
  292. package/lib/__internal__/checkable-input/checkable-input.component.js +16 -0
  293. package/lib/__internal__/checkable-input/checkable-input.style.js +11 -0
  294. package/lib/__internal__/checkable-input/hidden-checkable-input.component.js +20 -0
  295. package/lib/__internal__/checkable-input/hidden-checkable-input.style.js +3 -0
  296. package/lib/__internal__/checkable-input/index.js +2 -0
  297. package/lib/__internal__/field-help/field-help.component.js +6 -0
  298. package/lib/__internal__/field-help/field-help.style.js +4 -0
  299. package/lib/__internal__/field-help/index.js +2 -0
  300. package/lib/__internal__/fieldset/fieldset.component.js +9 -0
  301. package/lib/__internal__/fieldset/fieldset.style.js +7 -0
  302. package/lib/__internal__/fieldset/index.js +2 -0
  303. package/lib/__internal__/filter-object-properties/filter-object-properties.js +1 -0
  304. package/lib/__internal__/filter-object-properties/index.js +2 -0
  305. package/lib/__internal__/focus-trap/focus-trap-utils.js +26 -6
  306. package/lib/__internal__/focus-trap/focus-trap.component.js +26 -4
  307. package/lib/__internal__/focus-trap/index.js +2 -0
  308. package/lib/__internal__/form-field/form-field.component.js +18 -0
  309. package/lib/__internal__/form-field/form-field.style.js +6 -0
  310. package/lib/__internal__/form-field/index.js +2 -0
  311. package/lib/__internal__/full-screen-heading/full-screen-heading.component.js +10 -0
  312. package/lib/__internal__/full-screen-heading/full-screen-heading.style.js +5 -0
  313. package/lib/__internal__/full-screen-heading/index.js +2 -0
  314. package/lib/__internal__/i18n-context/index.js +5 -0
  315. package/lib/__internal__/input/index.js +4 -0
  316. package/lib/__internal__/input/input-presentation.component.js +13 -0
  317. package/lib/__internal__/input/input-presentation.style.js +12 -0
  318. package/lib/__internal__/input/input.component.js +33 -2
  319. package/lib/__internal__/input/input.style.js +4 -0
  320. package/lib/__internal__/input-behaviour/index.js +2 -0
  321. package/lib/__internal__/input-behaviour/input-behaviour.component.js +12 -2
  322. package/lib/__internal__/input-behaviour/input-group-behaviour.component.js +8 -0
  323. package/lib/__internal__/input-behaviour/useInputBehaviour.js +5 -2
  324. package/lib/__internal__/input-icon-toggle/index.js +2 -0
  325. package/lib/__internal__/input-icon-toggle/input-icon-toggle.component.js +11 -0
  326. package/lib/__internal__/input-icon-toggle/input-icon-toggle.style.js +7 -0
  327. package/lib/__internal__/label/icon-wrapper.style.js +5 -0
  328. package/lib/__internal__/label/index.js +2 -0
  329. package/lib/__internal__/label/label.component.js +22 -0
  330. package/lib/__internal__/label/label.style.js +4 -0
  331. package/lib/__internal__/popover/index.js +2 -0
  332. package/lib/__internal__/popover/popover.component.js +24 -0
  333. package/lib/__internal__/popover/popover.style.js +4 -0
  334. package/lib/__internal__/radio-button-mapper/index.d.ts +2 -2
  335. package/lib/__internal__/radio-button-mapper/index.js +2 -0
  336. package/lib/__internal__/radio-button-mapper/radio-button-mapper.component.d.ts +29 -0
  337. package/lib/__internal__/radio-button-mapper/radio-button-mapper.component.js +30 -21
  338. package/lib/__internal__/sticky-footer/index.js +2 -0
  339. package/lib/__internal__/sticky-footer/sticky-footer.component.js +13 -0
  340. package/lib/__internal__/sticky-footer/sticky-footer.style.js +4 -0
  341. package/lib/__internal__/tooltip-provider/index.js +9 -0
  342. package/lib/__internal__/utils/helpers/browser-type-check/index.js +3 -0
  343. package/lib/__internal__/utils/helpers/events/composedPath.js +6 -0
  344. package/lib/__internal__/utils/helpers/events/events.js +18 -0
  345. package/lib/__internal__/utils/helpers/events/index.js +2 -0
  346. package/lib/__internal__/utils/helpers/guid/index.js +3 -0
  347. package/lib/__internal__/utils/helpers/tags/index.js +2 -0
  348. package/lib/__internal__/utils/helpers/tags/tags-specs/index.js +1 -0
  349. package/lib/__internal__/utils/helpers/tags/tags-specs/tags-specs.js +5 -2
  350. package/lib/__internal__/utils/helpers/tags/tags.js +5 -0
  351. package/lib/__internal__/utils/helpers/useUniqueId/index.js +5 -0
  352. package/lib/__internal__/utils/logger/index.js +2 -1
  353. package/lib/__internal__/validation-message/index.js +2 -0
  354. package/lib/__internal__/validation-message/validation-message.component.js +6 -0
  355. package/lib/__internal__/validation-message/validation-message.style.js +4 -0
  356. package/lib/__internal__/validations/index.js +2 -0
  357. package/lib/__internal__/validations/validation-icon.component.js +18 -0
  358. package/lib/__internal__/validations/validation-icon.style.js +8 -0
  359. package/lib/__spec_helper__/enzyme-snapshot-helper.js +6 -0
  360. package/lib/__spec_helper__/expect.js +8 -2
  361. package/lib/__spec_helper__/index.js +4 -0
  362. package/lib/__spec_helper__/mock-match-media.js +7 -0
  363. package/lib/__spec_helper__/mock-resize-observer.js +3 -0
  364. package/lib/__spec_helper__/test-utils.js +87 -28
  365. package/lib/components/accordion/accordion-group/accordion-group.component.js +20 -0
  366. package/lib/components/accordion/accordion.component.js +19 -0
  367. package/lib/components/accordion/accordion.style.js +9 -0
  368. package/lib/components/accordion/index.js +3 -0
  369. package/lib/components/action-popover/action-popover-context.js +4 -0
  370. package/lib/components/action-popover/action-popover-divider/action-popover-divider.component.js +2 -0
  371. package/lib/components/action-popover/action-popover-item/action-popover-item.component.js +34 -2
  372. package/lib/components/action-popover/action-popover-menu/action-popover-menu.component.js +22 -2
  373. package/lib/components/action-popover/action-popover-menu-button/action-popover-menu-button.component.js +8 -0
  374. package/lib/components/action-popover/action-popover.component.js +35 -4
  375. package/lib/components/action-popover/action-popover.style.js +10 -0
  376. package/lib/components/action-popover/index.js +6 -0
  377. package/lib/components/advanced-color-picker/advanced-color-picker-cell.style.js +4 -0
  378. package/lib/components/advanced-color-picker/advanced-color-picker.component.js +30 -0
  379. package/lib/components/advanced-color-picker/advanced-color-picker.style.js +14 -0
  380. package/lib/components/advanced-color-picker/index.js +2 -0
  381. package/lib/components/alert/alert.component.js +7 -0
  382. package/lib/components/alert/index.js +2 -0
  383. package/lib/components/anchor-navigation/anchor-navigation-item/anchor-navigation-item.component.js +6 -0
  384. package/lib/components/anchor-navigation/anchor-navigation-item/anchor-navigation-item.style.js +4 -0
  385. package/lib/components/anchor-navigation/anchor-navigation.component.js +27 -5
  386. package/lib/components/anchor-navigation/anchor-navigation.style.js +3 -0
  387. package/lib/components/anchor-navigation/anchor-section-divider.component.js +3 -0
  388. package/lib/components/anchor-navigation/index.js +4 -0
  389. package/lib/components/badge/badge.component.js +6 -0
  390. package/lib/components/badge/badge.style.js +6 -0
  391. package/lib/components/badge/index.js +2 -0
  392. package/lib/components/batch-selection/batch-selection.component.js +11 -0
  393. package/lib/components/batch-selection/batch-selection.style.js +7 -0
  394. package/lib/components/batch-selection/index.js +2 -0
  395. package/lib/components/box/box.component.js +9 -0
  396. package/lib/components/box/box.config.js +3 -0
  397. package/lib/components/box/index.js +2 -0
  398. package/lib/components/button/button-types.style.js +6 -0
  399. package/lib/components/button/button.component.js +29 -0
  400. package/lib/components/button/button.style.js +16 -0
  401. package/lib/components/button/index.js +3 -0
  402. package/lib/components/button-bar/button-bar.component.js +18 -2
  403. package/lib/components/button-bar/button-bar.style.js +8 -0
  404. package/lib/components/button-bar/index.js +2 -0
  405. package/lib/components/button-toggle/button-toggle-icon.component.js +7 -0
  406. package/lib/components/button-toggle/button-toggle-input.component.js +15 -0
  407. package/lib/components/button-toggle/button-toggle.component.js +17 -0
  408. package/lib/components/button-toggle/button-toggle.style.js +6 -0
  409. package/lib/components/button-toggle/index.js +2 -0
  410. package/lib/components/button-toggle-group/button-toggle-group.component.js +18 -0
  411. package/lib/components/button-toggle-group/button-toggle-group.style.js +7 -0
  412. package/lib/components/button-toggle-group/index.js +2 -0
  413. package/lib/components/carbon-provider/carbon-provider.component.js +12 -0
  414. package/lib/components/carbon-provider/index.js +2 -0
  415. package/lib/components/carbon-provider/top-modal-context.js +13 -3
  416. package/lib/components/card/card-column/card-column.component.js +6 -0
  417. package/lib/components/card/card-column/card-column.style.js +3 -0
  418. package/lib/components/card/card-column/index.js +2 -0
  419. package/lib/components/card/card-footer/card-footer.component.js +8 -0
  420. package/lib/components/card/card-footer/card-footer.style.js +7 -0
  421. package/lib/components/card/card-footer/index.js +2 -0
  422. package/lib/components/card/card-row/card-row.component.js +8 -0
  423. package/lib/components/card/card-row/card-row.style.js +7 -0
  424. package/lib/components/card/card-row/index.js +2 -0
  425. package/lib/components/card/card.component.js +19 -0
  426. package/lib/components/card/card.style.js +7 -0
  427. package/lib/components/card/index.js +5 -0
  428. package/lib/components/carousel/carousel.component.js +24 -0
  429. package/lib/components/carousel/carousel.style.js +8 -0
  430. package/lib/components/carousel/index.js +3 -0
  431. package/lib/components/carousel/slide/index.js +2 -0
  432. package/lib/components/carousel/slide/slide.component.js +8 -0
  433. package/lib/components/carousel/slide/slide.style.js +5 -2
  434. package/lib/components/carousel/slide.config.js +2 -0
  435. package/lib/components/checkbox/checkbox-group.component.js +13 -0
  436. package/lib/components/checkbox/checkbox-group.style.js +10 -0
  437. package/lib/components/checkbox/checkbox-svg.component.js +6 -0
  438. package/lib/components/checkbox/checkbox.component.js +19 -0
  439. package/lib/components/checkbox/checkbox.style.d.ts +1 -1
  440. package/lib/components/checkbox/checkbox.style.js +13 -0
  441. package/lib/components/checkbox/index.js +3 -0
  442. package/lib/components/confirm/confirm.component.js +51 -0
  443. package/lib/components/confirm/confirm.style.js +8 -0
  444. package/lib/components/confirm/index.js +2 -0
  445. package/lib/components/content/content.component.js +7 -0
  446. package/lib/components/content/content.style.js +6 -0
  447. package/lib/components/content/index.js +2 -0
  448. package/lib/components/date/__internal__/date-formats/index.js +19 -6
  449. package/lib/components/date/__internal__/date-picker/date-picker.component.js +31 -2
  450. package/lib/components/date/__internal__/date-picker/day-picker.style.js +10 -1
  451. package/lib/components/date/__internal__/date-picker/index.js +2 -0
  452. package/lib/components/date/__internal__/navbar/button.style.js +3 -0
  453. package/lib/components/date/__internal__/navbar/index.js +2 -0
  454. package/lib/components/date/__internal__/navbar/navbar.component.js +8 -0
  455. package/lib/components/date/__internal__/navbar/navbar.style.js +3 -0
  456. package/lib/components/date/__internal__/utils.js +42 -1
  457. package/lib/components/date/__internal__/weekday/abbr.style.js +3 -0
  458. package/lib/components/date/__internal__/weekday/index.js +2 -0
  459. package/lib/components/date/__internal__/weekday/weekday.component.js +8 -0
  460. package/lib/components/date/__internal__/weekday/weekday.style.js +3 -0
  461. package/lib/components/date/date.component.js +71 -10
  462. package/lib/components/date/date.style.js +8 -0
  463. package/lib/components/date/index.js +2 -0
  464. package/lib/components/date-range/date-range.component.js +63 -14
  465. package/lib/components/date-range/date-range.context.js +4 -0
  466. package/lib/components/date-range/date-range.style.js +8 -0
  467. package/lib/components/date-range/index.js +2 -0
  468. package/lib/components/decimal/decimal.component.js +38 -4
  469. package/lib/components/decimal/index.js +2 -0
  470. package/lib/components/definition-list/__internal__/dl.context.js +4 -0
  471. package/lib/components/definition-list/dd.component.js +7 -0
  472. package/lib/components/definition-list/definition-list.style.js +8 -0
  473. package/lib/components/definition-list/dl.component.js +20 -0
  474. package/lib/components/definition-list/dt.component.js +10 -0
  475. package/lib/components/definition-list/index.js +4 -0
  476. package/lib/components/detail/detail.component.js +17 -2
  477. package/lib/components/detail/detail.style.js +8 -0
  478. package/lib/components/detail/index.js +2 -0
  479. package/lib/components/dialog/dialog.component.js +32 -0
  480. package/lib/components/dialog/dialog.style.js +14 -0
  481. package/lib/components/dialog/index.js +2 -0
  482. package/lib/components/dialog-full-screen/content.style.js +5 -0
  483. package/lib/components/dialog-full-screen/dialog-full-screen.component.js +42 -0
  484. package/lib/components/dialog-full-screen/dialog-full-screen.style.js +11 -0
  485. package/lib/components/dialog-full-screen/index.js +2 -0
  486. package/lib/components/dismissible-box/dismissible-box.component.js +9 -0
  487. package/lib/components/dismissible-box/dismissible-box.style.js +7 -0
  488. package/lib/components/dismissible-box/index.js +2 -0
  489. package/lib/components/draggable/draggable-container.component.js +30 -4
  490. package/lib/components/draggable/draggable-item.component.js +19 -2
  491. package/lib/components/draggable/draggable-item.style.js +6 -0
  492. package/lib/components/draggable/index.js +3 -0
  493. package/lib/components/drawer/drawer.component.js +29 -0
  494. package/lib/components/drawer/drawer.style.js +15 -0
  495. package/lib/components/drawer/index.js +3 -0
  496. package/lib/components/duelling-picklist/duelling-picklist.component.js +26 -2
  497. package/lib/components/duelling-picklist/duelling-picklist.context.js +4 -0
  498. package/lib/components/duelling-picklist/duelling-picklist.style.js +6 -0
  499. package/lib/components/duelling-picklist/index.js +7 -0
  500. package/lib/components/duelling-picklist/picklist/picklist.component.js +25 -0
  501. package/lib/components/duelling-picklist/picklist/picklist.style.js +4 -0
  502. package/lib/components/duelling-picklist/picklist-divider/picklist-divider.component.js +6 -0
  503. package/lib/components/duelling-picklist/picklist-divider/picklist-divider.style.js +3 -0
  504. package/lib/components/duelling-picklist/picklist-group/picklist-group.component.js +22 -0
  505. package/lib/components/duelling-picklist/picklist-group/picklist-group.style.js +7 -0
  506. package/lib/components/duelling-picklist/picklist-item/picklist-item.component.js +25 -0
  507. package/lib/components/duelling-picklist/picklist-item/picklist-item.style.js +8 -0
  508. package/lib/components/duelling-picklist/picklist-placeholder/picklist-placeholder.component.js +6 -0
  509. package/lib/components/fieldset/fieldset.component.js +11 -0
  510. package/lib/components/fieldset/fieldset.style.js +9 -0
  511. package/lib/components/fieldset/index.js +2 -0
  512. package/lib/components/flat-table/flat-table-body/flat-table-body.component.js +6 -0
  513. package/lib/components/flat-table/flat-table-body/index.js +2 -0
  514. package/lib/components/flat-table/flat-table-body-draggable/flat-table-body-draggable.component.js +23 -0
  515. package/lib/components/flat-table/flat-table-body-draggable/flat-table-body-draggable.style.js +4 -0
  516. package/lib/components/flat-table/flat-table-body-draggable/index.js +2 -0
  517. package/lib/components/flat-table/flat-table-cell/flat-table-cell.component.js +28 -0
  518. package/lib/components/flat-table/flat-table-cell/flat-table-cell.style.js +8 -0
  519. package/lib/components/flat-table/flat-table-cell/index.js +2 -0
  520. package/lib/components/flat-table/flat-table-checkbox/flat-table-checkbox.component.js +22 -0
  521. package/lib/components/flat-table/flat-table-checkbox/flat-table-checkbox.style.js +6 -0
  522. package/lib/components/flat-table/flat-table-checkbox/index.js +2 -0
  523. package/lib/components/flat-table/flat-table-head/flat-table-head.component.js +15 -4
  524. package/lib/components/flat-table/flat-table-head/flat-table-head.style.js +6 -0
  525. package/lib/components/flat-table/flat-table-head/index.js +2 -0
  526. package/lib/components/flat-table/flat-table-header/flat-table-header-utils.js +5 -1
  527. package/lib/components/flat-table/flat-table-header/flat-table-header.component.js +23 -0
  528. package/lib/components/flat-table/flat-table-header/flat-table-header.style.js +9 -0
  529. package/lib/components/flat-table/flat-table-header/index.js +2 -0
  530. package/lib/components/flat-table/flat-table-row/__internal__/flat-table-row-draggable.component.js +13 -0
  531. package/lib/components/flat-table/flat-table-row/flat-table-row.component.js +50 -0
  532. package/lib/components/flat-table/flat-table-row/flat-table-row.style.js +23 -2
  533. package/lib/components/flat-table/flat-table-row/index.js +2 -0
  534. package/lib/components/flat-table/flat-table-row-header/flat-table-row-header.component.js +25 -0
  535. package/lib/components/flat-table/flat-table-row-header/flat-table-row-header.style.js +8 -0
  536. package/lib/components/flat-table/flat-table-row-header/index.js +2 -0
  537. package/lib/components/flat-table/flat-table.component.js +29 -2
  538. package/lib/components/flat-table/flat-table.style.js +17 -0
  539. package/lib/components/flat-table/index.js +11 -0
  540. package/lib/components/flat-table/sort/index.js +2 -0
  541. package/lib/components/flat-table/sort/sort.component.js +16 -0
  542. package/lib/components/flat-table/sort/sort.style.js +4 -0
  543. package/lib/components/form/__internal__/form-summary.component.js +15 -0
  544. package/lib/components/form/__internal__/form-summary.style.js +7 -0
  545. package/lib/components/form/form.component.js +12 -0
  546. package/lib/components/form/form.style.js +17 -2
  547. package/lib/components/form/index.js +2 -0
  548. package/lib/components/global-header/global-header.component.js +16 -1
  549. package/lib/components/global-header/index.js +2 -0
  550. package/lib/components/grid/grid-container/grid-container.component.js +10 -0
  551. package/lib/components/grid/grid-container/grid-container.style.js +4 -0
  552. package/lib/components/grid/grid-container/index.js +2 -0
  553. package/lib/components/grid/grid-item/grid-item.component.js +10 -0
  554. package/lib/components/grid/grid-item/grid-item.style.js +19 -0
  555. package/lib/components/grid/grid-item/index.js +2 -0
  556. package/lib/components/grid/index.js +3 -0
  557. package/lib/components/grouped-character/grouped-character.component.js +28 -3
  558. package/lib/components/grouped-character/grouped-character.utils.js +4 -0
  559. package/lib/components/grouped-character/index.js +2 -0
  560. package/lib/components/heading/heading.component.js +16 -2
  561. package/lib/components/heading/heading.style.js +13 -0
  562. package/lib/components/heading/index.js +2 -0
  563. package/lib/components/help/help.component.js +20 -0
  564. package/lib/components/help/help.style.js +8 -0
  565. package/lib/components/help/index.js +2 -0
  566. package/lib/components/hr/hr.component.js +10 -0
  567. package/lib/components/hr/hr.style.js +5 -0
  568. package/lib/components/hr/index.js +2 -0
  569. package/lib/components/i18n-provider/i18n-provider.component.js +8 -0
  570. package/lib/components/i18n-provider/index.js +2 -0
  571. package/lib/components/icon/icon-unicodes.js +1 -2
  572. package/lib/components/icon/icon.component.js +27 -1
  573. package/lib/components/icon/icon.style.js +18 -0
  574. package/lib/components/icon/index.js +2 -0
  575. package/lib/components/icon-button/icon-button.component.js +15 -0
  576. package/lib/components/icon-button/icon-button.style.js +8 -0
  577. package/lib/components/icon-button/index.js +2 -0
  578. package/lib/components/image/image.component.js +8 -0
  579. package/lib/components/image/image.style.js +7 -2
  580. package/lib/components/image/index.js +2 -0
  581. package/lib/components/inline-inputs/index.js +3 -0
  582. package/lib/components/inline-inputs/inline-inputs.component.js +17 -0
  583. package/lib/components/inline-inputs/inline-inputs.style.js +8 -0
  584. package/lib/components/link/index.js +2 -0
  585. package/lib/components/link/link.component.js +24 -3
  586. package/lib/components/link/link.style.js +11 -0
  587. package/lib/components/link-preview/__internal__/placeholder.component.js +6 -0
  588. package/lib/components/link-preview/index.js +2 -0
  589. package/lib/components/link-preview/link-preview.component.js +17 -0
  590. package/lib/components/link-preview/link-preview.style.js +6 -0
  591. package/lib/components/loader/index.js +2 -0
  592. package/lib/components/loader/loader-square.style.js +10 -0
  593. package/lib/components/loader/loader.component.js +9 -0
  594. package/lib/components/loader/loader.style.js +5 -0
  595. package/lib/components/loader-bar/index.js +2 -0
  596. package/lib/components/loader-bar/loader-bar.component.js +10 -0
  597. package/lib/components/loader-bar/loader-bar.style.js +10 -0
  598. package/lib/components/menu/__internal__/keyboard-navigation/index.js +11 -0
  599. package/lib/components/menu/__internal__/spec-helper/index.js +7 -0
  600. package/lib/components/menu/__internal__/submenu/submenu.component.js +80 -7
  601. package/lib/components/menu/__internal__/submenu/submenu.context.js +4 -0
  602. package/lib/components/menu/__internal__/submenu/submenu.style.js +12 -0
  603. package/lib/components/menu/index.js +7 -0
  604. package/lib/components/menu/menu-divider/menu-divider.component.js +10 -0
  605. package/lib/components/menu/menu-divider/menu-divider.style.js +6 -0
  606. package/lib/components/menu/menu-full-screen/index.js +2 -0
  607. package/lib/components/menu/menu-full-screen/menu-full-screen.component.js +23 -0
  608. package/lib/components/menu/menu-full-screen/menu-full-screen.style.js +12 -0
  609. package/lib/components/menu/menu-item/index.js +2 -0
  610. package/lib/components/menu/menu-item/menu-item.component.js +52 -0
  611. package/lib/components/menu/menu-item/menu-item.style.js +8 -0
  612. package/lib/components/menu/menu-segment-title/menu-segment-title.component.js +11 -0
  613. package/lib/components/menu/menu-segment-title/menu-segment-title.style.js +6 -0
  614. package/lib/components/menu/menu.component.js +18 -0
  615. package/lib/components/menu/menu.context.js +7 -1
  616. package/lib/components/menu/menu.style.js +9 -0
  617. package/lib/components/menu/scrollable-block/index.js +2 -0
  618. package/lib/components/menu/scrollable-block/scrollable-block.component.js +19 -0
  619. package/lib/components/menu/scrollable-block/scrollable-block.style.js +7 -0
  620. package/lib/components/message/index.js +2 -0
  621. package/lib/components/message/message-content/message-content.component.js +7 -0
  622. package/lib/components/message/message-content/message-content.style.js +3 -0
  623. package/lib/components/message/message.component.js +16 -0
  624. package/lib/components/message/message.style.js +8 -0
  625. package/lib/components/message/type-icon/type-icon.component.js +7 -0
  626. package/lib/components/message/type-icon/type-icon.style.js +4 -0
  627. package/lib/components/modal/__internal__/modal-manager.js +25 -0
  628. package/lib/components/modal/index.js +3 -0
  629. package/lib/components/modal/modal.component.js +19 -0
  630. package/lib/components/modal/modal.style.js +6 -0
  631. package/lib/components/multi-action-button/index.js +2 -0
  632. package/lib/components/multi-action-button/multi-action-button.component.js +32 -3
  633. package/lib/components/multi-action-button/multi-action-button.style.js +9 -0
  634. package/lib/components/navigation-bar/index.js +2 -0
  635. package/lib/components/navigation-bar/navigation-bar.component.js +7 -0
  636. package/lib/components/navigation-bar/navigation-bar.style.js +6 -0
  637. package/lib/components/note/__internal__/status-icon/index.js +2 -0
  638. package/lib/components/note/__internal__/status-icon/status-icon.component.js +7 -0
  639. package/lib/components/note/__internal__/status-icon/status-icon.style.js +3 -0
  640. package/lib/components/note/index.js +2 -0
  641. package/lib/components/note/note.component.js +21 -1
  642. package/lib/components/note/note.style.js +8 -0
  643. package/lib/components/number/index.js +3 -0
  644. package/lib/components/number/number.component.js +14 -2
  645. package/lib/components/numeral-date/index.js +2 -0
  646. package/lib/components/numeral-date/numeral-date-context.js +4 -0
  647. package/lib/components/numeral-date/numeral-date.component.js +42 -9
  648. package/lib/components/numeral-date/numeral-date.style.js +9 -0
  649. package/lib/components/pager/__internal__/pager-navigation-link.component.js +18 -0
  650. package/lib/components/pager/__internal__/pager-navigation.component.js +34 -0
  651. package/lib/components/pager/index.js +2 -0
  652. package/lib/components/pager/pager.component.js +40 -0
  653. package/lib/components/pager/pager.style.js +10 -0
  654. package/lib/components/pages/index.js +3 -0
  655. package/lib/components/pages/page/index.js +2 -0
  656. package/lib/components/pages/page/page.component.js +14 -0
  657. package/lib/components/pages/page/page.style.js +5 -0
  658. package/lib/components/pages/pages.component.js +26 -4
  659. package/lib/components/pages/pages.config.js +2 -0
  660. package/lib/components/pages/pages.style.js +6 -0
  661. package/lib/components/pill/index.js +2 -0
  662. package/lib/components/pill/pill.component.js +10 -0
  663. package/lib/components/pill/pill.style.config.js +2 -0
  664. package/lib/components/pill/pill.style.js +15 -0
  665. package/lib/components/pod/index.js +2 -0
  666. package/lib/components/pod/pod.component.js +53 -4
  667. package/lib/components/pod/pod.style.js +19 -6
  668. package/lib/components/popover-container/index.js +2 -0
  669. package/lib/components/popover-container/popover-container.component.js +27 -2
  670. package/lib/components/popover-container/popover-container.style.js +10 -0
  671. package/lib/components/portal/index.js +2 -0
  672. package/lib/components/portal/portal.js +23 -2
  673. package/lib/components/portrait/index.js +2 -0
  674. package/lib/components/portrait/portrait-gravatar.component.js +10 -0
  675. package/lib/components/portrait/portrait-initials.component.js +20 -10
  676. package/lib/components/portrait/portrait.component.js +21 -0
  677. package/lib/components/portrait/portrait.style.js +19 -3
  678. package/lib/components/preview/__internal__/preview-placeholder.component.js +8 -0
  679. package/lib/components/preview/__internal__/preview-placeholder.style.js +4 -0
  680. package/lib/components/preview/index.js +2 -0
  681. package/lib/components/preview/preview.component.js +13 -0
  682. package/lib/components/preview/preview.style.js +6 -3
  683. package/lib/components/profile/index.js +2 -0
  684. package/lib/components/profile/profile.component.js +14 -0
  685. package/lib/components/profile/profile.style.js +7 -0
  686. package/lib/components/progress-tracker/index.js +2 -0
  687. package/lib/components/progress-tracker/progress-tracker.component.js +35 -2
  688. package/lib/components/progress-tracker/progress-tracker.config.js +1 -0
  689. package/lib/components/progress-tracker/progress-tracker.style.js +14 -0
  690. package/lib/components/radio-button/index.d.ts +4 -6
  691. package/lib/components/radio-button/index.js +5 -9
  692. package/lib/components/radio-button/radio-button-group.component.d.ts +42 -0
  693. package/lib/components/radio-button/radio-button-group.component.js +198 -49
  694. package/lib/components/radio-button/radio-button-group.style.d.ts +5 -0
  695. package/lib/components/radio-button/radio-button-group.style.js +4 -0
  696. package/lib/components/radio-button/radio-button-svg.component.d.ts +3 -0
  697. package/lib/components/radio-button/radio-button-svg.component.js +8 -0
  698. package/lib/components/radio-button/radio-button.component.d.ts +28 -0
  699. package/lib/components/radio-button/radio-button.component.js +548 -85
  700. package/lib/components/radio-button/radio-button.style.d.ts +5 -0
  701. package/lib/components/radio-button/radio-button.style.js +14 -0
  702. package/lib/components/search/index.js +2 -0
  703. package/lib/components/search/search-button.style.js +6 -0
  704. package/lib/components/search/search.component.js +34 -2
  705. package/lib/components/search/search.style.js +12 -0
  706. package/lib/components/select/__internal__/select-list-context.js +4 -0
  707. package/lib/components/select/__internal__/select-text/select-text.component.js +17 -0
  708. package/lib/components/select/__internal__/select-text/select-text.style.js +6 -0
  709. package/lib/components/select/filterable-select/filterable-select.component.js +91 -8
  710. package/lib/components/select/index.js +7 -0
  711. package/lib/components/select/list-action-button/list-action-button.component.js +12 -0
  712. package/lib/components/select/list-action-button/list-action-button.style.js +4 -0
  713. package/lib/components/select/multi-select/multi-select.component.js +102 -15
  714. package/lib/components/select/multi-select/multi-select.style.js +10 -0
  715. package/lib/components/select/option/option.component.js +21 -0
  716. package/lib/components/select/option/option.style.js +6 -0
  717. package/lib/components/select/option-group-header/option-group-header.component.js +8 -0
  718. package/lib/components/select/option-group-header/option-group-header.style.js +4 -0
  719. package/lib/components/select/option-row/option-row.component.js +18 -0
  720. package/lib/components/select/option-row/option-row.style.js +4 -0
  721. package/lib/components/select/select-list/select-list-container.style.js +4 -0
  722. package/lib/components/select/select-list/select-list.component.js +67 -2
  723. package/lib/components/select/select-list/select-list.style.js +5 -2
  724. package/lib/components/select/select-list/update-list-scroll.js +4 -0
  725. package/lib/components/select/select-textbox/select-textbox.component.js +53 -2
  726. package/lib/components/select/select.style.js +10 -0
  727. package/lib/components/select/simple-select/simple-select.component.js +78 -2
  728. package/lib/components/select/utils/get-next-child-by-text.js +9 -0
  729. package/lib/components/select/utils/get-next-index-by-key.js +14 -0
  730. package/lib/components/select/utils/highlight-part-of-text.js +11 -0
  731. package/lib/components/select/utils/is-expected-option.js +9 -0
  732. package/lib/components/select/utils/is-expected-value.js +2 -0
  733. package/lib/components/select/utils/is-navigation-key.js +1 -0
  734. package/lib/components/select/utils/matching-text.style.js +3 -0
  735. package/lib/components/select/utils/with-filter.hoc.js +43 -3
  736. package/lib/components/settings-row/index.js +2 -0
  737. package/lib/components/settings-row/settings-row.component.js +19 -2
  738. package/lib/components/settings-row/settings-row.style.js +8 -0
  739. package/lib/components/show-edit-pod/index.js +2 -0
  740. package/lib/components/show-edit-pod/show-edit-pod.component.js +58 -6
  741. package/lib/components/show-edit-pod/show-edit-pod.style.js +6 -0
  742. package/lib/components/sidebar/__internal__/sidebar-header/index.js +2 -0
  743. package/lib/components/sidebar/__internal__/sidebar-header/sidebar-header.component.js +6 -0
  744. package/lib/components/sidebar/__internal__/sidebar-header/sidebar-header.style.js +3 -0
  745. package/lib/components/sidebar/index.js +3 -0
  746. package/lib/components/sidebar/sidebar.component.js +26 -0
  747. package/lib/components/sidebar/sidebar.style.js +11 -0
  748. package/lib/components/simple-color-picker/color-sample-box/color-sample-box.component.js +11 -1
  749. package/lib/components/simple-color-picker/color-sample-box/color-sample-box.style.js +7 -0
  750. package/lib/components/simple-color-picker/color-sample-box/index.js +2 -0
  751. package/lib/components/simple-color-picker/index.js +3 -0
  752. package/lib/components/simple-color-picker/simple-color/index.js +2 -0
  753. package/lib/components/simple-color-picker/simple-color/simple-color.component.js +16 -0
  754. package/lib/components/simple-color-picker/simple-color/simple-color.style.js +3 -0
  755. package/lib/components/simple-color-picker/simple-color-input/simple-color-input.style.js +5 -0
  756. package/lib/components/simple-color-picker/simple-color-picker.component.js +59 -8
  757. package/lib/components/simple-color-picker/simple-color-picker.style.js +8 -0
  758. package/lib/components/simple-color-picker/tick-icon/tick-icon.style.js +12 -4
  759. package/lib/components/split-button/index.js +2 -0
  760. package/lib/components/split-button/split-button-children.style.js +7 -0
  761. package/lib/components/split-button/split-button-toggle.style.js +7 -0
  762. package/lib/components/split-button/split-button.component.js +40 -1
  763. package/lib/components/split-button/split-button.style.js +6 -0
  764. package/lib/components/step-sequence/index.js +3 -0
  765. package/lib/components/step-sequence/step-sequence-item/index.js +2 -0
  766. package/lib/components/step-sequence/step-sequence-item/step-sequence-item.component.js +17 -0
  767. package/lib/components/step-sequence/step-sequence-item/step-sequence-item.style.js +6 -0
  768. package/lib/components/step-sequence/step-sequence.component.js +9 -0
  769. package/lib/components/step-sequence/step-sequence.style.js +6 -0
  770. package/lib/components/switch/__internal__/switch-slider-panel.style.js +7 -0
  771. package/lib/components/switch/__internal__/switch-slider.component.js +12 -0
  772. package/lib/components/switch/__internal__/switch-slider.style.js +7 -0
  773. package/lib/components/switch/index.js +2 -0
  774. package/lib/components/switch/switch.component.js +18 -0
  775. package/lib/components/switch/switch.style.js +14 -0
  776. package/lib/components/tabs/__internal__/tab-title/index.js +2 -0
  777. package/lib/components/tabs/__internal__/tab-title/tab-title.component.js +37 -8
  778. package/lib/components/tabs/__internal__/tab-title/tab-title.style.js +8 -0
  779. package/lib/components/tabs/__internal__/tabs-header/index.js +2 -0
  780. package/lib/components/tabs/__internal__/tabs-header/tabs-header.component.js +6 -0
  781. package/lib/components/tabs/__internal__/tabs-header/tabs-header.style.js +8 -0
  782. package/lib/components/tabs/index.js +1 -0
  783. package/lib/components/tabs/tab/index.js +3 -0
  784. package/lib/components/tabs/tab/tab.component.js +35 -8
  785. package/lib/components/tabs/tab/tab.style.js +8 -0
  786. package/lib/components/tabs/tabs.component.js +75 -24
  787. package/lib/components/tabs/tabs.style.js +10 -0
  788. package/lib/components/text-editor/__internal__/decorators/index.js +5 -0
  789. package/lib/components/text-editor/__internal__/decorators/link-decorator.js +12 -10
  790. package/lib/components/text-editor/__internal__/editor-counter/editor-counter.component.js +11 -0
  791. package/lib/components/text-editor/__internal__/editor-counter/editor-counter.style.js +3 -0
  792. package/lib/components/text-editor/__internal__/editor-counter/index.js +2 -0
  793. package/lib/components/text-editor/__internal__/editor-link/editor-link.component.js +14 -2
  794. package/lib/components/text-editor/__internal__/editor-link/editor-link.style.js +4 -0
  795. package/lib/components/text-editor/__internal__/editor-link/index.js +2 -0
  796. package/lib/components/text-editor/__internal__/label-wrapper/index.js +2 -0
  797. package/lib/components/text-editor/__internal__/label-wrapper/label-wrapper.component.js +6 -0
  798. package/lib/components/text-editor/__internal__/toolbar/index.js +2 -0
  799. package/lib/components/text-editor/__internal__/toolbar/toolbar-button/index.js +2 -0
  800. package/lib/components/text-editor/__internal__/toolbar/toolbar-button/toolbar-button.component.js +12 -0
  801. package/lib/components/text-editor/__internal__/toolbar/toolbar-button/toolbar-button.style.js +6 -0
  802. package/lib/components/text-editor/__internal__/toolbar/toolbar.component.js +22 -0
  803. package/lib/components/text-editor/__internal__/toolbar/toolbar.style.js +4 -0
  804. package/lib/components/text-editor/__internal__/utils/index.js +1 -0
  805. package/lib/components/text-editor/__internal__/utils/utils.js +49 -9
  806. package/lib/components/text-editor/index.js +3 -0
  807. package/lib/components/text-editor/text-editor.component.js +76 -22
  808. package/lib/components/text-editor/text-editor.style.js +8 -0
  809. package/lib/components/textarea/index.js +2 -0
  810. package/lib/components/textarea/textarea.component.js +71 -6
  811. package/lib/components/textarea/textarea.style.js +10 -0
  812. package/lib/components/textbox/__internal__/prefix.style.js +3 -0
  813. package/lib/components/textbox/index.js +2 -0
  814. package/lib/components/textbox/textbox.component.js +28 -2
  815. package/lib/components/textbox/textbox.style.js +4 -0
  816. package/lib/components/tile/index.js +2 -0
  817. package/lib/components/tile/tile-footer/index.js +2 -0
  818. package/lib/components/tile/tile-footer/tile-footer.component.js +12 -2
  819. package/lib/components/tile/tile-footer/tile-footer.style.js +6 -0
  820. package/lib/components/tile/tile.component.js +16 -0
  821. package/lib/components/tile/tile.style.js +9 -0
  822. package/lib/components/tile-select/__internal__/accordion/accordion.component.js +9 -0
  823. package/lib/components/tile-select/__internal__/accordion/accordion.style.js +4 -0
  824. package/lib/components/tile-select/__internal__/accordion/index.js +2 -0
  825. package/lib/components/tile-select/index.js +3 -0
  826. package/lib/components/tile-select/tile-select-group.component.js +28 -2
  827. package/lib/components/tile-select/tile-select.component.js +48 -4
  828. package/lib/components/tile-select/tile-select.style.js +11 -0
  829. package/lib/components/toast/index.js +2 -0
  830. package/lib/components/toast/toast.component.js +34 -0
  831. package/lib/components/toast/toast.style.js +12 -0
  832. package/lib/components/tooltip/index.js +2 -0
  833. package/lib/components/tooltip/tooltip-pointer.style.js +8 -0
  834. package/lib/components/tooltip/tooltip.component.js +17 -0
  835. package/lib/components/tooltip/tooltip.style.js +13 -0
  836. package/lib/components/typography/index.js +3 -0
  837. package/lib/components/typography/list.component.js +11 -0
  838. package/lib/components/typography/typography.component.js +36 -0
  839. package/lib/components/vertical-divider/index.js +2 -0
  840. package/lib/components/vertical-divider/vertical-divider.component.js +10 -0
  841. package/lib/components/vertical-divider/vertical-divider.style.js +6 -0
  842. package/lib/hooks/__internal__/useCharacterCount/index.js +2 -0
  843. package/lib/hooks/__internal__/useCharacterCount/useCharacterCount.js +10 -0
  844. package/lib/hooks/__internal__/useClickAwayListener/index.js +2 -0
  845. package/lib/hooks/__internal__/useClickAwayListener/useClickAwayListener.js +4 -0
  846. package/lib/hooks/__internal__/useFloating/index.js +2 -0
  847. package/lib/hooks/__internal__/useFloating/useFloating.js +8 -0
  848. package/lib/hooks/__internal__/useInputAccessibility/index.js +2 -0
  849. package/lib/hooks/__internal__/useInputAccessibility/useInputAccessibility.js +1 -0
  850. package/lib/hooks/__internal__/useIsAboveBreakpoint/index.js +2 -0
  851. package/lib/hooks/__internal__/useIsAboveBreakpoint/useIsAboveBreakpoint.js +3 -0
  852. package/lib/hooks/__internal__/useIsStickyFooterForm/index.js +2 -0
  853. package/lib/hooks/__internal__/useIsStickyFooterForm/useIsStickyFooterForm.js +8 -0
  854. package/lib/hooks/__internal__/useLocale/index.js +2 -0
  855. package/lib/hooks/__internal__/useLocale/useLocale.js +4 -0
  856. package/lib/hooks/__internal__/useMenuKeyboardNavigation/index.js +2 -0
  857. package/lib/hooks/__internal__/useMenuKeyboardNavigation/useMenuKeyboardNavigation.js +23 -2
  858. package/lib/hooks/__internal__/useModalManager/index.js +2 -0
  859. package/lib/hooks/__internal__/useModalManager/useModalManager.js +9 -0
  860. package/lib/hooks/__internal__/usePrevious/index.js +2 -0
  861. package/lib/hooks/__internal__/useResizeObserver/index.js +2 -0
  862. package/lib/hooks/__internal__/useResizeObserver/useResizeObserver.js +10 -3
  863. package/lib/hooks/__internal__/useScrollBlock/index.js +2 -0
  864. package/lib/hooks/__internal__/useScrollBlock/scroll-block-manager.js +17 -6
  865. package/lib/hooks/__internal__/useScrollBlock/useScrollBlock.js +18 -8
  866. package/lib/hooks/useMediaQuery/index.js +2 -0
  867. package/lib/hooks/useMediaQuery/useMediaQuery.js +8 -0
  868. package/lib/locales/date-fns-locales/index.js +2 -0
  869. package/lib/locales/en-gb.js +9 -1
  870. package/lib/locales/index.js +3 -0
  871. package/lib/locales/pl-pl.js +9 -1
  872. package/lib/style/design-tokens/carbon-scoped-tokens-provider/carbon-scoped-tokens-provider.component.js +5 -1
  873. package/lib/style/design-tokens/carbon-scoped-tokens-provider/index.js +2 -0
  874. package/lib/style/design-tokens/debug-theme.util.js +12 -5
  875. package/lib/style/design-tokens/generate-css-variables.util.js +2 -0
  876. package/lib/style/global-style.js +2 -0
  877. package/lib/style/palette/index.js +9 -2
  878. package/lib/style/themes/aegean/aegean-theme.config.js +5 -0
  879. package/lib/style/themes/aegean/index.js +5 -0
  880. package/lib/style/themes/base/base-theme.config.js +9 -2
  881. package/lib/style/themes/base/index.js +12 -4
  882. package/lib/style/themes/index.js +7 -0
  883. package/lib/style/themes/medium/index.js +3 -0
  884. package/lib/style/themes/mint/index.js +5 -0
  885. package/lib/style/themes/mint/mint-theme.config.js +5 -0
  886. package/lib/style/themes/none/index.js +5 -0
  887. package/lib/style/themes/none/none-theme.config.js +2 -0
  888. package/lib/style/themes/sage/index.js +6 -4
  889. package/lib/style/themes/small/index.js +3 -0
  890. package/lib/style/themes/test-utils.js +6 -4
  891. package/lib/style/utils/add-hex-symbols.js +3 -0
  892. package/lib/style/utils/at-opacity.js +3 -0
  893. package/lib/style/utils/color.js +14 -3
  894. package/lib/style/utils/filter-out-position-props.js +4 -0
  895. package/lib/style/utils/filter-out-styled-system-spacing-props.js +4 -0
  896. package/lib/style/utils/filter-styled-system-margin-props.js +4 -0
  897. package/lib/style/utils/filter-styled-system-padding-props.js +5 -2
  898. package/lib/style/utils/form-style-utils.js +18 -0
  899. package/lib/style/utils/get-color-value.js +5 -0
  900. package/lib/style/utils/get-rgb-values.js +2 -1
  901. package/lib/style/utils/index.js +4 -0
  902. package/lib/style/utils/merge-deep.js +7 -1
  903. package/lib/style/utils/mix.js +9 -1
  904. package/lib/style/utils/shade.js +4 -0
  905. package/lib/style/utils/tint.js +4 -0
  906. package/lib/style/utils/width.js +4 -0
  907. package/package.json +1 -1
  908. package/esm/__internal__/radio-button-mapper/radio-button-mapper.d.ts +0 -20
  909. package/esm/components/radio-button/radio-button-group.d.ts +0 -42
  910. package/esm/components/radio-button/radio-button.d.ts +0 -30
  911. package/lib/__internal__/radio-button-mapper/radio-button-mapper.d.ts +0 -20
  912. package/lib/components/radio-button/radio-button-group.d.ts +0 -42
  913. package/lib/components/radio-button/radio-button.d.ts +0 -30
@@ -1,4 +1,5 @@
1
1
  function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
2
+
2
3
  import React, { useRef, useEffect, useContext } from "react";
3
4
  import PropTypes from "prop-types";
4
5
  import styledSystemPropTypes from "@styled-system/prop-types";
@@ -17,6 +18,7 @@ import { NewValidationContext } from "../carbon-provider/carbon-provider.compone
17
18
  import { ErrorBorder, StyledHintText } from "../textbox/textbox.style";
18
19
  import ValidationMessage from "../../__internal__/validation-message";
19
20
  const marginPropTypes = filterStyledSystemMarginProps(styledSystemPropTypes.space);
21
+
20
22
  const Textarea = ({
21
23
  autoFocus,
22
24
  fieldHelp,
@@ -58,20 +60,25 @@ const Textarea = ({
58
60
  const {
59
61
  validationRedesignOptIn
60
62
  } = useContext(NewValidationContext);
63
+
61
64
  const computeLabelPropValues = prop => validationRedesignOptIn ? undefined : prop;
65
+
62
66
  const {
63
67
  current: id
64
68
  } = useRef(idProp || guid());
65
69
  const inputRef = useRef();
66
70
  const minHeight = useRef(MIN_HEIGHT);
71
+
67
72
  const expandTextarea = () => {
68
73
  const textarea = inputRef.current;
74
+
69
75
  if (textarea.scrollHeight > minHeight.current) {
70
- textarea.style.height = "0px";
71
- // Set the height so all content is shown
76
+ textarea.style.height = "0px"; // Set the height so all content is shown
77
+
72
78
  textarea.style.height = `${Math.max(textarea.scrollHeight, minHeight.current)}px`;
73
79
  }
74
80
  };
81
+
75
82
  const {
76
83
  labelId,
77
84
  validationIconId,
@@ -86,8 +93,7 @@ const Textarea = ({
86
93
  label,
87
94
  fieldHelp
88
95
  });
89
- const [maxLength, characterCount] = useCharacterCount(value,
90
- // TODO: Can be removed after the characterLimit type is changed to number
96
+ const [maxLength, characterCount] = useCharacterCount(value, // TODO: Can be removed after the characterLimit type is changed to number
91
97
  typeof characterLimit === "string" ? parseInt(characterLimit, 10) : characterLimit, warnOverLimit, enforceCharacterLimit);
92
98
  useEffect(() => {
93
99
  if (rows) {
@@ -104,6 +110,7 @@ const Textarea = ({
104
110
  window.addEventListener("resize", expandTextarea);
105
111
  minHeight.current = inputRef.current.clientHeight;
106
112
  }
113
+
107
114
  return () => {
108
115
  if (expandable) {
109
116
  window.removeEventListener("resize", expandTextarea);
@@ -182,90 +189,127 @@ const Textarea = ({
182
189
  useValidationIcon: !(validationRedesignOptIn || validationOnLabel)
183
190
  }))), characterCount)));
184
191
  };
185
- Textarea.propTypes = {
186
- ...marginPropTypes,
192
+
193
+ Textarea.propTypes = { ...marginPropTypes,
194
+
187
195
  /** Automatically focus the input on component mount */
188
196
  autoFocus: PropTypes.bool,
197
+
189
198
  /** Identifier used for testing purposes, applied to the root element of the component. */
190
199
  "data-component": PropTypes.string,
200
+
191
201
  /** Identifier used for testing purposes, applied to the root element of the component. */
192
202
  "data-element": PropTypes.string,
203
+
193
204
  /** Identifier used for testing purposes, applied to the root element of the component. */
194
205
  "data-role": PropTypes.string,
206
+
195
207
  /** id of the input */
196
208
  id: PropTypes.string,
209
+
197
210
  /** Character limit of the textarea */
198
211
  characterLimit: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),
212
+
199
213
  /** Type of the icon that will be rendered next to the input */
200
214
  children: PropTypes.node,
215
+
201
216
  /** The visible width of the text control, in average character widths */
202
217
  cols: PropTypes.number,
218
+
203
219
  /** Adds disabled property */
204
220
  disabled: PropTypes.bool,
221
+
205
222
  /** Stop the user typing over the characterLimit */
206
223
  enforceCharacterLimit: PropTypes.bool,
224
+
207
225
  /** Allows the Textareas Height to change based on user input */
208
226
  expandable: PropTypes.bool,
227
+
209
228
  /** Help content to be displayed under an input */
210
229
  fieldHelp: PropTypes.node,
230
+
211
231
  /** The content of the label for the input */
212
232
  label: PropTypes.string,
233
+
213
234
  /** Text applied to label help tooltip */
214
235
  labelHelp: PropTypes.node,
236
+
215
237
  /** Inline label alignment */
216
238
  labelAlign: PropTypes.oneOf(["left", "right"]),
239
+
217
240
  /** When true, label is placed in line with an input */
218
241
  labelInline: PropTypes.bool,
242
+
219
243
  /** Spacing between label and a field for inline label, given number will be multiplied by base spacing unit (8) */
220
244
  labelSpacing: PropTypes.oneOf([1, 2]),
245
+
221
246
  /** Width of a label in percentage. Works only when labelInline is true */
222
247
  labelWidth: PropTypes.number,
248
+
223
249
  /** Width of an input in percentage. Works only when labelInline is true */
224
250
  inputWidth: PropTypes.number,
251
+
225
252
  /** Name of the input */
226
253
  name: PropTypes.string,
254
+
227
255
  /** Callback fired when the user types in the Textarea */
228
256
  onChange: PropTypes.func,
257
+
229
258
  /** Placeholder text for the component */
230
259
  placeholder: PropTypes.string,
260
+
231
261
  /** Adds readOnly property */
232
262
  readOnly: PropTypes.bool,
263
+
233
264
  /** The number of visible text lines for the control */
234
265
  rows: PropTypes.number,
266
+
235
267
  /** One of type of size to apply to the textarea */
236
268
  size: PropTypes.oneOf(["small", "medium", "large"]),
269
+
237
270
  /** The value of the Textarea */
238
271
  value: PropTypes.string,
272
+
239
273
  /** Whether to display the character count message in red */
240
274
  warnOverLimit: PropTypes.bool,
275
+
241
276
  /** Indicate that error has occurred
242
277
  Pass string to display icon, tooltip and red border
243
278
  Pass true boolean to only display red border */
244
279
  error: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
280
+
245
281
  /** Indicate that warning has occurred
246
282
  Pass string to display icon, tooltip and orange border
247
283
  Pass true boolean to only display orange border */
248
284
  warning: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
285
+
249
286
  /** Indicate additional information
250
287
  Pass string to display icon, tooltip and blue border
251
288
  Pass true boolean to only display blue border */
252
289
  info: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),
290
+
253
291
  /** When true, validation icon will be placed on label instead of being placed on the input */
254
292
  validationOnLabel: PropTypes.bool,
293
+
255
294
  /**
256
295
  * <a href="https://brand.sage.com/d/NdbrveWvNheA/foundations#/icons/icons" target="_blank">List of supported icons</a>
257
296
  *
258
297
  * Icon to display inside of the Textarea
259
298
  */
260
299
  inputIcon: PropTypes.string,
300
+
261
301
  /** Message to be displayed in a Tooltip when the user hovers over the help icon */
262
302
  tooltipMessage: PropTypes.string,
303
+
263
304
  /** Breakpoint for adaptive label (inline labels change to top aligned). Enables the adaptive behaviour when set */
264
305
  adaptiveLabelBreakpoint: PropTypes.number,
306
+
265
307
  /** Flag to configure component as mandatory */
266
308
  required: PropTypes.bool,
309
+
267
310
  /** Overrides the default tooltip position */
268
311
  tooltipPosition: PropTypes.oneOf(["top", "bottom", "left", "right"]),
312
+
269
313
  /** Aria label for rendered help component */
270
314
  helpAriaLabel: PropTypes.string
271
315
  };
@@ -1,4 +1,5 @@
1
1
  function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
2
+
2
3
  import React, { useContext } from "react";
3
4
  import PropTypes from "prop-types";
4
5
  import { filterStyledSystemMarginProps } from "../../style/utils";
@@ -15,6 +16,7 @@ import { ErrorBorder, StyledHintText } from "./textbox.style";
15
16
  import ValidationMessage from "../../__internal__/validation-message";
16
17
  import { NewValidationContext } from "../carbon-provider/carbon-provider.component";
17
18
  import NumeralDateContext from "../numeral-date/numeral-date-context";
19
+
18
20
  const Textbox = ({
19
21
  align = "left",
20
22
  autoFocus,
@@ -70,8 +72,7 @@ const Textbox = ({
70
72
  ...props
71
73
  }) => {
72
74
  const characterCountValue = typeof value === "string" ? value : "";
73
- const [maxLength, characterCount] = useCharacterCount(characterCountValue,
74
- // TODO: Can be removed after the characterLimit type is changed to number
75
+ const [maxLength, characterCount] = useCharacterCount(characterCountValue, // TODO: Can be removed after the characterLimit type is changed to number
75
76
  typeof characterLimit === "string" ? parseInt(characterLimit, 10) : characterLimit, warnOverLimit, enforceCharacterLimit);
76
77
  const {
77
78
  validationRedesignOptIn
@@ -79,7 +80,9 @@ const Textbox = ({
79
80
  const {
80
81
  disableErrorBorder
81
82
  } = useContext(NumeralDateContext);
83
+
82
84
  const computeLabelPropValues = prop => validationRedesignOptIn ? undefined : prop;
85
+
83
86
  const [uniqueId, uniqueName] = useUniqueId(id, name);
84
87
  const {
85
88
  labelId: internalLabelId,
@@ -181,6 +184,7 @@ const Textbox = ({
181
184
  validationIconId: validationRedesignOptIn ? undefined : validationIconId
182
185
  }))), characterCount));
183
186
  };
187
+
184
188
  Textbox.propTypes = {
185
189
  "about": PropTypes.string,
186
190
  "accept": PropTypes.string,
@@ -250,6 +254,9 @@ Textbox.propTypes = {
250
254
  "contentEditable": PropTypes.oneOfType([PropTypes.oneOf(["false", "inherit", "true"]), PropTypes.bool]),
251
255
  "contextMenu": PropTypes.string,
252
256
  "crossOrigin": PropTypes.string,
257
+ "css": PropTypes.oneOfType([PropTypes.func, PropTypes.number, PropTypes.object, PropTypes.shape({
258
+ "__emotion_styles": PropTypes.any.isRequired
259
+ }), PropTypes.string, PropTypes.bool]),
253
260
  "dangerouslySetInnerHTML": PropTypes.shape({
254
261
  "__html": PropTypes.string.isRequired
255
262
  }),
@@ -1,10 +1,12 @@
1
1
  function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
2
+
2
3
  import React from "react";
3
4
  import PropTypes from "prop-types";
4
5
  import styledSystemPropTypes from "@styled-system/prop-types";
5
6
  import StyledTileFooter from "./tile-footer.style";
6
7
  import { filterStyledSystemPaddingProps } from "../../../style/utils";
7
8
  const paddingPropTypes = filterStyledSystemPaddingProps(styledSystemPropTypes.space);
9
+
8
10
  const TileFooter = ({
9
11
  variant,
10
12
  children,
@@ -15,8 +17,9 @@ const TileFooter = ({
15
17
  variant: variant
16
18
  }, props), children);
17
19
  };
18
- TileFooter.propTypes = {
19
- ...paddingPropTypes,
20
+
21
+ TileFooter.propTypes = { ...paddingPropTypes,
22
+
20
23
  /** set which background color variant should be used */
21
24
  variant: PropTypes.oneOf(["default", "transparent"]),
22
25
  children: PropTypes.node
@@ -1,8 +1,10 @@
1
1
  function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
2
+
2
3
  import React from "react";
3
4
  import PropTypes from "prop-types";
4
5
  import propTypes from "@styled-system/prop-types";
5
6
  import { StyledTile, TileContent } from "./tile.style.js";
7
+
6
8
  const Tile = ({
7
9
  variant = "tile",
8
10
  p = 3,
@@ -12,11 +14,14 @@ const Tile = ({
12
14
  ...props
13
15
  }) => {
14
16
  const isHorizontal = () => orientation === "horizontal";
17
+
15
18
  const isVertical = () => orientation === "vertical";
19
+
16
20
  const wrappedChildren = React.Children.map(children, (child, index) => {
17
21
  if (!child) {
18
22
  return null;
19
23
  }
24
+
20
25
  const {
21
26
  width: contentWidth,
22
27
  ...childProps
@@ -43,11 +48,14 @@ const Tile = ({
43
48
  p: p
44
49
  }, props), wrappedChildren);
45
50
  };
51
+
46
52
  Tile.propTypes = {
47
53
  /** Styled system spacing props */
48
54
  ...propTypes.space,
55
+
49
56
  /** Sets the theme of the tile - either 'tile', 'transparent' or 'active' */
50
57
  variant: PropTypes.oneOf(["tile", "transparent", "active"]),
58
+
51
59
  /**
52
60
  * The content to render within the tile. Each child will be wrapped with
53
61
  * a TileContent wrapper, which allows any individual child component to take a
@@ -56,8 +64,10 @@ Tile.propTypes = {
56
64
  * Width will have no effect on a child component if the tile orientation is set to 'vertical'.
57
65
  */
58
66
  children: PropTypes.node,
67
+
59
68
  /** The orientation of the tile - set to either horizontal or vertical */
60
69
  orientation: PropTypes.oneOf(["horizontal", "vertical"]),
70
+
61
71
  /**
62
72
  * Set a percentage-based width for the whole Tile component, relative to its parent.
63
73
  * If unset or zero, this will default to 100%.
@@ -2,6 +2,7 @@ import React, { useEffect, useRef, useState } from "react";
2
2
  import PropTypes from "prop-types";
3
3
  import { StyledContentContainer, StyledContent } from "./accordion.style";
4
4
  import useResizeObserver from "../../../../hooks/__internal__/useResizeObserver";
5
+
5
6
  const Accordion = ({
6
7
  children,
7
8
  expanded,
@@ -28,6 +29,7 @@ const Accordion = ({
28
29
  "aria-labelledby": controlId
29
30
  }, children));
30
31
  };
32
+
31
33
  Accordion.propTypes = {
32
34
  children: PropTypes.node.isRequired,
33
35
  expanded: PropTypes.bool,
@@ -1,4 +1,5 @@
1
1
  function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
2
+
2
3
  import React from "react";
3
4
  import PropTypes from "prop-types";
4
5
  import styledSystemPropTypes from "@styled-system/prop-types";
@@ -8,6 +9,7 @@ import RadioButtonMapper from "../../__internal__/radio-button-mapper/radio-butt
8
9
  import { StyledTileSelectFieldset, StyledGroupDescription } from "./tile-select.style";
9
10
  import { filterStyledSystemMarginProps } from "../../style/utils";
10
11
  const marginPropTypes = filterStyledSystemMarginProps(styledSystemPropTypes.space);
12
+
11
13
  const TileSelectGroup = props => {
12
14
  const {
13
15
  children,
@@ -21,6 +23,7 @@ const TileSelectGroup = props => {
21
23
  ...rest
22
24
  } = props;
23
25
  let tiles;
26
+
24
27
  if (multiSelect) {
25
28
  tiles = children;
26
29
  } else {
@@ -33,14 +36,16 @@ const TileSelectGroup = props => {
33
36
  type: "radio"
34
37
  })));
35
38
  }
39
+
36
40
  return /*#__PURE__*/React.createElement(StyledTileSelectFieldset, _extends({
37
41
  legend: legend
38
42
  }, tagComponent("tile-select-group", rest), {
39
43
  multiSelect: multiSelect
40
44
  }, filterStyledSystemMarginProps(rest)), /*#__PURE__*/React.createElement(StyledGroupDescription, null, description), /*#__PURE__*/React.createElement("div", null, tiles));
41
45
  };
42
- TileSelectGroup.propTypes = {
43
- ...marginPropTypes,
46
+
47
+ TileSelectGroup.propTypes = { ...marginPropTypes,
48
+
44
49
  /** The TileSelect components to be rendered in the group */
45
50
  children: (props, propName, componentName) => {
46
51
  let error;
@@ -52,20 +57,29 @@ TileSelectGroup.propTypes = {
52
57
  });
53
58
  return error;
54
59
  },
60
+
55
61
  /** The content for the TileSelectGroup Legend */
56
62
  legend: PropTypes.string,
63
+
57
64
  /** Description to be rendered below the legend */
58
65
  description: PropTypes.string,
66
+
59
67
  /** The currently selected value - only for single select mode. */
60
68
  value: PropTypes.string,
69
+
61
70
  /** The name to apply to the input - only for single select mode. */
62
71
  name: PropTypes.string,
72
+
63
73
  /** A callback triggered when one of tiles is selected - only for single select mode. */
64
74
  onChange: PropTypes.func,
75
+
65
76
  /** A callback triggered when one of tiles is blurred - only for single select mode. */
66
77
  onBlur: PropTypes.func,
78
+
67
79
  /** When passed as true TileSelectGroup serves only visual purpose */
80
+
68
81
  /** It wraps TileSelects in fieldset element and renders the legend and description props content */
82
+
69
83
  /** onChange, onBlur, value, checked and name props are meant to be passed individually on each of the TileSelects */
70
84
  multiSelect: PropTypes.bool
71
85
  };
@@ -1,4 +1,5 @@
1
1
  function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
2
+
2
3
  import React, { useState, useEffect, useRef } from "react";
3
4
  import PropTypes from "prop-types";
4
5
  import styledSystemPropTypes from "@styled-system/prop-types";
@@ -11,9 +12,11 @@ import Accordion from "./__internal__/accordion";
11
12
  import { StyledTileSelectContainer, StyledTileSelect, StyledTileSelectInput, StyledTitleContainer, StyledTitle, StyledSubtitle, StyledAdornment, StyledDescription, StyledDeselectWrapper, StyledFooterWrapper, StyledFocusWrapper, StyledAccordionFooterWrapper } from "./tile-select.style";
12
13
  import { filterStyledSystemMarginProps } from "../../style/utils";
13
14
  const marginPropTypes = filterStyledSystemMarginProps(styledSystemPropTypes.space);
15
+
14
16
  const checkPropTypeIsNode = prop => typeof prop !== "string" && {
15
17
  as: "div"
16
18
  };
19
+
17
20
  const TileSelect = ({
18
21
  onChange,
19
22
  onBlur,
@@ -41,9 +44,9 @@ const TileSelect = ({
41
44
  }) => {
42
45
  const l = useLocale();
43
46
  const [hasFocus, setHasFocus] = useState(false);
47
+
44
48
  const handleDeselect = () => onChange({
45
- target: {
46
- ...(name && {
49
+ target: { ...(name && {
47
50
  name
48
51
  }),
49
52
  ...(id && {
@@ -53,6 +56,7 @@ const TileSelect = ({
53
56
  checked: false
54
57
  }
55
58
  });
59
+
56
60
  const renderActionButton = () => /*#__PURE__*/React.createElement(StyledDeselectWrapper, {
57
61
  hasActionAdornment: !!actionButtonAdornment
58
62
  }, customActionButton && customActionButton(handleDeselect), !customActionButton && checked && /*#__PURE__*/React.createElement(Button, {
@@ -61,6 +65,7 @@ const TileSelect = ({
61
65
  disabled: disabled,
62
66
  onClick: handleDeselect
63
67
  }, l.tileSelect.deselect()), actionButtonAdornment);
68
+
64
69
  useEffect(() => {
65
70
  if (disabled && hasFocus) {
66
71
  setHasFocus(false);
@@ -81,11 +86,13 @@ const TileSelect = ({
81
86
  onBlur: ev => {
82
87
  setHasFocus(false);
83
88
  /* istanbul ignore else */
89
+
84
90
  if (onBlur) onBlur(ev);
85
91
  },
86
92
  onFocus: ev => {
87
93
  setHasFocus(true);
88
94
  /* istanbul ignore else */
95
+
89
96
  if (onFocus) onFocus(ev);
90
97
  },
91
98
  checked: checked,
@@ -118,57 +125,79 @@ const TileSelect = ({
118
125
  expanded: accordionExpanded
119
126
  }, accordionContent)));
120
127
  };
128
+
121
129
  TileSelect.defaultProps = {
122
130
  checked: false,
123
131
  type: "checkbox"
124
132
  };
125
- TileSelect.propTypes = {
126
- ...marginPropTypes,
133
+ TileSelect.propTypes = { ...marginPropTypes,
134
+
127
135
  /** title of the TileSelect */
128
136
  title: PropTypes.node,
137
+
129
138
  /** adornment to be rendered next to the title */
130
139
  titleAdornment: PropTypes.node,
140
+
131
141
  /** subtitle of the TileSelect */
132
142
  subtitle: PropTypes.node,
143
+
133
144
  /** description of the TileSelect */
134
145
  description: PropTypes.node,
146
+
135
147
  /** disables the TileSelect input */
136
148
  disabled: PropTypes.bool,
149
+
137
150
  /** the value that is represented by this TileSelect */
138
151
  value: PropTypes.string,
152
+
139
153
  /** input id */
140
154
  id: PropTypes.string,
155
+
141
156
  /** input name */
142
157
  name: PropTypes.string,
158
+
143
159
  /** Callback triggered when user selects or deselects this tile */
144
160
  onChange: PropTypes.func,
161
+
145
162
  /** Callback triggered when the user blurs this tile */
146
163
  onBlur: PropTypes.func,
164
+
147
165
  /** Callback triggered when the user focuses this tile */
148
166
  onFocus: PropTypes.func,
167
+
149
168
  /** determines if this tile is selected or unselected */
150
169
  checked: PropTypes.bool,
170
+
151
171
  /** Custom class name passed to the root element of TileSelect */
152
172
  className: PropTypes.string,
173
+
153
174
  /** Type of the TileSelect input */
154
175
  type: PropTypes.oneOf(["radio", "checkbox"]),
176
+
155
177
  /** Render prop that allows overriding the default action button. `(onClick) => <Button onClick={onClick}>...</Button>` */
156
178
  customActionButton: PropTypes.func,
179
+
157
180
  /** An additional help info icon rendered next to the action button */
158
181
  actionButtonAdornment: PropTypes.node,
182
+
159
183
  /** footer of the TileSelect */
160
184
  footer: PropTypes.node,
185
+
161
186
  /** Component to render in the top left corner of TileSelect */
162
187
  prefixAdornment: PropTypes.node,
188
+
163
189
  /** Component to render additional information row between title and description */
164
190
  additionalInformation: PropTypes.node,
191
+
165
192
  /** Components to render in the TileSelect Accordion */
166
193
  accordionContent: PropTypes.node,
194
+
167
195
  /**
168
196
  * Render prop to support rendering the control to handle the expanded state of the TileSelect Accordion.
169
197
  * `(controlId, contentId) => <Button id={controlId} aria-controls={contentId}>...</Button>`
170
198
  */
171
199
  accordionControl: PropTypes.func,
200
+
172
201
  /** Flag to control the open state of TileSelect Accordion */
173
202
  accordionExpanded: PropTypes.bool
174
203
  };
@@ -1,4 +1,5 @@
1
1
  function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
2
+
2
3
  import React, { useCallback, useEffect, useMemo, useRef, useState } from "react";
3
4
  import classNames from "classnames";
4
5
  import { TransitionGroup, CSSTransition } from "react-transition-group";
@@ -45,15 +46,18 @@ const Toast = /*#__PURE__*/React.forwardRef(({
45
46
  useModalManager(open, dismissToast, refToPass);
46
47
  useEffect(() => {
47
48
  clearTimeout(timer.current);
49
+
48
50
  if (!timeout || !open || !onDismiss) {
49
51
  return;
50
52
  }
53
+
51
54
  timer.current = setTimeout(() => onDismiss(), timeout);
52
55
  }, [onDismiss, open, timeout]);
53
56
  useEffect(() => {
54
57
  if (!disableAutoFocus) {
55
58
  if (open) {
56
59
  var _toastContentNodeRef$;
60
+
57
61
  focusedElementBeforeOpening.current = document.activeElement;
58
62
  (_toastContentNodeRef$ = toastContentNodeRef.current) === null || _toastContentNodeRef$ === void 0 ? void 0 : _toastContentNodeRef$.focus();
59
63
  } else if (focusedElementBeforeOpening.current) {
@@ -70,6 +74,7 @@ const Toast = /*#__PURE__*/React.forwardRef(({
70
74
  }
71
75
  };
72
76
  }, []);
77
+
73
78
  function renderCloseIcon() {
74
79
  if (!onDismiss) return null;
75
80
  return /*#__PURE__*/React.createElement(IconButton, {
@@ -81,6 +86,7 @@ const Toast = /*#__PURE__*/React.forwardRef(({
81
86
  type: "close"
82
87
  }));
83
88
  }
89
+
84
90
  function renderToastContent() {
85
91
  if (!open) return null;
86
92
  const toastProps = {
@@ -116,6 +122,7 @@ const Toast = /*#__PURE__*/React.forwardRef(({
116
122
  isDismiss: onDismiss
117
123
  }, children), renderCloseIcon()));
118
124
  }
125
+
119
126
  return /*#__PURE__*/React.createElement(StyledPortal, {
120
127
  id: targetPortalId,
121
128
  isCenter: isCenter,
@@ -129,26 +136,37 @@ const Toast = /*#__PURE__*/React.forwardRef(({
129
136
  Toast.propTypes = {
130
137
  /** Customizes the appearance in the DLS theme */
131
138
  variant: PropTypes.oneOf(["error", "info", "success", "warning", "notice"]),
139
+
132
140
  /** Custom className */
133
141
  className: PropTypes.string,
142
+
134
143
  /** Custom id */
135
144
  id: PropTypes.string,
145
+
136
146
  /** Component name */
137
147
  "data-component": PropTypes.string,
148
+
138
149
  /** The rendered children of the component. */
139
150
  children: PropTypes.node,
151
+
140
152
  /** Determines if the Toast is open. */
141
153
  open: PropTypes.bool,
154
+
142
155
  /** Callback for when dismissed. */
143
156
  onDismiss: PropTypes.func,
157
+
144
158
  /** Time for Toast to remain on screen */
145
159
  timeout: PropTypes.oneOfType([PropTypes.string, PropTypes.number]),
160
+
146
161
  /** Centers the Toast on the screen */
147
162
  isCenter: PropTypes.bool,
163
+
148
164
  /** Target Portal ID where the Toast will render */
149
165
  targetPortalId: PropTypes.string,
166
+
150
167
  /** Maximum toast width */
151
168
  maxWidth: PropTypes.string,
169
+
152
170
  /** Disables auto focus functionality when the Toast has a close icon */
153
171
  disableAutoFocus: PropTypes.bool
154
172
  };
@@ -1,10 +1,12 @@
1
1
  import styled, { css } from "styled-components";
2
2
  import baseTheme from "../../style/themes/base";
3
3
  import { toColor } from "../../style/utils/color";
4
+
4
5
  const pointerColor = (theme, bgColor, type) => {
5
6
  if (bgColor) return toColor(theme, bgColor);
6
7
  return type === "error" ? "var(--colorsSemanticNegative500)" : "var(--colorsSemanticNeutral500)";
7
8
  };
9
+
8
10
  const StyledTooltipPointer = styled.div`
9
11
  ${({
10
12
  position,
@@ -1,4 +1,5 @@
1
1
  function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
2
+
2
3
  import React from "react";
3
4
  import PropTypes from "prop-types";
4
5
  import Tippy from "@tippyjs/react/headless";
@@ -29,6 +30,7 @@ const Tooltip = /*#__PURE__*/React.forwardRef(({
29
30
  }, ref) => {
30
31
  const isFlipOverridesValid = !flipOverrides || Array.isArray(flipOverrides) && flipOverrides.every(placement => TOOLTIP_POSITIONS.includes(placement));
31
32
  !isFlipOverridesValid ? process.env.NODE_ENV !== "production" ? invariant(false, `The flipOverrides prop supplied to Tooltip must be an array containing some or all of ["top", "bottom", "left", "right"].`) : invariant(false) : void 0;
33
+
32
34
  const tooltip = (attrs, content) => {
33
35
  const currentPosition = attrs["data-placement"] || position;
34
36
  return /*#__PURE__*/React.createElement(CarbonScopedTokensProvider, null, /*#__PURE__*/React.createElement(StyledTooltip, _extends({
@@ -56,6 +58,7 @@ const Tooltip = /*#__PURE__*/React.forwardRef(({
56
58
  bgColor: bgColor
57
59
  })), content));
58
60
  };
61
+
59
62
  return /*#__PURE__*/React.createElement(Tippy, _extends({
60
63
  placement: position,
61
64
  delay: TOOLTIP_DELAY