@onecx/angular-accelerator 4.13.0 → 4.13.2
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/assets/i18n/de.json +13 -0
- package/assets/i18n/en.json +13 -0
- package/esm2020/lib/angular-accelerator.module.mjs +2 -42
- package/esm2020/lib/pipes/ocxtimeago.pipe.mjs +98 -6
- package/fesm2015/onecx-angular-accelerator.mjs +96 -76
- package/fesm2015/onecx-angular-accelerator.mjs.map +1 -1
- package/fesm2020/onecx-angular-accelerator.mjs +96 -76
- package/fesm2020/onecx-angular-accelerator.mjs.map +1 -1
- package/lib/pipes/ocxtimeago.pipe.d.ts +12 -2
- package/package.json +2 -3
- package/esm2020/lib/utils/ocxtimeagointl.utils.mjs +0 -34
- package/lib/utils/ocxtimeagointl.utils.d.ts +0 -9
package/assets/i18n/de.json
CHANGED
|
@@ -126,5 +126,18 @@
|
|
|
126
126
|
"HORIZONTAL_BAR": "Zu horizontalem Balkendiagramm wechseln",
|
|
127
127
|
"VERTICAL_BAR": "Zu vertikalem Balkendiagramm wechseln"
|
|
128
128
|
}
|
|
129
|
+
},
|
|
130
|
+
"OCX_TIMEAGO": {
|
|
131
|
+
"A_DAY_AGO": "vor einem Tag",
|
|
132
|
+
"A_FEW_SECONDS_AGO": "vor ein paar Sekunden",
|
|
133
|
+
"AN_HOUR_AGO": "vor einer Stunde",
|
|
134
|
+
"A_MINUTE_AGO": "vor einer Minute",
|
|
135
|
+
"A_MONAT_AGO": "vor einem Monat",
|
|
136
|
+
"A_YEAR_AGO": "vor einem Jahr",
|
|
137
|
+
"DAYS_AGO": "vor {{days}} Tagen",
|
|
138
|
+
"HOURS_AGO": "vor {{hours}} Stunden",
|
|
139
|
+
"MINUTES_AGO": "vor {{minutes}} Minuten",
|
|
140
|
+
"MONTHS_AGO": "vor {{months}} Monaten",
|
|
141
|
+
"YEARS_AGO": "vor {{years}} Jahren"
|
|
129
142
|
}
|
|
130
143
|
}
|
package/assets/i18n/en.json
CHANGED
|
@@ -126,5 +126,18 @@
|
|
|
126
126
|
"HORIZONTAL_BAR": "Switch to horizontal bar chart",
|
|
127
127
|
"VERTICAL_BAR": "Switch to vertical bar chart"
|
|
128
128
|
}
|
|
129
|
+
},
|
|
130
|
+
"OCX_TIMEAGO": {
|
|
131
|
+
"A_DAY_AGO": "a day ago",
|
|
132
|
+
"A_FEW_SECONDS_AGO": "a few seconds ago",
|
|
133
|
+
"AN_HOUR_AGO": "an hour ago",
|
|
134
|
+
"A_MINUTE_AGO": "a minute ago",
|
|
135
|
+
"A_MONTH_AGO": "a month ago",
|
|
136
|
+
"A_YEAR_AGO": "a year ago",
|
|
137
|
+
"DAYS_AGO": "{{days}} days ago",
|
|
138
|
+
"HOURS_AGO": "{{hours}} hours ago",
|
|
139
|
+
"MINUTES_AGO": "{{minutes}} minutes ago",
|
|
140
|
+
"MONTHS_AGO": "{{months}} months ago",
|
|
141
|
+
"YEARS_AGO": "{{years}} years ago"
|
|
129
142
|
}
|
|
130
143
|
}
|
|
@@ -1,10 +1,9 @@
|
|
|
1
1
|
import { CommonModule } from '@angular/common';
|
|
2
|
-
import { CUSTOM_ELEMENTS_SCHEMA, LOCALE_ID, NgModule
|
|
2
|
+
import { CUSTOM_ELEMENTS_SCHEMA, LOCALE_ID, NgModule } from '@angular/core';
|
|
3
3
|
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
4
4
|
import { RouterModule } from '@angular/router';
|
|
5
5
|
import { HttpClient } from '@angular/common/http';
|
|
6
6
|
import { MissingTranslationHandler, TranslateLoader, TranslateModule, } from '@ngx-translate/core';
|
|
7
|
-
import { TimeagoClock, TimeagoCustomFormatter, TimeagoDefaultClock, TimeagoFormatter, TimeagoIntl, TimeagoModule, } from 'ngx-timeago';
|
|
8
7
|
import { AppStateService, UserService } from '@onecx/angular-integration-interface';
|
|
9
8
|
import { AngularAcceleratorPrimeNgModule } from './angular-accelerator-primeng.module';
|
|
10
9
|
import { ColumnGroupSelectionComponent } from './components/column-group-selection/column-group-selection.component';
|
|
@@ -24,7 +23,6 @@ import { DynamicPipe } from './pipes/dynamic.pipe';
|
|
|
24
23
|
import { IfPermissionDirective } from './directives/if-permission.directive';
|
|
25
24
|
import { IfBreakpointDirective } from './directives/if-breakpoint.directive';
|
|
26
25
|
import { OcxTimeAgoPipe } from './pipes/ocxtimeago.pipe';
|
|
27
|
-
import { OcxTimeagoIntl } from './utils/ocxtimeagointl.utils';
|
|
28
26
|
import { createTranslateLoader } from './utils/create-translate-loader.utils';
|
|
29
27
|
import { TranslationCacheService } from './services/translation-cache.service';
|
|
30
28
|
import { SrcDirective } from './directives/src.directive';
|
|
@@ -83,25 +81,6 @@ AngularAcceleratorModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0"
|
|
|
83
81
|
},
|
|
84
82
|
deps: [UserService],
|
|
85
83
|
},
|
|
86
|
-
{
|
|
87
|
-
provide: TimeagoIntl,
|
|
88
|
-
useFactory: (userService) => {
|
|
89
|
-
return new OcxTimeagoIntl(userService);
|
|
90
|
-
},
|
|
91
|
-
deps: [UserService],
|
|
92
|
-
},
|
|
93
|
-
importProvidersFrom(TimeagoModule),
|
|
94
|
-
{
|
|
95
|
-
provide: TimeagoFormatter,
|
|
96
|
-
useFactory: (TimeagoIntl) => {
|
|
97
|
-
return new TimeagoCustomFormatter(TimeagoIntl);
|
|
98
|
-
},
|
|
99
|
-
deps: [TimeagoIntl],
|
|
100
|
-
},
|
|
101
|
-
{
|
|
102
|
-
provide: TimeagoClock,
|
|
103
|
-
useClass: TimeagoDefaultClock,
|
|
104
|
-
},
|
|
105
84
|
], imports: [CommonModule,
|
|
106
85
|
AngularAcceleratorPrimeNgModule,
|
|
107
86
|
TranslateModule.forRoot({
|
|
@@ -169,25 +148,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
169
148
|
},
|
|
170
149
|
deps: [UserService],
|
|
171
150
|
},
|
|
172
|
-
{
|
|
173
|
-
provide: TimeagoIntl,
|
|
174
|
-
useFactory: (userService) => {
|
|
175
|
-
return new OcxTimeagoIntl(userService);
|
|
176
|
-
},
|
|
177
|
-
deps: [UserService],
|
|
178
|
-
},
|
|
179
|
-
importProvidersFrom(TimeagoModule),
|
|
180
|
-
{
|
|
181
|
-
provide: TimeagoFormatter,
|
|
182
|
-
useFactory: (TimeagoIntl) => {
|
|
183
|
-
return new TimeagoCustomFormatter(TimeagoIntl);
|
|
184
|
-
},
|
|
185
|
-
deps: [TimeagoIntl],
|
|
186
|
-
},
|
|
187
|
-
{
|
|
188
|
-
provide: TimeagoClock,
|
|
189
|
-
useClass: TimeagoDefaultClock,
|
|
190
|
-
},
|
|
191
151
|
],
|
|
192
152
|
exports: [
|
|
193
153
|
ColumnGroupSelectionComponent,
|
|
@@ -211,4 +171,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
211
171
|
schemas: [CUSTOM_ELEMENTS_SCHEMA],
|
|
212
172
|
}]
|
|
213
173
|
}] });
|
|
214
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-accelerator.module.js","sourceRoot":"","sources":["../../../../../libs/angular-accelerator/src/lib/angular-accelerator.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common'\nimport { CUSTOM_ELEMENTS_SCHEMA, LOCALE_ID, NgModule, importProvidersFrom } from '@angular/core'\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms'\nimport { RouterModule } from '@angular/router'\nimport { HttpClient } from '@angular/common/http'\nimport {\n  MissingTranslationHandler,\n  MissingTranslationHandlerParams,\n  TranslateLoader,\n  TranslateModule,\n} from '@ngx-translate/core'\nimport {\n  TimeagoClock,\n  TimeagoCustomFormatter,\n  TimeagoDefaultClock,\n  TimeagoFormatter,\n  TimeagoIntl,\n  TimeagoModule,\n} from 'ngx-timeago'\n\nimport { AppStateService, UserService } from '@onecx/angular-integration-interface'\n\nimport { AngularAcceleratorPrimeNgModule } from './angular-accelerator-primeng.module'\nimport { ColumnGroupSelectionComponent } from './components/column-group-selection/column-group-selection.component'\nimport { CustomGroupColumnSelectorComponent } from './components/custom-group-column-selector/custom-group-column-selector.component'\nimport { DataLayoutSelectionComponent } from './components/data-layout-selection/data-layout-selection.component'\nimport { DataListGridSortingComponent } from './components/data-list-grid-sorting/data-list-grid-sorting.component'\nimport { DataListGridComponent } from './components/data-list-grid/data-list-grid.component'\nimport { DataTableComponent } from './components/data-table/data-table.component'\nimport { DataViewComponent } from './components/data-view/data-view.component'\nimport { InteractiveDataViewComponent } from './components/interactive-data-view/interactive-data-view.component'\nimport { SearchConfigComponent } from './components/search-config/search-config.component'\nimport { PageHeaderComponent } from './components/page-header/page-header.component'\nimport { SearchHeaderComponent } from './components/search-header/search-header.component'\nimport { GroupByCountDiagramComponent } from './components/group-by-count-diagram/group-by-count-diagram.component'\nimport { DiagramComponent } from './components/diagram/diagram.component'\nimport { DynamicPipe } from './pipes/dynamic.pipe'\nimport { IfPermissionDirective } from './directives/if-permission.directive'\nimport { IfBreakpointDirective } from './directives/if-breakpoint.directive'\nimport { OcxTimeAgoPipe } from './pipes/ocxtimeago.pipe'\nimport { OcxTimeagoIntl } from './utils/ocxtimeagointl.utils'\nimport { createTranslateLoader } from './utils/create-translate-loader.utils'\nimport { TranslationCacheService } from './services/translation-cache.service'\nimport { SrcDirective } from './directives/src.directive'\n\nexport class AngularAcceleratorMissingTranslationHandler implements MissingTranslationHandler {\n  handle(params: MissingTranslationHandlerParams) {\n    console.log(`Missing translation for ${params.key}`, params)\n    return params.key\n  }\n}\n\n@NgModule({\n  imports: [\n    CommonModule,\n    AngularAcceleratorPrimeNgModule,\n    TranslateModule.forRoot({\n      isolate: true,\n      loader: {\n        provide: TranslateLoader,\n        useFactory: createTranslateLoader,\n        deps: [HttpClient, AppStateService, TranslationCacheService],\n      },\n      missingTranslationHandler: {\n        provide: MissingTranslationHandler,\n        useClass: AngularAcceleratorMissingTranslationHandler,\n      },\n    }),\n    FormsModule,\n    RouterModule,\n    ReactiveFormsModule,\n  ],\n  declarations: [\n    ColumnGroupSelectionComponent,\n    CustomGroupColumnSelectorComponent,\n    DataLayoutSelectionComponent,\n    DataListGridSortingComponent,\n    DataListGridComponent,\n    DataTableComponent,\n    DataViewComponent,\n    InteractiveDataViewComponent,\n    SearchConfigComponent,\n    PageHeaderComponent,\n    DynamicPipe,\n    SearchHeaderComponent,\n    DiagramComponent,\n    GroupByCountDiagramComponent,\n    IfPermissionDirective,\n    IfBreakpointDirective,\n    SrcDirective,\n    OcxTimeAgoPipe,\n  ],\n  providers: [\n    {\n      provide: LOCALE_ID,\n      useFactory: (UserService: UserService) => {\n        return UserService.lang$.getValue()\n      },\n      deps: [UserService],\n    },\n    {\n      provide: TimeagoIntl,\n      useFactory: (userService: UserService) => {\n        return new OcxTimeagoIntl(userService)\n      },\n      deps: [UserService],\n    },\n    importProvidersFrom(TimeagoModule),\n    {\n      provide: TimeagoFormatter,\n      useFactory: (TimeagoIntl: TimeagoIntl) => {\n        return new TimeagoCustomFormatter(TimeagoIntl)\n      },\n      deps: [TimeagoIntl],\n    },\n    {\n      provide: TimeagoClock,\n      useClass: TimeagoDefaultClock,\n    },\n  ],\n  exports: [\n    ColumnGroupSelectionComponent,\n    CustomGroupColumnSelectorComponent,\n    DataLayoutSelectionComponent,\n    DataListGridComponent,\n    DataTableComponent,\n    DataViewComponent,\n    InteractiveDataViewComponent,\n    SearchConfigComponent,\n    PageHeaderComponent,\n    SearchHeaderComponent,\n    DiagramComponent,\n    GroupByCountDiagramComponent,\n    IfPermissionDirective,\n    IfBreakpointDirective,\n    SrcDirective,\n    OcxTimeAgoPipe,\n    // DataListGridSortingComponent,\n  ],\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class AngularAcceleratorModule {}\n"]}
|
|
174
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"angular-accelerator.module.js","sourceRoot":"","sources":["../../../../../libs/angular-accelerator/src/lib/angular-accelerator.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common'\nimport { CUSTOM_ELEMENTS_SCHEMA, LOCALE_ID, NgModule } from '@angular/core'\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms'\nimport { RouterModule } from '@angular/router'\nimport { HttpClient } from '@angular/common/http'\nimport {\n  MissingTranslationHandler,\n  MissingTranslationHandlerParams,\n  TranslateLoader,\n  TranslateModule,\n} from '@ngx-translate/core'\n\nimport { AppStateService, UserService } from '@onecx/angular-integration-interface'\n\nimport { AngularAcceleratorPrimeNgModule } from './angular-accelerator-primeng.module'\nimport { ColumnGroupSelectionComponent } from './components/column-group-selection/column-group-selection.component'\nimport { CustomGroupColumnSelectorComponent } from './components/custom-group-column-selector/custom-group-column-selector.component'\nimport { DataLayoutSelectionComponent } from './components/data-layout-selection/data-layout-selection.component'\nimport { DataListGridSortingComponent } from './components/data-list-grid-sorting/data-list-grid-sorting.component'\nimport { DataListGridComponent } from './components/data-list-grid/data-list-grid.component'\nimport { DataTableComponent } from './components/data-table/data-table.component'\nimport { DataViewComponent } from './components/data-view/data-view.component'\nimport { InteractiveDataViewComponent } from './components/interactive-data-view/interactive-data-view.component'\nimport { SearchConfigComponent } from './components/search-config/search-config.component'\nimport { PageHeaderComponent } from './components/page-header/page-header.component'\nimport { SearchHeaderComponent } from './components/search-header/search-header.component'\nimport { GroupByCountDiagramComponent } from './components/group-by-count-diagram/group-by-count-diagram.component'\nimport { DiagramComponent } from './components/diagram/diagram.component'\nimport { DynamicPipe } from './pipes/dynamic.pipe'\nimport { IfPermissionDirective } from './directives/if-permission.directive'\nimport { IfBreakpointDirective } from './directives/if-breakpoint.directive'\nimport { OcxTimeAgoPipe } from './pipes/ocxtimeago.pipe'\nimport { createTranslateLoader } from './utils/create-translate-loader.utils'\nimport { TranslationCacheService } from './services/translation-cache.service'\nimport { SrcDirective } from './directives/src.directive'\n\nexport class AngularAcceleratorMissingTranslationHandler implements MissingTranslationHandler {\n  handle(params: MissingTranslationHandlerParams) {\n    console.log(`Missing translation for ${params.key}`, params)\n    return params.key\n  }\n}\n\n@NgModule({\n  imports: [\n    CommonModule,\n    AngularAcceleratorPrimeNgModule,\n    TranslateModule.forRoot({\n      isolate: true,\n      loader: {\n        provide: TranslateLoader,\n        useFactory: createTranslateLoader,\n        deps: [HttpClient, AppStateService, TranslationCacheService],\n      },\n      missingTranslationHandler: {\n        provide: MissingTranslationHandler,\n        useClass: AngularAcceleratorMissingTranslationHandler,\n      },\n    }),\n    FormsModule,\n    RouterModule,\n    ReactiveFormsModule,\n  ],\n  declarations: [\n    ColumnGroupSelectionComponent,\n    CustomGroupColumnSelectorComponent,\n    DataLayoutSelectionComponent,\n    DataListGridSortingComponent,\n    DataListGridComponent,\n    DataTableComponent,\n    DataViewComponent,\n    InteractiveDataViewComponent,\n    SearchConfigComponent,\n    PageHeaderComponent,\n    DynamicPipe,\n    SearchHeaderComponent,\n    DiagramComponent,\n    GroupByCountDiagramComponent,\n    IfPermissionDirective,\n    IfBreakpointDirective,\n    SrcDirective,\n    OcxTimeAgoPipe,\n  ],\n  providers: [\n    {\n      provide: LOCALE_ID,\n      useFactory: (UserService: UserService) => {\n        return UserService.lang$.getValue()\n      },\n      deps: [UserService],\n    },\n  ],\n  exports: [\n    ColumnGroupSelectionComponent,\n    CustomGroupColumnSelectorComponent,\n    DataLayoutSelectionComponent,\n    DataListGridComponent,\n    DataTableComponent,\n    DataViewComponent,\n    InteractiveDataViewComponent,\n    SearchConfigComponent,\n    PageHeaderComponent,\n    SearchHeaderComponent,\n    DiagramComponent,\n    GroupByCountDiagramComponent,\n    IfPermissionDirective,\n    IfBreakpointDirective,\n    SrcDirective,\n    OcxTimeAgoPipe,\n    // DataListGridSortingComponent,\n  ],\n  schemas: [CUSTOM_ELEMENTS_SCHEMA],\n})\nexport class AngularAcceleratorModule {}\n"]}
|
|
@@ -1,15 +1,107 @@
|
|
|
1
|
-
import { Pipe } from '@angular/core';
|
|
2
|
-
import {
|
|
1
|
+
import { ChangeDetectorRef, NgZone, Pipe } from '@angular/core';
|
|
2
|
+
import { TranslatePipe, TranslateService } from '@ngx-translate/core';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@ngx-translate/core";
|
|
4
5
|
// eslint-disable-next-line @angular-eslint/use-pipe-transform-interface
|
|
5
|
-
export class OcxTimeAgoPipe extends
|
|
6
|
+
export class OcxTimeAgoPipe extends TranslatePipe {
|
|
7
|
+
constructor(changeDetectorRef, ngZone, translateService) {
|
|
8
|
+
super(translateService, changeDetectorRef);
|
|
9
|
+
this.changeDetectorRef = changeDetectorRef;
|
|
10
|
+
this.ngZone = ngZone;
|
|
11
|
+
this.translateService = translateService;
|
|
12
|
+
}
|
|
13
|
+
transform(value) {
|
|
14
|
+
this.removeTimer();
|
|
15
|
+
const d = new Date(value);
|
|
16
|
+
const now = new Date();
|
|
17
|
+
const seconds = Math.round(Math.abs((now.getTime() - d.getTime()) / 1000));
|
|
18
|
+
const timeToUpdate = Number.isNaN(seconds) ? 1000 : this.getSecondsUntilUpdate(seconds) * 1000;
|
|
19
|
+
this.timer = this.ngZone.runOutsideAngular(() => {
|
|
20
|
+
if (typeof window !== 'undefined') {
|
|
21
|
+
return window.setTimeout(() => {
|
|
22
|
+
this.ngZone.run(() => this.changeDetectorRef.markForCheck());
|
|
23
|
+
}, timeToUpdate);
|
|
24
|
+
}
|
|
25
|
+
return null;
|
|
26
|
+
});
|
|
27
|
+
const minutes = Math.round(Math.abs(seconds / 60));
|
|
28
|
+
const hours = Math.round(Math.abs(minutes / 60));
|
|
29
|
+
const days = Math.round(Math.abs(hours / 24));
|
|
30
|
+
const months = Math.round(Math.abs(days / 30.416));
|
|
31
|
+
const years = Math.round(Math.abs(days / 365));
|
|
32
|
+
let translationKey = 'UNKNOWN';
|
|
33
|
+
if (Number.isNaN(seconds)) {
|
|
34
|
+
translationKey = 'NAN';
|
|
35
|
+
}
|
|
36
|
+
else if (seconds <= 45) {
|
|
37
|
+
translationKey = 'A_FEW_SECONDS_AGO';
|
|
38
|
+
}
|
|
39
|
+
else if (seconds <= 90) {
|
|
40
|
+
translationKey = 'A_MINUTE_AGO';
|
|
41
|
+
}
|
|
42
|
+
else if (minutes <= 45) {
|
|
43
|
+
translationKey = 'MINUTES_AGO';
|
|
44
|
+
}
|
|
45
|
+
else if (minutes <= 90) {
|
|
46
|
+
translationKey = 'AN_HOUR_AGO';
|
|
47
|
+
}
|
|
48
|
+
else if (hours <= 22) {
|
|
49
|
+
translationKey = 'HOURS_AGO';
|
|
50
|
+
}
|
|
51
|
+
else if (hours <= 36) {
|
|
52
|
+
translationKey = 'A_DAY_AGO';
|
|
53
|
+
}
|
|
54
|
+
else if (days <= 25) {
|
|
55
|
+
translationKey = 'DAYS_AGO';
|
|
56
|
+
}
|
|
57
|
+
else if (days <= 45) {
|
|
58
|
+
translationKey = 'A_MONTH_AGO';
|
|
59
|
+
}
|
|
60
|
+
else if (days <= 345) {
|
|
61
|
+
translationKey = 'MONTHS_AGO';
|
|
62
|
+
}
|
|
63
|
+
else if (days <= 545) {
|
|
64
|
+
translationKey = 'A_YEAR_AGO';
|
|
65
|
+
}
|
|
66
|
+
else {
|
|
67
|
+
translationKey = 'YEARS_AGO';
|
|
68
|
+
}
|
|
69
|
+
return super.transform('OCX_TIMEAGO.' + translationKey, { minutes, hours, days, months, years });
|
|
70
|
+
}
|
|
71
|
+
ngOnDestroy() {
|
|
72
|
+
this.removeTimer();
|
|
73
|
+
super.ngOnDestroy();
|
|
74
|
+
}
|
|
75
|
+
removeTimer() {
|
|
76
|
+
if (this.timer) {
|
|
77
|
+
window.clearTimeout(this.timer);
|
|
78
|
+
this.timer = null;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
getSecondsUntilUpdate(seconds) {
|
|
82
|
+
const min = 60;
|
|
83
|
+
const hr = min * 60;
|
|
84
|
+
const day = hr * 24;
|
|
85
|
+
if (seconds < min) {
|
|
86
|
+
return 2;
|
|
87
|
+
}
|
|
88
|
+
else if (seconds < hr) {
|
|
89
|
+
return 30;
|
|
90
|
+
}
|
|
91
|
+
else if (seconds < day) {
|
|
92
|
+
return 300;
|
|
93
|
+
}
|
|
94
|
+
else {
|
|
95
|
+
return 3600;
|
|
96
|
+
}
|
|
97
|
+
}
|
|
6
98
|
}
|
|
7
|
-
OcxTimeAgoPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: OcxTimeAgoPipe, deps:
|
|
99
|
+
OcxTimeAgoPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: OcxTimeAgoPipe, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.NgZone }, { token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Pipe });
|
|
8
100
|
OcxTimeAgoPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: OcxTimeAgoPipe, name: "timeago" });
|
|
9
101
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: OcxTimeAgoPipe, decorators: [{
|
|
10
102
|
type: Pipe,
|
|
11
103
|
args: [{
|
|
12
104
|
name: 'timeago',
|
|
13
105
|
}]
|
|
14
|
-
}] });
|
|
15
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
106
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.NgZone }, { type: i1.TranslateService }]; } });
|
|
107
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ocxtimeago.pipe.js","sourceRoot":"","sources":["../../../../../../libs/angular-accelerator/src/lib/pipes/ocxtimeago.pipe.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, NgZone, OnDestroy, Pipe, PipeTransform } from '@angular/core'\nimport { TranslatePipe, TranslateService } from '@ngx-translate/core'\n\n@Pipe({\n  name: 'timeago',\n})\n// eslint-disable-next-line @angular-eslint/use-pipe-transform-interface\nexport class OcxTimeAgoPipe extends TranslatePipe implements OnDestroy, PipeTransform {\n  private timer: number | undefined | null\n  constructor(\n    private changeDetectorRef: ChangeDetectorRef,\n    private ngZone: NgZone,\n    private translateService: TranslateService\n  ) {\n    super(translateService, changeDetectorRef)\n  }\n  override transform(value: string) {\n    this.removeTimer()\n    const d = new Date(value)\n    const now = new Date()\n    const seconds = Math.round(Math.abs((now.getTime() - d.getTime()) / 1000))\n    const timeToUpdate = Number.isNaN(seconds) ? 1000 : this.getSecondsUntilUpdate(seconds) * 1000\n    this.timer = this.ngZone.runOutsideAngular(() => {\n      if (typeof window !== 'undefined') {\n        return window.setTimeout(() => {\n          this.ngZone.run(() => this.changeDetectorRef.markForCheck())\n        }, timeToUpdate)\n      }\n      return null\n    })\n    const minutes = Math.round(Math.abs(seconds / 60))\n    const hours = Math.round(Math.abs(minutes / 60))\n    const days = Math.round(Math.abs(hours / 24))\n    const months = Math.round(Math.abs(days / 30.416))\n    const years = Math.round(Math.abs(days / 365))\n    let translationKey = 'UNKNOWN'\n    if (Number.isNaN(seconds)) {\n      translationKey = 'NAN'\n    } else if (seconds <= 45) {\n      translationKey = 'A_FEW_SECONDS_AGO'\n    } else if (seconds <= 90) {\n      translationKey = 'A_MINUTE_AGO'\n    } else if (minutes <= 45) {\n      translationKey = 'MINUTES_AGO'\n    } else if (minutes <= 90) {\n      translationKey = 'AN_HOUR_AGO'\n    } else if (hours <= 22) {\n      translationKey = 'HOURS_AGO'\n    } else if (hours <= 36) {\n      translationKey = 'A_DAY_AGO'\n    } else if (days <= 25) {\n      translationKey = 'DAYS_AGO'\n    } else if (days <= 45) {\n      translationKey = 'A_MONTH_AGO'\n    } else if (days <= 345) {\n      translationKey = 'MONTHS_AGO'\n    } else if (days <= 545) {\n      translationKey = 'A_YEAR_AGO'\n    } else {\n      translationKey = 'YEARS_AGO'\n    }\n    return super.transform('OCX_TIMEAGO.' + translationKey, { minutes, hours, days, months, years })\n  }\n  override ngOnDestroy(): void {\n    this.removeTimer()\n    super.ngOnDestroy()\n  }\n  private removeTimer() {\n    if (this.timer) {\n      window.clearTimeout(this.timer)\n      this.timer = null\n    }\n  }\n  private getSecondsUntilUpdate(seconds: number) {\n    const min = 60\n    const hr = min * 60\n    const day = hr * 24\n    if (seconds < min) {\n      return 2\n    } else if (seconds < hr) {\n      return 30\n    } else if (seconds < day) {\n      return 300\n    } else {\n      return 3600\n    }\n  }\n}\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { Directive, Optional, Input, HostListener, EventEmitter, Component, Output, LOCALE_ID, Inject, ContentChild, Pipe, ViewChild, Injectable, Injector, ViewEncapsulation, NgModule, inject,
|
|
2
|
+
import { Directive, Optional, Input, HostListener, EventEmitter, Component, Output, LOCALE_ID, Inject, ContentChild, Pipe, ViewChild, Injectable, Injector, ViewEncapsulation, NgModule, inject, CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
|
|
3
3
|
import * as i2 from '@onecx/angular-integration-interface';
|
|
4
4
|
import { UserService, AppStateService } from '@onecx/angular-integration-interface';
|
|
5
5
|
import * as i1 from '@angular/common/http';
|
|
@@ -14,7 +14,7 @@ import { PrimeIcons } from 'primeng/api';
|
|
|
14
14
|
import * as i3$1 from '@angular/forms';
|
|
15
15
|
import { FormGroup, FormControl, FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
16
16
|
import * as i1$1 from '@ngx-translate/core';
|
|
17
|
-
import { TranslateModule, TranslateLoader, MissingTranslationHandler } from '@ngx-translate/core';
|
|
17
|
+
import { TranslatePipe, TranslateModule, TranslateLoader, MissingTranslationHandler } from '@ngx-translate/core';
|
|
18
18
|
import * as i6 from 'primeng/button';
|
|
19
19
|
import { ButtonModule } from 'primeng/button';
|
|
20
20
|
import * as i4 from 'primeng/dialog';
|
|
@@ -33,15 +33,12 @@ import * as i6$2 from 'primeng/table';
|
|
|
33
33
|
import { TableModule } from 'primeng/table';
|
|
34
34
|
import * as i7$1 from 'primeng/multiselect';
|
|
35
35
|
import { MultiSelectModule } from 'primeng/multiselect';
|
|
36
|
-
import { TimeagoPipe, TimeagoIntl, TimeagoModule, TimeagoFormatter, TimeagoCustomFormatter, TimeagoClock, TimeagoDefaultClock } from 'ngx-timeago';
|
|
37
36
|
import * as d3 from 'd3-scale-chromatic';
|
|
38
37
|
import * as i5$1 from 'primeng/chart';
|
|
39
38
|
import { ChartModule } from 'primeng/chart';
|
|
40
39
|
import * as i5$2 from 'primeng/breadcrumb';
|
|
41
40
|
import { BreadcrumbModule } from 'primeng/breadcrumb';
|
|
42
41
|
import { SyncableTopic } from '@onecx/accelerator';
|
|
43
|
-
import { strings } from 'ngx-timeago/language-strings/en';
|
|
44
|
-
import { strings as strings$1 } from 'ngx-timeago/language-strings/de';
|
|
45
42
|
import { TranslateHttpLoader } from '@ngx-translate/http-loader';
|
|
46
43
|
|
|
47
44
|
class IfPermissionDirective {
|
|
@@ -972,16 +969,107 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
972
969
|
}] } });
|
|
973
970
|
|
|
974
971
|
// eslint-disable-next-line @angular-eslint/use-pipe-transform-interface
|
|
975
|
-
class OcxTimeAgoPipe extends
|
|
972
|
+
class OcxTimeAgoPipe extends TranslatePipe {
|
|
973
|
+
constructor(changeDetectorRef, ngZone, translateService) {
|
|
974
|
+
super(translateService, changeDetectorRef);
|
|
975
|
+
this.changeDetectorRef = changeDetectorRef;
|
|
976
|
+
this.ngZone = ngZone;
|
|
977
|
+
this.translateService = translateService;
|
|
978
|
+
}
|
|
979
|
+
transform(value) {
|
|
980
|
+
this.removeTimer();
|
|
981
|
+
const d = new Date(value);
|
|
982
|
+
const now = new Date();
|
|
983
|
+
const seconds = Math.round(Math.abs((now.getTime() - d.getTime()) / 1000));
|
|
984
|
+
const timeToUpdate = Number.isNaN(seconds) ? 1000 : this.getSecondsUntilUpdate(seconds) * 1000;
|
|
985
|
+
this.timer = this.ngZone.runOutsideAngular(() => {
|
|
986
|
+
if (typeof window !== 'undefined') {
|
|
987
|
+
return window.setTimeout(() => {
|
|
988
|
+
this.ngZone.run(() => this.changeDetectorRef.markForCheck());
|
|
989
|
+
}, timeToUpdate);
|
|
990
|
+
}
|
|
991
|
+
return null;
|
|
992
|
+
});
|
|
993
|
+
const minutes = Math.round(Math.abs(seconds / 60));
|
|
994
|
+
const hours = Math.round(Math.abs(minutes / 60));
|
|
995
|
+
const days = Math.round(Math.abs(hours / 24));
|
|
996
|
+
const months = Math.round(Math.abs(days / 30.416));
|
|
997
|
+
const years = Math.round(Math.abs(days / 365));
|
|
998
|
+
let translationKey = 'UNKNOWN';
|
|
999
|
+
if (Number.isNaN(seconds)) {
|
|
1000
|
+
translationKey = 'NAN';
|
|
1001
|
+
}
|
|
1002
|
+
else if (seconds <= 45) {
|
|
1003
|
+
translationKey = 'A_FEW_SECONDS_AGO';
|
|
1004
|
+
}
|
|
1005
|
+
else if (seconds <= 90) {
|
|
1006
|
+
translationKey = 'A_MINUTE_AGO';
|
|
1007
|
+
}
|
|
1008
|
+
else if (minutes <= 45) {
|
|
1009
|
+
translationKey = 'MINUTES_AGO';
|
|
1010
|
+
}
|
|
1011
|
+
else if (minutes <= 90) {
|
|
1012
|
+
translationKey = 'AN_HOUR_AGO';
|
|
1013
|
+
}
|
|
1014
|
+
else if (hours <= 22) {
|
|
1015
|
+
translationKey = 'HOURS_AGO';
|
|
1016
|
+
}
|
|
1017
|
+
else if (hours <= 36) {
|
|
1018
|
+
translationKey = 'A_DAY_AGO';
|
|
1019
|
+
}
|
|
1020
|
+
else if (days <= 25) {
|
|
1021
|
+
translationKey = 'DAYS_AGO';
|
|
1022
|
+
}
|
|
1023
|
+
else if (days <= 45) {
|
|
1024
|
+
translationKey = 'A_MONTH_AGO';
|
|
1025
|
+
}
|
|
1026
|
+
else if (days <= 345) {
|
|
1027
|
+
translationKey = 'MONTHS_AGO';
|
|
1028
|
+
}
|
|
1029
|
+
else if (days <= 545) {
|
|
1030
|
+
translationKey = 'A_YEAR_AGO';
|
|
1031
|
+
}
|
|
1032
|
+
else {
|
|
1033
|
+
translationKey = 'YEARS_AGO';
|
|
1034
|
+
}
|
|
1035
|
+
return super.transform('OCX_TIMEAGO.' + translationKey, { minutes, hours, days, months, years });
|
|
1036
|
+
}
|
|
1037
|
+
ngOnDestroy() {
|
|
1038
|
+
this.removeTimer();
|
|
1039
|
+
super.ngOnDestroy();
|
|
1040
|
+
}
|
|
1041
|
+
removeTimer() {
|
|
1042
|
+
if (this.timer) {
|
|
1043
|
+
window.clearTimeout(this.timer);
|
|
1044
|
+
this.timer = null;
|
|
1045
|
+
}
|
|
1046
|
+
}
|
|
1047
|
+
getSecondsUntilUpdate(seconds) {
|
|
1048
|
+
const min = 60;
|
|
1049
|
+
const hr = min * 60;
|
|
1050
|
+
const day = hr * 24;
|
|
1051
|
+
if (seconds < min) {
|
|
1052
|
+
return 2;
|
|
1053
|
+
}
|
|
1054
|
+
else if (seconds < hr) {
|
|
1055
|
+
return 30;
|
|
1056
|
+
}
|
|
1057
|
+
else if (seconds < day) {
|
|
1058
|
+
return 300;
|
|
1059
|
+
}
|
|
1060
|
+
else {
|
|
1061
|
+
return 3600;
|
|
1062
|
+
}
|
|
1063
|
+
}
|
|
976
1064
|
}
|
|
977
|
-
OcxTimeAgoPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: OcxTimeAgoPipe, deps:
|
|
1065
|
+
OcxTimeAgoPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: OcxTimeAgoPipe, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.NgZone }, { token: i1$1.TranslateService }], target: i0.ɵɵFactoryTarget.Pipe });
|
|
978
1066
|
OcxTimeAgoPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "15.2.10", ngImport: i0, type: OcxTimeAgoPipe, name: "timeago" });
|
|
979
1067
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: OcxTimeAgoPipe, decorators: [{
|
|
980
1068
|
type: Pipe,
|
|
981
1069
|
args: [{
|
|
982
1070
|
name: 'timeago',
|
|
983
1071
|
}]
|
|
984
|
-
}] });
|
|
1072
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.NgZone }, { type: i1$1.TranslateService }]; } });
|
|
985
1073
|
|
|
986
1074
|
class DataTableComponent extends DataSortBase {
|
|
987
1075
|
get rows() {
|
|
@@ -2836,36 +2924,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
2836
2924
|
}]
|
|
2837
2925
|
}] });
|
|
2838
2926
|
|
|
2839
|
-
class OcxTimeagoIntl extends TimeagoIntl {
|
|
2840
|
-
constructor(userService) {
|
|
2841
|
-
super();
|
|
2842
|
-
this.userService = userService;
|
|
2843
|
-
this.LANG_TO_STRINGS = {
|
|
2844
|
-
en: strings,
|
|
2845
|
-
de: strings$1,
|
|
2846
|
-
};
|
|
2847
|
-
this.DEFAULT_LANG = 'en';
|
|
2848
|
-
this.strings = strings;
|
|
2849
|
-
userService.lang$
|
|
2850
|
-
.pipe(map((lang) => {
|
|
2851
|
-
return this.getBestMatchLanguage(lang);
|
|
2852
|
-
}))
|
|
2853
|
-
.subscribe((lang) => {
|
|
2854
|
-
this.strings = this.LANG_TO_STRINGS[lang];
|
|
2855
|
-
this.changes.next();
|
|
2856
|
-
});
|
|
2857
|
-
}
|
|
2858
|
-
getBestMatchLanguage(lang) {
|
|
2859
|
-
if (Object.keys(this.LANG_TO_STRINGS).includes(lang)) {
|
|
2860
|
-
return lang;
|
|
2861
|
-
}
|
|
2862
|
-
else {
|
|
2863
|
-
console.log(`${lang} is not supported. Using ${this.DEFAULT_LANG} as a fallback.`);
|
|
2864
|
-
}
|
|
2865
|
-
return this.DEFAULT_LANG;
|
|
2866
|
-
}
|
|
2867
|
-
}
|
|
2868
|
-
|
|
2869
2927
|
class AsyncTranslateLoader {
|
|
2870
2928
|
constructor(translateLoader$) {
|
|
2871
2929
|
this.translateLoader$ = translateLoader$;
|
|
@@ -2995,25 +3053,6 @@ AngularAcceleratorModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0"
|
|
|
2995
3053
|
},
|
|
2996
3054
|
deps: [UserService],
|
|
2997
3055
|
},
|
|
2998
|
-
{
|
|
2999
|
-
provide: TimeagoIntl,
|
|
3000
|
-
useFactory: (userService) => {
|
|
3001
|
-
return new OcxTimeagoIntl(userService);
|
|
3002
|
-
},
|
|
3003
|
-
deps: [UserService],
|
|
3004
|
-
},
|
|
3005
|
-
importProvidersFrom(TimeagoModule),
|
|
3006
|
-
{
|
|
3007
|
-
provide: TimeagoFormatter,
|
|
3008
|
-
useFactory: (TimeagoIntl) => {
|
|
3009
|
-
return new TimeagoCustomFormatter(TimeagoIntl);
|
|
3010
|
-
},
|
|
3011
|
-
deps: [TimeagoIntl],
|
|
3012
|
-
},
|
|
3013
|
-
{
|
|
3014
|
-
provide: TimeagoClock,
|
|
3015
|
-
useClass: TimeagoDefaultClock,
|
|
3016
|
-
},
|
|
3017
3056
|
], imports: [CommonModule,
|
|
3018
3057
|
AngularAcceleratorPrimeNgModule,
|
|
3019
3058
|
TranslateModule.forRoot({
|
|
@@ -3081,25 +3120,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
3081
3120
|
},
|
|
3082
3121
|
deps: [UserService],
|
|
3083
3122
|
},
|
|
3084
|
-
{
|
|
3085
|
-
provide: TimeagoIntl,
|
|
3086
|
-
useFactory: (userService) => {
|
|
3087
|
-
return new OcxTimeagoIntl(userService);
|
|
3088
|
-
},
|
|
3089
|
-
deps: [UserService],
|
|
3090
|
-
},
|
|
3091
|
-
importProvidersFrom(TimeagoModule),
|
|
3092
|
-
{
|
|
3093
|
-
provide: TimeagoFormatter,
|
|
3094
|
-
useFactory: (TimeagoIntl) => {
|
|
3095
|
-
return new TimeagoCustomFormatter(TimeagoIntl);
|
|
3096
|
-
},
|
|
3097
|
-
deps: [TimeagoIntl],
|
|
3098
|
-
},
|
|
3099
|
-
{
|
|
3100
|
-
provide: TimeagoClock,
|
|
3101
|
-
useClass: TimeagoDefaultClock,
|
|
3102
|
-
},
|
|
3103
3123
|
],
|
|
3104
3124
|
exports: [
|
|
3105
3125
|
ColumnGroupSelectionComponent,
|