@acorex/core 6.5.28 → 6.5.30
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/README.md +3 -3
- package/acorex-core.d.ts +5 -0
- package/esm2020/acorex-core.mjs +5 -0
- package/esm2020/lib/classes/base-page.class.mjs +28 -0
- package/esm2020/lib/classes/color.class.mjs +49 -0
- package/esm2020/lib/classes/datetime.class.mjs +314 -0
- package/esm2020/lib/classes/menu.class.mjs +27 -0
- package/esm2020/lib/classes/navigator.class.mjs +2 -0
- package/esm2020/lib/classes/popup.class.mjs +2 -0
- package/esm2020/lib/classes/promise.class.mjs +19 -0
- package/esm2020/lib/classes/sectionlist.class.mjs +2 -0
- package/esm2020/lib/classes/select.class.mjs +3 -0
- package/esm2020/lib/core.module.mjs +27 -0
- package/esm2020/lib/error/error.class.mjs +2 -0
- package/esm2020/lib/error/error.module.mjs +19 -0
- package/esm2020/lib/error/error.service.mjs +21 -0
- package/esm2020/lib/events/keyboard.mjs +2 -0
- package/esm2020/lib/http/http-error.class.mjs +2 -0
- package/esm2020/lib/http/http-events.interceptor.mjs +3 -0
- package/esm2020/lib/http/http-request.class.mjs +2 -0
- package/esm2020/lib/http/http-result.class.mjs +21 -0
- package/esm2020/lib/http/http.module.mjs +37 -0
- package/esm2020/lib/http/http.service.mjs +145 -0
- package/{src → esm2020}/lib/locale/en.json +255 -255
- package/{src → esm2020}/lib/locale/fa.json +245 -245
- package/esm2020/lib/pipe/datetime.pipe.mjs +25 -0
- package/esm2020/lib/pipe/htmlToText.pipe.mjs +25 -0
- package/esm2020/lib/platform/index.mjs +2 -0
- package/esm2020/lib/platform/platform.service.mjs +150 -0
- package/esm2020/lib/services/config.mjs +29 -0
- package/esm2020/lib/services/event.service.mjs +36 -0
- package/esm2020/lib/services/navigator.service.mjs +10 -0
- package/esm2020/lib/services/storage.service.mjs +16 -0
- package/esm2020/lib/translator/translator.mjs +26 -0
- package/esm2020/lib/translator/translator.module.mjs +25 -0
- package/esm2020/lib/translator/translator.pipe.mjs +24 -0
- package/esm2020/lib/translator/translator.service.mjs +21 -0
- package/esm2020/lib/utils/array/array-util.mjs +133 -0
- package/esm2020/lib/utils/html/html-util.mjs +192 -0
- package/esm2020/lib/utils/html/html.module.mjs +19 -0
- package/esm2020/lib/utils/math/math-util.mjs +6 -0
- package/esm2020/lib/utils/object/object-util.mjs +83 -0
- package/esm2020/lib/utils/render/on-demand-preload-strategy.service.mjs +20 -0
- package/esm2020/lib/utils/render/render.service.mjs +103 -0
- package/esm2020/lib/utils/render/rendering.module.mjs +35 -0
- package/esm2020/lib/utils/scroll/scroll.directive.mjs +54 -0
- package/esm2020/lib/utils/scroll/scroll.module.mjs +19 -0
- package/esm2020/lib/utils/separator/separator.module.mjs +19 -0
- package/esm2020/lib/utils/separator/separator.pipe.mjs +33 -0
- package/esm2020/public-api.mjs +44 -0
- package/fesm2015/acorex-core.mjs +2274 -0
- package/fesm2015/acorex-core.mjs.map +1 -0
- package/fesm2020/acorex-core.mjs +2270 -0
- package/fesm2020/acorex-core.mjs.map +1 -0
- package/lib/classes/base-page.class.d.ts +13 -0
- package/lib/classes/color.class.d.ts +17 -0
- package/lib/classes/datetime.class.d.ts +63 -0
- package/lib/classes/menu.class.d.ts +34 -0
- package/{src/lib/classes/navigator.class.ts → lib/classes/navigator.class.d.ts} +5 -5
- package/{src/lib/classes/popup.class.ts → lib/classes/popup.class.d.ts} +12 -14
- package/lib/classes/promise.class.d.ts +7 -0
- package/{src/lib/classes/sectionlist.class.ts → lib/classes/sectionlist.class.d.ts} +8 -8
- package/lib/classes/select.class.d.ts +7 -0
- package/lib/core.module.d.ts +9 -0
- package/{src/lib/error/error.class.ts → lib/error/error.class.d.ts} +4 -4
- package/lib/error/error.module.d.ts +7 -0
- package/lib/error/error.service.d.ts +13 -0
- package/{src/lib/events/keyboard.ts → lib/events/keyboard.d.ts} +2 -5
- package/{src/lib/http/http-error.class.ts → lib/http/http-error.class.d.ts} +7 -7
- package/{src/lib/http/http-events.interceptor.ts → lib/http/http-events.interceptor.d.ts} +10 -14
- package/{src/lib/http/http-request.class.ts → lib/http/http-request.class.d.ts} +14 -14
- package/lib/http/http-result.class.d.ts +11 -0
- package/lib/http/http.module.d.ts +10 -0
- package/lib/http/http.service.d.ts +23 -0
- package/lib/pipe/datetime.pipe.d.ts +8 -0
- package/lib/pipe/htmlToText.pipe.d.ts +7 -0
- package/lib/platform/index.d.ts +1 -0
- package/lib/platform/platform.service.d.ts +26 -0
- package/lib/services/config.d.ts +9 -0
- package/lib/services/event.service.d.ts +9 -0
- package/lib/services/navigator.service.d.ts +8 -0
- package/lib/services/storage.service.d.ts +7 -0
- package/lib/translator/translator.d.ts +9 -0
- package/lib/translator/translator.module.d.ts +8 -0
- package/lib/translator/translator.pipe.d.ts +8 -0
- package/lib/translator/translator.service.d.ts +8 -0
- package/lib/utils/array/array-util.d.ts +6 -0
- package/lib/utils/html/html-util.d.ts +62 -0
- package/lib/utils/html/html.module.d.ts +8 -0
- package/lib/utils/math/math-util.d.ts +3 -0
- package/lib/utils/object/object-util.d.ts +7 -0
- package/lib/utils/render/on-demand-preload-strategy.service.d.ts +10 -0
- package/lib/utils/render/render.service.d.ts +18 -0
- package/lib/utils/render/rendering.module.d.ts +8 -0
- package/lib/utils/scroll/scroll.directive.d.ts +18 -0
- package/lib/utils/scroll/scroll.module.d.ts +8 -0
- package/lib/utils/separator/separator.module.d.ts +8 -0
- package/lib/utils/separator/separator.pipe.d.ts +8 -0
- package/package.json +33 -13
- package/{src/public-api.ts → public-api.d.ts} +43 -53
- package/karma.conf.js +0 -32
- package/ng-package.json +0 -10
- package/src/lib/classes/base-page.class.ts +0 -29
- package/src/lib/classes/color.class.ts +0 -61
- package/src/lib/classes/datetime.class.ts +0 -373
- package/src/lib/classes/menu.class.ts +0 -37
- package/src/lib/classes/promise.class.ts +0 -25
- package/src/lib/classes/select.class.ts +0 -7
- package/src/lib/core.module.ts +0 -21
- package/src/lib/error/error.module.ts +0 -13
- package/src/lib/error/error.service.ts +0 -23
- package/src/lib/error/index.ts +0 -3
- package/src/lib/http/http-result.class.ts +0 -34
- package/src/lib/http/http.module.ts +0 -25
- package/src/lib/http/http.service.ts +0 -159
- package/src/lib/pipe/datetime.pipe.ts +0 -20
- package/src/lib/pipe/htmlToText.pipe.ts +0 -18
- package/src/lib/platform/index.ts +0 -1
- package/src/lib/platform/platform.service.ts +0 -223
- package/src/lib/services/config.ts +0 -36
- package/src/lib/services/event.service.ts +0 -31
- package/src/lib/services/navigator.service.ts +0 -8
- package/src/lib/services/storage.service.ts +0 -11
- package/src/lib/translator/translator.module.ts +0 -19
- package/src/lib/translator/translator.pipe.ts +0 -22
- package/src/lib/translator/translator.service.ts +0 -19
- package/src/lib/translator/translator.ts +0 -31
- package/src/lib/utils/array/array-util.ts +0 -140
- package/src/lib/utils/html/html-util.ts +0 -264
- package/src/lib/utils/html/html.module.ts +0 -11
- package/src/lib/utils/math/math-util.ts +0 -5
- package/src/lib/utils/object/object-util.ts +0 -87
- package/src/lib/utils/render/on-demand-preload-strategy.service.ts +0 -25
- package/src/lib/utils/render/render.service.ts +0 -110
- package/src/lib/utils/render/rendering.module.ts +0 -25
- package/src/lib/utils/scroll/scroll.directive.ts +0 -35
- package/src/lib/utils/scroll/scroll.module.ts +0 -11
- package/src/lib/utils/separator/separator.module.ts +0 -11
- package/src/lib/utils/separator/separator.pipe.ts +0 -27
- package/src/test.ts +0 -28
- package/tsconfig.lib.json +0 -25
- package/tsconfig.lib.prod.json +0 -6
- package/tsconfig.spec.json +0 -18
- package/tslint.json +0 -17
|
@@ -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 = / /gi;
|
|
9
|
-
const regexAmp = /&/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,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
|
-
}
|