@netgrif/components-core 6.3.0 → 6.4.0-beta.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/assets/i18n/de.json +1 -0
- package/esm2020/assets/i18n/en.json +1 -0
- package/esm2020/assets/i18n/sk.json +1 -0
- package/esm2020/lib/data-fields/base-component/abstract-base-data-field.component.mjs +51 -0
- package/esm2020/lib/data-fields/boolean-field/abstract-boolean-field.component.mjs +7 -26
- package/esm2020/lib/data-fields/boolean-field/boolean-default-field/abstract-boolean-default-field.component.mjs +46 -0
- package/esm2020/lib/data-fields/boolean-field/models/boolean-field.mjs +9 -1
- package/esm2020/lib/data-fields/button-field/abstract-button-field.component.mjs +7 -39
- package/esm2020/lib/data-fields/button-field/button-default-field/abstract-button-default-field.component.mjs +58 -0
- package/esm2020/lib/data-fields/button-field/models/button-field.mjs +5 -1
- package/esm2020/lib/data-fields/case-ref-field/case-ref-default/case-ref-default.component.mjs +67 -0
- package/esm2020/lib/data-fields/case-ref-field/model/case-ref-field.mjs +11 -0
- package/esm2020/lib/data-fields/case-ref-field/model/case-ref-injection-tokens.mjs +4 -0
- package/esm2020/lib/data-fields/data-field-template/abstract-data-field-template.component.mjs +51 -6
- package/esm2020/lib/data-fields/date-field/abstract-date-field.component.mjs +10 -12
- package/esm2020/lib/data-fields/date-field/date-default-field/abstract-date-default-field.component.mjs +29 -0
- package/esm2020/lib/data-fields/date-field/models/date-field.mjs +5 -1
- package/esm2020/lib/data-fields/date-time-field/abstract-date-time-field.component.mjs +10 -12
- package/esm2020/lib/data-fields/date-time-field/date-time-default-field/abstract-date-time-default-field.component.mjs +29 -0
- package/esm2020/lib/data-fields/date-time-field/models/date-time-field.mjs +5 -1
- package/esm2020/lib/data-fields/enumeration-field/abstract-enumeration-field.component.mjs +4 -1
- package/esm2020/lib/data-fields/enumeration-field/enumeration-autocomplete-dynamic-field/abstract-enumeration-autocomplete-dynamic-field.component.mjs +23 -20
- package/esm2020/lib/data-fields/enumeration-field/enumeration-autocomplete-select-field/abstract-enumeration-autocomplete-select-field.component.mjs +20 -21
- package/esm2020/lib/data-fields/enumeration-field/enumeration-icon-field/abstract-enumeration-icon-field.component.mjs +26 -19
- package/esm2020/lib/data-fields/enumeration-field/enumeration-list-field/abstract-enumeration-list-field.component.mjs +16 -12
- package/esm2020/lib/data-fields/enumeration-field/enumeration-select-field/abstract-enumeration-select-field.component.mjs +16 -12
- package/esm2020/lib/data-fields/enumeration-field/enumeration-stepper-field/abstract-enumeration-stepper-field.component.mjs +26 -21
- package/esm2020/lib/data-fields/enumeration-field/models/enumeration-field.mjs +9 -1
- package/esm2020/lib/data-fields/file-field/abstract-file-field.component.mjs +11 -420
- package/esm2020/lib/data-fields/file-field/file-default-field/abstract-file-default-field.component.mjs +456 -0
- package/esm2020/lib/data-fields/file-field/models/file-field-constants.mjs +5 -0
- package/esm2020/lib/data-fields/file-field/models/file-field.mjs +6 -1
- package/esm2020/lib/data-fields/file-list-field/abstract-file-list-field.component.mjs +11 -278
- package/esm2020/lib/data-fields/file-list-field/file-list-default-field/abstract-file-list-default-field.component.mjs +304 -0
- package/esm2020/lib/data-fields/file-list-field/models/file-list-field.mjs +6 -1
- package/esm2020/lib/data-fields/filter-field/abstract-filter-field-tab-view-content.component.mjs +4 -4
- package/esm2020/lib/data-fields/filter-field/abstract-filter-field-tab-view.component.mjs +4 -4
- package/esm2020/lib/data-fields/filter-field/abstract-filter-field.component.mjs +8 -20
- package/esm2020/lib/data-fields/filter-field/filter-default-field/abstract-filter-default-field.component.mjs +38 -0
- package/esm2020/lib/data-fields/filter-field/models/filter-field.mjs +5 -1
- package/esm2020/lib/data-fields/i18n-field/abstract-i18n-errors.component.mjs +18 -16
- package/esm2020/lib/data-fields/i18n-field/abstract-i18n-field.component.mjs +4 -1
- package/esm2020/lib/data-fields/i18n-field/i18n-divider-field/abstract-i18n-divider-field.component.mjs +24 -20
- package/esm2020/lib/data-fields/i18n-field/i18n-text-field/abstract-i18n-text-field.component.mjs +35 -32
- package/esm2020/lib/data-fields/i18n-field/models/i18n-field.mjs +6 -2
- package/esm2020/lib/data-fields/models/abstract-data-field-component.mjs +4 -1
- package/esm2020/lib/data-fields/models/abstract-data-field.mjs +14 -2
- package/esm2020/lib/data-fields/models/component.mjs +21 -2
- package/esm2020/lib/data-fields/models/data-field-portal-data-injection-token.mjs +3 -0
- package/esm2020/lib/data-fields/models/update-strategy.mjs +7 -0
- package/esm2020/lib/data-fields/multichoice-field/abstract-multichoice-field.component.mjs +4 -1
- package/esm2020/lib/data-fields/multichoice-field/models/multichoice-field.mjs +9 -1
- package/esm2020/lib/data-fields/multichoice-field/multichoice-autocomplete-field/abstract-multichoice-autocomplete-field-component.component.mjs +30 -30
- package/esm2020/lib/data-fields/multichoice-field/multichoice-list-field/abstract-multichoice-list-field.component.mjs +16 -12
- package/esm2020/lib/data-fields/multichoice-field/multichoice-select-field/abstract-multichoice-select-field.component.mjs +16 -12
- package/esm2020/lib/data-fields/number-field/abstract-number-errors.component.mjs +17 -15
- package/esm2020/lib/data-fields/number-field/abstract-number-field.component.mjs +4 -1
- package/esm2020/lib/data-fields/number-field/currency-number-field/abstract-currency-number-field.component.mjs +21 -15
- package/esm2020/lib/data-fields/number-field/models/number-field.mjs +5 -1
- package/esm2020/lib/data-fields/number-field/number-default-field/abstract-default-number-field.component.mjs +12 -6
- package/esm2020/lib/data-fields/public-api.mjs +17 -2
- package/esm2020/lib/data-fields/task-ref-field/abstract-task-ref-field.component.mjs +10 -116
- package/esm2020/lib/data-fields/task-ref-field/model/task-ref-field.mjs +5 -1
- package/esm2020/lib/data-fields/task-ref-field/task-ref-dashboard-field/abstract-task-ref-dashboard-field.component.mjs +130 -0
- package/esm2020/lib/data-fields/task-ref-field/task-ref-list-field/abstract-task-ref-list-field.component.mjs +54 -0
- package/esm2020/lib/data-fields/text-field/abstract-dashboard-text-field.component.mjs +14 -14
- package/esm2020/lib/data-fields/text-field/abstract-text-errors.component.mjs +23 -3
- package/esm2020/lib/data-fields/text-field/dashboard-bar-chart-text-field/abstract-dashboard-bar-chart-text-field.component.mjs +12 -6
- package/esm2020/lib/data-fields/text-field/dashboard-iframe-text-field/abstract-dashboard-iframe-text-field.component.mjs +12 -6
- package/esm2020/lib/data-fields/text-field/dashboard-line-chart-text-field/abstract-dashboard-line-chart-text-field.component.mjs +12 -6
- package/esm2020/lib/data-fields/text-field/dashboard-pie-chart-text-field/abstract-dashboard-pie-chart-text-field.component.mjs +12 -6
- package/esm2020/lib/data-fields/text-field/dashboard-portal-text-field/abstract-dashboard-portal-text-field.component.mjs +12 -6
- package/esm2020/lib/data-fields/text-field/html-textarea-field/abstract-html-textarea-field.component.mjs +16 -16
- package/esm2020/lib/data-fields/text-field/models/text-field.mjs +8 -4
- package/esm2020/lib/data-fields/text-field/password-text-field/abstract-password-text-field.component.mjs +14 -14
- package/esm2020/lib/data-fields/text-field/rich-textarea-field/abstract-rich-textarea-field.component.mjs +14 -14
- package/esm2020/lib/data-fields/text-field/simple-text-field/abstract-simple-text-field.component.mjs +14 -14
- package/esm2020/lib/data-fields/text-field/textarea-field/abstract-textarea-field.component.mjs +17 -17
- package/esm2020/lib/data-fields/time-instance-abstract-field/abstract-time-instance-field.component.mjs +12 -12
- package/esm2020/lib/data-fields/user-field/abstract-user-field.component.mjs +7 -39
- package/esm2020/lib/data-fields/user-field/models/user-field.mjs +5 -1
- package/esm2020/lib/data-fields/user-field/user-default-field/abstract-user-default-field.component.mjs +70 -0
- package/esm2020/lib/data-fields/user-list-field/abstract-user-list-field.component.mjs +7 -45
- package/esm2020/lib/data-fields/user-list-field/models/user-list-field.mjs +5 -1
- package/esm2020/lib/data-fields/user-list-field/user-list-default-field/abstract-user-list-default-field.component.mjs +60 -0
- package/esm2020/lib/dialog/injection-tokens.mjs +10 -0
- package/esm2020/lib/dialog/public-api.mjs +2 -1
- package/esm2020/lib/filter/models/task-search-request-body.mjs +1 -1
- package/esm2020/lib/filter/user-filters.service.mjs +22 -15
- package/esm2020/lib/impersonation/services/impersonation-user-select.service.mjs +24 -17
- package/esm2020/lib/panel/workflow-panel/abstract-workflow-panel.component.mjs +6 -2
- package/esm2020/lib/registry/component-registry.service.mjs +38 -0
- package/esm2020/lib/registry/public-api.mjs +2 -0
- package/esm2020/lib/side-menu/content-components/public-api.mjs +2 -1
- package/esm2020/lib/task-content/field-component-resolver/abstract-field-component-resolver.component.mjs +24 -5
- package/esm2020/lib/task-content/model/field-type-resource.mjs +2 -1
- package/esm2020/lib/task-content/services/field-converter.service.mjs +4 -1
- package/esm2020/lib/task-content/task-content/abstract-task-content.component.mjs +20 -7
- package/esm2020/lib/view/case-view/service/case-view-service.mjs +20 -15
- package/esm2020/lib/view/workflow-view/abstract-workflow-view.component.mjs +12 -7
- package/esm2020/public-api.mjs +2 -1
- package/fesm2015/netgrif-components-core.mjs +1771 -961
- package/fesm2015/netgrif-components-core.mjs.map +1 -1
- package/fesm2020/netgrif-components-core.mjs +1675 -957
- package/fesm2020/netgrif-components-core.mjs.map +1 -1
- package/lib/data-fields/base-component/abstract-base-data-field.component.d.ts +18 -0
- package/lib/data-fields/boolean-field/abstract-boolean-field.component.d.ts +5 -7
- package/lib/data-fields/boolean-field/boolean-default-field/abstract-boolean-default-field.component.d.ts +14 -0
- package/lib/data-fields/boolean-field/models/boolean-field.d.ts +3 -0
- package/lib/data-fields/button-field/abstract-button-field.component.d.ts +5 -16
- package/lib/data-fields/button-field/button-default-field/abstract-button-default-field.component.d.ts +23 -0
- package/lib/data-fields/button-field/models/button-field.d.ts +1 -0
- package/lib/data-fields/case-ref-field/case-ref-default/case-ref-default.component.d.ts +16 -0
- package/lib/data-fields/case-ref-field/model/case-ref-field.d.ts +9 -0
- package/lib/data-fields/case-ref-field/model/case-ref-injection-tokens.d.ts +3 -0
- package/lib/data-fields/data-field-template/abstract-data-field-template.component.d.ts +22 -3
- package/lib/data-fields/date-field/abstract-date-field.component.d.ts +7 -7
- package/lib/data-fields/date-field/date-default-field/abstract-date-default-field.component.d.ts +12 -0
- package/lib/data-fields/date-field/models/date-field.d.ts +1 -0
- package/lib/data-fields/date-time-field/abstract-date-time-field.component.d.ts +7 -7
- package/lib/data-fields/date-time-field/date-time-default-field/abstract-date-time-default-field.component.d.ts +12 -0
- package/lib/data-fields/date-time-field/models/date-time-field.d.ts +1 -0
- package/lib/data-fields/enumeration-field/abstract-enumeration-field.component.d.ts +3 -0
- package/lib/data-fields/enumeration-field/enumeration-autocomplete-dynamic-field/abstract-enumeration-autocomplete-dynamic-field.component.d.ts +8 -10
- package/lib/data-fields/enumeration-field/enumeration-autocomplete-select-field/abstract-enumeration-autocomplete-select-field.component.d.ts +6 -10
- package/lib/data-fields/enumeration-field/enumeration-icon-field/abstract-enumeration-icon-field.component.d.ts +9 -9
- package/lib/data-fields/enumeration-field/enumeration-list-field/abstract-enumeration-list-field.component.d.ts +6 -8
- package/lib/data-fields/enumeration-field/enumeration-select-field/abstract-enumeration-select-field.component.d.ts +6 -8
- package/lib/data-fields/enumeration-field/enumeration-stepper-field/abstract-enumeration-stepper-field.component.d.ts +8 -9
- package/lib/data-fields/enumeration-field/models/enumeration-field.d.ts +3 -0
- package/lib/data-fields/file-field/abstract-file-field.component.d.ts +9 -147
- package/lib/data-fields/file-field/file-default-field/abstract-file-default-field.component.d.ts +151 -0
- package/lib/data-fields/file-field/models/file-field-constants.d.ts +4 -0
- package/lib/data-fields/file-field/models/file-field.d.ts +1 -0
- package/lib/data-fields/file-list-field/abstract-file-list-field.component.d.ts +8 -71
- package/lib/data-fields/file-list-field/file-list-default-field/abstract-file-list-default-field.component.d.ts +76 -0
- package/lib/data-fields/file-list-field/models/file-list-field.d.ts +1 -0
- package/lib/data-fields/filter-field/abstract-filter-field-tab-view-content.component.d.ts +3 -3
- package/lib/data-fields/filter-field/abstract-filter-field-tab-view.component.d.ts +3 -3
- package/lib/data-fields/filter-field/abstract-filter-field.component.d.ts +6 -11
- package/lib/data-fields/filter-field/filter-default-field/abstract-filter-default-field.component.d.ts +18 -0
- package/lib/data-fields/filter-field/models/filter-field.d.ts +1 -0
- package/lib/data-fields/i18n-field/abstract-i18n-errors.component.d.ts +6 -9
- package/lib/data-fields/i18n-field/abstract-i18n-field.component.d.ts +3 -0
- package/lib/data-fields/i18n-field/i18n-divider-field/abstract-i18n-divider-field.component.d.ts +6 -8
- package/lib/data-fields/i18n-field/i18n-text-field/abstract-i18n-text-field.component.d.ts +5 -8
- package/lib/data-fields/i18n-field/models/i18n-field.d.ts +1 -0
- package/lib/data-fields/models/abstract-data-field-component.d.ts +1 -0
- package/lib/data-fields/models/abstract-data-field.d.ts +9 -0
- package/lib/data-fields/models/component.d.ts +19 -0
- package/lib/data-fields/models/data-field-portal-data-injection-token.d.ts +13 -0
- package/lib/data-fields/models/update-strategy.d.ts +6 -0
- package/lib/data-fields/multichoice-field/abstract-multichoice-field.component.d.ts +3 -0
- package/lib/data-fields/multichoice-field/models/multichoice-field.d.ts +3 -0
- package/lib/data-fields/multichoice-field/multichoice-autocomplete-field/abstract-multichoice-autocomplete-field-component.component.d.ts +6 -9
- package/lib/data-fields/multichoice-field/multichoice-list-field/abstract-multichoice-list-field.component.d.ts +6 -7
- package/lib/data-fields/multichoice-field/multichoice-select-field/abstract-multichoice-select-field.component.d.ts +6 -8
- package/lib/data-fields/number-field/abstract-number-errors.component.d.ts +6 -9
- package/lib/data-fields/number-field/abstract-number-field.component.d.ts +3 -0
- package/lib/data-fields/number-field/currency-number-field/abstract-currency-number-field.component.d.ts +4 -2
- package/lib/data-fields/number-field/models/number-field.d.ts +1 -0
- package/lib/data-fields/number-field/number-default-field/abstract-default-number-field.component.d.ts +4 -2
- package/lib/data-fields/public-api.d.ts +16 -1
- package/lib/data-fields/task-ref-field/abstract-task-ref-field.component.d.ts +6 -13
- package/lib/data-fields/task-ref-field/model/task-ref-field.d.ts +1 -0
- package/lib/data-fields/task-ref-field/task-ref-dashboard-field/abstract-task-ref-dashboard-field.component.d.ts +20 -0
- package/lib/data-fields/task-ref-field/task-ref-list-field/abstract-task-ref-list-field.component.d.ts +16 -0
- package/lib/data-fields/text-field/abstract-dashboard-text-field.component.d.ts +5 -9
- package/lib/data-fields/text-field/abstract-text-errors.component.d.ts +7 -2
- package/lib/data-fields/text-field/dashboard-bar-chart-text-field/abstract-dashboard-bar-chart-text-field.component.d.ts +4 -2
- package/lib/data-fields/text-field/dashboard-iframe-text-field/abstract-dashboard-iframe-text-field.component.d.ts +4 -2
- package/lib/data-fields/text-field/dashboard-line-chart-text-field/abstract-dashboard-line-chart-text-field.component.d.ts +4 -2
- package/lib/data-fields/text-field/dashboard-pie-chart-text-field/abstract-dashboard-pie-chart-text-field.component.d.ts +4 -2
- package/lib/data-fields/text-field/dashboard-portal-text-field/abstract-dashboard-portal-text-field.component.d.ts +4 -2
- package/lib/data-fields/text-field/html-textarea-field/abstract-html-textarea-field.component.d.ts +5 -9
- package/lib/data-fields/text-field/models/text-field.d.ts +3 -2
- package/lib/data-fields/text-field/password-text-field/abstract-password-text-field.component.d.ts +5 -9
- package/lib/data-fields/text-field/rich-textarea-field/abstract-rich-textarea-field.component.d.ts +5 -9
- package/lib/data-fields/text-field/simple-text-field/abstract-simple-text-field.component.d.ts +5 -9
- package/lib/data-fields/text-field/textarea-field/abstract-textarea-field.component.d.ts +6 -9
- package/lib/data-fields/time-instance-abstract-field/abstract-time-instance-field.component.d.ts +6 -5
- package/lib/data-fields/user-field/abstract-user-field.component.d.ts +5 -27
- package/lib/data-fields/user-field/models/user-field.d.ts +1 -0
- package/lib/data-fields/user-field/user-default-field/abstract-user-default-field.component.d.ts +34 -0
- package/lib/data-fields/user-list-field/abstract-user-list-field.component.d.ts +5 -25
- package/lib/data-fields/user-list-field/models/user-list-field.d.ts +1 -0
- package/lib/data-fields/user-list-field/user-list-default-field/abstract-user-list-default-field.component.d.ts +24 -0
- package/lib/dialog/injection-tokens.d.ts +10 -0
- package/lib/dialog/public-api.d.ts +1 -0
- package/lib/filter/models/task-search-request-body.d.ts +6 -0
- package/lib/filter/user-filters.service.d.ts +4 -2
- package/lib/impersonation/services/impersonation-user-select.service.d.ts +3 -3
- package/lib/panel/workflow-panel/abstract-workflow-panel.component.d.ts +3 -1
- package/lib/{data-fields/text-field/dashboard-portal-text-field/dashboard-portal-component-registry.service.d.ts → registry/component-registry.service.d.ts} +6 -5
- package/lib/registry/public-api.d.ts +1 -0
- package/lib/side-menu/content-components/public-api.d.ts +1 -0
- package/lib/task-content/field-component-resolver/abstract-field-component-resolver.component.d.ts +7 -3
- package/lib/task-content/model/field-type-resource.d.ts +1 -0
- package/lib/task-content/task-content/abstract-task-content.component.d.ts +5 -1
- package/lib/view/case-view/service/case-view-service.d.ts +3 -3
- package/lib/view/workflow-view/abstract-workflow-view.component.d.ts +3 -3
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- package/src/assets/i18n/de.json +1 -0
- package/src/assets/i18n/en.json +1 -0
- package/src/assets/i18n/sk.json +1 -0
- package/esm2020/lib/data-fields/text-field/dashboard-portal-text-field/dashboard-portal-component-registry.service.mjs +0 -35
|
@@ -0,0 +1,456 @@
|
|
|
1
|
+
import { Component, Inject, Input, Optional, ViewChild } from "@angular/core";
|
|
2
|
+
import { FilePreviewType } from "../models/file-field";
|
|
3
|
+
import { BehaviorSubject } from "rxjs";
|
|
4
|
+
import { ProgressType } from "../../../resources/resource-provider.service";
|
|
5
|
+
import { HttpParams } from "@angular/common/http";
|
|
6
|
+
import { take } from "rxjs/operators";
|
|
7
|
+
import { DATA_FIELD_PORTAL_DATA } from "../../models/data-field-portal-data-injection-token";
|
|
8
|
+
import { AbstractBaseDataFieldComponent } from "../../base-component/abstract-base-data-field.component";
|
|
9
|
+
import { FILE_FIELD_HEIGHT, FILE_FIELD_PADDING, PREVIEW, PREVIEW_BUTTON } from '../models/file-field-constants';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "../../../resources/engine-endpoint/task-resource.service";
|
|
12
|
+
import * as i2 from "../../../logger/services/logger.service";
|
|
13
|
+
import * as i3 from "../../../snack-bar/services/snack-bar.service";
|
|
14
|
+
import * as i4 from "@ngx-translate/core";
|
|
15
|
+
import * as i5 from "../../../event/services/event.service";
|
|
16
|
+
import * as i6 from "@angular/platform-browser";
|
|
17
|
+
export class AbstractFileDefaultFieldComponent extends AbstractBaseDataFieldComponent {
|
|
18
|
+
/**
|
|
19
|
+
* Only inject services.
|
|
20
|
+
* @param _taskResourceService Provides to download a file from the backend
|
|
21
|
+
* @param _log Logger service
|
|
22
|
+
* @param _snackbar Snackbar service to notify user
|
|
23
|
+
* @param _translate Translate service for I18N
|
|
24
|
+
* @param _eventService used for parsing of backend response
|
|
25
|
+
* Option injected trough `NAE_INFORM_ABOUT_INVALID_DATA` InjectionToken
|
|
26
|
+
* @param _sanitizer Sanitize url of image preview
|
|
27
|
+
* @param dataFieldPortalData Field and form control data if field is provided with portal
|
|
28
|
+
*/
|
|
29
|
+
constructor(_taskResourceService, _log, _snackbar, _translate, _eventService, _sanitizer, dataFieldPortalData) {
|
|
30
|
+
super(dataFieldPortalData);
|
|
31
|
+
this._taskResourceService = _taskResourceService;
|
|
32
|
+
this._log = _log;
|
|
33
|
+
this._snackbar = _snackbar;
|
|
34
|
+
this._translate = _translate;
|
|
35
|
+
this._eventService = _eventService;
|
|
36
|
+
this._sanitizer = _sanitizer;
|
|
37
|
+
/**
|
|
38
|
+
* If file type can be displayed
|
|
39
|
+
*/
|
|
40
|
+
this.isDisplayable = false;
|
|
41
|
+
this.isFilePreview = false;
|
|
42
|
+
this.isFilePreviewButton = false;
|
|
43
|
+
this.state = this.defaultState;
|
|
44
|
+
this.fullSource = new BehaviorSubject(null);
|
|
45
|
+
this.taskId = dataFieldPortalData.additionalFieldProperties.taskId;
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Set :
|
|
49
|
+
* - File field to [FileFieldService]{@link FileFieldService}
|
|
50
|
+
* - Display name
|
|
51
|
+
*/
|
|
52
|
+
ngOnInit() {
|
|
53
|
+
this.isFilePreview = this.dataField?.component?.name === PREVIEW;
|
|
54
|
+
this.isFilePreviewButton = this.dataField?.component?.name === PREVIEW_BUTTON;
|
|
55
|
+
}
|
|
56
|
+
ngAfterViewInit() {
|
|
57
|
+
if (this.fileUploadEl) {
|
|
58
|
+
this.fileUploadEl.nativeElement.onchange = () => {
|
|
59
|
+
this.upload();
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
if (this.isFilePreview) {
|
|
63
|
+
if (!!this.imageDivEl) {
|
|
64
|
+
if (!this.isEmpty()) {
|
|
65
|
+
this.initializePreviewIfDisplayable();
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
if (this.isFilePreviewButton) {
|
|
70
|
+
if (!this.isEmpty()) {
|
|
71
|
+
this.initializePreviewIfDisplayable();
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
this.updatedFieldSubscription = this.dataField.updated.subscribe(() => {
|
|
75
|
+
this.previewSource = undefined;
|
|
76
|
+
if (!!this.isFilePreview && !!this.dataField?.value?.name) {
|
|
77
|
+
this.fileForDownload = undefined;
|
|
78
|
+
this.fileForPreview = undefined;
|
|
79
|
+
this.initializePreviewIfDisplayable();
|
|
80
|
+
}
|
|
81
|
+
if (!!this.isFilePreviewButton && !!this.dataField?.value?.name) {
|
|
82
|
+
this.fileForDownload = undefined;
|
|
83
|
+
this.fileForPreview = undefined;
|
|
84
|
+
this.initializePreviewIfDisplayable();
|
|
85
|
+
}
|
|
86
|
+
});
|
|
87
|
+
}
|
|
88
|
+
ngOnDestroy() {
|
|
89
|
+
super.ngOnDestroy();
|
|
90
|
+
this.fullSource.complete();
|
|
91
|
+
this.updatedFieldSubscription.unsubscribe();
|
|
92
|
+
}
|
|
93
|
+
chooseFile() {
|
|
94
|
+
if (this.state.uploading || this.formControlRef.disabled) {
|
|
95
|
+
return;
|
|
96
|
+
}
|
|
97
|
+
this.fileUploadEl.nativeElement.click();
|
|
98
|
+
}
|
|
99
|
+
/**
|
|
100
|
+
* Call after click on file field.
|
|
101
|
+
*
|
|
102
|
+
* If file field has no file uploaded
|
|
103
|
+
* [FilesUploadComponent]{@link AbstractFilesUploadComponent} via [SideMenu]{@link SideMenuService} opens.
|
|
104
|
+
*
|
|
105
|
+
* Otherwise opens a file picker from which the user can select files.
|
|
106
|
+
*/
|
|
107
|
+
upload() {
|
|
108
|
+
if (!this.fileUploadEl.nativeElement.files || this.fileUploadEl.nativeElement.files.length === 0) {
|
|
109
|
+
return;
|
|
110
|
+
}
|
|
111
|
+
if (!this.taskId) {
|
|
112
|
+
this._log.error('File cannot be uploaded. No task is set to the field.');
|
|
113
|
+
return;
|
|
114
|
+
}
|
|
115
|
+
if (this.dataField.value &&
|
|
116
|
+
this.dataField.value.name &&
|
|
117
|
+
this.fileUploadEl.nativeElement.files.item(0).name === this.dataField.value.name) {
|
|
118
|
+
this._log.error('User chose the same file. Uploading skipped');
|
|
119
|
+
this._snackbar.openErrorSnackBar(this._translate.instant('dataField.snackBar.wontUploadSameFile'));
|
|
120
|
+
this.fileUploadEl.nativeElement.value = '';
|
|
121
|
+
return;
|
|
122
|
+
}
|
|
123
|
+
if (this.dataField.maxUploadSizeInBytes &&
|
|
124
|
+
this.dataField.maxUploadSizeInBytes < this.fileUploadEl.nativeElement.files.item(0).size) {
|
|
125
|
+
this._log.error('File cannot be uploaded. Maximum size of file exceeded.');
|
|
126
|
+
this._snackbar.openErrorSnackBar(this._translate.instant('dataField.snackBar.maxFilesSizeExceeded') + this.dataField.maxUploadSizeInBytes);
|
|
127
|
+
this.fileUploadEl.nativeElement.value = '';
|
|
128
|
+
return;
|
|
129
|
+
}
|
|
130
|
+
this.state = this.defaultState;
|
|
131
|
+
this.state.uploading = true;
|
|
132
|
+
const fileFormData = new FormData();
|
|
133
|
+
const fileToUpload = this.fileUploadEl.nativeElement.files.item(0);
|
|
134
|
+
const data = {};
|
|
135
|
+
data[this.resolveParentTaskId()] = this.dataField.stringId;
|
|
136
|
+
fileFormData.append('file', fileToUpload);
|
|
137
|
+
fileFormData.append('data', new Blob([JSON.stringify(data)], { type: 'application/json' }));
|
|
138
|
+
this._taskResourceService.uploadFile(this.taskId, this.dataField.stringId, fileFormData, false)
|
|
139
|
+
.subscribe((response) => {
|
|
140
|
+
if (response.type && response.type === ProgressType.UPLOAD) {
|
|
141
|
+
this.state.progress = response.progress;
|
|
142
|
+
}
|
|
143
|
+
else {
|
|
144
|
+
this.state.completed = true;
|
|
145
|
+
this.state.uploading = false;
|
|
146
|
+
this.state.progress = 0;
|
|
147
|
+
if (response.error) {
|
|
148
|
+
this.state.error = true;
|
|
149
|
+
this._log.error(`File [${this.dataField.stringId}] ${this.fileUploadEl.nativeElement.files.item(0)} uploading has failed!`, response.error);
|
|
150
|
+
if (response.error) {
|
|
151
|
+
this._snackbar.openErrorSnackBar(this._translate.instant(response.error));
|
|
152
|
+
}
|
|
153
|
+
else {
|
|
154
|
+
this._snackbar.openErrorSnackBar(this._translate.instant('dataField.snackBar.fileUploadFailed'));
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
else {
|
|
158
|
+
const changedFieldsMap = this._eventService.parseChangedFieldsFromOutcomeTree(response.outcome);
|
|
159
|
+
this.dataField.emitChangedFields(changedFieldsMap);
|
|
160
|
+
this._log.debug(`File [${this.dataField.stringId}] ${this.fileUploadEl.nativeElement.files.item(0).name} was successfully uploaded`);
|
|
161
|
+
this.state.error = false;
|
|
162
|
+
this.dataField.downloaded = false;
|
|
163
|
+
this.dataField.value.name = fileToUpload.name;
|
|
164
|
+
if (this.isFilePreview) {
|
|
165
|
+
this.initializePreviewIfDisplayable();
|
|
166
|
+
}
|
|
167
|
+
this.fullSource.next(undefined);
|
|
168
|
+
this.fileForDownload = undefined;
|
|
169
|
+
this.formControlRef.setValue(this.dataField.value.name);
|
|
170
|
+
}
|
|
171
|
+
this.dataField.touch = true;
|
|
172
|
+
this.dataField.update();
|
|
173
|
+
this.fileUploadEl.nativeElement.value = '';
|
|
174
|
+
}
|
|
175
|
+
}, error => {
|
|
176
|
+
this.state.completed = true;
|
|
177
|
+
this.state.error = true;
|
|
178
|
+
this.state.uploading = false;
|
|
179
|
+
this.state.progress = 0;
|
|
180
|
+
this._log.error(`File [${this.dataField.stringId}] ${this.fileUploadEl.nativeElement.files.item(0)} uploading has failed!`, error);
|
|
181
|
+
if (error?.error?.message) {
|
|
182
|
+
this._snackbar.openErrorSnackBar(this._translate.instant(error.error.message));
|
|
183
|
+
}
|
|
184
|
+
else {
|
|
185
|
+
this._snackbar.openErrorSnackBar(this._translate.instant('dataField.snackBar.fileUploadFailed'));
|
|
186
|
+
}
|
|
187
|
+
this.dataField.touch = true;
|
|
188
|
+
this.dataField.update();
|
|
189
|
+
this.fileUploadEl.nativeElement.value = '';
|
|
190
|
+
});
|
|
191
|
+
}
|
|
192
|
+
download() {
|
|
193
|
+
if (!this.checkFileBeforeDownload()) {
|
|
194
|
+
return;
|
|
195
|
+
}
|
|
196
|
+
if (!!this.fileForDownload) {
|
|
197
|
+
this.downloadViaAnchor(this.fileForDownload);
|
|
198
|
+
return;
|
|
199
|
+
}
|
|
200
|
+
this.state = this.defaultState;
|
|
201
|
+
this.state.downloading = true;
|
|
202
|
+
this._taskResourceService.downloadFile(this.resolveParentTaskId(), this.dataField.stringId).subscribe(response => {
|
|
203
|
+
if (!response.type || response.type !== ProgressType.DOWNLOAD) {
|
|
204
|
+
this._log.debug(`File [${this.dataField.stringId}] ${this.dataField.value.name} was successfully downloaded`);
|
|
205
|
+
this.downloadViaAnchor(response);
|
|
206
|
+
if (this.isFilePreview) {
|
|
207
|
+
this.initDownloadFile(response);
|
|
208
|
+
}
|
|
209
|
+
this.state.downloading = false;
|
|
210
|
+
this.state.progress = 0;
|
|
211
|
+
this.dataField.downloaded = true;
|
|
212
|
+
}
|
|
213
|
+
}, error => {
|
|
214
|
+
this._log.error(`Downloading file [${this.dataField.stringId}] ${this.dataField.value.name} has failed!`, error);
|
|
215
|
+
this._snackbar.openErrorSnackBar(this.dataField.value.name + ' ' + this._translate.instant('dataField.snackBar.downloadFail'));
|
|
216
|
+
this.state.downloading = false;
|
|
217
|
+
this.state.progress = 0;
|
|
218
|
+
});
|
|
219
|
+
}
|
|
220
|
+
initDownloadFile(response) {
|
|
221
|
+
if (response instanceof Blob) {
|
|
222
|
+
if (this.previewExtension === FilePreviewType.pdf) {
|
|
223
|
+
this.fileForDownload = new Blob([response], { type: 'application/pdf' });
|
|
224
|
+
this.fullSource.next(this._sanitizer.bypassSecurityTrustResourceUrl(URL.createObjectURL(this.fileForDownload)));
|
|
225
|
+
}
|
|
226
|
+
else {
|
|
227
|
+
this.fileForDownload = new Blob([response], { type: 'application/octet-stream' });
|
|
228
|
+
this.fullSource.next(this._sanitizer.bypassSecurityTrustUrl(URL.createObjectURL(this.fileForDownload)));
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
downloadViaAnchor(blob) {
|
|
233
|
+
const a = document.createElement('a');
|
|
234
|
+
document.body.appendChild(a);
|
|
235
|
+
a.setAttribute('style', 'display: none');
|
|
236
|
+
if (!this.fileForDownload) {
|
|
237
|
+
blob = new Blob([blob], { type: 'application/octet-stream' });
|
|
238
|
+
}
|
|
239
|
+
const url = window.URL.createObjectURL(!!this.fileForDownload ? this.fileForDownload : blob);
|
|
240
|
+
a.href = url;
|
|
241
|
+
a.download = this.dataField.value.name;
|
|
242
|
+
a.click();
|
|
243
|
+
window.URL.revokeObjectURL(url);
|
|
244
|
+
document.body.removeChild(a);
|
|
245
|
+
}
|
|
246
|
+
deleteFile() {
|
|
247
|
+
if (!this.dataField.value || !this.dataField.value.name) {
|
|
248
|
+
return;
|
|
249
|
+
}
|
|
250
|
+
if (!this.taskId) {
|
|
251
|
+
this._log.error('File cannot be deleted. No task is set to the field.');
|
|
252
|
+
return;
|
|
253
|
+
}
|
|
254
|
+
let param = new HttpParams();
|
|
255
|
+
param = param.set("parentTaskId", this.resolveParentTaskId());
|
|
256
|
+
this._taskResourceService.deleteFile(this.taskId, this.dataField.stringId, undefined, param).pipe(take(1)).subscribe(response => {
|
|
257
|
+
if (response.success) {
|
|
258
|
+
const filename = this.dataField.value.name;
|
|
259
|
+
this.dataField.value = {};
|
|
260
|
+
this.formControlRef.setValue('');
|
|
261
|
+
this.dataField.update();
|
|
262
|
+
this.dataField.downloaded = false;
|
|
263
|
+
this.fullSource.next(undefined);
|
|
264
|
+
this.fileForDownload = undefined;
|
|
265
|
+
this.previewSource = undefined;
|
|
266
|
+
this.fileForPreview = undefined;
|
|
267
|
+
this._log.debug(`File [${this.dataField.stringId}] ${filename} was successfully deleted`);
|
|
268
|
+
this.formControlRef.markAsTouched();
|
|
269
|
+
}
|
|
270
|
+
else {
|
|
271
|
+
this._log.error(`Deleting file [${this.dataField.stringId}] ${this.dataField.value.name} has failed!`, response.error);
|
|
272
|
+
this._snackbar.openErrorSnackBar(this.dataField.value.name + ' ' + this._translate.instant('dataField.snackBar.fileDeleteFailed'));
|
|
273
|
+
}
|
|
274
|
+
});
|
|
275
|
+
}
|
|
276
|
+
isEmpty() {
|
|
277
|
+
return !this.dataField.value || !this.dataField.value.name;
|
|
278
|
+
}
|
|
279
|
+
get defaultState() {
|
|
280
|
+
return {
|
|
281
|
+
progress: 0,
|
|
282
|
+
completed: false,
|
|
283
|
+
error: false,
|
|
284
|
+
uploading: false,
|
|
285
|
+
downloading: false
|
|
286
|
+
};
|
|
287
|
+
}
|
|
288
|
+
/**
|
|
289
|
+
* Construct display name.
|
|
290
|
+
*/
|
|
291
|
+
constructDisplayName() {
|
|
292
|
+
if (!!this.dataField) {
|
|
293
|
+
if (!!this.dataField.value && !!this.dataField.value.name) {
|
|
294
|
+
return this.dataField.value.name;
|
|
295
|
+
}
|
|
296
|
+
else if (!!this.dataField.placeholder) {
|
|
297
|
+
return this.dataField.placeholder;
|
|
298
|
+
}
|
|
299
|
+
}
|
|
300
|
+
return this._translate.instant('dataField.file.noFile');
|
|
301
|
+
}
|
|
302
|
+
/**
|
|
303
|
+
* Initialize file field image from backend if it is image type.
|
|
304
|
+
*/
|
|
305
|
+
initFileFieldImage() {
|
|
306
|
+
if (!this.checkFileBeforeDownload()) {
|
|
307
|
+
return;
|
|
308
|
+
}
|
|
309
|
+
this.state.downloading = true;
|
|
310
|
+
this._taskResourceService.downloadFilePreview(this.resolveParentTaskId(), this.dataField.stringId).subscribe(response => {
|
|
311
|
+
if (response instanceof Blob) {
|
|
312
|
+
this._log.debug(`Preview of file [${this.dataField.stringId}] ${this.dataField.value.name} was successfully downloaded`);
|
|
313
|
+
this.fileForPreview = new Blob([response], { type: 'application/octet-stream' });
|
|
314
|
+
this.previewSource = this._sanitizer.bypassSecurityTrustUrl(URL.createObjectURL(this.fileForPreview));
|
|
315
|
+
}
|
|
316
|
+
if (response == null || response instanceof Blob) {
|
|
317
|
+
this.state.downloading = false;
|
|
318
|
+
}
|
|
319
|
+
}, error => {
|
|
320
|
+
this._log.error(`Downloading file [${this.dataField.stringId}] ${this.dataField.value.name} has failed!`, error);
|
|
321
|
+
this._snackbar.openErrorSnackBar(this.dataField.value.name + ' ' + this._translate.instant('dataField.snackBar.downloadFail'));
|
|
322
|
+
this.state.downloading = false;
|
|
323
|
+
this.state.progress = 0;
|
|
324
|
+
});
|
|
325
|
+
}
|
|
326
|
+
checkFileBeforeDownload() {
|
|
327
|
+
if (this.isEmpty()) {
|
|
328
|
+
return false;
|
|
329
|
+
}
|
|
330
|
+
if (!this.taskId) {
|
|
331
|
+
this._log.error('File cannot be downloaded. No task is set to the field.');
|
|
332
|
+
return false;
|
|
333
|
+
}
|
|
334
|
+
return true;
|
|
335
|
+
}
|
|
336
|
+
showPreviewDialog() {
|
|
337
|
+
if (!this.checkFileBeforeDownload()) {
|
|
338
|
+
return;
|
|
339
|
+
}
|
|
340
|
+
this._taskResourceService.downloadFile(this.resolveParentTaskId(), this.dataField.stringId).subscribe(response => {
|
|
341
|
+
if (!response.type || response.type !== ProgressType.DOWNLOAD) {
|
|
342
|
+
this._log.debug(`File [${this.dataField.stringId}] ${this.dataField.value.name} was successfully downloaded`);
|
|
343
|
+
this.initDownloadFile(response);
|
|
344
|
+
}
|
|
345
|
+
}, error => {
|
|
346
|
+
this._log.error(`Downloading file [${this.dataField.stringId}] ${this.dataField.value.name} has failed!`, error);
|
|
347
|
+
this._snackbar.openErrorSnackBar(this.dataField.value.name + ' ' + this._translate.instant('dataField.snackBar.downloadFail'));
|
|
348
|
+
this.state.progress = 0;
|
|
349
|
+
});
|
|
350
|
+
}
|
|
351
|
+
changeMaxWidth(event) {
|
|
352
|
+
if (!!this.imageEl) {
|
|
353
|
+
this.imageEl.nativeElement.style.maxWidth = event.newRect.width + 'px';
|
|
354
|
+
}
|
|
355
|
+
}
|
|
356
|
+
initializePreviewIfDisplayable() {
|
|
357
|
+
const extension = this.dataField.value.name.split('.').reverse()[0];
|
|
358
|
+
this.isDisplayable = Object.values(FilePreviewType).includes(extension);
|
|
359
|
+
if (this.isDisplayable) {
|
|
360
|
+
this.previewExtension = FilePreviewType[extension];
|
|
361
|
+
this.initFileFieldImage();
|
|
362
|
+
}
|
|
363
|
+
}
|
|
364
|
+
getHeight() {
|
|
365
|
+
return this.dataField.layout && this.dataField.layout.rows && this.dataField.layout.rows !== 1 ?
|
|
366
|
+
(this.dataField.layout.rows) * FILE_FIELD_HEIGHT - FILE_FIELD_PADDING : FILE_FIELD_HEIGHT - FILE_FIELD_PADDING;
|
|
367
|
+
}
|
|
368
|
+
getPreviewBorderWidth() {
|
|
369
|
+
if (this.borderPropertyEnabled('borderWidth')) {
|
|
370
|
+
return this.dataField.component.properties.borderWidth + 'px';
|
|
371
|
+
}
|
|
372
|
+
return `${AbstractFileDefaultFieldComponent.DEFAULT_PREVIEW_BORDER_WIDTH}px`;
|
|
373
|
+
}
|
|
374
|
+
getPreviewBorderStyle() {
|
|
375
|
+
if (this.borderPropertyEnabled('borderStyle')) {
|
|
376
|
+
return this.dataField.component.properties.borderStyle;
|
|
377
|
+
}
|
|
378
|
+
return AbstractFileDefaultFieldComponent.DEFAULT_PREVIEW_BORDER_STYLE;
|
|
379
|
+
}
|
|
380
|
+
getPreviewBorderColor() {
|
|
381
|
+
if (this.borderPropertyEnabled('borderColor')) {
|
|
382
|
+
return this.dataField.component.properties.borderColor;
|
|
383
|
+
}
|
|
384
|
+
return AbstractFileDefaultFieldComponent.DEFAULT_PREVIEW_BORDER_COLOR;
|
|
385
|
+
}
|
|
386
|
+
isBorderLGBTQ() {
|
|
387
|
+
if (this.borderPropertyEnabled('borderLGBTQ')) {
|
|
388
|
+
return this.dataField.component.properties.borderLGBTQ === 'true';
|
|
389
|
+
}
|
|
390
|
+
return false;
|
|
391
|
+
}
|
|
392
|
+
isBorderDefault() {
|
|
393
|
+
if (this.borderPropertyEnabled('borderEnabled')) {
|
|
394
|
+
return this.dataField.component.properties.borderEnabled === 'true';
|
|
395
|
+
}
|
|
396
|
+
return false;
|
|
397
|
+
}
|
|
398
|
+
borderPropertyEnabled(property) {
|
|
399
|
+
return !!this.dataField.component && !!this.dataField.component.properties && property in this.dataField.component.properties;
|
|
400
|
+
}
|
|
401
|
+
resolveParentTaskId() {
|
|
402
|
+
return !!this.dataField.parentTaskId ? this.dataField.parentTaskId : this.taskId;
|
|
403
|
+
}
|
|
404
|
+
hasTitle() {
|
|
405
|
+
return this.dataField.title !== undefined && this.dataField.title !== '';
|
|
406
|
+
}
|
|
407
|
+
hasHint() {
|
|
408
|
+
return this.dataField.description !== undefined && this.dataField.description !== '';
|
|
409
|
+
}
|
|
410
|
+
getCutProperty(i18nLabel) {
|
|
411
|
+
if (this.labelWidth !== i18nLabel.offsetWidth) {
|
|
412
|
+
this.labelWidth = i18nLabel.offsetWidth;
|
|
413
|
+
const calculatedWidth = 'calc(0.5em + ' + i18nLabel.offsetWidth / 4 * 3 + 'px)';
|
|
414
|
+
this.cutProperty = `polygon(0 0, 0 100%, 100% 100%, 100% 0%, ${calculatedWidth} 0, ${calculatedWidth} 6%, 0.5em 6%, 0.5em 0)`;
|
|
415
|
+
}
|
|
416
|
+
return this.cutProperty;
|
|
417
|
+
}
|
|
418
|
+
}
|
|
419
|
+
/**
|
|
420
|
+
* The width of the default file preview border in pixels. The `px` string is appended in the code.
|
|
421
|
+
*/
|
|
422
|
+
AbstractFileDefaultFieldComponent.DEFAULT_PREVIEW_BORDER_WIDTH = 0;
|
|
423
|
+
/**
|
|
424
|
+
* The CSS style attribute of the default file preview border.
|
|
425
|
+
*/
|
|
426
|
+
AbstractFileDefaultFieldComponent.DEFAULT_PREVIEW_BORDER_STYLE = 'none';
|
|
427
|
+
/**
|
|
428
|
+
* The CSS color string of the default file preview border.
|
|
429
|
+
*/
|
|
430
|
+
AbstractFileDefaultFieldComponent.DEFAULT_PREVIEW_BORDER_COLOR = 'black';
|
|
431
|
+
AbstractFileDefaultFieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: AbstractFileDefaultFieldComponent, deps: [{ token: i1.TaskResourceService }, { token: i2.LoggerService }, { token: i3.SnackBarService }, { token: i4.TranslateService }, { token: i5.EventService }, { token: i6.DomSanitizer }, { token: DATA_FIELD_PORTAL_DATA, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
432
|
+
AbstractFileDefaultFieldComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.12", type: AbstractFileDefaultFieldComponent, selector: "ncc-abstract-file-default-fied", inputs: { taskId: "taskId" }, viewQueries: [{ propertyName: "fileUploadEl", first: true, predicate: ["fileUploadInput"], descendants: true }, { propertyName: "imageEl", first: true, predicate: ["imageEl"], descendants: true }, { propertyName: "imageDivEl", first: true, predicate: ["imageDiv"], descendants: true }], usesInheritance: true, ngImport: i0, template: '', isInline: true });
|
|
433
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.12", ngImport: i0, type: AbstractFileDefaultFieldComponent, decorators: [{
|
|
434
|
+
type: Component,
|
|
435
|
+
args: [{
|
|
436
|
+
selector: 'ncc-abstract-file-default-fied',
|
|
437
|
+
template: ''
|
|
438
|
+
}]
|
|
439
|
+
}], ctorParameters: function () { return [{ type: i1.TaskResourceService }, { type: i2.LoggerService }, { type: i3.SnackBarService }, { type: i4.TranslateService }, { type: i5.EventService }, { type: i6.DomSanitizer }, { type: undefined, decorators: [{
|
|
440
|
+
type: Optional
|
|
441
|
+
}, {
|
|
442
|
+
type: Inject,
|
|
443
|
+
args: [DATA_FIELD_PORTAL_DATA]
|
|
444
|
+
}] }]; }, propDecorators: { taskId: [{
|
|
445
|
+
type: Input
|
|
446
|
+
}], fileUploadEl: [{
|
|
447
|
+
type: ViewChild,
|
|
448
|
+
args: ['fileUploadInput']
|
|
449
|
+
}], imageEl: [{
|
|
450
|
+
type: ViewChild,
|
|
451
|
+
args: ['imageEl']
|
|
452
|
+
}], imageDivEl: [{
|
|
453
|
+
type: ViewChild,
|
|
454
|
+
args: ['imageDiv']
|
|
455
|
+
}] } });
|
|
456
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-file-default-field.component.js","sourceRoot":"","sources":["../../../../../../../projects/netgrif-components-core/src/lib/data-fields/file-field/file-default-field/abstract-file-default-field.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    Component,\n    ElementRef,\n    Inject,\n    Input,\n    OnDestroy,\n    OnInit,\n    Optional,\n    ViewChild\n} from \"@angular/core\";\nimport {FileField, FilePreviewType} from \"../models/file-field\";\nimport {DomSanitizer, SafeUrl} from \"@angular/platform-browser\";\nimport {BehaviorSubject, Subscription} from \"rxjs\";\nimport {TaskResourceService} from \"../../../resources/engine-endpoint/task-resource.service\";\nimport {LoggerService} from \"../../../logger/services/logger.service\";\nimport {SnackBarService} from \"../../../snack-bar/services/snack-bar.service\";\nimport {TranslateService} from \"@ngx-translate/core\";\nimport {EventService} from \"../../../event/services/event.service\";\nimport {FileFieldIdBody} from \"../../models/file-field-id-body\";\nimport {EventOutcomeMessageResource} from \"../../../resources/interface/message-resource\";\nimport {ProgressType, ProviderProgress} from \"../../../resources/resource-provider.service\";\nimport {ChangedFieldsMap} from \"../../../event/services/interfaces/changed-fields-map\";\nimport {HttpParams} from \"@angular/common/http\";\nimport {take} from \"rxjs/operators\";\nimport {ResizedEvent} from \"angular-resize-event\";\nimport {DATA_FIELD_PORTAL_DATA, DataFieldPortalData} from \"../../models/data-field-portal-data-injection-token\";\nimport {AbstractBaseDataFieldComponent} from \"../../base-component/abstract-base-data-field.component\";\nimport {FILE_FIELD_HEIGHT, FILE_FIELD_PADDING, PREVIEW, PREVIEW_BUTTON} from '../models/file-field-constants';\n\nexport interface FileState {\n    progress: number;\n    uploading: boolean;\n    downloading: boolean;\n    completed: boolean;\n    error: boolean;\n}\n\n@Component({\n    selector: 'ncc-abstract-file-default-fied',\n    template: ''\n})\nexport abstract class AbstractFileDefaultFieldComponent extends AbstractBaseDataFieldComponent<FileField> implements OnInit, AfterViewInit, OnDestroy {\n    /**\n     * The width of the default file preview border in pixels. The `px` string is appended in the code.\n     */\n    public static readonly DEFAULT_PREVIEW_BORDER_WIDTH = 0;\n    /**\n     * The CSS style attribute of the default file preview border.\n     */\n    public static readonly DEFAULT_PREVIEW_BORDER_STYLE = 'none';\n    /**\n     * The CSS color string of the default file preview border.\n     */\n    public static readonly DEFAULT_PREVIEW_BORDER_COLOR = 'black';\n\n    public state: FileState;\n    /**\n     * Task mongo string id is binding property from parent component.\n     */\n    @Input() public taskId: string;\n\n    /**\n     * File picker element reference from component template that is initialized after view init.\n     */\n    @ViewChild('fileUploadInput') public fileUploadEl: ElementRef<HTMLInputElement>;\n    /**\n     * Image field view element reference from component template that is initialized after view init.\n     */\n    @ViewChild('imageEl') public imageEl: ElementRef;\n\n    @ViewChild('imageDiv') public imageDivEl: ElementRef;\n    /**\n     * If file type can be displayed\n     */\n    public isDisplayable = false;\n    /**\n     * Max height of preview\n     */\n    private maxHeight: string;\n    /**\n     * Store file for preview\n     */\n    private fileForPreview: Blob;\n    /**\n     * Url of preview file\n     */\n    public previewSource: SafeUrl;\n    /**\n     * Store file to show/download\n     */\n    private fileForDownload: Blob;\n    /**\n     * Full size file url\n     */\n    public fullSource: BehaviorSubject<SafeUrl>;\n    /**\n     * Extension of file to preview\n     */\n    public previewExtension: FilePreviewType;\n    /**\n     * Form control subscription\n     */\n    private updatedFieldSubscription: Subscription;\n\n    public isFilePreview = false;\n    public isFilePreviewButton = false;\n    private labelWidth: number;\n    public cutProperty: string;\n\n    /**\n     * Only inject services.\n     * @param _taskResourceService Provides to download a file from the backend\n     * @param _log Logger service\n     * @param _snackbar Snackbar service to notify user\n     * @param _translate Translate service for I18N\n     * @param _eventService used for parsing of backend response\n     * Option injected trough `NAE_INFORM_ABOUT_INVALID_DATA` InjectionToken\n     * @param _sanitizer Sanitize url of image preview\n     * @param dataFieldPortalData Field and form control data if field is provided with portal\n     */\n    protected constructor(protected _taskResourceService: TaskResourceService,\n                          protected _log: LoggerService,\n                          protected _snackbar: SnackBarService,\n                          protected _translate: TranslateService,\n                          protected _eventService: EventService,\n                          protected _sanitizer: DomSanitizer,\n                          @Optional() @Inject(DATA_FIELD_PORTAL_DATA) dataFieldPortalData: DataFieldPortalData<FileField>) {\n        super(dataFieldPortalData);\n        this.state = this.defaultState;\n        this.fullSource = new BehaviorSubject<SafeUrl>(null);\n        this.taskId = dataFieldPortalData.additionalFieldProperties.taskId as string;\n    }\n\n    /**\n     * Set :\n     *  - File field to [FileFieldService]{@link FileFieldService}\n     *  - Display name\n     */\n    ngOnInit() {\n        this.isFilePreview = this.dataField?.component?.name === PREVIEW;\n        this.isFilePreviewButton = this.dataField?.component?.name === PREVIEW_BUTTON;\n    }\n\n    ngAfterViewInit() {\n        if (this.fileUploadEl) {\n            this.fileUploadEl.nativeElement.onchange = () => {\n                this.upload();\n            };\n        }\n        if (this.isFilePreview) {\n            if (!!this.imageDivEl) {\n                if (!this.isEmpty()) {\n                    this.initializePreviewIfDisplayable();\n                }\n            }\n        }\n        if (this.isFilePreviewButton) {\n            if (!this.isEmpty()) {\n                this.initializePreviewIfDisplayable();\n            }\n        }\n        this.updatedFieldSubscription = this.dataField.updated.subscribe(() => {\n            this.previewSource = undefined;\n            if (!!this.isFilePreview && !!this.dataField?.value?.name) {\n                this.fileForDownload = undefined;\n                this.fileForPreview = undefined;\n                this.initializePreviewIfDisplayable();\n            }\n            if (!!this.isFilePreviewButton && !!this.dataField?.value?.name) {\n                this.fileForDownload = undefined;\n                this.fileForPreview = undefined;\n                this.initializePreviewIfDisplayable();\n            }\n        })\n    }\n\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n        this.fullSource.complete();\n        this.updatedFieldSubscription.unsubscribe();\n    }\n\n    public chooseFile() {\n        if (this.state.uploading || this.formControlRef.disabled) {\n            return;\n        }\n        this.fileUploadEl.nativeElement.click();\n    }\n\n    /**\n     * Call after click on file field.\n     *\n     * If file field has no file uploaded\n     * [FilesUploadComponent]{@link AbstractFilesUploadComponent} via [SideMenu]{@link SideMenuService} opens.\n     *\n     * Otherwise opens a file picker from which the user can select files.\n     */\n    public upload() {\n        if (!this.fileUploadEl.nativeElement.files || this.fileUploadEl.nativeElement.files.length === 0) {\n            return;\n        }\n        if (!this.taskId) {\n            this._log.error('File cannot be uploaded. No task is set to the field.');\n            return;\n        }\n        if (this.dataField.value &&\n            this.dataField.value.name &&\n            this.fileUploadEl.nativeElement.files.item(0).name === this.dataField.value.name) {\n            this._log.error('User chose the same file. Uploading skipped');\n            this._snackbar.openErrorSnackBar(this._translate.instant('dataField.snackBar.wontUploadSameFile'));\n            this.fileUploadEl.nativeElement.value = '';\n            return;\n        }\n        if (this.dataField.maxUploadSizeInBytes &&\n            this.dataField.maxUploadSizeInBytes < this.fileUploadEl.nativeElement.files.item(0).size) {\n            this._log.error('File cannot be uploaded. Maximum size of file exceeded.');\n            this._snackbar.openErrorSnackBar(\n                this._translate.instant('dataField.snackBar.maxFilesSizeExceeded') + this.dataField.maxUploadSizeInBytes\n            );\n            this.fileUploadEl.nativeElement.value = '';\n            return;\n        }\n        this.state = this.defaultState;\n        this.state.uploading = true;\n        const fileFormData = new FormData();\n        const fileToUpload = this.fileUploadEl.nativeElement.files.item(0) as File;\n        const data: FileFieldIdBody = {};\n        data[this.resolveParentTaskId()] = this.dataField.stringId;\n        fileFormData.append('file', fileToUpload);\n        fileFormData.append('data', new Blob([JSON.stringify(data)], {type: 'application/json'}));\n        this._taskResourceService.uploadFile(this.taskId, this.dataField.stringId, fileFormData, false)\n            .subscribe((response: EventOutcomeMessageResource) => {\n                if ((response as ProviderProgress).type && (response as ProviderProgress).type === ProgressType.UPLOAD) {\n                    this.state.progress = (response as ProviderProgress).progress;\n                } else {\n                    this.state.completed = true;\n                    this.state.uploading = false;\n                    this.state.progress = 0;\n\n                    if (response.error) {\n                        this.state.error = true;\n                        this._log.error(\n                            `File [${this.dataField.stringId}] ${this.fileUploadEl.nativeElement.files.item(0)} uploading has failed!`, response.error\n                        );\n                        if (response.error) {\n                            this._snackbar.openErrorSnackBar(this._translate.instant(response.error));\n                        } else {\n                            this._snackbar.openErrorSnackBar(this._translate.instant('dataField.snackBar.fileUploadFailed'));\n                        }\n                    } else {\n                        const changedFieldsMap: ChangedFieldsMap = this._eventService.parseChangedFieldsFromOutcomeTree(response.outcome);\n                        this.dataField.emitChangedFields(changedFieldsMap);\n                        this._log.debug(\n                            `File [${this.dataField.stringId}] ${this.fileUploadEl.nativeElement.files.item(0).name} was successfully uploaded`\n                        );\n                        this.state.error = false;\n                        this.dataField.downloaded = false;\n                        this.dataField.value.name = fileToUpload.name;\n                        if (this.isFilePreview) {\n                            this.initializePreviewIfDisplayable();\n                        }\n                        this.fullSource.next(undefined);\n                        this.fileForDownload = undefined;\n                        this.formControlRef.setValue(this.dataField.value.name);\n                    }\n                    this.dataField.touch = true;\n                    this.dataField.update();\n                    this.fileUploadEl.nativeElement.value = '';\n                }\n            }, error => {\n                this.state.completed = true;\n                this.state.error = true;\n                this.state.uploading = false;\n                this.state.progress = 0;\n                this._log.error(\n                    `File [${this.dataField.stringId}] ${this.fileUploadEl.nativeElement.files.item(0)} uploading has failed!`, error\n                );\n                if (error?.error?.message) {\n                    this._snackbar.openErrorSnackBar(this._translate.instant(error.error.message));\n                } else {\n                    this._snackbar.openErrorSnackBar(this._translate.instant('dataField.snackBar.fileUploadFailed'));\n                }\n                this.dataField.touch = true;\n                this.dataField.update();\n                this.fileUploadEl.nativeElement.value = '';\n            });\n    }\n\n    public download() {\n        if (!this.checkFileBeforeDownload()) {\n            return;\n        }\n        if (!!this.fileForDownload) {\n            this.downloadViaAnchor(this.fileForDownload);\n            return;\n        }\n        this.state = this.defaultState;\n        this.state.downloading = true;\n        this._taskResourceService.downloadFile(this.resolveParentTaskId(),\n            this.dataField.stringId).subscribe(response => {\n            if (!(response as ProviderProgress).type || (response as ProviderProgress).type !== ProgressType.DOWNLOAD) {\n                this._log.debug(`File [${this.dataField.stringId}] ${this.dataField.value.name} was successfully downloaded`);\n                this.downloadViaAnchor(response as Blob);\n                if (this.isFilePreview) {\n                    this.initDownloadFile(response);\n                }\n                this.state.downloading = false;\n                this.state.progress = 0;\n                this.dataField.downloaded = true;\n            }\n        }, error => {\n            this._log.error(`Downloading file [${this.dataField.stringId}] ${this.dataField.value.name} has failed!`, error);\n            this._snackbar.openErrorSnackBar(\n                this.dataField.value.name + ' ' + this._translate.instant('dataField.snackBar.downloadFail')\n            );\n            this.state.downloading = false;\n            this.state.progress = 0;\n        });\n    }\n\n    private initDownloadFile(response: Blob | ProviderProgress) {\n        if (response instanceof Blob) {\n            if (this.previewExtension === FilePreviewType.pdf) {\n                this.fileForDownload = new Blob([response], {type: 'application/pdf'});\n                this.fullSource.next(this._sanitizer.bypassSecurityTrustResourceUrl(URL.createObjectURL(this.fileForDownload)));\n            } else {\n                this.fileForDownload = new Blob([response], {type: 'application/octet-stream'});\n                this.fullSource.next(this._sanitizer.bypassSecurityTrustUrl(URL.createObjectURL(this.fileForDownload)));\n            }\n        }\n    }\n\n    protected downloadViaAnchor(blob: Blob): void {\n        const a = document.createElement('a');\n        document.body.appendChild(a);\n        a.setAttribute('style', 'display: none');\n        if (!this.fileForDownload) {\n            blob = new Blob([blob], {type: 'application/octet-stream'});\n        }\n        const url = window.URL.createObjectURL(!!this.fileForDownload ? this.fileForDownload : blob);\n        a.href = url;\n        a.download = this.dataField.value.name;\n        a.click();\n        window.URL.revokeObjectURL(url);\n        document.body.removeChild(a);\n    }\n\n    public deleteFile() {\n        if (!this.dataField.value || !this.dataField.value.name) {\n            return;\n        }\n        if (!this.taskId) {\n            this._log.error('File cannot be deleted. No task is set to the field.');\n            return;\n        }\n        let param = new HttpParams();\n        param = param.set(\"parentTaskId\", this.resolveParentTaskId());\n\n        this._taskResourceService.deleteFile(this.taskId,\n            this.dataField.stringId, undefined, param).pipe(take(1)).subscribe(response => {\n            if (response.success) {\n                const filename = this.dataField.value.name;\n                this.dataField.value = {};\n                this.formControlRef.setValue('');\n                this.dataField.update();\n                this.dataField.downloaded = false;\n                this.fullSource.next(undefined);\n                this.fileForDownload = undefined;\n                this.previewSource = undefined;\n                this.fileForPreview = undefined;\n                this._log.debug(`File [${this.dataField.stringId}] ${filename} was successfully deleted`);\n                this.formControlRef.markAsTouched();\n            } else {\n                this._log.error(`Deleting file [${this.dataField.stringId}] ${this.dataField.value.name} has failed!`, response.error);\n                this._snackbar.openErrorSnackBar(\n                    this.dataField.value.name + ' ' + this._translate.instant('dataField.snackBar.fileDeleteFailed')\n                );\n            }\n        });\n    }\n\n    isEmpty(): boolean {\n        return !this.dataField.value || !this.dataField.value.name;\n    }\n\n    protected get defaultState(): FileState {\n        return {\n            progress: 0,\n            completed: false,\n            error: false,\n            uploading: false,\n            downloading: false\n        };\n    }\n\n    /**\n     * Construct display name.\n     */\n    public constructDisplayName(): string {\n        if (!!this.dataField) {\n            if (!!this.dataField.value && !!this.dataField.value.name) {\n                return this.dataField.value.name;\n            } else if (!!this.dataField.placeholder) {\n                return this.dataField.placeholder;\n            }\n        }\n        return this._translate.instant('dataField.file.noFile');\n    }\n\n    /**\n     * Initialize file field image from backend if it is image type.\n     */\n    protected initFileFieldImage() {\n        if (!this.checkFileBeforeDownload()) {\n            return;\n        }\n        this.state.downloading = true;\n        this._taskResourceService.downloadFilePreview(this.resolveParentTaskId(), this.dataField.stringId).subscribe(response => {\n            if (response instanceof Blob) {\n                this._log.debug(`Preview of file [${this.dataField.stringId}] ${this.dataField.value.name} was successfully downloaded`);\n                this.fileForPreview = new Blob([response], {type: 'application/octet-stream'});\n                this.previewSource = this._sanitizer.bypassSecurityTrustUrl(URL.createObjectURL(this.fileForPreview));\n            }\n            if (response == null || response instanceof Blob) {\n                this.state.downloading = false;\n            }\n        }, error => {\n            this._log.error(`Downloading file [${this.dataField.stringId}] ${this.dataField.value.name} has failed!`, error);\n            this._snackbar.openErrorSnackBar(\n                this.dataField.value.name + ' ' + this._translate.instant('dataField.snackBar.downloadFail')\n            );\n            this.state.downloading = false;\n            this.state.progress = 0;\n        });\n    }\n\n    protected checkFileBeforeDownload() {\n        if (this.isEmpty()) {\n            return false;\n        }\n        if (!this.taskId) {\n            this._log.error('File cannot be downloaded. No task is set to the field.');\n            return false;\n        }\n        return true;\n    }\n\n    public showPreviewDialog() {\n        if (!this.checkFileBeforeDownload()) {\n            return;\n        }\n        this._taskResourceService.downloadFile(this.resolveParentTaskId(), this.dataField.stringId).subscribe(response => {\n            if (!(response as ProviderProgress).type || (response as ProviderProgress).type !== ProgressType.DOWNLOAD) {\n                this._log.debug(`File [${this.dataField.stringId}] ${this.dataField.value.name} was successfully downloaded`);\n                this.initDownloadFile(response);\n            }\n        }, error => {\n            this._log.error(`Downloading file [${this.dataField.stringId}] ${this.dataField.value.name} has failed!`, error);\n            this._snackbar.openErrorSnackBar(\n                this.dataField.value.name + ' ' + this._translate.instant('dataField.snackBar.downloadFail')\n            );\n            this.state.progress = 0;\n        });\n    }\n\n    public changeMaxWidth(event: ResizedEvent) {\n        if (!!this.imageEl) {\n            this.imageEl.nativeElement.style.maxWidth = event.newRect.width + 'px';\n        }\n    }\n\n    protected initializePreviewIfDisplayable() {\n        const extension = this.dataField.value.name.split('.').reverse()[0];\n        this.isDisplayable = Object.values(FilePreviewType).includes(extension as any);\n        if (this.isDisplayable) {\n            this.previewExtension = FilePreviewType[extension];\n            this.initFileFieldImage();\n        }\n    }\n\n    public getHeight() {\n        return this.dataField.layout && this.dataField.layout.rows && this.dataField.layout.rows !== 1 ?\n            (this.dataField.layout.rows) * FILE_FIELD_HEIGHT - FILE_FIELD_PADDING : FILE_FIELD_HEIGHT - FILE_FIELD_PADDING;\n    }\n\n    public getPreviewBorderWidth(): string {\n        if (this.borderPropertyEnabled('borderWidth')) {\n            return this.dataField.component.properties.borderWidth + 'px';\n        }\n        return `${AbstractFileDefaultFieldComponent.DEFAULT_PREVIEW_BORDER_WIDTH}px`;\n    }\n\n    public getPreviewBorderStyle(): string {\n        if (this.borderPropertyEnabled('borderStyle')) {\n            return this.dataField.component.properties.borderStyle;\n        }\n        return AbstractFileDefaultFieldComponent.DEFAULT_PREVIEW_BORDER_STYLE;\n    }\n\n    public getPreviewBorderColor(): string {\n        if (this.borderPropertyEnabled('borderColor')) {\n            return this.dataField.component.properties.borderColor;\n        }\n        return AbstractFileDefaultFieldComponent.DEFAULT_PREVIEW_BORDER_COLOR;\n    }\n\n    public isBorderLGBTQ(): boolean {\n        if (this.borderPropertyEnabled('borderLGBTQ')) {\n            return this.dataField.component.properties.borderLGBTQ === 'true';\n        }\n        return false;\n    }\n\n    public isBorderDefault(): boolean {\n        if (this.borderPropertyEnabled('borderEnabled')) {\n            return this.dataField.component.properties.borderEnabled === 'true';\n        }\n        return false;\n    }\n\n    public borderPropertyEnabled(property: string): boolean {\n        return !!this.dataField.component && !!this.dataField.component.properties && property in this.dataField.component.properties;\n    }\n\n    protected resolveParentTaskId(): string {\n        return !!this.dataField.parentTaskId ? this.dataField.parentTaskId : this.taskId;\n    }\n\n    public hasTitle(): boolean {\n        return this.dataField.title !== undefined && this.dataField.title !== '';\n    }\n\n    public hasHint(): boolean {\n        return this.dataField.description !== undefined && this.dataField.description !== '';\n    }\n\n    public getCutProperty(i18nLabel): string {\n        if (this.labelWidth !== i18nLabel.offsetWidth) {\n            this.labelWidth = i18nLabel.offsetWidth;\n            const calculatedWidth = 'calc(0.5em + ' + i18nLabel.offsetWidth / 4 * 3 + 'px)';\n            this.cutProperty = `polygon(0 0, 0 100%, 100% 100%, 100% 0%, ${calculatedWidth} 0, ${calculatedWidth} 6%, 0.5em 6%, 0.5em 0)`;\n        }\n        return this.cutProperty;\n    }\n}\n"]}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export const PREVIEW = 'preview';
|
|
2
|
+
export const PREVIEW_BUTTON = 'preview_button';
|
|
3
|
+
export const FILE_FIELD_HEIGHT = 75;
|
|
4
|
+
export const FILE_FIELD_PADDING = 16;
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1maWVsZC1jb25zdGFudHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZXRncmlmLWNvbXBvbmVudHMtY29yZS9zcmMvbGliL2RhdGEtZmllbGRzL2ZpbGUtZmllbGQvbW9kZWxzL2ZpbGUtZmllbGQtY29uc3RhbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBQyxNQUFNLE9BQU8sR0FBRyxTQUFTLENBQUM7QUFFakMsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHLGdCQUFnQixDQUFDO0FBRS9DLE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHLEVBQUUsQ0FBQztBQUVwQyxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxFQUFFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY29uc3QgUFJFVklFVyA9ICdwcmV2aWV3JztcblxuZXhwb3J0IGNvbnN0IFBSRVZJRVdfQlVUVE9OID0gJ3ByZXZpZXdfYnV0dG9uJztcblxuZXhwb3J0IGNvbnN0IEZJTEVfRklFTERfSEVJR0hUID0gNzU7XG5cbmV4cG9ydCBjb25zdCBGSUxFX0ZJRUxEX1BBRERJTkcgPSAxNjtcbiJdfQ==
|