@bizdoc/core 1.13.22 → 1.13.26
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/cldr-data/main/ar/ca-buddhist.json +530 -530
- package/assets/i18n/cldr-data/main/ar/ca-chinese.json +1254 -1254
- package/assets/i18n/cldr-data/main/ar/ca-coptic.json +539 -539
- package/assets/i18n/cldr-data/main/ar/ca-dangi.json +1254 -1254
- package/assets/i18n/cldr-data/main/ar/ca-ethiopic-amete-alem.json +536 -536
- package/assets/i18n/cldr-data/main/ar/ca-ethiopic.json +539 -539
- package/assets/i18n/cldr-data/main/ar/ca-generic.json +533 -533
- package/assets/i18n/cldr-data/main/ar/ca-gregorian.json +557 -557
- package/assets/i18n/cldr-data/main/ar/ca-hebrew.json +542 -542
- package/assets/i18n/cldr-data/main/ar/ca-indian.json +530 -530
- package/assets/i18n/cldr-data/main/ar/ca-islamic-civil.json +530 -530
- package/assets/i18n/cldr-data/main/ar/ca-islamic-rgsa.json +530 -530
- package/assets/i18n/cldr-data/main/ar/ca-islamic-tbla.json +530 -530
- package/assets/i18n/cldr-data/main/ar/ca-islamic-umalqura.json +530 -530
- package/assets/i18n/cldr-data/main/ar/ca-islamic.json +530 -530
- package/assets/i18n/cldr-data/main/ar/ca-japanese.json +1238 -1238
- package/assets/i18n/cldr-data/main/ar/ca-persian.json +530 -530
- package/assets/i18n/cldr-data/main/ar/ca-roc.json +533 -533
- package/assets/i18n/cldr-data/main/ar/characters.json +52 -52
- package/assets/i18n/cldr-data/main/ar/currencies.json +2306 -2306
- package/assets/i18n/cldr-data/main/ar/dateFields.json +1039 -1039
- package/assets/i18n/cldr-data/main/ar/delimiters.json +18 -18
- package/assets/i18n/cldr-data/main/ar/languages.json +556 -556
- package/assets/i18n/cldr-data/main/ar/layout.json +18 -18
- package/assets/i18n/cldr-data/main/ar/listPatterns.json +68 -68
- package/assets/i18n/cldr-data/main/ar/localeDisplayNames.json +230 -230
- package/assets/i18n/cldr-data/main/ar/measurementSystemNames.json +19 -19
- package/assets/i18n/cldr-data/main/ar/numbers.json +511 -511
- package/assets/i18n/cldr-data/main/ar/posix.json +18 -18
- package/assets/i18n/cldr-data/main/ar/scripts.json +202 -202
- package/assets/i18n/cldr-data/main/ar/territories.json +324 -324
- package/assets/i18n/cldr-data/main/ar/timeZoneNames.json +2268 -2268
- package/assets/i18n/cldr-data/main/ar/units.json +4587 -4587
- package/assets/i18n/cldr-data/main/ar/variants.json +119 -119
- package/assets/i18n/cldr-data/main/de/ca-buddhist.json +530 -530
- package/assets/i18n/cldr-data/main/de/ca-chinese.json +1254 -1254
- package/assets/i18n/cldr-data/main/de/ca-coptic.json +539 -539
- package/assets/i18n/cldr-data/main/de/ca-dangi.json +1254 -1254
- package/assets/i18n/cldr-data/main/de/ca-ethiopic-amete-alem.json +536 -536
- package/assets/i18n/cldr-data/main/de/ca-ethiopic.json +539 -539
- package/assets/i18n/cldr-data/main/de/ca-generic.json +533 -533
- package/assets/i18n/cldr-data/main/de/ca-gregorian.json +551 -551
- package/assets/i18n/cldr-data/main/de/ca-hebrew.json +542 -542
- package/assets/i18n/cldr-data/main/de/ca-indian.json +530 -530
- package/assets/i18n/cldr-data/main/de/ca-islamic-civil.json +530 -530
- package/assets/i18n/cldr-data/main/de/ca-islamic-rgsa.json +530 -530
- package/assets/i18n/cldr-data/main/de/ca-islamic-tbla.json +530 -530
- package/assets/i18n/cldr-data/main/de/ca-islamic-umalqura.json +530 -530
- package/assets/i18n/cldr-data/main/de/ca-islamic.json +530 -530
- package/assets/i18n/cldr-data/main/de/ca-japanese.json +1238 -1238
- package/assets/i18n/cldr-data/main/de/ca-persian.json +530 -530
- package/assets/i18n/cldr-data/main/de/ca-roc.json +533 -533
- package/assets/i18n/cldr-data/main/de/characters.json +52 -52
- package/assets/i18n/cldr-data/main/de/contextTransforms.json +18 -18
- package/assets/i18n/cldr-data/main/de/currencies.json +1932 -1932
- package/assets/i18n/cldr-data/main/de/dateFields.json +679 -679
- package/assets/i18n/cldr-data/main/de/delimiters.json +18 -18
- package/assets/i18n/cldr-data/main/de/languages.json +640 -640
- package/assets/i18n/cldr-data/main/de/layout.json +18 -18
- package/assets/i18n/cldr-data/main/de/listPatterns.json +68 -68
- package/assets/i18n/cldr-data/main/de/localeDisplayNames.json +230 -230
- package/assets/i18n/cldr-data/main/de/measurementSystemNames.json +19 -19
- package/assets/i18n/cldr-data/main/de/numbers.json +155 -155
- package/assets/i18n/cldr-data/main/de/posix.json +18 -18
- package/assets/i18n/cldr-data/main/de/scripts.json +209 -209
- package/assets/i18n/cldr-data/main/de/territories.json +324 -324
- package/assets/i18n/cldr-data/main/de/timeZoneNames.json +2332 -2332
- package/assets/i18n/cldr-data/main/de/units.json +2546 -2546
- package/assets/i18n/cldr-data/main/de/variants.json +119 -119
- package/assets/i18n/cldr-data/main/ru/ca-buddhist.json +524 -524
- package/assets/i18n/cldr-data/main/ru/ca-chinese.json +1248 -1248
- package/assets/i18n/cldr-data/main/ru/ca-coptic.json +533 -533
- package/assets/i18n/cldr-data/main/ru/ca-dangi.json +1248 -1248
- package/assets/i18n/cldr-data/main/ru/ca-ethiopic-amete-alem.json +530 -530
- package/assets/i18n/cldr-data/main/ru/ca-ethiopic.json +533 -533
- package/assets/i18n/cldr-data/main/ru/ca-generic.json +527 -527
- package/assets/i18n/cldr-data/main/ru/ca-gregorian.json +546 -546
- package/assets/i18n/cldr-data/main/ru/ca-hebrew.json +536 -536
- package/assets/i18n/cldr-data/main/ru/ca-indian.json +524 -524
- package/assets/i18n/cldr-data/main/ru/ca-islamic-civil.json +524 -524
- package/assets/i18n/cldr-data/main/ru/ca-islamic-rgsa.json +524 -524
- package/assets/i18n/cldr-data/main/ru/ca-islamic-tbla.json +524 -524
- package/assets/i18n/cldr-data/main/ru/ca-islamic-umalqura.json +524 -524
- package/assets/i18n/cldr-data/main/ru/ca-islamic.json +524 -524
- package/assets/i18n/cldr-data/main/ru/ca-japanese.json +1232 -1232
- package/assets/i18n/cldr-data/main/ru/ca-persian.json +524 -524
- package/assets/i18n/cldr-data/main/ru/ca-roc.json +527 -527
- package/assets/i18n/cldr-data/main/ru/characters.json +52 -52
- package/assets/i18n/cldr-data/main/ru/contextTransforms.json +62 -62
- package/assets/i18n/cldr-data/main/ru/currencies.json +2001 -2001
- package/assets/i18n/cldr-data/main/ru/dateFields.json +859 -859
- package/assets/i18n/cldr-data/main/ru/delimiters.json +18 -18
- package/assets/i18n/cldr-data/main/ru/languages.json +557 -557
- package/assets/i18n/cldr-data/main/ru/layout.json +18 -18
- package/assets/i18n/cldr-data/main/ru/listPatterns.json +68 -68
- package/assets/i18n/cldr-data/main/ru/localeDisplayNames.json +230 -230
- package/assets/i18n/cldr-data/main/ru/measurementSystemNames.json +19 -19
- package/assets/i18n/cldr-data/main/ru/numbers.json +231 -231
- package/assets/i18n/cldr-data/main/ru/posix.json +18 -18
- package/assets/i18n/cldr-data/main/ru/scripts.json +209 -209
- package/assets/i18n/cldr-data/main/ru/territories.json +324 -324
- package/assets/i18n/cldr-data/main/ru/timeZoneNames.json +2317 -2317
- package/assets/i18n/cldr-data/main/ru/units.json +3647 -3647
- package/assets/i18n/cldr-data/main/ru/variants.json +119 -119
- package/esm2020/lib/compose/attachments/preview/attachment-preview.component.mjs +6 -6
- package/esm2020/lib/core/controls/file.input.mjs +3 -3
- package/esm2020/lib/core/http.interceptor.mjs +3 -3
- package/esm2020/lib/core/info/attachment-info.service.mjs +1 -1
- package/esm2020/lib/core/mailbox.service.mjs +3 -3
- package/esm2020/lib/core/session.service.mjs +11 -9
- package/esm2020/lib/core/translate.service.mjs +18 -10
- package/esm2020/lib/core/translations.mjs +14 -8
- package/esm2020/lib/cube/accum/accum.component.mjs +3 -3
- package/esm2020/lib/cube/chart/chart.component.mjs +3 -3
- package/esm2020/lib/cube/cube.service.mjs +12 -1
- package/esm2020/lib/cube/grid/grid.component.mjs +3 -2
- package/esm2020/lib/cube/grid/spreadsheet.component.mjs +11 -8
- package/esm2020/lib/cube/matrix/table.component.mjs +7 -4
- package/esm2020/lib/cube/parallel/parallel.component.mjs +3 -3
- package/esm2020/lib/cube/pivot/pivot.component.mjs +3 -3
- package/esm2020/lib/cube/sum/sum.component.mjs +21 -21
- package/esm2020/lib/cube/view.pane.component.mjs +3 -3
- package/esm2020/lib/reports/report.mobile.component.mjs +11 -3
- package/esm2020/lib/reports/report.pane.component.mjs +1 -1
- package/esm2020/lib/views/cube/matrix.component.mjs +1 -1
- package/fesm2015/bizdoc-core.mjs +103 -66
- package/fesm2015/bizdoc-core.mjs.map +1 -1
- package/fesm2020/bizdoc-core.mjs +103 -66
- package/fesm2020/bizdoc-core.mjs.map +1 -1
- package/lib/core/mailbox.service.d.ts +1 -1
- package/lib/core/translate.service.d.ts +3 -0
- package/lib/core/translations.d.ts +13 -7
- package/lib/cube/cube.service.d.ts +2 -1
- package/lib/cube/grid/spreadsheet.component.d.ts +0 -1
- package/lib/cube/sum/sum.component.d.ts +4 -1
- package/lib/reports/report.mobile.component.d.ts +3 -0
- package/lib/reports/report.pane.component.d.ts +1 -1
- package/package.json +2 -2
package/fesm2020/bizdoc-core.mjs
CHANGED
@@ -27,7 +27,13 @@ import * as i2$1 from '@angular/cdk/a11y';
|
|
27
27
|
import { ActiveDescendantKeyManager } from '@angular/cdk/a11y';
|
28
28
|
import { L10n, setCulture, loadCldr, setCurrencyCode, Internationalization, enableRtl } from '@syncfusion/ej2-base';
|
29
29
|
import 'dayjs/locale/he';
|
30
|
+
import 'dayjs/locale/de';
|
31
|
+
import 'dayjs/locale/ru';
|
32
|
+
import 'dayjs/locale/ar';
|
30
33
|
import localeHe from '@angular/common/locales/he';
|
34
|
+
import localeAr from '@angular/common/locales/ar';
|
35
|
+
import localeRu from '@angular/common/locales/ru';
|
36
|
+
import localeDe from '@angular/common/locales/de';
|
31
37
|
import * as i8 from '@angular/material/icon';
|
32
38
|
import { MatIconModule } from '@angular/material/icon';
|
33
39
|
import * as brace from 'brace';
|
@@ -993,7 +999,7 @@ const THEMES = [
|
|
993
999
|
{ name: 'dark', primary: 'deepPurple', color: '#404041', accent: 'amber', dark: true },
|
994
1000
|
{ name: 'brown', primary: 'brown', color: '#795548', accent: 'grey' }
|
995
1001
|
];
|
996
|
-
const SUPPORTED_LANGUAGES = ['en
|
1002
|
+
const SUPPORTED_LANGUAGES = ['en', 'he', 'de', 'ar', 'ru'], RTL_LANGUALGES = ['he', 'ar'];
|
997
1003
|
class SessionService {
|
998
1004
|
constructor(_config, _http, _cookies, _hub) {
|
999
1005
|
this._config = _config;
|
@@ -1166,14 +1172,16 @@ class SessionService {
|
|
1166
1172
|
lang = navigator.languages[i];
|
1167
1173
|
if (this.languages.indexOf(lang) > -1)
|
1168
1174
|
return lang;
|
1175
|
+
if (lang.length > 2) {
|
1176
|
+
lang = lang.substring(0, 2).toLowerCase();
|
1177
|
+
if (this.languages.indexOf(lang) > -1)
|
1178
|
+
return lang;
|
1179
|
+
lang = this.languages.find(l => l.startsWith(lang));
|
1180
|
+
if (lang)
|
1181
|
+
return lang;
|
1182
|
+
}
|
1169
1183
|
}
|
1170
|
-
|
1171
|
-
const culture = navigator.languages[i].substring(0, 2).toLowerCase();
|
1172
|
-
lang = this.languages.find(l => l.startsWith(culture));
|
1173
|
-
if (lang)
|
1174
|
-
break;
|
1175
|
-
}
|
1176
|
-
return lang;
|
1184
|
+
return null;
|
1177
1185
|
}
|
1178
1186
|
/**
|
1179
1187
|
*
|
@@ -1245,9 +1253,9 @@ class MailboxService {
|
|
1245
1253
|
folder.count++;
|
1246
1254
|
});
|
1247
1255
|
}
|
1248
|
-
formatDownloadUrl(documentId, fileId) {
|
1256
|
+
formatDownloadUrl(documentId, fileId, inline) {
|
1249
1257
|
const token = this._auth.getAccessToken();
|
1250
|
-
return `/api/attachments/${documentId}/${fileId}?access_token=${token}`;
|
1258
|
+
return `/api/attachments/${documentId}/${fileId}?access_token=${token}&inline=${inline ? true : false}`;
|
1251
1259
|
}
|
1252
1260
|
download(documentId, fileId) {
|
1253
1261
|
//new Observable<any>(observe => {
|
@@ -1841,7 +1849,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
|
|
1841
1849
|
args: [MatSlideToggle]
|
1842
1850
|
}] } });
|
1843
1851
|
|
1844
|
-
const
|
1852
|
+
const L18N_STRINGS = {
|
1845
1853
|
'en': {
|
1846
1854
|
pivotview: {
|
1847
1855
|
filterAxisPrompt: '',
|
@@ -1851,6 +1859,8 @@ const SYNCFUSION_L18N = {
|
|
1851
1859
|
}
|
1852
1860
|
},
|
1853
1861
|
'de': {},
|
1862
|
+
'ar': {},
|
1863
|
+
'ru': {},
|
1854
1864
|
'he': {
|
1855
1865
|
'richtexteditor': {
|
1856
1866
|
alignments: "יישור",
|
@@ -1921,8 +1931,10 @@ const SYNCFUSION_L18N = {
|
|
1921
1931
|
}
|
1922
1932
|
};
|
1923
1933
|
const STRINGS = {
|
1924
|
-
'de
|
1925
|
-
'
|
1934
|
+
'de': {},
|
1935
|
+
'ar': {},
|
1936
|
+
'ru': {},
|
1937
|
+
'en': {
|
1926
1938
|
Editing: '{0} editing...',
|
1927
1939
|
CheckOut: 'Check out',
|
1928
1940
|
CheckIn: 'Check in',
|
@@ -2152,9 +2164,11 @@ const STRINGS = {
|
|
2152
2164
|
NewCommentsCount: '{0} comment(s) <strong>{1}</strong> new',
|
2153
2165
|
None: '- None -',
|
2154
2166
|
All: '- All -',
|
2155
|
-
'de
|
2156
|
-
'en
|
2157
|
-
'he
|
2167
|
+
'de': 'Deutsch',
|
2168
|
+
'en': 'English',
|
2169
|
+
'he': 'עברית',
|
2170
|
+
'ar': 'اللغة العربية',
|
2171
|
+
'ru': 'русский язык',
|
2158
2172
|
StartTour: 'Start tour',
|
2159
2173
|
UploadOk: '{0} uploaded',
|
2160
2174
|
UploadVersionOk: '{0} updated',
|
@@ -2380,7 +2394,7 @@ const STRINGS = {
|
|
2380
2394
|
Matrix: 'Matrix',
|
2381
2395
|
Working: 'Working on it...'
|
2382
2396
|
},
|
2383
|
-
'he
|
2397
|
+
'he': {
|
2384
2398
|
Editing: '{0} עורך/ת...',
|
2385
2399
|
EditingMale: '{0} עורך...',
|
2386
2400
|
EditingFemale: '{0} עורכת...',
|
@@ -2948,8 +2962,7 @@ const STRINGS = {
|
|
2948
2962
|
}
|
2949
2963
|
};
|
2950
2964
|
|
2951
|
-
const
|
2952
|
-
L10n.load(SYNCFUSION_L18N);
|
2965
|
+
const CLDR_FILES$1 = ['cldr-data/main/{0}/ca-gregorian.json', 'cldr-data/main/{0}/numbers.json', 'cldr-data/main/{0}/timeZoneNames.json'];
|
2953
2966
|
function TranslateProviderFactory(provider) {
|
2954
2967
|
return () => provider.cldr(provider.culture, CLDR_FILES$1);
|
2955
2968
|
}
|
@@ -2957,15 +2970,18 @@ class TranslateService {
|
|
2957
2970
|
constructor(_session, _http) {
|
2958
2971
|
this._session = _session;
|
2959
2972
|
this._http = _http;
|
2960
|
-
TranslateService.resource = STRINGS['en
|
2961
|
-
if (
|
2962
|
-
STRINGS[_session.language]
|
2963
|
-
Object.assign(TranslateService.resource, STRINGS[_session.language]);
|
2973
|
+
TranslateService.resource = STRINGS['en'];
|
2974
|
+
if ('en' !== _session.language) {
|
2975
|
+
Object.assign(TranslateService.resource, STRINGS[_session.language]);
|
2964
2976
|
const culture = _session.language.split('-')[0];
|
2965
2977
|
dayjs.locale(culture);
|
2966
2978
|
// syncfusion
|
2979
|
+
L10n.load(L18N_STRINGS);
|
2967
2980
|
setCulture(culture);
|
2968
|
-
registerLocaleData(localeHe, 'he');
|
2981
|
+
culture === 'he' && registerLocaleData(localeHe, 'he');
|
2982
|
+
culture === 'ru' && registerLocaleData(localeRu, 'ru');
|
2983
|
+
culture === 'ar' && registerLocaleData(localeAr, 'ar');
|
2984
|
+
culture === 'de' && registerLocaleData(localeDe, 'de');
|
2969
2985
|
}
|
2970
2986
|
;
|
2971
2987
|
_session.loaded.subscribe(() => this._gender = this._session.gender);
|
@@ -2982,7 +2998,7 @@ class TranslateService {
|
|
2982
2998
|
return this._session.language.split('-')[0];
|
2983
2999
|
}
|
2984
3000
|
cldr(culture, files) {
|
2985
|
-
if (
|
3001
|
+
if ('en' === this._session.language)
|
2986
3002
|
return Promise.resolve();
|
2987
3003
|
const observables = files.map(f => this._http.get('/assets/i18n/' + f.replace('{0}', culture)).pipe(tap(loadCldr)));
|
2988
3004
|
return forkJoin(observables).toPromise();
|
@@ -4671,7 +4687,7 @@ class AttachmentPreview {
|
|
4671
4687
|
this._afterClosed = new Subject();
|
4672
4688
|
this.dir = _directionality.value;
|
4673
4689
|
this.isImage = isImage(this.data.file.contentType);
|
4674
|
-
this.objectData = sanitizer.bypassSecurityTrustResourceUrl(this._url());
|
4690
|
+
this.objectData = sanitizer.bypassSecurityTrustResourceUrl(this._url(true));
|
4675
4691
|
this.beforeClose().subscribe(() => this.slideDown = 'leave');
|
4676
4692
|
}
|
4677
4693
|
resize() {
|
@@ -4689,8 +4705,8 @@ class AttachmentPreview {
|
|
4689
4705
|
download() {
|
4690
4706
|
location.assign(this._url());
|
4691
4707
|
}
|
4692
|
-
_url() {
|
4693
|
-
return this._service.formatDownloadUrl(this.data.documentId, this.data.file.id);
|
4708
|
+
_url(inline) {
|
4709
|
+
return this._service.formatDownloadUrl(this.data.documentId, this.data.file.id, inline);
|
4694
4710
|
}
|
4695
4711
|
rotate() {
|
4696
4712
|
const elem = (this.isImage ? this.img : this.obj).nativeElement;
|
@@ -4733,7 +4749,7 @@ class AttachmentPreview {
|
|
4733
4749
|
}
|
4734
4750
|
}
|
4735
4751
|
AttachmentPreview.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: AttachmentPreview, deps: [{ token: i7$2.Directionality }, { token: i0.Renderer2 }, { token: FILE_PREVIEW_DIALOG_DATA }, { token: i1$5.DomSanitizer }, { token: MailboxService }, { token: i1$4.OverlayRef }], target: i0.ɵɵFactoryTarget.Component });
|
4736
|
-
AttachmentPreview.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", type: AttachmentPreview, selector: "bizdoc-attachment-preview", host: { listeners: { "document:resize": "resize()", "document:keydown.escape": "close()" } }, viewQueries: [{ propertyName: "obj", first: true, predicate: ["obj"], descendants: true }, { propertyName: "img", first: true, predicate: ["img"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"overlay-content\" [@slideContent]=\"animationState\" (@slideContent.start)=\"onAnimationStart($event)\"\r\n
|
4752
|
+
AttachmentPreview.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", type: AttachmentPreview, selector: "bizdoc-attachment-preview", host: { listeners: { "document:resize": "resize()", "document:keydown.escape": "close()" } }, viewQueries: [{ propertyName: "obj", first: true, predicate: ["obj"], descendants: true }, { propertyName: "img", first: true, predicate: ["img"], descendants: true, static: true }], ngImport: i0, template: "<div class=\"overlay-content\" [@slideContent]=\"animationState\" (@slideContent.start)=\"onAnimationStart($event)\"\r\n [dir]=\"dir\" (@slideContent.done)=\"onAnimationDone($event)\">\r\n <div class=\"toolbar-wrapper\" fxLayout=\"row\" [@slideDown]=\"slideDown\" *ngIf=\"!loading\">\r\n <button mat-icon-button (click)=\"close()\" bizdocTooltip=\"{{'Back' | translate}}\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\r\n <span class=\"mat-body-1\">{{data.file.fileName}}</span>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"rotate()\" bizdocTooltip=\"{{'Rotate' | translate }}\"><mat-icon>screen_rotation</mat-icon></button>\r\n <button mat-icon-button (click)=\"download()\" bizdocTooltip=\"{{'Download' | translate}}\"><mat-icon>save_alt</mat-icon></button>\r\n </div>\r\n <div class=\"spinner-wrapper\" *ngIf=\"loading\">\r\n <mat-spinner></mat-spinner>\r\n </div>\r\n <object (load)=\"onLoad($event)\" [data]=\"objectData\" [type]=\"data.file.contentType\" *ngIf=\"!isImage\" #obj width=\"250\"\r\n height=\"200\">\r\n </object>\r\n <img *ngIf=\"isImage\" (load)=\"onLoad($event)\" [style.opacity]=\"loading ? 0 : 1\" [@fade]=\"loading ? 'fadeOut' : 'fadeIn'\" [src]=\"objectData\" #img>\r\n</div>\r\n", styles: [":host{display:flex;flex-direction:column;align-items:center}.spinner-wrapper{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:-1}img{width:100%;max-width:500px;height:auto}.overlay-content{padding:1em}.overlay-content .toolbar-wrapper{align-items:center;color:#f5f5f5}.divider{flex:1 1 auto}\n"], components: [{ type: i7$1.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i8.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i8$1.MatSpinner, selector: "mat-spinner", inputs: ["color"] }], directives: [{ type: i7$2.Dir, selector: "[dir]", inputs: ["dir"], outputs: ["dirChange"], exportAs: ["dir"] }, { type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6$1.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { type: TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }], pipes: { "translate": TranslatePipe }, animations: [
|
4737
4753
|
trigger('fade', [
|
4738
4754
|
state('fadeOut', style({ opacity: 0 })),
|
4739
4755
|
state('fadeIn', style({ opacity: 1 })),
|
@@ -4772,7 +4788,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
|
|
4772
4788
|
state('leave', style({ transform: 'translate3d(0, 25%, 0)', opacity: 0 })),
|
4773
4789
|
transition('* => *', animate(ANIMATION_TIMINGS)),
|
4774
4790
|
])
|
4775
|
-
], template: "<div class=\"overlay-content\" [@slideContent]=\"animationState\" (@slideContent.start)=\"onAnimationStart($event)\"\r\n
|
4791
|
+
], template: "<div class=\"overlay-content\" [@slideContent]=\"animationState\" (@slideContent.start)=\"onAnimationStart($event)\"\r\n [dir]=\"dir\" (@slideContent.done)=\"onAnimationDone($event)\">\r\n <div class=\"toolbar-wrapper\" fxLayout=\"row\" [@slideDown]=\"slideDown\" *ngIf=\"!loading\">\r\n <button mat-icon-button (click)=\"close()\" bizdocTooltip=\"{{'Back' | translate}}\"><mat-icon class=\"mat-icon-rtl-mirror\">keyboard_arrow_left</mat-icon></button>\r\n <span class=\"mat-body-1\">{{data.file.fileName}}</span>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"rotate()\" bizdocTooltip=\"{{'Rotate' | translate }}\"><mat-icon>screen_rotation</mat-icon></button>\r\n <button mat-icon-button (click)=\"download()\" bizdocTooltip=\"{{'Download' | translate}}\"><mat-icon>save_alt</mat-icon></button>\r\n </div>\r\n <div class=\"spinner-wrapper\" *ngIf=\"loading\">\r\n <mat-spinner></mat-spinner>\r\n </div>\r\n <object (load)=\"onLoad($event)\" [data]=\"objectData\" [type]=\"data.file.contentType\" *ngIf=\"!isImage\" #obj width=\"250\"\r\n height=\"200\">\r\n </object>\r\n <img *ngIf=\"isImage\" (load)=\"onLoad($event)\" [style.opacity]=\"loading ? 0 : 1\" [@fade]=\"loading ? 'fadeOut' : 'fadeIn'\" [src]=\"objectData\" #img>\r\n</div>\r\n", styles: [":host{display:flex;flex-direction:column;align-items:center}.spinner-wrapper{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:-1}img{width:100%;max-width:500px;height:auto}.overlay-content{padding:1em}.overlay-content .toolbar-wrapper{align-items:center;color:#f5f5f5}.divider{flex:1 1 auto}\n"] }]
|
4776
4792
|
}], ctorParameters: function () { return [{ type: i7$2.Directionality }, { type: i0.Renderer2 }, { type: undefined, decorators: [{
|
4777
4793
|
type: Inject,
|
4778
4794
|
args: [FILE_PREVIEW_DIALOG_DATA]
|
@@ -5355,10 +5371,10 @@ class FileInput {
|
|
5355
5371
|
}
|
5356
5372
|
FileInput.nextId = 0;
|
5357
5373
|
FileInput.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: FileInput, deps: [{ token: i0.ElementRef }, { token: MailboxService }, { token: i1$5.DomSanitizer }, { token: AttachmentInfo }, { token: TranslateService }, { token: SessionService }, { token: PromptService }, { token: i1$2.NgControl, optional: true, self: true }, { token: DOCUMENT_MODEL }], target: i0.ɵɵFactoryTarget.Component });
|
5358
|
-
FileInput.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", type: FileInput, selector: "bizdoc-file-upload", inputs: { multiple: "multiple", accept: "accept", icon: "icon", value: "value", placeholder: "placeholder", required: "required", disabled: "disabled" }, host: { listeners: { "document:drop": "handleDocumentDrop($event)", "drop": "handleDrop($event)", "dragenter": "handleEnter($event)", "dragleave": "handleLeave($event)", "dragover": "handleOver($event)" }, properties: { "id": "this.id", "attr.aria-describedby": "this.describedBy" }, classAttribute: "file-dropable" }, viewQueries: [{ propertyName: "_input", first: true, predicate: ["input"], descendants: true }], ngImport: i0, template: "<button mat-button *ngIf=\"!items; else preview\" (click)=\"prompt()\">\r\n <mat-icon class=\"filled\">{{icon}}</mat-icon>\r\n <span class=\"mat-h3\">{{placeholder}}</span>\r\n</button>\r\n<input type=\"file\" #input\r\n [accept]=accept [multiple]=multiple (change)='_change($event)' style=\"display: none\" />\r\n<ng-template #preview>\r\n <div *ngFor='let a of items' class=\"attachment-item\"\r\n [class.deleted]=\"a.deleted\" [class.failed]=\"a.failed\"\r\n [progressIndicator]=\"a.progress\">\r\n <img *ngIf=\"a.isImage\" [src]=\"a.url\" (click)=\"openPreview(a)\" height=\"80\" class=\"file-preview\">\r\n <div *ngIf=\"a.hasPreview && !a.isImage\" fxLayout=\"column\" class=\"file-preview\">\r\n <button mat-icon-button (click)=\"openPreview(a)\" [bizdocTooltip]=\"'Preview'|translate\"><mat-icon class=\"mat-icon-rtl-mirror\">find_in_page</mat-icon></button>\r\n <span>.{{a.fileExt}}</span>\r\n </div>\r\n <mat-icon *ngIf=\"a.icon\" [svgIcon]=\"a.icon\" [inline]=\"true\"></mat-icon>\r\n <div class=\"file-overlay row\">\r\n <span class=\"filename\">{{a.fileName}}</span>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button class=\"options\" [matMenuTriggerFor]=\"menu\" [bizdocTooltip]=\"'Options' | translate\">\r\n <mat-icon>more_vert</mat-icon>\r\n </button>\r\n </div>\r\n <mat-menu #menu>\r\n <ng-container *ngIf=\"!a.failed\">\r\n <ng-container *ngIf=\"canEdit(a) && !a.failed\">\r\n <ng-container *ngIf=\"!a.checkedOut\">\r\n <button mat-menu-item (click)=\"checkOut(a)\">{{\"CheckOut\" | translate}}</button>\r\n <button mat-menu-item (click)=\"prompt()\">{{\"Add\" | translate}}</button>\r\n </ng-container>\r\n <button mat-menu-item (click)=\"checkIn(a)\" *ngIf=\"a.checkedOut\">{{\"CheckIn\" | translate}}</button>\r\n </ng-container>\r\n <mat-divider></mat-divider>\r\n <button mat-menu-item (click)=\"download(a)\">{{\"Download\" | translate}}</button>\r\n <button mat-menu-item *ngIf=\"canPreview(a)\" (click)=\"openPreview(a)\"><mat-icon>landscape</mat-icon> {{\"Preview\" | translate}}</button>\r\n <ng-container *ngIf=\"hasVersion(a)\">\r\n <mat-divider></mat-divider>\r\n <button mat-menu-item *ngFor=\"let v of getVersions(a)\" (click)=\"previewOrDownload(v)\">{{v.time | amCalendar}}</button>\r\n </ng-container>\r\n <ng-container *ngIf=\"canEdit(a)\">\r\n <mat-divider></mat-divider>\r\n <button mat-menu-item (click)=\"discard(a)\">{{\"Discard\" | translate}}</button>\r\n </ng-container>\r\n </ng-container>\r\n <button mat-menu-item (click)=\"cancel(a)\" *ngIf=\"a.failed\">{{\"Cancel\" | translate}}</button>\r\n </mat-menu>\r\n </div>\r\n</ng-template>\r\n", styles: [":host{display:flex}.attachment-item{height:80px;position:relative}.attachment-item img{cursor:zoom-in}.attachment-item .file-preview{position:absolute}.attachment-item .file-overlay{position:relative;height:inherit}.attachment-item .file-overlay .filename{font-size:x-small;cursor:pointer;background:rgba(255,255,255,.4);align-self:flex-end}.attachment-item .file-overlay:hover .filename{background:white;opacity:.5}\n"], components: [{ type: i7$1.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i8.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i9.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { type: i9.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { type: i12$2.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }], directives: [{ type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i10.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: ProgressDirective, selector: "[progressIndicator]", inputs: ["progressIndicator"] }, { type: i6$1.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { type: TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }, { type: i9.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }], pipes: { "translate": TranslatePipe, "amCalendar": CalendarPipe } });
|
5374
|
+
FileInput.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", type: FileInput, selector: "bizdoc-file-upload", inputs: { multiple: "multiple", accept: "accept", icon: "icon", value: "value", placeholder: "placeholder", required: "required", disabled: "disabled" }, host: { listeners: { "document:drop": "handleDocumentDrop($event)", "drop": "handleDrop($event)", "dragenter": "handleEnter($event)", "dragleave": "handleLeave($event)", "dragover": "handleOver($event)" }, properties: { "id": "this.id", "attr.aria-describedby": "this.describedBy" }, classAttribute: "file-dropable" }, viewQueries: [{ propertyName: "_input", first: true, predicate: ["input"], descendants: true }], ngImport: i0, template: "<button mat-button *ngIf=\"!items; else preview\" (click)=\"prompt()\">\r\n <mat-icon class=\"filled\">{{icon}}</mat-icon>\r\n <span class=\"mat-h3\">{{placeholder}}</span>\r\n</button>\r\n<input type=\"file\" #input\r\n [accept]=accept [multiple]=multiple (change)='_change($event)' style=\"display: none\" />\r\n<ng-template #preview>\r\n <div *ngFor='let a of items' class=\"attachment-item\"\r\n [class.deleted]=\"a.deleted\" [class.failed]=\"a.failed\"\r\n [progressIndicator]=\"a.progress\">\r\n <img *ngIf=\"a.isImage\" [src]=\"a.url\" (click)=\"openPreview(a)\" height=\"80\" class=\"file-preview\">\r\n <div *ngIf=\"a.hasPreview && !a.isImage\" fxLayout=\"column\" class=\"file-preview\">\r\n <button mat-icon-button (click)=\"openPreview(a)\" [bizdocTooltip]=\"'Preview'|translate\"><mat-icon class=\"mat-icon-rtl-mirror\">find_in_page</mat-icon></button>\r\n <span>.{{a.fileExt}}</span>\r\n </div>\r\n <mat-icon *ngIf=\"a.icon\" [svgIcon]=\"a.icon\" [inline]=\"true\"></mat-icon>\r\n <div class=\"file-overlay row\">\r\n <span class=\"filename\">{{a.fileName}}</span>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button class=\"options\" [matMenuTriggerFor]=\"menu\" [bizdocTooltip]=\"'Options' | translate\">\r\n <mat-icon>more_vert</mat-icon>\r\n </button>\r\n </div>\r\n <mat-menu #menu>\r\n <ng-container *ngIf=\"!a.failed\">\r\n <ng-container *ngIf=\"canEdit(a) && !a.failed\">\r\n <ng-container *ngIf=\"!a.checkedOut\">\r\n <button mat-menu-item (click)=\"checkOut(a)\">{{\"CheckOut\" | translate}}</button>\r\n <button mat-menu-item (click)=\"prompt()\" *ngIf=\"multiple\">{{\"Add\" | translate}}</button>\r\n </ng-container>\r\n <button mat-menu-item (click)=\"checkIn(a)\" *ngIf=\"a.checkedOut\">{{\"CheckIn\" | translate}}</button>\r\n </ng-container>\r\n <mat-divider></mat-divider>\r\n <button mat-menu-item (click)=\"download(a)\">{{\"Download\" | translate}}</button>\r\n <button mat-menu-item *ngIf=\"canPreview(a)\" (click)=\"openPreview(a)\"><mat-icon>landscape</mat-icon> {{\"Preview\" | translate}}</button>\r\n <ng-container *ngIf=\"hasVersion(a)\">\r\n <mat-divider></mat-divider>\r\n <button mat-menu-item *ngFor=\"let v of getVersions(a)\" (click)=\"previewOrDownload(v)\">{{v.time | amCalendar}}</button>\r\n </ng-container>\r\n <ng-container *ngIf=\"canEdit(a)\">\r\n <mat-divider></mat-divider>\r\n <button mat-menu-item (click)=\"discard(a)\">{{\"Discard\" | translate}}</button>\r\n </ng-container>\r\n </ng-container>\r\n <button mat-menu-item (click)=\"cancel(a)\" *ngIf=\"a.failed\">{{\"Cancel\" | translate}}</button>\r\n </mat-menu>\r\n </div>\r\n</ng-template>\r\n", styles: [":host{display:flex}.attachment-item{height:80px;position:relative}.attachment-item img{cursor:zoom-in}.attachment-item .file-preview{position:absolute}.attachment-item .file-overlay{position:relative;height:inherit}.attachment-item .file-overlay .filename{font-size:x-small;cursor:pointer;background:rgba(255,255,255,.4);align-self:flex-end}.attachment-item .file-overlay:hover .filename{background:white;opacity:.5}\n"], components: [{ type: i7$1.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i8.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i9.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { type: i9.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { type: i12$2.MatDivider, selector: "mat-divider", inputs: ["vertical", "inset"] }], directives: [{ type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i10.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: ProgressDirective, selector: "[progressIndicator]", inputs: ["progressIndicator"] }, { type: i6$1.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { type: TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }, { type: i9.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }], pipes: { "translate": TranslatePipe, "amCalendar": CalendarPipe } });
|
5359
5375
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: FileInput, decorators: [{
|
5360
5376
|
type: Component,
|
5361
|
-
args: [{ host: { class: 'file-dropable' }, selector: 'bizdoc-file-upload', template: "<button mat-button *ngIf=\"!items; else preview\" (click)=\"prompt()\">\r\n <mat-icon class=\"filled\">{{icon}}</mat-icon>\r\n <span class=\"mat-h3\">{{placeholder}}</span>\r\n</button>\r\n<input type=\"file\" #input\r\n [accept]=accept [multiple]=multiple (change)='_change($event)' style=\"display: none\" />\r\n<ng-template #preview>\r\n <div *ngFor='let a of items' class=\"attachment-item\"\r\n [class.deleted]=\"a.deleted\" [class.failed]=\"a.failed\"\r\n [progressIndicator]=\"a.progress\">\r\n <img *ngIf=\"a.isImage\" [src]=\"a.url\" (click)=\"openPreview(a)\" height=\"80\" class=\"file-preview\">\r\n <div *ngIf=\"a.hasPreview && !a.isImage\" fxLayout=\"column\" class=\"file-preview\">\r\n <button mat-icon-button (click)=\"openPreview(a)\" [bizdocTooltip]=\"'Preview'|translate\"><mat-icon class=\"mat-icon-rtl-mirror\">find_in_page</mat-icon></button>\r\n <span>.{{a.fileExt}}</span>\r\n </div>\r\n <mat-icon *ngIf=\"a.icon\" [svgIcon]=\"a.icon\" [inline]=\"true\"></mat-icon>\r\n <div class=\"file-overlay row\">\r\n <span class=\"filename\">{{a.fileName}}</span>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button class=\"options\" [matMenuTriggerFor]=\"menu\" [bizdocTooltip]=\"'Options' | translate\">\r\n <mat-icon>more_vert</mat-icon>\r\n </button>\r\n </div>\r\n <mat-menu #menu>\r\n <ng-container *ngIf=\"!a.failed\">\r\n <ng-container *ngIf=\"canEdit(a) && !a.failed\">\r\n <ng-container *ngIf=\"!a.checkedOut\">\r\n <button mat-menu-item (click)=\"checkOut(a)\">{{\"CheckOut\" | translate}}</button>\r\n <button mat-menu-item (click)=\"prompt()\">{{\"Add\" | translate}}</button>\r\n </ng-container>\r\n <button mat-menu-item (click)=\"checkIn(a)\" *ngIf=\"a.checkedOut\">{{\"CheckIn\" | translate}}</button>\r\n </ng-container>\r\n <mat-divider></mat-divider>\r\n <button mat-menu-item (click)=\"download(a)\">{{\"Download\" | translate}}</button>\r\n <button mat-menu-item *ngIf=\"canPreview(a)\" (click)=\"openPreview(a)\"><mat-icon>landscape</mat-icon> {{\"Preview\" | translate}}</button>\r\n <ng-container *ngIf=\"hasVersion(a)\">\r\n <mat-divider></mat-divider>\r\n <button mat-menu-item *ngFor=\"let v of getVersions(a)\" (click)=\"previewOrDownload(v)\">{{v.time | amCalendar}}</button>\r\n </ng-container>\r\n <ng-container *ngIf=\"canEdit(a)\">\r\n <mat-divider></mat-divider>\r\n <button mat-menu-item (click)=\"discard(a)\">{{\"Discard\" | translate}}</button>\r\n </ng-container>\r\n </ng-container>\r\n <button mat-menu-item (click)=\"cancel(a)\" *ngIf=\"a.failed\">{{\"Cancel\" | translate}}</button>\r\n </mat-menu>\r\n </div>\r\n</ng-template>\r\n", styles: [":host{display:flex}.attachment-item{height:80px;position:relative}.attachment-item img{cursor:zoom-in}.attachment-item .file-preview{position:absolute}.attachment-item .file-overlay{position:relative;height:inherit}.attachment-item .file-overlay .filename{font-size:x-small;cursor:pointer;background:rgba(255,255,255,.4);align-self:flex-end}.attachment-item .file-overlay:hover .filename{background:white;opacity:.5}\n"] }]
|
5377
|
+
args: [{ host: { class: 'file-dropable' }, selector: 'bizdoc-file-upload', template: "<button mat-button *ngIf=\"!items; else preview\" (click)=\"prompt()\">\r\n <mat-icon class=\"filled\">{{icon}}</mat-icon>\r\n <span class=\"mat-h3\">{{placeholder}}</span>\r\n</button>\r\n<input type=\"file\" #input\r\n [accept]=accept [multiple]=multiple (change)='_change($event)' style=\"display: none\" />\r\n<ng-template #preview>\r\n <div *ngFor='let a of items' class=\"attachment-item\"\r\n [class.deleted]=\"a.deleted\" [class.failed]=\"a.failed\"\r\n [progressIndicator]=\"a.progress\">\r\n <img *ngIf=\"a.isImage\" [src]=\"a.url\" (click)=\"openPreview(a)\" height=\"80\" class=\"file-preview\">\r\n <div *ngIf=\"a.hasPreview && !a.isImage\" fxLayout=\"column\" class=\"file-preview\">\r\n <button mat-icon-button (click)=\"openPreview(a)\" [bizdocTooltip]=\"'Preview'|translate\"><mat-icon class=\"mat-icon-rtl-mirror\">find_in_page</mat-icon></button>\r\n <span>.{{a.fileExt}}</span>\r\n </div>\r\n <mat-icon *ngIf=\"a.icon\" [svgIcon]=\"a.icon\" [inline]=\"true\"></mat-icon>\r\n <div class=\"file-overlay row\">\r\n <span class=\"filename\">{{a.fileName}}</span>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button class=\"options\" [matMenuTriggerFor]=\"menu\" [bizdocTooltip]=\"'Options' | translate\">\r\n <mat-icon>more_vert</mat-icon>\r\n </button>\r\n </div>\r\n <mat-menu #menu>\r\n <ng-container *ngIf=\"!a.failed\">\r\n <ng-container *ngIf=\"canEdit(a) && !a.failed\">\r\n <ng-container *ngIf=\"!a.checkedOut\">\r\n <button mat-menu-item (click)=\"checkOut(a)\">{{\"CheckOut\" | translate}}</button>\r\n <button mat-menu-item (click)=\"prompt()\" *ngIf=\"multiple\">{{\"Add\" | translate}}</button>\r\n </ng-container>\r\n <button mat-menu-item (click)=\"checkIn(a)\" *ngIf=\"a.checkedOut\">{{\"CheckIn\" | translate}}</button>\r\n </ng-container>\r\n <mat-divider></mat-divider>\r\n <button mat-menu-item (click)=\"download(a)\">{{\"Download\" | translate}}</button>\r\n <button mat-menu-item *ngIf=\"canPreview(a)\" (click)=\"openPreview(a)\"><mat-icon>landscape</mat-icon> {{\"Preview\" | translate}}</button>\r\n <ng-container *ngIf=\"hasVersion(a)\">\r\n <mat-divider></mat-divider>\r\n <button mat-menu-item *ngFor=\"let v of getVersions(a)\" (click)=\"previewOrDownload(v)\">{{v.time | amCalendar}}</button>\r\n </ng-container>\r\n <ng-container *ngIf=\"canEdit(a)\">\r\n <mat-divider></mat-divider>\r\n <button mat-menu-item (click)=\"discard(a)\">{{\"Discard\" | translate}}</button>\r\n </ng-container>\r\n </ng-container>\r\n <button mat-menu-item (click)=\"cancel(a)\" *ngIf=\"a.failed\">{{\"Cancel\" | translate}}</button>\r\n </mat-menu>\r\n </div>\r\n</ng-template>\r\n", styles: [":host{display:flex}.attachment-item{height:80px;position:relative}.attachment-item img{cursor:zoom-in}.attachment-item .file-preview{position:absolute}.attachment-item .file-overlay{position:relative;height:inherit}.attachment-item .file-overlay .filename{font-size:x-small;cursor:pointer;background:rgba(255,255,255,.4);align-self:flex-end}.attachment-item .file-overlay:hover .filename{background:white;opacity:.5}\n"] }]
|
5362
5378
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: MailboxService }, { type: i1$5.DomSanitizer }, { type: AttachmentInfo }, { type: TranslateService }, { type: SessionService }, { type: PromptService }, { type: i1$2.NgControl, decorators: [{
|
5363
5379
|
type: Optional
|
5364
5380
|
}, {
|
@@ -6585,6 +6601,17 @@ function modelize() {
|
|
6585
6601
|
});
|
6586
6602
|
return data;
|
6587
6603
|
}));
|
6604
|
+
}
|
6605
|
+
function errResource(error) {
|
6606
|
+
switch (error.status) {
|
6607
|
+
case 401:
|
6608
|
+
return 'Unauthorized';
|
6609
|
+
case 426:
|
6610
|
+
return 'LicenseErr';
|
6611
|
+
case 406:
|
6612
|
+
return 'Unauthorized';
|
6613
|
+
}
|
6614
|
+
return null;
|
6588
6615
|
}
|
6589
6616
|
|
6590
6617
|
class ArraySortPipe {
|
@@ -9464,7 +9491,7 @@ class CubeAccumulationChartComponent {
|
|
9464
9491
|
this._draw();
|
9465
9492
|
this.loadingChange.emit(false);
|
9466
9493
|
}, (e) => {
|
9467
|
-
this._sb.error(e
|
9494
|
+
this._sb.error(errResource(e));
|
9468
9495
|
this.loadingChange.emit(false);
|
9469
9496
|
});
|
9470
9497
|
}
|
@@ -9718,7 +9745,7 @@ class CubeChartComponent {
|
|
9718
9745
|
this._draw();
|
9719
9746
|
this.loadingChange.emit(false);
|
9720
9747
|
}, (e) => {
|
9721
|
-
this._sb.error(e
|
9748
|
+
this._sb.error(errResource(e));
|
9722
9749
|
this.loadingChange.emit(false);
|
9723
9750
|
});
|
9724
9751
|
}
|
@@ -10009,7 +10036,7 @@ class CubeGridComponent {
|
|
10009
10036
|
this.loadingChange.emit(false);
|
10010
10037
|
});
|
10011
10038
|
}, (e) => {
|
10012
|
-
this._sb.error(e
|
10039
|
+
this._sb.error(errResource(e));
|
10013
10040
|
this.loadingChange.emit(false);
|
10014
10041
|
});
|
10015
10042
|
}
|
@@ -10315,7 +10342,7 @@ class CubePivotComponent {
|
|
10315
10342
|
this._draw();
|
10316
10343
|
this.loadingChange.emit(false);
|
10317
10344
|
}, (e) => {
|
10318
|
-
this._sb.error(e
|
10345
|
+
this._sb.error(errResource(e));
|
10319
10346
|
this.loadingChange.emit(false);
|
10320
10347
|
});
|
10321
10348
|
}
|
@@ -10694,18 +10721,20 @@ class CubeSpreadsheetComponent {
|
|
10694
10721
|
this._draw();
|
10695
10722
|
this.loadingChange.emit(false);
|
10696
10723
|
});
|
10697
|
-
}, e =>
|
10724
|
+
}, e => {
|
10725
|
+
this._sb.error(errResource(e));
|
10726
|
+
this.loadingChange.emit(false);
|
10727
|
+
});
|
10698
10728
|
else
|
10699
10729
|
this._service.table(this._cube.name, this._xAxis, { filters: this.filters, indices: this._indices }).
|
10700
10730
|
subscribe(data => {
|
10701
10731
|
this._datatable(data);
|
10702
10732
|
this._draw();
|
10703
10733
|
this.loadingChange.emit(false);
|
10704
|
-
}, e =>
|
10705
|
-
|
10706
|
-
|
10707
|
-
|
10708
|
-
this.loadingChange.emit(false);
|
10734
|
+
}, e => {
|
10735
|
+
this._sb.error(errResource(e));
|
10736
|
+
this.loadingChange.emit(false);
|
10737
|
+
});
|
10709
10738
|
}
|
10710
10739
|
_datatable(data) {
|
10711
10740
|
const cells = [], style = { fontWeight: 'bold', textAlign: 'center' };
|
@@ -10819,7 +10848,7 @@ class CubeSpreadsheetComponent {
|
|
10819
10848
|
return;
|
10820
10849
|
this._fillx(x, x1, axes);
|
10821
10850
|
}
|
10822
|
-
else if (this._indices && y <= this._indices.length
|
10851
|
+
else if (this._indices && y <= this._indices.length) {
|
10823
10852
|
index = this._indices[y - 1];
|
10824
10853
|
this._fillx(x, x1, axes);
|
10825
10854
|
}
|
@@ -11264,12 +11293,12 @@ class CubeViewPaneComponent extends ViewBase {
|
|
11264
11293
|
}
|
11265
11294
|
}
|
11266
11295
|
CubeViewPaneComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: CubeViewPaneComponent, deps: [{ token: SessionService }, { token: PaneRef }, { token: Popup }, { token: RouterImpl }, { token: CubeService }, { token: GuideService }], target: i0.ɵɵFactoryTarget.Component });
|
11267
|
-
CubeViewPaneComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", type: CubeViewPaneComponent, selector: "ng-component", host: { listeners: { "window:keydown.f1": "guide($event)" }, classAttribute: "pane" }, viewQueries: [{ propertyName: "viewPane", first: true, predicate: CubeViewComponent, descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<mat-toolbar class=\"nav-toolbar\">\r\n <button mat-icon-button (click)=\"guide()\" [bizdocTooltip]=\"'Help' | translate\" *ngIf=\"view.guide\"><mat-icon>help_outline</mat-icon></button>\r\n <button mat-icon-button (click)=\"vp.refresh()\" [bizdocTooltip]=\"'Refresh' | translate\"><mat-icon matAnimate=\"rotate\">autorenew</mat-icon></button>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button [bizdocTooltip]=\"'Download' | translate\"\r\n data-help=\"download\" (click)=\"vp.exportToExcel()\">\r\n <mat-icon>save_alt</mat-icon>\r\n </button>\r\n <button mat-icon-button [matMenuTriggerFor]=\"pmenu\" [bizdocTooltip]=\"'Patterns' | translate\" [disabled]=\"!patterns?.length\" data-help=\"pattern\"><mat-icon [class.filled]=\"pattern\">
|
11296
|
+
CubeViewPaneComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", type: CubeViewPaneComponent, selector: "ng-component", host: { listeners: { "window:keydown.f1": "guide($event)" }, classAttribute: "pane" }, viewQueries: [{ propertyName: "viewPane", first: true, predicate: CubeViewComponent, descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<mat-toolbar class=\"nav-toolbar\">\r\n <button mat-icon-button (click)=\"guide()\" [bizdocTooltip]=\"'Help' | translate\" *ngIf=\"view.guide\"><mat-icon>help_outline</mat-icon></button>\r\n <button mat-icon-button (click)=\"vp.refresh()\" [bizdocTooltip]=\"'Refresh' | translate\"><mat-icon matAnimate=\"rotate\">autorenew</mat-icon></button>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button [bizdocTooltip]=\"'Download' | translate\"\r\n data-help=\"download\" (click)=\"vp.exportToExcel()\">\r\n <mat-icon>save_alt</mat-icon>\r\n </button>\r\n <button mat-icon-button [matMenuTriggerFor]=\"pmenu\" [bizdocTooltip]=\"'Patterns' | translate\" [disabled]=\"!patterns?.length\" data-help=\"pattern\"><mat-icon [class.filled]=\"pattern\">tune</mat-icon></button>\r\n <mat-menu #pmenu>\r\n <button mat-menu-item *ngFor=\"let p of patterns\" (click)=\"patternChange(p)\">\r\n {{p.title}}\r\n </button>\r\n </mat-menu>\r\n <button mat-icon-button (click)=\"clearFilter()\" [bizdocTooltip]=\"'Clear' | translate\" [disabled]=\"!anyFilters\"><mat-icon>clear_all</mat-icon></button>\r\n <button mat-icon-button (click)=\"filterToggle($event)\" [bizdocTooltip]=\"'Filter' | translate\" [disabled]=\"!anyAxes\" data-help=\"filter\"><mat-icon [class.filled]=\"anyFilters\">filter_list</mat-icon></button>\r\n</mat-toolbar>\r\n<mat-progress-bar mode=\"query\" [style.visibility]=\"loading ? 'visible':'hidden'\"></mat-progress-bar>\r\n<!--<bizdoc-cube-tags [(filters)]=\"axes\" [cube]=\"cube\"></bizdoc-cube-tags>-->\r\n<bizdoc-cube-view [filters]=\"axes\" #vp\r\n (explore)=\"explore($event)\"\r\n [cube]=\"cube\"\r\n [view]=\"view\"\r\n [(loading)]=\"loading\"></bizdoc-cube-view>\r\n<!--<ng-lottie options=\"{path: 'assets/8318-loader.json'}\" *ngIf=\"loading\"></ng-lottie>-->\r\n", styles: [":host{display:flex;flex-direction:column;height:100%}:host ::ng-deep .cube-view{flex:1 auto}\n"], components: [{ type: i7$3.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { type: i7$1.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i8.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i9.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { type: i9.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { type: i11.MatProgressBar, selector: "mat-progress-bar", inputs: ["color", "value", "bufferValue", "mode"], outputs: ["animationEnd"], exportAs: ["matProgressBar"] }, { type: CubeViewComponent, selector: "bizdoc-cube-view", inputs: ["filters", "cube", "view", "loading"], outputs: ["explore", "loadingChange"] }], directives: [{ type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }, { type: MatIconAnimate, selector: "[matAnimate]" }, { type: i9.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { type: i10.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "translate": TranslatePipe } });
|
11268
11297
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: CubeViewPaneComponent, decorators: [{
|
11269
11298
|
type: Component,
|
11270
11299
|
args: [{ host: {
|
11271
11300
|
class: 'pane'
|
11272
|
-
}, template: "<mat-toolbar class=\"nav-toolbar\">\r\n <button mat-icon-button (click)=\"guide()\" [bizdocTooltip]=\"'Help' | translate\" *ngIf=\"view.guide\"><mat-icon>help_outline</mat-icon></button>\r\n <button mat-icon-button (click)=\"vp.refresh()\" [bizdocTooltip]=\"'Refresh' | translate\"><mat-icon matAnimate=\"rotate\">autorenew</mat-icon></button>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button [bizdocTooltip]=\"'Download' | translate\"\r\n data-help=\"download\" (click)=\"vp.exportToExcel()\">\r\n <mat-icon>save_alt</mat-icon>\r\n </button>\r\n <button mat-icon-button [matMenuTriggerFor]=\"pmenu\" [bizdocTooltip]=\"'Patterns' | translate\" [disabled]=\"!patterns?.length\" data-help=\"pattern\"><mat-icon [class.filled]=\"pattern\">
|
11301
|
+
}, template: "<mat-toolbar class=\"nav-toolbar\">\r\n <button mat-icon-button (click)=\"guide()\" [bizdocTooltip]=\"'Help' | translate\" *ngIf=\"view.guide\"><mat-icon>help_outline</mat-icon></button>\r\n <button mat-icon-button (click)=\"vp.refresh()\" [bizdocTooltip]=\"'Refresh' | translate\"><mat-icon matAnimate=\"rotate\">autorenew</mat-icon></button>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button [bizdocTooltip]=\"'Download' | translate\"\r\n data-help=\"download\" (click)=\"vp.exportToExcel()\">\r\n <mat-icon>save_alt</mat-icon>\r\n </button>\r\n <button mat-icon-button [matMenuTriggerFor]=\"pmenu\" [bizdocTooltip]=\"'Patterns' | translate\" [disabled]=\"!patterns?.length\" data-help=\"pattern\"><mat-icon [class.filled]=\"pattern\">tune</mat-icon></button>\r\n <mat-menu #pmenu>\r\n <button mat-menu-item *ngFor=\"let p of patterns\" (click)=\"patternChange(p)\">\r\n {{p.title}}\r\n </button>\r\n </mat-menu>\r\n <button mat-icon-button (click)=\"clearFilter()\" [bizdocTooltip]=\"'Clear' | translate\" [disabled]=\"!anyFilters\"><mat-icon>clear_all</mat-icon></button>\r\n <button mat-icon-button (click)=\"filterToggle($event)\" [bizdocTooltip]=\"'Filter' | translate\" [disabled]=\"!anyAxes\" data-help=\"filter\"><mat-icon [class.filled]=\"anyFilters\">filter_list</mat-icon></button>\r\n</mat-toolbar>\r\n<mat-progress-bar mode=\"query\" [style.visibility]=\"loading ? 'visible':'hidden'\"></mat-progress-bar>\r\n<!--<bizdoc-cube-tags [(filters)]=\"axes\" [cube]=\"cube\"></bizdoc-cube-tags>-->\r\n<bizdoc-cube-view [filters]=\"axes\" #vp\r\n (explore)=\"explore($event)\"\r\n [cube]=\"cube\"\r\n [view]=\"view\"\r\n [(loading)]=\"loading\"></bizdoc-cube-view>\r\n<!--<ng-lottie options=\"{path: 'assets/8318-loader.json'}\" *ngIf=\"loading\"></ng-lottie>-->\r\n", styles: [":host{display:flex;flex-direction:column;height:100%}:host ::ng-deep .cube-view{flex:1 auto}\n"] }]
|
11273
11302
|
}], ctorParameters: function () { return [{ type: SessionService }, { type: PaneRef }, { type: Popup }, { type: RouterImpl }, { type: CubeService }, { type: GuideService }]; }, propDecorators: { viewPane: [{
|
11274
11303
|
type: ViewChild,
|
11275
11304
|
args: [CubeViewComponent, { static: true }]
|
@@ -15329,7 +15358,7 @@ class CubeMatrixComponent {
|
|
15329
15358
|
clearTimeout(progressTask);
|
15330
15359
|
this.loadingChange.next(this.loading = false);
|
15331
15360
|
}, (e) => {
|
15332
|
-
this._sb.error(e
|
15361
|
+
this._sb.error(errResource(e));
|
15333
15362
|
clearTimeout(progressTask);
|
15334
15363
|
this.loadingChange.next(this.loading = false);
|
15335
15364
|
this.loadingChange.error(e);
|
@@ -15492,6 +15521,8 @@ class CubeMatrixComponent {
|
|
15492
15521
|
});
|
15493
15522
|
}
|
15494
15523
|
_format(val, options) {
|
15524
|
+
if (val === 0)
|
15525
|
+
return '0';
|
15495
15526
|
if (options) {
|
15496
15527
|
if (options.format === 'percent')
|
15497
15528
|
return formatPercent(val, this.LANGUAGE, options.precision || this.PRECISION);
|
@@ -15614,10 +15645,10 @@ class CubeMatrixComponent {
|
|
15614
15645
|
}
|
15615
15646
|
}
|
15616
15647
|
CubeMatrixComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: CubeMatrixComponent, deps: [{ token: PromptService }, { token: CubeService }, { token: SessionService }, { token: TranslateService }, { token: DatasourceService }], target: i0.ɵɵFactoryTarget.Component });
|
15617
|
-
CubeMatrixComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", type: CubeMatrixComponent, selector: "bizdoc-cube-matrix", inputs: { seriesTotalLabel: "seriesTotalLabel", xAxisTotalLabel: "xAxisTotalLabel", _cube: ["cube", "_cube"], _xAxis: ["xAxis", "_xAxis"], _series: ["series", "_series"], _indices: ["indices", "_indices"], indexAt: "indexAt", placeAt: "placeAt", scope: "scope", sum: "sum", filters: "filters", loading: "loading", interactive: "interactive" }, outputs: { onExplore: "explore", loadingChange: "loadingChange" }, viewQueries: [{ propertyName: "tableElement", first: true, predicate: ["table"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<table #table class=\"mat-table cube-table\" (mouseleave)=\"_move(-1, -1)\" *ngIf=\"data\">\r\n <thead>\r\n <!-- headers -->\r\n <tr class=\"mat-header-row\">\r\n <th></th>\r\n <th *ngFor=\"let column of columns; let x = index\"\r\n (mouseenter)=\"_move(x + 1, -2)\" class=\"mat-header-cell\">\r\n {{ column.value }}\r\n </th>\r\n <th class=\"mat-header-cell\">{{xAxisTotalLabel}}</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <!-- rows -->\r\n <tr *ngFor=\"let row of rows; let y = index\" class=\"mat-row\"\r\n [class.cube-index]=\"row.index\">\r\n <th class=\"mat-header-cell\" (mouseenter)=\"_move(-2, y )\">{{ row.value }}</th>\r\n <td *ngFor=\"let column of columns; let x = index\" class=\"mat-cell figure\"\r\n [class.explorable]=\"interactive && column.explorable !== false && row.explorable !== false\"\r\n (
|
15648
|
+
CubeMatrixComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", type: CubeMatrixComponent, selector: "bizdoc-cube-matrix", inputs: { seriesTotalLabel: "seriesTotalLabel", xAxisTotalLabel: "xAxisTotalLabel", _cube: ["cube", "_cube"], _xAxis: ["xAxis", "_xAxis"], _series: ["series", "_series"], _indices: ["indices", "_indices"], indexAt: "indexAt", placeAt: "placeAt", scope: "scope", sum: "sum", filters: "filters", loading: "loading", interactive: "interactive" }, outputs: { onExplore: "explore", loadingChange: "loadingChange" }, viewQueries: [{ propertyName: "tableElement", first: true, predicate: ["table"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<table #table class=\"mat-table cube-table\" (mouseleave)=\"_move(-1, -1)\" *ngIf=\"data\">\r\n <thead>\r\n <!-- headers -->\r\n <tr class=\"mat-header-row\">\r\n <th></th>\r\n <th *ngFor=\"let column of columns; let x = index\"\r\n (mouseenter)=\"_move(x + 1, -2)\" class=\"mat-header-cell\">\r\n {{ column.value }}\r\n </th>\r\n <th class=\"mat-header-cell\">{{xAxisTotalLabel}}</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <!-- rows -->\r\n <tr *ngFor=\"let row of rows; let y = index\" class=\"mat-row\"\r\n [class.cube-index]=\"row.index\">\r\n <th class=\"mat-header-cell\" (mouseenter)=\"_move(-2, y )\">{{ row.value }}</th>\r\n <td *ngFor=\"let column of columns; let x = index\" class=\"mat-cell figure\"\r\n (mouseenter)=\"_move(x + 1, y )\">\r\n <span *ngIf=\"data[row.key][column.key] !== '0'; else zero\" \r\n [class.explorable]=\"interactive && column.explorable !== false && row.explorable !== false\"\r\n (click)=\"explore(column, row)\">\r\n {{ data[row.key][column.key] }}\r\n </span>\r\n </td>\r\n <th class=\"mat-cell figure\" (mouseenter)=\"_move(-1, y )\">\r\n {{ data[row.key]['_total'] }}\r\n </th>\r\n </tr>\r\n </tbody>\r\n <tfoot>\r\n <!-- footer -->\r\n <tr class=\"mat-footer-row\">\r\n <td class=\"mat-footer-cell\">{{seriesTotalLabel}}</td>\r\n <td *ngFor=\"let column of columns; let x = index\" class=\"mat-footer-cell figure\"\r\n (mouseenter)=\"_move(x + 1, -2)\"\r\n [class.negative-figure]=\"totals[column.key].startsWith('-')\">\r\n <ng-container *ngIf=\"totals[column.key] !== undefined\">\r\n {{ totals[column.key] }}\r\n </ng-container>\r\n </td>\r\n <th class=\"mat-footer-cell figure\">{{ totals['_grand'] }}</th>\r\n </tr>\r\n </tfoot>\r\n</table>\r\n<ng-template #zero>0</ng-template>\r\n", styles: [".explorable{cursor:pointer}.cube-table{width:100%;table-layout:fixed}.cube-table th{cursor:default}.cube-table th.figure{font-weight:500}.cube-table td,.cube-table th{padding-right:8px}\n"], directives: [{ type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i10.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], animations: [matrixAnimation] });
|
15618
15649
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: CubeMatrixComponent, decorators: [{
|
15619
15650
|
type: Component,
|
15620
|
-
args: [{ selector: 'bizdoc-cube-matrix', animations: [matrixAnimation], template: "<table #table class=\"mat-table cube-table\" (mouseleave)=\"_move(-1, -1)\" *ngIf=\"data\">\r\n <thead>\r\n <!-- headers -->\r\n <tr class=\"mat-header-row\">\r\n <th></th>\r\n <th *ngFor=\"let column of columns; let x = index\"\r\n (mouseenter)=\"_move(x + 1, -2)\" class=\"mat-header-cell\">\r\n {{ column.value }}\r\n </th>\r\n <th class=\"mat-header-cell\">{{xAxisTotalLabel}}</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <!-- rows -->\r\n <tr *ngFor=\"let row of rows; let y = index\" class=\"mat-row\"\r\n [class.cube-index]=\"row.index\">\r\n <th class=\"mat-header-cell\" (mouseenter)=\"_move(-2, y )\">{{ row.value }}</th>\r\n <td *ngFor=\"let column of columns; let x = index\" class=\"mat-cell figure\"\r\n [class.explorable]=\"interactive && column.explorable !== false && row.explorable !== false\"\r\n (
|
15651
|
+
args: [{ selector: 'bizdoc-cube-matrix', animations: [matrixAnimation], template: "<table #table class=\"mat-table cube-table\" (mouseleave)=\"_move(-1, -1)\" *ngIf=\"data\">\r\n <thead>\r\n <!-- headers -->\r\n <tr class=\"mat-header-row\">\r\n <th></th>\r\n <th *ngFor=\"let column of columns; let x = index\"\r\n (mouseenter)=\"_move(x + 1, -2)\" class=\"mat-header-cell\">\r\n {{ column.value }}\r\n </th>\r\n <th class=\"mat-header-cell\">{{xAxisTotalLabel}}</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <!-- rows -->\r\n <tr *ngFor=\"let row of rows; let y = index\" class=\"mat-row\"\r\n [class.cube-index]=\"row.index\">\r\n <th class=\"mat-header-cell\" (mouseenter)=\"_move(-2, y )\">{{ row.value }}</th>\r\n <td *ngFor=\"let column of columns; let x = index\" class=\"mat-cell figure\"\r\n (mouseenter)=\"_move(x + 1, y )\">\r\n <span *ngIf=\"data[row.key][column.key] !== '0'; else zero\" \r\n [class.explorable]=\"interactive && column.explorable !== false && row.explorable !== false\"\r\n (click)=\"explore(column, row)\">\r\n {{ data[row.key][column.key] }}\r\n </span>\r\n </td>\r\n <th class=\"mat-cell figure\" (mouseenter)=\"_move(-1, y )\">\r\n {{ data[row.key]['_total'] }}\r\n </th>\r\n </tr>\r\n </tbody>\r\n <tfoot>\r\n <!-- footer -->\r\n <tr class=\"mat-footer-row\">\r\n <td class=\"mat-footer-cell\">{{seriesTotalLabel}}</td>\r\n <td *ngFor=\"let column of columns; let x = index\" class=\"mat-footer-cell figure\"\r\n (mouseenter)=\"_move(x + 1, -2)\"\r\n [class.negative-figure]=\"totals[column.key].startsWith('-')\">\r\n <ng-container *ngIf=\"totals[column.key] !== undefined\">\r\n {{ totals[column.key] }}\r\n </ng-container>\r\n </td>\r\n <th class=\"mat-footer-cell figure\">{{ totals['_grand'] }}</th>\r\n </tr>\r\n </tfoot>\r\n</table>\r\n<ng-template #zero>0</ng-template>\r\n", styles: [".explorable{cursor:pointer}.cube-table{width:100%;table-layout:fixed}.cube-table th{cursor:default}.cube-table th.figure{font-weight:500}.cube-table td,.cube-table th{padding-right:8px}\n"] }]
|
15621
15652
|
}], ctorParameters: function () { return [{ type: PromptService }, { type: CubeService }, { type: SessionService }, { type: TranslateService }, { type: DatasourceService }]; }, propDecorators: { tableElement: [{
|
15622
15653
|
type: ViewChild,
|
15623
15654
|
args: ['table']
|
@@ -17697,10 +17728,10 @@ class AppHttpInterceptor {
|
|
17697
17728
|
if (this._authenticating)
|
17698
17729
|
return this._authenticating;
|
17699
17730
|
else if (e.status === 401) {
|
17700
|
-
this._session.ok && this._router.navigate(['broken']);
|
17731
|
+
//this._session.ok && this._router.navigate(['broken']);
|
17701
17732
|
this._authenticating = this._auth.authorize().pipe(switchMap$1(() => {
|
17702
17733
|
this._authenticating = null;
|
17703
|
-
this._session.ok && history.back();
|
17734
|
+
//this._session.ok && history.back();
|
17704
17735
|
return forward();
|
17705
17736
|
}));
|
17706
17737
|
return this._authenticating;
|
@@ -20142,9 +20173,11 @@ class ReportComponent {
|
|
20142
20173
|
this._route.params.pipe(takeUntil(this._destroy)).subscribe(p => {
|
20143
20174
|
const id = p['id'];
|
20144
20175
|
this.report = this._session.profile.reports.find(r => r.name === id);
|
20176
|
+
this.hasFilters = (this.report.arguments && this.report.arguments.length > 0) || this.report.argumentsTemplate !== undefined;
|
20145
20177
|
this._cd.detectChanges();
|
20146
20178
|
this._title.set(this.report.title);
|
20147
20179
|
this.args = this._fromQueryArgs(this._route.snapshot.queryParams);
|
20180
|
+
this.anyFilters = Object.keys(this.args).length > 0;
|
20148
20181
|
this._navigating = true;
|
20149
20182
|
this.viewer.execute();
|
20150
20183
|
});
|
@@ -20160,6 +20193,12 @@ class ReportComponent {
|
|
20160
20193
|
guide() {
|
20161
20194
|
this._guide.start(this.report.guide);
|
20162
20195
|
}
|
20196
|
+
clearFilter() {
|
20197
|
+
this.args = {};
|
20198
|
+
this.anyFilters = false;
|
20199
|
+
this._cd.detectChanges();
|
20200
|
+
this.viewer.execute();
|
20201
|
+
}
|
20163
20202
|
/**
|
20164
20203
|
*
|
20165
20204
|
* @param qargs
|
@@ -20211,10 +20250,10 @@ class ReportComponent {
|
|
20211
20250
|
}
|
20212
20251
|
}
|
20213
20252
|
ReportComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: ReportComponent, deps: [{ token: WindowTitleService }, { token: i1$6.ActivatedRoute }, { token: SessionService }, { token: i0.ChangeDetectorRef }, { token: PromptService }, { token: GuideService }], target: i0.ɵɵFactoryTarget.Component });
|
20214
|
-
ReportComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", type: ReportComponent, selector: "bizdoc-report", viewQueries: [{ propertyName: "filter", first: true, predicate: MatSidenav, descendants: true, static: true }, { propertyName: "viewer", first: true, predicate: ReportViewerComponent, descendants: true, static: true }], ngImport: i0, template: "<mat-toolbar>\r\n <button mat-icon-button (click)=\"viewer.execute()\" [bizdocTooltip]=\"'Refresh' | translate\"><mat-icon matAnimate=\"rotate\">autorenew</mat-icon></button>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"viewer.exportExcel()\" bizdocTooltip=\"{{'Download' | translate}}\"><mat-icon>save_alt</mat-icon></button>\r\n <button mat-icon-button (click)=\"guide()\" [bizdocTooltip]=\"'Help' | translate\" *ngIf=\"report.guide\"><mat-icon>help_outline</mat-icon></button>\r\n <button mat-icon-button (click)=\"
|
20253
|
+
ReportComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", type: ReportComponent, selector: "bizdoc-report", viewQueries: [{ propertyName: "filter", first: true, predicate: MatSidenav, descendants: true, static: true }, { propertyName: "viewer", first: true, predicate: ReportViewerComponent, descendants: true, static: true }], ngImport: i0, template: "<mat-toolbar>\r\n <button mat-icon-button (click)=\"viewer.execute()\" [bizdocTooltip]=\"'Refresh' | translate\"><mat-icon matAnimate=\"rotate\">autorenew</mat-icon></button>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"viewer.exportExcel()\" bizdocTooltip=\"{{'Download' | translate}}\"><mat-icon>save_alt</mat-icon></button>\r\n <button mat-icon-button (click)=\"guide()\" [bizdocTooltip]=\"'Help' | translate\" *ngIf=\"report.guide\"><mat-icon>help_outline</mat-icon></button>\r\n <button mat-icon-button (click)=\"clearFilter()\" [bizdocTooltip]=\"'Clear' | translate\" *ngIf=\"hasFilters\" [disabled]=\"!anyFilters\"><mat-icon>clear_all</mat-icon></button>\r\n <button mat-icon-button (click)=\"filter($event)\" bizdocTooltip=\"{{'Filter' | translate}}\" *ngIf=\"hasFilters\"><mat-icon [class.filled]=\"anyFilters\">filter_alt</mat-icon></button>\r\n</mat-toolbar>\r\n<mat-sidenav-container class=\"page-container\">\r\n <mat-sidenav-content>\r\n <bizdoc-report-viewer [report]=\"report\" [args]=\"args\"></bizdoc-report-viewer>\r\n </mat-sidenav-content>\r\n <mat-sidenav mode=\"over\" opened=\"false\" #filter position=\"end\">\r\n <bizdoc-report-arguments *ngIf=\"viewer.reportRef\" [args]=\"args\" (argsChange)=\"argsChange($event)\" [reportRef]=\"viewer.reportRef\"\r\n [template]=\"report.argumentsTemplate\" [arguments]=\"report.arguments\"></bizdoc-report-arguments>\r\n </mat-sidenav>\r\n</mat-sidenav-container>\r\n", styles: [".contents{display:flex;flex-direction:column}\n"], components: [{ type: i7$3.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { type: i7$1.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i8.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i9$4.MatSidenavContainer, selector: "mat-sidenav-container", exportAs: ["matSidenavContainer"] }, { type: i9$4.MatSidenavContent, selector: "mat-sidenav-content" }, { type: ReportViewerComponent, selector: "bizdoc-report-viewer", inputs: ["report", "args"] }, { type: i9$4.MatSidenav, selector: "mat-sidenav", inputs: ["fixedInViewport", "fixedTopGap", "fixedBottomGap"], exportAs: ["matSidenav"] }, { type: ReportArgumentsComponent, selector: "bizdoc-report-arguments", inputs: ["reportRef", "template", "arguments", "args"], outputs: ["argsChange"] }], directives: [{ type: TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }, { type: MatIconAnimate, selector: "[matAnimate]" }, { type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "translate": TranslatePipe } });
|
20215
20254
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: ReportComponent, decorators: [{
|
20216
20255
|
type: Component,
|
20217
|
-
args: [{ selector: 'bizdoc-report', template: "<mat-toolbar>\r\n <button mat-icon-button (click)=\"viewer.execute()\" [bizdocTooltip]=\"'Refresh' | translate\"><mat-icon matAnimate=\"rotate\">autorenew</mat-icon></button>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"viewer.exportExcel()\" bizdocTooltip=\"{{'Download' | translate}}\"><mat-icon>save_alt</mat-icon></button>\r\n <button mat-icon-button (click)=\"guide()\" [bizdocTooltip]=\"'Help' | translate\" *ngIf=\"report.guide\"><mat-icon>help_outline</mat-icon></button>\r\n <button mat-icon-button (click)=\"
|
20256
|
+
args: [{ selector: 'bizdoc-report', template: "<mat-toolbar>\r\n <button mat-icon-button (click)=\"viewer.execute()\" [bizdocTooltip]=\"'Refresh' | translate\"><mat-icon matAnimate=\"rotate\">autorenew</mat-icon></button>\r\n <span class=\"divider\"></span>\r\n <button mat-icon-button (click)=\"viewer.exportExcel()\" bizdocTooltip=\"{{'Download' | translate}}\"><mat-icon>save_alt</mat-icon></button>\r\n <button mat-icon-button (click)=\"guide()\" [bizdocTooltip]=\"'Help' | translate\" *ngIf=\"report.guide\"><mat-icon>help_outline</mat-icon></button>\r\n <button mat-icon-button (click)=\"clearFilter()\" [bizdocTooltip]=\"'Clear' | translate\" *ngIf=\"hasFilters\" [disabled]=\"!anyFilters\"><mat-icon>clear_all</mat-icon></button>\r\n <button mat-icon-button (click)=\"filter($event)\" bizdocTooltip=\"{{'Filter' | translate}}\" *ngIf=\"hasFilters\"><mat-icon [class.filled]=\"anyFilters\">filter_alt</mat-icon></button>\r\n</mat-toolbar>\r\n<mat-sidenav-container class=\"page-container\">\r\n <mat-sidenav-content>\r\n <bizdoc-report-viewer [report]=\"report\" [args]=\"args\"></bizdoc-report-viewer>\r\n </mat-sidenav-content>\r\n <mat-sidenav mode=\"over\" opened=\"false\" #filter position=\"end\">\r\n <bizdoc-report-arguments *ngIf=\"viewer.reportRef\" [args]=\"args\" (argsChange)=\"argsChange($event)\" [reportRef]=\"viewer.reportRef\"\r\n [template]=\"report.argumentsTemplate\" [arguments]=\"report.arguments\"></bizdoc-report-arguments>\r\n </mat-sidenav>\r\n</mat-sidenav-container>\r\n", styles: [".contents{display:flex;flex-direction:column}\n"] }]
|
20218
20257
|
}], ctorParameters: function () { return [{ type: WindowTitleService }, { type: i1$6.ActivatedRoute }, { type: SessionService }, { type: i0.ChangeDetectorRef }, { type: PromptService }, { type: GuideService }]; }, propDecorators: { filter: [{
|
20219
20258
|
type: ViewChild,
|
20220
20259
|
args: [MatSidenav, { static: true }]
|
@@ -25705,9 +25744,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
|
|
25705
25744
|
}], ctorParameters: function () { return [{ type: SessionService }, { type: DocumentViewRef }, { type: CubeService }, { type: RouterImpl }]; } });
|
25706
25745
|
|
25707
25746
|
class CubeSumComponent {
|
25708
|
-
constructor(_ds, _service, _session) {
|
25747
|
+
constructor(_ds, _service, _sb, _session) {
|
25709
25748
|
this._ds = _ds;
|
25710
25749
|
this._service = _service;
|
25750
|
+
this._sb = _sb;
|
25711
25751
|
this._session = _session;
|
25712
25752
|
this.onExplore = new EventEmitter();
|
25713
25753
|
this.back = true;
|
@@ -25747,13 +25787,7 @@ class CubeSumComponent {
|
|
25747
25787
|
indices: this.indices,
|
25748
25788
|
scope: this.scope,
|
25749
25789
|
filters
|
25750
|
-
}).toPromise();
|
25751
|
-
function fill(serie, point) {
|
25752
|
-
if (serie.index)
|
25753
|
-
this.current.indices.push({ name: serie.index, title: serie.title, value: point.y });
|
25754
|
-
else
|
25755
|
-
this.current = { axis: point.x, name: axis, value: point.y, indices: [] };
|
25756
|
-
}
|
25790
|
+
}).toPromise().catch(this._handleErr.bind(this));
|
25757
25791
|
for (var i = 0; i < results.length; i++) {
|
25758
25792
|
const { index, title, points } = results[i];
|
25759
25793
|
for (var j = 0; j < points.length; j++) {
|
@@ -25795,7 +25829,7 @@ class CubeSumComponent {
|
|
25795
25829
|
indices: this.indices,
|
25796
25830
|
scope: this.scope,
|
25797
25831
|
filters
|
25798
|
-
}).toPromise();
|
25832
|
+
}).toPromise().catch(this._handleErr.bind(this));
|
25799
25833
|
const level = { axis, indices: [], scope };
|
25800
25834
|
for (var i = 0; i < results.length; i++) {
|
25801
25835
|
const { index, title, points } = results[i];
|
@@ -25814,6 +25848,9 @@ class CubeSumComponent {
|
|
25814
25848
|
else if (keyIndex === keys.length - 1)
|
25815
25849
|
this.next = await parallel(1);
|
25816
25850
|
}
|
25851
|
+
_handleErr(response) {
|
25852
|
+
this._sb.error(errResource(response));
|
25853
|
+
}
|
25817
25854
|
async _fish(axis) {
|
25818
25855
|
this.loading = true;
|
25819
25856
|
try {
|
@@ -25823,7 +25860,7 @@ class CubeSumComponent {
|
|
25823
25860
|
indices: this.indices, filters,
|
25824
25861
|
scope: this.scope
|
25825
25862
|
}).
|
25826
|
-
toPromise();
|
25863
|
+
toPromise().catch(this._handleErr.bind(this));
|
25827
25864
|
this.current = {
|
25828
25865
|
axis,
|
25829
25866
|
value: 0,
|
@@ -26012,7 +26049,7 @@ class CubeSumComponent {
|
|
26012
26049
|
const results = this._scoperesults = await this._service.series(this._cube.name, this.xAxis, {
|
26013
26050
|
indices: this.indices, filters,
|
26014
26051
|
scope: this.scope
|
26015
|
-
}).toPromise();
|
26052
|
+
}).toPromise().catch(this._handleErr.bind(this));
|
26016
26053
|
this._scope = scope;
|
26017
26054
|
if (!results.some(s => s.points.length))
|
26018
26055
|
return;
|
@@ -26065,7 +26102,7 @@ class CubeSumComponent {
|
|
26065
26102
|
this.onExplore.emit({ axes, index });
|
26066
26103
|
}
|
26067
26104
|
}
|
26068
|
-
CubeSumComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: CubeSumComponent, deps: [{ token: DatasourceService }, { token: CubeService }, { token: SessionService }], target: i0.ɵɵFactoryTarget.Component });
|
26105
|
+
CubeSumComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.3", ngImport: i0, type: CubeSumComponent, deps: [{ token: DatasourceService }, { token: CubeService }, { token: PromptService }, { token: SessionService }], target: i0.ɵɵFactoryTarget.Component });
|
26069
26106
|
CubeSumComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.3", type: CubeSumComponent, selector: "bizdoc-cube-sum", inputs: { xAxis: "xAxis", periodPolicy: "periodPolicy", parentAxis: "parentAxis", filters: "filters", cube: "cube", indices: "indices", scope: "scope" }, outputs: { onExplore: "explore" }, usesOnChanges: true, ngImport: i0, template: " <!-- levels -->\r\n<div class=\"row\">\r\n <div *ngIf=\"prev\" class=\"level prev-level\">\r\n <div class=\"level-header row\">\r\n <mat-icon class=\"cliclable mat-icon-rtl-mirror\" [inline]=true (click)=\"goprev()\" *ngIf=\"back\">keyboard_arrow_left</mat-icon>\r\n <div div class=\"mat-h1 title\">\r\n {{'PrevLevel'| translate}}\r\n </div>\r\n <span class=\"divider\"></span>\r\n <mat-icon *ngIf=\"forward\" class=\"cliclable mat-icon-rtl-mirror\" [inline]=true (click)=\"gonext()\">keyboard_arrow_right</mat-icon>\r\n </div>\r\n <ng-container *ngTemplateOutlet=\"level; context: {use: prev}\"></ng-container>\r\n </div>\r\n <div *ngIf=\"current\" class=\"level current-level\">\r\n <div class=\"level-header row\">\r\n <div div class=\"mat-h1 title\">\r\n {{'CurrentLevel'| translate : primaryAxis.title}}\r\n </div>\r\n <span class=\"divider\"></span>\r\n <mat-icon [bizdocTooltip]=\"help\" *ngIf=\"help\" [inline]=\"true\">help_outline</mat-icon>\r\n </div>\r\n <ng-container *ngTemplateOutlet=\"level; context: {use: current}\"></ng-container>\r\n </div>\r\n <div *ngIf=\"next\" class=\"level next-level\">\r\n <div class=\"level-header\">\r\n <div div class=\"mat-h1 title\">\r\n {{'NextLevel'| translate}}\r\n </div>\r\n </div>\r\n <ng-container *ngTemplateOutlet=\"level; context: {use: next}\"></ng-container>\r\n </div>\r\n</div>\r\n<!-- level -->\r\n<ng-template #level let-use=\"use\" let-help=\"help\">\r\n <div>\r\n <h2 class=\"mat-h1\" [class.cliclable]=\"use.value !== 0\" (click)=\"explore(use)\">{{use.title}}</h2>\r\n <div class=\"row\">\r\n <h3 class=\"mat-h1\" [class.cliclable]=\"use.value !== 0\" (click)=\"explore(use)\">{{use.value | currency : currencyCode : 'symbol' : digitsInfo}}</h3>\r\n <span class=\"divider\"></span>\r\n <div *ngIf=\"use.chain && use.value !== use.chain.value\">\r\n <span *ngIf=\"use.value !== 0 && use.chain.value !== 0\">{{Math.round(use.value / use.chain.value * 100) }}%</span>\r\n <mat-icon>{{use.value > use.chain.value ? 'trending_up':'trending_down' }}</mat-icon>\r\n </div>\r\n </div>\r\n </div>\r\n <!-- -->\r\n <div class=\"row\">\r\n <div *ngFor=\"let i of use.indices\" class=\"index\">\r\n <h4 class=\"mat-h3 title\">{{i.title}}</h4>\r\n <h5 class=\"mat-h3\" [class.cliclable]=\"i.value !== 0\" (click)=\"explore(use, i.name)\">{{i.value | currency : currencyCode : 'symbol' : digitsInfo}}</h5>\r\n </div>\r\n </div>\r\n <div class=\"bar\" *ngIf=\"use.indices.length\" [class.available]=\"use.percent < 100\">\r\n <div class=\"value\" [style.flexBasis]=\"Math.round(use.percent < 100 ?\r\n 100 - use.percent :\r\n 100 / use.percent * 100) + '%'\"\r\n [@bar]=\"use.animation\"></div>\r\n <div class=\"overflow\" *ngIf=\"use.percent > 0\"></div>\r\n </div>\r\n</ng-template>\r\n", styles: [":host{padding:0 8px}.level{border-width:thin;border-radius:3px;padding:8px;margin:3px;flex:1 1 0;border-style:solid}.level .cliclable{cursor:pointer}.level.next-level{border-style:dashed}.level .level-header{align-items:center}.level .level-header .title{margin:0;line-height:22px;font-size:inherit;font-feature-settings:\"pcap\",\"c2pc\";font-variant-caps:all-petite-caps}.level h3{margin:0;font-size:x-large}.level h2{font-weight:400;font-size:larger;margin:0}.level .percent{display:flex;align-items:center}.level .index{padding:0 4px}.level .index h5,.level .index h4{margin:0}.level .bar{display:flex}.level .bar .value,.level .bar .overflow{height:12px}.level .bar .value{flex:0 0 0%}.level .bar .overflow{flex:1 1 0%;box-sizing:border-box}.level .bar.available .overflow{border-width:1px;border-style:dashed}\n"], components: [{ type: i8.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }], directives: [{ type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i10.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: TooltipDirective, selector: "[bizdocTooltip]", inputs: ["bizdocTooltip", "bizdocTooltipTemplate", "bizdocTooltipContext", "bizdocTooltipPosition", "bizdocTooltipDuration", "bizdocTooltipDisabled"] }, { type: i10.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "translate": TranslatePipe, "currency": i10.CurrencyPipe }, animations: [trigger('bar', [
|
26070
26107
|
transition('*<=>*', [style({
|
26071
26108
|
flexBasis: '{{startWidth}}%'
|
@@ -26078,7 +26115,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.3", ngImpor
|
|
26078
26115
|
flexBasis: '{{startWidth}}%'
|
26079
26116
|
}), animate('500ms ease')], { params: { startWidth: 100 } }),
|
26080
26117
|
])], template: " <!-- levels -->\r\n<div class=\"row\">\r\n <div *ngIf=\"prev\" class=\"level prev-level\">\r\n <div class=\"level-header row\">\r\n <mat-icon class=\"cliclable mat-icon-rtl-mirror\" [inline]=true (click)=\"goprev()\" *ngIf=\"back\">keyboard_arrow_left</mat-icon>\r\n <div div class=\"mat-h1 title\">\r\n {{'PrevLevel'| translate}}\r\n </div>\r\n <span class=\"divider\"></span>\r\n <mat-icon *ngIf=\"forward\" class=\"cliclable mat-icon-rtl-mirror\" [inline]=true (click)=\"gonext()\">keyboard_arrow_right</mat-icon>\r\n </div>\r\n <ng-container *ngTemplateOutlet=\"level; context: {use: prev}\"></ng-container>\r\n </div>\r\n <div *ngIf=\"current\" class=\"level current-level\">\r\n <div class=\"level-header row\">\r\n <div div class=\"mat-h1 title\">\r\n {{'CurrentLevel'| translate : primaryAxis.title}}\r\n </div>\r\n <span class=\"divider\"></span>\r\n <mat-icon [bizdocTooltip]=\"help\" *ngIf=\"help\" [inline]=\"true\">help_outline</mat-icon>\r\n </div>\r\n <ng-container *ngTemplateOutlet=\"level; context: {use: current}\"></ng-container>\r\n </div>\r\n <div *ngIf=\"next\" class=\"level next-level\">\r\n <div class=\"level-header\">\r\n <div div class=\"mat-h1 title\">\r\n {{'NextLevel'| translate}}\r\n </div>\r\n </div>\r\n <ng-container *ngTemplateOutlet=\"level; context: {use: next}\"></ng-container>\r\n </div>\r\n</div>\r\n<!-- level -->\r\n<ng-template #level let-use=\"use\" let-help=\"help\">\r\n <div>\r\n <h2 class=\"mat-h1\" [class.cliclable]=\"use.value !== 0\" (click)=\"explore(use)\">{{use.title}}</h2>\r\n <div class=\"row\">\r\n <h3 class=\"mat-h1\" [class.cliclable]=\"use.value !== 0\" (click)=\"explore(use)\">{{use.value | currency : currencyCode : 'symbol' : digitsInfo}}</h3>\r\n <span class=\"divider\"></span>\r\n <div *ngIf=\"use.chain && use.value !== use.chain.value\">\r\n <span *ngIf=\"use.value !== 0 && use.chain.value !== 0\">{{Math.round(use.value / use.chain.value * 100) }}%</span>\r\n <mat-icon>{{use.value > use.chain.value ? 'trending_up':'trending_down' }}</mat-icon>\r\n </div>\r\n </div>\r\n </div>\r\n <!-- -->\r\n <div class=\"row\">\r\n <div *ngFor=\"let i of use.indices\" class=\"index\">\r\n <h4 class=\"mat-h3 title\">{{i.title}}</h4>\r\n <h5 class=\"mat-h3\" [class.cliclable]=\"i.value !== 0\" (click)=\"explore(use, i.name)\">{{i.value | currency : currencyCode : 'symbol' : digitsInfo}}</h5>\r\n </div>\r\n </div>\r\n <div class=\"bar\" *ngIf=\"use.indices.length\" [class.available]=\"use.percent < 100\">\r\n <div class=\"value\" [style.flexBasis]=\"Math.round(use.percent < 100 ?\r\n 100 - use.percent :\r\n 100 / use.percent * 100) + '%'\"\r\n [@bar]=\"use.animation\"></div>\r\n <div class=\"overflow\" *ngIf=\"use.percent > 0\"></div>\r\n </div>\r\n</ng-template>\r\n", styles: [":host{padding:0 8px}.level{border-width:thin;border-radius:3px;padding:8px;margin:3px;flex:1 1 0;border-style:solid}.level .cliclable{cursor:pointer}.level.next-level{border-style:dashed}.level .level-header{align-items:center}.level .level-header .title{margin:0;line-height:22px;font-size:inherit;font-feature-settings:\"pcap\",\"c2pc\";font-variant-caps:all-petite-caps}.level h3{margin:0;font-size:x-large}.level h2{font-weight:400;font-size:larger;margin:0}.level .percent{display:flex;align-items:center}.level .index{padding:0 4px}.level .index h5,.level .index h4{margin:0}.level .bar{display:flex}.level .bar .value,.level .bar .overflow{height:12px}.level .bar .value{flex:0 0 0%}.level .bar .overflow{flex:1 1 0%;box-sizing:border-box}.level .bar.available .overflow{border-width:1px;border-style:dashed}\n"] }]
|
26081
|
-
}], ctorParameters: function () { return [{ type: DatasourceService }, { type: CubeService }, { type: SessionService }]; }, propDecorators: { xAxis: [{
|
26118
|
+
}], ctorParameters: function () { return [{ type: DatasourceService }, { type: CubeService }, { type: PromptService }, { type: SessionService }]; }, propDecorators: { xAxis: [{
|
26082
26119
|
type: Input
|
26083
26120
|
}], periodPolicy: [{
|
26084
26121
|
type: Input
|
@@ -26364,7 +26401,7 @@ class CubeParallelComponent {
|
|
26364
26401
|
this.width = Math.max(Math.round(this.size / this.items.length), 150) + 'px';
|
26365
26402
|
this._loading.next(false);
|
26366
26403
|
}, (e) => {
|
26367
|
-
this._sb.error(e
|
26404
|
+
this._sb.error(errResource(e));
|
26368
26405
|
this._loading.next(false);
|
26369
26406
|
});
|
26370
26407
|
}
|