@acorex/core 6.5.27 → 6.5.29

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (143) hide show
  1. package/acorex-core.d.ts +5 -0
  2. package/esm2020/acorex-core.mjs +5 -0
  3. package/esm2020/lib/classes/base-page.class.mjs +28 -0
  4. package/esm2020/lib/classes/color.class.mjs +49 -0
  5. package/esm2020/lib/classes/datetime.class.mjs +314 -0
  6. package/esm2020/lib/classes/menu.class.mjs +27 -0
  7. package/esm2020/lib/classes/navigator.class.mjs +2 -0
  8. package/esm2020/lib/classes/popup.class.mjs +2 -0
  9. package/esm2020/lib/classes/promise.class.mjs +19 -0
  10. package/esm2020/lib/classes/sectionlist.class.mjs +2 -0
  11. package/esm2020/lib/classes/select.class.mjs +3 -0
  12. package/esm2020/lib/core.module.mjs +27 -0
  13. package/esm2020/lib/error/error.class.mjs +2 -0
  14. package/esm2020/lib/error/error.module.mjs +19 -0
  15. package/esm2020/lib/error/error.service.mjs +21 -0
  16. package/esm2020/lib/events/keyboard.mjs +2 -0
  17. package/esm2020/lib/http/http-error.class.mjs +2 -0
  18. package/esm2020/lib/http/http-events.interceptor.mjs +3 -0
  19. package/esm2020/lib/http/http-request.class.mjs +2 -0
  20. package/esm2020/lib/http/http-result.class.mjs +21 -0
  21. package/esm2020/lib/http/http.module.mjs +37 -0
  22. package/esm2020/lib/http/http.service.mjs +145 -0
  23. package/{src → esm2020}/lib/locale/en.json +6 -6
  24. package/{src → esm2020}/lib/locale/fa.json +7 -7
  25. package/esm2020/lib/pipe/datetime.pipe.mjs +25 -0
  26. package/esm2020/lib/pipe/htmlToText.pipe.mjs +25 -0
  27. package/esm2020/lib/platform/index.mjs +2 -0
  28. package/esm2020/lib/platform/platform.service.mjs +150 -0
  29. package/esm2020/lib/services/config.mjs +29 -0
  30. package/esm2020/lib/services/event.service.mjs +36 -0
  31. package/esm2020/lib/services/navigator.service.mjs +10 -0
  32. package/esm2020/lib/services/storage.service.mjs +16 -0
  33. package/esm2020/lib/translator/translator.mjs +26 -0
  34. package/esm2020/lib/translator/translator.module.mjs +25 -0
  35. package/esm2020/lib/translator/translator.pipe.mjs +24 -0
  36. package/esm2020/lib/translator/translator.service.mjs +21 -0
  37. package/esm2020/lib/utils/array/array-util.mjs +133 -0
  38. package/esm2020/lib/utils/html/html-util.mjs +192 -0
  39. package/esm2020/lib/utils/html/html.module.mjs +19 -0
  40. package/esm2020/lib/utils/math/math-util.mjs +6 -0
  41. package/esm2020/lib/utils/object/object-util.mjs +83 -0
  42. package/esm2020/lib/utils/render/on-demand-preload-strategy.service.mjs +20 -0
  43. package/esm2020/lib/utils/render/render.service.mjs +103 -0
  44. package/esm2020/lib/utils/render/rendering.module.mjs +35 -0
  45. package/esm2020/lib/utils/scroll/scroll.directive.mjs +54 -0
  46. package/esm2020/lib/utils/scroll/scroll.module.mjs +19 -0
  47. package/esm2020/lib/utils/separator/separator.module.mjs +19 -0
  48. package/esm2020/lib/utils/separator/separator.pipe.mjs +33 -0
  49. package/esm2020/public-api.mjs +44 -0
  50. package/fesm2015/acorex-core.mjs +2274 -0
  51. package/fesm2015/acorex-core.mjs.map +1 -0
  52. package/fesm2020/acorex-core.mjs +2270 -0
  53. package/fesm2020/acorex-core.mjs.map +1 -0
  54. package/lib/classes/base-page.class.d.ts +13 -0
  55. package/lib/classes/color.class.d.ts +17 -0
  56. package/lib/classes/datetime.class.d.ts +63 -0
  57. package/lib/classes/menu.class.d.ts +34 -0
  58. package/{src/lib/classes/navigator.class.ts → lib/classes/navigator.class.d.ts} +1 -1
  59. package/{src/lib/classes/popup.class.ts → lib/classes/popup.class.d.ts} +0 -2
  60. package/lib/classes/promise.class.d.ts +7 -0
  61. package/lib/classes/select.class.d.ts +7 -0
  62. package/lib/core.module.d.ts +9 -0
  63. package/lib/error/error.module.d.ts +7 -0
  64. package/lib/error/error.service.d.ts +13 -0
  65. package/{src/lib/events/keyboard.ts → lib/events/keyboard.d.ts} +0 -3
  66. package/{src/lib/http/http-error.class.ts → lib/http/http-error.class.d.ts} +2 -2
  67. package/{src/lib/http/http-events.interceptor.ts → lib/http/http-events.interceptor.d.ts} +3 -7
  68. package/{src/lib/http/http-request.class.ts → lib/http/http-request.class.d.ts} +5 -5
  69. package/lib/http/http-result.class.d.ts +11 -0
  70. package/lib/http/http.module.d.ts +10 -0
  71. package/lib/http/http.service.d.ts +23 -0
  72. package/lib/pipe/datetime.pipe.d.ts +8 -0
  73. package/lib/pipe/htmlToText.pipe.d.ts +7 -0
  74. package/lib/platform/index.d.ts +1 -0
  75. package/lib/platform/platform.service.d.ts +26 -0
  76. package/lib/services/config.d.ts +9 -0
  77. package/lib/services/event.service.d.ts +9 -0
  78. package/lib/services/navigator.service.d.ts +8 -0
  79. package/lib/services/storage.service.d.ts +7 -0
  80. package/lib/translator/translator.d.ts +9 -0
  81. package/lib/translator/translator.module.d.ts +8 -0
  82. package/lib/translator/translator.pipe.d.ts +8 -0
  83. package/lib/translator/translator.service.d.ts +8 -0
  84. package/lib/utils/array/array-util.d.ts +6 -0
  85. package/lib/utils/html/html-util.d.ts +62 -0
  86. package/lib/utils/html/html.module.d.ts +8 -0
  87. package/lib/utils/math/math-util.d.ts +3 -0
  88. package/lib/utils/object/object-util.d.ts +7 -0
  89. package/lib/utils/render/on-demand-preload-strategy.service.d.ts +10 -0
  90. package/lib/utils/render/render.service.d.ts +18 -0
  91. package/lib/utils/render/rendering.module.d.ts +8 -0
  92. package/lib/utils/scroll/scroll.directive.d.ts +18 -0
  93. package/lib/utils/scroll/scroll.module.d.ts +8 -0
  94. package/lib/utils/separator/separator.module.d.ts +8 -0
  95. package/lib/utils/separator/separator.pipe.d.ts +8 -0
  96. package/package.json +32 -12
  97. package/{src/public-api.ts → public-api.d.ts} +0 -10
  98. package/karma.conf.js +0 -32
  99. package/ng-package.json +0 -10
  100. package/src/lib/classes/base-page.class.ts +0 -29
  101. package/src/lib/classes/color.class.ts +0 -61
  102. package/src/lib/classes/datetime.class.ts +0 -373
  103. package/src/lib/classes/menu.class.ts +0 -37
  104. package/src/lib/classes/promise.class.ts +0 -25
  105. package/src/lib/classes/select.class.ts +0 -7
  106. package/src/lib/core.module.ts +0 -21
  107. package/src/lib/error/error.module.ts +0 -13
  108. package/src/lib/error/error.service.ts +0 -23
  109. package/src/lib/error/index.ts +0 -3
  110. package/src/lib/http/http-result.class.ts +0 -34
  111. package/src/lib/http/http.module.ts +0 -25
  112. package/src/lib/http/http.service.ts +0 -159
  113. package/src/lib/pipe/datetime.pipe.ts +0 -20
  114. package/src/lib/pipe/htmlToText.pipe.ts +0 -18
  115. package/src/lib/platform/index.ts +0 -1
  116. package/src/lib/platform/platform.service.ts +0 -223
  117. package/src/lib/services/config.ts +0 -36
  118. package/src/lib/services/event.service.ts +0 -31
  119. package/src/lib/services/navigator.service.ts +0 -8
  120. package/src/lib/services/storage.service.ts +0 -11
  121. package/src/lib/translator/translator.module.ts +0 -19
  122. package/src/lib/translator/translator.pipe.ts +0 -22
  123. package/src/lib/translator/translator.service.ts +0 -19
  124. package/src/lib/translator/translator.ts +0 -31
  125. package/src/lib/utils/array/array-util.ts +0 -140
  126. package/src/lib/utils/html/html-util.ts +0 -264
  127. package/src/lib/utils/html/html.module.ts +0 -11
  128. package/src/lib/utils/math/math-util.ts +0 -5
  129. package/src/lib/utils/object/object-util.ts +0 -87
  130. package/src/lib/utils/render/on-demand-preload-strategy.service.ts +0 -25
  131. package/src/lib/utils/render/render.service.ts +0 -110
  132. package/src/lib/utils/render/rendering.module.ts +0 -25
  133. package/src/lib/utils/scroll/scroll.directive.ts +0 -35
  134. package/src/lib/utils/scroll/scroll.module.ts +0 -11
  135. package/src/lib/utils/separator/separator.module.ts +0 -11
  136. package/src/lib/utils/separator/separator.pipe.ts +0 -27
  137. package/src/test.ts +0 -28
  138. package/tsconfig.lib.json +0 -25
  139. package/tsconfig.lib.prod.json +0 -6
  140. package/tsconfig.spec.json +0 -18
  141. package/tslint.json +0 -17
  142. /package/{src/lib/classes/sectionlist.class.ts → lib/classes/sectionlist.class.d.ts} +0 -0
  143. /package/{src/lib/error/error.class.ts → lib/error/error.class.d.ts} +0 -0
@@ -1,159 +0,0 @@
1
- import { Injectable, Injector, InjectFlags } from '@angular/core';
2
- import { HttpClient, HttpHeaders, HttpParams, HttpErrorResponse } from '@angular/common/http';
3
- import { HttpResult } from './http-result.class';
4
- import { IHttpError } from './http-error.class';
5
- import { AXHttpRequestOptions } from './http-request.class';
6
- import {
7
- AX_HTTP_EVENT_INTERCEPTOR, AXHttpEventInterceptor
8
- } from './http-events.interceptor';
9
- // import { catchError, retry, retryWhen, mergeMap, delay, switchMap, scan, takeWhile, flatMap } from 'rxjs/operators';
10
- // import { of, concat, throwError } from 'rxjs';
11
-
12
-
13
- @Injectable()
14
- export class AXHttpService {
15
-
16
- private interceptor: AXHttpEventInterceptor;
17
- constructor(private http: HttpClient, private injector: Injector) {
18
- this.interceptor = this.injector.get(AX_HTTP_EVENT_INTERCEPTOR);
19
- }
20
-
21
-
22
- get<T>(url: string, config: AXHttpRequestOptions = {}): HttpResult<T> {
23
- config.url = url;
24
- config.method = "get";
25
- return this.request(config);
26
- }
27
-
28
- post<T>(url: string, config: AXHttpRequestOptions = {}): HttpResult<T> {
29
- config.url = url;
30
- config.method = "post";
31
- return this.request(config);
32
- }
33
-
34
- delete<T>(url: string, config: AXHttpRequestOptions = {}): HttpResult<T> {
35
- config.url = url;
36
- config.method = "delete";
37
- return this.request(config);
38
- }
39
-
40
- put<T>(url: string, config: AXHttpRequestOptions = {}): HttpResult<T> {
41
- config.url = url;
42
- config.method = "put";
43
- return this.request(config);
44
- }
45
-
46
-
47
- request<T>(config: AXHttpRequestOptions): HttpResult<T> {
48
- return new HttpResult<T>((result?, error?, complete?) => {
49
- this.handleBegin(config).then(c => {
50
- this.http
51
- .request<T>(config.method, config.url, this.mapOptions(config))
52
- //.pipe(this.retry)
53
- .subscribe(data => {
54
- this.handleResult(data, result, complete, config);
55
- }, c => {
56
- this.handleError(c, error, complete, config);
57
- });
58
- });
59
- })
60
- }
61
-
62
-
63
- private handleResult(data, result, complete, config: AXHttpRequestOptions) {
64
- if (this.interceptor) {
65
- this.interceptor.success(config, data).then(c => {
66
- if (result)
67
- result(c);
68
- this.handleComplete(complete, config);
69
- });
70
- }
71
- else {
72
- //
73
- if (result)
74
- result(data);
75
- this.handleComplete(complete, config);
76
- }
77
- }
78
-
79
- private handleBegin(config: AXHttpRequestOptions): Promise<AXHttpRequestOptions> {
80
- return new Promise((resolve) => {
81
- if (!config.headers)
82
- config.headers = {};
83
- if (!config.params)
84
- config.params = {};
85
- //
86
- if (this.interceptor) {
87
- this.interceptor.begin(config).then(c => {
88
- resolve(c);
89
- });
90
- }
91
- else {
92
- resolve(config)
93
- }
94
- })
95
- }
96
-
97
- private handleComplete(complete: Function, config: AXHttpRequestOptions) {
98
- if (complete)
99
- complete();
100
- if (this.interceptor)
101
- this.interceptor.complete(config);
102
- }
103
-
104
- private handleError(c: HttpErrorResponse, error: Function, complete: Function, config: AXHttpRequestOptions) {
105
- let r: IHttpError = {
106
- message: c.message,
107
- status: c.status,
108
- code: c.status?.toString(),
109
- handled: false,
110
- error: c.error
111
- }
112
- if (error) {
113
- error(r);
114
- }
115
- if (!r.handled) {
116
- if (this.interceptor)
117
- this.interceptor.error(config, r);
118
- }
119
- this.handleComplete(complete, config);
120
- }
121
-
122
- private mapOptions(options: AXHttpRequestOptions) {
123
- let headers = new HttpHeaders();
124
-
125
- for (const key in options.headers) {
126
- if (options.headers.hasOwnProperty(key)) {
127
- const value = options.headers[key];
128
- headers = headers.set(key, value)
129
- }
130
- }
131
- let params = new HttpParams();
132
- for (const key in options.params) {
133
- if (options.params.hasOwnProperty(key)) {
134
- const value = options.params[key];
135
- params = params.set(key, value);
136
- }
137
- }
138
- return {
139
- headers: headers,
140
- params: params,
141
- body: options.body,
142
- responseType: options.responseType || 'json'
143
- };
144
- // if (options.method == "get") {
145
- // return {
146
- // headers: headers,
147
- // params: params
148
- // };
149
- // }
150
- // else {
151
- // return {
152
- // headers: headers,
153
- // params: params,
154
- // body: options.body
155
- // };
156
- // }
157
- }
158
-
159
- }
@@ -1,20 +0,0 @@
1
- import { PipeTransform, Pipe } from '@angular/core';
2
- import { AXDateTime } from '../classes/datetime.class';
3
-
4
- @Pipe({ name: 'dt' })
5
- export class AXDateTimePipe implements PipeTransform {
6
- constructor() { }
7
-
8
- transform(value: any, format?: string): string {
9
- const date: AXDateTime = AXDateTime.convert(value);
10
- if (value == null) {
11
- return '';
12
- }
13
- if (!format) {
14
- return date.toString();
15
- }
16
- else {
17
- return date.format(format);
18
- }
19
- }
20
- }
@@ -1,18 +0,0 @@
1
- import { Pipe, PipeTransform } from '@angular/core';
2
-
3
- @Pipe({ name: 'html2text' })
4
- export class AXHtmlToTextPipe implements PipeTransform {
5
- transform(value: string) {
6
- if (value) {
7
- const regexHtml = /<\/?[^>]+>/gi;
8
- const regexNbsp = /&nbsp;/gi;
9
- const regexAmp = /&amp;/gi;
10
- return value
11
- .replace(regexHtml, '')
12
- .replace(regexNbsp, '')
13
- .replace(regexAmp, '');
14
- } else {
15
- return '';
16
- }
17
- }
18
- }
@@ -1 +0,0 @@
1
- export * from './platform.service';
@@ -1,223 +0,0 @@
1
- import { Injectable } from "@angular/core";
2
- import { from, fromEvent, Subject } from "rxjs";
3
- import { debounceTime, distinctUntilChanged } from "rxjs/operators";
4
-
5
-
6
- export type AXPlatforms = 'Android' | 'Desktop' | 'iOS' | 'Mobile' | '';
7
- export type AXBrowsers = 'Chrome' | 'Safari' | 'Edge' | 'Firefox' | 'Opera' | 'MSIE';
8
- export type AXTechnologies = 'PWA' | 'Hybrid' | 'Electron';
9
- export type AXScreenSizes = 'SM' | 'MD' | 'LG' | 'XL' | '2XL';
10
-
11
-
12
-
13
- const isChrome = (win: Window): boolean =>
14
- testUserAgent(win, /Chrome/i);
15
-
16
- const isFirefox = (win: Window): boolean =>
17
- testUserAgent(win, /Firefox/i);
18
-
19
- const isEdge = (win: Window): boolean =>
20
- testUserAgent(win, /Edge/i);
21
-
22
- const isSafari = (win: Window): boolean =>
23
- testUserAgent(win, /Safari/i);
24
-
25
- const isOpera = (win: Window): boolean =>
26
- testUserAgent(win, /Opera/i) || testUserAgent(win, /OPR/i);
27
-
28
- const isMSIE = (win: Window): boolean =>
29
- testUserAgent(win, /MSIE/i) || testUserAgent(win, /Trident/i);
30
-
31
-
32
- const isMobileWeb = (win: Window): boolean =>
33
- isMobile(win) && !isHybrid(win);
34
-
35
- const isIpad = (win: Window) => {
36
- // iOS 12 and below
37
- if (testUserAgent(win, /iPad/i)) {
38
- return true;
39
- }
40
-
41
- // iOS 13+
42
- if (testUserAgent(win, /Macintosh/i) && isMobile(win)) {
43
- return true;
44
- }
45
-
46
- return false;
47
- };
48
-
49
- const isIphone = (win: Window) =>
50
- testUserAgent(win, /iPhone/i);
51
-
52
- const isIOS = (win: Window) =>
53
- testUserAgent(win, /iPhone|iPod/i) || isIpad(win);
54
-
55
- const isAndroid = (win: Window) =>
56
- testUserAgent(win, /android|sink/i);
57
-
58
- const isAndroidTablet = (win: Window) => {
59
- return isAndroid(win) && !testUserAgent(win, /mobile/i);
60
- };
61
-
62
- const isPhablet = (win: Window) => {
63
- const width = win.innerWidth;
64
- const height = win.innerHeight;
65
- const smallest = Math.min(width, height);
66
- const largest = Math.max(width, height);
67
-
68
- return (smallest > 390 && smallest < 520) &&
69
- (largest > 620 && largest < 800);
70
- };
71
-
72
- const isTablet = (win: Window) => {
73
- const width = win.innerWidth;
74
- const height = win.innerHeight;
75
- const smallest = Math.min(width, height);
76
- const largest = Math.max(width, height);
77
-
78
- return (
79
- isIpad(win) ||
80
- isAndroidTablet(win) ||
81
- (
82
- (smallest > 460 && smallest < 820) &&
83
- (largest > 780 && largest < 1400)
84
- )
85
- );
86
- };
87
-
88
- const isMobile = (win: Window) =>
89
- matchMedia(win, '(any-pointer:coarse)');
90
-
91
- const isTouch = (win: Window) => matchMedia(win, '(any-pointer:coarse)');
92
-
93
- const isDesktop = (win: Window) =>
94
- !isMobile(win);
95
-
96
- const isHybrid = (win: Window) =>
97
- isCordova(win) || isCapacitorNative(win);
98
-
99
- const isCordova = (win: any): boolean =>
100
- !!(win['cordova'] || win['phonegap'] || win['PhoneGap']);
101
-
102
- const isCapacitorNative = (win: any): boolean => {
103
- const capacitor = win['Capacitor'];
104
- return !!(capacitor && capacitor.isNative);
105
- };
106
-
107
- const isElectron = (win: Window): boolean =>
108
- testUserAgent(win, /electron/i);
109
-
110
- const isPWA = (win: Window): boolean =>
111
- !!(win.matchMedia('(display-mode: standalone)').matches || (win.navigator as any).standalone);
112
-
113
- export const testUserAgent = (win: Window, expr: RegExp) =>
114
- expr.test(win.navigator.userAgent);
115
-
116
- const matchMedia = (win: Window, query: string): boolean =>
117
- win.matchMedia(query).matches;
118
-
119
- const isSMScreen = (win: Window) => matchMedia(win, '(max-width: 640px)');
120
- const isMDScreen = (win: Window) => matchMedia(win, '(max-width: 768px)');
121
- const isLGScreen = (win: Window) => matchMedia(win, '(max-width: 1024px)');
122
- const isXLScreen = (win: Window) => matchMedia(win, '(max-width: 1280px)');
123
- const is2XLScreen = (win: Window) => matchMedia(win, '(max-width: 1536px)');
124
-
125
- const PLATFORMS_MAP = {
126
- 'Android': isAndroid,
127
- 'iOS': isIOS,
128
- 'Desktop': isDesktop,
129
- 'Mobile': isMobile,
130
- 'Touch': isTouch,
131
- 'Chrome': isChrome,
132
- 'Firefox': isFirefox,
133
- 'Safari': isSafari,
134
- 'Edge': isEdge,
135
- 'Opera': isOpera,
136
- 'Hybrid': isHybrid,
137
- 'PWA': isPWA,
138
- 'Electron': isElectron,
139
- SM: isSMScreen,
140
- MD: isMDScreen,
141
- LG: isLGScreen,
142
- XL: isXLScreen,
143
- "2XL": is2XLScreen,
144
- };
145
-
146
-
147
- export class AXPlatformEvent {
148
- nativeEvent: UIEvent | Event;
149
- source: AXPlatform
150
- }
151
-
152
- @Injectable({
153
- providedIn: 'root',
154
- })
155
- export class AXPlatform {
156
- resize: Subject<AXPlatformEvent> = new Subject<AXPlatformEvent>();
157
- click: Subject<AXPlatformEvent> = new Subject<AXPlatformEvent>()
158
- scroll: Subject<AXPlatformEvent> = new Subject<AXPlatformEvent>()
159
-
160
- isRtl(): boolean {
161
- return document.dir == 'rtl' || document.body.dir == 'rtl' || document.body.style.direction == 'rtl';
162
- }
163
-
164
-
165
- isLandscape(): boolean {
166
- return window.innerHeight < window.innerWidth;
167
- }
168
-
169
- isPortrate(): boolean {
170
- return !this.isLandscape()
171
- }
172
-
173
- is(name: AXPlatforms | AXBrowsers | AXTechnologies | AXScreenSizes): boolean {
174
- return PLATFORMS_MAP[name](window) || false;
175
- }
176
-
177
- switchDarkMode() {
178
- const _html = document.getElementsByTagName("html")[0];
179
- _html.classList.add('ax-dark')
180
-
181
- }
182
-
183
- switchLightMode() {
184
- const _html = document.getElementsByTagName("html")[0];
185
- _html.classList.remove('ax-dark')
186
- }
187
-
188
- private _setFullHeightRatio() {
189
- document.querySelector<HTMLElement>(':root').style.setProperty('--ax-vh', window.innerHeight / 100 + 'px');
190
- }
191
-
192
- constructor() {
193
-
194
- fromEvent<UIEvent>(window, 'resize')
195
- .pipe(debounceTime(100))
196
- .pipe(distinctUntilChanged())
197
- .subscribe((e) => {
198
- this.resize.next({
199
- nativeEvent: e,
200
- source: this
201
- });
202
- //
203
- this._setFullHeightRatio();
204
- });
205
-
206
-
207
- document.addEventListener('click', (e) => {
208
- this.click.next({
209
- nativeEvent: e,
210
- source: this
211
- });
212
- }, true)
213
-
214
- document.addEventListener('scroll', (e) => {
215
- this.scroll.next({
216
- nativeEvent: e,
217
- source: this
218
- });
219
- }, true);
220
- // init functions
221
- this._setFullHeightRatio();
222
- }
223
- }
@@ -1,36 +0,0 @@
1
- import { Subject, Observable } from 'rxjs';
2
- import { getPropByPath, setPropByPath } from '../utils/object/object-util';
3
-
4
- // @dynamic
5
- export class AXConfig {
6
- private static dataModel: any = {};
7
- private static dataChangeSubject = new Subject<any>();
8
-
9
-
10
- static get onChange(): Observable<any> {
11
- return AXConfig.dataChangeSubject.asObservable();
12
- }
13
-
14
- static set(config: any): any;
15
- static set(path: string, value?: any): void;
16
- static set(arg1?: any, arg2?: any) {
17
-
18
- if (arg1 && typeof arg1 == 'string') {
19
- setPropByPath(AXConfig.dataModel, arg1, arg2);
20
- AXConfig.dataChangeSubject.next(AXConfig.dataModel);
21
- return;
22
- }
23
- if (arg1 && typeof arg1 == 'object') {
24
- Object.assign(AXConfig.dataModel, arg1);
25
- AXConfig.dataChangeSubject.next(AXConfig.dataModel);
26
- return;
27
- }
28
- if (!arg1 && !arg2) {
29
- return AXConfig.dataChangeSubject.asObservable();
30
- }
31
- }
32
-
33
- static get(path: string): any {
34
- return getPropByPath(AXConfig.dataModel, path);
35
- }
36
- }
@@ -1,31 +0,0 @@
1
- import { Injectable } from '@angular/core';
2
-
3
- @Injectable({ providedIn: 'root' })
4
- export class AXEventService {
5
- private list: any[] = [];
6
-
7
- public broadcast(key: string, options?: any): void {
8
- const d = this.list.find(c => c.key === key);
9
- if (d) {
10
- d.events.forEach(c => {
11
- c(options);
12
- });
13
- }
14
- }
15
-
16
- public on(key: string, callback: (options?: any) => void) {
17
- let d = this.list.find(c => c.key === key);
18
- if (!d) {
19
- d = { key, events: [] };
20
- this.list.push(d);
21
- }
22
- d.events.push(callback);
23
- }
24
-
25
- public destroy(key: string, callback: (options?: any) => void): void {
26
- const d = this.list.find(c => c.key === key);
27
- if (d) {
28
- d.events = [];
29
- }
30
- }
31
- }
@@ -1,8 +0,0 @@
1
- import { Injectable } from '@angular/core';
2
- import { AXNavigatorParam } from '../classes/navigator.class';
3
-
4
- @Injectable()
5
- export abstract class AXNavigator {
6
- abstract navigate(params: AXNavigatorParam);
7
- abstract popup(params: AXNavigatorParam);
8
- }
@@ -1,11 +0,0 @@
1
- import { Injectable } from '@angular/core';
2
-
3
- @Injectable()
4
- export class AXStorageService {
5
- get(key: string): any {
6
- return localStorage.getItem(key) as any;
7
- }
8
- set(key: string, value: any): void {
9
- localStorage.setItem(key, value as string);
10
- }
11
- }
@@ -1,19 +0,0 @@
1
- import { NgModule } from '@angular/core';
2
- import { AXTranslatorPipe } from './translator.pipe';
3
- import * as en from '../locale/en.json';
4
- import * as fa from '../locale/fa.json';
5
- import { AXTranslator } from './translator';
6
-
7
-
8
- @NgModule({
9
- imports: [],
10
- exports: [AXTranslatorPipe],
11
- declarations: [AXTranslatorPipe],
12
- providers: [],
13
- })
14
- export class AXTranslatorModule {
15
- constructor() {
16
- AXTranslator.load('en', en);
17
- AXTranslator.load('fa', fa);
18
- }
19
- }
@@ -1,22 +0,0 @@
1
- import { Pipe, PipeTransform } from '@angular/core';
2
- import { AXTranslator } from './translator';
3
-
4
- @Pipe({ name: 'trans', pure: true })
5
- export class AXTranslatorPipe implements PipeTransform {
6
-
7
- constructor() { }
8
-
9
- // transform(value: string, lang?: string): Promise<string> {
10
- // return new Promise<string>((resolve, reject) => {
11
- // if (!value) {
12
- // resolve(value);
13
- // }
14
- // resolve(this.translate.get(value, lang));
15
- // });
16
-
17
- // }
18
-
19
- transform(value: string, lang?: string): string {
20
- return AXTranslator.get(value, lang);
21
- }
22
- }
@@ -1,19 +0,0 @@
1
- import { Injectable } from '@angular/core';
2
- import { AXTranslator } from './translator';
3
-
4
- @Injectable({ providedIn: 'platform' })
5
- export class AXTranslatorService {
6
-
7
- public load(lang: string, value: any) {
8
- AXTranslator.load(lang, value);
9
- }
10
-
11
- public use(lang: string) {
12
- AXTranslator.use(lang);
13
- }
14
-
15
- public get(key: string, lang?: string): string {
16
- return AXTranslator.get(lang, lang);
17
- }
18
- }
19
-
@@ -1,31 +0,0 @@
1
- import { Subject, Observable } from 'rxjs';
2
- import { getPropByPath} from '../utils/object/object-util';
3
- import merge from 'lodash-es/merge';
4
-
5
- // @dynamic
6
- export class AXTranslator {
7
- private static lang: string = 'en';
8
- private static dataChangeSubject = new Subject<any>();
9
-
10
-
11
- static get onChange(): Observable<any> {
12
- return AXTranslator.dataChangeSubject.asObservable();
13
- }
14
-
15
- public static load(lang: string, value: any) {
16
- if (typeof value === 'object') {
17
- if (!AXTranslator[`__data__${lang}`]) {
18
- AXTranslator[`__data__${lang}`] = {};
19
- }
20
- AXTranslator[`__data__${lang}`] = merge(AXTranslator[`__data__${lang}`], value);
21
- }
22
- }
23
-
24
- public static use(lang: string) {
25
- AXTranslator.lang = lang;
26
- }
27
-
28
- public static get(key: string, lang?: string): string {
29
- return getPropByPath(AXTranslator[`__data__${lang || AXTranslator.lang}`], key) || key;
30
- }
31
- }