samandesk 1.0.13 → 1.0.15

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.
package/dist/data.d.ts CHANGED
@@ -20,4 +20,10 @@ export declare function clearFrame(): void;
20
20
  export declare function setFrameSrc(src: string): void;
21
21
  /** ⁧تگ iframe را بر می‌گرداند ⁩ */
22
22
  export declare function getFrame(): HTMLIFrameElement;
23
+ /** تم کتابخانه را بر می‌گرداند */
24
+ export declare function getTheme(): "light" | "dark" | undefined;
25
+ /** ‌ تم جدید کتابخانه را تنظیم می‌کند */
26
+ export declare function setTheme(newTheme: 'light' | 'dark'): void;
27
+ /** عنصر بکدراپ را برمی‌گرداند */
28
+ export declare function getBackdrop(): HTMLDivElement;
23
29
  export {};
package/dist/index.d.ts CHANGED
@@ -12,8 +12,20 @@ export interface OpenConfig {
12
12
  * ⁧در این حالت یک overlay پشت کتابخانه قرار خواهد گرفت
13
13
  */
14
14
  fullScreen: boolean;
15
+ /**
16
+ * تم کتابخانه به چه صورت باشد؟
17
+ *
18
+ * ⁧'light': تم کتابخانه روشن است
19
+ *
20
+ * ⁧'dark': تم برنامه تاریک است
21
+ */
22
+ theme?: 'light' | 'dark';
15
23
  }
16
24
  export declare class SamanDesk {
25
+ /**
26
+ * ⁧ شی‌ء کلاس InterOperation
27
+ */
28
+ private interoperation?;
17
29
  /**
18
30
  * ⁧این تابع در ابتدا مقدار verifiedToken را دریافت کرده و سپس مقدار token‌ را دریافت و سپس آن را ذخیره می‌کند
19
31
  */
@@ -2,7 +2,7 @@ import { FunctionKeys } from 'utility-types';
2
2
  /**
3
3
  * این تابع برای فراخوانی متدهاییست که مقداری بر نمی‌گردانند
4
4
  */
5
- export declare function post(action: keyof InterOperation, data?: object): void;
5
+ export declare function post(action: string, data?: object): void;
6
6
  /**
7
7
  * این تابع برای فراخوانی متدهاییست که مقدار بر می‌گردانند
8
8
  */
@@ -13,4 +13,6 @@ export declare class InterOperation {
13
13
  setToken(data: any): void;
14
14
  /** بستن کتابخانه */
15
15
  close(): void;
16
+ /** تم کتابخانه را به بیرون اطلاع می‌دهد */
17
+ getTheme(data: any): void;
16
18
  }
@@ -1,73 +1,95 @@
1
1
  let p;
2
- const a = document.createElement("iframe"), m = {
2
+ const c = document.createElement("iframe");
3
+ let u;
4
+ const h = document.createElement("div"), f = {
3
5
  count: 0,
4
6
  promises: {}
5
7
  };
6
- function u() {
7
- return m;
8
+ function g() {
9
+ return f;
8
10
  }
9
- function f(n) {
11
+ function b(n) {
10
12
  p = n;
11
13
  }
12
- function h() {
14
+ function y() {
13
15
  return p;
14
16
  }
15
- function c() {
16
- a.src = "";
17
+ function d() {
18
+ c.src = "";
19
+ }
20
+ function l(n) {
21
+ c.src = n;
22
+ }
23
+ function i() {
24
+ return c;
17
25
  }
18
- function d(n) {
19
- a.src = n;
26
+ function k() {
27
+ return u;
20
28
  }
21
- function r() {
22
- return a;
29
+ function E(n) {
30
+ u = n;
23
31
  }
24
- const g = new Event("ready"), w = new Event("open"), y = new Event("close");
25
- function E() {
26
- return g;
32
+ function a() {
33
+ return h;
27
34
  }
28
- function x() {
35
+ const w = new Event("ready"), x = new Event("open"), v = new Event("close");
36
+ function S() {
29
37
  return w;
30
38
  }
31
- function v() {
32
- return y;
39
+ function C() {
40
+ return x;
33
41
  }
34
- function b(n) {
42
+ function T() {
43
+ return v;
44
+ }
45
+ function O(n) {
35
46
  window.addEventListener("message", (e) => {
36
47
  if (!e.data.from || e.data.from !== "SamanDesk")
37
48
  return;
38
49
  let t = !1;
39
50
  console.log(`message from (${e.origin})`, e);
40
51
  try {
41
- n[e.data.action](e.data.data), t = !0;
52
+ n[e.data.action](e.data), t = !0;
42
53
  } catch {
43
54
  console.error("error while run event action");
44
55
  }
45
- const o = e.data, s = o.id, i = u();
46
- s in i.promises ? (i.promises[s](o), delete i.promises[s]) : t || console.error("Message from outside of frame is invalid");
56
+ const o = e.data, r = o.id, s = g();
57
+ r in s.promises ? (s.promises[r](o), delete s.promises[r]) : t || console.error("Message from outside of frame is invalid");
47
58
  });
48
59
  }
49
- class k {
60
+ function D(n, e, t) {
61
+ var s;
62
+ const o = { from: "SamanDesk", action: t, data: e, id: n };
63
+ (s = i().contentWindow) == null || s.postMessage(o, "*");
64
+ }
65
+ class I {
50
66
  async init() {
51
- b(this);
67
+ O(this);
52
68
  }
53
69
  /** توکن را از میزبان دریافت کرده و آن را ذخیره می‌کند. سپس به میزبان اعلام می‌کند که آماده‌ی ادامه‌ی کار است */
54
70
  setToken(e) {
55
- f(e.token), c(), window.dispatchEvent(E());
71
+ b(e.data.token), d(), window.dispatchEvent(S());
56
72
  }
57
73
  /** بستن کتابخانه */
58
74
  close() {
59
- c(), document.body.removeChild(r()), window.dispatchEvent(v());
75
+ d();
76
+ const e = a();
77
+ document.body.removeChild(e), e.onclick = null, document.body.removeChild(i()), window.dispatchEvent(T());
78
+ }
79
+ /** تم کتابخانه را به بیرون اطلاع می‌دهد */
80
+ getTheme(e) {
81
+ D(e.id, { theme: k() }, e.action);
60
82
  }
61
83
  }
62
- const l = "http://localhost:2525";
63
- class O {
84
+ const m = {}.VITE_DEV_MODE === "1" ? "http://localhost:2525" : "https://samandesk.com";
85
+ class $ {
64
86
  /**
65
87
  * ⁧این تابع در ابتدا مقدار verifiedToken را دریافت کرده و سپس مقدار token‌ را دریافت و سپس آن را ذخیره می‌کند
66
88
  */
67
89
  async init(e) {
68
- new k().init();
69
- const o = r();
70
- d(`${l}/setup-interoperation/${e}`), o.width = "0", document.body.appendChild(o);
90
+ this.interoperation = new I(), this.interoperation.init();
91
+ const t = i(), o = a();
92
+ l(`${m}/setup-interoperation/${e}`), t.width = "0", t.style.width = "0", document.body.appendChild(o), document.body.appendChild(t);
71
93
  }
72
94
  /**
73
95
  * استایل مربوط به آیفریم را تنظیم می‌کند
@@ -76,8 +98,18 @@ class O {
76
98
  *
77
99
  */
78
100
  setStyle(e) {
79
- const t = r();
80
- t.style.position = "fixed", t.style.zIndex = "1000", e ? (Object.assign(t.style, {
101
+ const t = i(), o = a();
102
+ t.style.position = "fixed", t.style.zIndex = "1000";
103
+ const r = {
104
+ position: "fixed",
105
+ top: "0",
106
+ bottom: "0",
107
+ left: "0",
108
+ right: "0",
109
+ backgroundColor: "rgba(0,0,0,0.5)",
110
+ zIndex: "1000"
111
+ };
112
+ Object.assign(o.style, r), e ? (Object.assign(t.style, {
81
113
  bottom: "0",
82
114
  left: "0",
83
115
  top: "0",
@@ -87,7 +119,7 @@ class O {
87
119
  left: "50%",
88
120
  transform: "translate(-50%, -50%)",
89
121
  width: "100%",
90
- maxWidth: "450px",
122
+ maxWidth: "500px",
91
123
  boxShadow: "0px 0px 100px 0px rgba(0,0,0,0.48)",
92
124
  borderRadius: "24px",
93
125
  height: "100%",
@@ -98,10 +130,15 @@ class O {
98
130
  * این تابع آیفریم را باز می‌کند.
99
131
  */
100
132
  open(e) {
101
- const t = r(), o = e.link || `${l}/department-selection?token=${h()}`;
102
- d(o), this.setStyle(e.fullScreen), document.body.appendChild(t), window.dispatchEvent(x());
133
+ const t = i(), o = a();
134
+ E(e.theme ?? "light");
135
+ const r = e.link || `${m}/department-selection?token=${y()}`;
136
+ l(r), this.setStyle(e.fullScreen), document.body.appendChild(o), document.body.appendChild(t), o.onclick = () => {
137
+ var s;
138
+ (s = this.interoperation) == null || s.close();
139
+ }, window.dispatchEvent(C());
103
140
  }
104
141
  }
105
142
  export {
106
- O as SamanDesk
143
+ $ as SamanDesk
107
144
  };
@@ -1 +1 @@
1
- (function(s,i){typeof exports=="object"&&typeof module<"u"?i(exports):typeof define=="function"&&define.amd?define(["exports"],i):(s=typeof globalThis<"u"?globalThis:s||self,i(s.SamanDesk={}))})(this,function(s){"use strict";let i;const a=document.createElement("iframe"),u={count:0,promises:{}};function m(){return u}function h(n){i=n}function y(){return i}function l(){a.src=""}function f(n){a.src=n}function r(){return a}const g=new Event("ready"),w=new Event("open"),E=new Event("close");function x(){return g}function b(){return w}function v(){return E}function S(n){window.addEventListener("message",e=>{if(!e.data.from||e.data.from!=="SamanDesk")return;let t=!1;console.log(`message from (${e.origin})`,e);try{n[e.data.action](e.data.data),t=!0}catch{console.error("error while run event action")}const o=e.data,c=o.id,d=m();c in d.promises?(d.promises[c](o),delete d.promises[c]):t||console.error("Message from outside of frame is invalid")})}class k{async init(){S(this)}setToken(e){h(e.token),l(),window.dispatchEvent(x())}close(){l(),document.body.removeChild(r()),window.dispatchEvent(v())}}const p="http://localhost:2525";class T{async init(e){new k().init();const o=r();f(`${p}/setup-interoperation/${e}`),o.width="0",document.body.appendChild(o)}setStyle(e){const t=r();t.style.position="fixed",t.style.zIndex="1000",e?(Object.assign(t.style,{bottom:"0",left:"0",top:"0",right:"0"}),t.width="100%",t.height="100%"):Object.assign(t.style,{top:"50%",left:"50%",transform:"translate(-50%, -50%)",width:"100%",maxWidth:"450px",boxShadow:"0px 0px 100px 0px rgba(0,0,0,0.48)",borderRadius:"24px",height:"100%",maxHeight:"660px"})}open(e){const t=r(),o=e.link||`${p}/department-selection?token=${y()}`;f(o),this.setStyle(e.fullScreen),document.body.appendChild(t),window.dispatchEvent(b())}}s.SamanDesk=T,Object.defineProperty(s,Symbol.toStringTag,{value:"Module"})});
1
+ (function(r,a){typeof exports=="object"&&typeof module<"u"?a(exports):typeof define=="function"&&define.amd?define(["exports"],a):(r=typeof globalThis<"u"?globalThis:r||self,a(r.SamanDesk={}))})(this,function(r){"use strict";let a;const l=document.createElement("iframe");let p;const h=document.createElement("div"),g={count:0,promises:{}};function y(){return g}function b(n){a=n}function k(){return a}function m(){l.src=""}function u(n){l.src=n}function c(){return l}function E(){return p}function w(n){p=n}function d(){return h}const x=new Event("ready"),v=new Event("open"),S=new Event("close");function T(){return x}function C(){return v}function D(){return S}function O(n){window.addEventListener("message",e=>{if(!e.data.from||e.data.from!=="SamanDesk")return;let t=!1;console.log(`message from (${e.origin})`,e);try{n[e.data.action](e.data),t=!0}catch{console.error("error while run event action")}const o=e.data,i=o.id,s=y();i in s.promises?(s.promises[i](o),delete s.promises[i]):t||console.error("Message from outside of frame is invalid")})}function I(n,e,t){var s;const o={from:"SamanDesk",action:t,data:e,id:n};(s=c().contentWindow)==null||s.postMessage(o,"*")}class j{async init(){O(this)}setToken(e){b(e.data.token),m(),window.dispatchEvent(T())}close(){m();const e=d();document.body.removeChild(e),e.onclick=null,document.body.removeChild(c()),window.dispatchEvent(D())}getTheme(e){I(e.id,{theme:E()},e.action)}}const f={}.VITE_DEV_MODE==="1"?"http://localhost:2525":"https://samandesk.com";class R{async init(e){this.interoperation=new j,this.interoperation.init();const t=c(),o=d();u(`${f}/setup-interoperation/${e}`),t.width="0",t.style.width="0",document.body.appendChild(o),document.body.appendChild(t)}setStyle(e){const t=c(),o=d();t.style.position="fixed",t.style.zIndex="1000";const i={position:"fixed",top:"0",bottom:"0",left:"0",right:"0",backgroundColor:"rgba(0,0,0,0.5)",zIndex:"1000"};Object.assign(o.style,i),e?(Object.assign(t.style,{bottom:"0",left:"0",top:"0",right:"0"}),t.width="100%",t.height="100%"):Object.assign(t.style,{top:"50%",left:"50%",transform:"translate(-50%, -50%)",width:"100%",maxWidth:"500px",boxShadow:"0px 0px 100px 0px rgba(0,0,0,0.48)",borderRadius:"24px",height:"100%",maxHeight:"660px"})}open(e){const t=c(),o=d();w(e.theme??"light");const i=e.link||`${f}/department-selection?token=${k()}`;u(i),this.setStyle(e.fullScreen),document.body.appendChild(o),document.body.appendChild(t),o.onclick=()=>{var s;(s=this.interoperation)==null||s.close()},window.dispatchEvent(C())}}r.SamanDesk=R,Object.defineProperty(r,Symbol.toStringTag,{value:"Module"})});
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "samandesk",
3
- "version": "1.0.13",
3
+ "version": "1.0.15",
4
4
  "license": "MIT",
5
5
  "type": "module",
6
6
  "files": [