locator-ars-lib 1.0.8 → 1.0.9

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.
@@ -1,14 +1,14 @@
1
1
  var h = Object.defineProperty;
2
2
  var y = (e, s, i) => s in e ? h(e, s, { enumerable: !0, configurable: !0, writable: !0, value: i }) : e[s] = i;
3
3
  var c = (e, s, i) => y(e, typeof s != "symbol" ? s + "" : s, i);
4
- import { inject as v, ref as u, computed as p, watch as _, onUnmounted as g, defineComponent as k, toRefs as P, renderSlot as m } from "vue";
5
- import w from "axios";
6
- class C {
4
+ import { inject as v, ref as l, computed as p, watch as g, onUnmounted as _, defineComponent as k, toRefs as w, onMounted as P, renderSlot as d, createCommentVNode as C } from "vue";
5
+ import S from "axios";
6
+ class L {
7
7
  constructor(s) {
8
8
  c(this, "axios");
9
9
  c(this, "cache", /* @__PURE__ */ new Map());
10
10
  c(this, "endpoint");
11
- this.axios = w.create({
11
+ this.axios = S.create({
12
12
  baseURL: (s == null ? void 0 : s.baseUrl) || ""
13
13
  }), this.endpoint = (s == null ? void 0 : s.endpoint) || "/api/v1/dashboard/access";
14
14
  }
@@ -16,10 +16,10 @@ class C {
16
16
  if (this.cache.has(s))
17
17
  return this.cache.get(s);
18
18
  try {
19
- const r = (await this.axios.get(this.endpoint, {
19
+ const n = (await this.axios.get(this.endpoint, {
20
20
  params: { action: s }
21
21
  })).data.allowed || !1;
22
- return this.cache.set(s, r), r;
22
+ return this.cache.set(s, n), n;
23
23
  } catch (i) {
24
24
  return console.error(`Error checking permission for ${s}:`, i), !1;
25
25
  }
@@ -28,43 +28,43 @@ class C {
28
28
  s ? this.cache.delete(s) : this.cache.clear();
29
29
  }
30
30
  }
31
- let o = null;
32
- function S(e) {
33
- o = e;
31
+ let t = null;
32
+ function $(e) {
33
+ t = e;
34
34
  }
35
- const $ = {
35
+ const E = {
36
36
  async mounted(e, s) {
37
37
  const i = e.style.display;
38
38
  if (e._permission_data = {
39
39
  action: s.value,
40
40
  originalDisplay: i,
41
41
  permissionChecked: !1
42
- }, !o) {
42
+ }, !t) {
43
43
  console.warn("Permissions service not initialized yet. Element will remain visible.");
44
44
  return;
45
45
  }
46
46
  try {
47
- await o.can(s.value) || (e.style.display = "none"), e._permission_data.permissionChecked = !0;
48
- } catch (r) {
49
- console.error("Error checking permission:", r);
47
+ await t.can(s.value) || (e.style.display = "none"), e._permission_data.permissionChecked = !0;
48
+ } catch (n) {
49
+ console.error("Error checking permission:", n);
50
50
  }
51
51
  },
52
52
  async updated(e, s) {
53
53
  var i;
54
54
  if (!e._permission_data || e._permission_data.action !== s.value) {
55
- const r = ((i = e._permission_data) == null ? void 0 : i.originalDisplay) || e.style.display || "";
55
+ const n = ((i = e._permission_data) == null ? void 0 : i.originalDisplay) || e.style.display || "";
56
56
  if (e._permission_data = {
57
57
  action: s.value,
58
- originalDisplay: r,
58
+ originalDisplay: n,
59
59
  permissionChecked: !1
60
- }, !o) {
60
+ }, !t) {
61
61
  console.warn("Permissions service not initialized yet. Element will remain visible.");
62
62
  return;
63
63
  }
64
64
  try {
65
- await o.can(s.value) ? e.style.display = e._permission_data.originalDisplay : e.style.display = "none", e._permission_data.permissionChecked = !0;
66
- } catch (n) {
67
- console.error("Error checking permission:", n);
65
+ await t.can(s.value) ? e.style.display = e._permission_data.originalDisplay : e.style.display = "none", e._permission_data.permissionChecked = !0;
66
+ } catch (r) {
67
+ console.error("Error checking permission:", r);
68
68
  }
69
69
  }
70
70
  },
@@ -72,52 +72,52 @@ const $ = {
72
72
  e._permission_data && (e.style.display = e._permission_data.originalDisplay, delete e._permission_data);
73
73
  }
74
74
  }, f = Symbol("Permissions");
75
- function E(e) {
76
- const s = new C(e);
77
- return S(s), s;
75
+ function b(e) {
76
+ const s = new L(e);
77
+ return $(s), s;
78
78
  }
79
- const b = {
79
+ const D = {
80
80
  install(e, s) {
81
- const i = E(s);
81
+ const i = b(s);
82
82
  e.provide(f, i), e.config.globalProperties.$permissions = i;
83
83
  }
84
84
  };
85
- function D() {
85
+ function I() {
86
86
  const e = v(f);
87
87
  if (!e)
88
88
  throw new Error("Permissions plugin not installed!");
89
89
  return e;
90
90
  }
91
- function L(e, s = {}) {
92
- const i = D(), r = u(null), n = u(!1), t = u(null), d = p(() => typeof e == "string" ? e : e.value), l = async () => {
93
- if (d.value) {
94
- n.value = !0, t.value = null;
91
+ function U(e, s = {}) {
92
+ const i = I(), n = l(null), r = l(!1), a = l(null), m = p(() => typeof e == "string" ? e : e.value), u = async () => {
93
+ if (m.value) {
94
+ r.value = !0, a.value = null;
95
95
  try {
96
- r.value = await i.can(d.value);
97
- } catch (a) {
98
- t.value = a instanceof Error ? a : new Error(String(a)), r.value = !1;
96
+ n.value = await i.can(m.value);
97
+ } catch (o) {
98
+ a.value = o instanceof Error ? o : new Error(String(o)), n.value = !1;
99
99
  } finally {
100
- n.value = !1;
100
+ r.value = !1;
101
101
  }
102
102
  }
103
103
  };
104
- if (s.autoCheck !== !1 && l(), typeof e != "string") {
105
- const a = _(e, () => {
106
- l();
104
+ if (s.autoCheck !== !1 && u(), typeof e != "string") {
105
+ const o = g(e, () => {
106
+ u();
107
107
  });
108
- g(() => {
109
- a();
108
+ _(() => {
109
+ o();
110
110
  });
111
111
  }
112
112
  return {
113
- isAllowed: r,
114
- isLoading: n,
115
- error: t,
116
- check: l,
117
- can: p(() => r.value === !0)
113
+ isAllowed: n,
114
+ isLoading: r,
115
+ error: a,
116
+ check: u,
117
+ can: p(() => n.value === !0)
118
118
  };
119
119
  }
120
- const U = k({
120
+ const z = k({
121
121
  name: "Check",
122
122
  props: {
123
123
  action: {
@@ -130,33 +130,36 @@ const U = k({
130
130
  }
131
131
  },
132
132
  setup(e) {
133
- const { action: s } = P(e), { can: i, isLoading: r } = L(s, { autoCheck: !0 });
134
- return {
135
- can: i,
136
- isLoading: r
133
+ const { action: s } = w(e), i = l(!0), { can: n, isLoading: r, check: a } = U(s, { autoCheck: !1 });
134
+ return P(async () => {
135
+ await a(), i.value = !1;
136
+ }), {
137
+ can: n,
138
+ isLoading: r,
139
+ isInitialLoading: i
137
140
  };
138
141
  }
139
- }), x = (e, s) => {
142
+ }), M = (e, s) => {
140
143
  const i = e.__vccOpts || e;
141
- for (const [r, n] of s)
142
- i[r] = n;
144
+ for (const [n, r] of s)
145
+ i[n] = r;
143
146
  return i;
144
147
  };
145
- function z(e, s, i, r, n, t) {
146
- return e.can ? m(e.$slots, "default", { key: 0 }) : e.isLoading ? m(e.$slots, "loading", { key: 2 }) : m(e.$slots, "fallback", { key: 1 });
148
+ function R(e, s, i, n, r, a) {
149
+ return e.can && !e.isInitialLoading ? d(e.$slots, "default", { key: 0 }) : !e.isLoading && !e.isInitialLoading && !e.can ? d(e.$slots, "fallback", { key: 1 }) : e.isLoading || e.isInitialLoading ? d(e.$slots, "loading", { key: 2 }) : C("", !0);
147
150
  }
148
- const R = /* @__PURE__ */ x(U, [["render", z]]), B = {
151
+ const V = /* @__PURE__ */ M(z, [["render", R]]), B = {
149
152
  install(e, s) {
150
- e.use(b, s), e.component("Check", R), e.directive("can", $);
153
+ e.use(D, s), e.component("Check", V), e.directive("can", E);
151
154
  }
152
155
  };
153
156
  export {
154
- R as Check,
157
+ V as Check,
155
158
  B as default,
156
- S as setPermissionsService,
157
- E as setupPermissions,
158
- L as usePermissions,
159
- D as usePermissionsService,
160
- $ as vCan
159
+ $ as setPermissionsService,
160
+ b as setupPermissions,
161
+ U as usePermissions,
162
+ I as usePermissionsService,
163
+ E as vCan
161
164
  };
162
165
  //# sourceMappingURL=locator-ars-lib.es.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"locator-ars-lib.es.js","sources":["../src/services/permissionsService.ts","../src/directives/vCan.ts","../src/plugin.ts","../src/composables/usePermissions.ts","../src/components/Check.vue","../src/index.ts"],"sourcesContent":["import axios, { AxiosInstance } from 'axios'\n\nexport interface PermissionsOptions {\n baseUrl?: string\n endpoint?: string\n}\n\nexport class PermissionsService {\n private axios: AxiosInstance\n private cache: Map<string, boolean> = new Map()\n private endpoint: string\n\n constructor(options?: PermissionsOptions) {\n this.axios = axios.create({\n baseURL: options?.baseUrl || ''\n })\n this.endpoint = options?.endpoint || '/api/v1/dashboard/access'\n }\n\n async can(action: string): Promise<boolean> {\n // Check if we have a cached result\n if (this.cache.has(action)) {\n return this.cache.get(action) as boolean\n }\n\n try {\n const response = await this.axios.get(this.endpoint, {\n params: { action }\n })\n\n const allowed = response.data.allowed || false\n\n // Cache the result\n this.cache.set(action, allowed)\n\n return allowed\n } catch (error) {\n console.error(`Error checking permission for ${action}:`, error)\n return false\n }\n }\n\n clearCache(action?: string): void {\n if (action) {\n this.cache.delete(action)\n } else {\n this.cache.clear()\n }\n }\n} ","import { ObjectDirective, DirectiveBinding } from 'vue'\nimport { PermissionsService } from '../services/permissionsService'\n\ninterface CanHTMLElement extends HTMLElement {\n _permission_data?: {\n action: string\n originalDisplay: string\n permissionChecked?: boolean\n }\n}\n\n// Глобальный сервис проверки прав\nlet globalPermissionsService: PermissionsService | null = null;\n\n// Функция для установки экземпляра сервиса (будет вызываться при инициализации плагина)\nexport function setPermissionsService(service: PermissionsService): void {\n globalPermissionsService = service;\n}\n\nexport const vCan: ObjectDirective = {\n async mounted(el: CanHTMLElement, binding: DirectiveBinding) {\n // Store original display value\n const originalDisplay = el.style.display;\n\n // Store action and original display for updates\n el._permission_data = {\n action: binding.value,\n originalDisplay,\n permissionChecked: false\n };\n\n if (!globalPermissionsService) {\n console.warn('Permissions service not initialized yet. Element will remain visible.');\n return;\n }\n\n try {\n const hasPermission = await globalPermissionsService.can(binding.value);\n\n if (!hasPermission) {\n el.style.display = 'none';\n }\n\n el._permission_data.permissionChecked = true;\n } catch (error) {\n console.error('Error checking permission:', error);\n }\n },\n\n async updated(el: CanHTMLElement, binding: DirectiveBinding) {\n if (!el._permission_data || el._permission_data.action !== binding.value) {\n // Action has changed or directive is new\n const originalDisplay = el._permission_data?.originalDisplay || el.style.display || '';\n\n el._permission_data = {\n action: binding.value,\n originalDisplay,\n permissionChecked: false\n };\n\n if (!globalPermissionsService) {\n console.warn('Permissions service not initialized yet. Element will remain visible.');\n return;\n }\n\n try {\n const hasPermission = await globalPermissionsService.can(binding.value);\n\n if (!hasPermission) {\n el.style.display = 'none';\n } else {\n el.style.display = el._permission_data.originalDisplay;\n }\n\n el._permission_data.permissionChecked = true;\n } catch (error) {\n console.error('Error checking permission:', error);\n }\n }\n },\n\n unmounted(el: CanHTMLElement) {\n if (el._permission_data) {\n el.style.display = el._permission_data.originalDisplay;\n delete el._permission_data;\n }\n }\n} ","import { App, inject, InjectionKey } from 'vue'\nimport { PermissionsService, PermissionsOptions } from './services/permissionsService'\nimport { setPermissionsService } from './directives/vCan'\n\nexport const PermissionsKey: InjectionKey<PermissionsService> = Symbol('Permissions')\n\nexport function setupPermissions(options?: PermissionsOptions): PermissionsService {\n const service = new PermissionsService(options);\n // Устанавливаем глобальный сервис для директивы\n setPermissionsService(service);\n return service;\n}\n\nexport const PermissionsPlugin = {\n install(app: App, options?: PermissionsOptions) {\n const permissionsService = setupPermissions(options);\n app.provide(PermissionsKey, permissionsService);\n\n // Добавим сервис в глобальные свойства Vue для доступа откуда угодно\n app.config.globalProperties.$permissions = permissionsService;\n }\n}\n\nexport function usePermissionsService(): PermissionsService {\n const permissionsService = inject(PermissionsKey);\n if (!permissionsService) {\n throw new Error('Permissions plugin not installed!');\n }\n return permissionsService;\n} ","import { ref, computed, Ref, watch, onUnmounted } from 'vue'\nimport { usePermissionsService } from '../plugin'\n\nexport interface UsePermissionsOptions {\n autoCheck?: boolean\n}\n\nexport function usePermissions(action: string | Ref<string>, options: UsePermissionsOptions = {}) {\n const permissionsService = usePermissionsService()\n const isAllowed = ref<boolean | null>(null)\n const isLoading = ref(false)\n const error = ref<Error | null>(null)\n\n const actionValue = computed(() => {\n return typeof action === 'string' ? action : action.value\n })\n\n const checkPermission = async () => {\n if (!actionValue.value) return\n\n isLoading.value = true\n error.value = null\n\n try {\n isAllowed.value = await permissionsService.can(actionValue.value)\n } catch (err) {\n error.value = err instanceof Error ? err : new Error(String(err))\n isAllowed.value = false\n } finally {\n isLoading.value = false\n }\n }\n\n // Auto-check on mount if requested\n if (options.autoCheck !== false) {\n checkPermission()\n }\n\n // Re-check when action changes\n if (typeof action !== 'string') {\n const unwatch = watch(action, () => {\n checkPermission()\n })\n\n onUnmounted(() => {\n unwatch()\n })\n }\n\n return {\n isAllowed,\n isLoading,\n error,\n check: checkPermission,\n can: computed(() => isAllowed.value === true)\n }\n} ","<template>\n <slot v-if=\"can\" />\n <slot name=\"fallback\" v-else-if=\"!isLoading\" />\n <slot name=\"loading\" v-else />\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, toRefs, PropType } from 'vue';\nimport { usePermissions } from '../composables/usePermissions';\n\nexport default defineComponent({\n name: 'Check',\n props: {\n action: {\n type: String as PropType<string>,\n required: true\n },\n fallback: {\n type: Boolean,\n default: false\n }\n },\n setup(props) {\n const { action } = toRefs(props);\n const { can, isLoading } = usePermissions(action, { autoCheck: true });\n\n return {\n can,\n isLoading\n };\n }\n});\n</script> ","import { App } from 'vue'\nimport Check from './components/Check.vue'\nimport { usePermissions } from './composables/usePermissions'\nimport { PermissionsPlugin, setupPermissions, usePermissionsService } from './plugin'\nimport { vCan, setPermissionsService } from './directives/vCan'\n\n// Именованные экспорты\nexport {\n Check,\n usePermissions,\n setupPermissions,\n vCan,\n usePermissionsService,\n setPermissionsService\n}\n\n// Создаем основной объект плагина\nconst plugin = {\n install(app: App, options?: { baseUrl?: string }) {\n // Важно: сначала нужно инициализировать PermissionsPlugin для provide/inject механизма\n app.use(PermissionsPlugin, options)\n\n // Затем регистрируем компонент и директиву\n app.component('Check', Check)\n app.directive('can', vCan)\n }\n}\n\n// Экспортируем плагин как по умолчанию\nexport default plugin "],"names":["PermissionsService","options","__publicField","axios","action","allowed","error","globalPermissionsService","setPermissionsService","service","vCan","el","binding","originalDisplay","_a","PermissionsKey","setupPermissions","PermissionsPlugin","app","permissionsService","usePermissionsService","inject","usePermissions","isAllowed","ref","isLoading","actionValue","computed","checkPermission","err","unwatch","watch","onUnmounted","_sfc_main","defineComponent","props","toRefs","can","_ctx","_renderSlot","plugin","Check"],"mappings":"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"}
1
+ {"version":3,"file":"locator-ars-lib.es.js","sources":["../src/services/permissionsService.ts","../src/directives/vCan.ts","../src/plugin.ts","../src/composables/usePermissions.ts","../src/components/Check.vue","../src/index.ts"],"sourcesContent":["import axios, { AxiosInstance } from 'axios'\n\nexport interface PermissionsOptions {\n baseUrl?: string\n endpoint?: string\n}\n\nexport class PermissionsService {\n private axios: AxiosInstance\n private cache: Map<string, boolean> = new Map()\n private endpoint: string\n\n constructor(options?: PermissionsOptions) {\n this.axios = axios.create({\n baseURL: options?.baseUrl || ''\n })\n this.endpoint = options?.endpoint || '/api/v1/dashboard/access'\n }\n\n async can(action: string): Promise<boolean> {\n // Check if we have a cached result\n if (this.cache.has(action)) {\n return this.cache.get(action) as boolean\n }\n\n try {\n const response = await this.axios.get(this.endpoint, {\n params: { action }\n })\n\n const allowed = response.data.allowed || false\n\n // Cache the result\n this.cache.set(action, allowed)\n\n return allowed\n } catch (error) {\n console.error(`Error checking permission for ${action}:`, error)\n return false\n }\n }\n\n clearCache(action?: string): void {\n if (action) {\n this.cache.delete(action)\n } else {\n this.cache.clear()\n }\n }\n} ","import { ObjectDirective, DirectiveBinding } from 'vue'\nimport { PermissionsService } from '../services/permissionsService'\n\ninterface CanHTMLElement extends HTMLElement {\n _permission_data?: {\n action: string\n originalDisplay: string\n permissionChecked?: boolean\n }\n}\n\n// Глобальный сервис проверки прав\nlet globalPermissionsService: PermissionsService | null = null;\n\n// Функция для установки экземпляра сервиса (будет вызываться при инициализации плагина)\nexport function setPermissionsService(service: PermissionsService): void {\n globalPermissionsService = service;\n}\n\nexport const vCan: ObjectDirective = {\n async mounted(el: CanHTMLElement, binding: DirectiveBinding) {\n // Store original display value\n const originalDisplay = el.style.display;\n\n // Store action and original display for updates\n el._permission_data = {\n action: binding.value,\n originalDisplay,\n permissionChecked: false\n };\n\n if (!globalPermissionsService) {\n console.warn('Permissions service not initialized yet. Element will remain visible.');\n return;\n }\n\n try {\n const hasPermission = await globalPermissionsService.can(binding.value);\n\n if (!hasPermission) {\n el.style.display = 'none';\n }\n\n el._permission_data.permissionChecked = true;\n } catch (error) {\n console.error('Error checking permission:', error);\n }\n },\n\n async updated(el: CanHTMLElement, binding: DirectiveBinding) {\n if (!el._permission_data || el._permission_data.action !== binding.value) {\n // Action has changed or directive is new\n const originalDisplay = el._permission_data?.originalDisplay || el.style.display || '';\n\n el._permission_data = {\n action: binding.value,\n originalDisplay,\n permissionChecked: false\n };\n\n if (!globalPermissionsService) {\n console.warn('Permissions service not initialized yet. Element will remain visible.');\n return;\n }\n\n try {\n const hasPermission = await globalPermissionsService.can(binding.value);\n\n if (!hasPermission) {\n el.style.display = 'none';\n } else {\n el.style.display = el._permission_data.originalDisplay;\n }\n\n el._permission_data.permissionChecked = true;\n } catch (error) {\n console.error('Error checking permission:', error);\n }\n }\n },\n\n unmounted(el: CanHTMLElement) {\n if (el._permission_data) {\n el.style.display = el._permission_data.originalDisplay;\n delete el._permission_data;\n }\n }\n} ","import { App, inject, InjectionKey } from 'vue'\nimport { PermissionsService, PermissionsOptions } from './services/permissionsService'\nimport { setPermissionsService } from './directives/vCan'\n\nexport const PermissionsKey: InjectionKey<PermissionsService> = Symbol('Permissions')\n\nexport function setupPermissions(options?: PermissionsOptions): PermissionsService {\n const service = new PermissionsService(options);\n // Устанавливаем глобальный сервис для директивы\n setPermissionsService(service);\n return service;\n}\n\nexport const PermissionsPlugin = {\n install(app: App, options?: PermissionsOptions) {\n const permissionsService = setupPermissions(options);\n app.provide(PermissionsKey, permissionsService);\n\n // Добавим сервис в глобальные свойства Vue для доступа откуда угодно\n app.config.globalProperties.$permissions = permissionsService;\n }\n}\n\nexport function usePermissionsService(): PermissionsService {\n const permissionsService = inject(PermissionsKey);\n if (!permissionsService) {\n throw new Error('Permissions plugin not installed!');\n }\n return permissionsService;\n} ","import { ref, computed, Ref, watch, onUnmounted } from 'vue'\nimport { usePermissionsService } from '../plugin'\n\nexport interface UsePermissionsOptions {\n autoCheck?: boolean\n}\n\nexport function usePermissions(action: string | Ref<string>, options: UsePermissionsOptions = {}) {\n const permissionsService = usePermissionsService()\n const isAllowed = ref<boolean | null>(null)\n const isLoading = ref(false)\n const error = ref<Error | null>(null)\n\n const actionValue = computed(() => {\n return typeof action === 'string' ? action : action.value\n })\n\n const checkPermission = async () => {\n if (!actionValue.value) return\n\n isLoading.value = true\n error.value = null\n\n try {\n isAllowed.value = await permissionsService.can(actionValue.value)\n } catch (err) {\n error.value = err instanceof Error ? err : new Error(String(err))\n isAllowed.value = false\n } finally {\n isLoading.value = false\n }\n }\n\n // Auto-check on mount if requested\n if (options.autoCheck !== false) {\n checkPermission()\n }\n\n // Re-check when action changes\n if (typeof action !== 'string') {\n const unwatch = watch(action, () => {\n checkPermission()\n })\n\n onUnmounted(() => {\n unwatch()\n })\n }\n\n return {\n isAllowed,\n isLoading,\n error,\n check: checkPermission,\n can: computed(() => isAllowed.value === true)\n }\n} ","<template>\n <slot v-if=\"can && !isInitialLoading\" />\n <slot name=\"fallback\" v-else-if=\"!isLoading && !isInitialLoading && !can\" />\n <slot name=\"loading\" v-else-if=\"isLoading || isInitialLoading\" />\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, toRefs, PropType, ref, onMounted } from 'vue';\nimport { usePermissions } from '../composables/usePermissions';\n\nexport default defineComponent({\n name: 'Check',\n props: {\n action: {\n type: String as PropType<string>,\n required: true\n },\n fallback: {\n type: Boolean,\n default: false\n }\n },\n setup(props) {\n const { action } = toRefs(props);\n const isInitialLoading = ref(true);\n const { can, isLoading, check } = usePermissions(action, { autoCheck: false });\n \n onMounted(async () => {\n await check();\n isInitialLoading.value = false;\n });\n\n return {\n can,\n isLoading,\n isInitialLoading\n };\n }\n});\n</script> ","import { App } from 'vue'\nimport Check from './components/Check.vue'\nimport { usePermissions } from './composables/usePermissions'\nimport { PermissionsPlugin, setupPermissions, usePermissionsService } from './plugin'\nimport { vCan, setPermissionsService } from './directives/vCan'\n\n// Именованные экспорты\nexport {\n Check,\n usePermissions,\n setupPermissions,\n vCan,\n usePermissionsService,\n setPermissionsService\n}\n\n// Создаем основной объект плагина\nconst plugin = {\n install(app: App, options?: { baseUrl?: string }) {\n // Важно: сначала нужно инициализировать PermissionsPlugin для provide/inject механизма\n app.use(PermissionsPlugin, options)\n\n // Затем регистрируем компонент и директиву\n app.component('Check', Check)\n app.directive('can', vCan)\n }\n}\n\n// Экспортируем плагин как по умолчанию\nexport default plugin "],"names":["PermissionsService","options","__publicField","axios","action","allowed","error","globalPermissionsService","setPermissionsService","service","vCan","el","binding","originalDisplay","_a","PermissionsKey","setupPermissions","PermissionsPlugin","app","permissionsService","usePermissionsService","inject","usePermissions","isAllowed","ref","isLoading","actionValue","computed","checkPermission","err","unwatch","watch","onUnmounted","_sfc_main","defineComponent","props","toRefs","isInitialLoading","can","check","onMounted","_ctx","_renderSlot","_createCommentVNode","plugin","Check"],"mappings":";;;;;AAOO,MAAMA,EAAmB;AAAA,EAK5B,YAAYC,GAA8B;AAJlC,IAAAC,EAAA;AACA,IAAAA,EAAA,mCAAkC,IAAI;AACtC,IAAAA,EAAA;AAGC,SAAA,QAAQC,EAAM,OAAO;AAAA,MACtB,UAASF,KAAA,gBAAAA,EAAS,YAAW;AAAA,IAAA,CAChC,GACI,KAAA,YAAWA,KAAA,gBAAAA,EAAS,aAAY;AAAA,EAAA;AAAA,EAGzC,MAAM,IAAIG,GAAkC;AAExC,QAAI,KAAK,MAAM,IAAIA,CAAM;AACd,aAAA,KAAK,MAAM,IAAIA,CAAM;AAG5B,QAAA;AAKM,YAAAC,KAJW,MAAM,KAAK,MAAM,IAAI,KAAK,UAAU;AAAA,QACjD,QAAQ,EAAE,QAAAD,EAAO;AAAA,MAAA,CACpB,GAEwB,KAAK,WAAW;AAGpC,kBAAA,MAAM,IAAIA,GAAQC,CAAO,GAEvBA;AAAA,aACFC,GAAO;AACZ,qBAAQ,MAAM,iCAAiCF,CAAM,KAAKE,CAAK,GACxD;AAAA,IAAA;AAAA,EACX;AAAA,EAGJ,WAAWF,GAAuB;AAC9B,IAAIA,IACK,KAAA,MAAM,OAAOA,CAAM,IAExB,KAAK,MAAM,MAAM;AAAA,EACrB;AAER;ACrCA,IAAIG,IAAsD;AAGnD,SAASC,EAAsBC,GAAmC;AAC1C,EAAAF,IAAAE;AAC/B;AAEO,MAAMC,IAAwB;AAAA,EACjC,MAAM,QAAQC,GAAoBC,GAA2B;AAEnD,UAAAC,IAAkBF,EAAG,MAAM;AASjC,QANAA,EAAG,mBAAmB;AAAA,MAClB,QAAQC,EAAQ;AAAA,MAChB,iBAAAC;AAAA,MACA,mBAAmB;AAAA,IACvB,GAEI,CAACN,GAA0B;AAC3B,cAAQ,KAAK,uEAAuE;AACpF;AAAA,IAAA;AAGA,QAAA;AAGA,MAFsB,MAAMA,EAAyB,IAAIK,EAAQ,KAAK,MAGlED,EAAG,MAAM,UAAU,SAGvBA,EAAG,iBAAiB,oBAAoB;AAAA,aACnCL,GAAO;AACJ,cAAA,MAAM,8BAA8BA,CAAK;AAAA,IAAA;AAAA,EAEzD;AAAA,EAEA,MAAM,QAAQK,GAAoBC,GAA2B;;AACzD,QAAI,CAACD,EAAG,oBAAoBA,EAAG,iBAAiB,WAAWC,EAAQ,OAAO;AAEtE,YAAMC,MAAkBC,IAAAH,EAAG,qBAAH,gBAAAG,EAAqB,oBAAmBH,EAAG,MAAM,WAAW;AAQpF,UANAA,EAAG,mBAAmB;AAAA,QAClB,QAAQC,EAAQ;AAAA,QAChB,iBAAAC;AAAA,QACA,mBAAmB;AAAA,MACvB,GAEI,CAACN,GAA0B;AAC3B,gBAAQ,KAAK,uEAAuE;AACpF;AAAA,MAAA;AAGA,UAAA;AAGA,QAFsB,MAAMA,EAAyB,IAAIK,EAAQ,KAAK,IAK/DD,EAAA,MAAM,UAAUA,EAAG,iBAAiB,kBAFvCA,EAAG,MAAM,UAAU,QAKvBA,EAAG,iBAAiB,oBAAoB;AAAA,eACnCL,GAAO;AACJ,gBAAA,MAAM,8BAA8BA,CAAK;AAAA,MAAA;AAAA,IACrD;AAAA,EAER;AAAA,EAEA,UAAUK,GAAoB;AAC1B,IAAIA,EAAG,qBACAA,EAAA,MAAM,UAAUA,EAAG,iBAAiB,iBACvC,OAAOA,EAAG;AAAA,EACd;AAER,GCnFaI,IAAmD,OAAO,aAAa;AAE7E,SAASC,EAAiBf,GAAkD;AACzE,QAAAQ,IAAU,IAAIT,EAAmBC,CAAO;AAE9C,SAAAO,EAAsBC,CAAO,GACtBA;AACX;AAEO,MAAMQ,IAAoB;AAAA,EAC7B,QAAQC,GAAUjB,GAA8B;AACtC,UAAAkB,IAAqBH,EAAiBf,CAAO;AAC/C,IAAAiB,EAAA,QAAQH,GAAgBI,CAAkB,GAG1CD,EAAA,OAAO,iBAAiB,eAAeC;AAAA,EAAA;AAEnD;AAEO,SAASC,IAA4C;AAClD,QAAAD,IAAqBE,EAAON,CAAc;AAChD,MAAI,CAACI;AACK,UAAA,IAAI,MAAM,mCAAmC;AAEhD,SAAAA;AACX;ACtBO,SAASG,EAAelB,GAA8BH,IAAiC,IAAI;AAC9F,QAAMkB,IAAqBC,EAAsB,GAC3CG,IAAYC,EAAoB,IAAI,GACpCC,IAAYD,EAAI,EAAK,GACrBlB,IAAQkB,EAAkB,IAAI,GAE9BE,IAAcC,EAAS,MAClB,OAAOvB,KAAW,WAAWA,IAASA,EAAO,KACvD,GAEKwB,IAAkB,YAAY;AAC5B,QAACF,EAAY,OAEjB;AAAA,MAAAD,EAAU,QAAQ,IAClBnB,EAAM,QAAQ;AAEV,UAAA;AACA,QAAAiB,EAAU,QAAQ,MAAMJ,EAAmB,IAAIO,EAAY,KAAK;AAAA,eAC3DG,GAAK;AACJ,QAAAvB,EAAA,QAAQuB,aAAe,QAAQA,IAAM,IAAI,MAAM,OAAOA,CAAG,CAAC,GAChEN,EAAU,QAAQ;AAAA,MAAA,UACpB;AACE,QAAAE,EAAU,QAAQ;AAAA,MAAA;AAAA;AAAA,EAE1B;AAQI,MALAxB,EAAQ,cAAc,MACN2B,EAAA,GAIhB,OAAOxB,KAAW,UAAU;AACtB,UAAA0B,IAAUC,EAAM3B,GAAQ,MAAM;AAChB,MAAAwB,EAAA;AAAA,IAAA,CACnB;AAED,IAAAI,EAAY,MAAM;AACN,MAAAF,EAAA;AAAA,IAAA,CACX;AAAA,EAAA;AAGE,SAAA;AAAA,IACH,WAAAP;AAAA,IACA,WAAAE;AAAA,IACA,OAAAnB;AAAA,IACA,OAAOsB;AAAA,IACP,KAAKD,EAAS,MAAMJ,EAAU,UAAU,EAAI;AAAA,EAChD;AACJ;AC9CA,MAAAU,IAAeC,EAAgB;AAAA,EAC7B,MAAM;AAAA,EACN,OAAO;AAAA,IACL,QAAQ;AAAA,MACN,MAAM;AAAA,MACN,UAAU;AAAA,IACZ;AAAA,IACA,UAAU;AAAA,MACR,MAAM;AAAA,MACN,SAAS;AAAA,IAAA;AAAA,EAEb;AAAA,EACA,MAAMC,GAAO;AACX,UAAM,EAAE,QAAA/B,EAAA,IAAWgC,EAAOD,CAAK,GACzBE,IAAmBb,EAAI,EAAI,GAC3B,EAAE,KAAAc,GAAK,WAAAb,GAAW,OAAAc,EAAM,IAAIjB,EAAelB,GAAQ,EAAE,WAAW,IAAO;AAE7E,WAAAoC,EAAU,YAAY;AACpB,YAAMD,EAAM,GACZF,EAAiB,QAAQ;AAAA,IAAA,CAC1B,GAEM;AAAA,MACL,KAAAC;AAAA,MACA,WAAAb;AAAA,MACA,kBAAAY;AAAA,IACF;AAAA,EAAA;AAEJ,CAAC;;;;;;;AArCa,SAAAI,EAAA,OAAG,CAAKA,EAApB,mBAAAC,EAAwCD,EAD1C,QAAA,WAAA,EAAA,KAAA,EAAA,CAAA,IAAA,CAEoCA,eAAS,CAAKA,EAAA,oBAAgB,CAAKA,EAAA,MAArEC,EAA4ED,EAF9E,QAAA,YAAA,EAAA,KAAA,EAAA,CAAA,IAGkCA,EAAa,aAAAA,EAAA,mBAA7CC,EAAiED,EAHnE,QAAA,WAAA,EAAA,KAAA,EAAA,CAAA,IAAAE,EAAA,IAAA,EAAA;;iDCiBMC,IAAS;AAAA,EACX,QAAQ1B,GAAUjB,GAAgC;AAE1C,IAAAiB,EAAA,IAAID,GAAmBhB,CAAO,GAG9BiB,EAAA,UAAU,SAAS2B,CAAK,GACxB3B,EAAA,UAAU,OAAOR,CAAI;AAAA,EAAA;AAEjC;"}
@@ -1,2 +1,2 @@
1
- (function(n,i){typeof exports=="object"&&typeof module<"u"?i(exports,require("vue"),require("axios")):typeof define=="function"&&define.amd?define(["exports","vue","axios"],i):(n=typeof globalThis<"u"?globalThis:n||self,i(n.LocatorArsLib={},n.Vue,n.axios))})(this,function(n,i,o){"use strict";var E=Object.defineProperty;var L=(n,i,o)=>i in n?E(n,i,{enumerable:!0,configurable:!0,writable:!0,value:o}):n[i]=o;var d=(n,i,o)=>L(n,typeof i!="symbol"?i+"":i,o);class k{constructor(s){d(this,"axios");d(this,"cache",new Map);d(this,"endpoint");this.axios=o.create({baseURL:(s==null?void 0:s.baseUrl)||""}),this.endpoint=(s==null?void 0:s.endpoint)||"/api/v1/dashboard/access"}async can(s){if(this.cache.has(s))return this.cache.get(s);try{const t=(await this.axios.get(this.endpoint,{params:{action:s}})).data.allowed||!1;return this.cache.set(s,t),t}catch(r){return console.error(`Error checking permission for ${s}:`,r),!1}}clearCache(s){s?this.cache.delete(s):this.cache.clear()}}let c=null;function f(e){c=e}const p={async mounted(e,s){const r=e.style.display;if(e._permission_data={action:s.value,originalDisplay:r,permissionChecked:!1},!c){console.warn("Permissions service not initialized yet. Element will remain visible.");return}try{await c.can(s.value)||(e.style.display="none"),e._permission_data.permissionChecked=!0}catch(t){console.error("Error checking permission:",t)}},async updated(e,s){var r;if(!e._permission_data||e._permission_data.action!==s.value){const t=((r=e._permission_data)==null?void 0:r.originalDisplay)||e.style.display||"";if(e._permission_data={action:s.value,originalDisplay:t,permissionChecked:!1},!c){console.warn("Permissions service not initialized yet. Element will remain visible.");return}try{await c.can(s.value)?e.style.display=e._permission_data.originalDisplay:e.style.display="none",e._permission_data.permissionChecked=!0}catch(a){console.error("Error checking permission:",a)}}},unmounted(e){e._permission_data&&(e.style.display=e._permission_data.originalDisplay,delete e._permission_data)}},h=Symbol("Permissions");function y(e){const s=new k(e);return f(s),s}const w={install(e,s){const r=y(s);e.provide(h,r),e.config.globalProperties.$permissions=r}};function _(){const e=i.inject(h);if(!e)throw new Error("Permissions plugin not installed!");return e}function v(e,s={}){const r=_(),t=i.ref(null),a=i.ref(!1),u=i.ref(null),g=i.computed(()=>typeof e=="string"?e:e.value),m=async()=>{if(g.value){a.value=!0,u.value=null;try{t.value=await r.can(g.value)}catch(l){u.value=l instanceof Error?l:new Error(String(l)),t.value=!1}finally{a.value=!1}}};if(s.autoCheck!==!1&&m(),typeof e!="string"){const l=i.watch(e,()=>{m()});i.onUnmounted(()=>{l()})}return{isAllowed:t,isLoading:a,error:u,check:m,can:i.computed(()=>t.value===!0)}}const S=i.defineComponent({name:"Check",props:{action:{type:String,required:!0},fallback:{type:Boolean,default:!1}},setup(e){const{action:s}=i.toRefs(e),{can:r,isLoading:t}=v(s,{autoCheck:!0});return{can:r,isLoading:t}}}),C=(e,s)=>{const r=e.__vccOpts||e;for(const[t,a]of s)r[t]=a;return r};function b(e,s,r,t,a,u){return e.can?i.renderSlot(e.$slots,"default",{key:0}):e.isLoading?i.renderSlot(e.$slots,"loading",{key:2}):i.renderSlot(e.$slots,"fallback",{key:1})}const P=C(S,[["render",b]]),$={install(e,s){e.use(w,s),e.component("Check",P),e.directive("can",p)}};n.Check=P,n.default=$,n.setPermissionsService=f,n.setupPermissions=y,n.usePermissions=v,n.usePermissionsService=_,n.vCan=p,Object.defineProperties(n,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}})});
1
+ (function(n,i){typeof exports=="object"&&typeof module<"u"?i(exports,require("vue"),require("axios")):typeof define=="function"&&define.amd?define(["exports","vue","axios"],i):(n=typeof globalThis<"u"?globalThis:n||self,i(n.LocatorArsLib={},n.Vue,n.axios))})(this,function(n,i,t){"use strict";var $=Object.defineProperty;var E=(n,i,t)=>i in n?$(n,i,{enumerable:!0,configurable:!0,writable:!0,value:t}):n[i]=t;var u=(n,i,t)=>E(n,typeof i!="symbol"?i+"":i,t);class k{constructor(s){u(this,"axios");u(this,"cache",new Map);u(this,"endpoint");this.axios=t.create({baseURL:(s==null?void 0:s.baseUrl)||""}),this.endpoint=(s==null?void 0:s.endpoint)||"/api/v1/dashboard/access"}async can(s){if(this.cache.has(s))return this.cache.get(s);try{const a=(await this.axios.get(this.endpoint,{params:{action:s}})).data.allowed||!1;return this.cache.set(s,a),a}catch(r){return console.error(`Error checking permission for ${s}:`,r),!1}}clearCache(s){s?this.cache.delete(s):this.cache.clear()}}let l=null;function f(e){l=e}const p={async mounted(e,s){const r=e.style.display;if(e._permission_data={action:s.value,originalDisplay:r,permissionChecked:!1},!l){console.warn("Permissions service not initialized yet. Element will remain visible.");return}try{await l.can(s.value)||(e.style.display="none"),e._permission_data.permissionChecked=!0}catch(a){console.error("Error checking permission:",a)}},async updated(e,s){var r;if(!e._permission_data||e._permission_data.action!==s.value){const a=((r=e._permission_data)==null?void 0:r.originalDisplay)||e.style.display||"";if(e._permission_data={action:s.value,originalDisplay:a,permissionChecked:!1},!l){console.warn("Permissions service not initialized yet. Element will remain visible.");return}try{await l.can(s.value)?e.style.display=e._permission_data.originalDisplay:e.style.display="none",e._permission_data.permissionChecked=!0}catch(o){console.error("Error checking permission:",o)}}},unmounted(e){e._permission_data&&(e.style.display=e._permission_data.originalDisplay,delete e._permission_data)}},h=Symbol("Permissions");function y(e){const s=new k(e);return f(s),s}const w={install(e,s){const r=y(s);e.provide(h,r),e.config.globalProperties.$permissions=r}};function g(){const e=i.inject(h);if(!e)throw new Error("Permissions plugin not installed!");return e}function v(e,s={}){const r=g(),a=i.ref(null),o=i.ref(!1),c=i.ref(null),_=i.computed(()=>typeof e=="string"?e:e.value),m=async()=>{if(_.value){o.value=!0,c.value=null;try{a.value=await r.can(_.value)}catch(d){c.value=d instanceof Error?d:new Error(String(d)),a.value=!1}finally{o.value=!1}}};if(s.autoCheck!==!1&&m(),typeof e!="string"){const d=i.watch(e,()=>{m()});i.onUnmounted(()=>{d()})}return{isAllowed:a,isLoading:o,error:c,check:m,can:i.computed(()=>a.value===!0)}}const S=i.defineComponent({name:"Check",props:{action:{type:String,required:!0},fallback:{type:Boolean,default:!1}},setup(e){const{action:s}=i.toRefs(e),r=i.ref(!0),{can:a,isLoading:o,check:c}=v(s,{autoCheck:!1});return i.onMounted(async()=>{await c(),r.value=!1}),{can:a,isLoading:o,isInitialLoading:r}}}),C=(e,s)=>{const r=e.__vccOpts||e;for(const[a,o]of s)r[a]=o;return r};function L(e,s,r,a,o,c){return e.can&&!e.isInitialLoading?i.renderSlot(e.$slots,"default",{key:0}):!e.isLoading&&!e.isInitialLoading&&!e.can?i.renderSlot(e.$slots,"fallback",{key:1}):e.isLoading||e.isInitialLoading?i.renderSlot(e.$slots,"loading",{key:2}):i.createCommentVNode("",!0)}const P=C(S,[["render",L]]),b={install(e,s){e.use(w,s),e.component("Check",P),e.directive("can",p)}};n.Check=P,n.default=b,n.setPermissionsService=f,n.setupPermissions=y,n.usePermissions=v,n.usePermissionsService=g,n.vCan=p,Object.defineProperties(n,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}})});
2
2
  //# sourceMappingURL=locator-ars-lib.umd.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"locator-ars-lib.umd.js","sources":["../src/services/permissionsService.ts","../src/directives/vCan.ts","../src/plugin.ts","../src/composables/usePermissions.ts","../src/components/Check.vue","../src/index.ts"],"sourcesContent":["import axios, { AxiosInstance } from 'axios'\n\nexport interface PermissionsOptions {\n baseUrl?: string\n endpoint?: string\n}\n\nexport class PermissionsService {\n private axios: AxiosInstance\n private cache: Map<string, boolean> = new Map()\n private endpoint: string\n\n constructor(options?: PermissionsOptions) {\n this.axios = axios.create({\n baseURL: options?.baseUrl || ''\n })\n this.endpoint = options?.endpoint || '/api/v1/dashboard/access'\n }\n\n async can(action: string): Promise<boolean> {\n // Check if we have a cached result\n if (this.cache.has(action)) {\n return this.cache.get(action) as boolean\n }\n\n try {\n const response = await this.axios.get(this.endpoint, {\n params: { action }\n })\n\n const allowed = response.data.allowed || false\n\n // Cache the result\n this.cache.set(action, allowed)\n\n return allowed\n } catch (error) {\n console.error(`Error checking permission for ${action}:`, error)\n return false\n }\n }\n\n clearCache(action?: string): void {\n if (action) {\n this.cache.delete(action)\n } else {\n this.cache.clear()\n }\n }\n} ","import { ObjectDirective, DirectiveBinding } from 'vue'\nimport { PermissionsService } from '../services/permissionsService'\n\ninterface CanHTMLElement extends HTMLElement {\n _permission_data?: {\n action: string\n originalDisplay: string\n permissionChecked?: boolean\n }\n}\n\n// Глобальный сервис проверки прав\nlet globalPermissionsService: PermissionsService | null = null;\n\n// Функция для установки экземпляра сервиса (будет вызываться при инициализации плагина)\nexport function setPermissionsService(service: PermissionsService): void {\n globalPermissionsService = service;\n}\n\nexport const vCan: ObjectDirective = {\n async mounted(el: CanHTMLElement, binding: DirectiveBinding) {\n // Store original display value\n const originalDisplay = el.style.display;\n\n // Store action and original display for updates\n el._permission_data = {\n action: binding.value,\n originalDisplay,\n permissionChecked: false\n };\n\n if (!globalPermissionsService) {\n console.warn('Permissions service not initialized yet. Element will remain visible.');\n return;\n }\n\n try {\n const hasPermission = await globalPermissionsService.can(binding.value);\n\n if (!hasPermission) {\n el.style.display = 'none';\n }\n\n el._permission_data.permissionChecked = true;\n } catch (error) {\n console.error('Error checking permission:', error);\n }\n },\n\n async updated(el: CanHTMLElement, binding: DirectiveBinding) {\n if (!el._permission_data || el._permission_data.action !== binding.value) {\n // Action has changed or directive is new\n const originalDisplay = el._permission_data?.originalDisplay || el.style.display || '';\n\n el._permission_data = {\n action: binding.value,\n originalDisplay,\n permissionChecked: false\n };\n\n if (!globalPermissionsService) {\n console.warn('Permissions service not initialized yet. Element will remain visible.');\n return;\n }\n\n try {\n const hasPermission = await globalPermissionsService.can(binding.value);\n\n if (!hasPermission) {\n el.style.display = 'none';\n } else {\n el.style.display = el._permission_data.originalDisplay;\n }\n\n el._permission_data.permissionChecked = true;\n } catch (error) {\n console.error('Error checking permission:', error);\n }\n }\n },\n\n unmounted(el: CanHTMLElement) {\n if (el._permission_data) {\n el.style.display = el._permission_data.originalDisplay;\n delete el._permission_data;\n }\n }\n} ","import { App, inject, InjectionKey } from 'vue'\nimport { PermissionsService, PermissionsOptions } from './services/permissionsService'\nimport { setPermissionsService } from './directives/vCan'\n\nexport const PermissionsKey: InjectionKey<PermissionsService> = Symbol('Permissions')\n\nexport function setupPermissions(options?: PermissionsOptions): PermissionsService {\n const service = new PermissionsService(options);\n // Устанавливаем глобальный сервис для директивы\n setPermissionsService(service);\n return service;\n}\n\nexport const PermissionsPlugin = {\n install(app: App, options?: PermissionsOptions) {\n const permissionsService = setupPermissions(options);\n app.provide(PermissionsKey, permissionsService);\n\n // Добавим сервис в глобальные свойства Vue для доступа откуда угодно\n app.config.globalProperties.$permissions = permissionsService;\n }\n}\n\nexport function usePermissionsService(): PermissionsService {\n const permissionsService = inject(PermissionsKey);\n if (!permissionsService) {\n throw new Error('Permissions plugin not installed!');\n }\n return permissionsService;\n} ","import { ref, computed, Ref, watch, onUnmounted } from 'vue'\nimport { usePermissionsService } from '../plugin'\n\nexport interface UsePermissionsOptions {\n autoCheck?: boolean\n}\n\nexport function usePermissions(action: string | Ref<string>, options: UsePermissionsOptions = {}) {\n const permissionsService = usePermissionsService()\n const isAllowed = ref<boolean | null>(null)\n const isLoading = ref(false)\n const error = ref<Error | null>(null)\n\n const actionValue = computed(() => {\n return typeof action === 'string' ? action : action.value\n })\n\n const checkPermission = async () => {\n if (!actionValue.value) return\n\n isLoading.value = true\n error.value = null\n\n try {\n isAllowed.value = await permissionsService.can(actionValue.value)\n } catch (err) {\n error.value = err instanceof Error ? err : new Error(String(err))\n isAllowed.value = false\n } finally {\n isLoading.value = false\n }\n }\n\n // Auto-check on mount if requested\n if (options.autoCheck !== false) {\n checkPermission()\n }\n\n // Re-check when action changes\n if (typeof action !== 'string') {\n const unwatch = watch(action, () => {\n checkPermission()\n })\n\n onUnmounted(() => {\n unwatch()\n })\n }\n\n return {\n isAllowed,\n isLoading,\n error,\n check: checkPermission,\n can: computed(() => isAllowed.value === true)\n }\n} ","<template>\n <slot v-if=\"can\" />\n <slot name=\"fallback\" v-else-if=\"!isLoading\" />\n <slot name=\"loading\" v-else />\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, toRefs, PropType } from 'vue';\nimport { usePermissions } from '../composables/usePermissions';\n\nexport default defineComponent({\n name: 'Check',\n props: {\n action: {\n type: String as PropType<string>,\n required: true\n },\n fallback: {\n type: Boolean,\n default: false\n }\n },\n setup(props) {\n const { action } = toRefs(props);\n const { can, isLoading } = usePermissions(action, { autoCheck: true });\n\n return {\n can,\n isLoading\n };\n }\n});\n</script> ","import { App } from 'vue'\nimport Check from './components/Check.vue'\nimport { usePermissions } from './composables/usePermissions'\nimport { PermissionsPlugin, setupPermissions, usePermissionsService } from './plugin'\nimport { vCan, setPermissionsService } from './directives/vCan'\n\n// Именованные экспорты\nexport {\n Check,\n usePermissions,\n setupPermissions,\n vCan,\n usePermissionsService,\n setPermissionsService\n}\n\n// Создаем основной объект плагина\nconst plugin = {\n install(app: App, options?: { baseUrl?: string }) {\n // Важно: сначала нужно инициализировать PermissionsPlugin для provide/inject механизма\n app.use(PermissionsPlugin, options)\n\n // Затем регистрируем компонент и директиву\n app.component('Check', Check)\n app.directive('can', vCan)\n }\n}\n\n// Экспортируем плагин как по умолчанию\nexport default plugin "],"names":["PermissionsService","options","__publicField","axios","action","allowed","error","globalPermissionsService","setPermissionsService","service","vCan","el","binding","originalDisplay","_a","PermissionsKey","setupPermissions","PermissionsPlugin","app","permissionsService","usePermissionsService","inject","usePermissions","isAllowed","ref","isLoading","actionValue","computed","checkPermission","err","unwatch","watch","onUnmounted","_sfc_main","defineComponent","props","toRefs","can","_ctx","_renderSlot","plugin","Check"],"mappings":"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"}
1
+ {"version":3,"file":"locator-ars-lib.umd.js","sources":["../src/services/permissionsService.ts","../src/directives/vCan.ts","../src/plugin.ts","../src/composables/usePermissions.ts","../src/components/Check.vue","../src/index.ts"],"sourcesContent":["import axios, { AxiosInstance } from 'axios'\n\nexport interface PermissionsOptions {\n baseUrl?: string\n endpoint?: string\n}\n\nexport class PermissionsService {\n private axios: AxiosInstance\n private cache: Map<string, boolean> = new Map()\n private endpoint: string\n\n constructor(options?: PermissionsOptions) {\n this.axios = axios.create({\n baseURL: options?.baseUrl || ''\n })\n this.endpoint = options?.endpoint || '/api/v1/dashboard/access'\n }\n\n async can(action: string): Promise<boolean> {\n // Check if we have a cached result\n if (this.cache.has(action)) {\n return this.cache.get(action) as boolean\n }\n\n try {\n const response = await this.axios.get(this.endpoint, {\n params: { action }\n })\n\n const allowed = response.data.allowed || false\n\n // Cache the result\n this.cache.set(action, allowed)\n\n return allowed\n } catch (error) {\n console.error(`Error checking permission for ${action}:`, error)\n return false\n }\n }\n\n clearCache(action?: string): void {\n if (action) {\n this.cache.delete(action)\n } else {\n this.cache.clear()\n }\n }\n} ","import { ObjectDirective, DirectiveBinding } from 'vue'\nimport { PermissionsService } from '../services/permissionsService'\n\ninterface CanHTMLElement extends HTMLElement {\n _permission_data?: {\n action: string\n originalDisplay: string\n permissionChecked?: boolean\n }\n}\n\n// Глобальный сервис проверки прав\nlet globalPermissionsService: PermissionsService | null = null;\n\n// Функция для установки экземпляра сервиса (будет вызываться при инициализации плагина)\nexport function setPermissionsService(service: PermissionsService): void {\n globalPermissionsService = service;\n}\n\nexport const vCan: ObjectDirective = {\n async mounted(el: CanHTMLElement, binding: DirectiveBinding) {\n // Store original display value\n const originalDisplay = el.style.display;\n\n // Store action and original display for updates\n el._permission_data = {\n action: binding.value,\n originalDisplay,\n permissionChecked: false\n };\n\n if (!globalPermissionsService) {\n console.warn('Permissions service not initialized yet. Element will remain visible.');\n return;\n }\n\n try {\n const hasPermission = await globalPermissionsService.can(binding.value);\n\n if (!hasPermission) {\n el.style.display = 'none';\n }\n\n el._permission_data.permissionChecked = true;\n } catch (error) {\n console.error('Error checking permission:', error);\n }\n },\n\n async updated(el: CanHTMLElement, binding: DirectiveBinding) {\n if (!el._permission_data || el._permission_data.action !== binding.value) {\n // Action has changed or directive is new\n const originalDisplay = el._permission_data?.originalDisplay || el.style.display || '';\n\n el._permission_data = {\n action: binding.value,\n originalDisplay,\n permissionChecked: false\n };\n\n if (!globalPermissionsService) {\n console.warn('Permissions service not initialized yet. Element will remain visible.');\n return;\n }\n\n try {\n const hasPermission = await globalPermissionsService.can(binding.value);\n\n if (!hasPermission) {\n el.style.display = 'none';\n } else {\n el.style.display = el._permission_data.originalDisplay;\n }\n\n el._permission_data.permissionChecked = true;\n } catch (error) {\n console.error('Error checking permission:', error);\n }\n }\n },\n\n unmounted(el: CanHTMLElement) {\n if (el._permission_data) {\n el.style.display = el._permission_data.originalDisplay;\n delete el._permission_data;\n }\n }\n} ","import { App, inject, InjectionKey } from 'vue'\nimport { PermissionsService, PermissionsOptions } from './services/permissionsService'\nimport { setPermissionsService } from './directives/vCan'\n\nexport const PermissionsKey: InjectionKey<PermissionsService> = Symbol('Permissions')\n\nexport function setupPermissions(options?: PermissionsOptions): PermissionsService {\n const service = new PermissionsService(options);\n // Устанавливаем глобальный сервис для директивы\n setPermissionsService(service);\n return service;\n}\n\nexport const PermissionsPlugin = {\n install(app: App, options?: PermissionsOptions) {\n const permissionsService = setupPermissions(options);\n app.provide(PermissionsKey, permissionsService);\n\n // Добавим сервис в глобальные свойства Vue для доступа откуда угодно\n app.config.globalProperties.$permissions = permissionsService;\n }\n}\n\nexport function usePermissionsService(): PermissionsService {\n const permissionsService = inject(PermissionsKey);\n if (!permissionsService) {\n throw new Error('Permissions plugin not installed!');\n }\n return permissionsService;\n} ","import { ref, computed, Ref, watch, onUnmounted } from 'vue'\nimport { usePermissionsService } from '../plugin'\n\nexport interface UsePermissionsOptions {\n autoCheck?: boolean\n}\n\nexport function usePermissions(action: string | Ref<string>, options: UsePermissionsOptions = {}) {\n const permissionsService = usePermissionsService()\n const isAllowed = ref<boolean | null>(null)\n const isLoading = ref(false)\n const error = ref<Error | null>(null)\n\n const actionValue = computed(() => {\n return typeof action === 'string' ? action : action.value\n })\n\n const checkPermission = async () => {\n if (!actionValue.value) return\n\n isLoading.value = true\n error.value = null\n\n try {\n isAllowed.value = await permissionsService.can(actionValue.value)\n } catch (err) {\n error.value = err instanceof Error ? err : new Error(String(err))\n isAllowed.value = false\n } finally {\n isLoading.value = false\n }\n }\n\n // Auto-check on mount if requested\n if (options.autoCheck !== false) {\n checkPermission()\n }\n\n // Re-check when action changes\n if (typeof action !== 'string') {\n const unwatch = watch(action, () => {\n checkPermission()\n })\n\n onUnmounted(() => {\n unwatch()\n })\n }\n\n return {\n isAllowed,\n isLoading,\n error,\n check: checkPermission,\n can: computed(() => isAllowed.value === true)\n }\n} ","<template>\n <slot v-if=\"can && !isInitialLoading\" />\n <slot name=\"fallback\" v-else-if=\"!isLoading && !isInitialLoading && !can\" />\n <slot name=\"loading\" v-else-if=\"isLoading || isInitialLoading\" />\n</template>\n\n<script lang=\"ts\">\nimport { defineComponent, toRefs, PropType, ref, onMounted } from 'vue';\nimport { usePermissions } from '../composables/usePermissions';\n\nexport default defineComponent({\n name: 'Check',\n props: {\n action: {\n type: String as PropType<string>,\n required: true\n },\n fallback: {\n type: Boolean,\n default: false\n }\n },\n setup(props) {\n const { action } = toRefs(props);\n const isInitialLoading = ref(true);\n const { can, isLoading, check } = usePermissions(action, { autoCheck: false });\n \n onMounted(async () => {\n await check();\n isInitialLoading.value = false;\n });\n\n return {\n can,\n isLoading,\n isInitialLoading\n };\n }\n});\n</script> ","import { App } from 'vue'\nimport Check from './components/Check.vue'\nimport { usePermissions } from './composables/usePermissions'\nimport { PermissionsPlugin, setupPermissions, usePermissionsService } from './plugin'\nimport { vCan, setPermissionsService } from './directives/vCan'\n\n// Именованные экспорты\nexport {\n Check,\n usePermissions,\n setupPermissions,\n vCan,\n usePermissionsService,\n setPermissionsService\n}\n\n// Создаем основной объект плагина\nconst plugin = {\n install(app: App, options?: { baseUrl?: string }) {\n // Важно: сначала нужно инициализировать PermissionsPlugin для provide/inject механизма\n app.use(PermissionsPlugin, options)\n\n // Затем регистрируем компонент и директиву\n app.component('Check', Check)\n app.directive('can', vCan)\n }\n}\n\n// Экспортируем плагин как по умолчанию\nexport default plugin "],"names":["PermissionsService","options","__publicField","axios","action","allowed","error","globalPermissionsService","setPermissionsService","service","vCan","el","binding","originalDisplay","_a","PermissionsKey","setupPermissions","PermissionsPlugin","app","permissionsService","usePermissionsService","inject","usePermissions","isAllowed","ref","isLoading","actionValue","computed","checkPermission","err","unwatch","watch","onUnmounted","_sfc_main","defineComponent","props","toRefs","isInitialLoading","can","check","onMounted","_ctx","_renderSlot","_createCommentVNode","plugin","Check"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "locator-ars-lib",
3
- "version": "1.0.8",
3
+ "version": "1.0.9",
4
4
  "description": "Permissions library for Vue 3 applications",
5
5
  "type": "module",
6
6
  "main": "./dist/locator-ars-lib.umd.js",