@opengis/admin 0.1.75 → 0.1.77

Sign up to get free protection for your applications and to get access to all the features.
Files changed (137) hide show
  1. package/README.md +29 -29
  2. package/config.js +4 -4
  3. package/dist/{IconChevronDown-DpFXvgwL.js → IconChevronDown-C7p-qa08.js} +1 -1
  4. package/dist/{add-page-B34T9kD5.js → add-page-BjxUl0Xb.js} +1 -1
  5. package/dist/{admin-interface-B7RH9jC0.js → admin-interface-hP6bBpCA.js} +591 -534
  6. package/dist/{admin-view-CB6GnWqy.js → admin-view-Bg210Kja.js} +144 -139
  7. package/dist/admin.js +1 -1
  8. package/dist/admin.umd.cjs +51 -51
  9. package/dist/assets/favicon.svg +1 -0
  10. package/dist/assets/logo.svg +42 -0
  11. package/dist/{card-page-B2ZFa7Pi.js → card-page-DrVSEjOf.js} +3 -3
  12. package/dist/{card-view-BRWlfh-Z.js → card-view-CrrcS8Wm.js} +1 -1
  13. package/dist/{edit-page-BUhpjmtA.js → edit-page-CJxp0cdD.js} +1 -1
  14. package/dist/{import-file-C08TESFR.js → import-file-L1iBMu59.js} +4782 -4759
  15. package/dist/style.css +1 -1
  16. package/module/settings/card/admin.roles.table/access.hbs +27 -27
  17. package/module/settings/card/admin.roles.table/general_info.hbs +16 -16
  18. package/module/settings/card/admin.roles.table/index.yml +14 -14
  19. package/module/settings/card/admin.roles.table/users.hbs +27 -27
  20. package/module/settings/card/admin.routes.table/general_info.hbs +40 -40
  21. package/module/settings/card/admin.routes.table/index.yml +8 -8
  22. package/module/settings/card/admin.routes.table/users.hbs +33 -33
  23. package/module/settings/card/admin.users.table/general_info.hbs +25 -25
  24. package/module/settings/card/admin.users.table/index.yml +12 -12
  25. package/module/settings/card/admin.users.table/logs.hbs +30 -30
  26. package/module/settings/card/admin.users.table/user_roles.hbs +24 -24
  27. package/module/settings/cls/core.actions.json +13 -13
  28. package/module/settings/cls/core.scope.json +13 -13
  29. package/module/settings/cls/properties.site_status.json +13 -13
  30. package/module/settings/cls/properties.widget_status.json +13 -13
  31. package/module/settings/cls/users.user_type.json +13 -13
  32. package/module/settings/form/admin.access.form.json +36 -36
  33. package/module/settings/form/admin.custom_column.form.json +71 -71
  34. package/module/settings/form/admin.properties.form.json +15 -15
  35. package/module/settings/form/admin.roles.form.json +19 -19
  36. package/module/settings/form/admin.routes.form.json +25 -25
  37. package/module/settings/form/admin.user_properties.form.json +15 -15
  38. package/module/settings/form/admin.user_roles.form.json +21 -21
  39. package/module/settings/form/admin.users.form.json +153 -153
  40. package/module/settings/form/user.user_roles.form.json +13 -13
  41. package/module/settings/interface/admin.properties.json +4 -4
  42. package/module/settings/interface/admin.roles.json +4 -4
  43. package/module/settings/interface/admin.routes.json +4 -4
  44. package/module/settings/interface/admin.users.json +4 -4
  45. package/module/settings/menu.json +50 -50
  46. package/module/settings/select/core.roles.json +2 -2
  47. package/module/settings/select/core.routes.sql +1 -1
  48. package/module/settings/select/core.user_mentioned.sql +2 -0
  49. package/module/settings/select/core.user_uid.sql +1 -1
  50. package/module/settings/table/admin.access.table.json +83 -83
  51. package/module/settings/table/admin.custom_column.table.json +99 -99
  52. package/module/settings/table/admin.properties.table.json +39 -39
  53. package/module/settings/table/admin.roles.table.json +64 -64
  54. package/module/settings/table/admin.routes.table.json +68 -68
  55. package/module/settings/table/admin.user_properties.table.json +34 -34
  56. package/module/settings/table/admin.user_roles.table.json +72 -72
  57. package/module/settings/table/admin.users.table.json +121 -121
  58. package/package.json +82 -82
  59. package/plugin.js +27 -24
  60. package/server/helpers/controllers/badge.js +11 -11
  61. package/server/helpers/controllers/hb.js +2 -2
  62. package/server/helpers/controllers/map.js +2 -2
  63. package/server/helpers/controllers/mls.js +2 -2
  64. package/server/helpers/controllers/vue.js +2 -2
  65. package/server/helpers/index.mjs +15 -13
  66. package/server/plugins/adminHook.js +93 -93
  67. package/server/plugins/cron.js +10 -10
  68. package/server/plugins/docs.js +28 -28
  69. package/server/plugins/hook.js +214 -214
  70. package/server/plugins/vite.js +71 -71
  71. package/server/routes/calendar/controllers/calendar.data.js +88 -88
  72. package/server/routes/calendar/index.mjs +7 -7
  73. package/server/routes/calendar/schema.js +21 -21
  74. package/server/routes/data/controllers/cardData.js +61 -57
  75. package/server/routes/data/controllers/cardTabData.js +49 -49
  76. package/server/routes/data/controllers/funcs/getFilterSQL/index.js +92 -92
  77. package/server/routes/data/controllers/funcs/getFilterSQL/util/formatValue.js +170 -170
  78. package/server/routes/data/controllers/funcs/getFilterSQL/util/getCustomQuery.js +13 -13
  79. package/server/routes/data/controllers/funcs/getFilterSQL/util/getFilterQuery.js +64 -64
  80. package/server/routes/data/controllers/funcs/getFilterSQL/util/getOptimizedQuery.js +12 -12
  81. package/server/routes/data/controllers/funcs/getFilterSQL/util/getTableSql.js +34 -34
  82. package/server/routes/data/controllers/tableData.js +11 -10
  83. package/server/routes/data/controllers/tableDataId.js +27 -25
  84. package/server/routes/data/controllers/tableFilter.js +63 -63
  85. package/server/routes/data/controllers/utils/assignTokens.js +30 -30
  86. package/server/routes/data/controllers/utils/getColumns.js +8 -8
  87. package/server/routes/data/index.mjs +15 -15
  88. package/server/routes/data/schema.js +54 -54
  89. package/server/routes/menu/controllers/getMenu.js +67 -67
  90. package/server/routes/menu/index.mjs +5 -5
  91. package/server/routes/notifications/controllers/readNotifications.js +27 -23
  92. package/server/routes/notifications/controllers/testEmail.js +35 -0
  93. package/server/routes/notifications/controllers/userNotifications.js +57 -57
  94. package/server/routes/notifications/funcs/addNotification.js +21 -0
  95. package/server/routes/notifications/funcs/sendNotification.js +105 -0
  96. package/server/routes/notifications/funcs/utils/sendEmail.js +39 -0
  97. package/server/routes/notifications/hook/onWidgetSet.js +57 -57
  98. package/server/routes/notifications/index.mjs +27 -15
  99. package/server/routes/notifications/schema.js +17 -11
  100. package/server/routes/properties/controllers/admin.properties.get.js +29 -29
  101. package/server/routes/properties/controllers/user.properties.get.js +34 -34
  102. package/server/routes/properties/controllers/user.properties.post.js +30 -30
  103. package/server/routes/properties/funcs/getSettings.js +56 -56
  104. package/server/routes/properties/funcs/setSettings.js +44 -44
  105. package/server/routes/properties/funcs/utils/dataInsert.js +26 -26
  106. package/server/routes/properties/index.mjs +14 -14
  107. package/server/routes/properties/schema.js +10 -10
  108. package/server/routes/root.mjs +3 -3
  109. package/server/routes/templates/controllers/getTemplate.js +22 -22
  110. package/server/routes/templates/index.mjs +14 -14
  111. package/server/routes/templates/scheme.js +8 -8
  112. package/server/routes/user/controllers/user.cls.id.js +14 -0
  113. package/server/routes/user/controllers/user.cls.js +71 -0
  114. package/server/routes/user/controllers/user.cls.post.js +52 -0
  115. package/server/routes/user/controllers/user.info.js +17 -0
  116. package/server/routes/user/index.mjs +15 -0
  117. package/server/routes/user/schema.js +14 -0
  118. package/server/routes/widget/controllers/utils/historyFormat.js +75 -0
  119. package/server/routes/widget/controllers/utils/obj2db.js +13 -0
  120. package/server/routes/widget/controllers/widget.del.js +41 -0
  121. package/server/routes/widget/controllers/widget.get.js +96 -0
  122. package/server/routes/widget/controllers/widget.set.js +76 -0
  123. package/server/routes/widget/index.mjs +39 -0
  124. package/server/templates/cls/itree.recrzone_category.json +73 -73
  125. package/server/templates/cls/test.json +9 -9
  126. package/server/templates/form/admin.user_cls.data.form.json +49 -49
  127. package/server/templates/form/admin.user_group_rel.form.json +21 -21
  128. package/server/templates/form/cp_building.form.json +32 -32
  129. package/server/templates/form/form-user-pass.json +10 -10
  130. package/server/templates/form/form-user_group.json +39 -39
  131. package/server/templates/form/form-users.json +156 -156
  132. package/server/templates/form/user_group_access.form.json +22 -22
  133. package/server/templates/select/account_id.json +2 -2
  134. package/server/templates/table/gis.dataset.table.json +43 -43
  135. package/server/templates/table/management.user_group.table.json +112 -112
  136. package/server/templates/table/management.users.table.json +126 -126
  137. package/utils.js +26 -21
@@ -1,7 +1,7 @@
1
- import { _ as w, I as Q, u as B, V as F, a as O } from "./import-file-C08TESFR.js";
2
- import { openBlock as s, createElementBlock as r, createElementVNode as t, createStaticVNode as R, resolveComponent as _, normalizeClass as E, createTextVNode as L, toDisplayString as V, createVNode as c, Transition as T, withCtx as M, withDirectives as q, Fragment as N, renderList as S, vShow as G, ref as D, createCommentVNode as H, getCurrentInstance as J, watch as K, onBeforeUnmount as W, createBlock as X, withModifiers as Y } from "vue";
3
- import { I as ee } from "./IconChevronDown-DpFXvgwL.js";
4
- const te = {}, oe = {
1
+ import { _ as w, I as Q, u as B, s as F, V as R, a as O } from "./import-file-L1iBMu59.js";
2
+ import { openBlock as s, createElementBlock as r, createElementVNode as t, createStaticVNode as q, resolveComponent as v, normalizeClass as E, createTextVNode as L, toDisplayString as V, createVNode as c, Transition as T, withCtx as M, withDirectives as G, Fragment as N, renderList as S, vShow as J, ref as D, createCommentVNode as H, getCurrentInstance as K, watch as W, onBeforeUnmount as X, createBlock as Y, withModifiers as ee } from "vue";
3
+ import { I as te } from "./IconChevronDown-C7p-qa08.js";
4
+ const oe = {}, ne = {
5
5
  xmlns: "http://www.w3.org/2000/svg",
6
6
  viewBox: "0 0 24 24",
7
7
  fill: "none",
@@ -11,8 +11,8 @@ const te = {}, oe = {
11
11
  "stroke-linejoin": "round",
12
12
  class: "icon icon-tabler icons-tabler-outline icon-tabler-logout"
13
13
  };
14
- function ne(o, e, n, l, a, i) {
15
- return s(), r("svg", oe, e[0] || (e[0] = [
14
+ function se(o, e, n, l, a, i) {
15
+ return s(), r("svg", ne, e[0] || (e[0] = [
16
16
  t("path", {
17
17
  stroke: "none",
18
18
  d: "M0 0h24v24H0z",
@@ -23,18 +23,18 @@ function ne(o, e, n, l, a, i) {
23
23
  t("path", { d: "M18 15l3 -3" }, null, -1)
24
24
  ]));
25
25
  }
26
- const se = /* @__PURE__ */ w(te, [["render", ne]]), re = {}, ae = {
26
+ const re = /* @__PURE__ */ w(oe, [["render", se]]), ae = {}, le = {
27
27
  viewBox: "0 0 1823 249",
28
28
  fill: "none",
29
29
  xmlns: "http://www.w3.org/2000/svg"
30
30
  };
31
- function le(o, e, n, l, a, i) {
32
- return s(), r("svg", ae, e[0] || (e[0] = [
33
- R('<path d="M218.88 96.05C223.55 99.19 228.69 101.56 234.09 103.07V145.42C212.05 151.54 195.83 171.79 195.83 195.75C195.83 200.22 196.41 204.65 197.53 208.94L160.92 230.08C156.82 226.06 152.08 222.73 146.91 220.24V171.62C164.83 163.13 176.59 145.06 176.59 124.48C176.59 123.17 176.54 121.86 176.44 120.56L218.88 96.05ZM220.32 79.09L160.97 113.36C162.04 116.88 162.61 120.61 162.61 124.48C162.61 142.66 149.93 157.87 132.93 161.76V230.05C143.4 232.46 152.23 239.16 157.46 248.21L215 214.99C211.7 209.34 209.81 202.77 209.81 195.75C209.81 174.62 226.94 157.49 248.07 157.49V91.02C237.14 91.02 227.29 86.43 220.32 79.09Z" fill="#CE3936"></path><path d="M161.39 19.13L197.44 39.94C196.39 44.11 195.84 48.42 195.84 52.75C195.84 54.21 195.9 55.65 196.02 57.1L153.9 81.42C145.27 75.5 134.95 72.24 124.36 72.24C113.83 72.24 103.57 75.47 94.96 81.32L52.71 56.93C52.82 55.55 52.88 54.16 52.88 52.76C52.88 48.43 52.34 44.12 51.28 39.95L87.3 19.16C96.98 28.89 110.26 34.58 124.34 34.58C138.42 34.57 151.7 28.87 161.39 19.13ZM157.77 0.919983C151.24 12.66 138.71 20.6 124.33 20.6C109.95 20.6 97.44 12.67 90.9 0.939983L33.9 33.85C37.08 39.43 38.91 45.88 38.91 52.76C38.91 56.71 38.31 60.52 37.2 64.11L96.46 98.32C103.44 90.87 113.36 86.22 124.37 86.22C135.44 86.22 145.41 90.93 152.39 98.44L211.59 64.27C210.45 60.64 209.83 56.78 209.83 52.77C209.83 45.89 211.65 39.44 214.84 33.86L157.77 0.919983Z" fill="#CE3936"></path><path d="M29.97 95.95L72.28 120.38C72.17 121.74 72.12 123.1 72.12 124.47C72.12 145.02 83.86 163.08 101.74 171.58V220.23C96.58 222.71 91.84 226.04 87.75 230.05L51.17 208.93C52.29 204.64 52.87 200.21 52.87 195.74C52.87 171.78 36.65 151.53 14.61 145.41V103.06C20.07 101.55 25.27 99.14 29.97 95.95ZM28.5 78.97C21.52 86.38 11.63 91.02 0.640015 91.02V157.49C21.77 157.49 38.9 174.62 38.9 195.75C38.9 202.77 37 209.33 33.71 214.99L91.2 248.18C96.43 239.14 105.25 232.45 115.71 230.04V161.73C98.74 157.81 86.09 142.62 86.09 124.46C86.09 120.54 86.68 116.75 87.78 113.18L28.5 78.97Z" fill="#CE3936"></path><path d="M498.39 177.5V144.88C498.39 128.55 485.11 115.27 468.78 115.27H343.22C342.69 115.27 342.18 115.32 341.67 115.4H337.19C332.35 115.4 328.42 111.46 328.42 106.63V74C328.42 69.16 332.36 65.23 337.19 65.23H486.33C492.08 65.23 496.75 60.57 496.75 54.81C496.75 49.06 492.08 44.39 486.33 44.39H337.19C320.86 44.39 307.58 57.67 307.58 74V106.62C307.58 122.95 320.86 136.23 337.19 136.23H462.75C463.28 136.23 463.79 136.18 464.3 136.1H468.78C473.62 136.1 477.55 140.04 477.55 144.87V177.49C477.55 182.33 473.61 186.26 468.78 186.26H319.64C313.89 186.26 309.22 190.92 309.22 196.68C309.22 202.43 313.89 207.1 319.64 207.1H468.78C485.11 207.11 498.39 193.83 498.39 177.5Z" fill="#CE3935"></path><path d="M710.7 177.32V75.24C710.7 58.91 697.42 45.63 681.09 45.63H550.05C533.72 45.63 520.44 58.91 520.44 75.24V177.32C520.44 193.65 533.72 206.93 550.05 206.93H681.1C697.42 206.93 710.7 193.65 710.7 177.32ZM541.27 75.24C541.27 70.4 545.21 66.47 550.04 66.47H681.09C685.93 66.47 689.86 70.41 689.86 75.24V177.32C689.86 182.16 685.92 186.09 681.09 186.09H550.05C545.21 186.09 541.28 182.15 541.28 177.32V75.24H541.27Z" fill="#CE3935"></path><path d="M1823 177.32V75.24C1823 58.91 1809.72 45.63 1793.39 45.63H1662.34C1646.01 45.63 1632.73 58.91 1632.73 75.24V177.32C1632.73 193.65 1646.01 206.93 1662.34 206.93H1793.39C1809.72 206.93 1823 193.65 1823 177.32ZM1653.57 75.24C1653.57 70.4 1657.51 66.47 1662.34 66.47H1793.39C1798.23 66.47 1802.16 70.41 1802.16 75.24V177.32C1802.16 182.16 1798.22 186.09 1793.39 186.09H1662.34C1657.5 186.09 1653.57 182.15 1653.57 177.32V75.24Z" fill="#CE3935"></path><path d="M756.76 196.51V152H849.42C855.17 152 859.84 147.34 859.84 141.58C859.84 135.83 855.17 131.16 849.42 131.16H756.76V75.23C756.76 70.39 760.7 66.46 765.53 66.46H893.29C899.04 66.46 903.71 61.8 903.71 56.04C903.71 50.29 899.04 45.62 893.29 45.62H765.53C749.2 45.62 735.92 58.9 735.92 75.23V196.5C735.92 202.25 740.59 206.92 746.34 206.92C752.09 206.93 756.76 202.27 756.76 196.51Z" fill="#CE3935"></path><path d="M933.86 66.47H1006.51V194.32C1006.51 200.07 1011.18 204.74 1016.93 204.74C1022.68 204.74 1027.35 200.07 1027.35 194.32V66.47H1100C1105.75 66.47 1110.42 61.81 1110.42 56.05C1110.42 50.3 1105.76 45.63 1100 45.63H933.86C928.11 45.63 923.44 50.29 923.44 56.05C923.45 61.81 928.11 66.47 933.86 66.47Z" fill="#CE3935"></path><path d="M1218.44 204.19C1224.19 204.19 1228.86 199.53 1228.86 193.77V152H1368.13C1384.46 152 1397.74 138.72 1397.74 122.39V75.24C1397.74 58.91 1384.46 45.63 1368.13 45.63H1237.63C1221.3 45.63 1208.02 58.91 1208.02 75.24V193.77C1208.02 199.53 1212.68 204.19 1218.44 204.19ZM1237.63 66.47H1368.13C1372.97 66.47 1376.9 70.41 1376.9 75.24V122.39C1376.9 127.23 1372.96 131.16 1368.13 131.16H1228.86V75.23C1228.86 70.41 1232.79 66.47 1237.63 66.47Z" fill="#CE3935"></path><path d="M1430.64 204.19C1436.39 204.19 1441.06 199.53 1441.06 193.77V152H1523.95C1524.57 153.18 1525.42 154.26 1526.51 155.17L1581.89 201.23C1583.83 202.85 1586.2 203.64 1588.55 203.64C1591.54 203.64 1594.5 202.36 1596.57 199.88C1600.25 195.46 1599.64 188.89 1595.22 185.21L1555.29 152H1580.33C1596.66 152 1609.94 138.72 1609.94 122.39V75.24C1609.94 58.91 1596.66 45.63 1580.33 45.63H1449.83C1433.5 45.63 1420.22 58.91 1420.22 75.24V193.77C1420.22 199.53 1424.88 204.19 1430.64 204.19ZM1449.83 66.47H1580.33C1585.17 66.47 1589.1 70.41 1589.1 75.24V122.39C1589.1 127.23 1585.17 131.16 1580.33 131.16H1441.06V75.23C1441.05 70.41 1444.99 66.47 1449.83 66.47Z" fill="#CE3935"></path>', 10)
31
+ function ie(o, e, n, l, a, i) {
32
+ return s(), r("svg", le, e[0] || (e[0] = [
33
+ q('<path d="M218.88 96.05C223.55 99.19 228.69 101.56 234.09 103.07V145.42C212.05 151.54 195.83 171.79 195.83 195.75C195.83 200.22 196.41 204.65 197.53 208.94L160.92 230.08C156.82 226.06 152.08 222.73 146.91 220.24V171.62C164.83 163.13 176.59 145.06 176.59 124.48C176.59 123.17 176.54 121.86 176.44 120.56L218.88 96.05ZM220.32 79.09L160.97 113.36C162.04 116.88 162.61 120.61 162.61 124.48C162.61 142.66 149.93 157.87 132.93 161.76V230.05C143.4 232.46 152.23 239.16 157.46 248.21L215 214.99C211.7 209.34 209.81 202.77 209.81 195.75C209.81 174.62 226.94 157.49 248.07 157.49V91.02C237.14 91.02 227.29 86.43 220.32 79.09Z" fill="#CE3936"></path><path d="M161.39 19.13L197.44 39.94C196.39 44.11 195.84 48.42 195.84 52.75C195.84 54.21 195.9 55.65 196.02 57.1L153.9 81.42C145.27 75.5 134.95 72.24 124.36 72.24C113.83 72.24 103.57 75.47 94.96 81.32L52.71 56.93C52.82 55.55 52.88 54.16 52.88 52.76C52.88 48.43 52.34 44.12 51.28 39.95L87.3 19.16C96.98 28.89 110.26 34.58 124.34 34.58C138.42 34.57 151.7 28.87 161.39 19.13ZM157.77 0.919983C151.24 12.66 138.71 20.6 124.33 20.6C109.95 20.6 97.44 12.67 90.9 0.939983L33.9 33.85C37.08 39.43 38.91 45.88 38.91 52.76C38.91 56.71 38.31 60.52 37.2 64.11L96.46 98.32C103.44 90.87 113.36 86.22 124.37 86.22C135.44 86.22 145.41 90.93 152.39 98.44L211.59 64.27C210.45 60.64 209.83 56.78 209.83 52.77C209.83 45.89 211.65 39.44 214.84 33.86L157.77 0.919983Z" fill="#CE3936"></path><path d="M29.97 95.95L72.28 120.38C72.17 121.74 72.12 123.1 72.12 124.47C72.12 145.02 83.86 163.08 101.74 171.58V220.23C96.58 222.71 91.84 226.04 87.75 230.05L51.17 208.93C52.29 204.64 52.87 200.21 52.87 195.74C52.87 171.78 36.65 151.53 14.61 145.41V103.06C20.07 101.55 25.27 99.14 29.97 95.95ZM28.5 78.97C21.52 86.38 11.63 91.02 0.640015 91.02V157.49C21.77 157.49 38.9 174.62 38.9 195.75C38.9 202.77 37 209.33 33.71 214.99L91.2 248.18C96.43 239.14 105.25 232.45 115.71 230.04V161.73C98.74 157.81 86.09 142.62 86.09 124.46C86.09 120.54 86.68 116.75 87.78 113.18L28.5 78.97Z" fill="#CE3936"></path><path d="M498.39 177.5V144.88C498.39 128.55 485.11 115.27 468.78 115.27H343.22C342.69 115.27 342.18 115.32 341.67 115.4H337.19C332.35 115.4 328.42 111.46 328.42 106.63V74C328.42 69.16 332.36 65.23 337.19 65.23H486.33C492.08 65.23 496.75 60.57 496.75 54.81C496.75 49.06 492.08 44.39 486.33 44.39H337.19C320.86 44.39 307.58 57.67 307.58 74V106.62C307.58 122.95 320.86 136.23 337.19 136.23H462.75C463.28 136.23 463.79 136.18 464.3 136.1H468.78C473.62 136.1 477.55 140.04 477.55 144.87V177.49C477.55 182.33 473.61 186.26 468.78 186.26H319.64C313.89 186.26 309.22 190.92 309.22 196.68C309.22 202.43 313.89 207.1 319.64 207.1H468.78C485.11 207.11 498.39 193.83 498.39 177.5Z" fill="#CE3935"></path><path d="M710.7 177.32V75.24C710.7 58.91 697.42 45.63 681.09 45.63H550.05C533.72 45.63 520.44 58.91 520.44 75.24V177.32C520.44 193.65 533.72 206.93 550.05 206.93H681.1C697.42 206.93 710.7 193.65 710.7 177.32ZM541.27 75.24C541.27 70.4 545.21 66.47 550.04 66.47H681.09C685.93 66.47 689.86 70.41 689.86 75.24V177.32C689.86 182.16 685.92 186.09 681.09 186.09H550.05C545.21 186.09 541.28 182.15 541.28 177.32V75.24H541.27Z" fill="#CE3935"></path><path d="M1823 177.32V75.24C1823 58.91 1809.72 45.63 1793.39 45.63H1662.34C1646.01 45.63 1632.73 58.91 1632.73 75.24V177.32C1632.73 193.65 1646.01 206.93 1662.34 206.93H1793.39C1809.72 206.93 1823 193.65 1823 177.32ZM1653.57 75.24C1653.57 70.4 1657.51 66.47 1662.34 66.47H1793.39C1798.23 66.47 1802.16 70.41 1802.16 75.24V177.32C1802.16 182.16 1798.22 186.09 1793.39 186.09H1662.34C1657.5 186.09 1653.57 182.15 1653.57 177.32V75.24Z" fill="#CE3935"></path><path d="M756.76 196.51V152H849.42C855.17 152 859.84 147.34 859.84 141.58C859.84 135.83 855.17 131.16 849.42 131.16H756.76V75.23C756.76 70.39 760.7 66.46 765.53 66.46H893.29C899.04 66.46 903.71 61.8 903.71 56.04C903.71 50.29 899.04 45.62 893.29 45.62H765.53C749.2 45.62 735.92 58.9 735.92 75.23V196.5C735.92 202.25 740.59 206.92 746.34 206.92C752.09 206.93 756.76 202.27 756.76 196.51Z" fill="#CE3935"></path><path d="M933.86 66.47H1006.51V194.32C1006.51 200.07 1011.18 204.74 1016.93 204.74C1022.68 204.74 1027.35 200.07 1027.35 194.32V66.47H1100C1105.75 66.47 1110.42 61.81 1110.42 56.05C1110.42 50.3 1105.76 45.63 1100 45.63H933.86C928.11 45.63 923.44 50.29 923.44 56.05C923.45 61.81 928.11 66.47 933.86 66.47Z" fill="#CE3935"></path><path d="M1218.44 204.19C1224.19 204.19 1228.86 199.53 1228.86 193.77V152H1368.13C1384.46 152 1397.74 138.72 1397.74 122.39V75.24C1397.74 58.91 1384.46 45.63 1368.13 45.63H1237.63C1221.3 45.63 1208.02 58.91 1208.02 75.24V193.77C1208.02 199.53 1212.68 204.19 1218.44 204.19ZM1237.63 66.47H1368.13C1372.97 66.47 1376.9 70.41 1376.9 75.24V122.39C1376.9 127.23 1372.96 131.16 1368.13 131.16H1228.86V75.23C1228.86 70.41 1232.79 66.47 1237.63 66.47Z" fill="#CE3935"></path><path d="M1430.64 204.19C1436.39 204.19 1441.06 199.53 1441.06 193.77V152H1523.95C1524.57 153.18 1525.42 154.26 1526.51 155.17L1581.89 201.23C1583.83 202.85 1586.2 203.64 1588.55 203.64C1591.54 203.64 1594.5 202.36 1596.57 199.88C1600.25 195.46 1599.64 188.89 1595.22 185.21L1555.29 152H1580.33C1596.66 152 1609.94 138.72 1609.94 122.39V75.24C1609.94 58.91 1596.66 45.63 1580.33 45.63H1449.83C1433.5 45.63 1420.22 58.91 1420.22 75.24V193.77C1420.22 199.53 1424.88 204.19 1430.64 204.19ZM1449.83 66.47H1580.33C1585.17 66.47 1589.1 70.41 1589.1 75.24V122.39C1589.1 127.23 1585.17 131.16 1580.33 131.16H1441.06V75.23C1441.05 70.41 1444.99 66.47 1449.83 66.47Z" fill="#CE3935"></path>', 10)
34
34
  ]));
35
35
  }
36
- const ie = /* @__PURE__ */ w(re, [["render", le]]), ce = {
37
- components: { IconChevronDown: ee },
36
+ const ce = /* @__PURE__ */ w(ae, [["render", ie]]), ue = {
37
+ components: { IconChevronDown: te },
38
38
  props: { route: Object },
39
39
  mounted() {
40
40
  var o, e, n;
@@ -50,18 +50,18 @@ const ie = /* @__PURE__ */ w(re, [["render", le]]), ce = {
50
50
  isOpen: !1
51
51
  };
52
52
  }
53
- }, ue = {
53
+ }, de = {
54
54
  key: 0,
55
55
  class: ""
56
- }, de = { class: "ml-[30px] py-[6px] before:block before:absolute relative w-[196px] flex flex-col gap-[6px] inline-block before:w-[2px] before:h-[100%] before:bg-gray-100 before:left-[-14px] cursor-pointer" }, pe = { key: 1 };
57
- function fe(o, e, n, l, a, i) {
58
- var g, m, b, x, C, y, u, p, $, k, I, z, j;
59
- const v = _("IconChevronDown"), f = _("router-link");
60
- return (g = n.route) != null && g.menu ? (s(), r("div", ue, [
56
+ }, pe = { class: "ml-[30px] py-[6px] before:block before:absolute relative w-[196px] flex flex-col gap-[6px] inline-block before:w-[2px] before:h-[100%] before:bg-gray-100 before:left-[-14px] cursor-pointer" }, fe = { key: 1 };
57
+ function he(o, e, n, l, a, i) {
58
+ var g, C, x, _, m, y, u, p, $, k, I, z, j;
59
+ const b = v("IconChevronDown"), f = v("router-link");
60
+ return (g = n.route) != null && g.menu ? (s(), r("div", de, [
61
61
  t("button", {
62
62
  onClick: e[0] || (e[0] = (h) => a.isOpen = !a.isOpen),
63
63
  class: E(["flex cursor-pointer gap-x-3 py-2 px-3 text-sm text-gray-800 justify-start w-full border-none focus:outline-none text-gray-800 rounded-lg items-center hover:bg-gray-100 duration-300", [
64
- ((b = (m = n.route) == null ? void 0 : m.menu) == null ? void 0 : b.some(
64
+ ((x = (C = n.route) == null ? void 0 : C.menu) == null ? void 0 : x.some(
65
65
  (h) => {
66
66
  var d, Z;
67
67
  return (h == null ? void 0 : h.path) === o.$route.path.replace("/", "") || (h == null ? void 0 : h.table) === ((Z = (d = o.$route) == null ? void 0 : d.params) == null ? void 0 : Z.table) && (h == null ? void 0 : h.table);
@@ -69,8 +69,8 @@ function fe(o, e, n, l, a, i) {
69
69
  )) && "bg-gray-100"
70
70
  ]])
71
71
  }, [
72
- L(V((x = n.route) == null ? void 0 : x.ua) + " ", 1),
73
- c(v, {
72
+ L(V((_ = n.route) == null ? void 0 : _.ua) + " ", 1),
73
+ c(b, {
74
74
  class: E([[a.isOpen && "-rotate-180"], "ml-auto duration-300"]),
75
75
  width: "14",
76
76
  height: "14"
@@ -80,7 +80,7 @@ function fe(o, e, n, l, a, i) {
80
80
  default: M(() => {
81
81
  var h;
82
82
  return [
83
- q(t("ul", de, [
83
+ G(t("ul", pe, [
84
84
  (s(!0), r(N, null, S((h = n.route) == null ? void 0 : h.menu, (d, Z) => {
85
85
  var U, A;
86
86
  return s(), r("li", {
@@ -101,15 +101,15 @@ function fe(o, e, n, l, a, i) {
101
101
  ]);
102
102
  }), 128))
103
103
  ], 512), [
104
- [G, a.isOpen]
104
+ [J, a.isOpen]
105
105
  ])
106
106
  ];
107
107
  }),
108
108
  _: 1
109
109
  })
110
- ])) : (s(), r("div", pe, [
110
+ ])) : (s(), r("div", fe, [
111
111
  c(f, {
112
- to: ((y = (C = n.route) == null ? void 0 : C.path) == null ? void 0 : y[0]) === "/" ? (u = n.route) == null ? void 0 : u.path : "/" + ((p = n.route) == null ? void 0 : p.path),
112
+ to: ((y = (m = n.route) == null ? void 0 : m.path) == null ? void 0 : y[0]) === "/" ? (u = n.route) == null ? void 0 : u.path : "/" + ((p = n.route) == null ? void 0 : p.path),
113
113
  class: E([[
114
114
  ((($ = n.route) == null ? void 0 : $.path.replace("/", "")) === o.$route.path.replace("/", "") || ((I = (k = o.$route) == null ? void 0 : k.params) == null ? void 0 : I.table) === ((z = n.route) == null ? void 0 : z.table) && ((j = n.route) == null ? void 0 : j.table)) && "bg-gray-100"
115
115
  ], "flex gap-x-3 py-2 w-full font-[400] px-3 text-sm text-gray-800 rounded-lg items-center hover:bg-gray-100 duration-300 hover:text-gray-800"])
@@ -124,8 +124,8 @@ function fe(o, e, n, l, a, i) {
124
124
  }, 8, ["to", "class"])
125
125
  ]));
126
126
  }
127
- const he = /* @__PURE__ */ w(ce, [["render", fe]]), ge = {
128
- components: { IconLogout: se, NavbarItem: he, IconLogo: ie, IconSearch: Q },
127
+ const ge = /* @__PURE__ */ w(ue, [["render", he]]), xe = {
128
+ components: { IconLogout: re, NavbarItem: ge, IconLogo: ce, IconSearch: Q },
129
129
  data() {
130
130
  return {
131
131
  activeIndex: null,
@@ -141,6 +141,10 @@ const he = /* @__PURE__ */ w(ce, [["render", fe]]), ge = {
141
141
  return (i = (l = n == null ? void 0 : n.ua) == null ? void 0 : l.toLowerCase()) == null ? void 0 : i.includes((a = this.searchValue) == null ? void 0 : a.toLowerCase());
142
142
  }
143
143
  ) : B.value;
144
+ },
145
+ logo() {
146
+ var o;
147
+ return ((o = F.value) == null ? void 0 : o.logo) || "/assets/logo.svg";
144
148
  }
145
149
  },
146
150
  methods: {
@@ -151,29 +155,30 @@ const he = /* @__PURE__ */ w(ce, [["render", fe]]), ge = {
151
155
  }), e;
152
156
  }
153
157
  }
154
- }, xe = { class: "flex flex-col h-[100vh] border-r w-[260px] shrink-0" }, be = { class: "relative" }, _e = { class: "p-[16px] overflow-y-auto [&::-webkit-scrollbar]:w-2 [&::-webkit-scrollbar-thumb]:rounded-full [&::-webkit-scrollbar-track]:bg-gray-100 [&::-webkit-scrollbar-thumb]:bg-gray-300 dark:[&::-webkit-scrollbar-track]:bg-neutral-700 dark:[&::-webkit-scrollbar-thumb]:bg-neutral-500" }, ve = { class: "flex flex-col flex-wrap w-full pb-3" }, Ce = {
158
+ }, be = { class: "flex flex-col h-[100vh] border-r w-[260px] shrink-0" }, _e = ["src"], ve = { class: "relative" }, Ce = { class: "p-[16px] overflow-y-auto [&::-webkit-scrollbar]:w-2 [&::-webkit-scrollbar-thumb]:rounded-full [&::-webkit-scrollbar-track]:bg-gray-100 [&::-webkit-scrollbar-thumb]:bg-gray-300 dark:[&::-webkit-scrollbar-track]:bg-neutral-700 dark:[&::-webkit-scrollbar-thumb]:bg-neutral-500" }, we = { class: "flex flex-col flex-wrap w-full pb-3" }, me = {
155
159
  key: 0,
156
160
  class: "flex flex-col gap-[6px]"
157
- }, we = {
161
+ }, ye = {
158
162
  key: 1,
159
163
  class: "text-gray-800 text-lg mt-[20px]"
160
164
  };
161
- function me(o, e, n, l, a, i) {
162
- var b;
163
- const v = _("IconLogo"), f = _("IconSearch"), g = _("VsText"), m = _("NavbarItem");
164
- return s(), r("div", xe, [
165
- c(v, {
165
+ function ke(o, e, n, l, a, i) {
166
+ var C;
167
+ const b = v("IconSearch"), f = v("VsText"), g = v("NavbarItem");
168
+ return s(), r("div", be, [
169
+ t("img", {
170
+ src: i.logo,
166
171
  height: "40",
167
172
  width: "200",
168
173
  class: "my-[20px] ml-[20px]"
169
- }),
170
- t("div", be, [
171
- c(f, {
174
+ }, null, 8, _e),
175
+ t("div", ve, [
176
+ c(b, {
172
177
  height: "16",
173
178
  width: "16",
174
179
  class: "absolute top-[12px] left-[30px] text-gray-500 z-[1]"
175
180
  }),
176
- c(g, {
181
+ c(f, {
177
182
  type: "text",
178
183
  modelValue: a.searchValue,
179
184
  "onUpdate:modelValue": e[0] || (e[0] = (x) => a.searchValue = x),
@@ -182,21 +187,21 @@ function me(o, e, n, l, a, i) {
182
187
  class: "[&>input]:h-[40px] [&>input]:block [&>input]:rounded-none [&>input]:border-x-0 [&>input]:pl-[60px] [&>input:focus]:outline-none [&>input:focus]:focus:ring-0 [&>input:focus]:border-y-gray-200 [&>input:focus]:border-y-1 [&>input:focus]:border-x-0"
183
188
  }, null, 8, ["modelValue"])
184
189
  ]),
185
- t("div", _e, [
186
- t("nav", ve, [
187
- (b = i.data) != null && b.length ? (s(), r("ul", Ce, [
188
- (s(!0), r(N, null, S(i.data, (x, C) => (s(), r("li", {
189
- key: C,
190
+ t("div", Ce, [
191
+ t("nav", we, [
192
+ (C = i.data) != null && C.length ? (s(), r("ul", me, [
193
+ (s(!0), r(N, null, S(i.data, (x, _) => (s(), r("li", {
194
+ key: _,
190
195
  class: "flex flex-col gap-[6px]"
191
196
  }, [
192
- c(m, { route: x }, null, 8, ["route"])
197
+ c(g, { route: x }, null, 8, ["route"])
193
198
  ]))), 128))
194
- ])) : (s(), r("div", we, "Не знайдено"))
199
+ ])) : (s(), r("div", ye, "Не знайдено"))
195
200
  ])
196
201
  ])
197
202
  ]);
198
203
  }
199
- const ye = /* @__PURE__ */ w(ge, [["render", me]]), ke = {}, $e = {
204
+ const $e = /* @__PURE__ */ w(xe, [["render", ke]]), Ve = {}, Me = {
200
205
  class: "shrink-0",
201
206
  xmlns: "http://www.w3.org/2000/svg",
202
207
  width: "24",
@@ -208,13 +213,13 @@ const ye = /* @__PURE__ */ w(ge, [["render", me]]), ke = {}, $e = {
208
213
  "stroke-linecap": "round",
209
214
  "stroke-linejoin": "round"
210
215
  };
211
- function Ve(o, e) {
212
- return s(), r("svg", $e, e[0] || (e[0] = [
216
+ function He(o, e) {
217
+ return s(), r("svg", Me, e[0] || (e[0] = [
213
218
  t("path", { d: "M18 6 7 17l-5-5" }, null, -1),
214
219
  t("path", { d: "m22 10-7.5 7.5L13 16" }, null, -1)
215
220
  ]));
216
221
  }
217
- const Me = /* @__PURE__ */ w(ke, [["render", Ve]]), He = {}, Le = {
222
+ const Le = /* @__PURE__ */ w(Ve, [["render", He]]), Ie = {}, ze = {
218
223
  xmlns: "http://www.w3.org/2000/svg",
219
224
  width: "24",
220
225
  height: "24",
@@ -222,8 +227,8 @@ const Me = /* @__PURE__ */ w(ke, [["render", Ve]]), He = {}, Le = {
222
227
  fill: "currentColor",
223
228
  class: "icon icon-tabler icons-tabler-filled icon-tabler-user"
224
229
  };
225
- function Ie(o, e, n, l, a, i) {
226
- return s(), r("svg", Le, e[0] || (e[0] = [
230
+ function je(o, e, n, l, a, i) {
231
+ return s(), r("svg", ze, e[0] || (e[0] = [
227
232
  t("path", {
228
233
  stroke: "none",
229
234
  d: "M0 0h24v24H0z",
@@ -233,7 +238,7 @@ function Ie(o, e, n, l, a, i) {
233
238
  t("path", { d: "M14 14a5 5 0 0 1 5 5v1a2 2 0 0 1 -2 2h-10a2 2 0 0 1 -2 -2v-1a5 5 0 0 1 5 -5h4z" }, null, -1)
234
239
  ]));
235
240
  }
236
- const P = /* @__PURE__ */ w(He, [["render", Ie]]), ze = {}, je = {
241
+ const P = /* @__PURE__ */ w(Ie, [["render", je]]), Ee = {}, De = {
237
242
  class: "shrink-0 size-4",
238
243
  xmlns: "http://www.w3.org/2000/svg",
239
244
  width: "24",
@@ -245,27 +250,27 @@ const P = /* @__PURE__ */ w(He, [["render", Ie]]), ze = {}, je = {
245
250
  "stroke-linecap": "round",
246
251
  "stroke-linejoin": "round"
247
252
  };
248
- function Ee(o, e) {
249
- return s(), r("svg", je, e[0] || (e[0] = [
253
+ function Oe(o, e) {
254
+ return s(), r("svg", De, e[0] || (e[0] = [
250
255
  t("polyline", { points: "9 11 12 14 22 4" }, null, -1),
251
256
  t("path", { d: "M21 12v7a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h11" }, null, -1)
252
257
  ]));
253
258
  }
254
- const De = /* @__PURE__ */ w(ze, [["render", Ee]]), Oe = { class: "relative shrink-0" }, Ze = ["src"], Ne = {
259
+ const Ze = /* @__PURE__ */ w(Ee, [["render", Oe]]), Ne = { class: "relative shrink-0" }, Be = ["src"], Se = {
255
260
  key: 1,
256
261
  class: "h-[38px] w-[38px] bg-gray-200 rounded-full flex items-center justify-center"
257
- }, Be = {
262
+ }, Ue = {
258
263
  key: 2,
259
264
  class: "absolute top-4 -start-3 size-2 bg-blue-600 rounded-full dark:bg-blue-500"
260
- }, Se = { class: "grow" }, Ue = { class: "text-xs text-gray-500 dark:text-neutral-500" }, Ae = { class: "block text-sm font-medium text-gray-800 dark:text-neutral-300" }, Te = { class: "text-sm text-gray-500 dark:text-neutral-500" }, Pe = {
265
+ }, Ae = { class: "grow" }, Te = { class: "text-xs text-gray-500 dark:text-neutral-500" }, Pe = { class: "block text-sm font-medium text-gray-800 dark:text-neutral-300" }, Qe = { class: "text-sm text-gray-500 dark:text-neutral-500" }, Fe = {
261
266
  key: 0,
262
267
  class: "sm:group-hover:opacity-100 sm:opacity-0 sm:absolute sm:top-5 sm:end-5 inline-block p-0.5 bg-white border border-gray-200 rounded-lg shadow-sm transition ease-out"
263
- }, Qe = {
268
+ }, Re = {
264
269
  __name: "admin-notification-item",
265
270
  props: { item: Object },
266
271
  emits: ["update-notification"],
267
272
  setup(o, { emit: e }) {
268
- const n = e, l = D(!1), a = () => l.value = !0, i = () => l.value = !1, v = async () => {
273
+ const n = e, l = D(!1), a = () => l.value = !0, i = () => l.value = !1, b = async () => {
269
274
  var f;
270
275
  try {
271
276
  await O.get(`/api/notification-read/${(f = o.item) == null ? void 0 : f.id}`), await n("update-notification");
@@ -273,46 +278,46 @@ const De = /* @__PURE__ */ w(ze, [["render", Ee]]), Oe = { class: "relative shri
273
278
  }
274
279
  };
275
280
  return (f, g) => {
276
- var b, x, C, y, u, p;
277
- const m = _("VsPopover");
281
+ var x, _, m, y, u, p;
282
+ const C = v("VsPopover");
278
283
  return s(), r("li", {
279
- class: E(["relative group w-full flex gap-x-5 text-start p-5 border-b", [(b = o.item) != null && b.read ? "bg-gray-100" : "bg-white"]]),
284
+ class: E(["relative group w-full flex gap-x-5 text-start p-5 border-b", [(x = o.item) != null && x.read ? "bg-gray-100" : "bg-white"]]),
280
285
  onMouseenter: a,
281
286
  onMouseleave: i
282
287
  }, [
283
- t("div", Oe, [
284
- (x = o.item) != null && x.avatar ? (s(), r("img", {
288
+ t("div", Ne, [
289
+ (_ = o.item) != null && _.avatar ? (s(), r("img", {
285
290
  key: 0,
286
291
  class: "shrink-0 size-[38px] rounded-full",
287
- src: (C = o.item) == null ? void 0 : C.avatar,
292
+ src: (m = o.item) == null ? void 0 : m.avatar,
288
293
  alt: "Avatar"
289
- }, null, 8, Ze)) : (s(), r("div", Ne, [
294
+ }, null, 8, Be)) : (s(), r("div", Se, [
290
295
  c(P)
291
296
  ])),
292
- (y = o.item) != null && y.read ? (s(), r("span", Be)) : H("", !0)
297
+ (y = o.item) != null && y.read ? (s(), r("span", Ue)) : H("", !0)
293
298
  ]),
294
- t("div", Se, [
295
- t("p", Ue, [
296
- c(F, {
299
+ t("div", Ae, [
300
+ t("p", Te, [
301
+ c(R, {
297
302
  name: "cdate",
298
303
  data: o.item
299
304
  }, null, 8, ["data"])
300
305
  ]),
301
- t("span", Ae, V((u = o.item) == null ? void 0 : u.author), 1),
302
- t("p", Te, V((p = o.item) == null ? void 0 : p.subject), 1)
306
+ t("span", Pe, V((u = o.item) == null ? void 0 : u.author), 1),
307
+ t("p", Qe, V((p = o.item) == null ? void 0 : p.subject), 1)
303
308
  ]),
304
- l.value ? (s(), r("div", Pe, [
305
- c(m, {
309
+ l.value ? (s(), r("div", Fe, [
310
+ c(C, {
306
311
  trigger: "hover",
307
312
  placement: "left"
308
313
  }, {
309
314
  reference: M(() => [
310
315
  t("button", {
311
- onClick: v,
316
+ onClick: b,
312
317
  type: "button",
313
318
  class: "hs-tooltip-toggle hs-tooltip relative inline-block size-7 flex shrink-0 justify-center items-center text-gray-500 hover:bg-gray-100 hover:text-gray-800 rounded"
314
319
  }, [
315
- c(De)
320
+ c(Ze)
316
321
  ])
317
322
  ]),
318
323
  default: M(() => [
@@ -324,7 +329,7 @@ const De = /* @__PURE__ */ w(ze, [["render", Ee]]), Oe = { class: "relative shri
324
329
  ], 34);
325
330
  };
326
331
  }
327
- }, Fe = {}, Re = {
332
+ }, qe = {}, Ge = {
328
333
  class: "flex-shrink-0 size-4",
329
334
  xmlns: "http://www.w3.org/2000/svg",
330
335
  viewBox: "0 0 24 24",
@@ -334,13 +339,13 @@ const De = /* @__PURE__ */ w(ze, [["render", Ee]]), Oe = { class: "relative shri
334
339
  "stroke-linecap": "round",
335
340
  "stroke-linejoin": "round"
336
341
  };
337
- function qe(o, e, n, l, a, i) {
338
- return s(), r("svg", Re, e[0] || (e[0] = [
342
+ function Je(o, e, n, l, a, i) {
343
+ return s(), r("svg", Ge, e[0] || (e[0] = [
339
344
  t("path", { d: "M6 8a6 6 0 0 1 12 0c0 7 3 9 3 9H3s3-2 3-9" }, null, -1),
340
345
  t("path", { d: "M10.3 21a1.94 1.94 0 0 0 3.4 0" }, null, -1)
341
346
  ]));
342
347
  }
343
- const Ge = /* @__PURE__ */ w(Fe, [["render", qe]]), Je = {}, Ke = {
348
+ const Ke = /* @__PURE__ */ w(qe, [["render", Je]]), We = {}, Xe = {
344
349
  class: "shrink-0 size-4",
345
350
  xmlns: "http://www.w3.org/2000/svg",
346
351
  width: "24",
@@ -352,8 +357,8 @@ const Ge = /* @__PURE__ */ w(Fe, [["render", qe]]), Je = {}, Ke = {
352
357
  "stroke-linecap": "round",
353
358
  "stroke-linejoin": "round"
354
359
  };
355
- function We(o, e) {
356
- return s(), r("svg", Ke, e[0] || (e[0] = [
360
+ function Ye(o, e) {
361
+ return s(), r("svg", Xe, e[0] || (e[0] = [
357
362
  t("path", { d: "M12.22 2h-.44a2 2 0 0 0-2 2v.18a2 2 0 0 1-1 1.73l-.43.25a2 2 0 0 1-2 0l-.15-.08a2 2 0 0 0-2.73.73l-.22.38a2 2 0 0 0 .73 2.73l.15.1a2 2 0 0 1 1 1.72v.51a2 2 0 0 1-1 1.74l-.15.09a2 2 0 0 0-.73 2.73l.22.38a2 2 0 0 0 2.73.73l.15-.08a2 2 0 0 1 2 0l.43.25a2 2 0 0 1 1 1.73V20a2 2 0 0 0 2 2h.44a2 2 0 0 0 2-2v-.18a2 2 0 0 1 1-1.73l.43-.25a2 2 0 0 1 2 0l.15.08a2 2 0 0 0 2.73-.73l.22-.39a2 2 0 0 0-.73-2.73l-.15-.08a2 2 0 0 1-1-1.74v-.5a2 2 0 0 1 1-1.74l.15-.09a2 2 0 0 0 .73-2.73l-.22-.38a2 2 0 0 0-2.73-.73l-.15.08a2 2 0 0 1-2 0l-.43-.25a2 2 0 0 1-1-1.73V4a2 2 0 0 0-2-2z" }, null, -1),
358
363
  t("circle", {
359
364
  cx: "12",
@@ -362,23 +367,23 @@ function We(o, e) {
362
367
  }, null, -1)
363
368
  ]));
364
369
  }
365
- const Xe = /* @__PURE__ */ w(Je, [["render", We]]), Ye = {
370
+ const et = /* @__PURE__ */ w(We, [["render", Ye]]), tt = {
366
371
  key: 0,
367
372
  class: "flex absolute top-0 end-0 -mt-1.5 -me-1.5"
368
- }, et = { class: "relative min-w-[18px] min-h-[18px] inline-flex justify-center items-center text-[10px] bg-red-500 text-white rounded-full px-1" }, tt = {
373
+ }, ot = { class: "relative min-w-[18px] min-h-[18px] inline-flex justify-center items-center text-[10px] bg-red-500 text-white rounded-full px-1" }, nt = {
369
374
  key: 0,
370
375
  class: "w-96 h-[100px] z-[11] absolute top-[40px] right-0"
371
- }, ot = { class: "h-[50px] px-[20px] border-b w-full flex items-center justify-between rounded-t-lg bg-white shadow-[0_10px_40px_10px_rgba(0,0,0,0.08)]" }, nt = { class: "h-[30px] w-[30px] inline-flex justify-center items-center gap-x-2 rounded-full border border-transparent text-gray-500 hover:bg-gray-100 focus:outline-none focus:bg-gray-100" }, st = { class: "max-h-[400px] bg-white overflow-auto [&::-webkit-scrollbar]:w-2 [&::-webkit-scrollbar-thumb]:rounded-full [&::-webkit-scrollbar-track]:bg-gray-100 [&::-webkit-scrollbar-thumb]:bg-gray-300" }, rt = { key: 0 }, at = {
376
+ }, st = { class: "h-[50px] px-[20px] border-b w-full flex items-center justify-between rounded-t-lg bg-white shadow-[0_10px_40px_10px_rgba(0,0,0,0.08)]" }, rt = { class: "h-[30px] w-[30px] inline-flex justify-center items-center gap-x-2 rounded-full border border-transparent text-gray-500 hover:bg-gray-100 focus:outline-none focus:bg-gray-100" }, at = { class: "max-h-[400px] bg-white overflow-auto [&::-webkit-scrollbar]:w-2 [&::-webkit-scrollbar-thumb]:rounded-full [&::-webkit-scrollbar-track]:bg-gray-100 [&::-webkit-scrollbar-thumb]:bg-gray-300" }, lt = { key: 0 }, it = {
372
377
  __name: "admin-notification",
373
378
  setup(o) {
374
- var m, b, x, C, y;
375
- const e = D(0), n = D([]), l = D(!1), a = D(null), i = (y = (C = (x = (b = (m = J()) == null ? void 0 : m.appContext) == null ? void 0 : b.app) == null ? void 0 : x.config) == null ? void 0 : C.globalProperties) == null ? void 0 : y.$notify, v = (u) => {
379
+ var C, x, _, m, y;
380
+ const e = D(0), n = D([]), l = D(!1), a = D(null), i = (y = (m = (_ = (x = (C = K()) == null ? void 0 : C.appContext) == null ? void 0 : x.app) == null ? void 0 : _.config) == null ? void 0 : m.globalProperties) == null ? void 0 : y.$notify, b = (u) => {
376
381
  a.value && !a.value.contains(u.target) && (l.value = !1);
377
382
  };
378
- K(l, (u) => {
379
- u ? window.addEventListener("click", v) : window.removeEventListener("click", v);
380
- }), W(() => {
381
- window.removeEventListener("click", v);
383
+ W(l, (u) => {
384
+ u ? window.addEventListener("click", b) : window.removeEventListener("click", b);
385
+ }), X(() => {
386
+ window.removeEventListener("click", b);
382
387
  });
383
388
  const f = async () => {
384
389
  try {
@@ -413,34 +418,34 @@ const Xe = /* @__PURE__ */ w(Je, [["render", We]]), Ye = {
413
418
  onClick: p[0] || (p[0] = ($) => l.value = !l.value),
414
419
  class: "hs-tooltip-toggle relative size-[38px] inline-flex justify-center items-center gap-x-2 rounded-full border border-transparent text-gray-500 hover:bg-gray-100 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-gray-100"
415
420
  }, [
416
- c(Ge, {
421
+ c(Ke, {
417
422
  height: "24",
418
423
  width: "24"
419
424
  }),
420
- e.value ? (s(), r("span", Ye, [
425
+ e.value ? (s(), r("span", tt, [
421
426
  p[1] || (p[1] = t("span", { class: "absolute inline-flex bg-red-400 rounded-full opacity-75 animate-ping size-full dark:bg-red-600" }, null, -1)),
422
- t("span", et, V(e.value), 1)
427
+ t("span", ot, V(e.value), 1)
423
428
  ])) : H("", !0)
424
429
  ]),
425
430
  c(T, null, {
426
431
  default: M(() => {
427
432
  var $;
428
433
  return [
429
- l.value ? (s(), r("div", tt, [
430
- t("div", ot, [
434
+ l.value ? (s(), r("div", nt, [
435
+ t("div", st, [
431
436
  p[2] || (p[2] = t("nav", { class: "flex" }, [
432
437
  t("button", {
433
438
  type: "button",
434
439
  class: "px-2 py-1.5 relative inline-flex justify-center items-center gap-x-2 text-nowrap hover:bg-gray-100 text-gray-500 hover:text-gray-800 text-sm rounded-lg focus:outline-none focus:bg-gray-100 after:absolute after:bottom-[-9px] after:left-2.5 after:right-2.5 after:z-10 after:h-0.5 after:bg-gray-800"
435
440
  }, " Всі ")
436
441
  ], -1)),
437
- t("button", nt, [
438
- c(Xe)
442
+ t("button", rt, [
443
+ c(et)
439
444
  ])
440
445
  ]),
441
- t("div", st, [
442
- ($ = n.value) != null && $.length ? (s(), r("ul", rt, [
443
- (s(!0), r(N, null, S(n.value, (k) => (s(), X(Qe, {
446
+ t("div", at, [
447
+ ($ = n.value) != null && $.length ? (s(), r("ul", lt, [
448
+ (s(!0), r(N, null, S(n.value, (k) => (s(), Y(Re, {
444
449
  key: k == null ? void 0 : k.id,
445
450
  item: k,
446
451
  onUpdateNotification: f
@@ -451,7 +456,7 @@ const Xe = /* @__PURE__ */ w(Je, [["render", We]]), Ye = {
451
456
  onClick: g,
452
457
  class: "h-[50px] border-t w-full rounded-b-lg bg-white shadow p-4 flex justify-center items-center gap-x-2 text-sm text-gray-500 font-medium sm:rounded-b-lg hover:text-blue-600 focus:outline-none"
453
458
  }, [
454
- c(Me, {
459
+ c(Le, {
455
460
  height: "16",
456
461
  width: "16"
457
462
  }),
@@ -464,7 +469,7 @@ const Xe = /* @__PURE__ */ w(Je, [["render", We]]), Ye = {
464
469
  })
465
470
  ], 512));
466
471
  }
467
- }, lt = {}, it = {
472
+ }, ct = {}, ut = {
468
473
  class: "flex-shrink-0 size-4",
469
474
  xmlns: "http://www.w3.org/2000/svg",
470
475
  viewBox: "0 0 24 24",
@@ -474,8 +479,8 @@ const Xe = /* @__PURE__ */ w(Je, [["render", We]]), Ye = {
474
479
  "stroke-linecap": "round",
475
480
  "stroke-linejoin": "round"
476
481
  };
477
- function ct(o, e, n, l, a, i) {
478
- return s(), r("svg", it, e[0] || (e[0] = [
482
+ function dt(o, e, n, l, a, i) {
483
+ return s(), r("svg", ut, e[0] || (e[0] = [
479
484
  t("circle", {
480
485
  cx: "12",
481
486
  cy: "12",
@@ -485,8 +490,8 @@ function ct(o, e, n, l, a, i) {
485
490
  t("path", { d: "M12 17h.01" }, null, -1)
486
491
  ]));
487
492
  }
488
- const ut = /* @__PURE__ */ w(lt, [["render", ct]]), dt = {
489
- components: { IconQuestion: ut, IconUser: P, AdminNotification: at },
493
+ const pt = /* @__PURE__ */ w(ct, [["render", dt]]), ft = {
494
+ components: { IconQuestion: pt, IconUser: P, AdminNotification: it },
490
495
  mounted() {
491
496
  this.getUserData();
492
497
  },
@@ -525,67 +530,67 @@ const ut = /* @__PURE__ */ w(lt, [["render", ct]]), dt = {
525
530
  beforeUnmount() {
526
531
  window.removeEventListener("click", this.closeOnOutsideClick);
527
532
  }
528
- }, pt = {
533
+ }, ht = {
529
534
  class: "h-[60px] border-b flex justify-end px-[20px]",
530
535
  style: { width: "calc(100vw - 260px)" }
531
- }, ft = { class: "flex items-center gap-[6px]" }, ht = {
536
+ }, gt = { class: "flex items-center gap-[6px]" }, xt = {
532
537
  href: "docs-softpro.com",
533
538
  class: "size-[38px] inline-flex justify-center items-center gap-x-2 rounded-full border border-transparent text-gray-500 hover:bg-gray-100 disabled:opacity-50 disabled:pointer-events-none focus:outline-none focus:bg-gray-100 dark:text-neutral-400 dark:hover:bg-neutral-700 dark:focus:bg-neutral-700"
534
- }, gt = { class: "relative" }, xt = ["src"], bt = {
539
+ }, bt = { class: "relative" }, _t = ["src"], vt = {
535
540
  key: 1,
536
541
  class: "size-[40px] rounded-full bg-gray-200 flex items-center justify-center"
537
- }, _t = { class: "p-[10px] gap-[6px] items-center border-b flex justify-between" }, vt = ["src"], Ct = {
542
+ }, Ct = { class: "p-[10px] gap-[6px] items-center border-b flex justify-between" }, wt = ["src"], mt = {
538
543
  key: 1,
539
544
  class: "size-[40px] rounded-full bg-gray-200 flex items-center justify-center"
540
- }, wt = { class: "text-[14px] mr-[10px] text-gray-500" }, mt = { class: "flex flex-col p-[4px]" };
541
- function yt(o, e, n, l, a, i) {
542
- var b, x, C, y, u, p, $, k, I, z;
543
- const v = _("IconQuestion"), f = _("AdminNotification"), g = _("IconUser"), m = _("router-link");
544
- return s(), r("div", pt, [
545
- t("div", ft, [
546
- t("a", ht, [
547
- c(v, {
545
+ }, yt = { class: "text-[14px] mr-[10px] text-gray-500" }, kt = { class: "flex flex-col p-[4px]" };
546
+ function $t(o, e, n, l, a, i) {
547
+ var x, _, m, y, u, p, $, k, I, z;
548
+ const b = v("IconQuestion"), f = v("AdminNotification"), g = v("IconUser"), C = v("router-link");
549
+ return s(), r("div", ht, [
550
+ t("div", gt, [
551
+ t("a", xt, [
552
+ c(b, {
548
553
  height: "24",
549
554
  width: "24"
550
555
  })
551
556
  ]),
552
557
  c(f),
553
558
  e[4] || (e[4] = t("div", { class: "h-[30px] w-[1px] bg-gray-200 ml-[10px] mr-[10px]" }, null, -1)),
554
- t("div", gt, [
559
+ t("div", bt, [
555
560
  t("div", {
556
561
  onClick: e[0] || (e[0] = (j) => a.isVisible = !0),
557
562
  class: "cursor-pointer"
558
563
  }, [
559
- (x = (b = a.userData) == null ? void 0 : b.user) != null && x.avatar ? (s(), r("img", {
564
+ (_ = (x = a.userData) == null ? void 0 : x.user) != null && _.avatar ? (s(), r("img", {
560
565
  key: 0,
561
566
  class: "flex-shrink-0 size-[30px] rounded-full",
562
- src: (y = (C = a.userData) == null ? void 0 : C.user) == null ? void 0 : y.avatar,
567
+ src: (y = (m = a.userData) == null ? void 0 : m.user) == null ? void 0 : y.avatar,
563
568
  alt: "Image Description"
564
- }, null, 8, xt)) : (s(), r("div", bt, [
569
+ }, null, 8, _t)) : (s(), r("div", vt, [
565
570
  c(g)
566
571
  ]))
567
572
  ]),
568
573
  a.isVisible ? (s(), r("div", {
569
574
  key: 0,
570
- onClick: e[2] || (e[2] = Y(() => {
575
+ onClick: e[2] || (e[2] = ee(() => {
571
576
  }, ["stop"])),
572
577
  class: "fixed bg-white w-[180px] top-[55px] right-[20px] shadow-xl rounded-xl z-[1]"
573
578
  }, [
574
- t("div", _t, [
579
+ t("div", Ct, [
575
580
  (p = (u = a.userData) == null ? void 0 : u.user) != null && p.avatar ? (s(), r("img", {
576
581
  key: 0,
577
582
  class: "flex-shrink-0 size-[30px] rounded-full",
578
583
  src: (k = ($ = a.userData) == null ? void 0 : $.user) == null ? void 0 : k.avatar,
579
584
  alt: "Image Description"
580
- }, null, 8, vt)) : (s(), r("div", Ct, [
585
+ }, null, 8, wt)) : (s(), r("div", mt, [
581
586
  c(g)
582
587
  ])),
583
588
  t("div", null, [
584
- t("p", wt, V((z = (I = a.userData) == null ? void 0 : I.user) == null ? void 0 : z.username), 1)
589
+ t("p", yt, V((z = (I = a.userData) == null ? void 0 : I.user) == null ? void 0 : z.username), 1)
585
590
  ])
586
591
  ]),
587
- t("div", mt, [
588
- c(m, {
592
+ t("div", kt, [
593
+ c(C, {
589
594
  to: "profile",
590
595
  disabled: !0,
591
596
  class: "p-[8px] block rounded-lg w-full mb-[4px] text-start hover:bg-gray-100 !duration-300"
@@ -605,19 +610,19 @@ function yt(o, e, n, l, a, i) {
605
610
  ])
606
611
  ]);
607
612
  }
608
- const kt = /* @__PURE__ */ w(dt, [["render", yt]]), $t = {
609
- components: { navbar: ye, AdminHeader: kt },
613
+ const Vt = /* @__PURE__ */ w(ft, [["render", $t]]), Mt = {
614
+ components: { navbar: $e, AdminHeader: Vt },
610
615
  computed: {
611
616
  isMenu() {
612
617
  return B.value || null;
613
618
  }
614
619
  }
615
- }, Vt = { class: "admin-wrapper" }, Mt = { class: "flex flex-col" };
616
- function Ht(o, e, n, l, a, i) {
617
- const v = _("navbar"), f = _("admin-header"), g = _("router-view");
618
- return s(), r("div", Vt, [
619
- c(v),
620
- t("div", Mt, [
620
+ }, Ht = { class: "admin-wrapper" }, Lt = { class: "flex flex-col" };
621
+ function It(o, e, n, l, a, i) {
622
+ const b = v("navbar"), f = v("admin-header"), g = v("router-view");
623
+ return s(), r("div", Ht, [
624
+ c(b),
625
+ t("div", Lt, [
621
626
  i.isMenu ? (s(), r(N, { key: 0 }, [
622
627
  c(f),
623
628
  c(g)
@@ -625,7 +630,7 @@ function Ht(o, e, n, l, a, i) {
625
630
  ])
626
631
  ]);
627
632
  }
628
- const jt = /* @__PURE__ */ w($t, [["render", Ht], ["__scopeId", "data-v-a53a7af5"]]);
633
+ const Dt = /* @__PURE__ */ w(Mt, [["render", It], ["__scopeId", "data-v-36fd7ac9"]]);
629
634
  export {
630
- jt as default
635
+ Dt as default
631
636
  };