adata-ui 2.1.23 → 2.1.25

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 (413) 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 +161 -161
  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 +133 -133
  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 -177
  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 -108
  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 +158 -158
  106. package/components/modals/Resend.vue +82 -82
  107. package/components/modals/SubmitApplicationModal.vue +123 -123
  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 +330 -330
  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 +275 -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/gradiend-icons/files-gradient.vue +22 -0
  255. package/icons/gradiend-icons/hammer-gradient.vue +62 -0
  256. package/icons/graph-pie.vue +14 -14
  257. package/icons/hand/hand-thumb-up-filled.vue +5 -5
  258. package/icons/hand/hand-thumb-up.vue +5 -5
  259. package/icons/hand-with-phone/hand-with-phone-dark.vue +52 -52
  260. package/icons/hand-with-phone/hand-with-phone-light.vue +52 -52
  261. package/icons/handshake.vue +5 -5
  262. package/icons/hcheck.vue +14 -14
  263. package/icons/hdocument.vue +7 -7
  264. package/icons/history.vue +5 -5
  265. package/icons/horizontal-more.vue +13 -13
  266. package/icons/hot-line.vue +6 -6
  267. package/icons/hummer.vue +16 -16
  268. package/icons/id.vue +7 -7
  269. package/icons/info/info-circle.vue +29 -29
  270. package/icons/invoice.vue +7 -7
  271. package/icons/judge.vue +14 -14
  272. package/icons/kaspi-qr.vue +13 -13
  273. package/icons/link-chain.vue +28 -28
  274. package/icons/link.vue +7 -7
  275. package/icons/linkedin.vue +24 -24
  276. package/icons/loader-circle.vue +27 -27
  277. package/icons/location.vue +8 -8
  278. package/icons/lock.vue +5 -5
  279. package/icons/logo.vue +15 -15
  280. package/icons/logout.vue +16 -16
  281. package/icons/magnify/magnifying-glass-minus.vue +8 -8
  282. package/icons/magnify/magnifying-glass-plus.vue +9 -9
  283. package/icons/magnify/magnifying-glass.vue +9 -9
  284. package/icons/mail.vue +7 -7
  285. package/icons/mailru.vue +34 -34
  286. package/icons/main-filter.vue +5 -5
  287. package/icons/map/map-pin-filled.vue +7 -7
  288. package/icons/map/map-pin-rect.vue +15 -15
  289. package/icons/map/map-pin.vue +7 -7
  290. package/icons/map-marker-start.vue +7 -7
  291. package/icons/map-paper.vue +5 -5
  292. package/icons/medal.vue +7 -7
  293. package/icons/menu-filled.vue +20 -20
  294. package/icons/menu.vue +8 -8
  295. package/icons/message/message.vue +12 -12
  296. package/icons/minus/minus-circle.vue +10 -10
  297. package/icons/money.vue +5 -5
  298. package/icons/monitoring.vue +10 -10
  299. package/icons/moon.vue +8 -8
  300. package/icons/more.vue +29 -29
  301. package/icons/note-pencil.vue +14 -14
  302. package/icons/note.vue +14 -14
  303. package/icons/notification.vue +16 -16
  304. package/icons/paperclip.vue +7 -7
  305. package/icons/payment/payment-card.vue +6 -6
  306. package/icons/payment/payment-kaspi.vue +11 -11
  307. package/icons/person-vector.vue +7 -7
  308. package/icons/person-with-briefcase.vue +10 -10
  309. package/icons/phone-filled.vue +5 -5
  310. package/icons/phone.vue +7 -7
  311. package/icons/plus/plus-circle.vue +8 -8
  312. package/icons/plus/plus.vue +13 -13
  313. package/icons/profile.vue +5 -5
  314. package/icons/radio/radio-check.vue +8 -8
  315. package/icons/radio/radio-empty.vue +10 -10
  316. package/icons/receipt.vue +8 -8
  317. package/icons/robot.vue +14 -14
  318. package/icons/sanctions.vue +8 -8
  319. package/icons/scales/scale.vue +16 -16
  320. package/icons/scales/scales.vue +5 -5
  321. package/icons/scales/standing-scales.vue +15 -15
  322. package/icons/search.vue +27 -27
  323. package/icons/share/share-alt.vue +5 -5
  324. package/icons/share/share.vue +14 -14
  325. package/icons/ship.vue +8 -8
  326. package/icons/socials/face-book.vue +15 -15
  327. package/icons/socials/instagram.vue +19 -19
  328. package/icons/socials/telegram.vue +15 -15
  329. package/icons/socials/tik-tok.vue +15 -15
  330. package/icons/socials/youtube.vue +16 -16
  331. package/icons/sort/sort-asc.vue +15 -15
  332. package/icons/sort/sort-desc.vue +15 -15
  333. package/icons/splitting-arrows.vue +8 -8
  334. package/icons/star/star-filled.vue +40 -40
  335. package/icons/star/star-half-filled.vue +20 -20
  336. package/icons/star/star.vue +25 -25
  337. package/icons/sun.vue +14 -14
  338. package/icons/sviazi.vue +5 -5
  339. package/icons/tag.vue +30 -30
  340. package/icons/tasks.vue +10 -10
  341. package/icons/tender-search.vue +11 -11
  342. package/icons/toasts/check-circle-toast.vue +6 -6
  343. package/icons/toasts/warning-triangle-toast.vue +7 -7
  344. package/icons/trash.vue +13 -13
  345. package/icons/triangle.vue +10 -10
  346. package/icons/truck.vue +7 -7
  347. package/icons/user-square.vue +14 -14
  348. package/icons/user.vue +22 -22
  349. package/icons/users-focus.vue +8 -8
  350. package/icons/users-three.vue +7 -7
  351. package/icons/users.vue +8 -8
  352. package/icons/warning/warning-circle.vue +29 -29
  353. package/icons/warning/warning-triangle-filled.vue +12 -12
  354. package/icons/warning/warning-triangle.vue +28 -28
  355. package/icons/whatsapp.vue +8 -8
  356. package/icons/work-bag.vue +11 -11
  357. package/icons/work-case.vue +9 -9
  358. package/icons/work-search.vue +10 -10
  359. package/icons/work.vue +5 -5
  360. package/icons/x-mark.vue +15 -15
  361. package/icons/yandex.vue +28 -28
  362. package/illustrations/address-location.vue +38 -38
  363. package/illustrations/ball-with-chain.vue +120 -120
  364. package/illustrations/bill.vue +133 -133
  365. package/illustrations/buildings.vue +82 -82
  366. package/illustrations/calendar.vue +156 -156
  367. package/illustrations/chains.vue +152 -152
  368. package/illustrations/coin-percent.vue +126 -126
  369. package/illustrations/coins-stack.vue +202 -202
  370. package/illustrations/delete-dark.vue +31 -31
  371. package/illustrations/delete.vue +32 -32
  372. package/illustrations/doc-with-stamp.vue +126 -126
  373. package/illustrations/document.vue +64 -64
  374. package/illustrations/door.vue +74 -74
  375. package/illustrations/empty-box.vue +77 -77
  376. package/illustrations/empty-wallet.vue +161 -161
  377. package/illustrations/graph-in-coin.vue +119 -119
  378. package/illustrations/hammer.vue +156 -156
  379. package/illustrations/hand-cash.vue +108 -108
  380. package/illustrations/info.vue +39 -39
  381. package/illustrations/mail.vue +68 -68
  382. package/illustrations/ok.vue +62 -62
  383. package/illustrations/people-group.vue +237 -237
  384. package/illustrations/person-with-phone.vue +187 -187
  385. package/illustrations/person.vue +159 -159
  386. package/illustrations/phone-check.vue +90 -90
  387. package/illustrations/phone-payment-method.vue +223 -223
  388. package/illustrations/search.vue +14 -0
  389. package/illustrations/stop-hand.vue +77 -77
  390. package/illustrations/stop-sign.vue +34 -34
  391. package/illustrations/suit.vue +111 -111
  392. package/illustrations/suitcase.vue +105 -105
  393. package/illustrations/terminal-dark.vue +48 -48
  394. package/illustrations/terminal.vue +234 -234
  395. package/illustrations/trash-can.vue +108 -108
  396. package/illustrations/turn-on-tariff.vue +38 -38
  397. package/illustrations/two-persons.vue +169 -169
  398. package/lang/en.ts +835 -834
  399. package/lang/kk.ts +837 -836
  400. package/lang/ru.ts +838 -837
  401. package/layouts/default.vue +13 -13
  402. package/nuxt.config.ts +88 -88
  403. package/package.json +69 -69
  404. package/plugins/maska.ts +4 -4
  405. package/plugins/toast.client.ts +58 -58
  406. package/public/kaspi/logo.svg +4 -4
  407. package/shared/constans/pages.ts +90 -89
  408. package/tailwind.config.ts +163 -163
  409. package/tests/AButton.test.ts +81 -81
  410. package/tsconfig.json +6 -6
  411. package/utils/getMaxZindex.ts +25 -25
  412. package/utils/localizedNavigation.ts +36 -36
  413. package/vitest.config.ts +14 -14
@@ -1,140 +1,140 @@
1
- <script setup lang="ts">
2
- import AChips from '~/components/elements/chips/AChips.vue'
3
- import {isEqual} from 'lodash-es'
4
- import { twMerge } from 'tailwind-merge'
5
-
6
- type Item = {
7
- id: number | string
8
- name: string
9
- }
10
-
11
- interface Props {
12
- clearable?: boolean
13
- disabled?: boolean
14
- deletable?: boolean
15
- label: string
16
- selectedItems: Item[]
17
- btnClass?: string
18
- }
19
-
20
- // const items = defineModel<Item[]>('selectedItems', {required: true})
21
-
22
- type Emits = {
23
- (e: 'delete', item: Item): void
24
- }
25
-
26
- const props = withDefaults(defineProps<Props>(), {
27
- clearable: true,
28
- disabled: false,
29
- label: 'select',
30
- deletable: false,
31
- btnClass: '',
32
- })
33
- const items = computed(() => {
34
- return props.selectedItems
35
- })
36
- const emits = defineEmits<Emits>()
37
- const disabledStyles =
38
- 'disabled:pointer-events-none disabled:opacity-40 disabled:bg-deepblue-50 disabled:text-deepblue-200 disabled:dark:text-gray-500'
39
- const isOpen = defineModel<boolean>('isOpen')
40
-
41
- const minWidthOfChip = 100
42
- const buttonElement = ref()
43
- const buttonWidth = computed(() => buttonElement.value?.offsetWidth - 50)
44
- const itemsCount = computed(() => {
45
- return items.value.length
46
- })
47
- const maxWidthOfChip = computed(() => {
48
- if (itemsCount.value) {
49
- const width = (itemsCount.value <= 5 ? buttonWidth.value - itemsCount.value*8 : buttonWidth.value) / itemsCount.value
50
- if (width < minWidthOfChip) {
51
- return minWidthOfChip
52
- }
53
- return width
54
- }
55
- return 'auto'
56
- })
57
-
58
- const countOfVisibleItems = computed(() => {
59
- if (!items.value?.length) return undefined
60
- const maxCountOfVisibleItems = Math.floor((buttonElement.value?.offsetWidth - 50) / 120)
61
- if (maxCountOfVisibleItems > items.value.length) return items.value.length
62
- else if (maxCountOfVisibleItems < 0) return 4
63
- else return maxCountOfVisibleItems
64
- })
65
- const visibleItems = computed(() => {
66
- if (!items.value.length && !countOfVisibleItems) return undefined
67
- return items.value.slice(0, countOfVisibleItems.value)
68
- })
69
- const countOfUnvisibleItems = computed(() => {
70
- if (!items.value?.length && !countOfVisibleItems.value) return undefined
71
- return items.value.length - countOfVisibleItems.value
72
- })
73
- const deleteItem = (item: Item) => {
74
- emits('delete', item)
75
- items.value = items.value?.filter((el) => !isEqual(el, item))
76
- }
77
- const onClear = () => {
78
- items.value.length = 0
79
- }
80
- </script>
81
- <template>
82
- <div>
83
- <button
84
- ref="buttonElement"
85
- class="hover:border-blue focus-visible:outline-blue
86
- relative flex w-full items-center justify-between gap-2 rounded-md
87
- border border-solid border-deepblue-50 bg-deepblue-50 min-h-[40px] text-gray-500 body-400 px-4 py-1.5
88
- focus-visible:shadow-[0_0_0_4px#1B64B3] dark:border-gray-900 dark:bg-gray-200/5
89
- dark:hover:border-blue-700"
90
- :class="twMerge(disabledStyles, props.btnClass)"
91
- :disabled="disabled"
92
- @click="isOpen = !isOpen"
93
- >
94
- <div>
95
- <div
96
- v-if="visibleItems && visibleItems.length"
97
- class="flex gap-2"
98
- >
99
- <a-chips
100
- v-for="item in visibleItems"
101
- :key="item.id"
102
- size="md"
103
- class="text-deepblue-900 dark:text-gray-200 border-gray-500"
104
- :style="{ 'max-width': maxWidthOfChip + 'px' }"
105
- >
106
- <span class="truncate">{{ item.name }}</span>
107
- <button
108
- v-if="deletable"
109
- class="rounded-full bg-deepblue-100 dark:bg-gray-200/10"
110
- @click.stop="deleteItem(item)"
111
- >
112
- <a-icon-x-mark class="size-3 dark:text-gray-300" />
113
- </button>
114
- </a-chips>
115
- <a-chips
116
- v-if="countOfUnvisibleItems"
117
- class="text-blue-700 dark:text-blue-500 border-blue-700 dark:border-blue-500 whitespace-nowrap"
118
- size="md"
119
- >
120
- + {{ countOfUnvisibleItems }}
121
- </a-chips>
122
- </div>
123
- <div v-else>
124
- {{ label }}
125
- </div>
126
- </div>
127
- <!-- <button-->
128
- <!-- v-if="visibleItems && countOfVisibleItems && clearable"-->
129
- <!-- class="absolute right-10 top-1/2 -translate-y-1/2 rounded-full bg-deepblue-100 dark:bg-gray-200/10"-->
130
- <!-- @click.stop="onClear"-->
131
- <!-- >-->
132
- <!-- <a-icon-chevron-down class="!m-0 text-base dark:text-gray-300"/>-->
133
- <!-- </button>-->
134
- <a-icon-chevron-down
135
- class="!m-0 min-w-4 transition-all text-deepblue-900 dark:text-gray-500"
136
- :class="{ '-rotate-90': !isOpen }"
137
- />
138
- </button>
139
- </div>
140
- </template>
1
+ <script setup lang="ts">
2
+ import AChips from '~/components/elements/chips/AChips.vue'
3
+ import {isEqual} from 'lodash-es'
4
+ import { twMerge } from 'tailwind-merge'
5
+
6
+ type Item = {
7
+ id: number | string
8
+ name: string
9
+ }
10
+
11
+ interface Props {
12
+ clearable?: boolean
13
+ disabled?: boolean
14
+ deletable?: boolean
15
+ label: string
16
+ selectedItems: Item[]
17
+ btnClass?: string
18
+ }
19
+
20
+ // const items = defineModel<Item[]>('selectedItems', {required: true})
21
+
22
+ type Emits = {
23
+ (e: 'delete', item: Item): void
24
+ }
25
+
26
+ const props = withDefaults(defineProps<Props>(), {
27
+ clearable: true,
28
+ disabled: false,
29
+ label: 'select',
30
+ deletable: false,
31
+ btnClass: '',
32
+ })
33
+ const items = computed(() => {
34
+ return props.selectedItems
35
+ })
36
+ const emits = defineEmits<Emits>()
37
+ const disabledStyles =
38
+ 'disabled:pointer-events-none disabled:opacity-40 disabled:bg-deepblue-50 disabled:text-deepblue-200 disabled:dark:text-gray-500'
39
+ const isOpen = defineModel<boolean>('isOpen')
40
+
41
+ const minWidthOfChip = 100
42
+ const buttonElement = ref()
43
+ const buttonWidth = computed(() => buttonElement.value?.offsetWidth - 50)
44
+ const itemsCount = computed(() => {
45
+ return items.value.length
46
+ })
47
+ const maxWidthOfChip = computed(() => {
48
+ if (itemsCount.value) {
49
+ const width = (itemsCount.value <= 5 ? buttonWidth.value - itemsCount.value*8 : buttonWidth.value) / itemsCount.value
50
+ if (width < minWidthOfChip) {
51
+ return minWidthOfChip
52
+ }
53
+ return width
54
+ }
55
+ return 'auto'
56
+ })
57
+
58
+ const countOfVisibleItems = computed(() => {
59
+ if (!items.value?.length) return undefined
60
+ const maxCountOfVisibleItems = Math.floor((buttonElement.value?.offsetWidth - 50) / 120)
61
+ if (maxCountOfVisibleItems > items.value.length) return items.value.length
62
+ else if (maxCountOfVisibleItems < 0) return 4
63
+ else return maxCountOfVisibleItems
64
+ })
65
+ const visibleItems = computed(() => {
66
+ if (!items.value.length && !countOfVisibleItems) return undefined
67
+ return items.value.slice(0, countOfVisibleItems.value)
68
+ })
69
+ const countOfUnvisibleItems = computed(() => {
70
+ if (!items.value?.length && !countOfVisibleItems.value) return undefined
71
+ return items.value.length - countOfVisibleItems.value
72
+ })
73
+ const deleteItem = (item: Item) => {
74
+ emits('delete', item)
75
+ items.value = items.value?.filter((el) => !isEqual(el, item))
76
+ }
77
+ const onClear = () => {
78
+ items.value.length = 0
79
+ }
80
+ </script>
81
+ <template>
82
+ <div>
83
+ <button
84
+ ref="buttonElement"
85
+ class="hover:border-blue focus-visible:outline-blue
86
+ relative flex w-full items-center justify-between gap-2 rounded-md
87
+ border border-solid border-deepblue-50 bg-deepblue-50 min-h-[40px] text-gray-500 body-400 px-4 py-1.5
88
+ focus-visible:shadow-[0_0_0_4px#1B64B3] dark:border-gray-900 dark:bg-gray-200/5
89
+ dark:hover:border-blue-700"
90
+ :class="twMerge(disabledStyles, props.btnClass)"
91
+ :disabled="disabled"
92
+ @click="isOpen = !isOpen"
93
+ >
94
+ <div>
95
+ <div
96
+ v-if="visibleItems && visibleItems.length"
97
+ class="flex gap-2"
98
+ >
99
+ <a-chips
100
+ v-for="item in visibleItems"
101
+ :key="item.id"
102
+ size="md"
103
+ class="text-deepblue-900 dark:text-gray-200 border-gray-500"
104
+ :style="{ 'max-width': maxWidthOfChip + 'px' }"
105
+ >
106
+ <span class="truncate">{{ item.name }}</span>
107
+ <button
108
+ v-if="deletable"
109
+ class="rounded-full bg-deepblue-100 dark:bg-gray-200/10"
110
+ @click.stop="deleteItem(item)"
111
+ >
112
+ <a-icon-x-mark class="size-3 dark:text-gray-300" />
113
+ </button>
114
+ </a-chips>
115
+ <a-chips
116
+ v-if="countOfUnvisibleItems"
117
+ class="text-blue-700 dark:text-blue-500 border-blue-700 dark:border-blue-500 whitespace-nowrap"
118
+ size="md"
119
+ >
120
+ + {{ countOfUnvisibleItems }}
121
+ </a-chips>
122
+ </div>
123
+ <div v-else>
124
+ {{ label }}
125
+ </div>
126
+ </div>
127
+ <!-- <button-->
128
+ <!-- v-if="visibleItems && countOfVisibleItems && clearable"-->
129
+ <!-- class="absolute right-10 top-1/2 -translate-y-1/2 rounded-full bg-deepblue-100 dark:bg-gray-200/10"-->
130
+ <!-- @click.stop="onClear"-->
131
+ <!-- >-->
132
+ <!-- <a-icon-chevron-down class="!m-0 text-base dark:text-gray-300"/>-->
133
+ <!-- </button>-->
134
+ <a-icon-chevron-down
135
+ class="!m-0 min-w-4 transition-all text-deepblue-900 dark:text-gray-500"
136
+ :class="{ '-rotate-90': !isOpen }"
137
+ />
138
+ </button>
139
+ </div>
140
+ </template>
@@ -1,197 +1,197 @@
1
- <script setup lang="ts">
2
- // REFACTOR @Iskander
3
- import ui from './ui.config'
4
- import {Disclosure, DisclosureButton, DisclosurePanel} from '@headlessui/vue'
5
- import {twJoin, twMerge} from 'tailwind-merge'
6
- import type {Color, Size} from "#adata-ui/components/elements/accordion/types";
7
-
8
- export interface Props {
9
- label: string
10
- content?: any
11
- defaultOpen?: boolean
12
- disabled?: boolean
13
- size?: Size
14
- color?: Color
15
- slot?: string
16
- contentClass?: string
17
- bodyClass?: string
18
- activateOpenBg?: boolean
19
- }
20
-
21
- interface Emits {
22
- (e: 'toggle', isOpen: boolean): void
23
-
24
- (e: 'open'): void
25
-
26
- (e: 'close'): void
27
- }
28
-
29
- defineOptions({
30
- inheritAttrs: false
31
- })
32
- const attrs = useAttrs()
33
-
34
- const props = withDefaults(defineProps<Props>(), {
35
- defaultOpen: false,
36
- disabled: false,
37
- size: 'md',
38
- color: 'gray',
39
- slot: undefined
40
- })
41
-
42
-
43
- const emit = defineEmits<Emits>()
44
-
45
- const buttonClass = computed(() =>
46
- twMerge(twJoin(ui.item.color[props.color], ui.ring, ui.item.button, ui.item.size[props.size]))
47
- )
48
-
49
- function onEnter(_el: Element, done: () => void) {
50
- const el = _el as HTMLElement
51
- el.style.height = '0'
52
- el.offsetHeight // Trigger a reflow, flushing the CSS changes
53
- el.style.height = el.scrollHeight + 'px'
54
-
55
- el.addEventListener('transitionend', done, {once: true})
56
- }
57
-
58
- function onBeforeLeave(_el: Element) {
59
- const el = _el as HTMLElement
60
- el.style.height = el.scrollHeight + 'px'
61
- el.offsetHeight // Trigger a reflow, flushing the CSS changes
62
- }
63
-
64
- function onAfterEnter(_el: Element) {
65
- const el = _el as HTMLElement
66
- el.style.height = 'auto'
67
- }
68
-
69
- function onLeave(_el: Element, done: () => void) {
70
- const el = _el as HTMLElement
71
- el.style.height = '0'
72
-
73
- el.addEventListener('transitionend', done, {once: true})
74
- }
75
-
76
- const contClass = computed(() => twMerge(twJoin(ui.item.content, props.contentClass)))
77
- const bodyClassCompute = computed(() => twMerge(twJoin(ui.item.accordion, props.activateOpenBg ? isOpen.value && props.bodyClass : props.bodyClass)))
78
-
79
- const accordion = ref()
80
-
81
- const isOpen = ref()
82
-
83
- function updateState() {
84
- if (accordion.value) {
85
- const state = accordion.value?.el.getAttribute('data-headlessui-state')
86
- isOpen.value = !!state
87
- }
88
- }
89
- let observer: MutationObserver | null = null
90
-
91
- onMounted(() => {
92
- if (!accordion.value) return
93
-
94
- updateState()
95
-
96
- observer = new MutationObserver(updateState)
97
- observer.observe(accordion.value.el, {
98
- attributes: true,
99
- attributeFilter: ['data-headlessui-state']
100
- })
101
- })
102
-
103
- onBeforeUnmount(() => {
104
- if (observer) {
105
- observer.disconnect()
106
- observer = null
107
- }
108
- })
109
-
110
- function emulateButtonClick() {
111
- if (accordion.value) {
112
- accordion.value?.el.click()
113
- }
114
- }
115
-
116
- const handelOpen = () => {
117
- if (!isOpen.value) {
118
- emulateButtonClick()
119
- }
120
- }
121
- const handelClose = () => {
122
- if (isOpen.value) {
123
- emulateButtonClick()
124
- }
125
- }
126
-
127
- watch(isOpen, () => {
128
- emit('toggle', isOpen.value)
129
- isOpen.value ? emit('open') : emit('close')
130
- })
131
-
132
- defineExpose({
133
- ontoggle: emulateButtonClick,
134
- handelOpen,
135
- handelClose
136
- })
137
- </script>
138
-
139
- <template>
140
- <Disclosure
141
- v-slot="{ open, close }"
142
- as="div"
143
- :class="bodyClassCompute"
144
- :default-open="defaultOpen"
145
- v-bind="{ ...attrs }"
146
- >
147
- <DisclosureButton
148
- ref="accordion"
149
- :disabled="disabled"
150
- as="template"
151
- >
152
- <slot
153
- name="head"
154
- :open="open"
155
- :close="close"
156
- >
157
- <button :class="buttonClass">
158
- <span :class="size === 'md' ? 'text-sm': 'text-base'">{{ label }}</span>
159
- <slot name="additional"/>
160
- <a-icon-chevron-down
161
- :arrow-attrs="{ class: 'stroke-deepblue-900' }"
162
- :class="[{ 'rotate-180': open }, 'max-h-[16px] min-h-[16px] min-w-[16px] max-w-[16px]', ui.item.icon]"
163
- />
164
- </button>
165
- </slot>
166
- </DisclosureButton>
167
- <slot
168
- name="closedToShow"
169
- :open="open"
170
- :close="close"
171
- />
172
- <Transition
173
- v-bind="ui.transition"
174
- @enter="onEnter"
175
- @after-enter="onAfterEnter"
176
- @before-leave="onBeforeLeave"
177
- @leave="onLeave"
178
- >
179
- <div v-show="open">
180
- <DisclosurePanel static>
181
- <div :class="contClass">
182
- <slot
183
- :name="slot || 'default'"
184
- :content="content"
185
- :open="open"
186
- :close="close"
187
- >
188
- {{ content }}
189
- </slot>
190
- </div>
191
- </DisclosurePanel>
192
- </div>
193
- </Transition>
194
- </Disclosure>
195
- </template>
196
-
197
- <style scoped></style>
1
+ <script setup lang="ts">
2
+ // REFACTOR @Iskander
3
+ import ui from './ui.config'
4
+ import {Disclosure, DisclosureButton, DisclosurePanel} from '@headlessui/vue'
5
+ import {twJoin, twMerge} from 'tailwind-merge'
6
+ import type {Color, Size} from "#adata-ui/components/elements/accordion/types";
7
+
8
+ export interface Props {
9
+ label: string
10
+ content?: any
11
+ defaultOpen?: boolean
12
+ disabled?: boolean
13
+ size?: Size
14
+ color?: Color
15
+ slot?: string
16
+ contentClass?: string
17
+ bodyClass?: string
18
+ activateOpenBg?: boolean
19
+ }
20
+
21
+ interface Emits {
22
+ (e: 'toggle', isOpen: boolean): void
23
+
24
+ (e: 'open'): void
25
+
26
+ (e: 'close'): void
27
+ }
28
+
29
+ defineOptions({
30
+ inheritAttrs: false
31
+ })
32
+ const attrs = useAttrs()
33
+
34
+ const props = withDefaults(defineProps<Props>(), {
35
+ defaultOpen: false,
36
+ disabled: false,
37
+ size: 'md',
38
+ color: 'gray',
39
+ slot: undefined
40
+ })
41
+
42
+
43
+ const emit = defineEmits<Emits>()
44
+
45
+ const buttonClass = computed(() =>
46
+ twMerge(twJoin(ui.item.color[props.color], ui.ring, ui.item.button, ui.item.size[props.size]))
47
+ )
48
+
49
+ function onEnter(_el: Element, done: () => void) {
50
+ const el = _el as HTMLElement
51
+ el.style.height = '0'
52
+ el.offsetHeight // Trigger a reflow, flushing the CSS changes
53
+ el.style.height = el.scrollHeight + 'px'
54
+
55
+ el.addEventListener('transitionend', done, {once: true})
56
+ }
57
+
58
+ function onBeforeLeave(_el: Element) {
59
+ const el = _el as HTMLElement
60
+ el.style.height = el.scrollHeight + 'px'
61
+ el.offsetHeight // Trigger a reflow, flushing the CSS changes
62
+ }
63
+
64
+ function onAfterEnter(_el: Element) {
65
+ const el = _el as HTMLElement
66
+ el.style.height = 'auto'
67
+ }
68
+
69
+ function onLeave(_el: Element, done: () => void) {
70
+ const el = _el as HTMLElement
71
+ el.style.height = '0'
72
+
73
+ el.addEventListener('transitionend', done, {once: true})
74
+ }
75
+
76
+ const contClass = computed(() => twMerge(twJoin(ui.item.content, props.contentClass)))
77
+ const bodyClassCompute = computed(() => twMerge(twJoin(ui.item.accordion, props.activateOpenBg ? isOpen.value && props.bodyClass : props.bodyClass)))
78
+
79
+ const accordion = ref()
80
+
81
+ const isOpen = ref()
82
+
83
+ function updateState() {
84
+ if (accordion.value) {
85
+ const state = accordion.value?.el.getAttribute('data-headlessui-state')
86
+ isOpen.value = !!state
87
+ }
88
+ }
89
+ let observer: MutationObserver | null = null
90
+
91
+ onMounted(() => {
92
+ if (!accordion.value) return
93
+
94
+ updateState()
95
+
96
+ observer = new MutationObserver(updateState)
97
+ observer.observe(accordion.value.el, {
98
+ attributes: true,
99
+ attributeFilter: ['data-headlessui-state']
100
+ })
101
+ })
102
+
103
+ onBeforeUnmount(() => {
104
+ if (observer) {
105
+ observer.disconnect()
106
+ observer = null
107
+ }
108
+ })
109
+
110
+ function emulateButtonClick() {
111
+ if (accordion.value) {
112
+ accordion.value?.el.click()
113
+ }
114
+ }
115
+
116
+ const handelOpen = () => {
117
+ if (!isOpen.value) {
118
+ emulateButtonClick()
119
+ }
120
+ }
121
+ const handelClose = () => {
122
+ if (isOpen.value) {
123
+ emulateButtonClick()
124
+ }
125
+ }
126
+
127
+ watch(isOpen, () => {
128
+ emit('toggle', isOpen.value)
129
+ isOpen.value ? emit('open') : emit('close')
130
+ })
131
+
132
+ defineExpose({
133
+ ontoggle: emulateButtonClick,
134
+ handelOpen,
135
+ handelClose
136
+ })
137
+ </script>
138
+
139
+ <template>
140
+ <Disclosure
141
+ v-slot="{ open, close }"
142
+ as="div"
143
+ :class="bodyClassCompute"
144
+ :default-open="defaultOpen"
145
+ v-bind="{ ...attrs }"
146
+ >
147
+ <DisclosureButton
148
+ ref="accordion"
149
+ :disabled="disabled"
150
+ as="template"
151
+ >
152
+ <slot
153
+ name="head"
154
+ :open="open"
155
+ :close="close"
156
+ >
157
+ <button :class="buttonClass">
158
+ <span :class="size === 'md' ? 'text-sm': 'text-base'">{{ label }}</span>
159
+ <slot name="additional"/>
160
+ <a-icon-chevron-down
161
+ :arrow-attrs="{ class: 'stroke-deepblue-900' }"
162
+ :class="[{ 'rotate-180': open }, 'max-h-[16px] min-h-[16px] min-w-[16px] max-w-[16px]', ui.item.icon]"
163
+ />
164
+ </button>
165
+ </slot>
166
+ </DisclosureButton>
167
+ <slot
168
+ name="closedToShow"
169
+ :open="open"
170
+ :close="close"
171
+ />
172
+ <Transition
173
+ v-bind="ui.transition"
174
+ @enter="onEnter"
175
+ @after-enter="onAfterEnter"
176
+ @before-leave="onBeforeLeave"
177
+ @leave="onLeave"
178
+ >
179
+ <div v-show="open">
180
+ <DisclosurePanel static>
181
+ <div :class="contClass">
182
+ <slot
183
+ :name="slot || 'default'"
184
+ :content="content"
185
+ :open="open"
186
+ :close="close"
187
+ >
188
+ {{ content }}
189
+ </slot>
190
+ </div>
191
+ </DisclosurePanel>
192
+ </div>
193
+ </Transition>
194
+ </Disclosure>
195
+ </template>
196
+
197
+ <style scoped></style>