adata-ui 2.1.17 → 2.1.19

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 (410) hide show
  1. package/-error.vue +170 -170
  2. package/.editorconfig +12 -12
  3. package/.gitlab-ci.yml +16 -16
  4. package/.nuxtrc +1 -1
  5. package/.nvmrc +1 -1
  6. package/.playground/app.config.ts +5 -5
  7. package/.playground/nuxt.config.ts +3 -3
  8. package/README.md +75 -75
  9. package/app.config.ts +28 -28
  10. package/app.vue +8 -8
  11. package/assets/styles/index.scss +104 -104
  12. package/assets/styles/modules/_base.scss +5 -5
  13. package/assets/styles/modules/_typography.scss +152 -152
  14. package/components/elements/README.md +1 -1
  15. package/components/elements/a-select-row/index.vue +140 -140
  16. package/components/elements/accordion/AAccordion.vue +197 -197
  17. package/components/elements/accordion/AAccordionGroup/AAccordionGroup.vue +145 -145
  18. package/components/elements/accordion/AAccordionGroup/types.ts +20 -20
  19. package/components/elements/accordion/AAccordionGroup/ui.config.ts +22 -22
  20. package/components/elements/accordion/types.ts +14 -14
  21. package/components/elements/accordion/ui.config.ts +22 -22
  22. package/components/elements/alert/AAlert.vue +65 -65
  23. package/components/elements/banner/ABanner.vue +49 -49
  24. package/components/elements/bg-block/ABgBlock.vue +11 -11
  25. package/components/elements/button/AButton.vue +188 -188
  26. package/components/elements/button/types.ts +24 -24
  27. package/components/elements/button-login/index.vue +21 -21
  28. package/components/elements/calendar/ACalendar.vue +83 -83
  29. package/components/elements/carousel/ACarousel.vue +159 -159
  30. package/components/elements/carousel/config.ui.ts +15 -15
  31. package/components/elements/carousel/types.ts +18 -18
  32. package/components/elements/chip-wrapper/AChipWrapper.vue +80 -80
  33. package/components/elements/chip-wrapper/types.ts +12 -12
  34. package/components/elements/chips/AChips.vue +32 -32
  35. package/components/elements/companies/AOurClients.vue +42 -42
  36. package/components/elements/curve-block/ACurveBlock.vue +291 -291
  37. package/components/elements/digit-badge/ADigitBadge.vue +83 -83
  38. package/components/elements/error-template/index.vue +48 -48
  39. package/components/elements/error-template/types.ts +23 -23
  40. package/components/elements/feature-description/AFeatureDescription.vue +112 -112
  41. package/components/elements/illustrations/noAccess.vue +71 -71
  42. package/components/elements/infinite-carousel/AInfiniteCarousel.vue +57 -57
  43. package/components/elements/infinite-scroll/AInfiniteScroll.vue +33 -33
  44. package/components/elements/leave-note/ALeaveNote.vue +78 -78
  45. package/components/elements/pagination/APagination.vue +110 -110
  46. package/components/elements/photos-animation/APhotosAnimation.vue +85 -85
  47. package/components/elements/select/ASelect.vue +445 -445
  48. package/components/elements/select/ASelectMobile.vue +186 -186
  49. package/components/elements/select/ui/select-button.vue +112 -112
  50. package/components/elements/select/ui/select-list.vue +99 -99
  51. package/components/elements/show-more/AShowMore.vue +35 -35
  52. package/components/elements/skeleton/ASkeleton.vue +44 -44
  53. package/components/elements/star-rating/AStarRating.vue +181 -181
  54. package/components/elements/star-rating/types.ts +7 -7
  55. package/components/elements/star-rating/ui/Star.vue +74 -74
  56. package/components/elements/status-badge/AStatusBadge.vue +74 -74
  57. package/components/elements/table/ATable.vue +93 -93
  58. package/components/elements/table/table.config.ts +32 -32
  59. package/components/elements/tree-select/ATreeSelect.vue +169 -169
  60. package/components/elements/tree-select/TreeService.ts +249 -249
  61. package/components/elements/tree-select/components/tree-select-nodes.vue +90 -90
  62. package/components/elements/tree-select/types.ts +34 -34
  63. package/components/elements/tree-select-mobile/ATreeSelectMobile.vue +79 -79
  64. package/components/elements/tree-select-mobile/components/ATreeSelectNodesMobile.vue +175 -175
  65. package/components/features/color-mode/AColorMode.client.vue +53 -53
  66. package/components/features/dropdown/ADropdown.vue +124 -124
  67. package/components/features/go-top/GoTop.vue +58 -58
  68. package/components/features/lang-switcher/lang-switcher.vue +63 -63
  69. package/components/features/payment/banner/BasicPlusLimitBanner.vue +104 -104
  70. package/components/features/payment/banner/PaymentBanner.vue +108 -108
  71. package/components/features/payment/banner/UpSellBanner.vue +125 -125
  72. package/components/features/payment/process/PaymentKaspiQrSidePanel.vue +158 -158
  73. package/components/features/payment/process/PaymentKaspiRedirectSidePanel.vue +112 -112
  74. package/components/features/payment/process/PaymentMethodSidePanel.vue +121 -121
  75. package/components/features/payment/process/PaymentProcess.vue +138 -138
  76. package/components/features/payment/process/PaymentTopUpSidePanel.vue +130 -130
  77. package/components/features/pk-mobile-services/APkMobileServices.vue +149 -149
  78. package/components/features//321/201hange-version/AChangeVersion.vue +20 -20
  79. package/components/forms/README.md +1 -1
  80. package/components/forms/checkbox/ACheckbox.vue +149 -149
  81. package/components/forms/feedback-form/FeedbackForm.vue +177 -171
  82. package/components/forms/input/button/AInputButton.vue +53 -53
  83. package/components/forms/input/date/AInputDate.vue +213 -213
  84. package/components/forms/input/password/AInputPassword.vue +53 -53
  85. package/components/forms/input/standard/AInputStandard.vue +412 -412
  86. package/components/forms/input/textarea/ATextarea.vue +200 -200
  87. package/components/forms/radio-button/ARadioButton.vue +95 -95
  88. package/components/forms/request-demo/ARequestDemo.vue +108 -103
  89. package/components/forms/toggle/AToggle.vue +157 -157
  90. package/components/forms/toggle/types.ts +16 -16
  91. package/components/modals/AConfirmationEmail.vue +40 -40
  92. package/components/modals/AboutTariffModal.vue +114 -114
  93. package/components/modals/AnotherDeviceModal.vue +60 -60
  94. package/components/modals/ApplicationAcceptedModal.vue +47 -47
  95. package/components/modals/ConnectingTariffModal.vue +67 -67
  96. package/components/modals/ContactsMobileModel.vue +182 -182
  97. package/components/modals/ContentNavigationModal.vue +355 -355
  98. package/components/modals/Insufficient-funds-modal.vue +77 -77
  99. package/components/modals/LimitReachedModal.vue +30 -30
  100. package/components/modals/NoAccessModal.vue +37 -37
  101. package/components/modals/PaymentMethodModal.vue +101 -101
  102. package/components/modals/RedirectsBanksModal.vue +69 -69
  103. package/components/modals/ReplenishModal.vue +132 -132
  104. package/components/modals/ReportBugConfirmModal.vue +30 -30
  105. package/components/modals/ReportBugModal.vue +156 -156
  106. package/components/modals/Resend.vue +82 -82
  107. package/components/modals/SubmitApplicationModal.vue +123 -115
  108. package/components/modals/id/AuthModal.vue +82 -82
  109. package/components/modals/id/IdAutoLogoutModal.vue +45 -45
  110. package/components/modals/id/IdBanner.vue +61 -61
  111. package/components/modals/id/IdConfirmAccountOtpModal.vue +186 -186
  112. package/components/modals/id/IdConfirmSuccessfulModal.vue +41 -41
  113. package/components/modals/id/IdLoginModal.vue +326 -326
  114. package/components/modals/id/IdModals.vue +114 -114
  115. package/components/modals/id/IdNewPasswordModal.vue +129 -129
  116. package/components/modals/id/IdOtpInput.vue +155 -155
  117. package/components/modals/id/IdPasswordSuccessfulModal.vue +25 -25
  118. package/components/modals/id/IdRecoveryModal.vue +117 -117
  119. package/components/modals/id/IdRegistrationModal.vue +215 -215
  120. package/components/modals/id/IdResetPasswordOtpModal.vue +158 -158
  121. package/components/modals/id/IdTwoFactorModal.vue +130 -130
  122. package/components/navigation/README.md +1 -1
  123. package/components/navigation/bottom-navigation/ABottomNavigation.vue +106 -106
  124. package/components/navigation/breadcrumbs/ABreadcrumbs.vue +66 -66
  125. package/components/navigation/breadcrumbs/types.ts +4 -4
  126. package/components/navigation/footer/AFooter.vue +279 -279
  127. package/components/navigation/footer/ui/a-footer-accordion.vue +118 -118
  128. package/components/navigation/header/AHeader.vue +217 -217
  129. package/components/navigation/header/AlmatyContacts.vue +145 -145
  130. package/components/navigation/header/AstanaContacts.vue +67 -67
  131. package/components/navigation/header/CardGallery.vue +249 -249
  132. package/components/navigation/header/ContactMenu.vue +114 -114
  133. package/components/navigation/header/HeaderLink.vue +267 -267
  134. package/components/navigation/header/ListItem.vue +31 -31
  135. package/components/navigation/header/NavCard.vue +41 -41
  136. package/components/navigation/header/NavList.vue +131 -131
  137. package/components/navigation/header/NotificationsMenu.vue +51 -51
  138. package/components/navigation/header/ProductMenu.vue +143 -143
  139. package/components/navigation/header/ProfileMenu.vue +194 -194
  140. package/components/navigation/header/TopHeader.vue +194 -194
  141. package/components/navigation/header/types.ts +28 -28
  142. package/components/navigation/line-tabs/ALineTabs.vue +111 -111
  143. package/components/navigation/line-tabs/types.ts +21 -21
  144. package/components/navigation/mobile-navigation/AMobileNavigation.vue +104 -104
  145. package/components/navigation/pill-tabs/APillTabs.vue +171 -171
  146. package/components/navigation/pill-tabs/types.ts +23 -23
  147. package/components/navigation/side-navigation/ASideNavigation.vue +406 -406
  148. package/components/overlays/README.md +1 -1
  149. package/components/overlays/modal/AModal.vue +332 -332
  150. package/components/overlays/side-panel/ASidePanel.vue +439 -439
  151. package/components/overlays/sideover/ASlideover.vue +351 -351
  152. package/components/overlays/tooltip/ATooltip.vue +237 -237
  153. package/components/transitions/ATransitionHeight.vue +67 -67
  154. package/components/utils/index.ts +19 -19
  155. package/components/utils/removeTrailingSlash.ts +7 -7
  156. package/composables/highlight.ts +18 -18
  157. package/composables/modalsState.ts +8 -8
  158. package/composables/projectState.ts +2 -2
  159. package/composables/useAdaptive.ts +46 -46
  160. package/composables/useBuyTariffs.ts +91 -91
  161. package/composables/useCarouselScroll.ts +49 -49
  162. package/composables/useHeaderNavigationLinks.ts +453 -453
  163. package/composables/useIdModals.ts +36 -36
  164. package/composables/usePayment.ts +74 -74
  165. package/composables/useUIValidation.ts +16 -16
  166. package/composables/useUrls.ts +21 -21
  167. package/eslint.config.mjs +45 -45
  168. package/i18n/i18n.config.ts +21 -21
  169. package/i18n.config.ts +21 -21
  170. package/icons/adata-logo.vue +17 -17
  171. package/icons/ai-assistant.vue +13 -13
  172. package/icons/akimat.vue +20 -20
  173. package/icons/arrow/arrow-bottom-left-on-square.vue +5 -5
  174. package/icons/arrow/arrow-circle-down.vue +16 -16
  175. package/icons/arrow/arrow-circle-reset.vue +16 -16
  176. package/icons/arrow/arrow-corner.vue +9 -9
  177. package/icons/arrow/arrow-graph-down.vue +13 -13
  178. package/icons/arrow/arrow-graph-up.vue +14 -14
  179. package/icons/arrow/arrow-square-down.vue +15 -15
  180. package/icons/arrow/arrow-top-right-on-square.vue +6 -6
  181. package/icons/arrow-currency-gray.vue +5 -5
  182. package/icons/arrow-currency-green.vue +5 -5
  183. package/icons/arrow-currency-red.vue +5 -5
  184. package/icons/arrow-side-up.vue +6 -6
  185. package/icons/avatar.vue +12 -12
  186. package/icons/bank.vue +5 -5
  187. package/icons/block.vue +16 -16
  188. package/icons/bookmark/bookmark-filled.vue +18 -18
  189. package/icons/bookmark/bookmark.vue +5 -5
  190. package/icons/browsers/browser-duck.vue +65 -65
  191. package/icons/browsers/browser-google.vue +30 -30
  192. package/icons/browsers/browser-yandex.vue +13 -13
  193. package/icons/building-vector.vue +7 -7
  194. package/icons/calculator.vue +7 -7
  195. package/icons/calendar.vue +24 -24
  196. package/icons/car.vue +7 -7
  197. package/icons/chart-bar.vue +5 -5
  198. package/icons/chart-pie.vue +16 -16
  199. package/icons/check/check-circle.vue +6 -6
  200. package/icons/check/check-shield.vue +14 -14
  201. package/icons/check/check.vue +17 -17
  202. package/icons/check/checkmark-circle.vue +6 -6
  203. package/icons/check-sb.vue +7 -7
  204. package/icons/checkbox/checkbox-active.vue +17 -17
  205. package/icons/checkbox/checkbox-empty.vue +10 -10
  206. package/icons/checkbox/checkbox-intermediate.vue +7 -7
  207. package/icons/chevron/chevron-down.vue +5 -5
  208. package/icons/chevron/chevron-left.vue +5 -5
  209. package/icons/chevron/chevron-right.vue +5 -5
  210. package/icons/chevron/chevron-up.vue +5 -5
  211. package/icons/chevron/double-chevron-right.vue +12 -12
  212. package/icons/clipboard-text.vue +7 -7
  213. package/icons/clock.vue +25 -25
  214. package/icons/close.vue +16 -16
  215. package/icons/company/company-bazis.vue +21 -21
  216. package/icons/company/company-bereke.vue +25 -25
  217. package/icons/company/company-bigroup.vue +16 -16
  218. package/icons/company/company-erg.vue +17 -17
  219. package/icons/company/company-forte.vue +21 -21
  220. package/icons/company/company-halyk.vue +15 -15
  221. package/icons/company/company-jusan.vue +31 -31
  222. package/icons/company/company-kaspi.vue +14 -14
  223. package/icons/company/company-mycar.vue +13 -13
  224. package/icons/company/company-samruk.vue +21 -21
  225. package/icons/company-egov-small.vue +15 -15
  226. package/icons/company.vue +8 -8
  227. package/icons/copy.vue +7 -7
  228. package/icons/currency/currency-dollar.vue +16 -16
  229. package/icons/currency/currency-down.vue +22 -22
  230. package/icons/currency/currency-eur.vue +57 -57
  231. package/icons/currency/currency-rub.vue +7 -7
  232. package/icons/currency/currency-tenge.vue +9 -9
  233. package/icons/currency/currency-usd.vue +221 -221
  234. package/icons/currency/currency-yuan.vue +25 -25
  235. package/icons/default-avatar.vue +20 -20
  236. package/icons/delete.vue +7 -7
  237. package/icons/document.vue +5 -5
  238. package/icons/download.vue +11 -11
  239. package/icons/edit.vue +7 -7
  240. package/icons/education.vue +16 -16
  241. package/icons/egov-small.vue +7 -7
  242. package/icons/excel-icon.vue +14 -14
  243. package/icons/expand-window.vue +7 -7
  244. package/icons/eye-closed.vue +26 -26
  245. package/icons/eye-open.vue +7 -7
  246. package/icons/eye-opened.vue +23 -23
  247. package/icons/file/file.vue +16 -16
  248. package/icons/file/files.vue +16 -16
  249. package/icons/filter.vue +5 -5
  250. package/icons/flag.vue +7 -7
  251. package/icons/gift.vue +8 -8
  252. package/icons/globe.vue +16 -16
  253. package/icons/google.vue +41 -41
  254. package/icons/graph-pie.vue +14 -14
  255. package/icons/hand/hand-thumb-up-filled.vue +5 -5
  256. package/icons/hand/hand-thumb-up.vue +5 -5
  257. package/icons/hand-with-phone/hand-with-phone-dark.vue +52 -52
  258. package/icons/hand-with-phone/hand-with-phone-light.vue +52 -52
  259. package/icons/handshake.vue +5 -5
  260. package/icons/hcheck.vue +14 -14
  261. package/icons/hdocument.vue +7 -7
  262. package/icons/history.vue +5 -5
  263. package/icons/horizontal-more.vue +13 -13
  264. package/icons/hot-line.vue +6 -6
  265. package/icons/hummer.vue +16 -16
  266. package/icons/id.vue +7 -7
  267. package/icons/info/info-circle.vue +29 -29
  268. package/icons/invoice.vue +7 -7
  269. package/icons/judge.vue +14 -14
  270. package/icons/kaspi-qr.vue +13 -13
  271. package/icons/link-chain.vue +28 -28
  272. package/icons/link.vue +7 -7
  273. package/icons/linkedin.vue +24 -24
  274. package/icons/loader-circle.vue +27 -27
  275. package/icons/location.vue +8 -8
  276. package/icons/lock.vue +5 -5
  277. package/icons/logo.vue +15 -15
  278. package/icons/logout.vue +16 -16
  279. package/icons/magnify/magnifying-glass-minus.vue +8 -8
  280. package/icons/magnify/magnifying-glass-plus.vue +9 -9
  281. package/icons/magnify/magnifying-glass.vue +9 -9
  282. package/icons/mail.vue +7 -7
  283. package/icons/mailru.vue +34 -34
  284. package/icons/main-filter.vue +5 -5
  285. package/icons/map/map-pin-filled.vue +7 -7
  286. package/icons/map/map-pin-rect.vue +15 -15
  287. package/icons/map/map-pin.vue +7 -7
  288. package/icons/map-marker-start.vue +7 -7
  289. package/icons/map-paper.vue +5 -5
  290. package/icons/medal.vue +7 -7
  291. package/icons/menu-filled.vue +20 -20
  292. package/icons/menu.vue +8 -8
  293. package/icons/message/message.vue +12 -12
  294. package/icons/minus/minus-circle.vue +10 -10
  295. package/icons/money.vue +5 -5
  296. package/icons/monitoring.vue +10 -10
  297. package/icons/moon.vue +8 -8
  298. package/icons/more.vue +29 -29
  299. package/icons/note-pencil.vue +14 -14
  300. package/icons/note.vue +14 -14
  301. package/icons/notification.vue +16 -16
  302. package/icons/paperclip.vue +7 -7
  303. package/icons/payment/payment-card.vue +6 -6
  304. package/icons/payment/payment-kaspi.vue +11 -11
  305. package/icons/person-vector.vue +7 -7
  306. package/icons/person-with-briefcase.vue +10 -10
  307. package/icons/phone-filled.vue +5 -5
  308. package/icons/phone.vue +7 -7
  309. package/icons/plus/plus-circle.vue +8 -8
  310. package/icons/plus/plus.vue +13 -13
  311. package/icons/profile.vue +5 -5
  312. package/icons/radio/radio-check.vue +8 -8
  313. package/icons/radio/radio-empty.vue +10 -10
  314. package/icons/receipt.vue +8 -8
  315. package/icons/robot.vue +14 -14
  316. package/icons/sanctions.vue +8 -8
  317. package/icons/scales/scale.vue +16 -16
  318. package/icons/scales/scales.vue +5 -5
  319. package/icons/scales/standing-scales.vue +15 -15
  320. package/icons/search.vue +27 -27
  321. package/icons/share/share-alt.vue +5 -5
  322. package/icons/share/share.vue +14 -14
  323. package/icons/ship.vue +8 -8
  324. package/icons/socials/face-book.vue +15 -15
  325. package/icons/socials/instagram.vue +19 -19
  326. package/icons/socials/telegram.vue +15 -15
  327. package/icons/socials/tik-tok.vue +15 -15
  328. package/icons/socials/youtube.vue +16 -16
  329. package/icons/sort/sort-asc.vue +15 -15
  330. package/icons/sort/sort-desc.vue +15 -15
  331. package/icons/splitting-arrows.vue +8 -8
  332. package/icons/star/star-filled.vue +40 -40
  333. package/icons/star/star-half-filled.vue +20 -20
  334. package/icons/star/star.vue +25 -25
  335. package/icons/sun.vue +14 -14
  336. package/icons/sviazi.vue +5 -5
  337. package/icons/tag.vue +30 -30
  338. package/icons/tasks.vue +10 -10
  339. package/icons/tender-search.vue +11 -11
  340. package/icons/toasts/check-circle-toast.vue +6 -6
  341. package/icons/toasts/warning-triangle-toast.vue +7 -7
  342. package/icons/trash.vue +13 -13
  343. package/icons/triangle.vue +10 -10
  344. package/icons/truck.vue +7 -7
  345. package/icons/user-square.vue +14 -14
  346. package/icons/user.vue +22 -22
  347. package/icons/users-focus.vue +8 -8
  348. package/icons/users-three.vue +7 -7
  349. package/icons/users.vue +8 -8
  350. package/icons/warning/warning-circle.vue +29 -29
  351. package/icons/warning/warning-triangle-filled.vue +12 -12
  352. package/icons/warning/warning-triangle.vue +28 -28
  353. package/icons/whatsapp.vue +8 -8
  354. package/icons/work-bag.vue +11 -11
  355. package/icons/work-case.vue +9 -9
  356. package/icons/work-search.vue +10 -10
  357. package/icons/work.vue +5 -5
  358. package/icons/x-mark.vue +15 -15
  359. package/icons/yandex.vue +28 -28
  360. package/illustrations/address-location.vue +38 -38
  361. package/illustrations/ball-with-chain.vue +120 -120
  362. package/illustrations/bill.vue +133 -133
  363. package/illustrations/buildings.vue +82 -82
  364. package/illustrations/calendar.vue +156 -156
  365. package/illustrations/chains.vue +152 -152
  366. package/illustrations/coin-percent.vue +126 -126
  367. package/illustrations/coins-stack.vue +202 -202
  368. package/illustrations/delete-dark.vue +31 -31
  369. package/illustrations/delete.vue +32 -32
  370. package/illustrations/doc-with-stamp.vue +126 -126
  371. package/illustrations/document.vue +64 -64
  372. package/illustrations/door.vue +74 -74
  373. package/illustrations/empty-box.vue +77 -77
  374. package/illustrations/empty-wallet.vue +161 -161
  375. package/illustrations/graph-in-coin.vue +119 -119
  376. package/illustrations/hammer.vue +156 -156
  377. package/illustrations/hand-cash.vue +108 -108
  378. package/illustrations/info.vue +39 -39
  379. package/illustrations/mail.vue +68 -68
  380. package/illustrations/ok.vue +62 -62
  381. package/illustrations/people-group.vue +237 -237
  382. package/illustrations/person-with-phone.vue +187 -187
  383. package/illustrations/person.vue +159 -159
  384. package/illustrations/phone-check.vue +90 -90
  385. package/illustrations/phone-payment-method.vue +223 -223
  386. package/illustrations/stop-hand.vue +77 -77
  387. package/illustrations/stop-sign.vue +34 -34
  388. package/illustrations/suit.vue +111 -111
  389. package/illustrations/suitcase.vue +105 -105
  390. package/illustrations/terminal-dark.vue +48 -48
  391. package/illustrations/terminal.vue +234 -234
  392. package/illustrations/trash-can.vue +108 -108
  393. package/illustrations/turn-on-tariff.vue +38 -38
  394. package/illustrations/two-persons.vue +169 -169
  395. package/lang/en.ts +834 -834
  396. package/lang/kk.ts +836 -836
  397. package/lang/ru.ts +837 -837
  398. package/layouts/default.vue +13 -13
  399. package/nuxt.config.ts +88 -88
  400. package/package.json +69 -69
  401. package/plugins/maska.ts +4 -4
  402. package/plugins/toast.client.ts +58 -58
  403. package/public/kaspi/logo.svg +4 -4
  404. package/shared/constans/pages.ts +89 -89
  405. package/tailwind.config.ts +163 -163
  406. package/tests/AButton.test.ts +81 -81
  407. package/tsconfig.json +6 -6
  408. package/utils/getMaxZindex.ts +25 -25
  409. package/utils/localizedNavigation.ts +36 -36
  410. package/vitest.config.ts +14 -14
@@ -1,237 +1,237 @@
1
- <script setup lang="ts">
2
- import { ref, computed, nextTick, onMounted, onBeforeUnmount, watch } from 'vue'
3
-
4
- interface Props {
5
- text?: string
6
- header?: string
7
- openDelay?: number
8
- closeDelay?: number
9
- prevent?: boolean
10
- placement?: 'top' | 'bottom' | 'left' | 'right'
11
- popper?: boolean
12
- popperPosition?: 'start' | 'center' | 'end'
13
- size?: 'sm' | 'md'
14
- zIndex?: number
15
- truncate?: boolean
16
- errorParsing?: boolean
17
- parent?: HTMLElement
18
- }
19
-
20
- const props = withDefaults(defineProps<Props>(), {
21
- text: '',
22
- header: '',
23
- openDelay: 0,
24
- closeDelay: 0,
25
- prevent: false,
26
- placement: 'top',
27
- popper: true,
28
- popperPosition: 'start',
29
- size: 'md',
30
- truncate: true,
31
- errorParsing: false
32
- })
33
-
34
- /* --- refs --- */
35
- const wrapper = ref<HTMLElement | null>(null) // root wrapper
36
- const body = ref<HTMLElement | null>(null) // tooltip element
37
- const open = ref(false)
38
- let openTimeout: ReturnType<typeof setTimeout> | null = null
39
- let closeTimeout: ReturnType<typeof setTimeout> | null = null
40
-
41
- // inline styles for tooltip positioning
42
- const tooltipStyle = ref<Record<string, string>>({
43
- left: '0px',
44
- top: '0px',
45
- transform: 'translateX(0) translateY(0)'
46
- })
47
-
48
- // visual placement (may be flipped if not enough space)
49
- const visualPlacement = ref(props.placement)
50
- const popperPosition = ref(props.popperPosition)
51
-
52
- /* --- helpers: compute classes (you can keep your uiConfig) --- */
53
- const baseClass = computed(() => {
54
- // keep your Tailwind classes if you like, but we position via inline styles
55
- const bg = props.errorParsing ? 'bg-[#FAD9D7] dark:bg-[#4F393A]' : 'bg-deepblue-900 dark:bg-gray-50'
56
- const color = props.errorParsing ? 'text-[#E74135] dark:text-[#F47E75]' : 'text-white dark:text-deepblue-900'
57
- const pad = props.size === 'sm' ? 'px-4 py-2' : 'px-4 py-4'
58
- const truncated = props.truncate ? 'truncate' : 'max-w-[530px] w-max'
59
- return ['text-xs font-normal absolute', bg, color, 'rounded-md', pad, truncated].join(' ')
60
- })
61
-
62
- /* --- positioning logic --- */
63
- function updatePosition(targetEl: HTMLElement | null) {
64
- if (!targetEl || !body.value) return
65
-
66
- const targetRect = targetEl.getBoundingClientRect()
67
- const tooltipRect = body.value.getBoundingClientRect()
68
- const vw = window.innerWidth
69
- const vh = window.innerHeight
70
-
71
- // default placement = requested prop
72
- let place: Props['placement'] = props.placement
73
-
74
- // decide flip if not enough space
75
- if (place === 'top' && targetRect.top < tooltipRect.height + 8 && (vh - targetRect.bottom) >= tooltipRect.height + 8) {
76
- place = 'bottom'
77
- } else if (place === 'bottom' && (vh - targetRect.bottom) < tooltipRect.height + 8 && targetRect.top >= tooltipRect.height + 8) {
78
- place = 'top'
79
- } else if (place === 'left' && targetRect.left < tooltipRect.width + 8 && (vw - targetRect.right) >= tooltipRect.width + 8) {
80
- place = 'right'
81
- } else if (place === 'right' && (vw - targetRect.right) < tooltipRect.width + 8 && targetRect.left >= tooltipRect.width + 8) {
82
- place = 'left'
83
- }
84
-
85
- visualPlacement.value = place
86
-
87
- // compute left/top depending on placement and prefer 'start' unless end/center chosen by popperPosition
88
- let left = 0
89
- let top = 0
90
-
91
- if (place === 'top' || place === 'bottom') {
92
- // horizontal alignment depends on popperPosition
93
- if (popperPosition.value === 'center') {
94
- left = targetRect.left + targetRect.width / 2 - tooltipRect.width / 2
95
- } else if (popperPosition.value === 'end') {
96
- left = targetRect.right - tooltipRect.width
97
- } else {
98
- // start
99
- left = targetRect.left
100
- }
101
-
102
- // vertical
103
- if (place === 'top') {
104
- top = targetRect.top - tooltipRect.height - 8
105
- } else {
106
- top = targetRect.bottom + 8
107
- }
108
- } else {
109
- // left or right: vertical alignment
110
- if (popperPosition.value === 'center') {
111
- top = targetRect.top + targetRect.height / 2 - tooltipRect.height / 2
112
- } else if (popperPosition.value === 'end') {
113
- top = targetRect.bottom - tooltipRect.height
114
- } else {
115
- top = targetRect.top
116
- }
117
-
118
- if (place === 'left') {
119
- left = targetRect.left - tooltipRect.width - 8
120
- } else {
121
- left = targetRect.right + 8
122
- }
123
- }
124
-
125
- // keep tooltip inside the viewport (small clamp)
126
- const minGap = 6
127
- if (left < minGap) left = minGap
128
- if (left + tooltipRect.width > vw - minGap) left = vw - tooltipRect.width - minGap
129
- if (top < minGap) top = minGap
130
- if (top + tooltipRect.height > vh - minGap) top = vh - tooltipRect.height - minGap
131
-
132
- tooltipStyle.value.left = `${Math.round(left)}px`
133
- tooltipStyle.value.top = `${Math.round(top)}px`
134
- tooltipStyle.value.transform = 'none'
135
- }
136
-
137
- /* --- events --- */
138
- function handleMouseEnter(e: MouseEvent) {
139
- // clear close timeout
140
- if (closeTimeout) {
141
- clearTimeout(closeTimeout)
142
- closeTimeout = null
143
- }
144
-
145
- const targetEl = (e.currentTarget ?? e.target) as HTMLElement
146
-
147
- // schedule open
148
- openTimeout = openTimeout || setTimeout(async () => {
149
- open.value = true
150
- await nextTick()
151
- // measure and position after tooltip is rendered
152
- updatePosition(targetEl)
153
- openTimeout = null
154
- }, props.openDelay)
155
- }
156
-
157
- function handleMouseLeave(e?: MouseEvent) {
158
- if (openTimeout) {
159
- clearTimeout(openTimeout)
160
- openTimeout = null
161
- }
162
- if (!open.value) return
163
-
164
- closeTimeout = closeTimeout || setTimeout(() => {
165
- open.value = false
166
- closeTimeout = null
167
- }, props.closeDelay)
168
- }
169
-
170
- // if tooltip is open and user scrolls/resizes, recalc
171
- function onWindowChange() {
172
- // try to recalc against the wrapper's slot element if present
173
- // we assume wrapper contains the hovered child
174
- const hovered = wrapper.value?.querySelector(':hover') as HTMLElement | null
175
- const target = hovered ?? wrapper.value
176
- updatePosition(target)
177
- }
178
-
179
- onMounted(() => {
180
- window.addEventListener('resize', onWindowChange)
181
- window.addEventListener('scroll', onWindowChange, true)
182
- })
183
-
184
- onBeforeUnmount(() => {
185
- window.removeEventListener('resize', onWindowChange)
186
- window.removeEventListener('scroll', onWindowChange, true)
187
- })
188
-
189
- </script>
190
-
191
- <template>
192
- <div
193
- ref="wrapper"
194
- v-bind="$attrs"
195
- class="relative"
196
- @mouseenter="handleMouseEnter"
197
- @mouseleave="handleMouseLeave"
198
- >
199
- <slot :open="open">
200
- Hover
201
- </slot>
202
-
203
- <!-- tooltip rendered absolutely on body of component, positioned by inline styles -->
204
- <transition name="fade" appear>
205
- <div
206
- v-if="open && !props.prevent"
207
- class="pointer-events-none"
208
- :style="{ position: 'fixed', left: tooltipStyle.left, top: tooltipStyle.top, zIndex: props.zIndex ?? 9999 }"
209
- >
210
- <div ref="body" :class="baseClass">
211
- <div v-if="$slots.header || props.header" class="font-semibold mb-1">
212
- <slot name="header">
213
- <p>{{ props.header }}</p>
214
- </slot>
215
- </div>
216
-
217
- <slot name="content">
218
- {{ props.text }}
219
- </slot>
220
- </div>
221
- </div>
222
- </transition>
223
- </div>
224
- </template>
225
-
226
- <style scoped>
227
- /* simple fade (you can adapt to your transition) */
228
- .fade-enter-active, .fade-leave-active {
229
- transition: opacity .18s ease;
230
- }
231
- .fade-enter-from, .fade-leave-to {
232
- opacity: 0;
233
- }
234
- .fade-enter-to, .fade-leave-from {
235
- opacity: 1;
236
- }
237
- </style>
1
+ <script setup lang="ts">
2
+ import { ref, computed, nextTick, onMounted, onBeforeUnmount, watch } from 'vue'
3
+
4
+ interface Props {
5
+ text?: string
6
+ header?: string
7
+ openDelay?: number
8
+ closeDelay?: number
9
+ prevent?: boolean
10
+ placement?: 'top' | 'bottom' | 'left' | 'right'
11
+ popper?: boolean
12
+ popperPosition?: 'start' | 'center' | 'end'
13
+ size?: 'sm' | 'md'
14
+ zIndex?: number
15
+ truncate?: boolean
16
+ errorParsing?: boolean
17
+ parent?: HTMLElement
18
+ }
19
+
20
+ const props = withDefaults(defineProps<Props>(), {
21
+ text: '',
22
+ header: '',
23
+ openDelay: 0,
24
+ closeDelay: 0,
25
+ prevent: false,
26
+ placement: 'top',
27
+ popper: true,
28
+ popperPosition: 'start',
29
+ size: 'md',
30
+ truncate: true,
31
+ errorParsing: false
32
+ })
33
+
34
+ /* --- refs --- */
35
+ const wrapper = ref<HTMLElement | null>(null) // root wrapper
36
+ const body = ref<HTMLElement | null>(null) // tooltip element
37
+ const open = ref(false)
38
+ let openTimeout: ReturnType<typeof setTimeout> | null = null
39
+ let closeTimeout: ReturnType<typeof setTimeout> | null = null
40
+
41
+ // inline styles for tooltip positioning
42
+ const tooltipStyle = ref<Record<string, string>>({
43
+ left: '0px',
44
+ top: '0px',
45
+ transform: 'translateX(0) translateY(0)'
46
+ })
47
+
48
+ // visual placement (may be flipped if not enough space)
49
+ const visualPlacement = ref(props.placement)
50
+ const popperPosition = ref(props.popperPosition)
51
+
52
+ /* --- helpers: compute classes (you can keep your uiConfig) --- */
53
+ const baseClass = computed(() => {
54
+ // keep your Tailwind classes if you like, but we position via inline styles
55
+ const bg = props.errorParsing ? 'bg-[#FAD9D7] dark:bg-[#4F393A]' : 'bg-deepblue-900 dark:bg-gray-50'
56
+ const color = props.errorParsing ? 'text-[#E74135] dark:text-[#F47E75]' : 'text-white dark:text-deepblue-900'
57
+ const pad = props.size === 'sm' ? 'px-4 py-2' : 'px-4 py-4'
58
+ const truncated = props.truncate ? 'truncate' : 'max-w-[530px] w-max'
59
+ return ['text-xs font-normal absolute', bg, color, 'rounded-md', pad, truncated].join(' ')
60
+ })
61
+
62
+ /* --- positioning logic --- */
63
+ function updatePosition(targetEl: HTMLElement | null) {
64
+ if (!targetEl || !body.value) return
65
+
66
+ const targetRect = targetEl.getBoundingClientRect()
67
+ const tooltipRect = body.value.getBoundingClientRect()
68
+ const vw = window.innerWidth
69
+ const vh = window.innerHeight
70
+
71
+ // default placement = requested prop
72
+ let place: Props['placement'] = props.placement
73
+
74
+ // decide flip if not enough space
75
+ if (place === 'top' && targetRect.top < tooltipRect.height + 8 && (vh - targetRect.bottom) >= tooltipRect.height + 8) {
76
+ place = 'bottom'
77
+ } else if (place === 'bottom' && (vh - targetRect.bottom) < tooltipRect.height + 8 && targetRect.top >= tooltipRect.height + 8) {
78
+ place = 'top'
79
+ } else if (place === 'left' && targetRect.left < tooltipRect.width + 8 && (vw - targetRect.right) >= tooltipRect.width + 8) {
80
+ place = 'right'
81
+ } else if (place === 'right' && (vw - targetRect.right) < tooltipRect.width + 8 && targetRect.left >= tooltipRect.width + 8) {
82
+ place = 'left'
83
+ }
84
+
85
+ visualPlacement.value = place
86
+
87
+ // compute left/top depending on placement and prefer 'start' unless end/center chosen by popperPosition
88
+ let left = 0
89
+ let top = 0
90
+
91
+ if (place === 'top' || place === 'bottom') {
92
+ // horizontal alignment depends on popperPosition
93
+ if (popperPosition.value === 'center') {
94
+ left = targetRect.left + targetRect.width / 2 - tooltipRect.width / 2
95
+ } else if (popperPosition.value === 'end') {
96
+ left = targetRect.right - tooltipRect.width
97
+ } else {
98
+ // start
99
+ left = targetRect.left
100
+ }
101
+
102
+ // vertical
103
+ if (place === 'top') {
104
+ top = targetRect.top - tooltipRect.height - 8
105
+ } else {
106
+ top = targetRect.bottom + 8
107
+ }
108
+ } else {
109
+ // left or right: vertical alignment
110
+ if (popperPosition.value === 'center') {
111
+ top = targetRect.top + targetRect.height / 2 - tooltipRect.height / 2
112
+ } else if (popperPosition.value === 'end') {
113
+ top = targetRect.bottom - tooltipRect.height
114
+ } else {
115
+ top = targetRect.top
116
+ }
117
+
118
+ if (place === 'left') {
119
+ left = targetRect.left - tooltipRect.width - 8
120
+ } else {
121
+ left = targetRect.right + 8
122
+ }
123
+ }
124
+
125
+ // keep tooltip inside the viewport (small clamp)
126
+ const minGap = 6
127
+ if (left < minGap) left = minGap
128
+ if (left + tooltipRect.width > vw - minGap) left = vw - tooltipRect.width - minGap
129
+ if (top < minGap) top = minGap
130
+ if (top + tooltipRect.height > vh - minGap) top = vh - tooltipRect.height - minGap
131
+
132
+ tooltipStyle.value.left = `${Math.round(left)}px`
133
+ tooltipStyle.value.top = `${Math.round(top)}px`
134
+ tooltipStyle.value.transform = 'none'
135
+ }
136
+
137
+ /* --- events --- */
138
+ function handleMouseEnter(e: MouseEvent) {
139
+ // clear close timeout
140
+ if (closeTimeout) {
141
+ clearTimeout(closeTimeout)
142
+ closeTimeout = null
143
+ }
144
+
145
+ const targetEl = (e.currentTarget ?? e.target) as HTMLElement
146
+
147
+ // schedule open
148
+ openTimeout = openTimeout || setTimeout(async () => {
149
+ open.value = true
150
+ await nextTick()
151
+ // measure and position after tooltip is rendered
152
+ updatePosition(targetEl)
153
+ openTimeout = null
154
+ }, props.openDelay)
155
+ }
156
+
157
+ function handleMouseLeave(e?: MouseEvent) {
158
+ if (openTimeout) {
159
+ clearTimeout(openTimeout)
160
+ openTimeout = null
161
+ }
162
+ if (!open.value) return
163
+
164
+ closeTimeout = closeTimeout || setTimeout(() => {
165
+ open.value = false
166
+ closeTimeout = null
167
+ }, props.closeDelay)
168
+ }
169
+
170
+ // if tooltip is open and user scrolls/resizes, recalc
171
+ function onWindowChange() {
172
+ // try to recalc against the wrapper's slot element if present
173
+ // we assume wrapper contains the hovered child
174
+ const hovered = wrapper.value?.querySelector(':hover') as HTMLElement | null
175
+ const target = hovered ?? wrapper.value
176
+ updatePosition(target)
177
+ }
178
+
179
+ onMounted(() => {
180
+ window.addEventListener('resize', onWindowChange)
181
+ window.addEventListener('scroll', onWindowChange, true)
182
+ })
183
+
184
+ onBeforeUnmount(() => {
185
+ window.removeEventListener('resize', onWindowChange)
186
+ window.removeEventListener('scroll', onWindowChange, true)
187
+ })
188
+
189
+ </script>
190
+
191
+ <template>
192
+ <div
193
+ ref="wrapper"
194
+ v-bind="$attrs"
195
+ class="relative"
196
+ @mouseenter="handleMouseEnter"
197
+ @mouseleave="handleMouseLeave"
198
+ >
199
+ <slot :open="open">
200
+ Hover
201
+ </slot>
202
+
203
+ <!-- tooltip rendered absolutely on body of component, positioned by inline styles -->
204
+ <transition name="fade" appear>
205
+ <div
206
+ v-if="open && !props.prevent"
207
+ class="pointer-events-none"
208
+ :style="{ position: 'fixed', left: tooltipStyle.left, top: tooltipStyle.top, zIndex: props.zIndex ?? 9999 }"
209
+ >
210
+ <div ref="body" :class="baseClass">
211
+ <div v-if="$slots.header || props.header" class="font-semibold mb-1">
212
+ <slot name="header">
213
+ <p>{{ props.header }}</p>
214
+ </slot>
215
+ </div>
216
+
217
+ <slot name="content">
218
+ {{ props.text }}
219
+ </slot>
220
+ </div>
221
+ </div>
222
+ </transition>
223
+ </div>
224
+ </template>
225
+
226
+ <style scoped>
227
+ /* simple fade (you can adapt to your transition) */
228
+ .fade-enter-active, .fade-leave-active {
229
+ transition: opacity .18s ease;
230
+ }
231
+ .fade-enter-from, .fade-leave-to {
232
+ opacity: 0;
233
+ }
234
+ .fade-enter-to, .fade-leave-from {
235
+ opacity: 1;
236
+ }
237
+ </style>
@@ -1,67 +1,67 @@
1
- <script setup lang="ts">
2
- import ui from "#adata-ui/components/elements/accordion/AAccordionGroup/ui.config";
3
- import { twMerge } from 'tailwind-merge'
4
-
5
- const props = defineProps<{
6
- transition?: {
7
- enterActiveClass?: string
8
- leaveActiveClass?: string
9
- }
10
- }>()
11
-
12
- const mergedUi = computed(() => ({
13
- transition: {
14
- enterActiveClass: twMerge(
15
- ui.transition.enterActiveClass,
16
- props.transition?.enterActiveClass
17
- ),
18
- leaveActiveClass: twMerge(
19
- ui.transition.leaveActiveClass,
20
- props.transition?.leaveActiveClass
21
- )
22
- }
23
- }))
24
-
25
- function onEnter(_el: Element, done: () => void) {
26
- const el = _el as HTMLElement
27
- el.style.height = '0'
28
- el.offsetHeight // Trigger a reflow, flushing the CSS changes
29
- el.style.height = el.scrollHeight + 'px'
30
-
31
- el.addEventListener('transitionend', done, {once: true})
32
- }
33
-
34
- function onBeforeLeave(_el: Element) {
35
- const el = _el as HTMLElement
36
- el.style.height = el.scrollHeight + 'px'
37
- el.offsetHeight // Trigger a reflow, flushing the CSS changes
38
- }
39
-
40
- function onAfterEnter(_el: Element) {
41
- const el = _el as HTMLElement
42
- el.style.height = 'auto'
43
- }
44
-
45
- function onLeave(_el: Element, done: () => void) {
46
- const el = _el as HTMLElement
47
- el.style.height = '0'
48
-
49
- el.addEventListener('transitionend', done, {once: true})
50
- }
51
- </script>
52
-
53
- <template>
54
- <Transition
55
- v-bind="mergedUi.transition"
56
- @enter="onEnter"
57
- @after-enter="onAfterEnter"
58
- @before-leave="onBeforeLeave"
59
- @leave="onLeave"
60
- >
61
- <slot/>
62
- </Transition>
63
- </template>
64
-
65
- <style scoped>
66
-
67
- </style>
1
+ <script setup lang="ts">
2
+ import ui from "#adata-ui/components/elements/accordion/AAccordionGroup/ui.config";
3
+ import { twMerge } from 'tailwind-merge'
4
+
5
+ const props = defineProps<{
6
+ transition?: {
7
+ enterActiveClass?: string
8
+ leaveActiveClass?: string
9
+ }
10
+ }>()
11
+
12
+ const mergedUi = computed(() => ({
13
+ transition: {
14
+ enterActiveClass: twMerge(
15
+ ui.transition.enterActiveClass,
16
+ props.transition?.enterActiveClass
17
+ ),
18
+ leaveActiveClass: twMerge(
19
+ ui.transition.leaveActiveClass,
20
+ props.transition?.leaveActiveClass
21
+ )
22
+ }
23
+ }))
24
+
25
+ function onEnter(_el: Element, done: () => void) {
26
+ const el = _el as HTMLElement
27
+ el.style.height = '0'
28
+ el.offsetHeight // Trigger a reflow, flushing the CSS changes
29
+ el.style.height = el.scrollHeight + 'px'
30
+
31
+ el.addEventListener('transitionend', done, {once: true})
32
+ }
33
+
34
+ function onBeforeLeave(_el: Element) {
35
+ const el = _el as HTMLElement
36
+ el.style.height = el.scrollHeight + 'px'
37
+ el.offsetHeight // Trigger a reflow, flushing the CSS changes
38
+ }
39
+
40
+ function onAfterEnter(_el: Element) {
41
+ const el = _el as HTMLElement
42
+ el.style.height = 'auto'
43
+ }
44
+
45
+ function onLeave(_el: Element, done: () => void) {
46
+ const el = _el as HTMLElement
47
+ el.style.height = '0'
48
+
49
+ el.addEventListener('transitionend', done, {once: true})
50
+ }
51
+ </script>
52
+
53
+ <template>
54
+ <Transition
55
+ v-bind="mergedUi.transition"
56
+ @enter="onEnter"
57
+ @after-enter="onAfterEnter"
58
+ @before-leave="onBeforeLeave"
59
+ @leave="onLeave"
60
+ >
61
+ <slot/>
62
+ </Transition>
63
+ </template>
64
+
65
+ <style scoped>
66
+
67
+ </style>
@@ -1,19 +1,19 @@
1
- export function mergeConfig<T>(defaultUi: T, config: Partial<T>): T {
2
- const mergedUi = {...defaultUi};
3
-
4
- for (const key in config) {
5
- if (Object.prototype.hasOwnProperty.call(config, key)) {
6
- const defaultValue = defaultUi[key];
7
- const configValue = config[key];
8
- if (typeof defaultValue === 'object' && typeof configValue === 'object' && defaultValue !== null && configValue !== null) {
9
- mergedUi[key] = mergeConfig(defaultValue, configValue);
10
- } else if (typeof configValue === 'string') {
11
- mergedUi[key] = `${defaultValue} ${configValue}`;
12
- } else {
13
- mergedUi[key] = configValue;
14
- }
15
- }
16
- }
17
-
18
- return mergedUi as T;
19
- }
1
+ export function mergeConfig<T>(defaultUi: T, config: Partial<T>): T {
2
+ const mergedUi = {...defaultUi};
3
+
4
+ for (const key in config) {
5
+ if (Object.prototype.hasOwnProperty.call(config, key)) {
6
+ const defaultValue = defaultUi[key];
7
+ const configValue = config[key];
8
+ if (typeof defaultValue === 'object' && typeof configValue === 'object' && defaultValue !== null && configValue !== null) {
9
+ mergedUi[key] = mergeConfig(defaultValue, configValue);
10
+ } else if (typeof configValue === 'string') {
11
+ mergedUi[key] = `${defaultValue} ${configValue}`;
12
+ } else {
13
+ mergedUi[key] = configValue;
14
+ }
15
+ }
16
+ }
17
+
18
+ return mergedUi as T;
19
+ }
@@ -1,7 +1,7 @@
1
- export function removeTrailingSlash(str: string): string {
2
- if (str.endsWith('/')) {
3
- return str.slice(0, -1)
4
- }
5
-
6
- return str
7
- }
1
+ export function removeTrailingSlash(str: string): string {
2
+ if (str.endsWith('/')) {
3
+ return str.slice(0, -1)
4
+ }
5
+
6
+ return str
7
+ }