adata-ui 2.1.22 → 2.1.24

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 -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 -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,406 +1,406 @@
1
- <script setup lang="ts">
2
- import Hummer from "#adata-ui/icons/hummer.vue";
3
- import Work from "#adata-ui/icons/work.vue";
4
- import Company from "#adata-ui/icons/company.vue";
5
- import Car from "#adata-ui/icons/car.vue";
6
- import IconArrowGraph from "#adata-ui/icons/arrow/arrow-graph-up.vue";
7
- import IconSearch from "#adata-ui/icons/search.vue"
8
- import IconUsers from "#adata-ui/icons/users.vue";
9
- import IconDocument from "#adata-ui/icons/hdocument.vue";
10
- import IconArrowCircle from "#adata-ui/icons/arrow/arrow-circle-down.vue";
11
- import IconScales from "#adata-ui/icons/scales/scale.vue";
12
- import IconLink from "#adata-ui/icons/link-chain.vue";
13
- import IconGlobe from "#adata-ui/icons/globe.vue";
14
- import IconBlock from "#adata-ui/icons/block.vue";
15
- import IconWork from "#adata-ui/icons/work-bag.vue";
16
- import IconDollar from "#adata-ui/icons/currency/currency-dollar.vue";
17
- import IconFile from "#adata-ui/icons/file/file.vue";
18
- import IconCheck from "#adata-ui/icons/hcheck.vue";
19
- import IconCheckCircle from "#adata-ui/icons/check/check-circle.vue";
20
- import IconCar from "#adata-ui/icons/car.vue";
21
- import IconTruck from "#adata-ui/icons/truck.vue";
22
- import IconCompany from "#adata-ui/icons/company.vue";
23
- import IconMedal from "#adata-ui/icons/medal.vue";
24
-
25
- import { disableBodyScroll, enableBodyScroll } from 'body-scroll-lock'
26
- import {PAGES} from "#adata-ui/shared/constans/pages";
27
- import { useUrls } from '#adata-ui/composables/useUrls'
28
-
29
- type Modules = 'counterparty' | 'work' | 'tender' | 'fines' | 'analytics'
30
-
31
- interface Props {
32
- topMargin?: number
33
- width?: string
34
- panelDuration: number
35
- overlayDuration: number
36
- zIndex: number | string
37
- }
38
-
39
- const props = withDefaults(defineProps<Props>(), {
40
- topMargin: 0,
41
- width: 'auto',
42
- panelDuration: 300,
43
- overlayDuration: 500,
44
- zIndex: 'auto'
45
- })
46
- const { myLayer }: any = useAppConfig()
47
- const urls = useUrls()
48
-
49
- const activeModule = ref<Modules | null>(null)
50
- const bottom = ref<HTMLElement | null>(null)
51
- const bottomHeight = ref(0)
52
- const windowHeight = ref(0)
53
- const open = ref(!!activeModule.value)
54
-
55
- const calculateSize = () => {
56
- if (window?.innerHeight > 0) windowHeight.value = window.innerHeight
57
-
58
- bottomHeight.value = bottom.value ? bottom.value.clientHeight : 0
59
- }
60
-
61
- const sidebarHeight = computed(() => {
62
- if (!windowHeight.value) return
63
-
64
- return windowHeight.value - props.topMargin - bottomHeight.value
65
- })
66
-
67
- const menu = ref<HTMLElement | null>(null)
68
- const isBodyAlreadyLocked = ref<boolean>(false)
69
- const zIndex = ref()
70
- const items = [
71
- {
72
- label: "Контрагенты",
73
- icon: Company,
74
- value: "counterparty"
75
- },
76
- {
77
- label: "Работа",
78
- icon: Work,
79
- value: "work"
80
- },
81
- {
82
- label: "Тендеры",
83
- icon: Hummer,
84
- value: "tender"
85
- },
86
- {
87
- label: "Штрафы",
88
- icon: Car,
89
- value: "fines"
90
- },
91
- {
92
- label: "Аналитика",
93
- icon: IconArrowGraph,
94
- value: "analytics"
95
- }
96
- ]
97
-
98
- const sideLinks = {
99
- counterparty: [
100
- {
101
- icon: IconSearch,
102
- label: "Проверка контрагентов",
103
- link: urls.pk + PAGES.pk.main
104
- },
105
- {
106
- icon: IconScales,
107
- label: "Сравнение контрагентов",
108
- link: myLayer.counterParty ? urls.pk + myLayer.counterParty + PAGES.pk.compare : urls.pk + PAGES.pk.compare
109
- },
110
- {
111
- icon: IconLink,
112
- label: "Косвенные связи",
113
- link: myLayer.counterParty ? urls.pk + myLayer.counterParty + '/search-connections/check' : urls.pk + PAGES.pk.connections
114
- },
115
- {
116
- icon: IconUsers,
117
- label: "Массовая проверка",
118
- link: myLayer.counterParty ? urls.pk + myLayer.counterParty + PAGES.pk.employees : urls.pk + PAGES.pk.employees
119
- },
120
- {
121
- icon: IconGlobe,
122
- label: "Зарубежные контрагенты",
123
- link: urls.pk + PAGES.pk.foreign
124
- },
125
- {
126
- icon: IconBlock,
127
- label: "Санкции",
128
- link: myLayer.counterParty ? urls.pk + myLayer.counterParty + PAGES.pk.sanctions : urls.pk + PAGES.pk.sanctions
129
- },
130
- {
131
- icon: IconDollar,
132
- label: "Офшоры",
133
- link: myLayer.counterParty ? urls.pk + myLayer.counterParty + PAGES.pk.offshore : urls.pk + PAGES.pk.offshore
134
- },
135
- {
136
- icon: IconDocument,
137
- label: "Экспресс проверка",
138
- link: "#"
139
- },
140
- {
141
- icon: IconArrowCircle,
142
- label: "Выгрузка данных",
143
- link: urls.pk + PAGES.pk.unload
144
- }
145
- ],
146
- work: [
147
- {
148
- icon: IconWork,
149
- label: "Вакансии",
150
- link: urls.work + PAGES.work.vacancy
151
- },
152
- {
153
- icon: IconDocument,
154
- label: "Резюме",
155
- link: urls.work + PAGES.work.summary
156
- },
157
- ],
158
- tender: [
159
- {
160
- icon: IconSearch,
161
- label: "Поиск тендеров",
162
- link: urls.tender + PAGES.tender.main
163
- },
164
- {
165
- icon: IconFile,
166
- label: "Поиск договоров",
167
- link: urls.tender + PAGES.tender.contracts
168
- },
169
- {
170
- icon: IconCheck,
171
- label: "Планы закупок",
172
- link: urls.tender + PAGES.tender.plans
173
- }
174
- ],
175
- fines: [
176
- {
177
- icon: IconCheckCircle,
178
- label: "Проверка штрафов",
179
- link: urls.avto + PAGES.fines.main
180
- },
181
- {
182
- icon: IconCar,
183
- label: "Проверка авто",
184
- link: urls.avto + PAGES.fines.avto
185
- },
186
- {
187
- icon: IconTruck,
188
- label: "Массовая проверка авто",
189
- link: urls.avto + PAGES.fines.bulk
190
- }
191
- ],
192
- analytics: [
193
- {
194
- icon: IconSearch,
195
- label: "Поиск клиентов",
196
- link: urls.analytics + PAGES.analytics.clients
197
- },
198
- {
199
- icon: IconCheck,
200
- label: "Анализ закупок",
201
- link: urls.analytics + PAGES.analytics.analysis
202
- },
203
- {
204
- icon: IconArrowGraph,
205
- label: "Индекс деловой активности",
206
- link: urls.analytics + PAGES.analytics.index
207
- },
208
- {
209
- icon: IconCompany,
210
- label: "Субьекты бизнеса",
211
- link: urls.analytics + PAGES.analytics.business
212
- },
213
- {
214
- icon: IconMedal,
215
- label: "Рейтинг налогоплательщиков",
216
- link: urls.analytics + PAGES.analytics.rating
217
- }
218
- ],
219
- }
220
- const currentLinks = ref(sideLinks.counterparty)
221
-
222
- const getMaxZIndex = () =>
223
- Math.max(
224
- ...Array.from(document.querySelectorAll('body *'), (el) =>
225
- parseFloat(window.getComputedStyle(el).zIndex)
226
- ).filter((zIndex) => !Number.isNaN(zIndex)),
227
- 0
228
- )
229
-
230
- onMounted(() => {
231
- zIndex.value = props.zIndex === 'auto' ? getMaxZIndex() : props.zIndex
232
- })
233
-
234
- const toggleBodyScroll = (el: HTMLBodyElement | HTMLDivElement, lock: boolean) => {
235
- if (lock) {
236
- setTimeout(() => {
237
- disableBodyScroll(el, { reserveScrollBarGap: true })
238
- }, 0)
239
- return
240
- }
241
-
242
- enableBodyScroll(el)
243
- document.documentElement.style.removeProperty('overflow')
244
- }
245
-
246
- watch(() => [
247
- bottom.value,
248
- props.topMargin,
249
- open.value
250
- ], () => {
251
- nextTick(() => calculateSize())
252
- })
253
-
254
- watch(
255
- () => [open.value, menu.value],
256
- (newVal, oldVal) => {
257
- const wasShown = oldVal ? oldVal[0] : false
258
- const [isShown, menuEl] = newVal
259
- const isOpening = isShown
260
- const isClosing = wasShown && !isShown
261
-
262
- if (!menuEl) return
263
- if (isOpening) isBodyAlreadyLocked.value = !!document.body.style.overflow
264
-
265
- if (isShown) {
266
- toggleBodyScroll(menuEl, true)
267
- return;
268
- }
269
-
270
- if (!isClosing || isBodyAlreadyLocked.value) return;
271
-
272
- setTimeout(() => {
273
- if (menuEl) toggleBodyScroll(menuEl, false)
274
- }, props.panelDuration)
275
- })
276
-
277
- watch(activeModule, (e) => {
278
- if (e) {
279
- currentLinks.value = sideLinks[e]
280
- }
281
- open.value = !!e;
282
- })
283
-
284
- const overlayStyles = computed(() => ({
285
- zIndex: zIndex.value,
286
- animationDuration: `${props.overlayDuration}ms`,
287
- pointerEvents: !open.value ? 'none' : 'all',
288
- top: `${props.topMargin}px`,
289
- bottom: `${bottomHeight.value}px`,
290
- height: `${sidebarHeight.value}px`,
291
- }))
292
-
293
- const panelStyles = computed(() => ({
294
- zIndex: zIndex.value,
295
- width: props.width === 'auto' ? '100%': props.width,
296
- height: `${sidebarHeight.value}px`,
297
- bottom: `${bottomHeight.value}px`,
298
- top: `${props.topMargin}px`,
299
- animationDuration: `${props.panelDuration}ms`
300
- }))
301
- </script>
302
-
303
- <template>
304
- <div class="lg:hidden">
305
- <Transition name="overlay">
306
- <div
307
- v-show="open"
308
- ref="overlay"
309
- class="w-full h-full fixed left-0 top-0 backdrop-blur bg-gray-200/20"
310
- :style="overlayStyles"
311
- @click="activeModule = null"
312
- />
313
- </Transition>
314
- <Transition name="slide">
315
- <div
316
- v-if="open"
317
- ref="menu"
318
- class="bg-white dark:bg-gray-900 fixed w-full h-full overflow-y-auto overflow-x-hidden px-4 py-5"
319
- :style="panelStyles"
320
- >
321
- <Transition
322
- mode="out-in"
323
- name="module-slide"
324
- >
325
- <div :key="activeModule ? activeModule : 0">
326
- <nuxt-link
327
- v-for="item in currentLinks"
328
- :key="item.label"
329
- :to="item.link"
330
- class="flex items-center gap-4 px-4 py-3 bg-gray-50 dark:bg-gray-800 mb-2 rounded"
331
- >
332
- <component
333
- :is="item.icon"
334
- class="w-6 h-6"
335
- />
336
- <span>{{ item.label }}</span>
337
- </nuxt-link>
338
- </div>
339
- </Transition>
340
- </div>
341
- </Transition>
342
- </div>
343
- <div
344
- ref="bottom"
345
- class="sticky bottom-0 lg:hidden z-10"
346
- >
347
- <a-bottom-navigation
348
- v-model="activeModule"
349
- :items="items"
350
- grow
351
- />
352
- </div>
353
- </template>
354
-
355
- <style scoped lang="scss">
356
- .slide-enter-active,
357
- .slide-leave-active {
358
- animation: slide-left;
359
- }
360
-
361
- .slide-leave-active {
362
- animation-direction: reverse;
363
- }
364
-
365
- .overlay-enter-active,
366
- .overlay-leave-active {
367
- animation: overlay-transition;
368
- }
369
-
370
- .overlay-leave-active {
371
- animation-direction: reverse;
372
- }
373
-
374
- .module-slide-enter-active,
375
- .module-slide-leave-active {
376
- transition: .2s ease-in-out;
377
- }
378
-
379
- .module-slide-enter-from,
380
- .module-slide-leave-to {
381
- transform: translateX(50px);
382
- opacity: 0;
383
- }
384
-
385
- @keyframes slide-left {
386
- 0% {
387
- opacity: 0;
388
- transform: translateX(-100%);
389
- }
390
-
391
- 100% {
392
- opacity: 1;
393
- transform: translateX(0);
394
- }
395
- }
396
-
397
- @keyframes overlay-transition {
398
- 0% {
399
- opacity: 0;
400
- }
401
-
402
- 100% {
403
- opacity: 1;
404
- }
405
- }
406
- </style>
1
+ <script setup lang="ts">
2
+ import Hummer from "#adata-ui/icons/hummer.vue";
3
+ import Work from "#adata-ui/icons/work.vue";
4
+ import Company from "#adata-ui/icons/company.vue";
5
+ import Car from "#adata-ui/icons/car.vue";
6
+ import IconArrowGraph from "#adata-ui/icons/arrow/arrow-graph-up.vue";
7
+ import IconSearch from "#adata-ui/icons/search.vue"
8
+ import IconUsers from "#adata-ui/icons/users.vue";
9
+ import IconDocument from "#adata-ui/icons/hdocument.vue";
10
+ import IconArrowCircle from "#adata-ui/icons/arrow/arrow-circle-down.vue";
11
+ import IconScales from "#adata-ui/icons/scales/scale.vue";
12
+ import IconLink from "#adata-ui/icons/link-chain.vue";
13
+ import IconGlobe from "#adata-ui/icons/globe.vue";
14
+ import IconBlock from "#adata-ui/icons/block.vue";
15
+ import IconWork from "#adata-ui/icons/work-bag.vue";
16
+ import IconDollar from "#adata-ui/icons/currency/currency-dollar.vue";
17
+ import IconFile from "#adata-ui/icons/file/file.vue";
18
+ import IconCheck from "#adata-ui/icons/hcheck.vue";
19
+ import IconCheckCircle from "#adata-ui/icons/check/check-circle.vue";
20
+ import IconCar from "#adata-ui/icons/car.vue";
21
+ import IconTruck from "#adata-ui/icons/truck.vue";
22
+ import IconCompany from "#adata-ui/icons/company.vue";
23
+ import IconMedal from "#adata-ui/icons/medal.vue";
24
+
25
+ import { disableBodyScroll, enableBodyScroll } from 'body-scroll-lock'
26
+ import {PAGES} from "#adata-ui/shared/constans/pages";
27
+ import { useUrls } from '#adata-ui/composables/useUrls'
28
+
29
+ type Modules = 'counterparty' | 'work' | 'tender' | 'fines' | 'analytics'
30
+
31
+ interface Props {
32
+ topMargin?: number
33
+ width?: string
34
+ panelDuration: number
35
+ overlayDuration: number
36
+ zIndex: number | string
37
+ }
38
+
39
+ const props = withDefaults(defineProps<Props>(), {
40
+ topMargin: 0,
41
+ width: 'auto',
42
+ panelDuration: 300,
43
+ overlayDuration: 500,
44
+ zIndex: 'auto'
45
+ })
46
+ const { myLayer }: any = useAppConfig()
47
+ const urls = useUrls()
48
+
49
+ const activeModule = ref<Modules | null>(null)
50
+ const bottom = ref<HTMLElement | null>(null)
51
+ const bottomHeight = ref(0)
52
+ const windowHeight = ref(0)
53
+ const open = ref(!!activeModule.value)
54
+
55
+ const calculateSize = () => {
56
+ if (window?.innerHeight > 0) windowHeight.value = window.innerHeight
57
+
58
+ bottomHeight.value = bottom.value ? bottom.value.clientHeight : 0
59
+ }
60
+
61
+ const sidebarHeight = computed(() => {
62
+ if (!windowHeight.value) return
63
+
64
+ return windowHeight.value - props.topMargin - bottomHeight.value
65
+ })
66
+
67
+ const menu = ref<HTMLElement | null>(null)
68
+ const isBodyAlreadyLocked = ref<boolean>(false)
69
+ const zIndex = ref()
70
+ const items = [
71
+ {
72
+ label: "Контрагенты",
73
+ icon: Company,
74
+ value: "counterparty"
75
+ },
76
+ {
77
+ label: "Работа",
78
+ icon: Work,
79
+ value: "work"
80
+ },
81
+ {
82
+ label: "Тендеры",
83
+ icon: Hummer,
84
+ value: "tender"
85
+ },
86
+ {
87
+ label: "Штрафы",
88
+ icon: Car,
89
+ value: "fines"
90
+ },
91
+ {
92
+ label: "Аналитика",
93
+ icon: IconArrowGraph,
94
+ value: "analytics"
95
+ }
96
+ ]
97
+
98
+ const sideLinks = {
99
+ counterparty: [
100
+ {
101
+ icon: IconSearch,
102
+ label: "Проверка контрагентов",
103
+ link: urls.pk + PAGES.pk.main
104
+ },
105
+ {
106
+ icon: IconScales,
107
+ label: "Сравнение контрагентов",
108
+ link: myLayer.counterParty ? urls.pk + myLayer.counterParty + PAGES.pk.compare : urls.pk + PAGES.pk.compare
109
+ },
110
+ {
111
+ icon: IconLink,
112
+ label: "Косвенные связи",
113
+ link: myLayer.counterParty ? urls.pk + myLayer.counterParty + '/search-connections/check' : urls.pk + PAGES.pk.connections
114
+ },
115
+ {
116
+ icon: IconUsers,
117
+ label: "Массовая проверка",
118
+ link: myLayer.counterParty ? urls.pk + myLayer.counterParty + PAGES.pk.employees : urls.pk + PAGES.pk.employees
119
+ },
120
+ {
121
+ icon: IconGlobe,
122
+ label: "Зарубежные контрагенты",
123
+ link: urls.pk + PAGES.pk.foreign
124
+ },
125
+ {
126
+ icon: IconBlock,
127
+ label: "Санкции",
128
+ link: myLayer.counterParty ? urls.pk + myLayer.counterParty + PAGES.pk.sanctions : urls.pk + PAGES.pk.sanctions
129
+ },
130
+ {
131
+ icon: IconDollar,
132
+ label: "Офшоры",
133
+ link: myLayer.counterParty ? urls.pk + myLayer.counterParty + PAGES.pk.offshore : urls.pk + PAGES.pk.offshore
134
+ },
135
+ {
136
+ icon: IconDocument,
137
+ label: "Экспресс проверка",
138
+ link: "#"
139
+ },
140
+ {
141
+ icon: IconArrowCircle,
142
+ label: "Выгрузка данных",
143
+ link: urls.pk + PAGES.pk.unload
144
+ }
145
+ ],
146
+ work: [
147
+ {
148
+ icon: IconWork,
149
+ label: "Вакансии",
150
+ link: urls.work + PAGES.work.vacancy
151
+ },
152
+ {
153
+ icon: IconDocument,
154
+ label: "Резюме",
155
+ link: urls.work + PAGES.work.summary
156
+ },
157
+ ],
158
+ tender: [
159
+ {
160
+ icon: IconSearch,
161
+ label: "Поиск тендеров",
162
+ link: urls.tender + PAGES.tender.main
163
+ },
164
+ {
165
+ icon: IconFile,
166
+ label: "Поиск договоров",
167
+ link: urls.tender + PAGES.tender.contracts
168
+ },
169
+ {
170
+ icon: IconCheck,
171
+ label: "Планы закупок",
172
+ link: urls.tender + PAGES.tender.plans
173
+ }
174
+ ],
175
+ fines: [
176
+ {
177
+ icon: IconCheckCircle,
178
+ label: "Проверка штрафов",
179
+ link: urls.avto + PAGES.fines.main
180
+ },
181
+ {
182
+ icon: IconCar,
183
+ label: "Проверка авто",
184
+ link: urls.avto + PAGES.fines.avto
185
+ },
186
+ {
187
+ icon: IconTruck,
188
+ label: "Массовая проверка авто",
189
+ link: urls.avto + PAGES.fines.bulk
190
+ }
191
+ ],
192
+ analytics: [
193
+ {
194
+ icon: IconSearch,
195
+ label: "Поиск клиентов",
196
+ link: urls.analytics + PAGES.analytics.clients
197
+ },
198
+ {
199
+ icon: IconCheck,
200
+ label: "Анализ закупок",
201
+ link: urls.analytics + PAGES.analytics.analysis
202
+ },
203
+ {
204
+ icon: IconArrowGraph,
205
+ label: "Индекс деловой активности",
206
+ link: urls.analytics + PAGES.analytics.index
207
+ },
208
+ {
209
+ icon: IconCompany,
210
+ label: "Субьекты бизнеса",
211
+ link: urls.analytics + PAGES.analytics.business
212
+ },
213
+ {
214
+ icon: IconMedal,
215
+ label: "Рейтинг налогоплательщиков",
216
+ link: urls.analytics + PAGES.analytics.rating
217
+ }
218
+ ],
219
+ }
220
+ const currentLinks = ref(sideLinks.counterparty)
221
+
222
+ const getMaxZIndex = () =>
223
+ Math.max(
224
+ ...Array.from(document.querySelectorAll('body *'), (el) =>
225
+ parseFloat(window.getComputedStyle(el).zIndex)
226
+ ).filter((zIndex) => !Number.isNaN(zIndex)),
227
+ 0
228
+ )
229
+
230
+ onMounted(() => {
231
+ zIndex.value = props.zIndex === 'auto' ? getMaxZIndex() : props.zIndex
232
+ })
233
+
234
+ const toggleBodyScroll = (el: HTMLBodyElement | HTMLDivElement, lock: boolean) => {
235
+ if (lock) {
236
+ setTimeout(() => {
237
+ disableBodyScroll(el, { reserveScrollBarGap: true })
238
+ }, 0)
239
+ return
240
+ }
241
+
242
+ enableBodyScroll(el)
243
+ document.documentElement.style.removeProperty('overflow')
244
+ }
245
+
246
+ watch(() => [
247
+ bottom.value,
248
+ props.topMargin,
249
+ open.value
250
+ ], () => {
251
+ nextTick(() => calculateSize())
252
+ })
253
+
254
+ watch(
255
+ () => [open.value, menu.value],
256
+ (newVal, oldVal) => {
257
+ const wasShown = oldVal ? oldVal[0] : false
258
+ const [isShown, menuEl] = newVal
259
+ const isOpening = isShown
260
+ const isClosing = wasShown && !isShown
261
+
262
+ if (!menuEl) return
263
+ if (isOpening) isBodyAlreadyLocked.value = !!document.body.style.overflow
264
+
265
+ if (isShown) {
266
+ toggleBodyScroll(menuEl, true)
267
+ return;
268
+ }
269
+
270
+ if (!isClosing || isBodyAlreadyLocked.value) return;
271
+
272
+ setTimeout(() => {
273
+ if (menuEl) toggleBodyScroll(menuEl, false)
274
+ }, props.panelDuration)
275
+ })
276
+
277
+ watch(activeModule, (e) => {
278
+ if (e) {
279
+ currentLinks.value = sideLinks[e]
280
+ }
281
+ open.value = !!e;
282
+ })
283
+
284
+ const overlayStyles = computed(() => ({
285
+ zIndex: zIndex.value,
286
+ animationDuration: `${props.overlayDuration}ms`,
287
+ pointerEvents: !open.value ? 'none' : 'all',
288
+ top: `${props.topMargin}px`,
289
+ bottom: `${bottomHeight.value}px`,
290
+ height: `${sidebarHeight.value}px`,
291
+ }))
292
+
293
+ const panelStyles = computed(() => ({
294
+ zIndex: zIndex.value,
295
+ width: props.width === 'auto' ? '100%': props.width,
296
+ height: `${sidebarHeight.value}px`,
297
+ bottom: `${bottomHeight.value}px`,
298
+ top: `${props.topMargin}px`,
299
+ animationDuration: `${props.panelDuration}ms`
300
+ }))
301
+ </script>
302
+
303
+ <template>
304
+ <div class="lg:hidden">
305
+ <Transition name="overlay">
306
+ <div
307
+ v-show="open"
308
+ ref="overlay"
309
+ class="w-full h-full fixed left-0 top-0 backdrop-blur bg-gray-200/20"
310
+ :style="overlayStyles"
311
+ @click="activeModule = null"
312
+ />
313
+ </Transition>
314
+ <Transition name="slide">
315
+ <div
316
+ v-if="open"
317
+ ref="menu"
318
+ class="bg-white dark:bg-gray-900 fixed w-full h-full overflow-y-auto overflow-x-hidden px-4 py-5"
319
+ :style="panelStyles"
320
+ >
321
+ <Transition
322
+ mode="out-in"
323
+ name="module-slide"
324
+ >
325
+ <div :key="activeModule ? activeModule : 0">
326
+ <nuxt-link
327
+ v-for="item in currentLinks"
328
+ :key="item.label"
329
+ :to="item.link"
330
+ class="flex items-center gap-4 px-4 py-3 bg-gray-50 dark:bg-gray-800 mb-2 rounded"
331
+ >
332
+ <component
333
+ :is="item.icon"
334
+ class="w-6 h-6"
335
+ />
336
+ <span>{{ item.label }}</span>
337
+ </nuxt-link>
338
+ </div>
339
+ </Transition>
340
+ </div>
341
+ </Transition>
342
+ </div>
343
+ <div
344
+ ref="bottom"
345
+ class="sticky bottom-0 lg:hidden z-10"
346
+ >
347
+ <a-bottom-navigation
348
+ v-model="activeModule"
349
+ :items="items"
350
+ grow
351
+ />
352
+ </div>
353
+ </template>
354
+
355
+ <style scoped lang="scss">
356
+ .slide-enter-active,
357
+ .slide-leave-active {
358
+ animation: slide-left;
359
+ }
360
+
361
+ .slide-leave-active {
362
+ animation-direction: reverse;
363
+ }
364
+
365
+ .overlay-enter-active,
366
+ .overlay-leave-active {
367
+ animation: overlay-transition;
368
+ }
369
+
370
+ .overlay-leave-active {
371
+ animation-direction: reverse;
372
+ }
373
+
374
+ .module-slide-enter-active,
375
+ .module-slide-leave-active {
376
+ transition: .2s ease-in-out;
377
+ }
378
+
379
+ .module-slide-enter-from,
380
+ .module-slide-leave-to {
381
+ transform: translateX(50px);
382
+ opacity: 0;
383
+ }
384
+
385
+ @keyframes slide-left {
386
+ 0% {
387
+ opacity: 0;
388
+ transform: translateX(-100%);
389
+ }
390
+
391
+ 100% {
392
+ opacity: 1;
393
+ transform: translateX(0);
394
+ }
395
+ }
396
+
397
+ @keyframes overlay-transition {
398
+ 0% {
399
+ opacity: 0;
400
+ }
401
+
402
+ 100% {
403
+ opacity: 1;
404
+ }
405
+ }
406
+ </style>