adata-ui 2.1.18 → 2.1.20

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 -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 +156 -156
  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 -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,131 +1,131 @@
1
- <script setup lang="ts">
2
- import { PAGES } from '#adata-ui/shared/constans/pages'
3
-
4
- interface NavList {
5
- title: string
6
- to: string
7
- icon?: Component
8
- }
9
-
10
- const props = defineProps<{
11
- id: string
12
- icon?: Component
13
- title: string
14
- link: string
15
- badge?: boolean
16
- to: string
17
- navList: NavList[]
18
- currentModule: boolean
19
- }>()
20
-
21
- const colorMode = useColorMode()
22
-
23
- const isDark = computed(() => colorMode.value === 'dark')
24
-
25
- function isActive(itemPath: string) {
26
- if (!props.currentModule) return false
27
-
28
- const currentUrl = window.location.href.split('/').filter(item => !['kk', 'en'].includes(item)).join('/')
29
- const section = PAGES[props.id]
30
-
31
- const currentPath = itemPath.split('/').filter(item => !['kk', 'en'].includes(item)).join('/')
32
-
33
- if (currentUrl === currentPath) return true
34
-
35
- if (currentPath.endsWith('/')) {
36
- let atLeastOne = false
37
-
38
- for (const key in section) {
39
- const path = section[key]
40
- if (key !== 'main') {
41
- const includes = currentUrl.includes(path) || currentUrl.includes('car-result')
42
- if (includes) {
43
- atLeastOne = true
44
- break
45
- }
46
- }
47
- }
48
-
49
- return !atLeastOne
50
- }
51
-
52
- if (currentPath.includes('check-car')) {
53
- if (currentUrl.includes('car-result')) {
54
- return true
55
- }
56
- }
57
-
58
- for (const key in section) {
59
- const path = section[key]
60
- if (key !== 'main') {
61
- const includesBoth = currentUrl.includes(path) && currentUrl.startsWith(currentPath)
62
- if (includesBoth) {
63
- return true
64
- }
65
- }
66
- }
67
-
68
- return false
69
- }
70
- </script>
71
-
72
- <template>
73
- <div
74
- class="flex flex-col gap-2"
75
- :class="{ 'rounded-md bg-gray-50 p-2 dark:bg-gray-800': currentModule }"
76
- >
77
- <nuxt-link-locale class="flex items-center gap-2 pl-[10px] hover:text-blue-700 dark:hover:text-blue-500" :to="link">
78
- <p class="text-sm font-semibold">
79
- {{ title }}
80
- </p>
81
- <a-status-badge
82
- v-if="badge"
83
- type="primary"
84
- class="w-fit"
85
- size="xs"
86
- view="inverted"
87
- >
88
- NEW
89
- </a-status-badge>
90
- </nuxt-link-locale>
91
- <ul class="flex flex-col gap-2">
92
- <li
93
- v-for="item in navList"
94
- :key="item.title"
95
- class="flex w-full items-center gap-2 rounded-md px-[10px] py-[6px] hover:bg-blue-100 dark:hover:bg-gray-200/10 text-gray-600 dark:text-gray-200 hover:text-blue-700 dark:hover:text-blue-500"
96
- :class="{ 'bg-blue-100 dark:bg-gray-200/10': isActive(item.to) }"
97
- >
98
- <div class="rounded-lg p-1" :class="{ 'bg-gradient-blue-dark ': isDark, 'bg-gradient-blue-light': !isDark }">
99
- <component
100
- :is="item.icon"
101
- class="size-[18px] text-white dark:text-gray-900"
102
- />
103
- </div>
104
- <nuxt-link-locale
105
- v-if="item.to"
106
- :to="item.to"
107
- itemprop="name"
108
- class="inline-block normal-case w-full cursor-pointer align-middle text-sm font-semibold text-inherit hover:text-inherit"
109
- >
110
- {{ item.title }}
111
- </nuxt-link-locale>
112
- <div
113
- v-else
114
- class="inline-block w-full align-middle text-sm font-semibold text-gray-600 dark:text-gray-200"
115
- >
116
- {{ item.title }}
117
- </div>
118
- </li>
119
- </ul>
120
- </div>
121
- </template>
122
-
123
- <style scoped lang="scss">
124
- .bg-gradient-blue-dark {
125
- background: linear-gradient(236.46deg, #4FBDFF -2.39%, #1B98E2 79.1%);
126
- }
127
-
128
- .bg-gradient-blue-light {
129
- background: linear-gradient(236.46deg, #479FFF -2.39%, #0070EB 79.1%);
130
- }
131
- </style>
1
+ <script setup lang="ts">
2
+ import { PAGES } from '#adata-ui/shared/constans/pages'
3
+
4
+ interface NavList {
5
+ title: string
6
+ to: string
7
+ icon?: Component
8
+ }
9
+
10
+ const props = defineProps<{
11
+ id: string
12
+ icon?: Component
13
+ title: string
14
+ link: string
15
+ badge?: boolean
16
+ to: string
17
+ navList: NavList[]
18
+ currentModule: boolean
19
+ }>()
20
+
21
+ const colorMode = useColorMode()
22
+
23
+ const isDark = computed(() => colorMode.value === 'dark')
24
+
25
+ function isActive(itemPath: string) {
26
+ if (!props.currentModule) return false
27
+
28
+ const currentUrl = window.location.href.split('/').filter(item => !['kk', 'en'].includes(item)).join('/')
29
+ const section = PAGES[props.id]
30
+
31
+ const currentPath = itemPath.split('/').filter(item => !['kk', 'en'].includes(item)).join('/')
32
+
33
+ if (currentUrl === currentPath) return true
34
+
35
+ if (currentPath.endsWith('/')) {
36
+ let atLeastOne = false
37
+
38
+ for (const key in section) {
39
+ const path = section[key]
40
+ if (key !== 'main') {
41
+ const includes = currentUrl.includes(path) || currentUrl.includes('car-result')
42
+ if (includes) {
43
+ atLeastOne = true
44
+ break
45
+ }
46
+ }
47
+ }
48
+
49
+ return !atLeastOne
50
+ }
51
+
52
+ if (currentPath.includes('check-car')) {
53
+ if (currentUrl.includes('car-result')) {
54
+ return true
55
+ }
56
+ }
57
+
58
+ for (const key in section) {
59
+ const path = section[key]
60
+ if (key !== 'main') {
61
+ const includesBoth = currentUrl.includes(path) && currentUrl.startsWith(currentPath)
62
+ if (includesBoth) {
63
+ return true
64
+ }
65
+ }
66
+ }
67
+
68
+ return false
69
+ }
70
+ </script>
71
+
72
+ <template>
73
+ <div
74
+ class="flex flex-col gap-2"
75
+ :class="{ 'rounded-md bg-gray-50 p-2 dark:bg-gray-800': currentModule }"
76
+ >
77
+ <nuxt-link-locale class="flex items-center gap-2 pl-[10px] hover:text-blue-700 dark:hover:text-blue-500" :to="link">
78
+ <p class="text-sm font-semibold">
79
+ {{ title }}
80
+ </p>
81
+ <a-status-badge
82
+ v-if="badge"
83
+ type="primary"
84
+ class="w-fit"
85
+ size="xs"
86
+ view="inverted"
87
+ >
88
+ NEW
89
+ </a-status-badge>
90
+ </nuxt-link-locale>
91
+ <ul class="flex flex-col gap-2">
92
+ <li
93
+ v-for="item in navList"
94
+ :key="item.title"
95
+ class="flex w-full items-center gap-2 rounded-md px-[10px] py-[6px] hover:bg-blue-100 dark:hover:bg-gray-200/10 text-gray-600 dark:text-gray-200 hover:text-blue-700 dark:hover:text-blue-500"
96
+ :class="{ 'bg-blue-100 dark:bg-gray-200/10': isActive(item.to) }"
97
+ >
98
+ <div class="rounded-lg p-1" :class="{ 'bg-gradient-blue-dark ': isDark, 'bg-gradient-blue-light': !isDark }">
99
+ <component
100
+ :is="item.icon"
101
+ class="size-[18px] text-white dark:text-gray-900"
102
+ />
103
+ </div>
104
+ <nuxt-link-locale
105
+ v-if="item.to"
106
+ :to="item.to"
107
+ itemprop="name"
108
+ class="inline-block normal-case w-full cursor-pointer align-middle text-sm font-semibold text-inherit hover:text-inherit"
109
+ >
110
+ {{ item.title }}
111
+ </nuxt-link-locale>
112
+ <div
113
+ v-else
114
+ class="inline-block w-full align-middle text-sm font-semibold text-gray-600 dark:text-gray-200"
115
+ >
116
+ {{ item.title }}
117
+ </div>
118
+ </li>
119
+ </ul>
120
+ </div>
121
+ </template>
122
+
123
+ <style scoped lang="scss">
124
+ .bg-gradient-blue-dark {
125
+ background: linear-gradient(236.46deg, #4FBDFF -2.39%, #1B98E2 79.1%);
126
+ }
127
+
128
+ .bg-gradient-blue-light {
129
+ background: linear-gradient(236.46deg, #479FFF -2.39%, #0070EB 79.1%);
130
+ }
131
+ </style>
@@ -1,51 +1,51 @@
1
- <script lang="ts" setup>
2
- import iconUser from '#adata-ui/icons/user.vue'
3
-
4
- export interface Notification {
5
- id: number
6
- message: string
7
- date: string
8
- email: string
9
- status: string
10
- }
11
-
12
- defineProps<{
13
- notifications: Notification[]
14
- }>()
15
- </script>
16
- <template>
17
- <div class="flex w-[423px] flex-col gap-4 rounded-lg bg-white p-4 dark:bg-gray-900">
18
- <div class="flex items-center justify-between">
19
- <!-- <h4 class="heading-04">{{ $t('header.notifications.title') }}</h4>-->
20
- <h4 class="heading-04">Уведомления</h4>
21
- <ADigitBadge :value="`${notifications?.length} новых`" size="lg" />
22
- </div>
23
- <hr class="border-deepblue-900/5 dark:border-gray-200/5" />
24
-
25
- <ul v-if="notifications?.length" class="flex flex-col gap-2">
26
- <li
27
- v-for="(notification, idx) in notifications"
28
- :key="idx"
29
- class="flex items-center justify-between gap-2.5 rounded-md bg-gray-50 px-4 py-2 dark:bg-gray-950"
30
- >
31
- <div class="rounded-full bg-blue-500 p-2">
32
- <icon-user />
33
- </div>
34
- <div class="flex flex-col items-start gap-1 break-all">
35
- <p class="body-s-400">
36
- {{ notification.message + ' ' }}
37
- <a class="link-s-400" href="#">{{ notification.email }}</a>
38
- </p>
39
- <p class="text-[12px] leading-4 dark:text-gray-300">{{ notification.date }}</p>
40
- </div>
41
- </li>
42
- </ul>
43
-
44
- <div v-else class="flex flex-col items-center gap-4 py-8">
45
- <p class="body-400">Новых уведомлений нет</p>
46
- </div>
47
-
48
- <hr class="border-deepblue-900/5 dark:border-gray-200/5" />
49
- <AButton block>Посмотреть все уведомления</AButton>
50
- </div>
51
- </template>
1
+ <script lang="ts" setup>
2
+ import iconUser from '#adata-ui/icons/user.vue'
3
+
4
+ export interface Notification {
5
+ id: number
6
+ message: string
7
+ date: string
8
+ email: string
9
+ status: string
10
+ }
11
+
12
+ defineProps<{
13
+ notifications: Notification[]
14
+ }>()
15
+ </script>
16
+ <template>
17
+ <div class="flex w-[423px] flex-col gap-4 rounded-lg bg-white p-4 dark:bg-gray-900">
18
+ <div class="flex items-center justify-between">
19
+ <!-- <h4 class="heading-04">{{ $t('header.notifications.title') }}</h4>-->
20
+ <h4 class="heading-04">Уведомления</h4>
21
+ <ADigitBadge :value="`${notifications?.length} новых`" size="lg" />
22
+ </div>
23
+ <hr class="border-deepblue-900/5 dark:border-gray-200/5" />
24
+
25
+ <ul v-if="notifications?.length" class="flex flex-col gap-2">
26
+ <li
27
+ v-for="(notification, idx) in notifications"
28
+ :key="idx"
29
+ class="flex items-center justify-between gap-2.5 rounded-md bg-gray-50 px-4 py-2 dark:bg-gray-950"
30
+ >
31
+ <div class="rounded-full bg-blue-500 p-2">
32
+ <icon-user />
33
+ </div>
34
+ <div class="flex flex-col items-start gap-1 break-all">
35
+ <p class="body-s-400">
36
+ {{ notification.message + ' ' }}
37
+ <a class="link-s-400" href="#">{{ notification.email }}</a>
38
+ </p>
39
+ <p class="text-[12px] leading-4 dark:text-gray-300">{{ notification.date }}</p>
40
+ </div>
41
+ </li>
42
+ </ul>
43
+
44
+ <div v-else class="flex flex-col items-center gap-4 py-8">
45
+ <p class="body-400">Новых уведомлений нет</p>
46
+ </div>
47
+
48
+ <hr class="border-deepblue-900/5 dark:border-gray-200/5" />
49
+ <AButton block>Посмотреть все уведомления</AButton>
50
+ </div>
51
+ </template>
@@ -1,143 +1,143 @@
1
- <script setup lang="ts">
2
- import { useHeaderNavigationLinks } from '#adata-ui/composables/useHeaderNavigationLinks'
3
- import NavList from '#adata-ui/components/navigation/header/NavList.vue'
4
- import CardGallery from '#adata-ui/components/navigation/header/CardGallery.vue'
5
-
6
- const props = withDefaults(
7
- defineProps<{
8
- animation?: string
9
- index?: number
10
- url?: string
11
- }>(),
12
- {
13
- animation: 'next',
14
- index: 0,
15
- url: ''
16
- }
17
- )
18
-
19
- defineEmits(['outerClick', 'mouseOver'])
20
-
21
- const pageUrl = useRequestURL()
22
- const filteredItems = useHeaderNavigationLinks()
23
-
24
- function isCurrentModule(currentModule: string) {
25
- if (currentModule === 'fines') return 'avto'
26
- if (currentModule === 'analytics') return 'analytics-new'
27
- if (currentModule === 'compliance') return 'ac'
28
- if (currentModule === 'fea') return 'tnved'
29
- if (currentModule === 'tenders') return 'zakupki'
30
-
31
- return currentModule
32
- }
33
- </script>
34
-
35
- <template>
36
- <div class="capitalize">
37
- <div class="relative bg-white dark:bg-gray-950">
38
- <transition :name="animation">
39
- <div
40
- :key="index"
41
- class="a-container py-8"
42
- >
43
- <div class="flex justify-between gap-5">
44
- <div class="flex gap-[10px] divide-x divide-gray-500/50">
45
- <div class="flex flex-col gap-5 w-[290px]">
46
- <nav-list
47
- v-for="module in filteredItems.slice(0,3)"
48
- :id="module.key"
49
- :key="module.key"
50
- :current-module="pageUrl.hostname.startsWith(isCurrentModule(module.key))"
51
- :title="module.name"
52
- :link="module.link"
53
- :nav-list="module.items"
54
- :to="module.to"
55
- :icon="module.icon"
56
- :badge="module.is_new"
57
- />
58
- </div>
59
- <div class="flex flex-col gap-5 w-[290px] pl-[10px]">
60
- <nav-list
61
- v-for="module in filteredItems.slice(3,5)"
62
- :id="module.key"
63
- :key="module.key"
64
- :current-module="pageUrl.hostname.startsWith(isCurrentModule(module.key))"
65
- :title="module.name"
66
- :link="module.link"
67
- :nav-list="module.items"
68
- :to="module.to"
69
- :icon="module.icon"
70
- :badge="module.is_new"
71
- />
72
- </div>
73
- <div class="flex flex-col gap-5 w-[330px] pl-[10px]">
74
- <nav-list
75
- v-for="module in filteredItems.slice(5,8)"
76
- :id="module.key"
77
- :key="module.key"
78
- :current-module="pageUrl.hostname.startsWith(isCurrentModule(module.key))"
79
- :title="module.name"
80
- :link="module.link"
81
- :nav-list="module.items"
82
- :to="module.to"
83
- :icon="module.icon"
84
- :badge="module.is_new"
85
- />
86
- </div>
87
- </div>
88
- <card-gallery class="hidden xl:block" />
89
- </div>
90
- </div>
91
- </transition>
92
- <button
93
- class="absolute right-8 top-4"
94
- @click="$emit('outerClick')"
95
- >
96
- <a-icon-x-mark
97
- width="32"
98
- height="32"
99
- />
100
- </button>
101
- </div>
102
- </div>
103
- </template>
104
-
105
- <style scoped lang="scss">
106
- $percent: 30%;
107
- .next-enter-from,
108
- .next-leave-to {
109
- opacity: 0;
110
- transform: translateX($percent);
111
- position: absolute;
112
- }
113
-
114
- .next-enter-active {
115
- transition: all 0.6s cubic-bezier(0.175, 0.885, 0.32, 1.275);
116
- }
117
-
118
- .next-leave-active {
119
- transition: all 0.6s cubic-bezier(0.175, 0.885, 0.32, 1.275);
120
- opacity: 0;
121
- transform: translateX(-$percent);
122
- }
123
-
124
- // Backwards transition
125
-
126
- .prev-enter-from,
127
- .prev-leave-to {
128
- position: absolute;
129
-
130
- opacity: 0;
131
- transform: translateX(-$percent);
132
- }
133
-
134
- .prev-enter-active {
135
- transition: all 0.6s cubic-bezier(0.175, 0.885, 0.32, 1.275);
136
- }
137
-
138
- .prev-leave-active {
139
- transition: all 0.6s cubic-bezier(0.175, 0.885, 0.32, 1.275);
140
- opacity: 0;
141
- transform: translateX($percent);
142
- }
143
- </style>
1
+ <script setup lang="ts">
2
+ import { useHeaderNavigationLinks } from '#adata-ui/composables/useHeaderNavigationLinks'
3
+ import NavList from '#adata-ui/components/navigation/header/NavList.vue'
4
+ import CardGallery from '#adata-ui/components/navigation/header/CardGallery.vue'
5
+
6
+ const props = withDefaults(
7
+ defineProps<{
8
+ animation?: string
9
+ index?: number
10
+ url?: string
11
+ }>(),
12
+ {
13
+ animation: 'next',
14
+ index: 0,
15
+ url: ''
16
+ }
17
+ )
18
+
19
+ defineEmits(['outerClick', 'mouseOver'])
20
+
21
+ const pageUrl = useRequestURL()
22
+ const filteredItems = useHeaderNavigationLinks()
23
+
24
+ function isCurrentModule(currentModule: string) {
25
+ if (currentModule === 'fines') return 'avto'
26
+ if (currentModule === 'analytics') return 'analytics-new'
27
+ if (currentModule === 'compliance') return 'ac'
28
+ if (currentModule === 'fea') return 'tnved'
29
+ if (currentModule === 'tenders') return 'zakupki'
30
+
31
+ return currentModule
32
+ }
33
+ </script>
34
+
35
+ <template>
36
+ <div class="capitalize">
37
+ <div class="relative bg-white dark:bg-gray-950">
38
+ <transition :name="animation">
39
+ <div
40
+ :key="index"
41
+ class="a-container py-8"
42
+ >
43
+ <div class="flex justify-between gap-5">
44
+ <div class="flex gap-[10px] divide-x divide-gray-500/50">
45
+ <div class="flex flex-col gap-5 w-[290px]">
46
+ <nav-list
47
+ v-for="module in filteredItems.slice(0,3)"
48
+ :id="module.key"
49
+ :key="module.key"
50
+ :current-module="pageUrl.hostname.startsWith(isCurrentModule(module.key))"
51
+ :title="module.name"
52
+ :link="module.link"
53
+ :nav-list="module.items"
54
+ :to="module.to"
55
+ :icon="module.icon"
56
+ :badge="module.is_new"
57
+ />
58
+ </div>
59
+ <div class="flex flex-col gap-5 w-[290px] pl-[10px]">
60
+ <nav-list
61
+ v-for="module in filteredItems.slice(3,5)"
62
+ :id="module.key"
63
+ :key="module.key"
64
+ :current-module="pageUrl.hostname.startsWith(isCurrentModule(module.key))"
65
+ :title="module.name"
66
+ :link="module.link"
67
+ :nav-list="module.items"
68
+ :to="module.to"
69
+ :icon="module.icon"
70
+ :badge="module.is_new"
71
+ />
72
+ </div>
73
+ <div class="flex flex-col gap-5 w-[330px] pl-[10px]">
74
+ <nav-list
75
+ v-for="module in filteredItems.slice(5,8)"
76
+ :id="module.key"
77
+ :key="module.key"
78
+ :current-module="pageUrl.hostname.startsWith(isCurrentModule(module.key))"
79
+ :title="module.name"
80
+ :link="module.link"
81
+ :nav-list="module.items"
82
+ :to="module.to"
83
+ :icon="module.icon"
84
+ :badge="module.is_new"
85
+ />
86
+ </div>
87
+ </div>
88
+ <card-gallery class="hidden xl:block" />
89
+ </div>
90
+ </div>
91
+ </transition>
92
+ <button
93
+ class="absolute right-8 top-4"
94
+ @click="$emit('outerClick')"
95
+ >
96
+ <a-icon-x-mark
97
+ width="32"
98
+ height="32"
99
+ />
100
+ </button>
101
+ </div>
102
+ </div>
103
+ </template>
104
+
105
+ <style scoped lang="scss">
106
+ $percent: 30%;
107
+ .next-enter-from,
108
+ .next-leave-to {
109
+ opacity: 0;
110
+ transform: translateX($percent);
111
+ position: absolute;
112
+ }
113
+
114
+ .next-enter-active {
115
+ transition: all 0.6s cubic-bezier(0.175, 0.885, 0.32, 1.275);
116
+ }
117
+
118
+ .next-leave-active {
119
+ transition: all 0.6s cubic-bezier(0.175, 0.885, 0.32, 1.275);
120
+ opacity: 0;
121
+ transform: translateX(-$percent);
122
+ }
123
+
124
+ // Backwards transition
125
+
126
+ .prev-enter-from,
127
+ .prev-leave-to {
128
+ position: absolute;
129
+
130
+ opacity: 0;
131
+ transform: translateX(-$percent);
132
+ }
133
+
134
+ .prev-enter-active {
135
+ transition: all 0.6s cubic-bezier(0.175, 0.885, 0.32, 1.275);
136
+ }
137
+
138
+ .prev-leave-active {
139
+ transition: all 0.6s cubic-bezier(0.175, 0.885, 0.32, 1.275);
140
+ opacity: 0;
141
+ transform: translateX($percent);
142
+ }
143
+ </style>