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,118 +1,118 @@
1
- <script setup lang="ts">
2
- import { useMediaQuery } from '@vueuse/core'
3
-
4
- interface Item {
5
- title: string
6
- link: string
7
- }
8
-
9
- interface Props {
10
- label: string
11
- link: string
12
- content: Item[]
13
- }
14
-
15
- const props = defineProps<Props>()
16
-
17
- const isDesktop = useMediaQuery('(max-width: 1024px)')
18
-
19
- const open = ref(false)
20
- function toFinalValues(el: HTMLDivElement) {
21
- el.style.height = el.scrollHeight + 'px'
22
- el.style.opacity = '1'
23
- }
24
-
25
- function onAfterEnter(el: HTMLDivElement) {
26
- el.style.height = ''
27
- }
28
-
29
- const filterCheck = computed(() => {
30
- if (open.value) {
31
- return open.value
32
- }
33
- else {
34
- return open.value = !isDesktop.value
35
- }
36
- })
37
- </script>
38
-
39
- <template>
40
- <div class="flex flex-col gap-2 items-start">
41
- <div class="flex gap-2 justify-between w-full">
42
- <nuxt-link
43
- class="text-sm font-semibold lg:pb-3 lg:pr-4 lg:border-b-[0.5px] lg:border-white cursor-default"
44
- :class="{ 'cursor-pointer': link }"
45
- :to="link?.replace(/\/$/, '')"
46
- >
47
- {{ label }}
48
- </nuxt-link>
49
-
50
- <div class="transition-all lg:hidden cursor-pointer">
51
- <a-icon-chevron-down
52
- v-if="content.length"
53
- filled
54
- :font-controlled="false"
55
- class="size-6 transition-all"
56
- :class="{ 'rotate-180': open }"
57
- @click="open = !open"
58
- />
59
- </div>
60
- </div>
61
-
62
- <transition
63
- name="accordion"
64
- @enter="toFinalValues"
65
- @after-enter="onAfterEnter"
66
- @before-leave="toFinalValues"
67
- >
68
- <div
69
- v-if="filterCheck"
70
- class="flex gap-3 lg:gap-6 flex-col lg:flex-row"
71
- >
72
- <div
73
- v-for="(subItem, subIdx) in content"
74
- :key="subIdx"
75
- class="flex flex-col gap-3 lg:gap-2"
76
- >
77
- <div
78
- v-for="(link, idx) in subItem"
79
- :key="idx"
80
- class="flex gap-2 items-center"
81
- >
82
- <nuxt-link
83
- class="text-xs lg:font-medium flex gap-2 items-center cursor-pointer"
84
- :to="link.link?.replace(/\/$/, '')"
85
- >
86
- {{ link.title }}
87
- </nuxt-link>
88
-
89
- <div
90
- v-if="link.isNew"
91
- class="text-[9px] font-bold px-1 py-[2px] rounded-sm bg-white/20"
92
- >
93
- NEW
94
- </div>
95
- </div>
96
- </div>
97
- </div>
98
- </transition>
99
- </div>
100
- </template>
101
-
102
- <style scoped>
103
- .accordion-enter-active,
104
- .accordion-leave-active {
105
- overflow: hidden;
106
- transition: height 0.3s ease,
107
- opacity 0.3s ease,
108
- margin 0.3s ease;
109
-
110
- }
111
-
112
- .accordion-enter-from,
113
- .accordion-leave-to {
114
- height: 0 !important;
115
- opacity: 0 !important;
116
- margin: 0 !important;
117
- }
118
- </style>
1
+ <script setup lang="ts">
2
+ import { useMediaQuery } from '@vueuse/core'
3
+
4
+ interface Item {
5
+ title: string
6
+ link: string
7
+ }
8
+
9
+ interface Props {
10
+ label: string
11
+ link: string
12
+ content: Item[]
13
+ }
14
+
15
+ const props = defineProps<Props>()
16
+
17
+ const isDesktop = useMediaQuery('(max-width: 1024px)')
18
+
19
+ const open = ref(false)
20
+ function toFinalValues(el: HTMLDivElement) {
21
+ el.style.height = el.scrollHeight + 'px'
22
+ el.style.opacity = '1'
23
+ }
24
+
25
+ function onAfterEnter(el: HTMLDivElement) {
26
+ el.style.height = ''
27
+ }
28
+
29
+ const filterCheck = computed(() => {
30
+ if (open.value) {
31
+ return open.value
32
+ }
33
+ else {
34
+ return open.value = !isDesktop.value
35
+ }
36
+ })
37
+ </script>
38
+
39
+ <template>
40
+ <div class="flex flex-col gap-2 items-start">
41
+ <div class="flex gap-2 justify-between w-full">
42
+ <nuxt-link
43
+ class="text-sm font-semibold lg:pb-3 lg:pr-4 lg:border-b-[0.5px] lg:border-white cursor-default"
44
+ :class="{ 'cursor-pointer': link }"
45
+ :to="link?.replace(/\/$/, '')"
46
+ >
47
+ {{ label }}
48
+ </nuxt-link>
49
+
50
+ <div class="transition-all lg:hidden cursor-pointer">
51
+ <a-icon-chevron-down
52
+ v-if="content.length"
53
+ filled
54
+ :font-controlled="false"
55
+ class="size-6 transition-all"
56
+ :class="{ 'rotate-180': open }"
57
+ @click="open = !open"
58
+ />
59
+ </div>
60
+ </div>
61
+
62
+ <transition
63
+ name="accordion"
64
+ @enter="toFinalValues"
65
+ @after-enter="onAfterEnter"
66
+ @before-leave="toFinalValues"
67
+ >
68
+ <div
69
+ v-if="filterCheck"
70
+ class="flex gap-3 lg:gap-6 flex-col lg:flex-row"
71
+ >
72
+ <div
73
+ v-for="(subItem, subIdx) in content"
74
+ :key="subIdx"
75
+ class="flex flex-col gap-3 lg:gap-2"
76
+ >
77
+ <div
78
+ v-for="(link, idx) in subItem"
79
+ :key="idx"
80
+ class="flex gap-2 items-center"
81
+ >
82
+ <nuxt-link
83
+ class="text-xs lg:font-medium flex gap-2 items-center cursor-pointer"
84
+ :to="link.link?.replace(/\/$/, '')"
85
+ >
86
+ {{ link.title }}
87
+ </nuxt-link>
88
+
89
+ <div
90
+ v-if="link.isNew"
91
+ class="text-[9px] font-bold px-1 py-[2px] rounded-sm bg-white/20"
92
+ >
93
+ NEW
94
+ </div>
95
+ </div>
96
+ </div>
97
+ </div>
98
+ </transition>
99
+ </div>
100
+ </template>
101
+
102
+ <style scoped>
103
+ .accordion-enter-active,
104
+ .accordion-leave-active {
105
+ overflow: hidden;
106
+ transition: height 0.3s ease,
107
+ opacity 0.3s ease,
108
+ margin 0.3s ease;
109
+
110
+ }
111
+
112
+ .accordion-enter-from,
113
+ .accordion-leave-to {
114
+ height: 0 !important;
115
+ opacity: 0 !important;
116
+ margin: 0 !important;
117
+ }
118
+ </style>
@@ -1,217 +1,217 @@
1
- <script lang="ts" setup>
2
- import type { ProjectKeys } from '#adata-ui/components/navigation/header/types'
3
- import AColorMode from '#adata-ui/components/features/color-mode/AColorMode.client.vue'
4
- import LangSwitcher from '#adata-ui/components/features/lang-switcher/lang-switcher.vue'
5
- import AChangeVersion from '#adata-ui/components/features/сhange-version/AChangeVersion.vue'
6
- import ProfileMenu from '#adata-ui/components/navigation/header/ProfileMenu.vue'
7
- import TopHeader from '#adata-ui/components/navigation/header/TopHeader.vue'
8
- import { useContacts, useCurrentModule } from '#adata-ui/composables/projectState'
9
- import AdataLogo from '#adata-ui/icons/adata-logo.vue'
10
- import Arrow from '#adata-ui/icons/chevron/chevron-down.vue'
11
- import Logo from '#adata-ui/icons/logo.vue'
12
- import { buildLocalizedUrl, navigateToLocalizedPage } from '#adata-ui/utils/localizedNavigation'
13
- import HeaderLink from './HeaderLink.vue'
14
- import { useUrls } from '#adata-ui/composables/useUrls'
15
-
16
- defineOptions({ name: 'AHeader' })
17
-
18
- const props = withDefaults(defineProps<Props>(), {
19
- limitRemaining: 0,
20
- daysRemaining: 0,
21
- balance: 0,
22
- rate: 'Базовый',
23
- showLogIn: true,
24
- mobileHeaderType: 'default',
25
- module: 'pk',
26
- })
27
-
28
- const emit = defineEmits(['logout', 'search', 'login'])
29
-
30
- interface Props {
31
- replenish?: string
32
- hasNotification?: boolean
33
- email: string | undefined
34
- rate: string
35
- daysRemaining: number
36
- limitRemaining: number
37
- balance: number
38
- isAuthenticated: boolean
39
- showLogIn?: boolean
40
- mobileHeaderType?: 'search' | 'default'
41
- module?: ProjectKeys
42
- oldVersion?: string
43
- }
44
-
45
- const { t } = useI18n()
46
- const { locale } = useI18n()
47
-
48
- useCurrentModule().value = props.module
49
- const appConfig = useAppConfig()
50
- const { myLayer }: any = useAppConfig()
51
- const urls = useUrls()
52
-
53
- const langIsOn = appConfig.myLayer.langIsOn
54
- const contacts = ref(useContacts())
55
- const { loginModal } = useIdModals()
56
-
57
- function goAuth() {
58
- if (myLayer.authMode !== 'local') {
59
- if (window) {
60
- emit('login')
61
- let fullPath = encodeURIComponent(window.location.toString())
62
- if (fullPath.includes('basic-info')) {
63
- fullPath = fullPath.replace('%2Fcounterparty%2Fmain', '').replace('%2Fbasic-info', '')
64
- }
65
-
66
- navigateToLocalizedPage({
67
- locale,
68
- projectUrl: urls.login,
69
- path: `/?url=${fullPath}`,
70
- target: '_self',
71
- })
72
- }
73
- }
74
- else {
75
- loginModal.value = true
76
- }
77
- }
78
-
79
- function goToAnotherModule() {
80
- location.href = buildLocalizedUrl(locale.value, urls.landing, '')
81
- }
82
-
83
- async function fetchContacts() {
84
- try {
85
- const response = await fetch(
86
- 'https://pk-api.adata.kz/api/v1/data/counterparty/contacts/sales-department',
87
- )
88
- const { data } = await response.json()
89
- contacts.value = data
90
- }
91
- catch (e) {
92
- console.error(e.message)
93
- }
94
- }
95
-
96
- onBeforeMount(() => {
97
- fetchContacts()
98
- })
99
- </script>
100
-
101
- <template>
102
- <div>
103
- <top-header
104
- :days-remaining="daysRemaining"
105
- :is-authenticated="isAuthenticated"
106
- :module-name="module"
107
- :limit-remaining="limitRemaining"
108
- />
109
- <header
110
- class="relative h-16 border-b border-deepblue-900/10 bg-white dark:border-gray-200/10 dark:bg-gray-900"
111
- >
112
- <div class="a-container mobile-padding flex h-full items-center justify-between gap-2">
113
- <!-- Desktop hidden -->
114
- <section
115
- id="mobile-header"
116
- class="grow lg:hidden"
117
- >
118
- <div
119
- v-if="mobileHeaderType === 'default'"
120
- class="flex justify-center"
121
- >
122
- <div
123
- class="text-deepblue dark:text-[#E3E5E8]"
124
- @click="goToAnotherModule"
125
- >
126
- <span class="visually-hidden"> Сервисы Adata.kz</span>
127
-
128
- <adata-logo
129
- :font-controlled="false"
130
- filled
131
- />
132
- </div>
133
- </div>
134
- <div
135
- v-else-if="mobileHeaderType === 'search'"
136
- class="flex w-full items-center gap-2 bg-white dark:bg-gray-900 lg:hidden"
137
- >
138
- <logo
139
- class="dark:text-gray-200"
140
- @click="goToAnotherModule"
141
- />
142
- <button
143
- class="flex w-full items-center gap-2 rounded bg-gray-50 px-4 py-1.5 dark:bg-gray-800 dark:text-gray-500"
144
- @click="$emit('search')"
145
- >
146
- <a-icon-search />
147
- <span class="body-400">Найти</span>
148
- </button>
149
- </div>
150
- </section>
151
- <div class="lg:hidden">
152
- <lang-switcher
153
- v-if="langIsOn || module === 'fea'"
154
- class="lg:hidden"
155
- />
156
- </div>
157
- <!-- Mobile hidden -->
158
- <nav class="hidden items-center gap-4 lg:flex" itemscope itemtype="https://schema.org/SiteNavigationElement" role="list">
159
- <nuxt-link-locale
160
- aria-label="Adata-logo"
161
- :to="buildLocalizedUrl(locale, urls.landing)"
162
- class="text-deepblue cursor-pointer dark:text-[#E3E5E8]"
163
- @click="goToAnotherModule"
164
- >
165
- <adata-logo
166
- :font-controlled="false"
167
- filled
168
- />
169
- </nuxt-link-locale>
170
- <header-link />
171
- </nav>
172
- <div class="text-deepblue hidden items-center gap-4 dark:text-[#E3E5E8] lg:flex">
173
- <!-- Mobile hidden -->
174
- <div class="hidden items-center gap-4 lg:flex">
175
- <a-change-version
176
- v-if="oldVersion"
177
- :url="oldVersion"
178
- />
179
- <a-color-mode />
180
- <lang-switcher v-if="langIsOn || module === 'fea'" />
181
- </div>
182
-
183
- <a-dropdown
184
- v-show="isAuthenticated"
185
- placement="right"
186
- >
187
- <template #default="{ onExpand, expanded }">
188
- <div
189
- class="hidden cursor-pointer items-center gap-2 text-sm font-semibold lg:flex"
190
- @click.stop="onExpand"
191
- >
192
- <span>{{ email }}</span>
193
- <arrow :class="{ 'rotate-180': expanded }" />
194
- </div>
195
- </template>
196
- <template #content>
197
- <profile-menu
198
- :balance="balance"
199
- :days-remaining="daysRemaining"
200
- :limit-remaining="limitRemaining"
201
- :rate="rate"
202
- :replenish="replenish"
203
- @logout="$emit('logout')"
204
- />
205
- </template>
206
- </a-dropdown>
207
- <a-button-login
208
- v-show="!isAuthenticated && showLogIn"
209
- @click="goAuth"
210
- />
211
- </div>
212
- </div>
213
- </header>
214
- </div>
215
- </template>
216
-
217
- <style scoped></style>
1
+ <script lang="ts" setup>
2
+ import type { ProjectKeys } from '#adata-ui/components/navigation/header/types'
3
+ import AColorMode from '#adata-ui/components/features/color-mode/AColorMode.client.vue'
4
+ import LangSwitcher from '#adata-ui/components/features/lang-switcher/lang-switcher.vue'
5
+ import AChangeVersion from '#adata-ui/components/features/сhange-version/AChangeVersion.vue'
6
+ import ProfileMenu from '#adata-ui/components/navigation/header/ProfileMenu.vue'
7
+ import TopHeader from '#adata-ui/components/navigation/header/TopHeader.vue'
8
+ import { useContacts, useCurrentModule } from '#adata-ui/composables/projectState'
9
+ import AdataLogo from '#adata-ui/icons/adata-logo.vue'
10
+ import Arrow from '#adata-ui/icons/chevron/chevron-down.vue'
11
+ import Logo from '#adata-ui/icons/logo.vue'
12
+ import { buildLocalizedUrl, navigateToLocalizedPage } from '#adata-ui/utils/localizedNavigation'
13
+ import HeaderLink from './HeaderLink.vue'
14
+ import { useUrls } from '#adata-ui/composables/useUrls'
15
+
16
+ defineOptions({ name: 'AHeader' })
17
+
18
+ const props = withDefaults(defineProps<Props>(), {
19
+ limitRemaining: 0,
20
+ daysRemaining: 0,
21
+ balance: 0,
22
+ rate: 'Базовый',
23
+ showLogIn: true,
24
+ mobileHeaderType: 'default',
25
+ module: 'pk',
26
+ })
27
+
28
+ const emit = defineEmits(['logout', 'search', 'login'])
29
+
30
+ interface Props {
31
+ replenish?: string
32
+ hasNotification?: boolean
33
+ email: string | undefined
34
+ rate: string
35
+ daysRemaining: number
36
+ limitRemaining: number
37
+ balance: number
38
+ isAuthenticated: boolean
39
+ showLogIn?: boolean
40
+ mobileHeaderType?: 'search' | 'default'
41
+ module?: ProjectKeys
42
+ oldVersion?: string
43
+ }
44
+
45
+ const { t } = useI18n()
46
+ const { locale } = useI18n()
47
+
48
+ useCurrentModule().value = props.module
49
+ const appConfig = useAppConfig()
50
+ const { myLayer }: any = useAppConfig()
51
+ const urls = useUrls()
52
+
53
+ const langIsOn = appConfig.myLayer.langIsOn
54
+ const contacts = ref(useContacts())
55
+ const { loginModal } = useIdModals()
56
+
57
+ function goAuth() {
58
+ if (myLayer.authMode !== 'local') {
59
+ if (window) {
60
+ emit('login')
61
+ let fullPath = encodeURIComponent(window.location.toString())
62
+ if (fullPath.includes('basic-info')) {
63
+ fullPath = fullPath.replace('%2Fcounterparty%2Fmain', '').replace('%2Fbasic-info', '')
64
+ }
65
+
66
+ navigateToLocalizedPage({
67
+ locale,
68
+ projectUrl: urls.login,
69
+ path: `/?url=${fullPath}`,
70
+ target: '_self',
71
+ })
72
+ }
73
+ }
74
+ else {
75
+ loginModal.value = true
76
+ }
77
+ }
78
+
79
+ function goToAnotherModule() {
80
+ location.href = buildLocalizedUrl(locale.value, urls.landing, '')
81
+ }
82
+
83
+ async function fetchContacts() {
84
+ try {
85
+ const response = await fetch(
86
+ 'https://pk-api.adata.kz/api/v1/data/counterparty/contacts/sales-department',
87
+ )
88
+ const { data } = await response.json()
89
+ contacts.value = data
90
+ }
91
+ catch (e) {
92
+ console.error(e.message)
93
+ }
94
+ }
95
+
96
+ onBeforeMount(() => {
97
+ fetchContacts()
98
+ })
99
+ </script>
100
+
101
+ <template>
102
+ <div>
103
+ <top-header
104
+ :days-remaining="daysRemaining"
105
+ :is-authenticated="isAuthenticated"
106
+ :module-name="module"
107
+ :limit-remaining="limitRemaining"
108
+ />
109
+ <header
110
+ class="relative h-16 border-b border-deepblue-900/10 bg-white dark:border-gray-200/10 dark:bg-gray-900"
111
+ >
112
+ <div class="a-container mobile-padding flex h-full items-center justify-between gap-2">
113
+ <!-- Desktop hidden -->
114
+ <section
115
+ id="mobile-header"
116
+ class="grow lg:hidden"
117
+ >
118
+ <div
119
+ v-if="mobileHeaderType === 'default'"
120
+ class="flex justify-center"
121
+ >
122
+ <div
123
+ class="text-deepblue dark:text-[#E3E5E8]"
124
+ @click="goToAnotherModule"
125
+ >
126
+ <span class="visually-hidden"> Сервисы Adata.kz</span>
127
+
128
+ <adata-logo
129
+ :font-controlled="false"
130
+ filled
131
+ />
132
+ </div>
133
+ </div>
134
+ <div
135
+ v-else-if="mobileHeaderType === 'search'"
136
+ class="flex w-full items-center gap-2 bg-white dark:bg-gray-900 lg:hidden"
137
+ >
138
+ <logo
139
+ class="dark:text-gray-200"
140
+ @click="goToAnotherModule"
141
+ />
142
+ <button
143
+ class="flex w-full items-center gap-2 rounded bg-gray-50 px-4 py-1.5 dark:bg-gray-800 dark:text-gray-500"
144
+ @click="$emit('search')"
145
+ >
146
+ <a-icon-search />
147
+ <span class="body-400">Найти</span>
148
+ </button>
149
+ </div>
150
+ </section>
151
+ <div class="lg:hidden">
152
+ <lang-switcher
153
+ v-if="langIsOn || module === 'fea'"
154
+ class="lg:hidden"
155
+ />
156
+ </div>
157
+ <!-- Mobile hidden -->
158
+ <nav class="hidden items-center gap-4 lg:flex" itemscope itemtype="https://schema.org/SiteNavigationElement" role="list">
159
+ <nuxt-link-locale
160
+ aria-label="Adata-logo"
161
+ :to="buildLocalizedUrl(locale, urls.landing)"
162
+ class="text-deepblue cursor-pointer dark:text-[#E3E5E8]"
163
+ @click="goToAnotherModule"
164
+ >
165
+ <adata-logo
166
+ :font-controlled="false"
167
+ filled
168
+ />
169
+ </nuxt-link-locale>
170
+ <header-link />
171
+ </nav>
172
+ <div class="text-deepblue hidden items-center gap-4 dark:text-[#E3E5E8] lg:flex">
173
+ <!-- Mobile hidden -->
174
+ <div class="hidden items-center gap-4 lg:flex">
175
+ <a-change-version
176
+ v-if="oldVersion"
177
+ :url="oldVersion"
178
+ />
179
+ <a-color-mode />
180
+ <lang-switcher v-if="langIsOn || module === 'fea'" />
181
+ </div>
182
+
183
+ <a-dropdown
184
+ v-show="isAuthenticated"
185
+ placement="right"
186
+ >
187
+ <template #default="{ onExpand, expanded }">
188
+ <div
189
+ class="hidden cursor-pointer items-center gap-2 text-sm font-semibold lg:flex"
190
+ @click.stop="onExpand"
191
+ >
192
+ <span>{{ email }}</span>
193
+ <arrow :class="{ 'rotate-180': expanded }" />
194
+ </div>
195
+ </template>
196
+ <template #content>
197
+ <profile-menu
198
+ :balance="balance"
199
+ :days-remaining="daysRemaining"
200
+ :limit-remaining="limitRemaining"
201
+ :rate="rate"
202
+ :replenish="replenish"
203
+ @logout="$emit('logout')"
204
+ />
205
+ </template>
206
+ </a-dropdown>
207
+ <a-button-login
208
+ v-show="!isAuthenticated && showLogIn"
209
+ @click="goAuth"
210
+ />
211
+ </div>
212
+ </div>
213
+ </header>
214
+ </div>
215
+ </template>
216
+
217
+ <style scoped></style>