ng-wsl-library 0.18.0 → 0.19.0
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/esm2020/lib/directives/wsl-image.directive.mjs +3 -3
- package/esm2020/lib/pipes/wsl-lang-path/wsl-lang-path.pipe.mjs +28 -48
- package/fesm2015/ng-wsl-library.mjs +70 -83
- package/fesm2015/ng-wsl-library.mjs.map +1 -1
- package/fesm2020/ng-wsl-library.mjs +29 -49
- package/fesm2020/ng-wsl-library.mjs.map +1 -1
- package/lib/pipes/wsl-lang-path/wsl-lang-path.pipe.d.ts +3 -9
- package/package.json +1 -1
|
@@ -20,8 +20,8 @@ export class WslImageDirective {
|
|
|
20
20
|
this.el.nativeElement.removeEventListener('error', this.errorListener);
|
|
21
21
|
}
|
|
22
22
|
}
|
|
23
|
-
setupImageWithFallback() {
|
|
24
|
-
const primaryUrl = this.langPathPipe.transform(this.src, this.lang, this.domain);
|
|
23
|
+
async setupImageWithFallback() {
|
|
24
|
+
const primaryUrl = await this.langPathPipe.transform(this.src, this.lang, this.domain);
|
|
25
25
|
this.renderer.setAttribute(this.el.nativeElement, 'src', primaryUrl);
|
|
26
26
|
this.errorListener = () => {
|
|
27
27
|
if (!this.hasAttemptedFallback) {
|
|
@@ -67,4 +67,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
67
67
|
}], hideOnError: [{
|
|
68
68
|
type: Input
|
|
69
69
|
}] } });
|
|
70
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
70
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid3NsLWltYWdlLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXdzbC1saWJyYXJ5L3NyYy9saWIvZGlyZWN0aXZlcy93c2wtaW1hZ2UuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxTQUFTLEVBRVQsS0FBSyxHQUlOLE1BQU0sZUFBZSxDQUFDOzs7QUFPdkIsTUFBTSxPQUFPLGlCQUFpQjtJQVc1QixZQUNVLEVBQWdDLEVBQ2hDLFFBQW1CLEVBQ25CLFlBQTZCO1FBRjdCLE9BQUUsR0FBRixFQUFFLENBQThCO1FBQ2hDLGFBQVEsR0FBUixRQUFRLENBQVc7UUFDbkIsaUJBQVksR0FBWixZQUFZLENBQWlCO1FBUjlCLGdCQUFXLEdBQVksSUFBSSxDQUFDLENBQUMsOENBQThDO1FBRzVFLHlCQUFvQixHQUFHLEtBQUssQ0FBQztJQU1sQyxDQUFDO0lBRUosUUFBUTtRQUNOLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFO1lBQ2IsT0FBTztTQUNSO1FBRUQsSUFBSSxDQUFDLHNCQUFzQixFQUFFLENBQUM7SUFDaEMsQ0FBQztJQUVELFdBQVc7UUFDVCxJQUFJLElBQUksQ0FBQyxhQUFhLEVBQUU7WUFDdEIsSUFBSSxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUMsbUJBQW1CLENBQUMsT0FBTyxFQUFFLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQztTQUN4RTtJQUNILENBQUM7SUFFTyxLQUFLLENBQUMsc0JBQXNCO1FBQ2xDLE1BQU0sVUFBVSxHQUFHLE1BQU0sSUFBSSxDQUFDLFlBQVksQ0FBQyxTQUFTLENBQ2xELElBQUksQ0FBQyxHQUFHLEVBQ1IsSUFBSSxDQUFDLElBQUksRUFDVCxJQUFJLENBQUMsTUFBTSxDQUNaLENBQUM7UUFFRixJQUFJLENBQUMsUUFBUSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsRUFBRSxLQUFLLEVBQUUsVUFBVSxDQUFDLENBQUM7UUFFckUsSUFBSSxDQUFDLGFBQWEsR0FBRyxHQUFHLEVBQUU7WUFDeEIsSUFBSSxDQUFDLElBQUksQ0FBQyxvQkFBb0IsRUFBRTtnQkFDOUIsSUFBSSxDQUFDLG9CQUFvQixHQUFHLElBQUksQ0FBQztnQkFFakMsTUFBTSxXQUFXLEdBQ2YsSUFBSSxDQUFDLGNBQWMsS0FBSyxTQUFTO29CQUMvQixDQUFDLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFLElBQUksQ0FBQyxjQUFjLENBQUM7b0JBQzlDLENBQUMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO2dCQUUzQyxJQUFJLENBQUMsUUFBUSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsRUFBRSxLQUFLLEVBQUUsV0FBVyxDQUFDLENBQUM7YUFDdkU7aUJBQU0sSUFBSSxJQUFJLENBQUMsV0FBVyxFQUFFO2dCQUMzQixJQUFJLENBQUMsUUFBUSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsRUFBRSxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7Z0JBQzdELElBQUksQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxFQUFFLFNBQVMsRUFBRSxNQUFNLENBQUMsQ0FBQzthQUNsRTtRQUNILENBQUMsQ0FBQztRQUVGLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLGdCQUFnQixDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUM7SUFDdEUsQ0FBQztJQUVPLFFBQVEsQ0FBQyxJQUFZLEVBQUUsTUFBc0I7UUFDbkQsSUFBSSxDQUFDLE1BQU0sRUFBRTtZQUNYLE9BQU8sSUFBSSxDQUFDO1NBQ2I7UUFDRCxNQUFNLFdBQVcsR0FBRyxNQUFNLENBQUMsT0FBTyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUM5QyxNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUMxQyxPQUFPLEdBQUcsV0FBVyxJQUFJLFNBQVMsRUFBRSxDQUFDO0lBQ3ZDLENBQUM7OzhHQWxFVSxpQkFBaUI7a0dBQWpCLGlCQUFpQjsyRkFBakIsaUJBQWlCO2tCQUg3QixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxlQUFlO2lCQUMxQjt1SkFFVSxHQUFHO3NCQUFYLEtBQUs7Z0JBQ0csSUFBSTtzQkFBWixLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSztnQkFDRyxjQUFjO3NCQUF0QixLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csV0FBVztzQkFBbkIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIERpcmVjdGl2ZSxcbiAgRWxlbWVudFJlZixcbiAgSW5wdXQsXG4gIE9uSW5pdCxcbiAgUmVuZGVyZXIyLFxuICBPbkRlc3Ryb3ksXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgV3NsTGFuZ1BhdGhQaXBlIH0gZnJvbSAnLi4vcGlwZXMvd3NsLWxhbmctcGF0aC93c2wtbGFuZy1wYXRoLnBpcGUnO1xuaW1wb3J0IHsgV3NsTGFuZ1BhdGhPcHRpb25zIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy93c2wtbGFuZy1wYXRoLW9wdGlvbnMuaW50ZXJmYWNlJztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnaW1nW3dzbEltYWdlXScsXG59KVxuZXhwb3J0IGNsYXNzIFdzbEltYWdlRGlyZWN0aXZlIGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xuICBASW5wdXQoKSBzcmMhOiBzdHJpbmc7XG4gIEBJbnB1dCgpIGxhbmc/OiBzdHJpbmc7XG4gIEBJbnB1dCgpIGRvbWFpbj86IHN0cmluZyB8IG51bGw7XG4gIEBJbnB1dCgpIGZhbGxiYWNrRG9tYWluPzogc3RyaW5nIHwgbnVsbDtcbiAgQElucHV0KCkgd3NsT3B0aW9ucz86IFdzbExhbmdQYXRoT3B0aW9ucztcbiAgQElucHV0KCkgaGlkZU9uRXJyb3I6IGJvb2xlYW4gPSB0cnVlOyAvLyBIaWRlIGltYWdlIGFmdGVyIGFsbCBmYWxsYmFjayBhdHRlbXB0cyBmYWlsXG5cbiAgcHJpdmF0ZSBlcnJvckxpc3RlbmVyPzogKCkgPT4gdm9pZDtcbiAgcHJpdmF0ZSBoYXNBdHRlbXB0ZWRGYWxsYmFjayA9IGZhbHNlO1xuXG4gIGNvbnN0cnVjdG9yKFxuICAgIHByaXZhdGUgZWw6IEVsZW1lbnRSZWY8SFRNTEltYWdlRWxlbWVudD4sXG4gICAgcHJpdmF0ZSByZW5kZXJlcjogUmVuZGVyZXIyLFxuICAgIHByaXZhdGUgbGFuZ1BhdGhQaXBlOiBXc2xMYW5nUGF0aFBpcGVcbiAgKSB7fVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIGlmICghdGhpcy5zcmMpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICB0aGlzLnNldHVwSW1hZ2VXaXRoRmFsbGJhY2soKTtcbiAgfVxuXG4gIG5nT25EZXN0cm95KCk6IHZvaWQge1xuICAgIGlmICh0aGlzLmVycm9yTGlzdGVuZXIpIHtcbiAgICAgIHRoaXMuZWwubmF0aXZlRWxlbWVudC5yZW1vdmVFdmVudExpc3RlbmVyKCdlcnJvcicsIHRoaXMuZXJyb3JMaXN0ZW5lcik7XG4gICAgfVxuICB9XG5cbiAgcHJpdmF0ZSBhc3luYyBzZXR1cEltYWdlV2l0aEZhbGxiYWNrKCk6IFByb21pc2U8dm9pZD4ge1xuICAgIGNvbnN0IHByaW1hcnlVcmwgPSBhd2FpdCB0aGlzLmxhbmdQYXRoUGlwZS50cmFuc2Zvcm0oXG4gICAgICB0aGlzLnNyYyxcbiAgICAgIHRoaXMubGFuZyxcbiAgICAgIHRoaXMuZG9tYWluXG4gICAgKTtcblxuICAgIHRoaXMucmVuZGVyZXIuc2V0QXR0cmlidXRlKHRoaXMuZWwubmF0aXZlRWxlbWVudCwgJ3NyYycsIHByaW1hcnlVcmwpO1xuXG4gICAgdGhpcy5lcnJvckxpc3RlbmVyID0gKCkgPT4ge1xuICAgICAgaWYgKCF0aGlzLmhhc0F0dGVtcHRlZEZhbGxiYWNrKSB7XG4gICAgICAgIHRoaXMuaGFzQXR0ZW1wdGVkRmFsbGJhY2sgPSB0cnVlO1xuXG4gICAgICAgIGNvbnN0IGZhbGxiYWNrVXJsID1cbiAgICAgICAgICB0aGlzLmZhbGxiYWNrRG9tYWluICE9PSB1bmRlZmluZWRcbiAgICAgICAgICAgID8gdGhpcy5idWlsZFVybCh0aGlzLnNyYywgdGhpcy5mYWxsYmFja0RvbWFpbilcbiAgICAgICAgICAgIDogdGhpcy5idWlsZFVybCh0aGlzLnNyYywgdGhpcy5kb21haW4pO1xuXG4gICAgICAgIHRoaXMucmVuZGVyZXIuc2V0QXR0cmlidXRlKHRoaXMuZWwubmF0aXZlRWxlbWVudCwgJ3NyYycsIGZhbGxiYWNrVXJsKTtcbiAgICAgIH0gZWxzZSBpZiAodGhpcy5oaWRlT25FcnJvcikge1xuICAgICAgICB0aGlzLnJlbmRlcmVyLnNldEF0dHJpYnV0ZSh0aGlzLmVsLm5hdGl2ZUVsZW1lbnQsICdzcmMnLCAnJyk7XG4gICAgICAgIHRoaXMucmVuZGVyZXIuc2V0U3R5bGUodGhpcy5lbC5uYXRpdmVFbGVtZW50LCAnZGlzcGxheScsICdub25lJyk7XG4gICAgICB9XG4gICAgfTtcblxuICAgIHRoaXMuZWwubmF0aXZlRWxlbWVudC5hZGRFdmVudExpc3RlbmVyKCdlcnJvcicsIHRoaXMuZXJyb3JMaXN0ZW5lcik7XG4gIH1cblxuICBwcml2YXRlIGJ1aWxkVXJsKHBhdGg6IHN0cmluZywgZG9tYWluPzogc3RyaW5nIHwgbnVsbCk6IHN0cmluZyB7XG4gICAgaWYgKCFkb21haW4pIHtcbiAgICAgIHJldHVybiBwYXRoO1xuICAgIH1cbiAgICBjb25zdCBjbGVhbkRvbWFpbiA9IGRvbWFpbi5yZXBsYWNlKC9cXC8kLywgJycpO1xuICAgIGNvbnN0IGNsZWFuUGF0aCA9IHBhdGgucmVwbGFjZSgvXlxcLy8sICcnKTtcbiAgICByZXR1cm4gYCR7Y2xlYW5Eb21haW59LyR7Y2xlYW5QYXRofWA7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -4,12 +4,12 @@ import * as i1 from "../../services/config/wsl-config.service";
|
|
|
4
4
|
export class WslLangPathPipe {
|
|
5
5
|
constructor(configService) {
|
|
6
6
|
this.configService = configService;
|
|
7
|
+
this.cache = new Map();
|
|
7
8
|
}
|
|
8
|
-
transform(url, langOrOptionsParam, domainParam, optionsParam) {
|
|
9
|
-
if (!url)
|
|
9
|
+
async transform(url, langOrOptionsParam, domainParam, optionsParam) {
|
|
10
|
+
if (!url)
|
|
10
11
|
return '';
|
|
11
|
-
|
|
12
|
-
// Smart parameter detection - check if second parameter is options object
|
|
12
|
+
// --- Parameter detection ---
|
|
13
13
|
let language;
|
|
14
14
|
let domain;
|
|
15
15
|
let options;
|
|
@@ -19,27 +19,15 @@ export class WslLangPathPipe {
|
|
|
19
19
|
options = { format: 'path', ...langOrOptionsParam };
|
|
20
20
|
}
|
|
21
21
|
else {
|
|
22
|
-
// Normal parameter order: pipe:'en':domain:options
|
|
23
22
|
language = langOrOptionsParam;
|
|
24
23
|
domain = domainParam;
|
|
25
24
|
options = { format: 'path', ...optionsParam };
|
|
26
25
|
}
|
|
27
26
|
const resolvedLanguage = language || this.configService.language || 'en';
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
}
|
|
33
|
-
else if (domain === null) {
|
|
34
|
-
resolvedDomain = '';
|
|
35
|
-
}
|
|
36
|
-
else {
|
|
37
|
-
resolvedDomain = domain;
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
else {
|
|
41
|
-
resolvedDomain = this.configService.get('domain', '');
|
|
42
|
-
}
|
|
27
|
+
const resolvedDomain = domain !== undefined && domain !== null
|
|
28
|
+
? domain
|
|
29
|
+
: this.configService.get('domain', '');
|
|
30
|
+
// --- Build URLs ---
|
|
43
31
|
const langSuffixUrl = this.addLanguageSuffix(url, resolvedLanguage);
|
|
44
32
|
const primaryUrl = resolvedDomain
|
|
45
33
|
? this.joinUrlParts(resolvedDomain, langSuffixUrl)
|
|
@@ -47,13 +35,15 @@ export class WslLangPathPipe {
|
|
|
47
35
|
const fallbackUrl = resolvedDomain
|
|
48
36
|
? this.joinUrlParts(resolvedDomain, url)
|
|
49
37
|
: url;
|
|
50
|
-
|
|
38
|
+
// --- Validate primary image ---
|
|
39
|
+
const isValid = await this.imageExists(primaryUrl);
|
|
40
|
+
const finalUrl = isValid ? primaryUrl : fallbackUrl;
|
|
41
|
+
return this.formatOutput(finalUrl, options);
|
|
51
42
|
}
|
|
52
43
|
addLanguageSuffix(url, language) {
|
|
53
44
|
const lastDotIndex = url.lastIndexOf('.');
|
|
54
|
-
if (lastDotIndex === -1)
|
|
45
|
+
if (lastDotIndex === -1)
|
|
55
46
|
return `${url}_${language}`;
|
|
56
|
-
}
|
|
57
47
|
const basePath = url.substring(0, lastDotIndex);
|
|
58
48
|
const extension = url.substring(lastDotIndex);
|
|
59
49
|
return `${basePath}_${language}${extension}`;
|
|
@@ -63,37 +53,27 @@ export class WslLangPathPipe {
|
|
|
63
53
|
const cleanPath = path.replace(/^\//, '');
|
|
64
54
|
return `${cleanDomain}/${cleanPath}`;
|
|
65
55
|
}
|
|
66
|
-
formatOutput(
|
|
56
|
+
formatOutput(url, options) {
|
|
67
57
|
switch (options.format) {
|
|
68
58
|
case 'url':
|
|
69
|
-
return `url(${primaryUrl})`;
|
|
70
59
|
case 'url-with-fallback':
|
|
71
|
-
return `url(${
|
|
60
|
+
return `url(${url})`;
|
|
72
61
|
case 'path':
|
|
73
62
|
default:
|
|
74
|
-
return
|
|
63
|
+
return url;
|
|
75
64
|
}
|
|
76
65
|
}
|
|
77
|
-
|
|
78
|
-
if (
|
|
79
|
-
return
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
}
|
|
89
|
-
const langSuffixUrl = this.addLanguageSuffix(url, lang);
|
|
90
|
-
const primaryUrl = resolvedDomain
|
|
91
|
-
? this.joinUrlParts(resolvedDomain, langSuffixUrl)
|
|
92
|
-
: langSuffixUrl;
|
|
93
|
-
const fallbackUrl = resolvedDomain
|
|
94
|
-
? this.joinUrlParts(resolvedDomain, url)
|
|
95
|
-
: url;
|
|
96
|
-
return { primary: primaryUrl, fallback: fallbackUrl };
|
|
66
|
+
async imageExists(src) {
|
|
67
|
+
if (this.cache.has(src))
|
|
68
|
+
return this.cache.get(src);
|
|
69
|
+
const result = await new Promise((resolve) => {
|
|
70
|
+
const img = new Image();
|
|
71
|
+
img.onload = () => resolve(true);
|
|
72
|
+
img.onerror = () => resolve(false);
|
|
73
|
+
img.src = src;
|
|
74
|
+
});
|
|
75
|
+
this.cache.set(src, result);
|
|
76
|
+
return result;
|
|
97
77
|
}
|
|
98
78
|
}
|
|
99
79
|
WslLangPathPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: WslLangPathPipe, deps: [{ token: i1.WslConfigService }], target: i0.ɵɵFactoryTarget.Pipe });
|
|
@@ -110,4 +90,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
110
90
|
name: 'wslLangPath',
|
|
111
91
|
}]
|
|
112
92
|
}], ctorParameters: function () { return [{ type: i1.WslConfigService }]; } });
|
|
113
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wsl-lang-path.pipe.js","sourceRoot":"","sources":["../../../../../../projects/ng-wsl-library/src/lib/pipes/wsl-lang-path/wsl-lang-path.pipe.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Pipe, PipeTransform } from '@angular/core';\nimport { WslConfigService } from '../../services/config/wsl-config.service';\nimport { WslLangPathOptions } from '../../interfaces/wsl-lang-path-options.interface';\n\n@Injectable({\n  providedIn: 'root',\n})\n@Pipe({\n  name: 'wslLangPath',\n})\nexport class WslLangPathPipe implements PipeTransform {\n  constructor(private configService: WslConfigService) {}\n\n  // Method overloads\n  transform(url: string): string;\n  transform(url: string, language: string): string;\n  transform(url: string, language: string, domain: string | null): string;\n  transform(\n    url: string,\n    language: string,\n    domain: string | null,\n    options: WslLangPathOptions\n  ): string;\n  transform(url: string, options: WslLangPathOptions): string;\n  transform(\n    url: string,\n    langOrOptionsParam?: string | WslLangPathOptions,\n    domainParam?: string | null,\n    optionsParam?: WslLangPathOptions\n  ): string {\n    if (!url) {\n      return '';\n    }\n\n    // Smart parameter detection - check if second parameter is options object\n    let language: string | undefined;\n    let domain: string | null | undefined;\n    let options: WslLangPathOptions;\n\n    if (typeof langOrOptionsParam === 'object' && langOrOptionsParam !== null) {\n      language = undefined;\n      domain = undefined;\n      options = { format: 'path', ...langOrOptionsParam };\n    } else {\n      // Normal parameter order: pipe:'en':domain:options\n      language = langOrOptionsParam as string | undefined;\n      domain = domainParam;\n      options = { format: 'path', ...optionsParam };\n    }\n\n    const resolvedLanguage = language || this.configService.language || 'en';\n\n    let resolvedDomain = '';\n    if (domain !== undefined) {\n      if (domain === '') {\n        resolvedDomain = '';\n      } else if (domain === null) {\n        resolvedDomain = '';\n      } else {\n        resolvedDomain = domain;\n      }\n    } else {\n      resolvedDomain = this.configService.get<string>('domain', '');\n    }\n\n    const langSuffixUrl = this.addLanguageSuffix(url, resolvedLanguage);\n    const primaryUrl = resolvedDomain\n      ? this.joinUrlParts(resolvedDomain, langSuffixUrl)\n      : langSuffixUrl;\n\n    const fallbackUrl = resolvedDomain\n      ? this.joinUrlParts(resolvedDomain, url)\n      : url;\n\n    return this.formatOutput(primaryUrl, fallbackUrl, options);\n  }\n\n  private addLanguageSuffix(url: string, language: string): string {\n    const lastDotIndex = url.lastIndexOf('.');\n\n    if (lastDotIndex === -1) {\n      return `${url}_${language}`;\n    }\n\n    const basePath = url.substring(0, lastDotIndex);\n    const extension = url.substring(lastDotIndex);\n\n    return `${basePath}_${language}${extension}`;\n  }\n\n  private joinUrlParts(domain: string, path: string): string {\n    const cleanDomain = domain.replace(/\\/$/, '');\n    const cleanPath = path.replace(/^\\//, '');\n    return `${cleanDomain}/${cleanPath}`;\n  }\n\n  private formatOutput(\n    primaryUrl: string,\n    fallbackUrl: string,\n    options: WslLangPathOptions\n  ): string {\n    switch (options.format) {\n      case 'url':\n        return `url(${primaryUrl})`;\n\n      case 'url-with-fallback':\n        return `url(${primaryUrl}), url(${fallbackUrl})`;\n\n      case 'path':\n      default:\n        return primaryUrl;\n    }\n  }\n\n  getUrls(\n    url: string,\n    language?: string,\n    domain?: string | null\n  ): { primary: string; fallback: string } {\n    if (!url) {\n      return { primary: '', fallback: '' };\n    }\n\n    const lang = language || this.configService.language || 'en';\n\n    let resolvedDomain = '';\n    if (domain !== undefined) {\n      resolvedDomain = domain || '';\n    } else {\n      resolvedDomain = this.configService.get<string>('domain', '');\n    }\n\n    const langSuffixUrl = this.addLanguageSuffix(url, lang);\n    const primaryUrl = resolvedDomain\n      ? this.joinUrlParts(resolvedDomain, langSuffixUrl)\n      : langSuffixUrl;\n\n    const fallbackUrl = resolvedDomain\n      ? this.joinUrlParts(resolvedDomain, url)\n      : url;\n\n    return { primary: primaryUrl, fallback: fallbackUrl };\n  }\n}\n"]}
|
|
93
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"wsl-lang-path.pipe.js","sourceRoot":"","sources":["../../../../../../projects/ng-wsl-library/src/lib/pipes/wsl-lang-path/wsl-lang-path.pipe.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Pipe, PipeTransform } from '@angular/core';\nimport { WslConfigService } from '../../services/config/wsl-config.service';\nimport { WslLangPathOptions } from '../../interfaces/wsl-lang-path-options.interface';\n\n@Injectable({\n  providedIn: 'root',\n})\n@Pipe({\n  name: 'wslLangPath',\n})\nexport class WslLangPathPipe implements PipeTransform {\n  private cache = new Map<string, boolean>();\n\n  constructor(private configService: WslConfigService) {}\n\n  async transform(\n    url: string,\n    langOrOptionsParam?: string | WslLangPathOptions,\n    domainParam?: string | null,\n    optionsParam?: WslLangPathOptions\n  ): Promise<string> {\n    if (!url) return '';\n\n    // --- Parameter detection ---\n    let language: string | undefined;\n    let domain: string | null | undefined;\n    let options: WslLangPathOptions;\n\n    if (typeof langOrOptionsParam === 'object' && langOrOptionsParam !== null) {\n      language = undefined;\n      domain = undefined;\n      options = { format: 'path', ...langOrOptionsParam };\n    } else {\n      language = langOrOptionsParam as string | undefined;\n      domain = domainParam;\n      options = { format: 'path', ...optionsParam };\n    }\n\n    const resolvedLanguage = language || this.configService.language || 'en';\n    const resolvedDomain =\n      domain !== undefined && domain !== null\n        ? domain\n        : this.configService.get<string>('domain', '');\n\n    // --- Build URLs ---\n    const langSuffixUrl = this.addLanguageSuffix(url, resolvedLanguage);\n    const primaryUrl = resolvedDomain\n      ? this.joinUrlParts(resolvedDomain, langSuffixUrl)\n      : langSuffixUrl;\n\n    const fallbackUrl = resolvedDomain\n      ? this.joinUrlParts(resolvedDomain, url)\n      : url;\n\n    // --- Validate primary image ---\n    const isValid = await this.imageExists(primaryUrl);\n    const finalUrl = isValid ? primaryUrl : fallbackUrl;\n\n    return this.formatOutput(finalUrl, options);\n  }\n\n  private addLanguageSuffix(url: string, language: string): string {\n    const lastDotIndex = url.lastIndexOf('.');\n    if (lastDotIndex === -1) return `${url}_${language}`;\n    const basePath = url.substring(0, lastDotIndex);\n    const extension = url.substring(lastDotIndex);\n    return `${basePath}_${language}${extension}`;\n  }\n\n  private joinUrlParts(domain: string, path: string): string {\n    const cleanDomain = domain.replace(/\\/$/, '');\n    const cleanPath = path.replace(/^\\//, '');\n    return `${cleanDomain}/${cleanPath}`;\n  }\n\n  private formatOutput(url: string, options: WslLangPathOptions): string {\n    switch (options.format) {\n      case 'url':\n      case 'url-with-fallback':\n        return `url(${url})`;\n      case 'path':\n      default:\n        return url;\n    }\n  }\n\n  private async imageExists(src: string): Promise<boolean> {\n    if (this.cache.has(src)) return this.cache.get(src)!;\n\n    const result = await new Promise<boolean>((resolve) => {\n      const img = new Image();\n      img.onload = () => resolve(true);\n      img.onerror = () => resolve(false);\n      img.src = src;\n    });\n\n    this.cache.set(src, result);\n    return result;\n  }\n}\n"]}
|
|
@@ -4,6 +4,7 @@ import * as i2 from '@angular/common';
|
|
|
4
4
|
import { CommonModule, DOCUMENT } from '@angular/common';
|
|
5
5
|
import { BehaviorSubject, Subject, fromEvent, noop } from 'rxjs';
|
|
6
6
|
import { map, distinctUntilChanged, debounceTime, throttleTime, startWith } from 'rxjs/operators';
|
|
7
|
+
import { __awaiter } from 'tslib';
|
|
7
8
|
import { cloneDeep } from 'lodash';
|
|
8
9
|
import * as i1 from '@angular/animations';
|
|
9
10
|
import { animate, style } from '@angular/animations';
|
|
@@ -457,56 +458,48 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
457
458
|
class WslLangPathPipe {
|
|
458
459
|
constructor(configService) {
|
|
459
460
|
this.configService = configService;
|
|
461
|
+
this.cache = new Map();
|
|
460
462
|
}
|
|
461
463
|
transform(url, langOrOptionsParam, domainParam, optionsParam) {
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
}
|
|
474
|
-
else {
|
|
475
|
-
// Normal parameter order: pipe:'en':domain:options
|
|
476
|
-
language = langOrOptionsParam;
|
|
477
|
-
domain = domainParam;
|
|
478
|
-
options = Object.assign({ format: 'path' }, optionsParam);
|
|
479
|
-
}
|
|
480
|
-
const resolvedLanguage = language || this.configService.language || 'en';
|
|
481
|
-
let resolvedDomain = '';
|
|
482
|
-
if (domain !== undefined) {
|
|
483
|
-
if (domain === '') {
|
|
484
|
-
resolvedDomain = '';
|
|
485
|
-
}
|
|
486
|
-
else if (domain === null) {
|
|
487
|
-
resolvedDomain = '';
|
|
464
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
465
|
+
if (!url)
|
|
466
|
+
return '';
|
|
467
|
+
// --- Parameter detection ---
|
|
468
|
+
let language;
|
|
469
|
+
let domain;
|
|
470
|
+
let options;
|
|
471
|
+
if (typeof langOrOptionsParam === 'object' && langOrOptionsParam !== null) {
|
|
472
|
+
language = undefined;
|
|
473
|
+
domain = undefined;
|
|
474
|
+
options = Object.assign({ format: 'path' }, langOrOptionsParam);
|
|
488
475
|
}
|
|
489
476
|
else {
|
|
490
|
-
|
|
477
|
+
language = langOrOptionsParam;
|
|
478
|
+
domain = domainParam;
|
|
479
|
+
options = Object.assign({ format: 'path' }, optionsParam);
|
|
491
480
|
}
|
|
492
|
-
|
|
493
|
-
|
|
494
|
-
|
|
495
|
-
|
|
496
|
-
|
|
497
|
-
|
|
498
|
-
|
|
499
|
-
|
|
500
|
-
|
|
501
|
-
|
|
502
|
-
|
|
503
|
-
|
|
481
|
+
const resolvedLanguage = language || this.configService.language || 'en';
|
|
482
|
+
const resolvedDomain = domain !== undefined && domain !== null
|
|
483
|
+
? domain
|
|
484
|
+
: this.configService.get('domain', '');
|
|
485
|
+
// --- Build URLs ---
|
|
486
|
+
const langSuffixUrl = this.addLanguageSuffix(url, resolvedLanguage);
|
|
487
|
+
const primaryUrl = resolvedDomain
|
|
488
|
+
? this.joinUrlParts(resolvedDomain, langSuffixUrl)
|
|
489
|
+
: langSuffixUrl;
|
|
490
|
+
const fallbackUrl = resolvedDomain
|
|
491
|
+
? this.joinUrlParts(resolvedDomain, url)
|
|
492
|
+
: url;
|
|
493
|
+
// --- Validate primary image ---
|
|
494
|
+
const isValid = yield this.imageExists(primaryUrl);
|
|
495
|
+
const finalUrl = isValid ? primaryUrl : fallbackUrl;
|
|
496
|
+
return this.formatOutput(finalUrl, options);
|
|
497
|
+
});
|
|
504
498
|
}
|
|
505
499
|
addLanguageSuffix(url, language) {
|
|
506
500
|
const lastDotIndex = url.lastIndexOf('.');
|
|
507
|
-
if (lastDotIndex === -1)
|
|
501
|
+
if (lastDotIndex === -1)
|
|
508
502
|
return `${url}_${language}`;
|
|
509
|
-
}
|
|
510
503
|
const basePath = url.substring(0, lastDotIndex);
|
|
511
504
|
const extension = url.substring(lastDotIndex);
|
|
512
505
|
return `${basePath}_${language}${extension}`;
|
|
@@ -516,37 +509,29 @@ class WslLangPathPipe {
|
|
|
516
509
|
const cleanPath = path.replace(/^\//, '');
|
|
517
510
|
return `${cleanDomain}/${cleanPath}`;
|
|
518
511
|
}
|
|
519
|
-
formatOutput(
|
|
512
|
+
formatOutput(url, options) {
|
|
520
513
|
switch (options.format) {
|
|
521
514
|
case 'url':
|
|
522
|
-
return `url(${primaryUrl})`;
|
|
523
515
|
case 'url-with-fallback':
|
|
524
|
-
return `url(${
|
|
516
|
+
return `url(${url})`;
|
|
525
517
|
case 'path':
|
|
526
518
|
default:
|
|
527
|
-
return
|
|
528
|
-
}
|
|
529
|
-
}
|
|
530
|
-
|
|
531
|
-
|
|
532
|
-
|
|
533
|
-
|
|
534
|
-
|
|
535
|
-
|
|
536
|
-
|
|
537
|
-
|
|
538
|
-
|
|
539
|
-
|
|
540
|
-
|
|
541
|
-
|
|
542
|
-
|
|
543
|
-
const primaryUrl = resolvedDomain
|
|
544
|
-
? this.joinUrlParts(resolvedDomain, langSuffixUrl)
|
|
545
|
-
: langSuffixUrl;
|
|
546
|
-
const fallbackUrl = resolvedDomain
|
|
547
|
-
? this.joinUrlParts(resolvedDomain, url)
|
|
548
|
-
: url;
|
|
549
|
-
return { primary: primaryUrl, fallback: fallbackUrl };
|
|
519
|
+
return url;
|
|
520
|
+
}
|
|
521
|
+
}
|
|
522
|
+
imageExists(src) {
|
|
523
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
524
|
+
if (this.cache.has(src))
|
|
525
|
+
return this.cache.get(src);
|
|
526
|
+
const result = yield new Promise((resolve) => {
|
|
527
|
+
const img = new Image();
|
|
528
|
+
img.onload = () => resolve(true);
|
|
529
|
+
img.onerror = () => resolve(false);
|
|
530
|
+
img.src = src;
|
|
531
|
+
});
|
|
532
|
+
this.cache.set(src, result);
|
|
533
|
+
return result;
|
|
534
|
+
});
|
|
550
535
|
}
|
|
551
536
|
}
|
|
552
537
|
WslLangPathPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: WslLangPathPipe, deps: [{ token: WslConfigService }], target: i0.ɵɵFactoryTarget.Pipe });
|
|
@@ -1151,22 +1136,24 @@ class WslImageDirective {
|
|
|
1151
1136
|
}
|
|
1152
1137
|
}
|
|
1153
1138
|
setupImageWithFallback() {
|
|
1154
|
-
|
|
1155
|
-
|
|
1156
|
-
|
|
1157
|
-
|
|
1158
|
-
this.hasAttemptedFallback
|
|
1159
|
-
|
|
1160
|
-
|
|
1161
|
-
|
|
1162
|
-
|
|
1163
|
-
|
|
1164
|
-
|
|
1165
|
-
|
|
1166
|
-
|
|
1167
|
-
|
|
1168
|
-
|
|
1169
|
-
|
|
1139
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
1140
|
+
const primaryUrl = yield this.langPathPipe.transform(this.src, this.lang, this.domain);
|
|
1141
|
+
this.renderer.setAttribute(this.el.nativeElement, 'src', primaryUrl);
|
|
1142
|
+
this.errorListener = () => {
|
|
1143
|
+
if (!this.hasAttemptedFallback) {
|
|
1144
|
+
this.hasAttemptedFallback = true;
|
|
1145
|
+
const fallbackUrl = this.fallbackDomain !== undefined
|
|
1146
|
+
? this.buildUrl(this.src, this.fallbackDomain)
|
|
1147
|
+
: this.buildUrl(this.src, this.domain);
|
|
1148
|
+
this.renderer.setAttribute(this.el.nativeElement, 'src', fallbackUrl);
|
|
1149
|
+
}
|
|
1150
|
+
else if (this.hideOnError) {
|
|
1151
|
+
this.renderer.setAttribute(this.el.nativeElement, 'src', '');
|
|
1152
|
+
this.renderer.setStyle(this.el.nativeElement, 'display', 'none');
|
|
1153
|
+
}
|
|
1154
|
+
};
|
|
1155
|
+
this.el.nativeElement.addEventListener('error', this.errorListener);
|
|
1156
|
+
});
|
|
1170
1157
|
}
|
|
1171
1158
|
buildUrl(path, domain) {
|
|
1172
1159
|
if (!domain) {
|