@onereach/ui-components 4.6.4-beta.2804.0 → 4.6.4

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 (394) hide show
  1. package/dist/bundled/v2/components/OrBottomSheetV3/OrBottomSheet.js +30 -47
  2. package/dist/bundled/v2/components/OrBottomSheetV3/OrBottomSheet.vue.d.ts +19 -10
  3. package/dist/bundled/v2/components/OrBottomSheetV3/index.js +1 -0
  4. package/dist/bundled/v2/components/OrCardCollectionV3/OrCardCollection.js +2 -1
  5. package/dist/bundled/v2/components/OrCardCollectionV3/index.js +2 -1
  6. package/dist/bundled/v2/components/OrConfirmV3/OrConfirm.js +28 -52
  7. package/dist/bundled/v2/components/OrConfirmV3/OrConfirm.vue.d.ts +18 -36
  8. package/dist/bundled/v2/components/OrConfirmV3/index.js +1 -0
  9. package/dist/bundled/v2/components/OrDatePickerV3/OrDatePicker.js +3 -2
  10. package/dist/bundled/v2/components/OrDatePickerV3/index.js +2 -1
  11. package/dist/bundled/v2/components/OrDateTimePickerV3/OrDateTimePicker.js +4 -3
  12. package/dist/bundled/v2/components/OrDateTimePickerV3/index.js +2 -1
  13. package/dist/bundled/v2/components/OrIconButtonV3/OrIconButton.js +2 -1
  14. package/dist/bundled/v2/components/OrIconButtonV3/index.js +2 -1
  15. package/dist/bundled/v2/components/OrInlineInputV3/OrInlineInput.js +2 -1
  16. package/dist/bundled/v2/components/OrInlineInputV3/index.js +2 -1
  17. package/dist/bundled/v2/components/OrInlineTextareaV3/OrInlineTextarea.js +2 -1
  18. package/dist/bundled/v2/components/OrInlineTextareaV3/index.js +2 -1
  19. package/dist/bundled/v2/components/OrInputV3/OrInput.js +2 -1
  20. package/dist/bundled/v2/components/OrInputV3/index.js +2 -1
  21. package/dist/bundled/v2/components/OrMenuV3/OrMenu.js +21 -48
  22. package/dist/bundled/v2/components/OrMenuV3/OrMenu.vue.d.ts +13 -16
  23. package/dist/bundled/v2/components/OrMenuV3/index.js +1 -0
  24. package/dist/bundled/v2/components/OrModalV3/OrModal.js +220 -65
  25. package/dist/bundled/v2/components/OrModalV3/OrModal.vue.d.ts +13 -19
  26. package/dist/bundled/v2/components/OrModalV3/index.js +9 -8
  27. package/dist/bundled/v2/components/OrModalV3/styles.d.ts +0 -3
  28. package/dist/bundled/v2/components/OrModalV3/styles.js +1 -16
  29. package/dist/bundled/v2/components/OrNotificationV3/OrNotification.js +2 -1
  30. package/dist/bundled/v2/components/OrNotificationV3/index.js +2 -1
  31. package/dist/bundled/v2/components/OrPaginationV3/OrPagination.js +2 -1
  32. package/dist/bundled/v2/components/OrPaginationV3/index.js +1 -0
  33. package/dist/bundled/v2/components/OrPopoverV3/OrPopover.js +31 -102
  34. package/dist/bundled/v2/components/OrPopoverV3/OrPopover.vue.d.ts +19 -12
  35. package/dist/bundled/v2/components/OrPopoverV3/index.js +1 -0
  36. package/dist/bundled/v2/components/OrSearchV3/OrSearch.js +1 -0
  37. package/dist/bundled/v2/components/OrSearchV3/index.js +1 -0
  38. package/dist/bundled/v2/components/OrSelectV3/OrSelect.js +1 -0
  39. package/dist/bundled/v2/components/OrSelectV3/index.js +1 -0
  40. package/dist/bundled/v2/components/OrSidebarV3/OrSidebar.js +1 -0
  41. package/dist/bundled/v2/components/OrSidebarV3/index.js +1 -0
  42. package/dist/bundled/v2/components/OrTabsV3/OrTabs.js +1 -0
  43. package/dist/bundled/v2/components/OrTabsV3/index.js +1 -0
  44. package/dist/bundled/v2/components/OrTagV3/OrTag.js +2 -1
  45. package/dist/bundled/v2/components/OrTagV3/index.js +2 -1
  46. package/dist/bundled/v2/components/OrTagsV3/OrTags.js +1 -0
  47. package/dist/bundled/v2/components/OrTagsV3/index.js +1 -0
  48. package/dist/bundled/v2/components/OrTimePickerV3/OrTimePicker.js +2 -1
  49. package/dist/bundled/v2/components/OrTimePickerV3/index.js +1 -0
  50. package/dist/bundled/v2/components/OrToastContainerV3/OrToastContainer.js +1 -0
  51. package/dist/bundled/v2/components/OrToastContainerV3/index.js +1 -0
  52. package/dist/bundled/v2/components/OrToastV3/OrToast.js +2 -1
  53. package/dist/bundled/v2/components/OrToastV3/index.js +2 -1
  54. package/dist/bundled/v2/components/OrTooltipV3/OrTooltip.js +32 -39
  55. package/dist/bundled/v2/components/OrTooltipV3/OrTooltip.vue.d.ts +20 -17
  56. package/dist/bundled/v2/components/OrTooltipV3/index.js +2 -1
  57. package/dist/bundled/v2/components/index.js +2 -1
  58. package/dist/bundled/v2/hooks/index.d.ts +1 -1
  59. package/dist/bundled/v2/hooks/index.js +1 -3
  60. package/dist/bundled/v2/hooks/useControlAttributes.d.ts +1 -2
  61. package/dist/bundled/v2/hooks/useElevation.js +3 -1
  62. package/dist/bundled/v2/hooks/useOverflow.d.ts +2 -2
  63. package/dist/bundled/v2/hooks/usePopoverState.d.ts +11 -0
  64. package/dist/bundled/v2/hooks/usePopoverState.js +42 -0
  65. package/dist/bundled/v2/hooks/useValidationAttributes.d.ts +1 -2
  66. package/dist/bundled/v2/index.js +3 -5
  67. package/dist/bundled/v3/{OrBottomSheet.vue_vue_type_script_lang-a81b2abb.js → OrBottomSheet.vue_vue_type_script_lang-aebedcb2.js} +28 -45
  68. package/dist/bundled/v3/{OrCardCollection.vue_vue_type_script_lang-f2d222a5.js → OrCardCollection.vue_vue_type_script_lang-d15329fd.js} +3 -3
  69. package/dist/bundled/v3/{OrConfirm.vue_vue_type_script_lang-b1b13331.js → OrConfirm.vue_vue_type_script_lang-84f80066.js} +28 -52
  70. package/dist/bundled/v3/{OrDatePicker.vue_vue_type_script_lang-31f5d798.js → OrDatePicker.vue_vue_type_script_lang-92222927.js} +3 -3
  71. package/dist/bundled/v3/{OrDateTimePicker.vue_vue_type_script_lang-a0354296.js → OrDateTimePicker.vue_vue_type_script_lang-81f3cb69.js} +3 -3
  72. package/dist/bundled/v3/{OrDateTimePickerMonthSelect-98b935cb.js → OrDateTimePickerMonthSelect-354e1af8.js} +2 -2
  73. package/dist/bundled/v3/{OrIconButton.vue_vue_type_script_lang-5bba9f3f.js → OrIconButton.vue_vue_type_script_lang-fe97e57a.js} +1 -1
  74. package/dist/bundled/v3/{OrInlineInput.vue_vue_type_script_lang-3c6b0958.js → OrInlineInput.vue_vue_type_script_lang-3131ae11.js} +1 -1
  75. package/dist/bundled/v3/{OrInlineTextarea.vue_vue_type_script_lang-da59cd8e.js → OrInlineTextarea.vue_vue_type_script_lang-db28519e.js} +1 -1
  76. package/dist/bundled/v3/{OrInput.vue_vue_type_script_lang-d08b3796.js → OrInput.vue_vue_type_script_lang-5f74dd08.js} +1 -1
  77. package/dist/bundled/v3/OrMenu.vue_vue_type_script_lang-1f45bf44.js +66 -0
  78. package/dist/bundled/v3/OrModal.vue_vue_type_script_lang-31c15ba1.js +160 -0
  79. package/dist/bundled/v3/{OrNotification.vue_vue_type_script_lang-463e1a82.js → OrNotification.vue_vue_type_script_lang-89bbc41f.js} +1 -1
  80. package/dist/bundled/v3/{OrPagination.vue_vue_type_script_lang-bdc8d9fb.js → OrPagination.vue_vue_type_script_lang-1835d432.js} +1 -1
  81. package/dist/bundled/v3/{OrPopover.vue_vue_type_script_lang-7b1b2488.js → OrPopover.vue_vue_type_script_lang-c75dbd63.js} +27 -98
  82. package/dist/bundled/v3/{OrSearch.vue_vue_type_script_lang-940d8e1f.js → OrSearch.vue_vue_type_script_lang-142ab019.js} +1 -1
  83. package/dist/bundled/v3/{OrSelect.vue_vue_type_script_lang-1c77663e.js → OrSelect.vue_vue_type_script_lang-0ab50e13.js} +3 -3
  84. package/dist/bundled/v3/{OrSidebar.vue_vue_type_script_lang-780eaa84.js → OrSidebar.vue_vue_type_script_lang-23c6a11f.js} +1 -1
  85. package/dist/bundled/v3/{OrTabs.vue_vue_type_script_lang-9d4221f1.js → OrTabs.vue_vue_type_script_lang-255f33d2.js} +1 -1
  86. package/dist/bundled/v3/{OrTag.vue_vue_type_script_lang-09948d1f.js → OrTag.vue_vue_type_script_lang-f4321103.js} +1 -1
  87. package/dist/bundled/v3/{OrTags.vue_vue_type_script_lang-71fb4f1d.js → OrTags.vue_vue_type_script_lang-4684a9c5.js} +2 -2
  88. package/dist/bundled/v3/{OrTimePicker.vue_vue_type_script_lang-21be27c6.js → OrTimePicker.vue_vue_type_script_lang-e9684fe9.js} +2 -2
  89. package/dist/bundled/v3/OrTooltip.vue_vue_type_script_lang-f3ccffce.js +56 -0
  90. package/dist/bundled/v3/components/OrBottomSheetV3/OrBottomSheet.js +7 -6
  91. package/dist/bundled/v3/components/OrBottomSheetV3/OrBottomSheet.vue.d.ts +16 -10
  92. package/dist/bundled/v3/components/OrBottomSheetV3/index.js +3 -2
  93. package/dist/bundled/v3/components/OrCardCollectionV3/OrCardCollection.js +12 -11
  94. package/dist/bundled/v3/components/OrCardCollectionV3/index.js +11 -10
  95. package/dist/bundled/v3/components/OrConfirmV3/OrConfirm.js +11 -10
  96. package/dist/bundled/v3/components/OrConfirmV3/OrConfirm.vue.d.ts +18 -35
  97. package/dist/bundled/v3/components/OrConfirmV3/index.js +8 -7
  98. package/dist/bundled/v3/components/OrDatePickerV3/OrDatePicker.js +11 -10
  99. package/dist/bundled/v3/components/OrDatePickerV3/index.js +9 -8
  100. package/dist/bundled/v3/components/OrDateTimePickerV3/OrDateTimePicker.js +12 -11
  101. package/dist/bundled/v3/components/OrDateTimePickerV3/index.js +9 -8
  102. package/dist/bundled/v3/components/OrIconButtonV3/OrIconButton.js +8 -7
  103. package/dist/bundled/v3/components/OrIconButtonV3/index.js +7 -6
  104. package/dist/bundled/v3/components/OrInlineInputV3/OrInlineInput.js +9 -8
  105. package/dist/bundled/v3/components/OrInlineInputV3/index.js +8 -7
  106. package/dist/bundled/v3/components/OrInlineTextareaV3/OrInlineTextarea.js +9 -8
  107. package/dist/bundled/v3/components/OrInlineTextareaV3/index.js +8 -7
  108. package/dist/bundled/v3/components/OrInputV3/OrInput.js +9 -8
  109. package/dist/bundled/v3/components/OrInputV3/index.js +8 -7
  110. package/dist/bundled/v3/components/OrMenuV3/OrMenu.js +9 -8
  111. package/dist/bundled/v3/components/OrMenuV3/OrMenu.vue.d.ts +13 -5
  112. package/dist/bundled/v3/components/OrMenuV3/index.js +5 -4
  113. package/dist/bundled/v3/components/OrModalV3/OrModal.js +36 -33
  114. package/dist/bundled/v3/components/OrModalV3/OrModal.vue.d.ts +14 -16
  115. package/dist/bundled/v3/components/OrModalV3/index.js +15 -14
  116. package/dist/bundled/v3/components/OrModalV3/styles.d.ts +0 -3
  117. package/dist/bundled/v3/components/OrModalV3/styles.js +1 -16
  118. package/dist/bundled/v3/components/OrNotificationV3/OrNotification.js +9 -8
  119. package/dist/bundled/v3/components/OrNotificationV3/index.js +8 -7
  120. package/dist/bundled/v3/components/OrOverlayV3/OrOverlay.js +2 -2
  121. package/dist/bundled/v3/components/OrOverlayV3/index.js +1 -1
  122. package/dist/bundled/v3/components/OrPaginationV3/OrPagination.js +8 -7
  123. package/dist/bundled/v3/components/OrPaginationV3/index.js +6 -5
  124. package/dist/bundled/v3/components/OrPopoverV3/OrPopover.js +8 -7
  125. package/dist/bundled/v3/components/OrPopoverV3/OrPopover.vue.d.ts +16 -11
  126. package/dist/bundled/v3/components/OrPopoverV3/index.js +4 -3
  127. package/dist/bundled/v3/components/OrSearchV3/OrSearch.js +9 -8
  128. package/dist/bundled/v3/components/OrSearchV3/index.js +8 -7
  129. package/dist/bundled/v3/components/OrSelectV3/OrSelect.js +10 -9
  130. package/dist/bundled/v3/components/OrSelectV3/index.js +9 -8
  131. package/dist/bundled/v3/components/OrSidebarV3/OrSidebar.js +8 -7
  132. package/dist/bundled/v3/components/OrSidebarV3/index.js +7 -6
  133. package/dist/bundled/v3/components/OrTabsV3/OrTabs.js +7 -6
  134. package/dist/bundled/v3/components/OrTabsV3/index.js +6 -5
  135. package/dist/bundled/v3/components/OrTagV3/OrTag.js +9 -8
  136. package/dist/bundled/v3/components/OrTagV3/index.js +8 -7
  137. package/dist/bundled/v3/components/OrTagsV3/OrTags.js +9 -8
  138. package/dist/bundled/v3/components/OrTagsV3/index.js +8 -7
  139. package/dist/bundled/v3/components/OrTimePickerV3/OrTimePicker.js +9 -8
  140. package/dist/bundled/v3/components/OrTimePickerV3/index.js +7 -6
  141. package/dist/bundled/v3/components/OrToastContainerV3/OrToastContainer.js +8 -7
  142. package/dist/bundled/v3/components/OrToastContainerV3/index.js +7 -6
  143. package/dist/bundled/v3/components/OrToastV3/OrToast.js +7 -6
  144. package/dist/bundled/v3/components/OrToastV3/index.js +8 -7
  145. package/dist/bundled/v3/components/OrTooltipV3/OrTooltip.js +13 -10
  146. package/dist/bundled/v3/components/OrTooltipV3/OrTooltip.vue.d.ts +17 -6
  147. package/dist/bundled/v3/components/OrTooltipV3/index.js +6 -5
  148. package/dist/bundled/v3/components/index.js +26 -25
  149. package/dist/bundled/v3/hooks/index.d.ts +1 -1
  150. package/dist/bundled/v3/hooks/index.js +1 -3
  151. package/dist/bundled/v3/hooks/useControlAttributes.d.ts +1 -2
  152. package/dist/bundled/v3/hooks/useElevation.js +3 -1
  153. package/dist/bundled/v3/hooks/useOverflow.d.ts +2 -2
  154. package/dist/bundled/v3/hooks/usePopoverState.d.ts +11 -0
  155. package/dist/bundled/v3/hooks/usePopoverState.js +42 -0
  156. package/dist/bundled/v3/hooks/useValidationAttributes.d.ts +1 -2
  157. package/dist/bundled/v3/index.js +27 -29
  158. package/dist/esm/v2/{OrBottomSheet-75a3b3c0.js → OrBottomSheet-0592ccb2.js} +31 -48
  159. package/dist/esm/v2/{OrCardCollection-94e0d4b3.js → OrCardCollection-2b9bc050.js} +4 -4
  160. package/dist/esm/v2/{OrCheckbox-41f2822d.js → OrCheckbox-3a8c93ad.js} +0 -2
  161. package/dist/esm/v2/{OrCheckboxGroup-97cfcbda.js → OrCheckboxGroup-b0d95dd6.js} +1 -1
  162. package/dist/esm/v2/{OrCheckboxTree-a7dc126c.js → OrCheckboxTree-54b0fdc1.js} +1 -1
  163. package/dist/esm/v2/{OrConfirm-93176f0d.js → OrConfirm-3f19c23b.js} +30 -54
  164. package/dist/esm/v2/{OrDatePicker-1f49baf1.js → OrDatePicker-e991e7b2.js} +4 -4
  165. package/dist/esm/v2/{OrDateTimePicker-3609de6e.js → OrDateTimePicker-7bbd81d1.js} +5 -5
  166. package/dist/esm/v2/{OrDateTimePickerMonthSelect-94af0df9.js → OrDateTimePickerMonthSelect-d75a849c.js} +3 -3
  167. package/dist/esm/v2/{OrIconButton-1ee067fd.js → OrIconButton-75972865.js} +2 -2
  168. package/dist/esm/v2/{OrInlineInput-737e8fff.js → OrInlineInput-cf17dbb2.js} +1 -3
  169. package/dist/esm/v2/{OrInlineTextarea-8bc79191.js → OrInlineTextarea-2b0e2f39.js} +1 -3
  170. package/dist/esm/v2/{OrInput-00cba216.js → OrInput-1a2b8ad9.js} +1 -3
  171. package/dist/esm/v2/{OrMenu-1c14379f.js → OrMenu-a35caf3b.js} +23 -49
  172. package/dist/esm/v2/OrModal-4aaae6bc.js +312 -0
  173. package/dist/esm/v2/{OrNotification-b2dd7471.js → OrNotification-a773f1df.js} +1 -1
  174. package/dist/esm/v2/{OrOverlay-cdaf5b7a.js → OrOverlay-f791976c.js} +1 -3
  175. package/dist/esm/v2/{OrPagination-06a860c7.js → OrPagination-3513165d.js} +3 -5
  176. package/dist/esm/v2/{OrPassword-681f8c53.js → OrPassword-1de0dc6c.js} +0 -2
  177. package/dist/esm/v2/{OrPopover-7096d459.js → OrPopover-a8950b85.js} +33 -106
  178. package/dist/esm/v2/{OrProgress-e079e857.js → OrProgress-102e3b5d.js} +0 -2
  179. package/dist/esm/v2/{OrRadio-23810acd.js → OrRadio-a812088f.js} +0 -2
  180. package/dist/esm/v2/{OrRadioGroup-0e1bf22c.js → OrRadioGroup-0de37d76.js} +1 -1
  181. package/dist/esm/v2/{OrSearch-408fb293.js → OrSearch-19c157b3.js} +1 -1
  182. package/dist/esm/v2/{OrSelect-1d437402.js → OrSelect-991b8be3.js} +4 -6
  183. package/dist/esm/v2/{OrSidebar-c106e59c.js → OrSidebar-bfbb8b0a.js} +1 -1
  184. package/dist/esm/v2/{OrSidebarCollapseButton-db2b96c5.js → OrSidebarCollapseButton-a98037d6.js} +1 -1
  185. package/dist/esm/v2/{OrSwitch-cb97f4d3.js → OrSwitch-9fae0bae.js} +0 -2
  186. package/dist/esm/v2/{OrTabs-52acc3f2.js → OrTabs-abf290af.js} +2 -2
  187. package/dist/esm/v2/{OrTag-dc2a1452.js → OrTag-aa46cecd.js} +1 -1
  188. package/dist/esm/v2/{OrTags-33e9a167.js → OrTags-2a567e79.js} +2 -4
  189. package/dist/esm/v2/{OrTextarea-01df0715.js → OrTextarea-e5c66426.js} +0 -2
  190. package/dist/esm/v2/{OrTextbox-a937432f.js → OrTextbox-c85d7fe6.js} +0 -2
  191. package/dist/esm/v2/{OrTimePicker-13359d63.js → OrTimePicker-766637cb.js} +3 -3
  192. package/dist/esm/v2/{OrTooltip-0649a0cd.js → OrTooltip-0dc63c1a.js} +33 -40
  193. package/dist/esm/v2/components/index.js +38 -39
  194. package/dist/esm/v2/components/or-bottom-sheet-v3/OrBottomSheet.vue.d.ts +19 -10
  195. package/dist/esm/v2/components/or-bottom-sheet-v3/index.js +4 -5
  196. package/dist/esm/v2/components/or-card-collection-v3/index.js +11 -12
  197. package/dist/esm/v2/components/or-checkbox-group-v3/index.js +3 -5
  198. package/dist/esm/v2/components/or-checkbox-tree-v3/index.js +2 -4
  199. package/dist/esm/v2/components/or-checkbox-v3/index.js +1 -3
  200. package/dist/esm/v2/components/or-confirm-v3/OrConfirm.vue.d.ts +18 -36
  201. package/dist/esm/v2/components/or-confirm-v3/index.js +9 -10
  202. package/dist/esm/v2/components/or-date-picker-v3/index.js +10 -11
  203. package/dist/esm/v2/components/or-date-time-picker-v3/index.js +10 -11
  204. package/dist/esm/v2/components/or-icon-button-v3/index.js +7 -8
  205. package/dist/esm/v2/components/or-inline-input-v3/index.js +8 -9
  206. package/dist/esm/v2/components/or-inline-textarea-v3/index.js +8 -9
  207. package/dist/esm/v2/components/or-input-v3/index.js +8 -9
  208. package/dist/esm/v2/components/or-menu-v3/OrMenu.vue.d.ts +13 -16
  209. package/dist/esm/v2/components/or-menu-v3/index.js +7 -8
  210. package/dist/esm/v2/components/or-modal-v3/OrModal.vue.d.ts +13 -19
  211. package/dist/esm/v2/components/or-modal-v3/index.js +12 -13
  212. package/dist/esm/v2/components/or-modal-v3/partials/or-modal-content/OrModalContent.vue.d.ts +8 -0
  213. package/dist/esm/v2/components/or-modal-v3/partials/or-modal-content/styles.d.ts +1 -0
  214. package/dist/esm/v2/components/or-modal-v3/partials/or-modal-footer/OrModalFooter.vue.d.ts +8 -0
  215. package/dist/esm/v2/components/or-modal-v3/partials/or-modal-footer/styles.d.ts +1 -0
  216. package/dist/esm/v2/components/or-modal-v3/partials/or-modal-header/OrModalHeader.vue.d.ts +12 -0
  217. package/dist/esm/v2/components/or-modal-v3/partials/or-modal-header/styles.d.ts +1 -0
  218. package/dist/esm/v2/components/or-modal-v3/styles.d.ts +0 -3
  219. package/dist/esm/v2/components/or-notification-v3/index.js +8 -9
  220. package/dist/esm/v2/components/or-overlay-v3/index.js +2 -4
  221. package/dist/esm/v2/components/or-pagination-v3/index.js +7 -8
  222. package/dist/esm/v2/components/or-password/index.js +1 -3
  223. package/dist/esm/v2/components/or-popover-v3/OrPopover.vue.d.ts +19 -12
  224. package/dist/esm/v2/components/or-popover-v3/index.js +5 -6
  225. package/dist/esm/v2/components/or-progress-v3/index.js +1 -3
  226. package/dist/esm/v2/components/or-radio-group-v3/index.js +2 -4
  227. package/dist/esm/v2/components/or-radio-v3/index.js +1 -3
  228. package/dist/esm/v2/components/or-search-v3/index.js +9 -10
  229. package/dist/esm/v2/components/or-select-v3/index.js +11 -12
  230. package/dist/esm/v2/components/or-sidebar-v3/index.js +9 -10
  231. package/dist/esm/v2/components/or-sidebar-v3/partials/index.js +8 -9
  232. package/dist/esm/v2/components/or-sidebar-v3/partials/or-sidebar-collapse-button/index.js +8 -9
  233. package/dist/esm/v2/components/or-switch-v3/index.js +1 -3
  234. package/dist/esm/v2/components/or-tabs-v3/index.js +7 -8
  235. package/dist/esm/v2/components/or-tag-v3/index.js +8 -9
  236. package/dist/esm/v2/components/or-tags-v3/index.js +9 -10
  237. package/dist/esm/v2/components/or-textarea-v3/index.js +1 -3
  238. package/dist/esm/v2/components/or-textbox/index.js +1 -3
  239. package/dist/esm/v2/components/or-time-picker-v3/index.js +8 -9
  240. package/dist/esm/v2/components/or-toast-v3/index.js +8 -9
  241. package/dist/esm/v2/components/or-toast-v3/or-toast-container-v3/index.js +8 -9
  242. package/dist/esm/v2/components/or-tooltip-v3/OrTooltip.vue.d.ts +20 -17
  243. package/dist/esm/v2/components/or-tooltip-v3/index.js +7 -8
  244. package/dist/esm/v2/hooks/index.d.ts +1 -1
  245. package/dist/esm/v2/hooks/index.js +2 -4
  246. package/dist/esm/v2/hooks/useControlAttributes.d.ts +1 -2
  247. package/dist/esm/v2/hooks/useOverflow.d.ts +2 -2
  248. package/dist/esm/v2/hooks/usePopoverState.d.ts +11 -0
  249. package/dist/esm/v2/hooks/useValidationAttributes.d.ts +1 -2
  250. package/dist/esm/v2/index.js +38 -40
  251. package/dist/esm/v2/{types-a8cdee2b.js → types-f30860ee.js} +2 -4
  252. package/dist/esm/{v3/useElevation-b5a49746.js → v2/useElevation-a50ec347.js} +3 -1
  253. package/dist/esm/v2/usePopoverState-8a95a300.js +42 -0
  254. package/dist/esm/v3/{OrBottomSheet-77311b39.js → OrBottomSheet-a39fb331.js} +31 -48
  255. package/dist/esm/v3/{OrCardCollection-bb83c68d.js → OrCardCollection-3d652a34.js} +4 -4
  256. package/dist/esm/v3/{OrCheckbox-2194e473.js → OrCheckbox-7093e9c2.js} +0 -2
  257. package/dist/esm/v3/{OrCheckboxGroup-6c36527f.js → OrCheckboxGroup-f755d216.js} +1 -1
  258. package/dist/esm/v3/{OrCheckboxTree-1873a941.js → OrCheckboxTree-99f6eaec.js} +1 -1
  259. package/dist/esm/v3/{OrConfirm-db0bc902.js → OrConfirm-cb0b2b78.js} +30 -54
  260. package/dist/esm/v3/{OrDatePicker-afede6ed.js → OrDatePicker-6a44ad41.js} +4 -4
  261. package/dist/esm/v3/{OrDateTimePicker-c74ee133.js → OrDateTimePicker-2cbcf8c7.js} +5 -5
  262. package/dist/esm/v3/{OrDateTimePickerMonthSelect-37ab67a7.js → OrDateTimePickerMonthSelect-2f61d92f.js} +3 -3
  263. package/dist/esm/v3/{OrIconButton-22ed57ad.js → OrIconButton-e34a20eb.js} +2 -2
  264. package/dist/esm/v3/{OrInlineInput-180b24c4.js → OrInlineInput-ad0d4264.js} +1 -3
  265. package/dist/esm/v3/{OrInlineTextarea-0ac83ef3.js → OrInlineTextarea-b5ec488d.js} +1 -3
  266. package/dist/esm/v3/{OrInput-ae5c1b2f.js → OrInput-a9aeef6e.js} +1 -3
  267. package/dist/esm/v3/{OrMenu-659eb389.js → OrMenu-f590d761.js} +24 -50
  268. package/dist/esm/v3/OrModal-9dc09e95.js +226 -0
  269. package/dist/esm/v3/{OrNotification-bcae9dec.js → OrNotification-69031471.js} +1 -1
  270. package/dist/esm/v3/{OrOverlay-5db47cfe.js → OrOverlay-28952099.js} +1 -3
  271. package/dist/esm/v3/{OrPagination-9e2ee086.js → OrPagination-f3be120f.js} +3 -5
  272. package/dist/esm/v3/{OrPassword-cd8a3c46.js → OrPassword-9192b9ea.js} +0 -2
  273. package/dist/esm/v3/{OrPopover-e2208d1c.js → OrPopover-ebd57053.js} +31 -104
  274. package/dist/esm/v3/{OrProgress-a54a42c0.js → OrProgress-efa51d7b.js} +0 -2
  275. package/dist/esm/v3/{OrRadio-4f0026c9.js → OrRadio-a6c88f29.js} +0 -2
  276. package/dist/esm/v3/{OrRadioGroup-d215409c.js → OrRadioGroup-5d1fe6fd.js} +1 -1
  277. package/dist/esm/v3/{OrSearch-5c1384ce.js → OrSearch-5576cf14.js} +1 -1
  278. package/dist/esm/v3/{OrSelect-f32d7727.js → OrSelect-0b3ebce9.js} +4 -6
  279. package/dist/esm/v3/{OrSidebar-47bea81a.js → OrSidebar-303ef558.js} +1 -1
  280. package/dist/esm/v3/{OrSidebarCollapseButton-ece05a32.js → OrSidebarCollapseButton-d7f004df.js} +1 -1
  281. package/dist/esm/v3/{OrSwitch-ed9868db.js → OrSwitch-594f5a63.js} +0 -2
  282. package/dist/esm/v3/{OrTabs-b9de0432.js → OrTabs-b6c8077c.js} +2 -2
  283. package/dist/esm/v3/{OrTag-c6f35b07.js → OrTag-4ac45254.js} +1 -1
  284. package/dist/esm/v3/{OrTags-5990db43.js → OrTags-de9f065e.js} +2 -4
  285. package/dist/esm/v3/{OrTextarea-0f9a2a27.js → OrTextarea-93cf7da7.js} +0 -2
  286. package/dist/esm/v3/{OrTextbox-8d2903db.js → OrTextbox-56714f51.js} +0 -2
  287. package/dist/esm/v3/{OrTimePicker-81437237.js → OrTimePicker-0fe72767.js} +3 -3
  288. package/dist/esm/v3/{OrTooltip-7e0473b9.js → OrTooltip-edb28095.js} +28 -41
  289. package/dist/esm/v3/components/index.js +38 -39
  290. package/dist/esm/v3/components/or-bottom-sheet-v3/OrBottomSheet.vue.d.ts +16 -10
  291. package/dist/esm/v3/components/or-bottom-sheet-v3/index.js +4 -5
  292. package/dist/esm/v3/components/or-card-collection-v3/index.js +11 -12
  293. package/dist/esm/v3/components/or-checkbox-group-v3/index.js +3 -5
  294. package/dist/esm/v3/components/or-checkbox-tree-v3/index.js +2 -4
  295. package/dist/esm/v3/components/or-checkbox-v3/index.js +1 -3
  296. package/dist/esm/v3/components/or-confirm-v3/OrConfirm.vue.d.ts +18 -35
  297. package/dist/esm/v3/components/or-confirm-v3/index.js +9 -10
  298. package/dist/esm/v3/components/or-date-picker-v3/index.js +10 -11
  299. package/dist/esm/v3/components/or-date-time-picker-v3/index.js +10 -11
  300. package/dist/esm/v3/components/or-icon-button-v3/index.js +7 -8
  301. package/dist/esm/v3/components/or-inline-input-v3/index.js +8 -9
  302. package/dist/esm/v3/components/or-inline-textarea-v3/index.js +8 -9
  303. package/dist/esm/v3/components/or-input-v3/index.js +8 -9
  304. package/dist/esm/v3/components/or-menu-v3/OrMenu.vue.d.ts +13 -5
  305. package/dist/esm/v3/components/or-menu-v3/index.js +7 -8
  306. package/dist/esm/v3/components/or-modal-v3/OrModal.vue.d.ts +14 -16
  307. package/dist/esm/v3/components/or-modal-v3/index.js +11 -12
  308. package/dist/esm/v3/components/or-modal-v3/partials/or-modal-content/OrModalContent.vue.d.ts +5 -0
  309. package/dist/esm/v3/components/or-modal-v3/partials/or-modal-content/styles.d.ts +1 -0
  310. package/dist/esm/v3/components/or-modal-v3/partials/or-modal-footer/OrModalFooter.vue.d.ts +5 -0
  311. package/dist/esm/v3/components/or-modal-v3/partials/or-modal-footer/styles.d.ts +1 -0
  312. package/dist/esm/v3/components/or-modal-v3/partials/or-modal-header/OrModalHeader.vue.d.ts +7 -0
  313. package/dist/esm/v3/components/or-modal-v3/partials/or-modal-header/styles.d.ts +1 -0
  314. package/dist/esm/v3/components/or-modal-v3/styles.d.ts +0 -3
  315. package/dist/esm/v3/components/or-notification-v3/index.js +8 -9
  316. package/dist/esm/v3/components/or-overlay-v3/index.js +2 -4
  317. package/dist/esm/v3/components/or-pagination-v3/index.js +7 -8
  318. package/dist/esm/v3/components/or-password/index.js +1 -3
  319. package/dist/esm/v3/components/or-popover-v3/OrPopover.vue.d.ts +16 -11
  320. package/dist/esm/v3/components/or-popover-v3/index.js +5 -6
  321. package/dist/esm/v3/components/or-progress-v3/index.js +1 -3
  322. package/dist/esm/v3/components/or-radio-group-v3/index.js +2 -4
  323. package/dist/esm/v3/components/or-radio-v3/index.js +1 -3
  324. package/dist/esm/v3/components/or-search-v3/index.js +9 -10
  325. package/dist/esm/v3/components/or-select-v3/index.js +11 -12
  326. package/dist/esm/v3/components/or-sidebar-v3/index.js +9 -10
  327. package/dist/esm/v3/components/or-sidebar-v3/partials/index.js +8 -9
  328. package/dist/esm/v3/components/or-sidebar-v3/partials/or-sidebar-collapse-button/index.js +8 -9
  329. package/dist/esm/v3/components/or-switch-v3/index.js +1 -3
  330. package/dist/esm/v3/components/or-tabs-v3/index.js +7 -8
  331. package/dist/esm/v3/components/or-tag-v3/index.js +8 -9
  332. package/dist/esm/v3/components/or-tags-v3/index.js +9 -10
  333. package/dist/esm/v3/components/or-textarea-v3/index.js +1 -3
  334. package/dist/esm/v3/components/or-textbox/index.js +1 -3
  335. package/dist/esm/v3/components/or-time-picker-v3/index.js +8 -9
  336. package/dist/esm/v3/components/or-toast-v3/index.js +8 -9
  337. package/dist/esm/v3/components/or-toast-v3/or-toast-container-v3/index.js +8 -9
  338. package/dist/esm/v3/components/or-tooltip-v3/OrTooltip.vue.d.ts +17 -6
  339. package/dist/esm/v3/components/or-tooltip-v3/index.js +7 -8
  340. package/dist/esm/v3/hooks/index.d.ts +1 -1
  341. package/dist/esm/v3/hooks/index.js +2 -4
  342. package/dist/esm/v3/hooks/useControlAttributes.d.ts +1 -2
  343. package/dist/esm/v3/hooks/useOverflow.d.ts +2 -2
  344. package/dist/esm/v3/hooks/usePopoverState.d.ts +11 -0
  345. package/dist/esm/v3/hooks/useValidationAttributes.d.ts +1 -2
  346. package/dist/esm/v3/index.js +38 -40
  347. package/dist/esm/v3/{types-637a5626.js → types-60f3dd35.js} +2 -4
  348. package/dist/esm/{v2/useElevation-b5a49746.js → v3/useElevation-a50ec347.js} +3 -1
  349. package/dist/esm/v3/usePopoverState-8a95a300.js +42 -0
  350. package/package.json +4 -4
  351. package/src/components/or-bottom-sheet-v3/OrBottomSheet.vue +29 -58
  352. package/src/components/or-confirm-v3/OrConfirm.vue +29 -50
  353. package/src/components/or-date-picker-v3/OrDatePicker.vue +1 -1
  354. package/src/components/or-date-time-picker-v3/OrDateTimePicker.vue +2 -2
  355. package/src/components/or-menu-v3/OrMenu.vue +18 -40
  356. package/src/components/or-modal-v3/OrModal.vue +32 -66
  357. package/src/components/or-modal-v3/partials/or-modal-content/OrModalContent.vue +37 -0
  358. package/src/components/or-modal-v3/partials/or-modal-content/styles.ts +10 -0
  359. package/src/components/or-modal-v3/partials/or-modal-footer/OrModalFooter.vue +37 -0
  360. package/src/components/or-modal-v3/partials/or-modal-footer/styles.ts +4 -0
  361. package/src/components/or-modal-v3/partials/or-modal-header/OrModalHeader.vue +54 -0
  362. package/src/components/or-modal-v3/partials/or-modal-header/styles.ts +10 -0
  363. package/src/components/or-modal-v3/styles.ts +0 -25
  364. package/src/components/or-pagination-v3/OrPagination.vue +1 -1
  365. package/src/components/or-popover-v3/OrPopover.vue +28 -125
  366. package/src/components/or-time-picker-v3/OrTimePicker.vue +1 -1
  367. package/src/components/or-tooltip-v3/OrTooltip.vue +24 -40
  368. package/src/hooks/index.ts +1 -1
  369. package/src/hooks/useControlAttributes.ts +1 -1
  370. package/src/hooks/useElevation.ts +7 -2
  371. package/src/hooks/useOverflow.ts +5 -3
  372. package/src/hooks/usePopoverState.ts +66 -0
  373. package/src/hooks/useValidationAttributes.ts +1 -1
  374. package/src/shims-png.d.ts +2 -2
  375. package/src/shims-vue.d.ts +2 -3
  376. package/src/shims.d.ts +3 -5
  377. package/dist/bundled/v2/hooks/useTheme.d.ts +0 -2
  378. package/dist/bundled/v2/hooks/useTheme.js +0 -10128
  379. package/dist/bundled/v3/OrMenu.vue_vue_type_script_lang-115f2c60.js +0 -93
  380. package/dist/bundled/v3/OrModal.vue_vue_type_script_lang-202c4e2f.js +0 -71
  381. package/dist/bundled/v3/OrTooltip.vue_vue_type_script_lang-bb3db5bf.js +0 -72
  382. package/dist/bundled/v3/hooks/useTheme.d.ts +0 -2
  383. package/dist/bundled/v3/hooks/useTheme.js +0 -10128
  384. package/dist/esm/v2/OrModal-3dca06f9.js +0 -174
  385. package/dist/esm/v2/hooks/useTheme.d.ts +0 -2
  386. package/dist/esm/v2/useTheme-e23d13c8.js +0 -9
  387. package/dist/esm/v3/OrModal-2db2eb9f.js +0 -150
  388. package/dist/esm/v3/hooks/useTheme.d.ts +0 -2
  389. package/dist/esm/v3/useTheme-e23d13c8.js +0 -9
  390. package/src/hooks/useTheme.ts +0 -7
  391. package/src/shims-mdx.d.ts +0 -4
  392. /package/dist/bundled/v2/{OrDateTimePickerMonthSelect-30f79990.js → OrDateTimePickerMonthSelect-9a8e332c.js} +0 -0
  393. /package/dist/bundled/v3/{OrOverlay.vue_vue_type_script_lang-86c7b93a.js → OrOverlay.vue_vue_type_script_lang-29ff6fd8.js} +0 -0
  394. /package/dist/bundled/v3/{OrToastContainer.vue_vue_type_script_lang-485ef171.js → OrToastContainer.vue_vue_type_script_lang-461fb6d1.js} +0 -0
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@onereach/ui-components",
3
- "version": "4.6.4-beta.2804.0",
3
+ "version": "4.6.4",
4
4
  "description": "Vue components library for v2/3",
5
5
  "sideEffects": false,
6
6
  "main": "./dist/auto/index.js",
@@ -38,7 +38,7 @@
38
38
  "@codemirror/lang-json": "6.0.0",
39
39
  "@codemirror/lang-markdown": "6.0.1",
40
40
  "@floating-ui/dom": "0.3.1",
41
- "@onereach/styles": "^2.39.4-beta.2804.0",
41
+ "@onereach/styles": "^2.39.3",
42
42
  "@splidejs/splide": "4.0.6",
43
43
  "@types/lodash": "4.14.173",
44
44
  "@types/sortablejs": "1.10.7",
@@ -49,7 +49,6 @@
49
49
  "codemirror": "6.0.1",
50
50
  "focus-trap": "7.2.0",
51
51
  "sortablejs": "1.14.0",
52
- "tailwindcss": "3.1.3",
53
52
  "uuid": "8.3.2"
54
53
  },
55
54
  "devDependencies": {
@@ -154,5 +153,6 @@
154
153
  "default": "./dist/bundled/v3/components/*/index.js"
155
154
  },
156
155
  "./package.json": "./package.json"
157
- }
156
+ },
157
+ "gitHead": "87cc5310857dbd7b1e50ed03333ec8e3bae469a3"
158
158
  }
@@ -1,7 +1,7 @@
1
1
  <template>
2
2
  <OrOverlay
3
- v-if="state !== 'closed'"
4
- :fullscreen="state === 'fullscreen'"
3
+ v-if="state === 'open'"
4
+ :fullscreen="fullscreen"
5
5
  >
6
6
  <div
7
7
  ref="root"
@@ -16,7 +16,7 @@
16
16
  <slot name="header" />
17
17
  </div>
18
18
 
19
- <div :class="[state === 'fullscreen' ? 'overflow-y-auto' : 'overflow-hidden']">
19
+ <div :class="[fullscreen ? 'overflow-y-auto' : 'overflow-hidden']">
20
20
  <slot />
21
21
  </div>
22
22
  </div>
@@ -25,7 +25,8 @@
25
25
 
26
26
  <script lang="ts">
27
27
  import { onClickOutside, SwipeDirection, usePointerSwipe } from '@vueuse/core';
28
- import { computed, defineComponent, PropType, ref, unref, watch } from 'vue-demi';
28
+ import { computed, defineComponent, PropType, ref, toRef, unref, watch } from 'vue-demi';
29
+ import { usePopoverState } from '../../hooks';
29
30
  import { OrOverlayV3 as OrOverlay } from '../or-overlay-v3';
30
31
  import { BottomSheetVariant } from './props';
31
32
  import { BottomSheet, BottomSheetHandle, BottomSheetHeader, BottomSheetVariants } from './styles';
@@ -40,6 +41,11 @@ export default defineComponent({
40
41
  inheritAttrs: false,
41
42
 
42
43
  props: {
44
+ isOpen: {
45
+ type: Boolean,
46
+ default: false,
47
+ },
48
+
43
49
  variant: {
44
50
  type: String as PropType<`${BottomSheetVariant}`>,
45
51
  default: BottomSheetVariant.Advanced,
@@ -48,20 +54,19 @@ export default defineComponent({
48
54
 
49
55
  emits: [
50
56
  'update:state',
51
- 'update:state:open',
52
- 'update:state:fullscreen',
53
- 'update:state:closed',
54
- 'update:state:closed-automatically',
57
+
58
+ 'open',
59
+ 'close',
55
60
  ],
56
61
 
57
62
  expose: [
58
63
  'root',
64
+
59
65
  'state',
60
- 'isOpen',
61
- 'isFullscreen',
62
- 'isClosed',
66
+
63
67
  'open',
64
68
  'close',
69
+ 'toggle',
65
70
  ],
66
71
 
67
72
  setup(props, context) {
@@ -84,53 +89,16 @@ export default defineComponent({
84
89
  ]);
85
90
 
86
91
  // State
87
- const state = ref<'open' | 'fullscreen' | 'closed'>('closed');
92
+ const { state, open, close, toggle } = usePopoverState(toRef(props, 'isOpen'), context);
88
93
 
89
- const isOpen = computed(() => state.value === 'open');
90
- const isFullscreen = computed(() => state.value === 'fullscreen');
91
- const isClosed = computed(() => state.value === 'closed');
94
+ const fullscreen = ref<boolean>(false);
92
95
 
93
- // Events
94
96
  watch(state, (value) => {
95
- context.emit('update:state', value);
96
-
97
- switch (value) {
98
- case 'open':
99
- context.emit('update:state:open');
100
- break;
101
-
102
- case 'fullscreen':
103
- context.emit('update:state:fullscreen');
104
- break;
105
-
106
- case 'closed':
107
- context.emit('update:state:closed');
108
- break;
97
+ if (value === 'closed') {
98
+ fullscreen.value = false;
109
99
  }
110
100
  });
111
101
 
112
- // Methods
113
- function open(): void {
114
- state.value = 'open';
115
- }
116
-
117
- function close(auto: boolean = false): void {
118
- state.value = 'closed';
119
-
120
- if (auto) {
121
- context.emit('update:state:closed-automatically');
122
- }
123
- }
124
-
125
- // Handlers
126
- function onSwipeUp(): void {
127
- state.value = 'fullscreen';
128
- }
129
-
130
- function onSwipeDown(): void {
131
- state.value = state.value === 'fullscreen' ? 'open' : 'closed';
132
- }
133
-
134
102
  // Effects
135
103
  // #region Swipe
136
104
  const swipeOptions = {
@@ -160,7 +128,7 @@ export default defineComponent({
160
128
  maxHeight: '100%',
161
129
  });
162
130
 
163
- onSwipeUp();
131
+ fullscreen.value = true;
164
132
 
165
133
  break;
166
134
 
@@ -171,7 +139,11 @@ export default defineComponent({
171
139
  maxHeight: '50%',
172
140
  });
173
141
 
174
- onSwipeDown();
142
+ if (fullscreen.value) {
143
+ fullscreen.value = false;
144
+ } else {
145
+ close();
146
+ }
175
147
 
176
148
  break;
177
149
  }
@@ -187,7 +159,7 @@ export default defineComponent({
187
159
  const path = event.composedPath() as Element[];
188
160
 
189
161
  if (!path.some(({ classList }) => classList?.contains('or-popover-v3') || classList?.contains('or-bottom-sheet-v3'))) {
190
- close(true);
162
+ close();
191
163
  }
192
164
  });
193
165
  // #endregion
@@ -198,11 +170,10 @@ export default defineComponent({
198
170
  handleStyles,
199
171
  headerStyles,
200
172
  state,
201
- isOpen,
202
- isFullscreen,
203
- isClosed,
173
+ fullscreen,
204
174
  open,
205
175
  close,
176
+ toggle,
206
177
  };
207
178
  },
208
179
  });
@@ -1,7 +1,7 @@
1
1
  <template>
2
2
  <OrOverlay
3
- v-if="isActive"
4
- fullscreen
3
+ v-if="state === 'open'"
4
+ :fullscreen="true"
5
5
  >
6
6
  <div
7
7
  ref="root"
@@ -17,6 +17,7 @@
17
17
 
18
18
  <div :class="['grow', 'overflow-y-auto', 'overflow-x-hidden']">
19
19
  <slot />
20
+
20
21
  <div
21
22
  v-if="confirmationText"
22
23
  :class="inputBoxStyles"
@@ -67,7 +68,8 @@
67
68
  <script lang="ts">
68
69
  import { onClickOutside, useMagicKeys, whenever } from '@vueuse/core';
69
70
  import { logicAnd } from '@vueuse/math';
70
- import { computed, defineComponent, PropType, ref, watch } from 'vue-demi';
71
+ import { PropType, computed, defineComponent, ref, toRef, watch } from 'vue-demi';
72
+ import { usePopoverState } from '../../hooks';
71
73
  import { ButtonColor, OrButtonV3 as OrButton } from '../or-button-v3';
72
74
  import { OrInputV3 as OrInput } from '../or-input-v3';
73
75
  import { OrOverlayV3 as OrOverlay } from '../or-overlay-v3';
@@ -86,6 +88,11 @@ export default defineComponent({
86
88
  inheritAttrs: false,
87
89
 
88
90
  props: {
91
+ isOpen: {
92
+ type: Boolean,
93
+ default: false,
94
+ },
95
+
89
96
  titleText: {
90
97
  type: String,
91
98
  required: false,
@@ -94,25 +101,21 @@ export default defineComponent({
94
101
 
95
102
  confirmButtonText: {
96
103
  type: String,
97
- required: false,
98
104
  default: 'Confirm',
99
105
  },
100
106
 
101
107
  cancelButtonText: {
102
108
  type: String,
103
- required: false,
104
109
  default: 'Cancel',
105
110
  },
106
111
 
107
112
  confirmType: {
108
113
  type: String as PropType<ConfirmType>,
109
- required: false,
110
114
  default: ConfirmType.C,
111
115
  },
112
116
 
113
117
  loading: {
114
118
  type: Boolean,
115
- required: false,
116
119
  default: false,
117
120
  },
118
121
 
@@ -124,36 +127,28 @@ export default defineComponent({
124
127
 
125
128
  confirmationText: {
126
129
  type: String,
127
- required: false,
128
- default: null,
130
+ default: undefined,
129
131
  },
130
132
 
131
133
  textConfirmationLabel: {
132
134
  type: String,
133
- required: false,
134
- default: null,
135
+ default: undefined,
135
136
  },
136
137
 
137
138
  textConfirmationPlaceholder: {
138
139
  type: String,
139
- required: false,
140
- default: null,
140
+ default: undefined,
141
141
  },
142
142
 
143
143
  textConfirmationError: {
144
144
  type: String,
145
- required: false,
146
- default: null,
147
- },
148
-
149
- isOpen: {
150
- type: Boolean,
151
- required: false,
152
145
  default: undefined,
153
146
  },
154
147
  },
155
148
 
156
149
  emits: [
150
+ 'update:state',
151
+
157
152
  'open',
158
153
  'close',
159
154
  'confirm',
@@ -161,12 +156,14 @@ export default defineComponent({
161
156
 
162
157
  expose: [
163
158
  'root',
164
- 'isActive',
159
+
160
+ 'state',
161
+
165
162
  'open',
166
163
  'close',
167
164
  ],
168
165
 
169
- setup(props, { emit }) {
166
+ setup(props, context) {
170
167
  // Refs
171
168
  const root = ref<HTMLElement>();
172
169
  const confirmationInput = ref<InstanceType<typeof OrInput>>();
@@ -174,7 +171,7 @@ export default defineComponent({
174
171
 
175
172
  // State
176
173
  const touched = ref(false);
177
- const isActive = ref(props.isOpen || false);
174
+ const { state, open, close } = usePopoverState(toRef(props, 'isOpen'), context);
178
175
  const isInputActive = ref(false);
179
176
  const confirmationValue = ref<string>('');
180
177
 
@@ -191,23 +188,10 @@ export default defineComponent({
191
188
  );
192
189
 
193
190
  // Methods
194
- function open(): void {
195
- isActive.value = true;
196
- emit('open');
197
- }
198
-
199
- function close(): void {
200
- // In case if component opened by isOpen - only event can be emited, app will catch it and flip reference
201
- if (props.isOpen === true) {
202
- emit('close');
203
- } else {
204
- isActive.value = false;
205
- emit('close');
206
- }
207
- }
208
-
209
191
  function confirm(): void {
210
- if (!props.disabled && !isInvalid.value) emit('confirm');
192
+ if (!props.disabled && !isInvalid.value) {
193
+ context.emit('confirm');
194
+ }
211
195
  }
212
196
 
213
197
  function onInputFocus(): void {
@@ -220,20 +204,15 @@ export default defineComponent({
220
204
  }
221
205
 
222
206
  // Events
223
- watch(() => props.isOpen, (value) => {
224
- // In case if component opened by isOpen - no need to emmit events, we need just sync local state
225
- if (value != undefined) {
226
- isActive.value = value;
227
- }
228
- }, { immediate: true });
229
-
230
207
  watch(escape, (val) => {
231
208
  if (val) close();
232
209
  });
233
210
 
234
- watch(isActive, () => {
235
- confirmationValue.value = '';
236
- touched.value = false;
211
+ watch(state, (value) => {
212
+ if (value === 'closed') {
213
+ confirmationValue.value = '';
214
+ touched.value = false;
215
+ }
237
216
  });
238
217
 
239
218
  // types here are used for fixing TS2349
@@ -286,7 +265,7 @@ export default defineComponent({
286
265
  isInvalid,
287
266
  isConfirmationButtonDisabled,
288
267
  touched,
289
- isActive,
268
+ state,
290
269
  isInputActive,
291
270
  escape,
292
271
  rootStyles,
@@ -43,7 +43,7 @@
43
43
  :bottom-sheet-props="{ variant: 'basic' }"
44
44
  :trigger="inputBoxRoot"
45
45
  :placement="'bottom-start'"
46
- @update:state:closed-automatically="reset()"
46
+ @close="reset()"
47
47
  >
48
48
  <OrDateTimePickerPopoverHeader>
49
49
  <OrDateTimePickerMobileControl label="Date">
@@ -52,7 +52,7 @@
52
52
  :bottom-sheet-props="{ variant: 'basic' }"
53
53
  :trigger="inputBoxRoot"
54
54
  :placement="'bottom-start'"
55
- @update:state:closed-automatically="reset()"
55
+ @close="reset()"
56
56
  >
57
57
  <OrDateTimePickerPopoverHeader>
58
58
  <OrDateTimePickerMobileControl label="Date">
@@ -90,7 +90,7 @@
90
90
  :bottom-sheet-props="{ variant: 'basic' }"
91
91
  :trigger="inputBoxRoot"
92
92
  :placement="'bottom-start'"
93
- @update:state:closed-automatically="reset()"
93
+ @close="reset()"
94
94
  >
95
95
  <OrDateTimePickerPopoverHeader>
96
96
  <OrDateTimePickerMobileControl label="Date">
@@ -1,12 +1,12 @@
1
1
  <template>
2
2
  <OrPopover
3
- ref="popover"
3
+ :is-open="state === 'open'"
4
4
  :variant="'auto'"
5
5
  :trigger="trigger"
6
6
  :placement="placement"
7
7
  :full-width="false"
8
8
  :disable-default-styles="false"
9
- @update:state="$emit('update:state', $event)"
9
+ @update:state="state = $event"
10
10
  >
11
11
  <div
12
12
  ref="root"
@@ -20,7 +20,8 @@
20
20
  </template>
21
21
 
22
22
  <script lang="ts">
23
- import { computed, defineComponent, PropType, ref } from 'vue-demi';
23
+ import { computed, defineComponent, PropType, ref, toRef } from 'vue-demi';
24
+ import { usePopoverState } from '../../hooks';
24
25
  import { OrPopoverV3 as OrPopover } from '../or-popover-v3';
25
26
  import { MenuPlacement } from './props';
26
27
  import { MenuRoot } from './styles';
@@ -35,6 +36,11 @@ export default defineComponent({
35
36
  inheritAttrs: false,
36
37
 
37
38
  props: {
39
+ isOpen: {
40
+ type: Boolean,
41
+ default: false,
42
+ },
43
+
38
44
  trigger: {
39
45
  type: HTMLElement,
40
46
  default: undefined,
@@ -48,25 +54,25 @@ export default defineComponent({
48
54
 
49
55
  emits: [
50
56
  'update:state',
57
+
58
+ 'open',
59
+ 'close',
51
60
  ],
52
61
 
53
62
  expose: [
54
63
  'root',
64
+
55
65
  'state',
56
- 'isOpen',
66
+
57
67
  'open',
58
68
  'close',
59
69
  'toggle',
60
70
  ],
61
71
 
62
- setup() {
72
+ setup(props, context) {
63
73
  // Refs
64
74
  const root = ref<HTMLElement>();
65
75
 
66
- const popover = ref<InstanceType<typeof OrPopover>>();
67
- const popoverRoot = computed(() => popover.value?.root);
68
- const popoverState = computed(() => popover.value?.state);
69
-
70
76
  // Styles
71
77
  const rootStyles = computed(() => [
72
78
  'or-menu-v3',
@@ -74,49 +80,21 @@ export default defineComponent({
74
80
  ]);
75
81
 
76
82
  // State
77
- const isOpen = computed(() => popover.value?.isOpen);
78
-
79
- // Methods
80
- function open(): void {
81
- const popoverInstance = popover.value;
82
-
83
- if (popoverInstance) {
84
- (popoverInstance.open as () => void)();
85
- }
86
- }
87
-
88
- function close(): void {
89
- const popoverInstance = popover.value;
90
-
91
- if (popoverInstance) {
92
- (popoverInstance.close as () => void)();
93
- }
94
- }
95
-
96
- function toggle(): void {
97
- isOpen.value ? close() : open();
98
- }
83
+ const { state, open, close, toggle } = usePopoverState(toRef(props, 'isOpen'), context);
99
84
 
100
85
  // Handlers
101
86
  function onClick(event: Event): void {
102
87
  const path = event.composedPath() as HTMLElement[];
103
88
 
104
- const classLists = path
105
- .filter(({ classList }) => !!classList)
106
- .map(({ classList }) => classList);
107
-
108
- if (classLists.some((classList) => classList.contains('or-menu-item-v3'))) {
89
+ if (path.some(({ classList }) => classList?.contains('or-menu-item-v3'))) {
109
90
  close();
110
91
  }
111
92
  }
112
93
 
113
94
  return {
114
95
  root,
115
- popover,
116
- popoverRoot,
117
- state: popoverState,
118
96
  rootStyles,
119
- isOpen,
97
+ state,
120
98
  open,
121
99
  close,
122
100
  toggle,
@@ -1,6 +1,6 @@
1
1
  <template>
2
2
  <OrOverlay
3
- v-if="isActive"
3
+ v-if="state === 'open'"
4
4
  :fullscreen="true"
5
5
  >
6
6
  <div
@@ -8,64 +8,67 @@
8
8
  v-bind="$attrs"
9
9
  :class="rootStyles"
10
10
  >
11
- <div :class="headerStyles">
12
- <div :class="['grow']">
13
- <slot name="header" />
14
- </div>
15
-
16
- <OrIconButton
17
- :icon="'close'"
18
- :size="'l'"
19
- @click.stop="close"
20
- />
21
- </div>
22
-
23
- <div :class="contentStyles">
11
+ <OrModalHeader @close="close()">
12
+ <slot name="header" />
13
+ </OrModalHeader>
14
+
15
+ <OrModalContent>
24
16
  <slot />
25
- </div>
26
- <div :class="footerStyles">
17
+ </OrModalContent>
18
+
19
+ <OrModalFooter v-if="$slots.footer">
27
20
  <slot name="footer" />
28
- </div>
21
+ </OrModalFooter>
29
22
  </div>
30
23
  </OrOverlay>
31
24
  </template>
32
25
 
33
26
  <script lang="ts">
34
- import { computed, defineComponent, PropType, ref, watch } from 'vue-demi';
35
- import { OrIconButtonV3 as OrIconButton } from '../or-icon-button-v3';
27
+ import { computed, defineComponent, PropType, ref, toRef } from 'vue-demi';
28
+ import { usePopoverState } from '../../hooks';
36
29
  import { OrOverlayV3 as OrOverlay } from '../or-overlay-v3';
30
+ import OrModalContent from './partials/or-modal-content/OrModalContent.vue';
31
+ import OrModalFooter from './partials/or-modal-footer/OrModalFooter.vue';
32
+ import OrModalHeader from './partials/or-modal-header/OrModalHeader.vue';
37
33
  import { ModalSize } from './props';
38
- import { ModalHeader, ModalRoot, ModalRootSizes, ModalContent, ModalFooter } from './styles';
34
+ import { ModalRoot, ModalRootSizes } from './styles';
39
35
 
40
36
  export default defineComponent({
41
37
  name: 'OrModal',
42
38
 
43
39
  components: {
40
+ OrModalContent,
41
+ OrModalFooter,
42
+ OrModalHeader,
44
43
  OrOverlay,
45
- OrIconButton,
46
44
  },
47
45
 
48
46
  inheritAttrs: false,
49
47
 
50
48
  props: {
51
- size: {
52
- type: String as PropType<ModalSize>,
53
- default: ModalSize.M,
54
- },
55
49
  isOpen: {
56
- type: Boolean as PropType<boolean>,
50
+ type: Boolean,
57
51
  default: false,
58
52
  },
53
+
54
+ size: {
55
+ type: String as PropType<`${ModalSize}`>,
56
+ default: ModalSize.M,
57
+ },
59
58
  },
60
59
 
61
60
  emits: [
61
+ 'update:state',
62
+
62
63
  'open',
63
64
  'close',
64
65
  ],
65
66
 
66
67
  expose: [
67
68
  'root',
68
- 'isActive',
69
+
70
+ 'state',
71
+
69
72
  'open',
70
73
  'close',
71
74
  ],
@@ -81,50 +84,13 @@ export default defineComponent({
81
84
  ...ModalRootSizes[props.size],
82
85
  ]);
83
86
 
84
- const headerStyles = computed(() => [
85
- ...ModalHeader,
86
- ]);
87
-
88
- const contentStyles = computed(() => [
89
- ...ModalContent,
90
- ]);
91
-
92
- const footerStyles = computed(() => [
93
- ...ModalFooter,
94
- ]);
95
-
96
87
  // State
97
- const isActive = ref(false);
98
-
99
- // Events
100
- watch(isActive, (value) => {
101
- context.emit(value ? 'open' : 'close');
102
- });
103
-
104
- watch(() => props.isOpen, (newIsOpen) => {
105
- if (newIsOpen) {
106
- open();
107
- } else {
108
- close();
109
- }
110
- }, { immediate: true });
111
-
112
- // Methods
113
- function open(): void {
114
- isActive.value = true;
115
- }
116
-
117
- function close(): void {
118
- isActive.value = false;
119
- }
88
+ const { state, open, close } = usePopoverState(toRef(props, 'isOpen'), context);
120
89
 
121
90
  return {
122
91
  root,
123
92
  rootStyles,
124
- headerStyles,
125
- contentStyles,
126
- footerStyles,
127
- isActive,
93
+ state,
128
94
  open,
129
95
  close,
130
96
  };