@tilde-nlp/ngx-common 6.1.29 → 6.1.30

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,16 @@
1
+ import { Injectable } from "@angular/core";
2
+ import * as i0 from "@angular/core";
3
+ export class ChargebeeMountService {
4
+ constructor() {
5
+ this.chargebeeMounted = false;
6
+ }
7
+ static { this.ɵfac = function ChargebeeMountService_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || ChargebeeMountService)(); }; }
8
+ static { this.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: ChargebeeMountService, factory: ChargebeeMountService.ɵfac, providedIn: 'root' }); }
9
+ }
10
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ChargebeeMountService, [{
11
+ type: Injectable,
12
+ args: [{
13
+ providedIn: 'root'
14
+ }]
15
+ }], null, null); })();
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcmdlYmVlLW1vdW50LnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tbW9uL3NyYy9saWIvc3Vic2NyaXB0aW9uL2NoYXJnZWJlZS1tb3VudC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBTTNDLE1BQU0sT0FBTyxxQkFBcUI7SUFIbEM7UUFJRSxxQkFBZ0IsR0FBRyxLQUFLLENBQUM7S0FDMUI7c0hBRlkscUJBQXFCO3VFQUFyQixxQkFBcUIsV0FBckIscUJBQXFCLG1CQUZwQixNQUFNOztpRkFFUCxxQkFBcUI7Y0FIakMsVUFBVTtlQUFDO2dCQUNWLFVBQVUsRUFBRSxNQUFNO2FBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcblxyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290J1xyXG59KVxyXG5leHBvcnQgY2xhc3MgQ2hhcmdlYmVlTW91bnRTZXJ2aWNlIHtcclxuICBjaGFyZ2ViZWVNb3VudGVkID0gZmFsc2U7XHJcbn1cclxuIl19
@@ -1,2 +1,3 @@
1
1
  export * from './subscription.component';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tbW9uL3NyYy9saWIvc3Vic2NyaXB0aW9uL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsMEJBQTBCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3N1YnNjcmlwdGlvbi5jb21wb25lbnQnO1xyXG4iXX0=
2
+ export * from './models';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tbW9uL3NyYy9saWIvc3Vic2NyaXB0aW9uL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyxVQUFVLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3N1YnNjcmlwdGlvbi5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL21vZGVscyc7XHJcbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcmdlYmVlLXNldHRpbmdzLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWNvbW1vbi9zcmMvbGliL3N1YnNjcmlwdGlvbi9tb2RlbHMvY2hhcmdlYmVlLXNldHRpbmdzLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIENoYXJnZWJlZVNldHRpbmdze1xyXG4gIHNpdGU6IHN0cmluZztcclxuICBzY3JpcHQ6IHN0cmluZztcclxufVxyXG4iXX0=
@@ -0,0 +1,2 @@
1
+ export * from './chargebee-settings.model';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tbW9uL3NyYy9saWIvc3Vic2NyaXB0aW9uL21vZGVscy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDRCQUE0QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jaGFyZ2ViZWUtc2V0dGluZ3MubW9kZWwnO1xyXG4iXX0=
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3Vic2NyaXB0aW9uLXF1b3RhLWRpc3BsYXkubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tbW9uL3NyYy9saWIvc3Vic2NyaXB0aW9uL21vZGVscy9zdWJzY3JpcHRpb24tcXVvdGEtZGlzcGxheS5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUXVvdGFVc2FnZSB9IGZyb20gXCJAdGlsZGUtbmxwL25neC1zZXJ2aWNlc1wiO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBTdWJzY3JpcHRpb25RdW90YURpc3BsYXkgZXh0ZW5kcyBRdW90YVVzYWdle1xyXG4gIGlzVW5saW1pdGVkOiBib29sZWFuO1xyXG4gIC8qKiBDb252ZXJ0ZWQgdG8gZGlzcGxheWFibGUgbWVhc3VybWVudHMuIEUuZy4gaWYgcXVvdGEgaXMgY291bnRlZCBpbiBzZWNvbmRzLCB0aGlzIG1heWJlIGNvbnZlcnRlZCB0byBtaW5zIG9yIGhvdXJzLCBkZXBlbmRpbmcgb24gcXVvdGEgdHlwZS4gKi9cclxuICBjb252ZXJ0ZWRMaW1pdDogc3RyaW5nO1xyXG4gIC8qKiBDb252ZXJ0ZWQgdG8gZGlzcGxheWFibGUgbWVhc3VybWVudHMuIEUuZy4gaWYgcXVvdGEgaXMgY291bnRlZCBpbiBzZWNvbmRzLCB0aGlzIG1heWJlIGNvbnZlcnRlZCB0byBtaW5zIG9yIGhvdXJzLCBkZXBlbmRpbmcgb24gcXVvdGEgdHlwZS4gKi9cclxuICBjb252ZXJ0ZWRVc2VkOiBzdHJpbmc7XHJcbiAgcGVyY2VudFVzZWQ6IG51bWJlcjtcclxufVxyXG4iXX0=
@@ -1,31 +1,35 @@
1
- import { Component, computed, input } from '@angular/core';
2
- import { TranslatePipe } from '@ngx-translate/core';
3
1
  import { CommonModule, DatePipe } from '@angular/common';
4
- import { SUBSCRIPTION_STATE } from './models/subscription-state.enum';
2
+ import { Component, computed, inject, input } from '@angular/core';
5
3
  import { MatProgressBarModule } from '@angular/material/progress-bar';
4
+ import { TranslatePipe } from '@ngx-translate/core';
5
+ import { QuotaType } from '@tilde-nlp/ngx-services';
6
+ import { SUBSCRIPTION_STATE } from './models/subscription-state.enum';
7
+ import { MatButtonModule } from '@angular/material/button';
8
+ import { ChargebeeMountService } from './chargebee-mount.service';
6
9
  import * as i0 from "@angular/core";
7
10
  import * as i1 from "@angular/material/progress-bar";
8
11
  import * as i2 from "@angular/common";
12
+ import * as i3 from "@angular/material/button";
9
13
  const _c0 = a0 => ({ date: a0 });
10
- const _c1 = (a0, a1) => ({ used: a0, limit: a1 });
14
+ const _c1 = (a0, a1, a2) => ({ used: a0, limit: a1, percent: a2 });
11
15
  function SubscriptionComponent_Conditional_0_Template(rf, ctx) { if (rf & 1) {
12
16
  i0.ɵɵdeclareLet(0);
13
- i0.ɵɵelementStart(1, "h3", 0);
17
+ i0.ɵɵelementStart(1, "h3", 3);
14
18
  i0.ɵɵtext(2);
15
19
  i0.ɵɵpipe(3, "translate");
16
20
  i0.ɵɵelementEnd();
17
- i0.ɵɵelementStart(4, "div", 1)(5, "div", 2)(6, "span", 3);
21
+ i0.ɵɵelementStart(4, "div", 4)(5, "div", 5)(6, "span", 6);
18
22
  i0.ɵɵtext(7);
19
23
  i0.ɵɵpipe(8, "translate");
20
24
  i0.ɵɵelementEnd()();
21
- i0.ɵɵelementStart(9, "div", 4)(10, "span");
25
+ i0.ɵɵelementStart(9, "div", 7)(10, "span");
22
26
  i0.ɵɵtext(11);
23
27
  i0.ɵɵelementEnd()()();
24
- i0.ɵɵelementStart(12, "div", 1)(13, "div", 2)(14, "span", 3);
28
+ i0.ɵɵelementStart(12, "div", 4)(13, "div", 5)(14, "span", 6);
25
29
  i0.ɵɵtext(15);
26
30
  i0.ɵɵpipe(16, "translate");
27
31
  i0.ɵɵelementEnd()();
28
- i0.ɵɵelementStart(17, "div", 4)(18, "span");
32
+ i0.ɵɵelementStart(17, "div", 7)(18, "span");
29
33
  i0.ɵɵtext(19);
30
34
  i0.ɵɵelementEnd()()();
31
35
  } if (rf & 2) {
@@ -82,11 +86,11 @@ function SubscriptionComponent_Conditional_1_Case_12_Template(rf, ctx) { if (rf
82
86
  i0.ɵɵtextInterpolate1(" (", i0.ɵɵpipeBind2(2, 4, "SUBSCRIPTION.END_DATE", i0.ɵɵpureFunction1(7, _c0, i0.ɵɵpipeBind2(1, 1, currentSubscription_r2.EndDate, "dd.MM.yyyy."))), ") ");
83
87
  } }
84
88
  function SubscriptionComponent_Conditional_1_Conditional_13_Template(rf, ctx) { if (rf & 1) {
85
- i0.ɵɵelementStart(0, "div", 1)(1, "div", 2)(2, "span", 3);
89
+ i0.ɵɵelementStart(0, "div", 4)(1, "div", 5)(2, "span", 6);
86
90
  i0.ɵɵtext(3);
87
91
  i0.ɵɵpipe(4, "translate");
88
92
  i0.ɵɵelementEnd()();
89
- i0.ɵɵelementStart(5, "div", 4);
93
+ i0.ɵɵelementStart(5, "div", 7);
90
94
  i0.ɵɵelementContainerStart(6);
91
95
  i0.ɵɵelementStart(7, "span");
92
96
  i0.ɵɵtext(8);
@@ -115,11 +119,11 @@ function SubscriptionComponent_Conditional_1_Conditional_14_For_7_Template(rf, c
115
119
  i0.ɵɵtextInterpolate2("", item_r3.id, "", currentSubscription_r2.Addons.length - 1 > ɵ$index_95_r4 ? "," : "", " ");
116
120
  } }
117
121
  function SubscriptionComponent_Conditional_1_Conditional_14_Template(rf, ctx) { if (rf & 1) {
118
- i0.ɵɵelementStart(0, "div", 5)(1, "div", 2)(2, "span", 3);
122
+ i0.ɵɵelementStart(0, "div", 8)(1, "div", 5)(2, "span", 6);
119
123
  i0.ɵɵtext(3);
120
124
  i0.ɵɵpipe(4, "translate");
121
125
  i0.ɵɵelementEnd()();
122
- i0.ɵɵelementStart(5, "div", 4);
126
+ i0.ɵɵelementStart(5, "div", 7);
123
127
  i0.ɵɵrepeaterCreate(6, SubscriptionComponent_Conditional_1_Conditional_14_For_7_Template, 2, 2, "span", null, i0.ɵɵrepeaterTrackByIndex);
124
128
  i0.ɵɵelementEnd()();
125
129
  } if (rf & 2) {
@@ -132,11 +136,11 @@ function SubscriptionComponent_Conditional_1_Conditional_14_Template(rf, ctx) {
132
136
  } }
133
137
  function SubscriptionComponent_Conditional_1_Template(rf, ctx) { if (rf & 1) {
134
138
  i0.ɵɵdeclareLet(0);
135
- i0.ɵɵelementStart(1, "div", 5)(2, "div", 2)(3, "span", 3);
139
+ i0.ɵɵelementStart(1, "div", 8)(2, "div", 5)(3, "span", 6);
136
140
  i0.ɵɵtext(4);
137
141
  i0.ɵɵpipe(5, "translate");
138
142
  i0.ɵɵelementEnd()();
139
- i0.ɵɵelementStart(6, "div", 4);
143
+ i0.ɵɵelementStart(6, "div", 7);
140
144
  i0.ɵɵelementContainerStart(7);
141
145
  i0.ɵɵelementStart(8, "span");
142
146
  i0.ɵɵtext(9);
@@ -144,7 +148,7 @@ function SubscriptionComponent_Conditional_1_Template(rf, ctx) { if (rf & 1) {
144
148
  i0.ɵɵelementEnd();
145
149
  i0.ɵɵelementContainerEnd();
146
150
  i0.ɵɵelementEnd()();
147
- i0.ɵɵtemplate(13, SubscriptionComponent_Conditional_1_Conditional_13_Template, 10, 7, "div", 1)(14, SubscriptionComponent_Conditional_1_Conditional_14_Template, 8, 3, "div", 5);
151
+ i0.ɵɵtemplate(13, SubscriptionComponent_Conditional_1_Conditional_13_Template, 10, 7, "div", 4)(14, SubscriptionComponent_Conditional_1_Conditional_14_Template, 8, 3, "div", 8);
148
152
  } if (rf & 2) {
149
153
  let tmp_4_0;
150
154
  const ctx_r4 = i0.ɵɵnextContext();
@@ -161,9 +165,9 @@ function SubscriptionComponent_Conditional_1_Template(rf, ctx) { if (rf & 1) {
161
165
  i0.ɵɵconditional((currentSubscription_r6.Addons == null ? null : currentSubscription_r6.Addons.length) ? 14 : -1);
162
166
  } }
163
167
  function SubscriptionComponent_Conditional_2_For_4_Template(rf, ctx) { if (rf & 1) {
164
- i0.ɵɵelementStart(0, "div", 6);
165
- i0.ɵɵelement(1, "mat-progress-bar", 7);
166
- i0.ɵɵelementStart(2, "div", 8)(3, "span", 9);
168
+ i0.ɵɵelementStart(0, "div", 9);
169
+ i0.ɵɵelement(1, "mat-progress-bar", 10);
170
+ i0.ɵɵelementStart(2, "div", 11)(3, "span", 12);
167
171
  i0.ɵɵtext(4);
168
172
  i0.ɵɵpipe(5, "uppercase");
169
173
  i0.ɵɵpipe(6, "translate");
@@ -171,16 +175,16 @@ function SubscriptionComponent_Conditional_2_For_4_Template(rf, ctx) { if (rf &
171
175
  } if (rf & 2) {
172
176
  const currentQuota_r7 = ctx.$implicit;
173
177
  i0.ɵɵadvance();
174
- i0.ɵɵproperty("value", (currentQuota_r7.quotaLimit - currentQuota_r7.quotaRemaining) / currentQuota_r7.quotaLimit * 100);
178
+ i0.ɵɵproperty("value", currentQuota_r7.percentUsed);
175
179
  i0.ɵɵadvance(3);
176
- i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind2(6, 4, "QUOTA." + i0.ɵɵpipeBind1(5, 2, currentQuota_r7.quotaType.toString()), i0.ɵɵpureFunction2(7, _c1, currentQuota_r7.quotaLimit - currentQuota_r7.quotaRemaining, currentQuota_r7.quotaLimit)), " ");
180
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind2(6, 4, "QUOTA." + i0.ɵɵpipeBind1(5, 2, currentQuota_r7.quotaType.toString()) + (currentQuota_r7.isUnlimited ? "_UNLIMITED" : ""), i0.ɵɵpureFunction3(7, _c1, currentQuota_r7.convertedUsed, currentQuota_r7.convertedLimit, currentQuota_r7.percentUsed)), " ");
177
181
  } }
178
182
  function SubscriptionComponent_Conditional_2_Template(rf, ctx) { if (rf & 1) {
179
- i0.ɵɵelementStart(0, "h3", 0);
183
+ i0.ɵɵelementStart(0, "h3", 3);
180
184
  i0.ɵɵtext(1);
181
185
  i0.ɵɵpipe(2, "translate");
182
186
  i0.ɵɵelementEnd();
183
- i0.ɵɵrepeaterCreate(3, SubscriptionComponent_Conditional_2_For_4_Template, 7, 10, "div", 6, i0.ɵɵrepeaterTrackByIndex);
187
+ i0.ɵɵrepeaterCreate(3, SubscriptionComponent_Conditional_2_For_4_Template, 7, 11, "div", 9, i0.ɵɵrepeaterTrackByIndex);
184
188
  } if (rf & 2) {
185
189
  const ctx_r4 = i0.ɵɵnextContext();
186
190
  i0.ɵɵadvance();
@@ -188,8 +192,29 @@ function SubscriptionComponent_Conditional_2_Template(rf, ctx) { if (rf & 1) {
188
192
  i0.ɵɵadvance(2);
189
193
  i0.ɵɵrepeater(ctx_r4.visibleQuotas());
190
194
  } }
195
+ function SubscriptionComponent_Conditional_4_Template(rf, ctx) { if (rf & 1) {
196
+ i0.ɵɵelementStart(0, "a", 1);
197
+ i0.ɵɵtext(1);
198
+ i0.ɵɵpipe(2, "translate");
199
+ i0.ɵɵelementEnd();
200
+ } if (rf & 2) {
201
+ i0.ɵɵadvance();
202
+ i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(2, 1, "SUBSCRIPTION.MANAGE"), " ");
203
+ } }
204
+ function SubscriptionComponent_Conditional_5_Template(rf, ctx) { if (rf & 1) {
205
+ i0.ɵɵelementStart(0, "a", 2);
206
+ i0.ɵɵtext(1);
207
+ i0.ɵɵpipe(2, "translate");
208
+ i0.ɵɵelementEnd();
209
+ } if (rf & 2) {
210
+ const ctx_r4 = i0.ɵɵnextContext();
211
+ i0.ɵɵattribute("href", ctx_r4.contactUsUrl(), i0.ɵɵsanitizeUrl);
212
+ i0.ɵɵadvance();
213
+ i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(2, 2, "SUBSCRIPTION.CONTACT"));
214
+ } }
191
215
  export class SubscriptionComponent {
192
216
  constructor() {
217
+ this.#chargebeeMountService = inject(ChargebeeMountService);
193
218
  /** Parsed user token to get user related info */
194
219
  this.token = input.required();
195
220
  /** Current user plan that app has selected */
@@ -197,15 +222,24 @@ export class SubscriptionComponent {
197
222
  /** Quota usage */
198
223
  this.quota = input.required();
199
224
  this.visibleQuotaTypes = input();
225
+ this.contactUsUrl = input();
226
+ this.chargebeeSettings = input();
200
227
  this.visibleQuotas = computed(() => {
201
228
  const quota = this.quota();
202
229
  if (!quota?.usage) {
203
230
  return [];
204
231
  }
232
+ let filtered;
205
233
  if (!this.visibleQuotaTypes()) {
206
- return quota.usage;
234
+ filtered = quota.usage;
235
+ }
236
+ else {
237
+ filtered = quota.usage.filter(quota => this.visibleQuotaTypes()?.includes(quota.quotaType));
207
238
  }
208
- return quota.usage.filter(quota => this.visibleQuotaTypes()?.includes(quota.quotaType));
239
+ const visibleQuotas = filtered.map(quota => {
240
+ return this.#convertUsageToDisplayQuota(quota);
241
+ });
242
+ return visibleQuotas;
209
243
  });
210
244
  this.subscriptionStates = SUBSCRIPTION_STATE;
211
245
  this.subscriptionState = computed(() => {
@@ -225,18 +259,92 @@ export class SubscriptionComponent {
225
259
  }
226
260
  });
227
261
  }
262
+ #chargebeeMountService;
263
+ ngOnInit() {
264
+ this.#mountChargeBeeScript();
265
+ }
266
+ #mountChargeBeeScript() {
267
+ const chargebeeSettings = this.chargebeeSettings();
268
+ if (!chargebeeSettings?.site || !chargebeeSettings.script) {
269
+ return;
270
+ }
271
+ if (!this.#chargebeeMountService.chargebeeMounted) {
272
+ const el = document.createElement('script');
273
+ el.onload = () => {
274
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
275
+ const windowObj = window;
276
+ windowObj.Chargebee.init({
277
+ site: chargebeeSettings.site
278
+ });
279
+ windowObj.Chargebee.registerAgain();
280
+ this.#chargebeeMountService.chargebeeMounted = true;
281
+ };
282
+ el.setAttribute('src', chargebeeSettings.script);
283
+ document.head.appendChild(el);
284
+ }
285
+ else {
286
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
287
+ const windowObj = window;
288
+ windowObj.Chargebee.registerAgain();
289
+ }
290
+ }
291
+ #convertUsageToDisplayQuota(quota) {
292
+ // int max in c#
293
+ const unlimitedBenchmark = 2147483647;
294
+ const used = quota.quotaLimit - quota.quotaRemaining;
295
+ let convertedLimit = quota.quotaLimit.toString();
296
+ let convertedUsed = used.toString();
297
+ const isUnlimited = unlimitedBenchmark <= quota.quotaLimit;
298
+ const percentUsed = Math.round(((quota.quotaLimit - quota.quotaRemaining) / quota.quotaLimit) * 100);
299
+ switch (quota.quotaType) {
300
+ case QuotaType.ASR_FILE_LENGTH_SECONDS:
301
+ case QuotaType.ONLINE_ASR_USED_SECONDS:
302
+ convertedLimit = Math.ceil(quota.quotaLimit / 60).toString();
303
+ convertedUsed = Math.round(used / 60).toString();
304
+ break;
305
+ case QuotaType.ASR_FILE_SIZE_KB:
306
+ convertedLimit = this.#formatBytes(quota.quotaLimit * 1024);
307
+ convertedUsed = this.#formatBytes(used * 1024);
308
+ break;
309
+ case QuotaType.LLM_REQUESTS:
310
+ break;
311
+ }
312
+ return {
313
+ ...quota,
314
+ convertedLimit,
315
+ convertedUsed,
316
+ isUnlimited,
317
+ percentUsed
318
+ };
319
+ }
320
+ #formatBytes(bytes, decimals = 0) {
321
+ if (!+bytes)
322
+ return '0 Bytes';
323
+ const k = 1024;
324
+ const dm = decimals < 0 ? 0 : decimals;
325
+ const sizes = ['Bytes', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'];
326
+ const i = Math.floor(Math.log(bytes) / Math.log(k));
327
+ return `${parseFloat((bytes / Math.pow(k, i)).toFixed(dm))} ${sizes[i]}`;
328
+ }
228
329
  static { this.ɵfac = function SubscriptionComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || SubscriptionComponent)(); }; }
229
- static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: SubscriptionComponent, selectors: [["lib-subscription"]], inputs: { token: [1, "token"], subscription: [1, "subscription"], quota: [1, "quota"], visibleQuotaTypes: [1, "visibleQuotaTypes"] }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 3, vars: 3, consts: [[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) {
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) {
230
331
  i0.ɵɵtemplate(0, SubscriptionComponent_Conditional_0_Template, 20, 11)(1, SubscriptionComponent_Conditional_1_Template, 15, 8)(2, SubscriptionComponent_Conditional_2_Template, 5, 3);
332
+ i0.ɵɵelementStart(3, "div", 0);
333
+ i0.ɵɵtemplate(4, SubscriptionComponent_Conditional_4_Template, 3, 3, "a", 1)(5, SubscriptionComponent_Conditional_5_Template, 3, 4, "a", 2);
334
+ i0.ɵɵelementEnd();
231
335
  } if (rf & 2) {
232
336
  i0.ɵɵconditional(ctx.token() ? 0 : -1);
233
337
  i0.ɵɵadvance();
234
338
  i0.ɵɵconditional(ctx.subscription() ? 1 : -1);
235
339
  i0.ɵɵadvance();
236
340
  i0.ɵɵconditional(ctx.visibleQuotas().length ? 2 : -1);
341
+ i0.ɵɵadvance(2);
342
+ i0.ɵɵconditional(ctx.chargebeeSettings() ? 4 : -1);
343
+ i0.ɵɵadvance();
344
+ i0.ɵɵconditional(ctx.contactUsUrl() ? 5 : -1);
237
345
  } }, dependencies: [TranslatePipe,
238
346
  DatePipe,
239
- MatProgressBarModule, i1.MatProgressBar, CommonModule, i2.UpperCasePipe], styles: ["[_nghost-%COMP%]{display:block}mat-card[_ngcontent-%COMP%]{margin:1.5rem}.subscription-container[_ngcontent-%COMP%]:not(.mobile){margin:16px 32px}.subscription-section-title[_ngcontent-%COMP%]{margin:32px 0 18px}.subscription-data-row[_ngcontent-%COMP%]{border-bottom:2px solid var(--base-70);margin-bottom:18px;flex-direction:row;display:flex}.subscription-data[_ngcontent-%COMP%]{color:var(--base-30);word-wrap:break-word;margin-left:.5rem}.subscription-limit-wrapper[_ngcontent-%COMP%], .subscription-limit[_ngcontent-%COMP%]{margin-top:16px}.subscription-actions-wrapper[_ngcontent-%COMP%]{padding:32px 0 18px}.subscription-manage-link[_ngcontent-%COMP%]{text-decoration:none}.subscription-container[_ngcontent-%COMP%]:not(.mobile, .empty)[_ngcontent-%COMP%]{width:75%}.subscription-label[_ngcontent-%COMP%]:not(.mobile, .empty)[_ngcontent-%COMP%]{width:35%}.subscription-data[_ngcontent-%COMP%]:not(.mobile, .empty)[_ngcontent-%COMP%]{width:65%}.untranslated-files-disclaimer[_ngcontent-%COMP%]{margin-top:16px;margin-bottom:10px;color:var(--base-40)}.no-subscription-message[_ngcontent-%COMP%]{margin-top:32px;color:var(--base-40)}.contact-sales-btn[_ngcontent-%COMP%]{text-align:center}.contact-sales-btn[_ngcontent-%COMP%]:hover{text-decoration:none}"] }); }
347
+ MatProgressBarModule, i1.MatProgressBar, CommonModule, i2.UpperCasePipe, MatButtonModule, i3.MatAnchor], styles: ["[_nghost-%COMP%]{display:block}mat-card[_ngcontent-%COMP%]{margin:1.5rem}.subscription-container[_ngcontent-%COMP%]:not(.mobile){margin:16px 32px}.subscription-section-title[_ngcontent-%COMP%]{margin:32px 0 18px}.subscription-data-row[_ngcontent-%COMP%]{border-bottom:2px solid var(--base-70);margin-bottom:18px;flex-direction:row;display:flex}.subscription-data[_ngcontent-%COMP%]{color:var(--base-30);word-wrap:break-word;margin-left:.5rem}.subscription-limit-wrapper[_ngcontent-%COMP%], .subscription-limit[_ngcontent-%COMP%]{margin-top:16px}.subscription-actions-wrapper[_ngcontent-%COMP%]{padding:32px 0 18px;display:flex;flex-direction:row;gap:24px}.subscription-manage-link[_ngcontent-%COMP%]{text-decoration:none}.subscription-container[_ngcontent-%COMP%]:not(.mobile, .empty)[_ngcontent-%COMP%]{width:75%}.subscription-label[_ngcontent-%COMP%]:not(.mobile, .empty)[_ngcontent-%COMP%]{width:35%}.subscription-data[_ngcontent-%COMP%]:not(.mobile, .empty)[_ngcontent-%COMP%]{width:65%}.untranslated-files-disclaimer[_ngcontent-%COMP%]{margin-top:16px;margin-bottom:10px;color:var(--base-40)}.no-subscription-message[_ngcontent-%COMP%]{margin-top:32px;color:var(--base-40)}.contact-sales-btn[_ngcontent-%COMP%]{text-align:center}.contact-sales-btn[_ngcontent-%COMP%]:hover{text-decoration:none}"] }); }
240
348
  }
241
349
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SubscriptionComponent, [{
242
350
  type: Component,
@@ -244,8 +352,9 @@ export class SubscriptionComponent {
244
352
  TranslatePipe,
245
353
  DatePipe,
246
354
  MatProgressBarModule,
247
- CommonModule
248
- ], 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.quotaLimit - currentQuota.quotaRemaining) / currentQuota.quotaLimit) * 100\"></mat-progress-bar>\r\n <div class=\"subscription-limit\">\r\n <span class=\"text-l-semi-bold\">\r\n {{ \"QUOTA.\" + (currentQuota.quotaType.toString() | uppercase) | translate: { used: currentQuota.quotaLimit - currentQuota.quotaRemaining, limit: currentQuota.quotaLimit } }}\r\n </span>\r\n </div>\r\n </div>\r\n }\r\n}\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}.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"] }]
355
+ CommonModule,
356
+ 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"] }]
249
358
  }], null, null); })();
250
- (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(SubscriptionComponent, { className: "SubscriptionComponent", filePath: "lib\\subscription\\subscription.component.ts", lineNumber: 22 }); })();
251
- //# 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":"AAAA,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAI3D,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AACzD,OAAO,EAAE,kBAAkB,EAAE,MAAM,kCAAkC,CAAC;AACtE,OAAO,EAAE,oBAAoB,EAAE,MAAM,gCAAgC,CAAC;;;;;;;ICLpE,kBAAyB;IAEvB,6BAAwD;IAAA,YAA0C;;IAAA,iBAAK;IAInG,AADF,AADF,8BAAmC,aACD,cACV;IAAA,YAA2C;;IACjE,AADiE,iBAAO,EAClE;IAGJ,AADF,8BAA+B,YACvB;IAAA,aAAoB;IAE9B,AADE,AAD4B,iBAAO,EAC7B,EACF;IAIF,AADF,AADF,+BAAmC,cACD,eACV;IAAA,aAA4C;;IAClE,AADkE,iBAAO,EACnE;IAGJ,AADF,+BAA+B,YACvB;IAAA,aAAqB;IAE/B,AADE,AAD6B,iBAAO,EAC9B,EACF;;yBAtBS,0BAAO;IAEkC,eAA0C;IAA1C,oEAA0C;IAI1E,eAA2C;IAA3C,qEAA2C;IAIzD,eAAoB;IAApB,uCAAoB;IAMN,eAA4C;IAA5C,uEAA4C;IAI1D,eAAqB;IAArB,wCAAqB;;;IAoBrB,4BAAM;IAAC,YAA+G;;;IAAA,iBAAO;;;;IAAtH,cAA+G;IAA/G,uLAA+G;;;IAIpH,4BAAM;IAAC,YAAyG;;;IAAA,iBAAO;;;;IAAhH,cAAyG;IAAzG,iLAAyG;;;IADlH,kGAAiC;;;;IAAjC,yDAEC;;;IAGH,YACA;;;;;;IADA,iLACA;;;IAUN,AADF,AADF,8BAAmC,aACD,cACV;IAAA,YAA4D;;IAClF,AADkF,iBAAO,EACnF;IAEN,8BAA+B;IAC7B,6BAAc;IACZ,4BAAM;IAAA,YAAoD;;IAAA,iBAAO;;IAGrE,AADA,iBAAM,EACA;;;;IARgB,eAA4D;IAA5D,sFAA4D;IAKxE,eAAoD;IAApD,wFAAoD;;;IActD,4BAAM;IAAA,YAAyE;IAAA,iBAAO;;;;;;IAAhF,cAAyE;IAAzE,mHAAyE;;;IALnF,AADF,AADF,8BAAkD,aAChB,cACV;IAAA,YAAkD;;IACxE,AADwE,iBAAO,EACzE;IAEN,8BAA+B;IAC7B,wIAEC;IAEL,AADE,iBAAM,EACF;;;;IARkB,eAAkD;IAAlD,4EAAkD;IAItE,eAEC;IAFD,4CAEC;;;IArDP,kBAA0C;IAItC,AADF,AADF,8BAAkD,aAChB,cACV;IAAA,YAA2D;;IACjF,AADiF,iBAAO,EAClF;IAEN,8BAA+B;IAC7B,6BAAc;IACZ,4BAAM;IACJ,YAEA;IASE,AALA,AAHA,qFAAgC,gEAGG,gEAKD;IAItC,iBAAO;;IAGb,AADE,iBAAM,EACF;IAgBN,AAdA,+FAAiC,iFAcO;;;;mCA5CxC,cAA2B,qBAAc,CAAC;IAIlB,eAA2D;IAA3D,qFAA2D;IAM3E,eAEA;IAFA,4HAEA;IAAA,cAYC;IAZD,6MAYC;IAMT,eAYC;IAZD,0DAYC;IAED,cAYC;IAZD,iHAYC;;;IAOC,8BAAwC;IACtC,sCAAyI;IAEvI,AADF,8BAAgC,cACC;IAC7B,YACF;;;IAEJ,AADE,AADE,iBAAO,EACH,EACF;;;IANc,cAAmG;IAAnG,wHAAmG;IAGjH,eACF;IADE,iPACF;;;IARN,6BAAwD;IAAA,YAAuC;;IAAA,iBAAK;IAEpG,sHASC;;;IAXuD,cAAuC;IAAvC,iEAAuC;IAE/F,eASC;IATD,cAAA,sBAAe,CASd;;AD9EH,MAAM,OAAO,qBAAqB;IAZlC;QAaE,iDAAiD;QACxC,UAAK,GAAG,KAAK,CAAC,QAAQ,EAAwB,CAAC;QACxD,8CAA8C;QACrC,iBAAY,GAAG,KAAK,CAAC,QAAQ,EAAgC,CAAC;QACvE,kBAAkB;QACT,UAAK,GAAG,KAAK,CAAC,QAAQ,EAA6B,CAAC;QAEpD,sBAAiB,GAAG,KAAK,EAAe,CAAC;QAEzC,kBAAa,GAAG,QAAQ,CAAC,GAAG,EAAE;YACrC,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;YAC3B,IAAI,CAAC,KAAK,EAAE,KAAK,EAAE,CAAC;gBAClB,OAAO,EAAE,CAAC;YACZ,CAAC;YAED,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE,EAAE,CAAC;gBAC9B,OAAO,KAAK,CAAC,KAAK,CAAC;YACrB,CAAC;YAED,OAAO,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,iBAAiB,EAAE,EAAE,QAAQ,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC;QAC1F,CAAC,CAAC,CAAA;QAEO,uBAAkB,GAAG,kBAAkB,CAAC;QAExC,sBAAiB,GAAG,QAAQ,CAAC,GAAG,EAAE;YACzC,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;YACzC,IAAI,CAAC,YAAY,EAAE,CAAC;gBAClB,OAAO,kBAAkB,CAAC,IAAI,CAAC;YACjC,CAAC;YAED,IAAI,YAAY,CAAC,OAAO,EAAE,CAAC;gBACzB,OAAO,kBAAkB,CAAC,KAAK,CAAC;YAClC,CAAC;YAGD,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC;YACvB,IAAI,CAAC,YAAY,CAAC,OAAO,IAAI,IAAI,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,GAAG,GAAG,EAAE,CAAC;gBAClE,OAAO,kBAAkB,CAAC,MAAM,CAAC;YACnC,CAAC;iBAAM,CAAC;gBACN,OAAO,kBAAkB,CAAC,KAAK,CAAC;YAClC,CAAC;QACH,CAAC,CAAC,CAAC;KACJ;sHA3CY,qBAAqB;oEAArB,qBAAqB;YCkElC,AA5DA,AA3BA,sEAAa,wDA2BO,uDA4DQ;;YAvF5B,sCAyBC;YAED,cA0DC;YA1DD,6CA0DC;YAED,cAaC;YAbD,qDAaC;4BDvFG,aAAa;YACb,QAAQ;YACR,oBAAoB,qBACpB,YAAY;;iFAKH,qBAAqB;cAZjC,SAAS;2BACE,kBAAkB,cAChB,IAAI,WACP;oBACP,aAAa;oBACb,QAAQ;oBACR,oBAAoB;oBACpB,YAAY;iBACb;;kFAIU,qBAAqB","sourcesContent":["import { Component, computed, input } from '@angular/core';\r\nimport { QuotaResponse, QuotaType } 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 { TranslatePipe } from '@ngx-translate/core';\r\nimport { CommonModule, DatePipe } from '@angular/common';\r\nimport { SUBSCRIPTION_STATE } from './models/subscription-state.enum';\r\nimport { MatProgressBarModule } from '@angular/material/progress-bar';\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  ],\r\n  templateUrl: './subscription.component.html',\r\n  styleUrl: './subscription.component.scss'\r\n})\r\nexport class SubscriptionComponent {\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\r\n  readonly visibleQuotaTypes = input<QuotaType[]>();\r\n\r\n  readonly visibleQuotas = computed(() => {\r\n    const quota = this.quota();\r\n    if (!quota?.usage) {\r\n      return [];\r\n    }\r\n\r\n    if (!this.visibleQuotaTypes()) {\r\n      return quota.usage;\r\n    }\r\n\r\n    return quota.usage.filter(quota => this.visibleQuotaTypes()?.includes(quota.quotaType));\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","@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.quotaLimit - currentQuota.quotaRemaining) / currentQuota.quotaLimit) * 100\"></mat-progress-bar>\r\n      <div class=\"subscription-limit\">\r\n        <span class=\"text-l-semi-bold\">\r\n          {{ \"QUOTA.\" + (currentQuota.quotaType.toString() | uppercase) | translate: { used: currentQuota.quotaLimit - currentQuota.quotaRemaining, limit: currentQuota.quotaLimit } }}\r\n        </span>\r\n      </div>\r\n    </div>\r\n  }\r\n}\r\n"]}
359
+ (() => { (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"]}