@tilde-nlp/ngx-common 6.1.33 → 6.1.35
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/esm2022/lib/core/localization/index.mjs +2 -1
- package/esm2022/lib/core/localization/select-language-dialog-component/index.mjs +2 -0
- package/esm2022/lib/core/localization/select-language-dialog-component/select-language-dialog.component.mjs +110 -0
- package/esm2022/lib/pipes/language-translate/language-translate.pipe.mjs +9 -2
- package/esm2022/lib/subscription/subscription.component.mjs +37 -8
- package/fesm2022/tilde-nlp-ngx-common.mjs +141 -10
- package/fesm2022/tilde-nlp-ngx-common.mjs.map +1 -1
- package/lib/core/localization/index.d.ts +1 -0
- package/lib/core/localization/select-language-dialog-component/index.d.ts +1 -0
- package/lib/core/localization/select-language-dialog-component/select-language-dialog.component.d.ts +15 -0
- package/lib/pipes/language-translate/language-translate.pipe.d.ts +1 -0
- package/lib/subscription/subscription.component.d.ts +5 -1
- package/package.json +1 -1
- package/web-components/main.js +1 -1
|
@@ -1,2 +1,3 @@
|
|
|
1
1
|
export * from './missing-translation-handler.service';
|
|
2
|
-
|
|
2
|
+
export * from './select-language-dialog-component';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tbW9uL3NyYy9saWIvY29yZS9sb2NhbGl6YXRpb24vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLG9DQUFvQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9taXNzaW5nLXRyYW5zbGF0aW9uLWhhbmRsZXIuc2VydmljZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vc2VsZWN0LWxhbmd1YWdlLWRpYWxvZy1jb21wb25lbnQnO1xyXG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './select-language-dialog.component';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tbW9uL3NyYy9saWIvY29yZS9sb2NhbGl6YXRpb24vc2VsZWN0LWxhbmd1YWdlLWRpYWxvZy1jb21wb25lbnQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxvQ0FBb0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vc2VsZWN0LWxhbmd1YWdlLWRpYWxvZy5jb21wb25lbnQnO1xyXG4iXX0=
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
import { AsyncPipe } from '@angular/common';
|
|
2
|
+
import { Component, inject } from '@angular/core';
|
|
3
|
+
import { MAT_DIALOG_DATA, MatDialogModule } from '@angular/material/dialog';
|
|
4
|
+
import { SortLanguageListPipe } from '../../../pipes';
|
|
5
|
+
import { TranslatePipe, TranslateService } from '@ngx-translate/core';
|
|
6
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
7
|
+
import { MatSelectModule } from '@angular/material/select';
|
|
8
|
+
import { DialogRef } from '@angular/cdk/dialog';
|
|
9
|
+
import { FormsModule } from '@angular/forms';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "@angular/material/dialog";
|
|
12
|
+
import * as i2 from "@angular/material/button";
|
|
13
|
+
import * as i3 from "@angular/material/form-field";
|
|
14
|
+
import * as i4 from "@angular/material/select";
|
|
15
|
+
import * as i5 from "@angular/material/core";
|
|
16
|
+
import * as i6 from "@angular/forms";
|
|
17
|
+
function SelectLanguageDialogComponent_For_13_Template(rf, ctx) { if (rf & 1) {
|
|
18
|
+
i0.ɵɵelementStart(0, "mat-option", 5)(1, "span", 9);
|
|
19
|
+
i0.ɵɵtext(2);
|
|
20
|
+
i0.ɵɵelementEnd()();
|
|
21
|
+
} if (rf & 2) {
|
|
22
|
+
const language_r1 = ctx.$implicit;
|
|
23
|
+
i0.ɵɵproperty("value", language_r1.value);
|
|
24
|
+
i0.ɵɵadvance(2);
|
|
25
|
+
i0.ɵɵtextInterpolate1(" ", language_r1.translation, " ");
|
|
26
|
+
} }
|
|
27
|
+
/**
|
|
28
|
+
This is an extension dialog component.
|
|
29
|
+
Use <lib-open-extension-dialog> to open this dialog, by proivding [extensions] to it you can specify what extensions should be displayed.
|
|
30
|
+
*/
|
|
31
|
+
export class SelectLanguageDialogComponent {
|
|
32
|
+
constructor() {
|
|
33
|
+
this.#data = inject(MAT_DIALOG_DATA);
|
|
34
|
+
this.#translate = inject(TranslateService);
|
|
35
|
+
this.#dialogRef = inject(DialogRef);
|
|
36
|
+
this.selectedLanguage = this.#translate.currentLang;
|
|
37
|
+
}
|
|
38
|
+
#data;
|
|
39
|
+
#translate;
|
|
40
|
+
#dialogRef;
|
|
41
|
+
ngOnInit() {
|
|
42
|
+
this.languages = this.#data.languages;
|
|
43
|
+
}
|
|
44
|
+
save() {
|
|
45
|
+
this.#translate.use(this.selectedLanguage);
|
|
46
|
+
this.#dialogRef.close();
|
|
47
|
+
}
|
|
48
|
+
static { this.ɵfac = function SelectLanguageDialogComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || SelectLanguageDialogComponent)(); }; }
|
|
49
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: SelectLanguageDialogComponent, selectors: [["lib-extension-dialog"]], standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 23, vars: 20, consts: [["mat-dialog-title", ""], ["mat-dialog-content", ""], [1, "description"], ["appearance", "outline", 1, "w-full", "mb-9"], [3, "ngModelChange", "ngModel"], [3, "value"], ["align", "end"], ["mat-stroked-button", "", "color", "primary-accent-darker", "mat-dialog-close", ""], ["mat-flat-button", "", "color", "primary-accent-darker", 3, "click"], [1, "language-name"]], template: function SelectLanguageDialogComponent_Template(rf, ctx) { if (rf & 1) {
|
|
50
|
+
i0.ɵɵelementStart(0, "h1", 0);
|
|
51
|
+
i0.ɵɵtext(1);
|
|
52
|
+
i0.ɵɵpipe(2, "translate");
|
|
53
|
+
i0.ɵɵelementEnd();
|
|
54
|
+
i0.ɵɵelementStart(3, "div", 1)(4, "p", 2);
|
|
55
|
+
i0.ɵɵtext(5);
|
|
56
|
+
i0.ɵɵpipe(6, "translate");
|
|
57
|
+
i0.ɵɵelementEnd();
|
|
58
|
+
i0.ɵɵelementStart(7, "mat-form-field", 3)(8, "mat-label");
|
|
59
|
+
i0.ɵɵtext(9);
|
|
60
|
+
i0.ɵɵpipe(10, "translate");
|
|
61
|
+
i0.ɵɵelementEnd();
|
|
62
|
+
i0.ɵɵelementStart(11, "mat-select", 4);
|
|
63
|
+
i0.ɵɵtwoWayListener("ngModelChange", function SelectLanguageDialogComponent_Template_mat_select_ngModelChange_11_listener($event) { i0.ɵɵtwoWayBindingSet(ctx.selectedLanguage, $event) || (ctx.selectedLanguage = $event); return $event; });
|
|
64
|
+
i0.ɵɵrepeaterCreate(12, SelectLanguageDialogComponent_For_13_Template, 3, 2, "mat-option", 5, i0.ɵɵrepeaterTrackByIndex);
|
|
65
|
+
i0.ɵɵpipe(14, "sortLanguageList");
|
|
66
|
+
i0.ɵɵpipe(15, "async");
|
|
67
|
+
i0.ɵɵelementEnd()()();
|
|
68
|
+
i0.ɵɵelementStart(16, "mat-dialog-actions", 6)(17, "button", 7);
|
|
69
|
+
i0.ɵɵtext(18);
|
|
70
|
+
i0.ɵɵpipe(19, "translate");
|
|
71
|
+
i0.ɵɵelementEnd();
|
|
72
|
+
i0.ɵɵelementStart(20, "button", 8);
|
|
73
|
+
i0.ɵɵlistener("click", function SelectLanguageDialogComponent_Template_button_click_20_listener() { return ctx.save(); });
|
|
74
|
+
i0.ɵɵtext(21);
|
|
75
|
+
i0.ɵɵpipe(22, "translate");
|
|
76
|
+
i0.ɵɵelementEnd()();
|
|
77
|
+
} if (rf & 2) {
|
|
78
|
+
i0.ɵɵadvance();
|
|
79
|
+
i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(2, 6, "SELECT_LANGUAGE.TITLE"));
|
|
80
|
+
i0.ɵɵadvance(4);
|
|
81
|
+
i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(6, 8, "SELECT_LANGUAGE.DESCRIPTION"));
|
|
82
|
+
i0.ɵɵadvance(4);
|
|
83
|
+
i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(10, 10, "SELECT_LANGUAGE.INPUT_LABEL"));
|
|
84
|
+
i0.ɵɵadvance(2);
|
|
85
|
+
i0.ɵɵtwoWayProperty("ngModel", ctx.selectedLanguage);
|
|
86
|
+
i0.ɵɵadvance();
|
|
87
|
+
i0.ɵɵrepeater(i0.ɵɵpipeBind1(15, 14, i0.ɵɵpipeBind1(14, 12, ctx.languages)));
|
|
88
|
+
i0.ɵɵadvance(6);
|
|
89
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(19, 16, "SELECT_LANGUAGE.CANCEL"), " ");
|
|
90
|
+
i0.ɵɵadvance(3);
|
|
91
|
+
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(22, 18, "SELECT_LANGUAGE.SAVE"), " ");
|
|
92
|
+
} }, dependencies: [SortLanguageListPipe,
|
|
93
|
+
AsyncPipe,
|
|
94
|
+
TranslatePipe,
|
|
95
|
+
MatDialogModule, i1.MatDialogClose, i1.MatDialogTitle, i1.MatDialogActions, i1.MatDialogContent, MatButtonModule, i2.MatButton, MatSelectModule, i3.MatFormField, i3.MatLabel, i4.MatSelect, i5.MatOption, FormsModule, i6.NgControlStatus, i6.NgModel] }); }
|
|
96
|
+
}
|
|
97
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SelectLanguageDialogComponent, [{
|
|
98
|
+
type: Component,
|
|
99
|
+
args: [{ selector: 'lib-extension-dialog', standalone: true, imports: [
|
|
100
|
+
SortLanguageListPipe,
|
|
101
|
+
AsyncPipe,
|
|
102
|
+
TranslatePipe,
|
|
103
|
+
MatDialogModule,
|
|
104
|
+
MatButtonModule,
|
|
105
|
+
MatSelectModule,
|
|
106
|
+
FormsModule
|
|
107
|
+
], template: "<h1 mat-dialog-title>{{ \"SELECT_LANGUAGE.TITLE\" | translate }}</h1>\r\n<div mat-dialog-content>\r\n <p class=\"description\">{{ \"SELECT_LANGUAGE.DESCRIPTION\" | translate }}</p>\r\n\r\n <mat-form-field appearance=\"outline\" class=\"w-full mb-9\">\r\n <mat-label>{{ \"SELECT_LANGUAGE.INPUT_LABEL\" | translate }}</mat-label>\r\n <mat-select [(ngModel)]=\"selectedLanguage\">\r\n @for (language of languages | sortLanguageList | async; track $index) {\r\n <mat-option [value]=\"language.value\">\r\n <span class=\"language-name\">\r\n {{language.translation}}\r\n </span>\r\n </mat-option>\r\n }\r\n </mat-select>\r\n </mat-form-field>\r\n</div>\r\n\r\n<mat-dialog-actions align=\"end\">\r\n <button mat-stroked-button color=\"primary-accent-darker\" mat-dialog-close>\r\n {{ \"SELECT_LANGUAGE.CANCEL\" | translate }}\r\n </button>\r\n <button mat-flat-button color=\"primary-accent-darker\" (click)=\"save()\">\r\n {{ \"SELECT_LANGUAGE.SAVE\" | translate }}\r\n </button>\r\n</mat-dialog-actions>\r\n\r\n\r\n\r\n" }]
|
|
108
|
+
}], null, null); })();
|
|
109
|
+
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(SelectLanguageDialogComponent, { className: "SelectLanguageDialogComponent", filePath: "lib\\core\\localization\\select-language-dialog-component\\select-language-dialog.component.ts", lineNumber: 29 }); })();
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0LWxhbmd1YWdlLWRpYWxvZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tbW9uL3NyYy9saWIvY29yZS9sb2NhbGl6YXRpb24vc2VsZWN0LWxhbmd1YWdlLWRpYWxvZy1jb21wb25lbnQvc2VsZWN0LWxhbmd1YWdlLWRpYWxvZy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tbW9uL3NyYy9saWIvY29yZS9sb2NhbGl6YXRpb24vc2VsZWN0LWxhbmd1YWdlLWRpYWxvZy1jb21wb25lbnQvc2VsZWN0LWxhbmd1YWdlLWRpYWxvZy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDNUMsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFDMUQsT0FBTyxFQUFFLGVBQWUsRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUM1RSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUN0RCxPQUFPLEVBQUUsYUFBYSxFQUFFLGdCQUFnQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDdEUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDaEQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDOzs7Ozs7Ozs7SUNDckMsQUFERixxQ0FBcUMsY0FDUDtJQUMxQixZQUNGO0lBQ0YsQUFERSxpQkFBTyxFQUNJOzs7SUFKRCx5Q0FBd0I7SUFFaEMsZUFDRjtJQURFLHdEQUNGOztBREZSOzs7RUFHRTtBQWdCRixNQUFNLE9BQU8sNkJBQTZCO0lBZjFDO1FBZ0JXLFVBQUssR0FBRyxNQUFNLENBQUMsZUFBZSxDQUFDLENBQUM7UUFDaEMsZUFBVSxHQUFHLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1FBQ3RDLGVBQVUsR0FBRyxNQUFNLENBQUMsU0FBUyxDQUFDLENBQUM7UUFHeEMscUJBQWdCLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxXQUFXLENBQUM7S0FhaEQ7SUFsQlUsS0FBSyxDQUEyQjtJQUNoQyxVQUFVLENBQTRCO0lBQ3RDLFVBQVUsQ0FBcUI7SUFLeEMsUUFBUTtRQUNOLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxTQUFTLENBQUM7SUFDeEMsQ0FBQztJQUVELElBQUk7UUFDRixJQUFJLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztRQUMzQyxJQUFJLENBQUMsVUFBVSxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQzFCLENBQUM7OEhBZlUsNkJBQTZCO29FQUE3Qiw2QkFBNkI7WUM1QjFDLDZCQUFxQjtZQUFBLFlBQXlDOztZQUFBLGlCQUFLO1lBRWpFLEFBREYsOEJBQXdCLFdBQ0M7WUFBQSxZQUErQzs7WUFBQSxpQkFBSTtZQUd4RSxBQURGLHlDQUF5RCxnQkFDNUM7WUFBQSxZQUErQzs7WUFBQSxpQkFBWTtZQUN0RSxzQ0FBMkM7WUFBL0IsNk9BQThCO1lBQ3hDLHdIQU1DOzs7WUFHUCxBQURFLEFBREUsaUJBQWEsRUFDRSxFQUNiO1lBR0osQUFERiw4Q0FBZ0MsaUJBQzRDO1lBQ3hFLGFBQ0Y7O1lBQUEsaUJBQVM7WUFDVCxrQ0FBdUU7WUFBakIsMkdBQVMsVUFBTSxJQUFDO1lBQ3BFLGFBQ0Y7O1lBQ0YsQUFERSxpQkFBUyxFQUNVOztZQXpCQSxjQUF5QztZQUF6QyxtRUFBeUM7WUFFckMsZUFBK0M7WUFBL0MseUVBQStDO1lBR3pELGVBQStDO1lBQS9DLDJFQUErQztZQUM5QyxlQUE4QjtZQUE5QixvREFBOEI7WUFDeEMsY0FNQztZQU5ELDRFQU1DO1lBT0gsZUFDRjtZQURFLGlGQUNGO1lBRUUsZUFDRjtZQURFLCtFQUNGOzRCRExFLG9CQUFvQjtZQUNwQixTQUFTO1lBQ1QsYUFBYTtZQUNiLGVBQWUsa0ZBQ2YsZUFBZSxnQkFDZixlQUFlLDREQUNmLFdBQVc7O2lGQUdGLDZCQUE2QjtjQWZ6QyxTQUFTOzJCQUNFLHNCQUFzQixjQUdwQixJQUFJLFdBQ1A7b0JBQ1Asb0JBQW9CO29CQUNwQixTQUFTO29CQUNULGFBQWE7b0JBQ2IsZUFBZTtvQkFDZixlQUFlO29CQUNmLGVBQWU7b0JBQ2YsV0FBVztpQkFDWjs7a0ZBRVUsNkJBQTZCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQXN5bmNQaXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgQ29tcG9uZW50LCBpbmplY3QsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBNQVRfRElBTE9HX0RBVEEsIE1hdERpYWxvZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XHJcbmltcG9ydCB7IFNvcnRMYW5ndWFnZUxpc3RQaXBlIH0gZnJvbSAnLi4vLi4vLi4vcGlwZXMnO1xyXG5pbXBvcnQgeyBUcmFuc2xhdGVQaXBlLCBUcmFuc2xhdGVTZXJ2aWNlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XHJcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XHJcbmltcG9ydCB7IE1hdFNlbGVjdE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3NlbGVjdCc7XHJcbmltcG9ydCB7IERpYWxvZ1JlZiB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9kaWFsb2cnO1xyXG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuLyoqXHJcbiAgVGhpcyBpcyBhbiBleHRlbnNpb24gZGlhbG9nIGNvbXBvbmVudC5cclxuICBVc2UgPGxpYi1vcGVuLWV4dGVuc2lvbi1kaWFsb2c+IHRvIG9wZW4gdGhpcyBkaWFsb2csIGJ5IHByb2l2ZGluZyBbZXh0ZW5zaW9uc10gdG8gaXQgeW91IGNhbiBzcGVjaWZ5IHdoYXQgZXh0ZW5zaW9ucyBzaG91bGQgYmUgZGlzcGxheWVkLlxyXG4qL1xyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2xpYi1leHRlbnNpb24tZGlhbG9nJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vc2VsZWN0LWxhbmd1YWdlLWRpYWxvZy5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vc2VsZWN0LWxhbmd1YWdlLWRpYWxvZy5jb21wb25lbnQuc2NzcyddLFxyXG4gIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgaW1wb3J0czogW1xyXG4gICAgU29ydExhbmd1YWdlTGlzdFBpcGUsXHJcbiAgICBBc3luY1BpcGUsXHJcbiAgICBUcmFuc2xhdGVQaXBlLFxyXG4gICAgTWF0RGlhbG9nTW9kdWxlLFxyXG4gICAgTWF0QnV0dG9uTW9kdWxlLFxyXG4gICAgTWF0U2VsZWN0TW9kdWxlLFxyXG4gICAgRm9ybXNNb2R1bGVcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTZWxlY3RMYW5ndWFnZURpYWxvZ0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgcmVhZG9ubHkgI2RhdGEgPSBpbmplY3QoTUFUX0RJQUxPR19EQVRBKTtcclxuICByZWFkb25seSAjdHJhbnNsYXRlID0gaW5qZWN0KFRyYW5zbGF0ZVNlcnZpY2UpO1xyXG4gIHJlYWRvbmx5ICNkaWFsb2dSZWYgPSBpbmplY3QoRGlhbG9nUmVmKTtcclxuXHJcbiAgbGFuZ3VhZ2VzITogc3RyaW5nW107XHJcbiAgc2VsZWN0ZWRMYW5ndWFnZSA9IHRoaXMuI3RyYW5zbGF0ZS5jdXJyZW50TGFuZztcclxuXHJcbiAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICB0aGlzLmxhbmd1YWdlcyA9IHRoaXMuI2RhdGEubGFuZ3VhZ2VzO1xyXG4gIH1cclxuXHJcbiAgc2F2ZSgpe1xyXG4gICAgdGhpcy4jdHJhbnNsYXRlLnVzZSh0aGlzLnNlbGVjdGVkTGFuZ3VhZ2UpO1xyXG4gICAgdGhpcy4jZGlhbG9nUmVmLmNsb3NlKCk7XHJcbiAgfVxyXG5cclxuXHJcblxyXG59XHJcbiIsIjxoMSBtYXQtZGlhbG9nLXRpdGxlPnt7IFwiU0VMRUNUX0xBTkdVQUdFLlRJVExFXCIgfCB0cmFuc2xhdGUgfX08L2gxPlxyXG48ZGl2IG1hdC1kaWFsb2ctY29udGVudD5cclxuICA8cCBjbGFzcz1cImRlc2NyaXB0aW9uXCI+e3sgXCJTRUxFQ1RfTEFOR1VBR0UuREVTQ1JJUFRJT05cIiB8IHRyYW5zbGF0ZSB9fTwvcD5cclxuXHJcbiAgPG1hdC1mb3JtLWZpZWxkIGFwcGVhcmFuY2U9XCJvdXRsaW5lXCIgY2xhc3M9XCJ3LWZ1bGwgbWItOVwiPlxyXG4gICAgPG1hdC1sYWJlbD57eyBcIlNFTEVDVF9MQU5HVUFHRS5JTlBVVF9MQUJFTFwiIHwgdHJhbnNsYXRlIH19PC9tYXQtbGFiZWw+XHJcbiAgICA8bWF0LXNlbGVjdCBbKG5nTW9kZWwpXT1cInNlbGVjdGVkTGFuZ3VhZ2VcIj5cclxuICAgICAgQGZvciAobGFuZ3VhZ2Ugb2YgbGFuZ3VhZ2VzIHwgc29ydExhbmd1YWdlTGlzdCB8IGFzeW5jOyB0cmFjayAkaW5kZXgpIHtcclxuICAgICAgPG1hdC1vcHRpb24gW3ZhbHVlXT1cImxhbmd1YWdlLnZhbHVlXCI+XHJcbiAgICAgICAgPHNwYW4gY2xhc3M9XCJsYW5ndWFnZS1uYW1lXCI+XHJcbiAgICAgICAgICB7e2xhbmd1YWdlLnRyYW5zbGF0aW9ufX1cclxuICAgICAgICA8L3NwYW4+XHJcbiAgICAgIDwvbWF0LW9wdGlvbj5cclxuICAgICAgfVxyXG4gICAgPC9tYXQtc2VsZWN0PlxyXG4gIDwvbWF0LWZvcm0tZmllbGQ+XHJcbjwvZGl2PlxyXG5cclxuPG1hdC1kaWFsb2ctYWN0aW9ucyBhbGlnbj1cImVuZFwiPlxyXG4gIDxidXR0b24gbWF0LXN0cm9rZWQtYnV0dG9uIGNvbG9yPVwicHJpbWFyeS1hY2NlbnQtZGFya2VyXCIgbWF0LWRpYWxvZy1jbG9zZT5cclxuICAgIHt7IFwiU0VMRUNUX0xBTkdVQUdFLkNBTkNFTFwiIHwgdHJhbnNsYXRlIH19XHJcbiAgPC9idXR0b24+XHJcbiAgPGJ1dHRvbiBtYXQtZmxhdC1idXR0b24gY29sb3I9XCJwcmltYXJ5LWFjY2VudC1kYXJrZXJcIiAoY2xpY2spPVwic2F2ZSgpXCI+XHJcbiAgICB7eyBcIlNFTEVDVF9MQU5HVUFHRS5TQVZFXCIgfCB0cmFuc2xhdGUgfX1cclxuICA8L2J1dHRvbj5cclxuPC9tYXQtZGlhbG9nLWFjdGlvbnM+XHJcblxyXG5cclxuXHJcbiJdfQ==
|
|
@@ -10,6 +10,13 @@ export class LanguageTranslatePipe {
|
|
|
10
10
|
this.translate = translate;
|
|
11
11
|
this.languagesLocalizationKey = 'LANGUAGES';
|
|
12
12
|
this.translationCache = new Map();
|
|
13
|
+
// For languages where region is different code (but in reality the same), we should not show region.
|
|
14
|
+
this.localeSameRegions = {
|
|
15
|
+
"nb": ["no"],
|
|
16
|
+
"sl": ["si"],
|
|
17
|
+
"sv": ["se"],
|
|
18
|
+
"uk": ["ua"]
|
|
19
|
+
};
|
|
13
20
|
this.translate.onLangChange.subscribe(() => {
|
|
14
21
|
this.translationCache.clear();
|
|
15
22
|
this.lastUiLanguage = this.translate.currentLang;
|
|
@@ -72,7 +79,7 @@ export class LanguageTranslatePipe {
|
|
|
72
79
|
}
|
|
73
80
|
isLanguageCodeSameAsRegion(fullLangCode) {
|
|
74
81
|
const [code, region, extra] = fullLangCode.split('-');
|
|
75
|
-
return code === region?.toLowerCase() && !extra;
|
|
82
|
+
return (code === region?.toLowerCase() || this.localeSameRegions[code]?.includes(region.toLowerCase())) && !extra;
|
|
76
83
|
}
|
|
77
84
|
getRegionFromLanguageCode(fullLangCode) {
|
|
78
85
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
@@ -97,4 +104,4 @@ export class LanguageTranslatePipe {
|
|
|
97
104
|
standalone: true
|
|
98
105
|
}]
|
|
99
106
|
}], () => [{ type: i1.TranslateService }], null); })();
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"language-translate.pipe.js","sourceRoot":"","sources":["../../../../../../projects/ngx-common/src/lib/pipes/language-translate/language-translate.pipe.ts"],"names":[],"mappings":"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","sourcesContent":["import { Pipe, PipeTransform } from '@angular/core';\r\nimport { TranslateService } from '@ngx-translate/core';\r\n\r\n@Pipe({\r\n  name: 'languageTranslate',\r\n  pure: false,\r\n  standalone: true\r\n})\r\n/**\r\n  This pipe searches for a language code translation within our JSON files.\r\n  If the translation for a given language code is not found there, it retrieves it from the browser's Intl object.\r\n*/\r\nexport class LanguageTranslatePipe implements PipeTransform {\r\n  private readonly languagesLocalizationKey = 'LANGUAGES';\r\n\r\n  private lastUiLanguage: string;\r\n\r\n  private readonly translationCache = new Map<string, string>();\r\n\r\n  constructor(private readonly translate: TranslateService) {\r\n    this.translate.onLangChange.subscribe(() => {\r\n      this.translationCache.clear();\r\n      this.lastUiLanguage = this.translate.currentLang;\r\n    });\r\n    this.lastUiLanguage = this.translate.currentLang;\r\n  }\r\n\r\n  transform(fullLangCode: string, hideRegion = false): string {\r\n    if (!fullLangCode) {\r\n      return '';\r\n    }\r\n\r\n    if (this.lastUiLanguage !== this.translate.currentLang) {\r\n      this.translationCache.clear();\r\n      this.lastUiLanguage = this.translate.currentLang;\r\n    }\r\n\r\n    const cacheKey = `${fullLangCode}:${hideRegion}`;\r\n\r\n    if (this.translationCache.has(cacheKey)) {\r\n      return this.translationCache.get(cacheKey)!;\r\n    }\r\n\r\n    const langCodeWithoutRegion = this.getLanguageFromLanguageCode(fullLangCode);\r\n    const isCodeAndRegionSame = this.isLanguageCodeSameAsRegion(fullLangCode);\r\n    const langCodeForTranslation = isCodeAndRegionSame ? langCodeWithoutRegion : fullLangCode;\r\n\r\n    const translation = this.getTranslation(langCodeForTranslation, hideRegion);\r\n\r\n    this.translationCache.set(cacheKey, translation);\r\n\r\n    return translation;\r\n  }\r\n\r\n  private getTranslation(langCode: string, hideRegion?: boolean): string {\r\n    const languageTranslations = this.translate.instant(this.languagesLocalizationKey);\r\n    let translation =\r\n      /**\r\n          e.g. In case we need to display \"en-GB\" language code as \"British\" we can do this\r\n        by adding \"EN_GB\": \"British\" in localization files under \"LANGUAGES\" key.\r\n      */\r\n      languageTranslations[langCode.toUpperCase().replace('-', '_')] ??\r\n      this.getLanguageTranslationFromLanguageCode(this.translate.currentLang, langCode);\r\n\r\n    if (hideRegion) {\r\n      translation = translation.split('(')[0].trim();\r\n    }\r\n\r\n    return translation;\r\n  }\r\n\r\n  private getLanguageTranslationFromLanguageCode(currentLang: string, code: string): string {\r\n    const languageNamesInCurrentLang = new Intl.DisplayNames([currentLang], { type: 'language' });\r\n    const regionNamesInCurrentLang = new Intl.DisplayNames([currentLang], { type: 'region' });\r\n\r\n    let translation: string;\r\n\r\n    try {\r\n      const language = this.getLanguageFromLanguageCode(code);\r\n      const region = this.getRegionFromLanguageCode(code);\r\n\r\n      const languagetranslation = languageNamesInCurrentLang.of(language);\r\n      const regionTranslation = regionNamesInCurrentLang.of(region);\r\n\r\n      translation = `${languagetranslation} (${regionTranslation})`;\r\n    } catch {\r\n      try {\r\n        translation = languageNamesInCurrentLang.of(code) as string;\r\n      } catch {\r\n        return code;\r\n      }\r\n    }\r\n\r\n    return this.capitalizeFirstLetter(translation);\r\n  }\r\n\r\n  private isLanguageCodeSameAsRegion(fullLangCode: string): boolean {\r\n    const [code, region, extra] = fullLangCode.split('-');\r\n    return code === region?.toLowerCase() && !extra;\r\n  }\r\n\r\n  private getRegionFromLanguageCode(fullLangCode: string): string {\r\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\r\n    const [_code, region, extra] = fullLangCode.split('-');\r\n    const regionCode = extra ? `${region}-${extra}` : `${region}`;\r\n    return regionCode.toUpperCase();\r\n  }\r\n\r\n  private getLanguageFromLanguageCode(fullLangCode: string): string {\r\n    return fullLangCode.split('-')[0].toLowerCase();\r\n  }\r\n\r\n  private capitalizeFirstLetter(text: string): string {\r\n    return text.charAt(0).toUpperCase() + text.slice(1);\r\n  }\r\n}\r\n"]}
|
|
107
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"language-translate.pipe.js","sourceRoot":"","sources":["../../../../../../projects/ngx-common/src/lib/pipes/language-translate/language-translate.pipe.ts"],"names":[],"mappings":"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","sourcesContent":["import { Pipe, PipeTransform } from '@angular/core';\r\nimport { TranslateService } from '@ngx-translate/core';\r\n\r\n@Pipe({\r\n  name: 'languageTranslate',\r\n  pure: false,\r\n  standalone: true\r\n})\r\n/**\r\n  This pipe searches for a language code translation within our JSON files.\r\n  If the translation for a given language code is not found there, it retrieves it from the browser's Intl object.\r\n*/\r\nexport class LanguageTranslatePipe implements PipeTransform {\r\n  private readonly languagesLocalizationKey = 'LANGUAGES';\r\n\r\n  private lastUiLanguage: string;\r\n\r\n  private readonly translationCache = new Map<string, string>();\r\n\r\n  // For languages where region is different code (but in reality the same), we should not show region.\r\n  private readonly localeSameRegions: Record<string, string[]> = {\r\n    \"nb\": [\"no\"],\r\n    \"sl\": [\"si\"],\r\n    \"sv\": [\"se\"],\r\n    \"uk\": [\"ua\"]\r\n  };\r\n\r\n  constructor(private readonly translate: TranslateService) {\r\n    this.translate.onLangChange.subscribe(() => {\r\n      this.translationCache.clear();\r\n      this.lastUiLanguage = this.translate.currentLang;\r\n    });\r\n    this.lastUiLanguage = this.translate.currentLang;\r\n  }\r\n\r\n  transform(fullLangCode: string, hideRegion = false): string {\r\n    if (!fullLangCode) {\r\n      return '';\r\n    }\r\n\r\n    if (this.lastUiLanguage !== this.translate.currentLang) {\r\n      this.translationCache.clear();\r\n      this.lastUiLanguage = this.translate.currentLang;\r\n    }\r\n\r\n    const cacheKey = `${fullLangCode}:${hideRegion}`;\r\n\r\n    if (this.translationCache.has(cacheKey)) {\r\n      return this.translationCache.get(cacheKey)!;\r\n    }\r\n\r\n    const langCodeWithoutRegion = this.getLanguageFromLanguageCode(fullLangCode);\r\n    const isCodeAndRegionSame = this.isLanguageCodeSameAsRegion(fullLangCode);\r\n    const langCodeForTranslation = isCodeAndRegionSame ? langCodeWithoutRegion : fullLangCode;\r\n\r\n    const translation = this.getTranslation(langCodeForTranslation, hideRegion);\r\n\r\n    this.translationCache.set(cacheKey, translation);\r\n\r\n    return translation;\r\n  }\r\n\r\n  private getTranslation(langCode: string, hideRegion?: boolean): string {\r\n    const languageTranslations = this.translate.instant(this.languagesLocalizationKey);\r\n    let translation =\r\n      /**\r\n          e.g. In case we need to display \"en-GB\" language code as \"British\" we can do this\r\n        by adding \"EN_GB\": \"British\" in localization files under \"LANGUAGES\" key.\r\n      */\r\n      languageTranslations[langCode.toUpperCase().replace('-', '_')] ??\r\n      this.getLanguageTranslationFromLanguageCode(this.translate.currentLang, langCode);\r\n\r\n    if (hideRegion) {\r\n      translation = translation.split('(')[0].trim();\r\n    }\r\n\r\n    return translation;\r\n  }\r\n\r\n  private getLanguageTranslationFromLanguageCode(currentLang: string, code: string): string {\r\n    const languageNamesInCurrentLang = new Intl.DisplayNames([currentLang], { type: 'language' });\r\n    const regionNamesInCurrentLang = new Intl.DisplayNames([currentLang], { type: 'region' });\r\n\r\n    let translation: string;\r\n\r\n    try {\r\n      const language = this.getLanguageFromLanguageCode(code);\r\n      const region = this.getRegionFromLanguageCode(code);\r\n\r\n      const languagetranslation = languageNamesInCurrentLang.of(language);\r\n      const regionTranslation = regionNamesInCurrentLang.of(region);\r\n\r\n      translation = `${languagetranslation} (${regionTranslation})`;\r\n    } catch {\r\n      try {\r\n        translation = languageNamesInCurrentLang.of(code) as string;\r\n      } catch {\r\n        return code;\r\n      }\r\n    }\r\n\r\n    return this.capitalizeFirstLetter(translation);\r\n  }\r\n\r\n  private isLanguageCodeSameAsRegion(fullLangCode: string): boolean {\r\n    const [code, region, extra] = fullLangCode.split('-');\r\n    return (code === region?.toLowerCase() || this.localeSameRegions[code]?.includes(region.toLowerCase())) && !extra;\r\n  }\r\n\r\n  private getRegionFromLanguageCode(fullLangCode: string): string {\r\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\r\n    const [_code, region, extra] = fullLangCode.split('-');\r\n    const regionCode = extra ? `${region}-${extra}` : `${region}`;\r\n    return regionCode.toUpperCase();\r\n  }\r\n\r\n  private getLanguageFromLanguageCode(fullLangCode: string): string {\r\n    return fullLangCode.split('-')[0].toLowerCase();\r\n  }\r\n\r\n  private capitalizeFirstLetter(text: string): string {\r\n    return text.charAt(0).toUpperCase() + text.slice(1);\r\n  }\r\n}\r\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { CommonModule, DatePipe } from '@angular/common';
|
|
2
|
-
import { Component, computed, inject, input } from '@angular/core';
|
|
2
|
+
import { Component, computed, inject, input, output } from '@angular/core';
|
|
3
3
|
import { MatProgressBarModule } from '@angular/material/progress-bar';
|
|
4
4
|
import { TranslatePipe } from '@ngx-translate/core';
|
|
5
5
|
import { QuotaType } from '@tilde-nlp/ngx-services';
|
|
@@ -106,17 +106,34 @@ function SubscriptionComponent_Conditional_1_Conditional_13_Template(rf, ctx) {
|
|
|
106
106
|
i0.ɵɵadvance(5);
|
|
107
107
|
i0.ɵɵtextInterpolate(i0.ɵɵpipeBind2(9, 4, currentSubscription_r2.EndDate, "dd.MM.yyyy"));
|
|
108
108
|
} }
|
|
109
|
+
function SubscriptionComponent_Conditional_1_Conditional_14_For_7_Conditional_2_Template(rf, ctx) { if (rf & 1) {
|
|
110
|
+
i0.ɵɵelementStart(0, "span");
|
|
111
|
+
i0.ɵɵtext(1);
|
|
112
|
+
i0.ɵɵelementEnd();
|
|
113
|
+
} if (rf & 2) {
|
|
114
|
+
const item_r3 = i0.ɵɵnextContext().$implicit;
|
|
115
|
+
i0.ɵɵadvance();
|
|
116
|
+
i0.ɵɵtextInterpolate1(" (", item_r3.qt, ")");
|
|
117
|
+
} }
|
|
109
118
|
function SubscriptionComponent_Conditional_1_Conditional_14_For_7_Template(rf, ctx) { if (rf & 1) {
|
|
110
119
|
i0.ɵɵelementStart(0, "span");
|
|
111
120
|
i0.ɵɵtext(1);
|
|
112
121
|
i0.ɵɵelementEnd();
|
|
122
|
+
i0.ɵɵtemplate(2, SubscriptionComponent_Conditional_1_Conditional_14_For_7_Conditional_2_Template, 2, 1, "span");
|
|
123
|
+
i0.ɵɵelementStart(3, "span");
|
|
124
|
+
i0.ɵɵtext(4);
|
|
125
|
+
i0.ɵɵelementEnd();
|
|
113
126
|
} if (rf & 2) {
|
|
114
127
|
const item_r3 = ctx.$implicit;
|
|
115
128
|
const ɵ$index_95_r4 = ctx.$index;
|
|
116
129
|
i0.ɵɵnextContext(2);
|
|
117
130
|
const currentSubscription_r2 = i0.ɵɵreadContextLet(0);
|
|
118
131
|
i0.ɵɵadvance();
|
|
119
|
-
i0.ɵɵ
|
|
132
|
+
i0.ɵɵtextInterpolate(item_r3.id);
|
|
133
|
+
i0.ɵɵadvance();
|
|
134
|
+
i0.ɵɵconditional(item_r3.qt > 1 ? 2 : -1);
|
|
135
|
+
i0.ɵɵadvance(2);
|
|
136
|
+
i0.ɵɵtextInterpolate1(" ", currentSubscription_r2.Addons.length - 1 > ɵ$index_95_r4 ? "," : "", " ");
|
|
120
137
|
} }
|
|
121
138
|
function SubscriptionComponent_Conditional_1_Conditional_14_Template(rf, ctx) { if (rf & 1) {
|
|
122
139
|
i0.ɵɵelementStart(0, "div", 8)(1, "div", 5)(2, "span", 6);
|
|
@@ -124,7 +141,7 @@ function SubscriptionComponent_Conditional_1_Conditional_14_Template(rf, ctx) {
|
|
|
124
141
|
i0.ɵɵpipe(4, "translate");
|
|
125
142
|
i0.ɵɵelementEnd()();
|
|
126
143
|
i0.ɵɵelementStart(5, "div", 7);
|
|
127
|
-
i0.ɵɵrepeaterCreate(6, SubscriptionComponent_Conditional_1_Conditional_14_For_7_Template,
|
|
144
|
+
i0.ɵɵrepeaterCreate(6, SubscriptionComponent_Conditional_1_Conditional_14_For_7_Template, 5, 3, null, null, i0.ɵɵrepeaterTrackByIndex);
|
|
128
145
|
i0.ɵɵelementEnd()();
|
|
129
146
|
} if (rf & 2) {
|
|
130
147
|
i0.ɵɵnextContext();
|
|
@@ -193,7 +210,9 @@ function SubscriptionComponent_Conditional_2_Template(rf, ctx) { if (rf & 1) {
|
|
|
193
210
|
i0.ɵɵrepeater(ctx_r4.visibleQuotas());
|
|
194
211
|
} }
|
|
195
212
|
function SubscriptionComponent_Conditional_4_Template(rf, ctx) { if (rf & 1) {
|
|
196
|
-
i0.ɵɵ
|
|
213
|
+
const _r8 = i0.ɵɵgetCurrentView();
|
|
214
|
+
i0.ɵɵelementStart(0, "a", 13);
|
|
215
|
+
i0.ɵɵlistener("click", function SubscriptionComponent_Conditional_4_Template_a_click_0_listener() { i0.ɵɵrestoreView(_r8); const ctx_r4 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r4.manageClicked()); });
|
|
197
216
|
i0.ɵɵtext(1);
|
|
198
217
|
i0.ɵɵpipe(2, "translate");
|
|
199
218
|
i0.ɵɵelementEnd();
|
|
@@ -202,7 +221,9 @@ function SubscriptionComponent_Conditional_4_Template(rf, ctx) { if (rf & 1) {
|
|
|
202
221
|
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(2, 1, "SUBSCRIPTION.MANAGE"), " ");
|
|
203
222
|
} }
|
|
204
223
|
function SubscriptionComponent_Conditional_5_Template(rf, ctx) { if (rf & 1) {
|
|
205
|
-
i0.ɵɵ
|
|
224
|
+
const _r9 = i0.ɵɵgetCurrentView();
|
|
225
|
+
i0.ɵɵelementStart(0, "a", 14);
|
|
226
|
+
i0.ɵɵlistener("click", function SubscriptionComponent_Conditional_5_Template_a_click_0_listener() { i0.ɵɵrestoreView(_r9); const ctx_r4 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r4.contactUsClicked()); });
|
|
206
227
|
i0.ɵɵtext(1);
|
|
207
228
|
i0.ɵɵpipe(2, "translate");
|
|
208
229
|
i0.ɵɵelementEnd();
|
|
@@ -224,6 +245,8 @@ export class SubscriptionComponent {
|
|
|
224
245
|
this.visibleQuotaTypes = input();
|
|
225
246
|
this.contactUsUrl = input();
|
|
226
247
|
this.chargebeeSettings = input();
|
|
248
|
+
this.manageClick = output();
|
|
249
|
+
this.contactUsClick = output();
|
|
227
250
|
this.visibleQuotas = computed(() => {
|
|
228
251
|
const quota = this.quota();
|
|
229
252
|
if (!quota?.usage) {
|
|
@@ -263,6 +286,12 @@ export class SubscriptionComponent {
|
|
|
263
286
|
ngOnInit() {
|
|
264
287
|
this.#mountChargeBeeScript();
|
|
265
288
|
}
|
|
289
|
+
manageClicked() {
|
|
290
|
+
this.manageClick.emit();
|
|
291
|
+
}
|
|
292
|
+
contactUsClicked() {
|
|
293
|
+
this.contactUsClick.emit();
|
|
294
|
+
}
|
|
266
295
|
#mountChargeBeeScript() {
|
|
267
296
|
const chargebeeSettings = this.chargebeeSettings();
|
|
268
297
|
if (!chargebeeSettings?.site || !chargebeeSettings.script) {
|
|
@@ -327,7 +356,7 @@ export class SubscriptionComponent {
|
|
|
327
356
|
return `${parseFloat((bytes / Math.pow(k, i)).toFixed(dm))} ${sizes[i]}`;
|
|
328
357
|
}
|
|
329
358
|
static { this.ɵfac = function SubscriptionComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || SubscriptionComponent)(); }; }
|
|
330
|
-
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: SubscriptionComponent, selectors: [["lib-subscription"]], inputs: { token: [1, "token"], subscription: [1, "subscription"], quota: [1, "quota"], visibleQuotaTypes: [1, "visibleQuotaTypes"], contactUsUrl: [1, "contactUsUrl"], chargebeeSettings: [1, "chargebeeSettings"] }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 6, vars: 5, consts: [[1, "subscription-actions-wrapper"], ["mat-flat-button", "", "color", "primary-accent-darker", "href", "javascript:void(0)", "data-cb-type", "portal", 1, "manage-sub-btn", "button-row-element"], ["mat-stroked-button", "", "target", "_blank", "color", "primary-accent-darker"], [1, "subscription-section-title", "text-l-semi-bold"], [1, "subscription-data-row"], [1, "subscription-label"], [1, "label"], [1, "subscription-data"], ["fxLayout", "row", 1, "subscription-data-row"], [1, "subscription-limit-wrapper"], [3, "value"], [1, "subscription-limit"], [1, "text-l-semi-bold"]], template: function SubscriptionComponent_Template(rf, ctx) { if (rf & 1) {
|
|
359
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: SubscriptionComponent, selectors: [["lib-subscription"]], inputs: { token: [1, "token"], subscription: [1, "subscription"], quota: [1, "quota"], visibleQuotaTypes: [1, "visibleQuotaTypes"], contactUsUrl: [1, "contactUsUrl"], chargebeeSettings: [1, "chargebeeSettings"] }, outputs: { manageClick: "manageClick", contactUsClick: "contactUsClick" }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 6, vars: 5, consts: [[1, "subscription-actions-wrapper"], ["mat-flat-button", "", "color", "primary-accent-darker", "href", "javascript:void(0)", "data-cb-type", "portal", 1, "manage-sub-btn", "button-row-element"], ["mat-stroked-button", "", "target", "_blank", "color", "primary-accent-darker"], [1, "subscription-section-title", "text-l-semi-bold"], [1, "subscription-data-row"], [1, "subscription-label"], [1, "label"], [1, "subscription-data"], ["fxLayout", "row", 1, "subscription-data-row"], [1, "subscription-limit-wrapper"], [3, "value"], [1, "subscription-limit"], [1, "text-l-semi-bold"], ["mat-flat-button", "", "color", "primary-accent-darker", "href", "javascript:void(0)", "data-cb-type", "portal", 1, "manage-sub-btn", "button-row-element", 3, "click"], ["mat-stroked-button", "", "target", "_blank", "color", "primary-accent-darker", 3, "click"]], template: function SubscriptionComponent_Template(rf, ctx) { if (rf & 1) {
|
|
331
360
|
i0.ɵɵtemplate(0, SubscriptionComponent_Conditional_0_Template, 20, 11)(1, SubscriptionComponent_Conditional_1_Template, 15, 8)(2, SubscriptionComponent_Conditional_2_Template, 5, 3);
|
|
332
361
|
i0.ɵɵelementStart(3, "div", 0);
|
|
333
362
|
i0.ɵɵtemplate(4, SubscriptionComponent_Conditional_4_Template, 3, 3, "a", 1)(5, SubscriptionComponent_Conditional_5_Template, 3, 4, "a", 2);
|
|
@@ -354,7 +383,7 @@ export class SubscriptionComponent {
|
|
|
354
383
|
MatProgressBarModule,
|
|
355
384
|
CommonModule,
|
|
356
385
|
MatButtonModule
|
|
357
|
-
], template: "@if(token()){\r\n <!-- narrow type to non null property -->\r\n @let userToken = token()!;\r\n\r\n <h3 class=\"subscription-section-title text-l-semi-bold\">{{ \"SUBSCRIPTION.USER_INFO\" | translate }}</h3>\r\n\r\n <div class=\"subscription-data-row\">\r\n <div class=\"subscription-label\">\r\n <span class=\"label\">{{ \"SUBSCRIPTION.LABEL_NAME\" | translate }}</span>\r\n </div>\r\n\r\n <div class=\"subscription-data\">\r\n <span>{{ userToken.name }}</span>\r\n </div>\r\n </div>\r\n\r\n <div class=\"subscription-data-row\">\r\n <div class=\"subscription-label\">\r\n <span class=\"label\">{{ \"SUBSCRIPTION.LABEL_EMAIL\" | translate }}</span>\r\n </div>\r\n\r\n <div class=\"subscription-data\">\r\n <span>{{ userToken.email }}</span>\r\n </div>\r\n </div>\r\n}\r\n\r\n@if(subscription()){\r\n @let currentSubscription = subscription()!;\r\n\r\n <div fxLayout=\"row\" class=\"subscription-data-row\">\r\n <div class=\"subscription-label\">\r\n <span class=\"label\">{{ \"SUBSCRIPTION.LABEL_SUBSCRIPTION_PLAN_ID\" | translate }}</span>\r\n </div>\r\n\r\n <div class=\"subscription-data\">\r\n <ng-container>\r\n <span>\r\n {{ currentSubscription.Label ? currentSubscription.Label : currentSubscription.PlanId }}\r\n\r\n @switch (subscriptionState()) {\r\n @case(subscriptionStates.TRIAL){\r\n <span> ({{ \"SUBSCRIPTION.TRIAL_END_DATE\" | translate: { date: currentSubscription.EndDate | date: \"dd.MM.yyyy.\" } }}) </span>\r\n }\r\n @case (subscriptionStates.ACTIVE) {\r\n @if(currentSubscription.EndDate){\r\n <span> ({{ \"SUBSCRIPTION.END_DATE\" | translate: { date: currentSubscription.EndDate | date: \"dd.MM.yyyy.\" } }}) </span>\r\n }\r\n }\r\n @case (subscriptionStates.ENDED) {\r\n ({{ \"SUBSCRIPTION.END_DATE\" | translate: { date: currentSubscription.EndDate | date: \"dd.MM.yyyy.\" } }})\r\n }\r\n }\r\n </span>\r\n </ng-container>\r\n </div>\r\n </div>\r\n\r\n @if(currentSubscription.EndDate){\r\n <div class=\"subscription-data-row\">\r\n <div class=\"subscription-label\">\r\n <span class=\"label\">{{ \"SUBSCRIPTION.LABEL_SUBSCRIPTION_END_DATE\" | translate }}</span>\r\n </div>\r\n\r\n <div class=\"subscription-data\">\r\n <ng-container>\r\n <span>{{currentSubscription.EndDate | date: \"dd.MM.yyyy\"}}</span>\r\n </ng-container>\r\n </div>\r\n </div>\r\n }\r\n\r\n @if(currentSubscription.Addons?.length){\r\n <div fxLayout=\"row\" class=\"subscription-data-row\">\r\n <div class=\"subscription-label\">\r\n <span class=\"label\">{{ \"SUBSCRIPTION.ADDITIONS_PLUGINS\" | translate }}</span>\r\n </div>\r\n\r\n <div class=\"subscription-data\">\r\n @for (item of currentSubscription.Addons; track $index; let i = $index) {\r\n <span>{{ item.id }}{{ currentSubscription.Addons!.length - 1 > i ? \",\" : \"\" }} </span>\r\n }\r\n </div>\r\n </div>\r\n }\r\n}\r\n\r\n@if(visibleQuotas().length){\r\n <h3 class=\"subscription-section-title text-l-semi-bold\">{{ \"SUBSCRIPTION.LIMITS\" | translate }}</h3>\r\n\r\n @for (currentQuota of visibleQuotas(); track $index) {\r\n <div class=\"subscription-limit-wrapper\">\r\n <mat-progress-bar [value]=\"currentQuota.percentUsed\"></mat-progress-bar>\r\n <div class=\"subscription-limit\">\r\n <span class=\"text-l-semi-bold\">\r\n {{ (\"QUOTA.\" + (currentQuota.quotaType.toString() | uppercase) + (currentQuota.isUnlimited? \"_UNLIMITED\": \"\")) | translate: { used: currentQuota.convertedUsed, limit: currentQuota.convertedLimit, percent: currentQuota.percentUsed} }}\r\n </span>\r\n </div>\r\n </div>\r\n }\r\n}\r\n\r\n<div class=\"subscription-actions-wrapper\">\r\n @if(chargebeeSettings()){\r\n <a mat-flat-button color=\"primary-accent-darker\" class=\"manage-sub-btn button-row-element\" href=\"javascript:void(0)\" data-cb-type=\"portal\">\r\n {{ \"SUBSCRIPTION.MANAGE\" | translate }}\r\n </a>\r\n }\r\n @if(contactUsUrl()){\r\n <a mat-stroked-button [attr.href]=\"contactUsUrl()\" target=\"_blank\" color=\"primary-accent-darker\">{{\"SUBSCRIPTION.CONTACT\" | translate}}</a>\r\n }\r\n</div>\r\n", styles: [":host{display:block}mat-card{margin:1.5rem}.subscription-container:not(.mobile){margin:16px 32px}.subscription-section-title{margin:32px 0 18px}.subscription-data-row{border-bottom:2px solid var(--base-70);margin-bottom:18px;flex-direction:row;display:flex}.subscription-data{color:var(--base-30);word-wrap:break-word;margin-left:.5rem}.subscription-limit-wrapper,.subscription-limit{margin-top:16px}.subscription-actions-wrapper{padding:32px 0 18px;display:flex;flex-direction:row;gap:24px}.subscription-manage-link{text-decoration:none}.subscription-container:not(.mobile,.empty){width:75%}.subscription-label:not(.mobile,.empty){width:35%}.subscription-data:not(.mobile,.empty){width:65%}.untranslated-files-disclaimer{margin-top:16px;margin-bottom:10px;color:var(--base-40)}.no-subscription-message{margin-top:32px;color:var(--base-40)}.contact-sales-btn{text-align:center}.contact-sales-btn:hover{text-decoration:none}\n"] }]
|
|
386
|
+
], template: "@if(token()){\r\n <!-- narrow type to non null property -->\r\n @let userToken = token()!;\r\n\r\n <h3 class=\"subscription-section-title text-l-semi-bold\">{{ \"SUBSCRIPTION.USER_INFO\" | translate }}</h3>\r\n\r\n <div class=\"subscription-data-row\">\r\n <div class=\"subscription-label\">\r\n <span class=\"label\">{{ \"SUBSCRIPTION.LABEL_NAME\" | translate }}</span>\r\n </div>\r\n\r\n <div class=\"subscription-data\">\r\n <span>{{ userToken.name }}</span>\r\n </div>\r\n </div>\r\n\r\n <div class=\"subscription-data-row\">\r\n <div class=\"subscription-label\">\r\n <span class=\"label\">{{ \"SUBSCRIPTION.LABEL_EMAIL\" | translate }}</span>\r\n </div>\r\n\r\n <div class=\"subscription-data\">\r\n <span>{{ userToken.email }}</span>\r\n </div>\r\n </div>\r\n}\r\n\r\n@if(subscription()){\r\n @let currentSubscription = subscription()!;\r\n\r\n <div fxLayout=\"row\" class=\"subscription-data-row\">\r\n <div class=\"subscription-label\">\r\n <span class=\"label\">{{ \"SUBSCRIPTION.LABEL_SUBSCRIPTION_PLAN_ID\" | translate }}</span>\r\n </div>\r\n\r\n <div class=\"subscription-data\">\r\n <ng-container>\r\n <span>\r\n {{ currentSubscription.Label ? currentSubscription.Label : currentSubscription.PlanId }}\r\n\r\n @switch (subscriptionState()) {\r\n @case(subscriptionStates.TRIAL){\r\n <span> ({{ \"SUBSCRIPTION.TRIAL_END_DATE\" | translate: { date: currentSubscription.EndDate | date: \"dd.MM.yyyy.\" } }}) </span>\r\n }\r\n @case (subscriptionStates.ACTIVE) {\r\n @if(currentSubscription.EndDate){\r\n <span> ({{ \"SUBSCRIPTION.END_DATE\" | translate: { date: currentSubscription.EndDate | date: \"dd.MM.yyyy.\" } }}) </span>\r\n }\r\n }\r\n @case (subscriptionStates.ENDED) {\r\n ({{ \"SUBSCRIPTION.END_DATE\" | translate: { date: currentSubscription.EndDate | date: \"dd.MM.yyyy.\" } }})\r\n }\r\n }\r\n </span>\r\n </ng-container>\r\n </div>\r\n </div>\r\n\r\n @if(currentSubscription.EndDate){\r\n <div class=\"subscription-data-row\">\r\n <div class=\"subscription-label\">\r\n <span class=\"label\">{{ \"SUBSCRIPTION.LABEL_SUBSCRIPTION_END_DATE\" | translate }}</span>\r\n </div>\r\n\r\n <div class=\"subscription-data\">\r\n <ng-container>\r\n <span>{{currentSubscription.EndDate | date: \"dd.MM.yyyy\"}}</span>\r\n </ng-container>\r\n </div>\r\n </div>\r\n }\r\n\r\n @if(currentSubscription.Addons?.length){\r\n <div fxLayout=\"row\" class=\"subscription-data-row\">\r\n <div class=\"subscription-label\">\r\n <span class=\"label\">{{ \"SUBSCRIPTION.ADDITIONS_PLUGINS\" | translate }}</span>\r\n </div>\r\n\r\n <div class=\"subscription-data\">\r\n @for (item of currentSubscription.Addons; track $index; let i = $index) {\r\n <span>{{ item.id }}</span>\r\n @if(item.qt>1){\r\n <span> ({{item.qt}})</span>\r\n }\r\n <span> {{ currentSubscription.Addons!.length - 1 > i ? \",\" : \"\" }} </span>\r\n }\r\n </div>\r\n </div>\r\n }\r\n}\r\n\r\n@if(visibleQuotas().length){\r\n <h3 class=\"subscription-section-title text-l-semi-bold\">{{ \"SUBSCRIPTION.LIMITS\" | translate }}</h3>\r\n\r\n @for (currentQuota of visibleQuotas(); track $index) {\r\n <div class=\"subscription-limit-wrapper\">\r\n <mat-progress-bar [value]=\"currentQuota.percentUsed\"></mat-progress-bar>\r\n <div class=\"subscription-limit\">\r\n <span class=\"text-l-semi-bold\">\r\n {{ (\"QUOTA.\" + (currentQuota.quotaType.toString() | uppercase) + (currentQuota.isUnlimited? \"_UNLIMITED\": \"\")) | translate: { used: currentQuota.convertedUsed, limit: currentQuota.convertedLimit, percent: currentQuota.percentUsed} }}\r\n </span>\r\n </div>\r\n </div>\r\n }\r\n}\r\n\r\n<div class=\"subscription-actions-wrapper\">\r\n @if(chargebeeSettings()){\r\n <a mat-flat-button color=\"primary-accent-darker\" class=\"manage-sub-btn button-row-element\" href=\"javascript:void(0)\" data-cb-type=\"portal\" (click)=\"manageClicked()\">\r\n {{ \"SUBSCRIPTION.MANAGE\" | translate }}\r\n </a>\r\n }\r\n @if(contactUsUrl()){\r\n <a mat-stroked-button [attr.href]=\"contactUsUrl()\" target=\"_blank\" color=\"primary-accent-darker\" (click)=\"contactUsClicked()\">{{\"SUBSCRIPTION.CONTACT\" | translate}}</a>\r\n }\r\n</div>\r\n", styles: [":host{display:block}mat-card{margin:1.5rem}.subscription-container:not(.mobile){margin:16px 32px}.subscription-section-title{margin:32px 0 18px}.subscription-data-row{border-bottom:2px solid var(--base-70);margin-bottom:18px;flex-direction:row;display:flex}.subscription-data{color:var(--base-30);word-wrap:break-word;margin-left:.5rem}.subscription-limit-wrapper,.subscription-limit{margin-top:16px}.subscription-actions-wrapper{padding:32px 0 18px;display:flex;flex-direction:row;gap:24px}.subscription-manage-link{text-decoration:none}.subscription-container:not(.mobile,.empty){width:75%}.subscription-label:not(.mobile,.empty){width:35%}.subscription-data:not(.mobile,.empty){width:65%}.untranslated-files-disclaimer{margin-top:16px;margin-bottom:10px;color:var(--base-40)}.no-subscription-message{margin-top:32px;color:var(--base-40)}.contact-sales-btn{text-align:center}.contact-sales-btn:hover{text-decoration:none}\n"] }]
|
|
358
387
|
}], null, null); })();
|
|
359
388
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(SubscriptionComponent, { className: "SubscriptionComponent", filePath: "lib\\subscription\\subscription.component.ts", lineNumber: 27 }); })();
|
|
360
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"subscription.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-common/src/lib/subscription/subscription.component.ts","../../../../../projects/ngx-common/src/lib/subscription/subscription.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, DatePipe } from '@angular/common';\r\nimport { Component, computed, inject, input, OnInit } from '@angular/core';\r\nimport { MatProgressBarModule } from '@angular/material/progress-bar';\r\nimport { TranslatePipe } from '@ngx-translate/core';\r\nimport { QuotaResponse, QuotaType, QuotaUsage } from '@tilde-nlp/ngx-services';\r\nimport { AuthSubscription } from '../core/auth/auth-subscription.model';\r\nimport { JwtToken } from '../core/auth/jwt-token.model';\r\nimport { SUBSCRIPTION_STATE } from './models/subscription-state.enum';\r\nimport { SubscriptionQuotaDisplay } from './models/subscription-quota-display.model';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { ChargebeeMountService } from './chargebee-mount.service';\r\nimport { ChargebeeSettings } from './models/chargebee-settings.model';\r\n\r\n@Component({\r\n  selector: 'lib-subscription',\r\n  standalone: true,\r\n  imports: [\r\n    TranslatePipe,\r\n    DatePipe,\r\n    MatProgressBarModule,\r\n    CommonModule,\r\n    MatButtonModule\r\n  ],\r\n  templateUrl: './subscription.component.html',\r\n  styleUrl: './subscription.component.scss'\r\n})\r\nexport class SubscriptionComponent implements OnInit {\r\n  readonly #chargebeeMountService = inject(ChargebeeMountService);\r\n\r\n  /** Parsed user token to get user related info */\r\n  readonly token = input.required<JwtToken | undefined>();\r\n  /** Current user plan that app has selected */\r\n  readonly subscription = input.required<AuthSubscription | undefined>();\r\n  /** Quota usage */\r\n  readonly quota = input.required<QuotaResponse | undefined>();\r\n  readonly visibleQuotaTypes = input<QuotaType[]>();\r\n  readonly contactUsUrl = input<string>();\r\n  readonly chargebeeSettings = input<ChargebeeSettings>();\r\n\r\n  readonly visibleQuotas = computed<SubscriptionQuotaDisplay[]>(() => {\r\n    const quota = this.quota();\r\n    if (!quota?.usage) {\r\n      return [];\r\n    }\r\n\r\n    let filtered: QuotaUsage[];\r\n    if (!this.visibleQuotaTypes()) {\r\n      filtered = quota.usage;\r\n    }\r\n    else {\r\n      filtered = quota.usage.filter(quota => this.visibleQuotaTypes()?.includes(quota.quotaType));\r\n    }\r\n\r\n    const visibleQuotas: SubscriptionQuotaDisplay[] = filtered.map(quota => {\r\n      return this.#convertUsageToDisplayQuota(quota);\r\n    });\r\n    return visibleQuotas;\r\n  })\r\n\r\n  readonly subscriptionStates = SUBSCRIPTION_STATE;\r\n\r\n  readonly subscriptionState = computed(() => {\r\n    const subscription = this.subscription();\r\n    if (!subscription) {\r\n      return SUBSCRIPTION_STATE.NONE;\r\n    }\r\n\r\n    if (subscription.IsTrial) {\r\n      return SUBSCRIPTION_STATE.TRIAL;\r\n    }\r\n\r\n\r\n    const now = new Date();\r\n    if (!subscription.EndDate || new Date(subscription.EndDate) < now) {\r\n      return SUBSCRIPTION_STATE.ACTIVE;\r\n    } else {\r\n      return SUBSCRIPTION_STATE.ENDED;\r\n    }\r\n  });\r\n\r\n  ngOnInit(): void {\r\n    this.#mountChargeBeeScript();\r\n  }\r\n\r\n  #mountChargeBeeScript() {\r\n    const chargebeeSettings = this.chargebeeSettings();\r\n    if (!chargebeeSettings?.site || !chargebeeSettings.script) {\r\n      return;\r\n    }\r\n\r\n    if (!this.#chargebeeMountService.chargebeeMounted) {\r\n      const el = document.createElement('script');\r\n      el.onload = () => {\r\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n        const windowObj: any = window;\r\n        windowObj.Chargebee.init({\r\n          site: chargebeeSettings.site\r\n        });\r\n        windowObj.Chargebee.registerAgain();\r\n        this.#chargebeeMountService.chargebeeMounted = true;\r\n      };\r\n      el.setAttribute('src', chargebeeSettings.script);\r\n      document.head.appendChild(el);\r\n    } else {\r\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n      const windowObj: any = window;\r\n      windowObj.Chargebee.registerAgain();\r\n    }\r\n  }\r\n\r\n  #convertUsageToDisplayQuota(quota: QuotaUsage): SubscriptionQuotaDisplay {\r\n    // int max in c#\r\n    const unlimitedBenchmark = 2147483647;\r\n\r\n    const used = quota.quotaLimit - quota.quotaRemaining;\r\n    let convertedLimit = quota.quotaLimit.toString();\r\n    let convertedUsed = used.toString();\r\n    const isUnlimited = unlimitedBenchmark <= quota.quotaLimit;\r\n    const percentUsed = Math.round(((quota.quotaLimit - quota.quotaRemaining) / quota.quotaLimit) * 100);\r\n\r\n    switch (quota.quotaType) {\r\n      case QuotaType.ASR_FILE_LENGTH_SECONDS:\r\n      case QuotaType.ONLINE_ASR_USED_SECONDS:\r\n        convertedLimit = Math.ceil(quota.quotaLimit / 60).toString();\r\n        convertedUsed = Math.round(used / 60).toString();\r\n        break;\r\n      case QuotaType.ASR_FILE_SIZE_KB:\r\n        convertedLimit = this.#formatBytes(quota.quotaLimit * 1024);\r\n        convertedUsed = this.#formatBytes(used * 1024);\r\n        break;\r\n      case QuotaType.LLM_REQUESTS:\r\n        break;\r\n    }\r\n\r\n    return {\r\n      ...quota,\r\n      convertedLimit,\r\n      convertedUsed,\r\n      isUnlimited,\r\n      percentUsed\r\n    };\r\n  }\r\n\r\n  #formatBytes(bytes: number, decimals = 0) {\r\n    if (!+bytes) return '0 Bytes'\r\n\r\n    const k = 1024\r\n    const dm = decimals < 0 ? 0 : decimals\r\n    const sizes = ['Bytes', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB']\r\n\r\n    const i = Math.floor(Math.log(bytes) / Math.log(k))\r\n\r\n    return `${parseFloat((bytes / Math.pow(k, i)).toFixed(dm))} ${sizes[i]}`\r\n  }\r\n\r\n}\r\n","@if(token()){\r\n  <!-- narrow type to non null property -->\r\n  @let userToken = token()!;\r\n\r\n    <h3 class=\"subscription-section-title text-l-semi-bold\">{{ \"SUBSCRIPTION.USER_INFO\" | translate }}</h3>\r\n\r\n    <div class=\"subscription-data-row\">\r\n      <div class=\"subscription-label\">\r\n        <span class=\"label\">{{ \"SUBSCRIPTION.LABEL_NAME\" | translate }}</span>\r\n      </div>\r\n\r\n      <div class=\"subscription-data\">\r\n        <span>{{ userToken.name }}</span>\r\n      </div>\r\n    </div>\r\n\r\n    <div class=\"subscription-data-row\">\r\n      <div class=\"subscription-label\">\r\n        <span class=\"label\">{{ \"SUBSCRIPTION.LABEL_EMAIL\" | translate }}</span>\r\n      </div>\r\n\r\n      <div class=\"subscription-data\">\r\n        <span>{{ userToken.email }}</span>\r\n      </div>\r\n    </div>\r\n}\r\n\r\n@if(subscription()){\r\n  @let currentSubscription = subscription()!;\r\n\r\n  <div fxLayout=\"row\" class=\"subscription-data-row\">\r\n    <div class=\"subscription-label\">\r\n      <span class=\"label\">{{ \"SUBSCRIPTION.LABEL_SUBSCRIPTION_PLAN_ID\" | translate }}</span>\r\n    </div>\r\n\r\n    <div class=\"subscription-data\">\r\n      <ng-container>\r\n        <span>\r\n          {{ currentSubscription.Label ? currentSubscription.Label : currentSubscription.PlanId }}\r\n\r\n          @switch (subscriptionState()) {\r\n            @case(subscriptionStates.TRIAL){\r\n              <span> ({{ \"SUBSCRIPTION.TRIAL_END_DATE\" | translate: { date: currentSubscription.EndDate | date: \"dd.MM.yyyy.\" } }}) </span>\r\n            }\r\n            @case (subscriptionStates.ACTIVE) {\r\n              @if(currentSubscription.EndDate){\r\n                <span> ({{ \"SUBSCRIPTION.END_DATE\" | translate: { date: currentSubscription.EndDate | date: \"dd.MM.yyyy.\" } }}) </span>\r\n              }\r\n            }\r\n            @case (subscriptionStates.ENDED) {\r\n            ({{ \"SUBSCRIPTION.END_DATE\" | translate: { date: currentSubscription.EndDate | date: \"dd.MM.yyyy.\" } }})\r\n            }\r\n          }\r\n        </span>\r\n      </ng-container>\r\n    </div>\r\n  </div>\r\n\r\n  @if(currentSubscription.EndDate){\r\n  <div class=\"subscription-data-row\">\r\n    <div class=\"subscription-label\">\r\n      <span class=\"label\">{{ \"SUBSCRIPTION.LABEL_SUBSCRIPTION_END_DATE\" | translate }}</span>\r\n    </div>\r\n\r\n    <div class=\"subscription-data\">\r\n      <ng-container>\r\n        <span>{{currentSubscription.EndDate | date: \"dd.MM.yyyy\"}}</span>\r\n      </ng-container>\r\n    </div>\r\n    </div>\r\n  }\r\n\r\n  @if(currentSubscription.Addons?.length){\r\n    <div fxLayout=\"row\" class=\"subscription-data-row\">\r\n      <div class=\"subscription-label\">\r\n        <span class=\"label\">{{ \"SUBSCRIPTION.ADDITIONS_PLUGINS\" | translate }}</span>\r\n      </div>\r\n\r\n      <div class=\"subscription-data\">\r\n        @for (item of currentSubscription.Addons; track $index; let i = $index) {\r\n            <span>{{ item.id }}{{ currentSubscription.Addons!.length - 1 > i ? \",\" : \"\" }} </span>\r\n        }\r\n      </div>\r\n    </div>\r\n  }\r\n}\r\n\r\n@if(visibleQuotas().length){\r\n  <h3 class=\"subscription-section-title text-l-semi-bold\">{{ \"SUBSCRIPTION.LIMITS\" | translate }}</h3>\r\n\r\n  @for (currentQuota of visibleQuotas(); track $index) {\r\n    <div class=\"subscription-limit-wrapper\">\r\n      <mat-progress-bar [value]=\"currentQuota.percentUsed\"></mat-progress-bar>\r\n      <div class=\"subscription-limit\">\r\n        <span class=\"text-l-semi-bold\">\r\n          {{ (\"QUOTA.\" + (currentQuota.quotaType.toString() | uppercase) + (currentQuota.isUnlimited? \"_UNLIMITED\": \"\")) | translate: { used: currentQuota.convertedUsed, limit: currentQuota.convertedLimit, percent: currentQuota.percentUsed} }}\r\n        </span>\r\n      </div>\r\n    </div>\r\n  }\r\n}\r\n\r\n<div class=\"subscription-actions-wrapper\">\r\n  @if(chargebeeSettings()){\r\n    <a mat-flat-button color=\"primary-accent-darker\" class=\"manage-sub-btn button-row-element\" href=\"javascript:void(0)\" data-cb-type=\"portal\">\r\n      {{ \"SUBSCRIPTION.MANAGE\" | translate }}\r\n    </a>\r\n  }\r\n  @if(contactUsUrl()){\r\n    <a mat-stroked-button [attr.href]=\"contactUsUrl()\" target=\"_blank\" color=\"primary-accent-darker\">{{\"SUBSCRIPTION.CONTACT\" | translate}}</a>\r\n  }\r\n</div>\r\n"]}
|
|
389
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"subscription.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-common/src/lib/subscription/subscription.component.ts","../../../../../projects/ngx-common/src/lib/subscription/subscription.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule, DatePipe } from '@angular/common';\r\nimport { Component, computed, inject, input, OnInit, output } from '@angular/core';\r\nimport { MatProgressBarModule } from '@angular/material/progress-bar';\r\nimport { TranslatePipe } from '@ngx-translate/core';\r\nimport { QuotaResponse, QuotaType, QuotaUsage } from '@tilde-nlp/ngx-services';\r\nimport { AuthSubscription } from '../core/auth/auth-subscription.model';\r\nimport { JwtToken } from '../core/auth/jwt-token.model';\r\nimport { SUBSCRIPTION_STATE } from './models/subscription-state.enum';\r\nimport { SubscriptionQuotaDisplay } from './models/subscription-quota-display.model';\r\nimport { MatButtonModule } from '@angular/material/button';\r\nimport { ChargebeeMountService } from './chargebee-mount.service';\r\nimport { ChargebeeSettings } from './models/chargebee-settings.model';\r\n\r\n@Component({\r\n  selector: 'lib-subscription',\r\n  standalone: true,\r\n  imports: [\r\n    TranslatePipe,\r\n    DatePipe,\r\n    MatProgressBarModule,\r\n    CommonModule,\r\n    MatButtonModule\r\n  ],\r\n  templateUrl: './subscription.component.html',\r\n  styleUrl: './subscription.component.scss'\r\n})\r\nexport class SubscriptionComponent implements OnInit {\r\n  readonly #chargebeeMountService = inject(ChargebeeMountService);\r\n\r\n  /** Parsed user token to get user related info */\r\n  readonly token = input.required<JwtToken | undefined>();\r\n  /** Current user plan that app has selected */\r\n  readonly subscription = input.required<AuthSubscription | undefined>();\r\n  /** Quota usage */\r\n  readonly quota = input.required<QuotaResponse | undefined>();\r\n  readonly visibleQuotaTypes = input<QuotaType[]>();\r\n  readonly contactUsUrl = input<string>();\r\n  readonly chargebeeSettings = input<ChargebeeSettings>();\r\n\r\n  readonly manageClick = output();\r\n  readonly contactUsClick = output();\r\n\r\n  readonly visibleQuotas = computed<SubscriptionQuotaDisplay[]>(() => {\r\n    const quota = this.quota();\r\n    if (!quota?.usage) {\r\n      return [];\r\n    }\r\n\r\n    let filtered: QuotaUsage[];\r\n    if (!this.visibleQuotaTypes()) {\r\n      filtered = quota.usage;\r\n    }\r\n    else {\r\n      filtered = quota.usage.filter(quota => this.visibleQuotaTypes()?.includes(quota.quotaType));\r\n    }\r\n\r\n    const visibleQuotas: SubscriptionQuotaDisplay[] = filtered.map(quota => {\r\n      return this.#convertUsageToDisplayQuota(quota);\r\n    });\r\n    return visibleQuotas;\r\n  })\r\n\r\n  readonly subscriptionStates = SUBSCRIPTION_STATE;\r\n\r\n  readonly subscriptionState = computed(() => {\r\n    const subscription = this.subscription();\r\n    if (!subscription) {\r\n      return SUBSCRIPTION_STATE.NONE;\r\n    }\r\n\r\n    if (subscription.IsTrial) {\r\n      return SUBSCRIPTION_STATE.TRIAL;\r\n    }\r\n\r\n\r\n    const now = new Date();\r\n    if (!subscription.EndDate || new Date(subscription.EndDate) < now) {\r\n      return SUBSCRIPTION_STATE.ACTIVE;\r\n    } else {\r\n      return SUBSCRIPTION_STATE.ENDED;\r\n    }\r\n  });\r\n\r\n  ngOnInit(): void {\r\n    this.#mountChargeBeeScript();\r\n  }\r\n\r\n  manageClicked(){\r\n    this.manageClick.emit();\r\n  }\r\n\r\n  contactUsClicked(){\r\n    this.contactUsClick.emit();\r\n  }\r\n\r\n  #mountChargeBeeScript() {\r\n    const chargebeeSettings = this.chargebeeSettings();\r\n    if (!chargebeeSettings?.site || !chargebeeSettings.script) {\r\n      return;\r\n    }\r\n\r\n    if (!this.#chargebeeMountService.chargebeeMounted) {\r\n      const el = document.createElement('script');\r\n      el.onload = () => {\r\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n        const windowObj: any = window;\r\n        windowObj.Chargebee.init({\r\n          site: chargebeeSettings.site\r\n        });\r\n        windowObj.Chargebee.registerAgain();\r\n        this.#chargebeeMountService.chargebeeMounted = true;\r\n      };\r\n      el.setAttribute('src', chargebeeSettings.script);\r\n      document.head.appendChild(el);\r\n    } else {\r\n      // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n      const windowObj: any = window;\r\n      windowObj.Chargebee.registerAgain();\r\n    }\r\n  }\r\n\r\n  #convertUsageToDisplayQuota(quota: QuotaUsage): SubscriptionQuotaDisplay {\r\n    // int max in c#\r\n    const unlimitedBenchmark = 2147483647;\r\n\r\n    const used = quota.quotaLimit - quota.quotaRemaining;\r\n    let convertedLimit = quota.quotaLimit.toString();\r\n    let convertedUsed = used.toString();\r\n    const isUnlimited = unlimitedBenchmark <= quota.quotaLimit;\r\n    const percentUsed = Math.round(((quota.quotaLimit - quota.quotaRemaining) / quota.quotaLimit) * 100);\r\n\r\n    switch (quota.quotaType) {\r\n      case QuotaType.ASR_FILE_LENGTH_SECONDS:\r\n      case QuotaType.ONLINE_ASR_USED_SECONDS:\r\n        convertedLimit = Math.ceil(quota.quotaLimit / 60).toString();\r\n        convertedUsed = Math.round(used / 60).toString();\r\n        break;\r\n      case QuotaType.ASR_FILE_SIZE_KB:\r\n        convertedLimit = this.#formatBytes(quota.quotaLimit * 1024);\r\n        convertedUsed = this.#formatBytes(used * 1024);\r\n        break;\r\n      case QuotaType.LLM_REQUESTS:\r\n        break;\r\n    }\r\n\r\n    return {\r\n      ...quota,\r\n      convertedLimit,\r\n      convertedUsed,\r\n      isUnlimited,\r\n      percentUsed\r\n    };\r\n  }\r\n\r\n  #formatBytes(bytes: number, decimals = 0) {\r\n    if (!+bytes) return '0 Bytes'\r\n\r\n    const k = 1024\r\n    const dm = decimals < 0 ? 0 : decimals\r\n    const sizes = ['Bytes', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB']\r\n\r\n    const i = Math.floor(Math.log(bytes) / Math.log(k))\r\n\r\n    return `${parseFloat((bytes / Math.pow(k, i)).toFixed(dm))} ${sizes[i]}`\r\n  }\r\n\r\n}\r\n","@if(token()){\r\n  <!-- narrow type to non null property -->\r\n  @let userToken = token()!;\r\n\r\n    <h3 class=\"subscription-section-title text-l-semi-bold\">{{ \"SUBSCRIPTION.USER_INFO\" | translate }}</h3>\r\n\r\n    <div class=\"subscription-data-row\">\r\n      <div class=\"subscription-label\">\r\n        <span class=\"label\">{{ \"SUBSCRIPTION.LABEL_NAME\" | translate }}</span>\r\n      </div>\r\n\r\n      <div class=\"subscription-data\">\r\n        <span>{{ userToken.name }}</span>\r\n      </div>\r\n    </div>\r\n\r\n    <div class=\"subscription-data-row\">\r\n      <div class=\"subscription-label\">\r\n        <span class=\"label\">{{ \"SUBSCRIPTION.LABEL_EMAIL\" | translate }}</span>\r\n      </div>\r\n\r\n      <div class=\"subscription-data\">\r\n        <span>{{ userToken.email }}</span>\r\n      </div>\r\n    </div>\r\n}\r\n\r\n@if(subscription()){\r\n  @let currentSubscription = subscription()!;\r\n\r\n  <div fxLayout=\"row\" class=\"subscription-data-row\">\r\n    <div class=\"subscription-label\">\r\n      <span class=\"label\">{{ \"SUBSCRIPTION.LABEL_SUBSCRIPTION_PLAN_ID\" | translate }}</span>\r\n    </div>\r\n\r\n    <div class=\"subscription-data\">\r\n      <ng-container>\r\n        <span>\r\n          {{ currentSubscription.Label ? currentSubscription.Label : currentSubscription.PlanId }}\r\n\r\n          @switch (subscriptionState()) {\r\n            @case(subscriptionStates.TRIAL){\r\n              <span> ({{ \"SUBSCRIPTION.TRIAL_END_DATE\" | translate: { date: currentSubscription.EndDate | date: \"dd.MM.yyyy.\" } }}) </span>\r\n            }\r\n            @case (subscriptionStates.ACTIVE) {\r\n              @if(currentSubscription.EndDate){\r\n                <span> ({{ \"SUBSCRIPTION.END_DATE\" | translate: { date: currentSubscription.EndDate | date: \"dd.MM.yyyy.\" } }}) </span>\r\n              }\r\n            }\r\n            @case (subscriptionStates.ENDED) {\r\n            ({{ \"SUBSCRIPTION.END_DATE\" | translate: { date: currentSubscription.EndDate | date: \"dd.MM.yyyy.\" } }})\r\n            }\r\n          }\r\n        </span>\r\n      </ng-container>\r\n    </div>\r\n  </div>\r\n\r\n  @if(currentSubscription.EndDate){\r\n  <div class=\"subscription-data-row\">\r\n    <div class=\"subscription-label\">\r\n      <span class=\"label\">{{ \"SUBSCRIPTION.LABEL_SUBSCRIPTION_END_DATE\" | translate }}</span>\r\n    </div>\r\n\r\n    <div class=\"subscription-data\">\r\n      <ng-container>\r\n        <span>{{currentSubscription.EndDate | date: \"dd.MM.yyyy\"}}</span>\r\n      </ng-container>\r\n    </div>\r\n    </div>\r\n  }\r\n\r\n  @if(currentSubscription.Addons?.length){\r\n    <div fxLayout=\"row\" class=\"subscription-data-row\">\r\n      <div class=\"subscription-label\">\r\n        <span class=\"label\">{{ \"SUBSCRIPTION.ADDITIONS_PLUGINS\" | translate }}</span>\r\n      </div>\r\n\r\n      <div class=\"subscription-data\">\r\n        @for (item of currentSubscription.Addons; track $index; let i = $index) {\r\n            <span>{{ item.id }}</span>\r\n            @if(item.qt>1){\r\n              <span> ({{item.qt}})</span>\r\n            }\r\n            <span> {{ currentSubscription.Addons!.length - 1 > i ? \",\" : \"\" }} </span>\r\n        }\r\n      </div>\r\n    </div>\r\n  }\r\n}\r\n\r\n@if(visibleQuotas().length){\r\n  <h3 class=\"subscription-section-title text-l-semi-bold\">{{ \"SUBSCRIPTION.LIMITS\" | translate }}</h3>\r\n\r\n  @for (currentQuota of visibleQuotas(); track $index) {\r\n    <div class=\"subscription-limit-wrapper\">\r\n      <mat-progress-bar [value]=\"currentQuota.percentUsed\"></mat-progress-bar>\r\n      <div class=\"subscription-limit\">\r\n        <span class=\"text-l-semi-bold\">\r\n          {{ (\"QUOTA.\" + (currentQuota.quotaType.toString() | uppercase) + (currentQuota.isUnlimited? \"_UNLIMITED\": \"\")) | translate: { used: currentQuota.convertedUsed, limit: currentQuota.convertedLimit, percent: currentQuota.percentUsed} }}\r\n        </span>\r\n      </div>\r\n    </div>\r\n  }\r\n}\r\n\r\n<div class=\"subscription-actions-wrapper\">\r\n  @if(chargebeeSettings()){\r\n    <a mat-flat-button color=\"primary-accent-darker\" class=\"manage-sub-btn button-row-element\" href=\"javascript:void(0)\" data-cb-type=\"portal\" (click)=\"manageClicked()\">\r\n      {{ \"SUBSCRIPTION.MANAGE\" | translate }}\r\n    </a>\r\n  }\r\n  @if(contactUsUrl()){\r\n    <a mat-stroked-button [attr.href]=\"contactUsUrl()\" target=\"_blank\" color=\"primary-accent-darker\" (click)=\"contactUsClicked()\">{{\"SUBSCRIPTION.CONTACT\" | translate}}</a>\r\n  }\r\n</div>\r\n"]}
|