geonetwork-ui 2.4.0-dev.f5019723 → 2.4.0-dev.fdf8f64b
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/libs/feature/editor/src/lib/components/import-record/import-record.component.mjs +2 -2
- package/esm2022/libs/feature/editor/src/lib/components/online-service-resource-input/online-service-resource-input.component.mjs +72 -0
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.mjs +6 -4
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-resources/form-field-online-resources.component.mjs +191 -0
- package/esm2022/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.mjs +8 -6
- package/esm2022/libs/feature/editor/src/lib/fields.config.mjs +10 -2
- package/esm2022/libs/ui/inputs/src/lib/file-input/file-input.component.mjs +3 -3
- package/esm2022/libs/ui/inputs/src/lib/image-input/image-input.component.mjs +2 -2
- package/esm2022/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.mjs +5 -3
- package/esm2022/libs/ui/inputs/src/lib/url-input/url-input.component.mjs +20 -4
- package/esm2022/translations/de.json +7 -0
- package/esm2022/translations/en.json +7 -0
- package/esm2022/translations/es.json +7 -0
- package/esm2022/translations/fr.json +8 -1
- package/esm2022/translations/it.json +7 -0
- package/esm2022/translations/nl.json +7 -0
- package/esm2022/translations/pt.json +7 -0
- package/fesm2022/geonetwork-ui.mjs +644 -336
- package/fesm2022/geonetwork-ui.mjs.map +1 -1
- package/libs/feature/editor/src/lib/components/online-service-resource-input/online-service-resource-input.component.d.ts +16 -0
- package/libs/feature/editor/src/lib/components/online-service-resource-input/online-service-resource-input.component.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-resources/form-field-online-resources.component.d.ts +44 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-resources/form-field-online-resources.component.d.ts.map +1 -0
- package/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.d.ts.map +1 -1
- package/libs/feature/editor/src/lib/fields.config.d.ts +1 -0
- package/libs/feature/editor/src/lib/fields.config.d.ts.map +1 -1
- package/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.d.ts +1 -0
- package/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.d.ts.map +1 -1
- package/libs/ui/inputs/src/lib/url-input/url-input.component.d.ts +6 -3
- package/libs/ui/inputs/src/lib/url-input/url-input.component.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/libs/feature/editor/src/lib/components/online-service-resource-input/online-service-resource-input.component.css +0 -0
- package/src/libs/feature/editor/src/lib/components/online-service-resource-input/online-service-resource-input.component.html +31 -0
- package/src/libs/feature/editor/src/lib/components/online-service-resource-input/online-service-resource-input.component.ts +82 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.html +20 -11
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.ts +3 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-resources/form-field-online-resources.component.css +0 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-resources/form-field-online-resources.component.html +71 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-resources/form-field-online-resources.component.ts +241 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.html +8 -0
- package/src/libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.ts +5 -3
- package/src/libs/feature/editor/src/lib/fields.config.ts +10 -1
- package/src/libs/ui/inputs/src/lib/file-input/file-input.component.html +8 -8
- package/src/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.html +1 -1
- package/src/libs/ui/inputs/src/lib/switch-toggle/switch-toggle.component.ts +3 -1
- package/src/libs/ui/inputs/src/lib/url-input/url-input.component.html +5 -1
- package/src/libs/ui/inputs/src/lib/url-input/url-input.component.ts +25 -2
- package/translations/de.json +7 -0
- package/translations/en.json +7 -0
- package/translations/es.json +7 -0
- package/translations/fr.json +8 -1
- package/translations/it.json +7 -0
- package/translations/nl.json +7 -0
- package/translations/pt.json +7 -0
- package/translations/sk.json +7 -0
|
@@ -8,17 +8,18 @@ import { TranslateModule } from '@ngx-translate/core';
|
|
|
8
8
|
import { FormFieldDateUpdatedComponent, FormFieldLicenseComponent, FormFieldTemporalExtentsComponent, } from '.';
|
|
9
9
|
import { FormFieldArrayComponent } from './form-field-array/form-field-array.component';
|
|
10
10
|
import { FormFieldContactsForResourceComponent } from './form-field-contacts-for-resource/form-field-contacts-for-resource.component';
|
|
11
|
+
import { FormFieldContactsComponent } from './form-field-contacts/form-field-contacts.component';
|
|
11
12
|
import { FormFieldFileComponent } from './form-field-file/form-field-file.component';
|
|
12
13
|
import { FormFieldKeywordsComponent } from './form-field-keywords/form-field-keywords.component';
|
|
13
14
|
import { FormFieldObjectComponent } from './form-field-object/form-field-object.component';
|
|
15
|
+
import { FormFieldOnlineLinkResourcesComponent } from './form-field-online-link-resources/form-field-online-link-resources.component';
|
|
16
|
+
import { FormFieldOnlineResourcesComponent } from './form-field-online-resources/form-field-online-resources.component';
|
|
17
|
+
import { FormFieldOpenDataComponent } from './form-field-open-data/form-field-open-data.component';
|
|
14
18
|
import { FormFieldOverviewsComponent } from './form-field-overviews/form-field-overviews.component';
|
|
15
19
|
import { FormFieldRichComponent } from './form-field-rich/form-field-rich.component';
|
|
16
20
|
import { FormFieldSimpleComponent } from './form-field-simple/form-field-simple.component';
|
|
17
21
|
import { FormFieldSpatialExtentComponent } from './form-field-spatial-extent/form-field-spatial-extent.component';
|
|
18
22
|
import { FormFieldUpdateFrequencyComponent } from './form-field-update-frequency/form-field-update-frequency.component';
|
|
19
|
-
import { FormFieldOpenDataComponent } from './form-field-open-data/form-field-open-data.component';
|
|
20
|
-
import { FormFieldOnlineLinkResourcesComponent } from './form-field-online-link-resources/form-field-online-link-resources.component';
|
|
21
|
-
import { FormFieldContactsComponent } from './form-field-contacts/form-field-contacts.component';
|
|
22
23
|
import * as i0 from "@angular/core";
|
|
23
24
|
import * as i1 from "@angular/common";
|
|
24
25
|
import * as i2 from "@ngx-translate/core";
|
|
@@ -62,7 +63,7 @@ export class FormFieldComponent {
|
|
|
62
63
|
return this.value;
|
|
63
64
|
}
|
|
64
65
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FormFieldComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
65
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: FormFieldComponent, isStandalone: true, selector: "gn-ui-form-field", inputs: { uniqueIdentifier: "uniqueIdentifier", model: "model", modelSpecifier: "modelSpecifier", config: "config", value: "value" }, outputs: { valueChange: "valueChange" }, viewQueries: [{ propertyName: "titleInput", first: true, predicate: ["titleInput"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"model === 'licenses'\">\n <gn-ui-form-field-open-data\n [value]=\"valueAsConstraints\"\n (valueChange)=\"valueChange.emit($event)\"\n (openDataChange)=\"isHidden = $event\"\n ></gn-ui-form-field-open-data>\n</ng-container>\n<div class=\"flex flex-col h-full\" *ngIf=\"!isHidden\">\n <ng-container *ngIf=\"withoutWrapper; else withGenericWrapper\">\n <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n </ng-container>\n <ng-template #withGenericWrapper>\n <gn-ui-form-field-wrapper\n [label]=\"config.labelKey! | translate\"\n [hint]=\"config.hintKey! | translate\"\n >\n <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n </gn-ui-form-field-wrapper>\n </ng-template>\n</div>\n\n<ng-template #fieldContent>\n <ng-container [ngSwitch]=\"model\">\n <ng-container *ngSwitchCase=\"'title'\">\n <div class=\"flex flex-row flex-start items-center gap-3 mb-[12px]\">\n <span\n #titleInput\n data-test=\"recordTitleInput\"\n class=\"grow font-title text-3xl font-normal\"\n [gnUiEditableLabel]=\"valueAsString\"\n (editableLabelChanged)=\"valueChange.emit($event)\"\n ></span>\n <div class=\"flex flex-row justify-between\">\n <span\n class=\"material-symbols-outlined gn-ui-icon-small m-2 cursor-pointer\"\n (click)=\"focusTitleInput()\"\n >edit</span\n >\n <span\n class=\"material-symbols-outlined gn-ui-icon-small m-2\"\n [matTooltip]=\"config.hintKey! | translate\"\n matTooltipPosition=\"above\"\n >\n help\n </span>\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'abstract'\">\n <gn-ui-form-field-rich\n [label]=\"config.labelKey! | translate\"\n [hint]=\"config.hintKey! | translate\"\n [value]=\"valueAsString\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-rich>\n </ng-container>\n <ng-container *ngSwitchCase=\"'overviews'\">\n <gn-ui-form-field-overviews\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOverviews\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-overviews>\n </ng-container>\n <ng-container *ngSwitchCase=\"'uniqueIdentifier'\">\n <gn-ui-form-field-simple\n type=\"text\"\n [readonly]=\"true\"\n [value]=\"valueAsString\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-simple>\n </ng-container>\n <ng-container *ngSwitchCase=\"'resourceUpdated'\">\n <gn-ui-form-field-date-updated\n [value]=\"valueAsDate\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-date-updated>\n </ng-container>\n <ng-container *ngSwitchCase=\"'recordUpdated'\">\n <gn-ui-form-field-date-updated\n [value]=\"valueAsDate\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-date-updated>\n </ng-container>\n <ng-container *ngSwitchCase=\"'updateFrequency'\">\n <gn-ui-form-field-update-frequency\n [value]=\"valueAsUpdateFrequency\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-update-frequency>\n </ng-container>\n <ng-container *ngSwitchCase=\"'temporalExtents'\">\n <gn-ui-form-field-temporal-extents\n [value]=\"valueAsTemporalExtents\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-temporal-extents>\n </ng-container>\n <ng-container *ngSwitchCase=\"'spatialExtents'\">\n <gn-ui-form-field-spatial-extent></gn-ui-form-field-spatial-extent>\n </ng-container>\n <ng-container *ngSwitchCase=\"'keywords'\">\n <gn-ui-form-field-keywords\n [value]=\"valueAsKeywords\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-keywords>\n </ng-container>\n <ng-container *ngSwitchCase=\"'licenses'\">\n <gn-ui-form-field-license\n [label]=\"config.labelKey! | translate\"\n [value]=\"valueAsConstraints\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-license>\n </ng-container>\n <ng-container *ngSwitchCase=\"'contactsForResource'\">\n <gn-ui-form-field-contacts-for-resource\n [value]=\"valueAsIndividuals\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-contacts-for-resource>\n </ng-container>\n <ng-container *ngSwitchCase=\"'contacts'\">\n <gn-ui-form-field-contacts\n [value]=\"valueAsIndividuals\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-contacts>\n </ng-container>\n <ng-container *ngSwitchCase=\"'onlineResources'\">\n <gn-ui-form-field-online-link-resources\n *ngIf=\"modelSpecifier === 'onlineResourceType:link'\"\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOnlineResources\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-online-link-resources>\n </ng-container>\n </ng-container>\n</ng-template>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "directive", type: EditableLabelDirective, selector: "[gnUiEditableLabel]", inputs: ["gnUiEditableLabel"], outputs: ["editableLabelChanged"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i3.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: FormFieldWrapperComponent, selector: "gn-ui-form-field-wrapper", inputs: ["label", "hint"] }, { kind: "component", type: FormFieldLicenseComponent, selector: "gn-ui-form-field-license", inputs: ["label", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldDateUpdatedComponent, selector: "gn-ui-form-field-date-updated", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldUpdateFrequencyComponent, selector: "gn-ui-form-field-update-frequency", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldTemporalExtentsComponent, selector: "gn-ui-form-field-temporal-extents", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldSimpleComponent, selector: "gn-ui-form-field-simple", inputs: ["type", "readonly", "invalid", "placeholder", "options", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldRichComponent, selector: "gn-ui-form-field-rich", inputs: ["label", "hint", "placeholder", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldSpatialExtentComponent, selector: "gn-ui-form-field-spatial-extent" }, { kind: "component", type: FormFieldKeywordsComponent, selector: "gn-ui-form-field-keywords", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldOverviewsComponent, selector: "gn-ui-form-field-overviews", inputs: ["metadataUuid", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldContactsForResourceComponent, selector: "gn-ui-form-field-contacts-for-resource", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldOpenDataComponent, selector: "gn-ui-form-field-open-data", inputs: ["value"], outputs: ["valueChange", "openDataChange"] }, { kind: "component", type: FormFieldOnlineLinkResourcesComponent, selector: "gn-ui-form-field-online-link-resources", inputs: ["metadataUuid", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldContactsComponent, selector: "gn-ui-form-field-contacts", inputs: ["value"], outputs: ["valueChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
66
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: FormFieldComponent, isStandalone: true, selector: "gn-ui-form-field", inputs: { uniqueIdentifier: "uniqueIdentifier", model: "model", modelSpecifier: "modelSpecifier", config: "config", value: "value" }, outputs: { valueChange: "valueChange" }, viewQueries: [{ propertyName: "titleInput", first: true, predicate: ["titleInput"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"model === 'licenses'\">\n <gn-ui-form-field-open-data\n [value]=\"valueAsConstraints\"\n (valueChange)=\"valueChange.emit($event)\"\n (openDataChange)=\"isHidden = $event\"\n ></gn-ui-form-field-open-data>\n</ng-container>\n<div class=\"flex flex-col h-full\" *ngIf=\"!isHidden\">\n <ng-container *ngIf=\"withoutWrapper; else withGenericWrapper\">\n <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n </ng-container>\n <ng-template #withGenericWrapper>\n <gn-ui-form-field-wrapper\n [label]=\"config.labelKey! | translate\"\n [hint]=\"config.hintKey! | translate\"\n >\n <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n </gn-ui-form-field-wrapper>\n </ng-template>\n</div>\n\n<ng-template #fieldContent>\n <ng-container [ngSwitch]=\"model\">\n <ng-container *ngSwitchCase=\"'title'\">\n <div class=\"flex flex-row flex-start items-center gap-3 mb-[12px]\">\n <span\n #titleInput\n data-test=\"recordTitleInput\"\n class=\"grow font-title text-3xl font-normal\"\n [gnUiEditableLabel]=\"valueAsString\"\n (editableLabelChanged)=\"valueChange.emit($event)\"\n ></span>\n <div class=\"flex flex-row justify-between\">\n <span\n class=\"material-symbols-outlined gn-ui-icon-small m-2 cursor-pointer\"\n (click)=\"focusTitleInput()\"\n >edit</span\n >\n <span\n class=\"material-symbols-outlined gn-ui-icon-small m-2\"\n [matTooltip]=\"config.hintKey! | translate\"\n matTooltipPosition=\"above\"\n >\n help\n </span>\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'abstract'\">\n <gn-ui-form-field-rich\n [label]=\"config.labelKey! | translate\"\n [hint]=\"config.hintKey! | translate\"\n [value]=\"valueAsString\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-rich>\n </ng-container>\n <ng-container *ngSwitchCase=\"'overviews'\">\n <gn-ui-form-field-overviews\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOverviews\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-overviews>\n </ng-container>\n <ng-container *ngSwitchCase=\"'uniqueIdentifier'\">\n <gn-ui-form-field-simple\n type=\"text\"\n [readonly]=\"true\"\n [value]=\"valueAsString\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-simple>\n </ng-container>\n <ng-container *ngSwitchCase=\"'resourceUpdated'\">\n <gn-ui-form-field-date-updated\n [value]=\"valueAsDate\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-date-updated>\n </ng-container>\n <ng-container *ngSwitchCase=\"'recordUpdated'\">\n <gn-ui-form-field-date-updated\n [value]=\"valueAsDate\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-date-updated>\n </ng-container>\n <ng-container *ngSwitchCase=\"'updateFrequency'\">\n <gn-ui-form-field-update-frequency\n [value]=\"valueAsUpdateFrequency\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-update-frequency>\n </ng-container>\n <ng-container *ngSwitchCase=\"'temporalExtents'\">\n <gn-ui-form-field-temporal-extents\n [value]=\"valueAsTemporalExtents\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-temporal-extents>\n </ng-container>\n <ng-container *ngSwitchCase=\"'spatialExtents'\">\n <gn-ui-form-field-spatial-extent></gn-ui-form-field-spatial-extent>\n </ng-container>\n <ng-container *ngSwitchCase=\"'keywords'\">\n <gn-ui-form-field-keywords\n [value]=\"valueAsKeywords\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-keywords>\n </ng-container>\n <ng-container *ngSwitchCase=\"'licenses'\">\n <gn-ui-form-field-license\n [label]=\"config.labelKey! | translate\"\n [value]=\"valueAsConstraints\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-license>\n </ng-container>\n <ng-container *ngSwitchCase=\"'contactsForResource'\">\n <gn-ui-form-field-contacts-for-resource\n [value]=\"valueAsIndividuals\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-contacts-for-resource>\n </ng-container>\n <ng-container *ngSwitchCase=\"'contacts'\">\n <gn-ui-form-field-contacts\n [value]=\"valueAsIndividuals\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-contacts>\n </ng-container>\n <ng-container *ngSwitchCase=\"'onlineResources'\">\n <gn-ui-form-field-online-resources\n *ngIf=\"modelSpecifier === 'onlineResourceType:!link'\"\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOnlineResources\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-online-resources>\n </ng-container>\n <ng-container *ngSwitchCase=\"'onlineResources'\">\n <gn-ui-form-field-online-link-resources\n *ngIf=\"modelSpecifier === 'onlineResourceType:link'\"\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOnlineResources\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-online-link-resources>\n </ng-container>\n </ng-container>\n</ng-template>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "directive", type: EditableLabelDirective, selector: "[gnUiEditableLabel]", inputs: ["gnUiEditableLabel"], outputs: ["editableLabelChanged"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i3.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: FormFieldWrapperComponent, selector: "gn-ui-form-field-wrapper", inputs: ["label", "hint"] }, { kind: "component", type: FormFieldLicenseComponent, selector: "gn-ui-form-field-license", inputs: ["label", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldDateUpdatedComponent, selector: "gn-ui-form-field-date-updated", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldUpdateFrequencyComponent, selector: "gn-ui-form-field-update-frequency", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldTemporalExtentsComponent, selector: "gn-ui-form-field-temporal-extents", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldSimpleComponent, selector: "gn-ui-form-field-simple", inputs: ["type", "readonly", "invalid", "placeholder", "options", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldRichComponent, selector: "gn-ui-form-field-rich", inputs: ["label", "hint", "placeholder", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldSpatialExtentComponent, selector: "gn-ui-form-field-spatial-extent" }, { kind: "component", type: FormFieldKeywordsComponent, selector: "gn-ui-form-field-keywords", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldOverviewsComponent, selector: "gn-ui-form-field-overviews", inputs: ["metadataUuid", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldContactsForResourceComponent, selector: "gn-ui-form-field-contacts-for-resource", inputs: ["value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldOpenDataComponent, selector: "gn-ui-form-field-open-data", inputs: ["value"], outputs: ["valueChange", "openDataChange"] }, { kind: "component", type: FormFieldOnlineResourcesComponent, selector: "gn-ui-form-field-online-resources", inputs: ["metadataUuid", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldOnlineLinkResourcesComponent, selector: "gn-ui-form-field-online-link-resources", inputs: ["metadataUuid", "value"], outputs: ["valueChange"] }, { kind: "component", type: FormFieldContactsComponent, selector: "gn-ui-form-field-contacts", inputs: ["value"], outputs: ["valueChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
66
67
|
}
|
|
67
68
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FormFieldComponent, decorators: [{
|
|
68
69
|
type: Component,
|
|
@@ -87,9 +88,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
87
88
|
FormFieldOverviewsComponent,
|
|
88
89
|
FormFieldContactsForResourceComponent,
|
|
89
90
|
FormFieldOpenDataComponent,
|
|
91
|
+
FormFieldOnlineResourcesComponent,
|
|
90
92
|
FormFieldOnlineLinkResourcesComponent,
|
|
91
93
|
FormFieldContactsComponent,
|
|
92
|
-
], template: "<ng-container *ngIf=\"model === 'licenses'\">\n <gn-ui-form-field-open-data\n [value]=\"valueAsConstraints\"\n (valueChange)=\"valueChange.emit($event)\"\n (openDataChange)=\"isHidden = $event\"\n ></gn-ui-form-field-open-data>\n</ng-container>\n<div class=\"flex flex-col h-full\" *ngIf=\"!isHidden\">\n <ng-container *ngIf=\"withoutWrapper; else withGenericWrapper\">\n <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n </ng-container>\n <ng-template #withGenericWrapper>\n <gn-ui-form-field-wrapper\n [label]=\"config.labelKey! | translate\"\n [hint]=\"config.hintKey! | translate\"\n >\n <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n </gn-ui-form-field-wrapper>\n </ng-template>\n</div>\n\n<ng-template #fieldContent>\n <ng-container [ngSwitch]=\"model\">\n <ng-container *ngSwitchCase=\"'title'\">\n <div class=\"flex flex-row flex-start items-center gap-3 mb-[12px]\">\n <span\n #titleInput\n data-test=\"recordTitleInput\"\n class=\"grow font-title text-3xl font-normal\"\n [gnUiEditableLabel]=\"valueAsString\"\n (editableLabelChanged)=\"valueChange.emit($event)\"\n ></span>\n <div class=\"flex flex-row justify-between\">\n <span\n class=\"material-symbols-outlined gn-ui-icon-small m-2 cursor-pointer\"\n (click)=\"focusTitleInput()\"\n >edit</span\n >\n <span\n class=\"material-symbols-outlined gn-ui-icon-small m-2\"\n [matTooltip]=\"config.hintKey! | translate\"\n matTooltipPosition=\"above\"\n >\n help\n </span>\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'abstract'\">\n <gn-ui-form-field-rich\n [label]=\"config.labelKey! | translate\"\n [hint]=\"config.hintKey! | translate\"\n [value]=\"valueAsString\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-rich>\n </ng-container>\n <ng-container *ngSwitchCase=\"'overviews'\">\n <gn-ui-form-field-overviews\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOverviews\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-overviews>\n </ng-container>\n <ng-container *ngSwitchCase=\"'uniqueIdentifier'\">\n <gn-ui-form-field-simple\n type=\"text\"\n [readonly]=\"true\"\n [value]=\"valueAsString\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-simple>\n </ng-container>\n <ng-container *ngSwitchCase=\"'resourceUpdated'\">\n <gn-ui-form-field-date-updated\n [value]=\"valueAsDate\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-date-updated>\n </ng-container>\n <ng-container *ngSwitchCase=\"'recordUpdated'\">\n <gn-ui-form-field-date-updated\n [value]=\"valueAsDate\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-date-updated>\n </ng-container>\n <ng-container *ngSwitchCase=\"'updateFrequency'\">\n <gn-ui-form-field-update-frequency\n [value]=\"valueAsUpdateFrequency\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-update-frequency>\n </ng-container>\n <ng-container *ngSwitchCase=\"'temporalExtents'\">\n <gn-ui-form-field-temporal-extents\n [value]=\"valueAsTemporalExtents\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-temporal-extents>\n </ng-container>\n <ng-container *ngSwitchCase=\"'spatialExtents'\">\n <gn-ui-form-field-spatial-extent></gn-ui-form-field-spatial-extent>\n </ng-container>\n <ng-container *ngSwitchCase=\"'keywords'\">\n <gn-ui-form-field-keywords\n [value]=\"valueAsKeywords\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-keywords>\n </ng-container>\n <ng-container *ngSwitchCase=\"'licenses'\">\n <gn-ui-form-field-license\n [label]=\"config.labelKey! | translate\"\n [value]=\"valueAsConstraints\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-license>\n </ng-container>\n <ng-container *ngSwitchCase=\"'contactsForResource'\">\n <gn-ui-form-field-contacts-for-resource\n [value]=\"valueAsIndividuals\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-contacts-for-resource>\n </ng-container>\n <ng-container *ngSwitchCase=\"'contacts'\">\n <gn-ui-form-field-contacts\n [value]=\"valueAsIndividuals\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-contacts>\n </ng-container>\n <ng-container *ngSwitchCase=\"'onlineResources'\">\n <gn-ui-form-field-online-link-resources\n *ngIf=\"modelSpecifier === 'onlineResourceType:link'\"\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOnlineResources\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-online-link-resources>\n </ng-container>\n </ng-container>\n</ng-template>\n" }]
|
|
94
|
+
], template: "<ng-container *ngIf=\"model === 'licenses'\">\n <gn-ui-form-field-open-data\n [value]=\"valueAsConstraints\"\n (valueChange)=\"valueChange.emit($event)\"\n (openDataChange)=\"isHidden = $event\"\n ></gn-ui-form-field-open-data>\n</ng-container>\n<div class=\"flex flex-col h-full\" *ngIf=\"!isHidden\">\n <ng-container *ngIf=\"withoutWrapper; else withGenericWrapper\">\n <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n </ng-container>\n <ng-template #withGenericWrapper>\n <gn-ui-form-field-wrapper\n [label]=\"config.labelKey! | translate\"\n [hint]=\"config.hintKey! | translate\"\n >\n <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n </gn-ui-form-field-wrapper>\n </ng-template>\n</div>\n\n<ng-template #fieldContent>\n <ng-container [ngSwitch]=\"model\">\n <ng-container *ngSwitchCase=\"'title'\">\n <div class=\"flex flex-row flex-start items-center gap-3 mb-[12px]\">\n <span\n #titleInput\n data-test=\"recordTitleInput\"\n class=\"grow font-title text-3xl font-normal\"\n [gnUiEditableLabel]=\"valueAsString\"\n (editableLabelChanged)=\"valueChange.emit($event)\"\n ></span>\n <div class=\"flex flex-row justify-between\">\n <span\n class=\"material-symbols-outlined gn-ui-icon-small m-2 cursor-pointer\"\n (click)=\"focusTitleInput()\"\n >edit</span\n >\n <span\n class=\"material-symbols-outlined gn-ui-icon-small m-2\"\n [matTooltip]=\"config.hintKey! | translate\"\n matTooltipPosition=\"above\"\n >\n help\n </span>\n </div>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'abstract'\">\n <gn-ui-form-field-rich\n [label]=\"config.labelKey! | translate\"\n [hint]=\"config.hintKey! | translate\"\n [value]=\"valueAsString\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-rich>\n </ng-container>\n <ng-container *ngSwitchCase=\"'overviews'\">\n <gn-ui-form-field-overviews\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOverviews\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-overviews>\n </ng-container>\n <ng-container *ngSwitchCase=\"'uniqueIdentifier'\">\n <gn-ui-form-field-simple\n type=\"text\"\n [readonly]=\"true\"\n [value]=\"valueAsString\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-simple>\n </ng-container>\n <ng-container *ngSwitchCase=\"'resourceUpdated'\">\n <gn-ui-form-field-date-updated\n [value]=\"valueAsDate\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-date-updated>\n </ng-container>\n <ng-container *ngSwitchCase=\"'recordUpdated'\">\n <gn-ui-form-field-date-updated\n [value]=\"valueAsDate\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-date-updated>\n </ng-container>\n <ng-container *ngSwitchCase=\"'updateFrequency'\">\n <gn-ui-form-field-update-frequency\n [value]=\"valueAsUpdateFrequency\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-update-frequency>\n </ng-container>\n <ng-container *ngSwitchCase=\"'temporalExtents'\">\n <gn-ui-form-field-temporal-extents\n [value]=\"valueAsTemporalExtents\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-temporal-extents>\n </ng-container>\n <ng-container *ngSwitchCase=\"'spatialExtents'\">\n <gn-ui-form-field-spatial-extent></gn-ui-form-field-spatial-extent>\n </ng-container>\n <ng-container *ngSwitchCase=\"'keywords'\">\n <gn-ui-form-field-keywords\n [value]=\"valueAsKeywords\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-keywords>\n </ng-container>\n <ng-container *ngSwitchCase=\"'licenses'\">\n <gn-ui-form-field-license\n [label]=\"config.labelKey! | translate\"\n [value]=\"valueAsConstraints\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-license>\n </ng-container>\n <ng-container *ngSwitchCase=\"'contactsForResource'\">\n <gn-ui-form-field-contacts-for-resource\n [value]=\"valueAsIndividuals\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-contacts-for-resource>\n </ng-container>\n <ng-container *ngSwitchCase=\"'contacts'\">\n <gn-ui-form-field-contacts\n [value]=\"valueAsIndividuals\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-contacts>\n </ng-container>\n <ng-container *ngSwitchCase=\"'onlineResources'\">\n <gn-ui-form-field-online-resources\n *ngIf=\"modelSpecifier === 'onlineResourceType:!link'\"\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOnlineResources\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-online-resources>\n </ng-container>\n <ng-container *ngSwitchCase=\"'onlineResources'\">\n <gn-ui-form-field-online-link-resources\n *ngIf=\"modelSpecifier === 'onlineResourceType:link'\"\n [metadataUuid]=\"uniqueIdentifier\"\n [value]=\"valueAsOnlineResources\"\n (valueChange)=\"valueChange.emit($event)\"\n ></gn-ui-form-field-online-link-resources>\n </ng-container>\n </ng-container>\n</ng-template>\n" }]
|
|
93
95
|
}], propDecorators: { uniqueIdentifier: [{
|
|
94
96
|
type: Input
|
|
95
97
|
}], model: [{
|
|
@@ -106,4 +108,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
106
108
|
type: ViewChild,
|
|
107
109
|
args: ['titleInput']
|
|
108
110
|
}] } });
|
|
109
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-field.component.js","sourceRoot":"","sources":["../../../../../../../../../../libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.ts","../../../../../../../../../../libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common'\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  ViewChild,\n} from '@angular/core'\nimport { MatIconModule } from '@angular/material/icon'\nimport { MatTooltipModule } from '@angular/material/tooltip'\nimport {\n  CatalogRecordKeys,\n  Constraint,\n  DatasetTemporalExtent,\n  GraphicOverview,\n  Individual,\n  Keyword,\n  OnlineResource,\n  UpdateFrequency,\n} from '../../../../../../../../libs/common/domain/src/lib/model/record'\nimport { EditableLabelDirective } from '../../../../../../../../libs/ui/inputs/src'\nimport { FormFieldWrapperComponent } from '../../../../../../../../libs/ui/layout/src'\nimport { TranslateModule } from '@ngx-translate/core'\nimport {\n  FormFieldDateUpdatedComponent,\n  FormFieldLicenseComponent,\n  FormFieldTemporalExtentsComponent,\n} from '.'\nimport { FieldModelSpecifier, FormFieldConfig } from '../../../models'\nimport { FormFieldArrayComponent } from './form-field-array/form-field-array.component'\nimport { FormFieldContactsForResourceComponent } from './form-field-contacts-for-resource/form-field-contacts-for-resource.component'\nimport { FormFieldFileComponent } from './form-field-file/form-field-file.component'\nimport { FormFieldKeywordsComponent } from './form-field-keywords/form-field-keywords.component'\nimport { FormFieldObjectComponent } from './form-field-object/form-field-object.component'\nimport { FormFieldOverviewsComponent } from './form-field-overviews/form-field-overviews.component'\nimport { FormFieldRichComponent } from './form-field-rich/form-field-rich.component'\nimport { FormFieldSimpleComponent } from './form-field-simple/form-field-simple.component'\nimport { FormFieldSpatialExtentComponent } from './form-field-spatial-extent/form-field-spatial-extent.component'\nimport { FormFieldUpdateFrequencyComponent } from './form-field-update-frequency/form-field-update-frequency.component'\nimport { FormFieldOpenDataComponent } from './form-field-open-data/form-field-open-data.component'\nimport { FormFieldOnlineLinkResourcesComponent } from './form-field-online-link-resources/form-field-online-link-resources.component'\nimport { FormFieldContactsComponent } from './form-field-contacts/form-field-contacts.component'\n\n@Component({\n  selector: 'gn-ui-form-field',\n  templateUrl: './form-field.component.html',\n  styleUrls: ['./form-field.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    TranslateModule,\n    EditableLabelDirective,\n    MatIconModule,\n    MatTooltipModule,\n    FormFieldWrapperComponent,\n    FormFieldLicenseComponent,\n    FormFieldDateUpdatedComponent,\n    FormFieldUpdateFrequencyComponent,\n    FormFieldTemporalExtentsComponent,\n    FormFieldSimpleComponent,\n    FormFieldRichComponent,\n    FormFieldObjectComponent,\n    FormFieldSpatialExtentComponent,\n    FormFieldFileComponent,\n    FormFieldArrayComponent,\n    FormFieldKeywordsComponent,\n    FormFieldOverviewsComponent,\n    FormFieldContactsForResourceComponent,\n    FormFieldOpenDataComponent,\n    FormFieldOnlineLinkResourcesComponent,\n    FormFieldContactsComponent,\n  ],\n})\nexport class FormFieldComponent {\n  @Input() uniqueIdentifier: string\n  @Input() model: CatalogRecordKeys\n  @Input() modelSpecifier: FieldModelSpecifier\n  @Input() config: FormFieldConfig\n  @Input() value: unknown\n\n  @Output() valueChange: EventEmitter<unknown> = new EventEmitter()\n\n  @ViewChild('titleInput') titleInput: ElementRef\n\n  isHidden = false\n\n  focusTitleInput() {\n    this.titleInput.nativeElement.children[0].focus()\n  }\n\n  get withoutWrapper() {\n    return this.model === 'title' || this.model === 'abstract'\n  }\n\n  get valueAsString() {\n    return this.value as string\n  }\n  get valueAsDate() {\n    return this.value as Date\n  }\n\n  get valueAsOverviews() {\n    return this.value as Array<GraphicOverview>\n  }\n  get valueAsUpdateFrequency() {\n    return this.value as UpdateFrequency\n  }\n  get valueAsTemporalExtents() {\n    return this.value as Array<DatasetTemporalExtent>\n  }\n  get valueAsKeywords() {\n    return this.value as Array<Keyword>\n  }\n  get valueAsConstraints() {\n    return this.value as Array<Constraint>\n  }\n  get valueAsIndividuals() {\n    return this.value as Array<Individual>\n  }\n  get valueAsOnlineResources() {\n    return this.value as Array<OnlineResource>\n  }\n}\n","<ng-container *ngIf=\"model === 'licenses'\">\n  <gn-ui-form-field-open-data\n    [value]=\"valueAsConstraints\"\n    (valueChange)=\"valueChange.emit($event)\"\n    (openDataChange)=\"isHidden = $event\"\n  ></gn-ui-form-field-open-data>\n</ng-container>\n<div class=\"flex flex-col h-full\" *ngIf=\"!isHidden\">\n  <ng-container *ngIf=\"withoutWrapper; else withGenericWrapper\">\n    <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n  </ng-container>\n  <ng-template #withGenericWrapper>\n    <gn-ui-form-field-wrapper\n      [label]=\"config.labelKey! | translate\"\n      [hint]=\"config.hintKey! | translate\"\n    >\n      <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n    </gn-ui-form-field-wrapper>\n  </ng-template>\n</div>\n\n<ng-template #fieldContent>\n  <ng-container [ngSwitch]=\"model\">\n    <ng-container *ngSwitchCase=\"'title'\">\n      <div class=\"flex flex-row flex-start items-center gap-3 mb-[12px]\">\n        <span\n          #titleInput\n          data-test=\"recordTitleInput\"\n          class=\"grow font-title text-3xl font-normal\"\n          [gnUiEditableLabel]=\"valueAsString\"\n          (editableLabelChanged)=\"valueChange.emit($event)\"\n        ></span>\n        <div class=\"flex flex-row justify-between\">\n          <span\n            class=\"material-symbols-outlined gn-ui-icon-small m-2 cursor-pointer\"\n            (click)=\"focusTitleInput()\"\n            >edit</span\n          >\n          <span\n            class=\"material-symbols-outlined gn-ui-icon-small m-2\"\n            [matTooltip]=\"config.hintKey! | translate\"\n            matTooltipPosition=\"above\"\n          >\n            help\n          </span>\n        </div>\n      </div>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'abstract'\">\n      <gn-ui-form-field-rich\n        [label]=\"config.labelKey! | translate\"\n        [hint]=\"config.hintKey! | translate\"\n        [value]=\"valueAsString\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-rich>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'overviews'\">\n      <gn-ui-form-field-overviews\n        [metadataUuid]=\"uniqueIdentifier\"\n        [value]=\"valueAsOverviews\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-overviews>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'uniqueIdentifier'\">\n      <gn-ui-form-field-simple\n        type=\"text\"\n        [readonly]=\"true\"\n        [value]=\"valueAsString\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-simple>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'resourceUpdated'\">\n      <gn-ui-form-field-date-updated\n        [value]=\"valueAsDate\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-date-updated>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'recordUpdated'\">\n      <gn-ui-form-field-date-updated\n        [value]=\"valueAsDate\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-date-updated>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'updateFrequency'\">\n      <gn-ui-form-field-update-frequency\n        [value]=\"valueAsUpdateFrequency\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-update-frequency>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'temporalExtents'\">\n      <gn-ui-form-field-temporal-extents\n        [value]=\"valueAsTemporalExtents\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-temporal-extents>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'spatialExtents'\">\n      <gn-ui-form-field-spatial-extent></gn-ui-form-field-spatial-extent>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'keywords'\">\n      <gn-ui-form-field-keywords\n        [value]=\"valueAsKeywords\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-keywords>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'licenses'\">\n      <gn-ui-form-field-license\n        [label]=\"config.labelKey! | translate\"\n        [value]=\"valueAsConstraints\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-license>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'contactsForResource'\">\n      <gn-ui-form-field-contacts-for-resource\n        [value]=\"valueAsIndividuals\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-contacts-for-resource>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'contacts'\">\n      <gn-ui-form-field-contacts\n        [value]=\"valueAsIndividuals\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-contacts>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'onlineResources'\">\n      <gn-ui-form-field-online-link-resources\n        *ngIf=\"modelSpecifier === 'onlineResourceType:link'\"\n        [metadataUuid]=\"uniqueIdentifier\"\n        [value]=\"valueAsOnlineResources\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-online-link-resources>\n    </ng-container>\n  </ng-container>\n</ng-template>\n"]}
|
|
111
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-field.component.js","sourceRoot":"","sources":["../../../../../../../../../../libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.ts","../../../../../../../../../../libs/feature/editor/src/lib/components/record-form/form-field/form-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common'\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  ViewChild,\n} from '@angular/core'\nimport { MatIconModule } from '@angular/material/icon'\nimport { MatTooltipModule } from '@angular/material/tooltip'\nimport {\n  CatalogRecordKeys,\n  Constraint,\n  DatasetTemporalExtent,\n  GraphicOverview,\n  Individual,\n  Keyword,\n  OnlineResource,\n  UpdateFrequency,\n} from '../../../../../../../../libs/common/domain/src/lib/model/record'\nimport { EditableLabelDirective } from '../../../../../../../../libs/ui/inputs/src'\nimport { FormFieldWrapperComponent } from '../../../../../../../../libs/ui/layout/src'\nimport { TranslateModule } from '@ngx-translate/core'\nimport {\n  FormFieldDateUpdatedComponent,\n  FormFieldLicenseComponent,\n  FormFieldTemporalExtentsComponent,\n} from '.'\nimport { FieldModelSpecifier, FormFieldConfig } from '../../../models'\nimport { FormFieldArrayComponent } from './form-field-array/form-field-array.component'\nimport { FormFieldContactsForResourceComponent } from './form-field-contacts-for-resource/form-field-contacts-for-resource.component'\nimport { FormFieldContactsComponent } from './form-field-contacts/form-field-contacts.component'\nimport { FormFieldFileComponent } from './form-field-file/form-field-file.component'\nimport { FormFieldKeywordsComponent } from './form-field-keywords/form-field-keywords.component'\nimport { FormFieldObjectComponent } from './form-field-object/form-field-object.component'\nimport { FormFieldOnlineLinkResourcesComponent } from './form-field-online-link-resources/form-field-online-link-resources.component'\nimport { FormFieldOnlineResourcesComponent } from './form-field-online-resources/form-field-online-resources.component'\nimport { FormFieldOpenDataComponent } from './form-field-open-data/form-field-open-data.component'\nimport { FormFieldOverviewsComponent } from './form-field-overviews/form-field-overviews.component'\nimport { FormFieldRichComponent } from './form-field-rich/form-field-rich.component'\nimport { FormFieldSimpleComponent } from './form-field-simple/form-field-simple.component'\nimport { FormFieldSpatialExtentComponent } from './form-field-spatial-extent/form-field-spatial-extent.component'\nimport { FormFieldUpdateFrequencyComponent } from './form-field-update-frequency/form-field-update-frequency.component'\n\n@Component({\n  selector: 'gn-ui-form-field',\n  templateUrl: './form-field.component.html',\n  styleUrls: ['./form-field.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    TranslateModule,\n    EditableLabelDirective,\n    MatIconModule,\n    MatTooltipModule,\n    FormFieldWrapperComponent,\n    FormFieldLicenseComponent,\n    FormFieldDateUpdatedComponent,\n    FormFieldUpdateFrequencyComponent,\n    FormFieldTemporalExtentsComponent,\n    FormFieldSimpleComponent,\n    FormFieldRichComponent,\n    FormFieldObjectComponent,\n    FormFieldSpatialExtentComponent,\n    FormFieldFileComponent,\n    FormFieldArrayComponent,\n    FormFieldKeywordsComponent,\n    FormFieldOverviewsComponent,\n    FormFieldContactsForResourceComponent,\n    FormFieldOpenDataComponent,\n    FormFieldOnlineResourcesComponent,\n    FormFieldOnlineLinkResourcesComponent,\n    FormFieldContactsComponent,\n  ],\n})\nexport class FormFieldComponent {\n  @Input() uniqueIdentifier: string\n  @Input() model: CatalogRecordKeys\n  @Input() modelSpecifier: FieldModelSpecifier\n  @Input() config: FormFieldConfig\n  @Input() value: unknown\n\n  @Output() valueChange: EventEmitter<unknown> = new EventEmitter()\n\n  @ViewChild('titleInput') titleInput: ElementRef\n\n  isHidden = false\n\n  focusTitleInput() {\n    this.titleInput.nativeElement.children[0].focus()\n  }\n\n  get withoutWrapper() {\n    return this.model === 'title' || this.model === 'abstract'\n  }\n\n  get valueAsString() {\n    return this.value as string\n  }\n  get valueAsDate() {\n    return this.value as Date\n  }\n\n  get valueAsOverviews() {\n    return this.value as Array<GraphicOverview>\n  }\n  get valueAsUpdateFrequency() {\n    return this.value as UpdateFrequency\n  }\n  get valueAsTemporalExtents() {\n    return this.value as Array<DatasetTemporalExtent>\n  }\n  get valueAsKeywords() {\n    return this.value as Array<Keyword>\n  }\n  get valueAsConstraints() {\n    return this.value as Array<Constraint>\n  }\n  get valueAsIndividuals() {\n    return this.value as Array<Individual>\n  }\n  get valueAsOnlineResources() {\n    return this.value as Array<OnlineResource>\n  }\n}\n","<ng-container *ngIf=\"model === 'licenses'\">\n  <gn-ui-form-field-open-data\n    [value]=\"valueAsConstraints\"\n    (valueChange)=\"valueChange.emit($event)\"\n    (openDataChange)=\"isHidden = $event\"\n  ></gn-ui-form-field-open-data>\n</ng-container>\n<div class=\"flex flex-col h-full\" *ngIf=\"!isHidden\">\n  <ng-container *ngIf=\"withoutWrapper; else withGenericWrapper\">\n    <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n  </ng-container>\n  <ng-template #withGenericWrapper>\n    <gn-ui-form-field-wrapper\n      [label]=\"config.labelKey! | translate\"\n      [hint]=\"config.hintKey! | translate\"\n    >\n      <ng-container *ngTemplateOutlet=\"fieldContent\"></ng-container>\n    </gn-ui-form-field-wrapper>\n  </ng-template>\n</div>\n\n<ng-template #fieldContent>\n  <ng-container [ngSwitch]=\"model\">\n    <ng-container *ngSwitchCase=\"'title'\">\n      <div class=\"flex flex-row flex-start items-center gap-3 mb-[12px]\">\n        <span\n          #titleInput\n          data-test=\"recordTitleInput\"\n          class=\"grow font-title text-3xl font-normal\"\n          [gnUiEditableLabel]=\"valueAsString\"\n          (editableLabelChanged)=\"valueChange.emit($event)\"\n        ></span>\n        <div class=\"flex flex-row justify-between\">\n          <span\n            class=\"material-symbols-outlined gn-ui-icon-small m-2 cursor-pointer\"\n            (click)=\"focusTitleInput()\"\n            >edit</span\n          >\n          <span\n            class=\"material-symbols-outlined gn-ui-icon-small m-2\"\n            [matTooltip]=\"config.hintKey! | translate\"\n            matTooltipPosition=\"above\"\n          >\n            help\n          </span>\n        </div>\n      </div>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'abstract'\">\n      <gn-ui-form-field-rich\n        [label]=\"config.labelKey! | translate\"\n        [hint]=\"config.hintKey! | translate\"\n        [value]=\"valueAsString\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-rich>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'overviews'\">\n      <gn-ui-form-field-overviews\n        [metadataUuid]=\"uniqueIdentifier\"\n        [value]=\"valueAsOverviews\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-overviews>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'uniqueIdentifier'\">\n      <gn-ui-form-field-simple\n        type=\"text\"\n        [readonly]=\"true\"\n        [value]=\"valueAsString\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-simple>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'resourceUpdated'\">\n      <gn-ui-form-field-date-updated\n        [value]=\"valueAsDate\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-date-updated>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'recordUpdated'\">\n      <gn-ui-form-field-date-updated\n        [value]=\"valueAsDate\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-date-updated>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'updateFrequency'\">\n      <gn-ui-form-field-update-frequency\n        [value]=\"valueAsUpdateFrequency\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-update-frequency>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'temporalExtents'\">\n      <gn-ui-form-field-temporal-extents\n        [value]=\"valueAsTemporalExtents\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-temporal-extents>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'spatialExtents'\">\n      <gn-ui-form-field-spatial-extent></gn-ui-form-field-spatial-extent>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'keywords'\">\n      <gn-ui-form-field-keywords\n        [value]=\"valueAsKeywords\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-keywords>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'licenses'\">\n      <gn-ui-form-field-license\n        [label]=\"config.labelKey! | translate\"\n        [value]=\"valueAsConstraints\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-license>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'contactsForResource'\">\n      <gn-ui-form-field-contacts-for-resource\n        [value]=\"valueAsIndividuals\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-contacts-for-resource>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'contacts'\">\n      <gn-ui-form-field-contacts\n        [value]=\"valueAsIndividuals\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-contacts>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'onlineResources'\">\n      <gn-ui-form-field-online-resources\n        *ngIf=\"modelSpecifier === 'onlineResourceType:!link'\"\n        [metadataUuid]=\"uniqueIdentifier\"\n        [value]=\"valueAsOnlineResources\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-online-resources>\n    </ng-container>\n    <ng-container *ngSwitchCase=\"'onlineResources'\">\n      <gn-ui-form-field-online-link-resources\n        *ngIf=\"modelSpecifier === 'onlineResourceType:link'\"\n        [metadataUuid]=\"uniqueIdentifier\"\n        [value]=\"valueAsOnlineResources\"\n        (valueChange)=\"valueChange.emit($event)\"\n      ></gn-ui-form-field-online-link-resources>\n    </ng-container>\n  </ng-container>\n</ng-template>\n"]}
|
|
@@ -92,6 +92,13 @@ export const RECORD_SPATIAL_EXTENTS_FIELD = {
|
|
|
92
92
|
labelKey: marker('editor.record.form.field.spatialExtents'),
|
|
93
93
|
},
|
|
94
94
|
};
|
|
95
|
+
export const RECORD_ONLINE_RESOURCES = {
|
|
96
|
+
model: 'onlineResources',
|
|
97
|
+
modelSpecifier: 'onlineResourceType:!link',
|
|
98
|
+
formFieldConfig: {
|
|
99
|
+
labelKey: marker('editor.record.form.field.onlineResources'),
|
|
100
|
+
},
|
|
101
|
+
};
|
|
95
102
|
export const RECORD_ONLINE_LINK_RESOURCES = {
|
|
96
103
|
model: 'onlineResources',
|
|
97
104
|
modelSpecifier: 'onlineResourceType:link',
|
|
@@ -132,10 +139,11 @@ export const ASSOCIATED_RESOURCES_SECTION = {
|
|
|
132
139
|
labelKey: marker('editor.record.form.section.associatedResources.label'),
|
|
133
140
|
descriptionKey: marker('editor.record.form.section.associatedResources.description'),
|
|
134
141
|
hidden: false,
|
|
135
|
-
fields: [],
|
|
142
|
+
fields: [RECORD_ONLINE_RESOURCES],
|
|
136
143
|
};
|
|
137
144
|
export const ANNEXES_SECTION = {
|
|
138
145
|
labelKey: marker('editor.record.form.section.annexes.label'),
|
|
146
|
+
descriptionKey: marker('editor.record.form.section.annexes.description'),
|
|
139
147
|
hidden: false,
|
|
140
148
|
fields: [RECORD_ONLINE_LINK_RESOURCES],
|
|
141
149
|
};
|
|
@@ -217,4 +225,4 @@ export const SPATIAL_SCOPES = [
|
|
|
217
225
|
type: 'theme',
|
|
218
226
|
},
|
|
219
227
|
];
|
|
220
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fields.config.js","sourceRoot":"","sources":["../../../../../../../libs/feature/editor/src/lib/fields.config.ts"],"names":[],"mappings":"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","sourcesContent":["import { marker } from '@biesbjerg/ngx-translate-extract-marker'\nimport {\n  EditorConfig,\n  EditorField,\n  EditorSection,\n} from './models/editor-config.model'\nimport { Keyword } from '../../../../../libs/common/domain/src/lib/model/record'\n\n/**\n * This file contains the configuration of the fields that will be displayed in the editor.\n * To add a new field, you need to create a new EditorField object in the fields part of this file.\n * Then add it to the corresponding section in the sections part of this file.\n * Finally, add the section to the corresponding page in the pages part of this file.\n */\n\n/************************************************************\n ***************           FIELDS           *****************\n ************************************************************\n */\n\nexport const RECORD_LICENSE_FIELD: EditorField = {\n  model: 'licenses',\n  formFieldConfig: {\n    labelKey: marker('editor.record.form.field.license'),\n  },\n}\n\nexport const RECORD_KEYWORDS_FIELD: EditorField = {\n  model: 'keywords',\n  formFieldConfig: {\n    labelKey: marker('editor.record.form.field.keywords'),\n  },\n}\n\nexport const RECORD_UNIQUE_IDENTIFIER_FIELD: EditorField = {\n  model: 'uniqueIdentifier',\n  formFieldConfig: {\n    labelKey: marker('editor.record.form.field.uniqueIdentifier'),\n    locked: true,\n  },\n}\n\nexport const RECORD_RESOURCE_UPDATED_FIELD: EditorField = {\n  model: 'resourceUpdated',\n  formFieldConfig: {\n    labelKey: marker('editor.record.form.field.resourceUpdated'),\n  },\n  gridColumnSpan: 1,\n}\n\nexport const RECORD_UPDATED_FIELD: EditorField = {\n  model: 'recordUpdated',\n  formFieldConfig: {\n    labelKey: marker('editor.record.form.field.recordUpdated'),\n    locked: true,\n  },\n  onSaveProcess: '${dateNow()}',\n  gridColumnSpan: 1,\n}\n\nexport const RECORD_UPDATE_FREQUENCY_FIELD: EditorField = {\n  model: 'updateFrequency',\n  formFieldConfig: {},\n}\n// keeping track of the label to not lose existing translation\nmarker('editor.record.form.field.updateFrequency')\n\nexport const RECORD_TEMPORAL_EXTENTS_FIELD: EditorField = {\n  model: 'temporalExtents',\n  formFieldConfig: {\n    labelKey: marker('editor.record.form.field.temporalExtents'),\n  },\n}\n\nexport const RECORD_TITLE_FIELD: EditorField = {\n  model: 'title',\n  formFieldConfig: {\n    labelKey: marker('editor.record.form.field.title'),\n  },\n}\n\nexport const RECORD_ABSTRACT_FIELD: EditorField = {\n  model: 'abstract',\n  formFieldConfig: {\n    labelKey: marker('editor.record.form.field.abstract'),\n  },\n}\n\nexport const CONTACTS_FOR_RESOURCE_FIELD: EditorField = {\n  model: 'contactsForResource',\n  formFieldConfig: {\n    labelKey: '',\n  },\n}\n\nexport const CONTACTS: EditorField = {\n  model: 'contacts',\n  formFieldConfig: {\n    labelKey: '',\n  },\n}\n\nexport const RECORD_GRAPHICAL_OVERVIEW_FIELD: EditorField = {\n  model: 'overviews',\n  formFieldConfig: {\n    labelKey: marker('editor.record.form.field.overviews'),\n  },\n}\n\nexport const RECORD_SPATIAL_EXTENTS_FIELD: EditorField = {\n  model: 'spatialExtents',\n  formFieldConfig: {\n    labelKey: marker('editor.record.form.field.spatialExtents'),\n  },\n}\n\nexport const RECORD_ONLINE_LINK_RESOURCES: EditorField = {\n  model: 'onlineResources',\n  modelSpecifier: 'onlineResourceType:link',\n  formFieldConfig: {\n    labelKey: marker('editor.record.form.field.onlineLinkResources'),\n  },\n}\n\n/************************************************************\n ***************          SECTIONS          *****************\n ************************************************************\n */\n\nexport const TITLE_SECTION: EditorSection = {\n  hidden: false,\n  fields: [\n    RECORD_TITLE_FIELD,\n    RECORD_ABSTRACT_FIELD,\n    RECORD_GRAPHICAL_OVERVIEW_FIELD,\n  ],\n}\n\nexport const ABOUT_SECTION: EditorSection = {\n  labelKey: marker('editor.record.form.section.about.label'),\n  descriptionKey: marker('editor.record.form.section.about.description'),\n  hidden: false,\n  fields: [\n    RECORD_UNIQUE_IDENTIFIER_FIELD,\n    RECORD_RESOURCE_UPDATED_FIELD,\n    RECORD_UPDATED_FIELD,\n    RECORD_UPDATE_FREQUENCY_FIELD,\n    RECORD_TEMPORAL_EXTENTS_FIELD,\n  ],\n}\n\nexport const GEOGRAPHICAL_COVERAGE_SECTION: EditorSection = {\n  labelKey: marker('editor.record.form.section.geographicalCoverage.label'),\n  hidden: false,\n  fields: [RECORD_SPATIAL_EXTENTS_FIELD],\n}\n\nexport const ASSOCIATED_RESOURCES_SECTION: EditorSection = {\n  labelKey: marker('editor.record.form.section.associatedResources.label'),\n  descriptionKey: marker(\n    'editor.record.form.section.associatedResources.description'\n  ),\n  hidden: false,\n  fields: [],\n}\n\nexport const ANNEXES_SECTION: EditorSection = {\n  labelKey: marker('editor.record.form.section.annexes.label'),\n  hidden: false,\n  fields: [RECORD_ONLINE_LINK_RESOURCES],\n}\n\nexport const CLASSIFICATION_SECTION: EditorSection = {\n  labelKey: marker('editor.record.form.section.classification.label'),\n  descriptionKey: marker(\n    'editor.record.form.section.classification.description'\n  ),\n  hidden: false,\n  fields: [RECORD_KEYWORDS_FIELD],\n}\n\nexport const USE_AND_ACCESS_CONDITIONS_SECTION: EditorSection = {\n  labelKey: marker('editor.record.form.section.useAndAccessConditions.label'),\n  hidden: false,\n  fields: [RECORD_LICENSE_FIELD],\n}\n\nexport const DATA_MANAGERS_SECTION: EditorSection = {\n  labelKey: marker('editor.record.form.section.dataManagers.label'),\n  descriptionKey: marker('editor.record.form.section.dataManagers.description'),\n  hidden: false,\n  fields: [CONTACTS_FOR_RESOURCE_FIELD],\n}\n\nexport const DATA_POINT_OF_CONTACT_SECTION: EditorSection = {\n  labelKey: marker('editor.record.form.section.dataPointOfContact.label'),\n  descriptionKey: marker(\n    'editor.record.form.section.dataPointOfContact.description'\n  ),\n  hidden: false,\n  fields: [CONTACTS],\n}\n\n/************************************************************\n ***************           PAGES            *****************\n ************************************************************\n */\nexport const DEFAULT_CONFIGURATION: EditorConfig = {\n  pages: [\n    {\n      labelKey: marker('editor.record.form.page.description'),\n      sections: [TITLE_SECTION, ABOUT_SECTION, GEOGRAPHICAL_COVERAGE_SECTION],\n    },\n    {\n      labelKey: marker('editor.record.form.page.ressources'),\n      sections: [ASSOCIATED_RESOURCES_SECTION, ANNEXES_SECTION],\n    },\n    {\n      labelKey: marker('editor.record.form.page.accessAndContact'),\n      sections: [\n        CLASSIFICATION_SECTION,\n        USE_AND_ACCESS_CONDITIONS_SECTION,\n        DATA_MANAGERS_SECTION,\n        DATA_POINT_OF_CONTACT_SECTION,\n      ],\n    },\n  ],\n}\n\n/************************************************************\n ***************           LICENSES            **************\n ************************************************************\n */\nexport const OPEN_DATA_LICENSES: string[] = [\n  'etalab',\n  'etalab-v2',\n  'odbl',\n  'odc-by',\n  'pddl',\n]\n\nexport const MAX_UPLOAD_SIZE_MB = 10\n/************************************************************\n ***************        SPATIAL SCOPE            ************\n ************************************************************\n */\n\nexport const SPATIAL_SCOPES: Keyword[] = [\n  {\n    key: 'http://inspire.ec.europa.eu/metadata-codelist/SpatialScope/national',\n    label: 'National',\n    description: '',\n    type: 'theme',\n  },\n  {\n    key: 'http://inspire.ec.europa.eu/metadata-codelist/SpatialScope/regional',\n    label: 'Regional',\n    description: '',\n    type: 'theme',\n  },\n]\n"]}
|
|
228
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fields.config.js","sourceRoot":"","sources":["../../../../../../../libs/feature/editor/src/lib/fields.config.ts"],"names":[],"mappings":"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","sourcesContent":["import { marker } from '@biesbjerg/ngx-translate-extract-marker'\nimport {\n  EditorConfig,\n  EditorField,\n  EditorSection,\n} from './models/editor-config.model'\nimport { Keyword } from '../../../../../libs/common/domain/src/lib/model/record'\n\n/**\n * This file contains the configuration of the fields that will be displayed in the editor.\n * To add a new field, you need to create a new EditorField object in the fields part of this file.\n * Then add it to the corresponding section in the sections part of this file.\n * Finally, add the section to the corresponding page in the pages part of this file.\n */\n\n/************************************************************\n ***************           FIELDS           *****************\n ************************************************************\n */\n\nexport const RECORD_LICENSE_FIELD: EditorField = {\n  model: 'licenses',\n  formFieldConfig: {\n    labelKey: marker('editor.record.form.field.license'),\n  },\n}\n\nexport const RECORD_KEYWORDS_FIELD: EditorField = {\n  model: 'keywords',\n  formFieldConfig: {\n    labelKey: marker('editor.record.form.field.keywords'),\n  },\n}\n\nexport const RECORD_UNIQUE_IDENTIFIER_FIELD: EditorField = {\n  model: 'uniqueIdentifier',\n  formFieldConfig: {\n    labelKey: marker('editor.record.form.field.uniqueIdentifier'),\n    locked: true,\n  },\n}\n\nexport const RECORD_RESOURCE_UPDATED_FIELD: EditorField = {\n  model: 'resourceUpdated',\n  formFieldConfig: {\n    labelKey: marker('editor.record.form.field.resourceUpdated'),\n  },\n  gridColumnSpan: 1,\n}\n\nexport const RECORD_UPDATED_FIELD: EditorField = {\n  model: 'recordUpdated',\n  formFieldConfig: {\n    labelKey: marker('editor.record.form.field.recordUpdated'),\n    locked: true,\n  },\n  onSaveProcess: '${dateNow()}',\n  gridColumnSpan: 1,\n}\n\nexport const RECORD_UPDATE_FREQUENCY_FIELD: EditorField = {\n  model: 'updateFrequency',\n  formFieldConfig: {},\n}\n// keeping track of the label to not lose existing translation\nmarker('editor.record.form.field.updateFrequency')\n\nexport const RECORD_TEMPORAL_EXTENTS_FIELD: EditorField = {\n  model: 'temporalExtents',\n  formFieldConfig: {\n    labelKey: marker('editor.record.form.field.temporalExtents'),\n  },\n}\n\nexport const RECORD_TITLE_FIELD: EditorField = {\n  model: 'title',\n  formFieldConfig: {\n    labelKey: marker('editor.record.form.field.title'),\n  },\n}\n\nexport const RECORD_ABSTRACT_FIELD: EditorField = {\n  model: 'abstract',\n  formFieldConfig: {\n    labelKey: marker('editor.record.form.field.abstract'),\n  },\n}\n\nexport const CONTACTS_FOR_RESOURCE_FIELD: EditorField = {\n  model: 'contactsForResource',\n  formFieldConfig: {\n    labelKey: '',\n  },\n}\n\nexport const CONTACTS: EditorField = {\n  model: 'contacts',\n  formFieldConfig: {\n    labelKey: '',\n  },\n}\n\nexport const RECORD_GRAPHICAL_OVERVIEW_FIELD: EditorField = {\n  model: 'overviews',\n  formFieldConfig: {\n    labelKey: marker('editor.record.form.field.overviews'),\n  },\n}\n\nexport const RECORD_SPATIAL_EXTENTS_FIELD: EditorField = {\n  model: 'spatialExtents',\n  formFieldConfig: {\n    labelKey: marker('editor.record.form.field.spatialExtents'),\n  },\n}\n\nexport const RECORD_ONLINE_RESOURCES: EditorField = {\n  model: 'onlineResources',\n  modelSpecifier: 'onlineResourceType:!link',\n  formFieldConfig: {\n    labelKey: marker('editor.record.form.field.onlineResources'),\n  },\n}\n\nexport const RECORD_ONLINE_LINK_RESOURCES: EditorField = {\n  model: 'onlineResources',\n  modelSpecifier: 'onlineResourceType:link',\n  formFieldConfig: {\n    labelKey: marker('editor.record.form.field.onlineLinkResources'),\n  },\n}\n\n/************************************************************\n ***************          SECTIONS          *****************\n ************************************************************\n */\n\nexport const TITLE_SECTION: EditorSection = {\n  hidden: false,\n  fields: [\n    RECORD_TITLE_FIELD,\n    RECORD_ABSTRACT_FIELD,\n    RECORD_GRAPHICAL_OVERVIEW_FIELD,\n  ],\n}\n\nexport const ABOUT_SECTION: EditorSection = {\n  labelKey: marker('editor.record.form.section.about.label'),\n  descriptionKey: marker('editor.record.form.section.about.description'),\n  hidden: false,\n  fields: [\n    RECORD_UNIQUE_IDENTIFIER_FIELD,\n    RECORD_RESOURCE_UPDATED_FIELD,\n    RECORD_UPDATED_FIELD,\n    RECORD_UPDATE_FREQUENCY_FIELD,\n    RECORD_TEMPORAL_EXTENTS_FIELD,\n  ],\n}\n\nexport const GEOGRAPHICAL_COVERAGE_SECTION: EditorSection = {\n  labelKey: marker('editor.record.form.section.geographicalCoverage.label'),\n  hidden: false,\n  fields: [RECORD_SPATIAL_EXTENTS_FIELD],\n}\n\nexport const ASSOCIATED_RESOURCES_SECTION: EditorSection = {\n  labelKey: marker('editor.record.form.section.associatedResources.label'),\n  descriptionKey: marker(\n    'editor.record.form.section.associatedResources.description'\n  ),\n  hidden: false,\n  fields: [RECORD_ONLINE_RESOURCES],\n}\n\nexport const ANNEXES_SECTION: EditorSection = {\n  labelKey: marker('editor.record.form.section.annexes.label'),\n  descriptionKey: marker('editor.record.form.section.annexes.description'),\n  hidden: false,\n  fields: [RECORD_ONLINE_LINK_RESOURCES],\n}\n\nexport const CLASSIFICATION_SECTION: EditorSection = {\n  labelKey: marker('editor.record.form.section.classification.label'),\n  descriptionKey: marker(\n    'editor.record.form.section.classification.description'\n  ),\n  hidden: false,\n  fields: [RECORD_KEYWORDS_FIELD],\n}\n\nexport const USE_AND_ACCESS_CONDITIONS_SECTION: EditorSection = {\n  labelKey: marker('editor.record.form.section.useAndAccessConditions.label'),\n  hidden: false,\n  fields: [RECORD_LICENSE_FIELD],\n}\n\nexport const DATA_MANAGERS_SECTION: EditorSection = {\n  labelKey: marker('editor.record.form.section.dataManagers.label'),\n  descriptionKey: marker('editor.record.form.section.dataManagers.description'),\n  hidden: false,\n  fields: [CONTACTS_FOR_RESOURCE_FIELD],\n}\n\nexport const DATA_POINT_OF_CONTACT_SECTION: EditorSection = {\n  labelKey: marker('editor.record.form.section.dataPointOfContact.label'),\n  descriptionKey: marker(\n    'editor.record.form.section.dataPointOfContact.description'\n  ),\n  hidden: false,\n  fields: [CONTACTS],\n}\n\n/************************************************************\n ***************           PAGES            *****************\n ************************************************************\n */\nexport const DEFAULT_CONFIGURATION: EditorConfig = {\n  pages: [\n    {\n      labelKey: marker('editor.record.form.page.description'),\n      sections: [TITLE_SECTION, ABOUT_SECTION, GEOGRAPHICAL_COVERAGE_SECTION],\n    },\n    {\n      labelKey: marker('editor.record.form.page.ressources'),\n      sections: [ASSOCIATED_RESOURCES_SECTION, ANNEXES_SECTION],\n    },\n    {\n      labelKey: marker('editor.record.form.page.accessAndContact'),\n      sections: [\n        CLASSIFICATION_SECTION,\n        USE_AND_ACCESS_CONDITIONS_SECTION,\n        DATA_MANAGERS_SECTION,\n        DATA_POINT_OF_CONTACT_SECTION,\n      ],\n    },\n  ],\n}\n\n/************************************************************\n ***************           LICENSES            **************\n ************************************************************\n */\nexport const OPEN_DATA_LICENSES: string[] = [\n  'etalab',\n  'etalab-v2',\n  'odbl',\n  'odc-by',\n  'pddl',\n]\n\nexport const MAX_UPLOAD_SIZE_MB = 10\n/************************************************************\n ***************        SPATIAL SCOPE            ************\n ************************************************************\n */\n\nexport const SPATIAL_SCOPES: Keyword[] = [\n  {\n    key: 'http://inspire.ec.europa.eu/metadata-codelist/SpatialScope/national',\n    label: 'National',\n    description: '',\n    type: 'theme',\n  },\n  {\n    key: 'http://inspire.ec.europa.eu/metadata-codelist/SpatialScope/regional',\n    label: 'Regional',\n    description: '',\n    type: 'theme',\n  },\n]\n"]}
|
|
@@ -60,7 +60,7 @@ export class FileInputComponent {
|
|
|
60
60
|
this.uploadCancel.emit();
|
|
61
61
|
}
|
|
62
62
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FileInputComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
63
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: FileInputComponent, isStandalone: true, selector: "gn-ui-file-input", inputs: { maxSizeMB: "maxSizeMB", uploadProgress: "uploadProgress" }, outputs: { fileChange: "fileChange", urlChange: "urlChange", uploadCancel: "uploadCancel" }, ngImport: i0, template: "<div class=\"w-full flex flex-col gap-[16px]\">\n <label\n gnUiFilesDrop\n class=\"flex-1 border-2 border-dashed rounded-lg p-6 flex flex-col items-center justify-center gap-4 transition-colors duration-100\"\n [ngClass]=\"{\n 'border-primary-lighter bg-primary-white': dragFilesOver,\n 'border-gray-300': !dragFilesOver,\n 'cursor-pointer hover:border-gray-500': !isUploadInProgress\n }\"\n [attr.tabindex]=\"isUploadInProgress ? null : 0\"\n (dragFilesOver)=\"handleDragFilesOver($event)\"\n (dropFiles)=\"handleDropFiles($event)\"\n (keydown.enter)=\"fileInput.click()\"\n >\n <div\n class=\"w-14 h-14 rounded-md bg-gray-50 grid\"\n *ngIf=\"!isUploadInProgress\"\n >\n <mat-icon\n *ngIf=\"!dragFilesOver\"\n class=\"material-symbols-outlined place-self-center text-primary\"\n >cloud_upload</mat-icon\n >\n <mat-icon\n *ngIf=\"dragFilesOver\"\n class=\"material-symbols-outlined place-self-center text-primary\"\n >add_box</mat-icon\n >\n </div>\n <div\n *ngIf=\"isUploadInProgress\"\n class=\"w-14 h-14 grid items-center justify-center relative\"\n >\n <div class=\"text-gray-100 absolute\">\n <mat-progress-spinner\n class=\"place-self-center\"\n [diameter]=\"56\"\n mode=\"determinate\"\n [value]=\"100\"\n ></mat-progress-spinner>\n </div>\n <div class=\"text-primary absolute\">\n <mat-progress-spinner\n class=\"place-self-center\"\n [diameter]=\"56\"\n mode=\"determinate\"\n [value]=\"uploadProgress\"\n ></mat-progress-spinner>\n </div>\n <span class=\"text-sm text-main font-bold\">{{ uploadProgress }}%</span>\n </div>\n <div class=\"flex flex-col items-center gap-1\">\n <p class=\"font-medium\">\n {{ getPrimaryText() | translate: { sizeMB: maxSizeMB.toFixed(0) } }}\n </p>\n <p\n class=\"text-sm\"\n [class]=\"\n isUploadInProgress\n ? 'font-bold text-primary cursor-pointer'\n : 'font-medium text-gray-500'\n \"\n (click)=\"handleSecondaryTextClick($event)\"\n >\n {{ getSecondaryText() | translate }}\n </p>\n </div>\n <p class=\"w-full flex flex-row items-center justify-stretch gap-[16px]\">\n <span class=\"border-b border-gray-300 grow\"></span>\n <span class=\"text-sm font-medium text-gray-500 or-input-url\" translate>\n input.file.orInputUrl</span\n >\n <span class=\"border-b border-gray-300 grow\"></span>\n </p>\n <
|
|
63
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: FileInputComponent, isStandalone: true, selector: "gn-ui-file-input", inputs: { maxSizeMB: "maxSizeMB", uploadProgress: "uploadProgress" }, outputs: { fileChange: "fileChange", urlChange: "urlChange", uploadCancel: "uploadCancel" }, ngImport: i0, template: "<div class=\"w-full flex flex-col gap-[16px]\">\n <label\n gnUiFilesDrop\n class=\"flex-1 border-2 border-dashed rounded-lg p-6 flex flex-col items-center justify-center gap-4 transition-colors duration-100\"\n [ngClass]=\"{\n 'border-primary-lighter bg-primary-white': dragFilesOver,\n 'border-gray-300': !dragFilesOver,\n 'cursor-pointer hover:border-gray-500': !isUploadInProgress\n }\"\n [attr.tabindex]=\"isUploadInProgress ? null : 0\"\n (dragFilesOver)=\"handleDragFilesOver($event)\"\n (dropFiles)=\"handleDropFiles($event)\"\n (keydown.enter)=\"fileInput.click()\"\n >\n <input\n #fileInput\n type=\"file\"\n class=\"hidden\"\n (change)=\"handleFileInput($event)\"\n [disabled]=\"isUploadInProgress\"\n />\n\n <div\n class=\"w-14 h-14 rounded-md bg-gray-50 grid\"\n *ngIf=\"!isUploadInProgress\"\n >\n <mat-icon\n *ngIf=\"!dragFilesOver\"\n class=\"material-symbols-outlined place-self-center text-primary\"\n >cloud_upload</mat-icon\n >\n <mat-icon\n *ngIf=\"dragFilesOver\"\n class=\"material-symbols-outlined place-self-center text-primary\"\n >add_box</mat-icon\n >\n </div>\n <div\n *ngIf=\"isUploadInProgress\"\n class=\"w-14 h-14 grid items-center justify-center relative\"\n >\n <div class=\"text-gray-100 absolute\">\n <mat-progress-spinner\n class=\"place-self-center\"\n [diameter]=\"56\"\n mode=\"determinate\"\n [value]=\"100\"\n ></mat-progress-spinner>\n </div>\n <div class=\"text-primary absolute\">\n <mat-progress-spinner\n class=\"place-self-center\"\n [diameter]=\"56\"\n mode=\"determinate\"\n [value]=\"uploadProgress\"\n ></mat-progress-spinner>\n </div>\n <span class=\"text-sm text-main font-bold\">{{ uploadProgress }}%</span>\n </div>\n <div class=\"flex flex-col items-center gap-1\">\n <p class=\"font-medium\">\n {{ getPrimaryText() | translate: { sizeMB: maxSizeMB.toFixed(0) } }}\n </p>\n <p\n class=\"text-sm\"\n [class]=\"\n isUploadInProgress\n ? 'font-bold text-primary cursor-pointer'\n : 'font-medium text-gray-500'\n \"\n (click)=\"handleSecondaryTextClick($event)\"\n >\n {{ getSecondaryText() | translate }}\n </p>\n </div>\n <p class=\"w-full flex flex-row items-center justify-stretch gap-[16px]\">\n <span class=\"border-b border-gray-300 grow\"></span>\n <span class=\"text-sm font-medium text-gray-500 or-input-url\" translate>\n input.file.orInputUrl</span\n >\n <span class=\"border-b border-gray-300 grow\"></span>\n </p>\n <gn-ui-url-input\n class=\"w-full\"\n [disabled]=\"isUploadInProgress\"\n (valueChange)=\"handleUrlChange($event)\"\n ></gn-ui-url-input>\n </label>\n</div>\n", styles: [":host{--gn-ui-button-padding: 8px 8px;--gn-ui-button-rounded: 8px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i2.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: FilesDropDirective, selector: "[gnUiFilesDrop]", outputs: ["dragFilesOver", "dropFiles"] }, { kind: "ngmodule", type: MatProgressSpinnerModule }, { kind: "component", type: i3.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i4.TranslatePipe, name: "translate" }, { kind: "directive", type: i4.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: UrlInputComponent, selector: "gn-ui-url-input", inputs: ["value", "extraClass", "placeholder", "disabled", "urlCanParse"], outputs: ["valueChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
64
64
|
}
|
|
65
65
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FileInputComponent, decorators: [{
|
|
66
66
|
type: Component,
|
|
@@ -72,7 +72,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
72
72
|
MatProgressSpinnerModule,
|
|
73
73
|
TranslateModule,
|
|
74
74
|
UrlInputComponent,
|
|
75
|
-
], template: "<div class=\"w-full flex flex-col gap-[16px]\">\n <label\n gnUiFilesDrop\n class=\"flex-1 border-2 border-dashed rounded-lg p-6 flex flex-col items-center justify-center gap-4 transition-colors duration-100\"\n [ngClass]=\"{\n 'border-primary-lighter bg-primary-white': dragFilesOver,\n 'border-gray-300': !dragFilesOver,\n 'cursor-pointer hover:border-gray-500': !isUploadInProgress\n }\"\n [attr.tabindex]=\"isUploadInProgress ? null : 0\"\n (dragFilesOver)=\"handleDragFilesOver($event)\"\n (dropFiles)=\"handleDropFiles($event)\"\n (keydown.enter)=\"fileInput.click()\"\n >\n <div\n class=\"w-14 h-14 rounded-md bg-gray-50 grid\"\n *ngIf=\"!isUploadInProgress\"\n >\n <mat-icon\n *ngIf=\"!dragFilesOver\"\n class=\"material-symbols-outlined place-self-center text-primary\"\n >cloud_upload</mat-icon\n >\n <mat-icon\n *ngIf=\"dragFilesOver\"\n class=\"material-symbols-outlined place-self-center text-primary\"\n >add_box</mat-icon\n >\n </div>\n <div\n *ngIf=\"isUploadInProgress\"\n class=\"w-14 h-14 grid items-center justify-center relative\"\n >\n <div class=\"text-gray-100 absolute\">\n <mat-progress-spinner\n class=\"place-self-center\"\n [diameter]=\"56\"\n mode=\"determinate\"\n [value]=\"100\"\n ></mat-progress-spinner>\n </div>\n <div class=\"text-primary absolute\">\n <mat-progress-spinner\n class=\"place-self-center\"\n [diameter]=\"56\"\n mode=\"determinate\"\n [value]=\"uploadProgress\"\n ></mat-progress-spinner>\n </div>\n <span class=\"text-sm text-main font-bold\">{{ uploadProgress }}%</span>\n </div>\n <div class=\"flex flex-col items-center gap-1\">\n <p class=\"font-medium\">\n {{ getPrimaryText() | translate: { sizeMB: maxSizeMB.toFixed(0) } }}\n </p>\n <p\n class=\"text-sm\"\n [class]=\"\n isUploadInProgress\n ? 'font-bold text-primary cursor-pointer'\n : 'font-medium text-gray-500'\n \"\n (click)=\"handleSecondaryTextClick($event)\"\n >\n {{ getSecondaryText() | translate }}\n </p>\n </div>\n <p class=\"w-full flex flex-row items-center justify-stretch gap-[16px]\">\n <span class=\"border-b border-gray-300 grow\"></span>\n <span class=\"text-sm font-medium text-gray-500 or-input-url\" translate>\n input.file.orInputUrl</span\n >\n <span class=\"border-b border-gray-300 grow\"></span>\n </p>\n <
|
|
75
|
+
], template: "<div class=\"w-full flex flex-col gap-[16px]\">\n <label\n gnUiFilesDrop\n class=\"flex-1 border-2 border-dashed rounded-lg p-6 flex flex-col items-center justify-center gap-4 transition-colors duration-100\"\n [ngClass]=\"{\n 'border-primary-lighter bg-primary-white': dragFilesOver,\n 'border-gray-300': !dragFilesOver,\n 'cursor-pointer hover:border-gray-500': !isUploadInProgress\n }\"\n [attr.tabindex]=\"isUploadInProgress ? null : 0\"\n (dragFilesOver)=\"handleDragFilesOver($event)\"\n (dropFiles)=\"handleDropFiles($event)\"\n (keydown.enter)=\"fileInput.click()\"\n >\n <input\n #fileInput\n type=\"file\"\n class=\"hidden\"\n (change)=\"handleFileInput($event)\"\n [disabled]=\"isUploadInProgress\"\n />\n\n <div\n class=\"w-14 h-14 rounded-md bg-gray-50 grid\"\n *ngIf=\"!isUploadInProgress\"\n >\n <mat-icon\n *ngIf=\"!dragFilesOver\"\n class=\"material-symbols-outlined place-self-center text-primary\"\n >cloud_upload</mat-icon\n >\n <mat-icon\n *ngIf=\"dragFilesOver\"\n class=\"material-symbols-outlined place-self-center text-primary\"\n >add_box</mat-icon\n >\n </div>\n <div\n *ngIf=\"isUploadInProgress\"\n class=\"w-14 h-14 grid items-center justify-center relative\"\n >\n <div class=\"text-gray-100 absolute\">\n <mat-progress-spinner\n class=\"place-self-center\"\n [diameter]=\"56\"\n mode=\"determinate\"\n [value]=\"100\"\n ></mat-progress-spinner>\n </div>\n <div class=\"text-primary absolute\">\n <mat-progress-spinner\n class=\"place-self-center\"\n [diameter]=\"56\"\n mode=\"determinate\"\n [value]=\"uploadProgress\"\n ></mat-progress-spinner>\n </div>\n <span class=\"text-sm text-main font-bold\">{{ uploadProgress }}%</span>\n </div>\n <div class=\"flex flex-col items-center gap-1\">\n <p class=\"font-medium\">\n {{ getPrimaryText() | translate: { sizeMB: maxSizeMB.toFixed(0) } }}\n </p>\n <p\n class=\"text-sm\"\n [class]=\"\n isUploadInProgress\n ? 'font-bold text-primary cursor-pointer'\n : 'font-medium text-gray-500'\n \"\n (click)=\"handleSecondaryTextClick($event)\"\n >\n {{ getSecondaryText() | translate }}\n </p>\n </div>\n <p class=\"w-full flex flex-row items-center justify-stretch gap-[16px]\">\n <span class=\"border-b border-gray-300 grow\"></span>\n <span class=\"text-sm font-medium text-gray-500 or-input-url\" translate>\n input.file.orInputUrl</span\n >\n <span class=\"border-b border-gray-300 grow\"></span>\n </p>\n <gn-ui-url-input\n class=\"w-full\"\n [disabled]=\"isUploadInProgress\"\n (valueChange)=\"handleUrlChange($event)\"\n ></gn-ui-url-input>\n </label>\n</div>\n", styles: [":host{--gn-ui-button-padding: 8px 8px;--gn-ui-button-rounded: 8px}\n"] }]
|
|
76
76
|
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { maxSizeMB: [{
|
|
77
77
|
type: Input
|
|
78
78
|
}], uploadProgress: [{
|
|
@@ -84,4 +84,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
84
84
|
}], uploadCancel: [{
|
|
85
85
|
type: Output
|
|
86
86
|
}] } });
|
|
87
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-input.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/inputs/src/lib/file-input/file-input.component.ts","../../../../../../../../libs/ui/inputs/src/lib/file-input/file-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common'\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n} from '@angular/core'\nimport { MatIconModule } from '@angular/material/icon'\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner'\nimport { ButtonComponent } from '../button/button.component'\nimport { FilesDropDirective } from '../files-drop/files-drop.directive'\nimport { TranslateModule } from '@ngx-translate/core'\nimport { marker } from '@biesbjerg/ngx-translate-extract-marker'\nimport { UrlInputComponent } from '../url-input/url-input.component'\n\n@Component({\n  selector: 'gn-ui-file-input',\n  templateUrl: './file-input.component.html',\n  styleUrls: ['./file-input.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    ButtonComponent,\n    MatIconModule,\n    FilesDropDirective,\n    MatProgressSpinnerModule,\n    TranslateModule,\n    UrlInputComponent,\n  ],\n})\nexport class FileInputComponent {\n  @Input() maxSizeMB: number\n  @Input() uploadProgress?: number\n  @Output() fileChange: EventEmitter<File> = new EventEmitter()\n  @Output() urlChange: EventEmitter<string> = new EventEmitter()\n  @Output() uploadCancel: EventEmitter<void> = new EventEmitter()\n\n  dragFilesOver = false\n\n  get isUploadInProgress() {\n    return this.uploadProgress !== undefined\n  }\n\n  constructor(private cd: ChangeDetectorRef) {}\n\n  getPrimaryText() {\n    if (this.uploadProgress) {\n      return marker('input.file.uploadProgressLabel')\n    }\n    return marker('input.file.selectFileLabel')\n  }\n\n  getSecondaryText() {\n    if (this.uploadProgress) {\n      return marker('input.file.uploadProgressCancel')\n    }\n    return marker('input.file.dropFileLabel')\n  }\n\n  handleDragFilesOver(dragFilesOver: boolean) {\n    this.dragFilesOver = dragFilesOver\n    this.cd.markForCheck()\n  }\n\n  handleDropFiles(files: File[]) {\n    if (files.length > 0) {\n      this.fileChange.emit(files[0])\n    }\n  }\n\n  handleFileInput(event: Event) {\n    this.handleDropFiles(Array.from((event.target as HTMLInputElement).files))\n  }\n\n  handleUrlChange(url: string) {\n    this.urlChange.emit(url)\n  }\n\n  handleSecondaryTextClick(event: Event) {\n    if (this.uploadProgress) {\n      this.handleCancel()\n      event.preventDefault()\n    }\n  }\n\n  handleCancel() {\n    this.uploadCancel.emit()\n  }\n}\n","<div class=\"w-full flex flex-col gap-[16px]\">\n  <label\n    gnUiFilesDrop\n    class=\"flex-1 border-2 border-dashed rounded-lg p-6 flex flex-col items-center justify-center gap-4 transition-colors duration-100\"\n    [ngClass]=\"{\n      'border-primary-lighter bg-primary-white': dragFilesOver,\n      'border-gray-300': !dragFilesOver,\n      'cursor-pointer hover:border-gray-500': !isUploadInProgress\n    }\"\n    [attr.tabindex]=\"isUploadInProgress ? null : 0\"\n    (dragFilesOver)=\"handleDragFilesOver($event)\"\n    (dropFiles)=\"handleDropFiles($event)\"\n    (keydown.enter)=\"fileInput.click()\"\n  >\n    <div\n      class=\"w-14 h-14 rounded-md bg-gray-50 grid\"\n      *ngIf=\"!isUploadInProgress\"\n    >\n      <mat-icon\n        *ngIf=\"!dragFilesOver\"\n        class=\"material-symbols-outlined place-self-center text-primary\"\n        >cloud_upload</mat-icon\n      >\n      <mat-icon\n        *ngIf=\"dragFilesOver\"\n        class=\"material-symbols-outlined place-self-center text-primary\"\n        >add_box</mat-icon\n      >\n    </div>\n    <div\n      *ngIf=\"isUploadInProgress\"\n      class=\"w-14 h-14 grid items-center justify-center relative\"\n    >\n      <div class=\"text-gray-100 absolute\">\n        <mat-progress-spinner\n          class=\"place-self-center\"\n          [diameter]=\"56\"\n          mode=\"determinate\"\n          [value]=\"100\"\n        ></mat-progress-spinner>\n      </div>\n      <div class=\"text-primary absolute\">\n        <mat-progress-spinner\n          class=\"place-self-center\"\n          [diameter]=\"56\"\n          mode=\"determinate\"\n          [value]=\"uploadProgress\"\n        ></mat-progress-spinner>\n      </div>\n      <span class=\"text-sm text-main font-bold\">{{ uploadProgress }}%</span>\n    </div>\n    <div class=\"flex flex-col items-center gap-1\">\n      <p class=\"font-medium\">\n        {{ getPrimaryText() | translate: { sizeMB: maxSizeMB.toFixed(0) } }}\n      </p>\n      <p\n        class=\"text-sm\"\n        [class]=\"\n          isUploadInProgress\n            ? 'font-bold text-primary cursor-pointer'\n            : 'font-medium text-gray-500'\n        \"\n        (click)=\"handleSecondaryTextClick($event)\"\n      >\n        {{ getSecondaryText() | translate }}\n      </p>\n    </div>\n    <p class=\"w-full flex flex-row items-center justify-stretch gap-[16px]\">\n      <span class=\"border-b border-gray-300 grow\"></span>\n      <span class=\"text-sm font-medium text-gray-500 or-input-url\" translate>\n        input.file.orInputUrl</span\n      >\n      <span class=\"border-b border-gray-300 grow\"></span>\n    </p>\n    <input\n      #fileInput\n      type=\"file\"\n      class=\"hidden\"\n      (change)=\"handleFileInput($event)\"\n      [disabled]=\"isUploadInProgress\"\n    />\n\n    <gn-ui-url-input\n      class=\"w-full\"\n      [disabled]=\"isUploadInProgress\"\n      (valueChange)=\"handleUrlChange($event)\"\n    ></gn-ui-url-input>\n  </label>\n</div>\n"]}
|
|
87
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-input.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/inputs/src/lib/file-input/file-input.component.ts","../../../../../../../../libs/ui/inputs/src/lib/file-input/file-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common'\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n} from '@angular/core'\nimport { MatIconModule } from '@angular/material/icon'\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner'\nimport { ButtonComponent } from '../button/button.component'\nimport { FilesDropDirective } from '../files-drop/files-drop.directive'\nimport { TranslateModule } from '@ngx-translate/core'\nimport { marker } from '@biesbjerg/ngx-translate-extract-marker'\nimport { UrlInputComponent } from '../url-input/url-input.component'\n\n@Component({\n  selector: 'gn-ui-file-input',\n  templateUrl: './file-input.component.html',\n  styleUrls: ['./file-input.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    ButtonComponent,\n    MatIconModule,\n    FilesDropDirective,\n    MatProgressSpinnerModule,\n    TranslateModule,\n    UrlInputComponent,\n  ],\n})\nexport class FileInputComponent {\n  @Input() maxSizeMB: number\n  @Input() uploadProgress?: number\n  @Output() fileChange: EventEmitter<File> = new EventEmitter()\n  @Output() urlChange: EventEmitter<string> = new EventEmitter()\n  @Output() uploadCancel: EventEmitter<void> = new EventEmitter()\n\n  dragFilesOver = false\n\n  get isUploadInProgress() {\n    return this.uploadProgress !== undefined\n  }\n\n  constructor(private cd: ChangeDetectorRef) {}\n\n  getPrimaryText() {\n    if (this.uploadProgress) {\n      return marker('input.file.uploadProgressLabel')\n    }\n    return marker('input.file.selectFileLabel')\n  }\n\n  getSecondaryText() {\n    if (this.uploadProgress) {\n      return marker('input.file.uploadProgressCancel')\n    }\n    return marker('input.file.dropFileLabel')\n  }\n\n  handleDragFilesOver(dragFilesOver: boolean) {\n    this.dragFilesOver = dragFilesOver\n    this.cd.markForCheck()\n  }\n\n  handleDropFiles(files: File[]) {\n    if (files.length > 0) {\n      this.fileChange.emit(files[0])\n    }\n  }\n\n  handleFileInput(event: Event) {\n    this.handleDropFiles(Array.from((event.target as HTMLInputElement).files))\n  }\n\n  handleUrlChange(url: string) {\n    this.urlChange.emit(url)\n  }\n\n  handleSecondaryTextClick(event: Event) {\n    if (this.uploadProgress) {\n      this.handleCancel()\n      event.preventDefault()\n    }\n  }\n\n  handleCancel() {\n    this.uploadCancel.emit()\n  }\n}\n","<div class=\"w-full flex flex-col gap-[16px]\">\n  <label\n    gnUiFilesDrop\n    class=\"flex-1 border-2 border-dashed rounded-lg p-6 flex flex-col items-center justify-center gap-4 transition-colors duration-100\"\n    [ngClass]=\"{\n      'border-primary-lighter bg-primary-white': dragFilesOver,\n      'border-gray-300': !dragFilesOver,\n      'cursor-pointer hover:border-gray-500': !isUploadInProgress\n    }\"\n    [attr.tabindex]=\"isUploadInProgress ? null : 0\"\n    (dragFilesOver)=\"handleDragFilesOver($event)\"\n    (dropFiles)=\"handleDropFiles($event)\"\n    (keydown.enter)=\"fileInput.click()\"\n  >\n    <input\n      #fileInput\n      type=\"file\"\n      class=\"hidden\"\n      (change)=\"handleFileInput($event)\"\n      [disabled]=\"isUploadInProgress\"\n    />\n\n    <div\n      class=\"w-14 h-14 rounded-md bg-gray-50 grid\"\n      *ngIf=\"!isUploadInProgress\"\n    >\n      <mat-icon\n        *ngIf=\"!dragFilesOver\"\n        class=\"material-symbols-outlined place-self-center text-primary\"\n        >cloud_upload</mat-icon\n      >\n      <mat-icon\n        *ngIf=\"dragFilesOver\"\n        class=\"material-symbols-outlined place-self-center text-primary\"\n        >add_box</mat-icon\n      >\n    </div>\n    <div\n      *ngIf=\"isUploadInProgress\"\n      class=\"w-14 h-14 grid items-center justify-center relative\"\n    >\n      <div class=\"text-gray-100 absolute\">\n        <mat-progress-spinner\n          class=\"place-self-center\"\n          [diameter]=\"56\"\n          mode=\"determinate\"\n          [value]=\"100\"\n        ></mat-progress-spinner>\n      </div>\n      <div class=\"text-primary absolute\">\n        <mat-progress-spinner\n          class=\"place-self-center\"\n          [diameter]=\"56\"\n          mode=\"determinate\"\n          [value]=\"uploadProgress\"\n        ></mat-progress-spinner>\n      </div>\n      <span class=\"text-sm text-main font-bold\">{{ uploadProgress }}%</span>\n    </div>\n    <div class=\"flex flex-col items-center gap-1\">\n      <p class=\"font-medium\">\n        {{ getPrimaryText() | translate: { sizeMB: maxSizeMB.toFixed(0) } }}\n      </p>\n      <p\n        class=\"text-sm\"\n        [class]=\"\n          isUploadInProgress\n            ? 'font-bold text-primary cursor-pointer'\n            : 'font-medium text-gray-500'\n        \"\n        (click)=\"handleSecondaryTextClick($event)\"\n      >\n        {{ getSecondaryText() | translate }}\n      </p>\n    </div>\n    <p class=\"w-full flex flex-row items-center justify-stretch gap-[16px]\">\n      <span class=\"border-b border-gray-300 grow\"></span>\n      <span class=\"text-sm font-medium text-gray-500 or-input-url\" translate>\n        input.file.orInputUrl</span\n      >\n      <span class=\"border-b border-gray-300 grow\"></span>\n    </p>\n    <gn-ui-url-input\n      class=\"w-full\"\n      [disabled]=\"isUploadInProgress\"\n      (valueChange)=\"handleUrlChange($event)\"\n    ></gn-ui-url-input>\n  </label>\n</div>\n"]}
|
|
@@ -149,7 +149,7 @@ export class ImageInputComponent {
|
|
|
149
149
|
});
|
|
150
150
|
}
|
|
151
151
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ImageInputComponent, deps: [{ token: i1.HttpClient }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
152
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ImageInputComponent, isStandalone: true, selector: "gn-ui-image-input", inputs: { maxSizeMB: "maxSizeMB", previewUrl: "previewUrl", altText: "altText", uploadProgress: "uploadProgress", uploadError: "uploadError" }, outputs: { fileChange: "fileChange", urlChange: "urlChange", uploadCancel: "uploadCancel", delete: "delete", altTextChange: "altTextChange" }, ngImport: i0, template: "<ng-container *ngIf=\"previewUrl; then withImage; else withoutImage\">\n</ng-container>\n\n<ng-template #withImage>\n <div class=\"w-full h-full flex flex-col gap-2\">\n <div class=\"flex-1 group relative\">\n <img\n class=\"w-full object-cover border-2 border-gray-300 rounded-lg h-[172px]\"\n [alt]=\"altText\"\n loading=\"lazy\"\n [src]=\"previewUrl\"\n />\n <gn-ui-button\n type=\"outline\"\n style=\"--gn-ui-button-height: 40px; --gn-ui-button-width: 40px\"\n extraClass=\"absolute right-2 bottom-2 invisible group-hover:visible bg-background\"\n (buttonClick)=\"handleDelete()\"\n >\n <mat-icon class=\"material-symbols-outlined\">delete</mat-icon>\n </gn-ui-button>\n </div>\n <gn-ui-text-input\n *ngIf=\"showAltTextInput\"\n [placeholder]=\"'input.image.altTextPlaceholder' | translate\"\n [value]=\"altText ?? ''\"\n (valueChange)=\"handleAltTextChange($event)\"\n extraClass=\"gn-ui-editor-textarea\"\n ></gn-ui-text-input>\n <div class=\"flex flex-row gap-2 mt-2\">\n <gn-ui-button type=\"gray\" (buttonClick)=\"handleDelete()\">\n <mat-icon class=\"material-symbols-outlined me-1 text-primary\"\n >delete</mat-icon\n >\n {{ 'input.image.delete' | translate }}\n </gn-ui-button>\n <gn-ui-button\n *ngIf=\"!showAltTextInput\"\n type=\"gray\"\n (buttonClick)=\"toggleAltTextInput()\"\n >\n <mat-icon class=\"material-symbols-outlined me-1 text-primary\"\n >add</mat-icon\n >\n {{ 'input.image.displayAltTextInput' | translate }}\n </gn-ui-button>\n </div>\n </div>\n</ng-template>\n\n<ng-template #withoutImage>\n <div class=\"w-full h-full flex flex-col gap-2\">\n <label\n gnUiFilesDrop\n class=\"flex-1 border-2 border-dashed rounded-lg p-6 flex flex-col items-center justify-center gap-4 transition-colors duration-100\"\n [ngClass]=\"{\n 'border-primary-lighter bg-primary-white': dragFilesOver,\n 'border-gray-300': !dragFilesOver,\n 'cursor-pointer hover:border-gray-500':\n !isUploadInProgress && !uploadError && !showUrlInput\n }\"\n [attr.tabindex]=\"\n isUploadInProgress || uploadError || showUrlInput ? null : 0\n \"\n (keydown.enter)=\"fileInput.click()\"\n (dragFilesOver)=\"handleDragFilesOver($event)\"\n (dropFiles)=\"handleDropFiles($event)\"\n >\n <div\n class=\"w-14 h-14 rounded-md bg-gray-50 grid\"\n *ngIf=\"!isUploadInProgress && !uploadError\"\n >\n <mat-icon\n *ngIf=\"!dragFilesOver\"\n class=\"material-symbols-outlined place-self-center text-primary\"\n >image</mat-icon\n >\n <mat-icon\n *ngIf=\"dragFilesOver\"\n class=\"material-symbols-outlined place-self-center text-primary\"\n >add_box</mat-icon\n >\n </div>\n\n <div\n *ngIf=\"isUploadInProgress && !uploadError\"\n class=\"w-14 h-14 grid items-center justify-center relative\"\n >\n <div class=\"text-gray-100 absolute\">\n <mat-progress-spinner\n class=\"place-self-center\"\n [diameter]=\"56\"\n mode=\"determinate\"\n [value]=\"100\"\n ></mat-progress-spinner>\n </div>\n <div class=\"text-primary absolute\">\n <mat-progress-spinner\n class=\"place-self-center\"\n [diameter]=\"56\"\n mode=\"determinate\"\n [value]=\"uploadProgress\"\n ></mat-progress-spinner>\n </div>\n <span class=\"text-sm text-main font-bold\">{{ uploadProgress }}%</span>\n </div>\n\n <div class=\"w-14 h-14 rounded-md bg-gray-50 grid\" *ngIf=\"uploadError\">\n <mat-icon\n class=\"material-symbols-outlined place-self-center text-rose-500\"\n >broken_image</mat-icon\n >\n </div>\n\n <div class=\"flex flex-col items-center gap-1\">\n <p class=\"font-medium\">{{ getPrimaryText() | translate }}</p>\n <p\n class=\"text-sm\"\n [class]=\"\n isUploadInProgress || uploadError\n ? 'font-bold text-blue-500 cursor-pointer'\n : 'font-medium text-gray-500'\n \"\n (click)=\"handleSecondaryTextClick($event)\"\n >\n {{ getSecondaryText() | translate }}\n </p>\n </div>\n <input\n #fileInput\n type=\"file\"\n class=\"hidden\"\n (change)=\"handleFileInput($event)\"\n [disabled]=\"showUrlInput || isUploadInProgress || uploadError\"\n />\n </label>\n\n <div *ngIf=\"!showUrlInput\" class=\"flex-none mt-2\">\n <gn-ui-button (buttonClick)=\"displayUrlInput()\" type=\"gray\">\n <mat-icon class=\"material-symbols-outlined me-1 text-primary\"\n >link</mat-icon\n >\n {{ 'input.image.displayUrlInput' | translate }}\n </gn-ui-button>\n </div>\n\n <gn-ui-url-input\n *ngIf=\"showUrlInput\"\n class=\"mt-3.5\"\n (valueChange)=\"downloadUrl($event)\"\n [disabled]=\"isUploadInProgress\"\n >\n </gn-ui-url-input>\n </div>\n</ng-template>\n", styles: [":host{--gn-ui-button-padding: 8px 8px;--gn-ui-button-rounded: 8px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: ButtonComponent, selector: "gn-ui-button", inputs: ["type", "disabled", "extraClass"], outputs: ["buttonClick"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: FilesDropDirective, selector: "[gnUiFilesDrop]", outputs: ["dragFilesOver", "dropFiles"] }, { kind: "ngmodule", type: MatProgressSpinnerModule }, { kind: "component", type: i4.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }, { kind: "component", type: UrlInputComponent, selector: "gn-ui-url-input", inputs: ["value", "extraClass", "placeholder", "disabled"], outputs: ["valueChange"] }, { kind: "component", type: TextInputComponent, selector: "gn-ui-text-input", inputs: ["value", "extraClass", "placeholder", "required", "disabled"], outputs: ["valueChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
152
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ImageInputComponent, isStandalone: true, selector: "gn-ui-image-input", inputs: { maxSizeMB: "maxSizeMB", previewUrl: "previewUrl", altText: "altText", uploadProgress: "uploadProgress", uploadError: "uploadError" }, outputs: { fileChange: "fileChange", urlChange: "urlChange", uploadCancel: "uploadCancel", delete: "delete", altTextChange: "altTextChange" }, ngImport: i0, template: "<ng-container *ngIf=\"previewUrl; then withImage; else withoutImage\">\n</ng-container>\n\n<ng-template #withImage>\n <div class=\"w-full h-full flex flex-col gap-2\">\n <div class=\"flex-1 group relative\">\n <img\n class=\"w-full object-cover border-2 border-gray-300 rounded-lg h-[172px]\"\n [alt]=\"altText\"\n loading=\"lazy\"\n [src]=\"previewUrl\"\n />\n <gn-ui-button\n type=\"outline\"\n style=\"--gn-ui-button-height: 40px; --gn-ui-button-width: 40px\"\n extraClass=\"absolute right-2 bottom-2 invisible group-hover:visible bg-background\"\n (buttonClick)=\"handleDelete()\"\n >\n <mat-icon class=\"material-symbols-outlined\">delete</mat-icon>\n </gn-ui-button>\n </div>\n <gn-ui-text-input\n *ngIf=\"showAltTextInput\"\n [placeholder]=\"'input.image.altTextPlaceholder' | translate\"\n [value]=\"altText ?? ''\"\n (valueChange)=\"handleAltTextChange($event)\"\n extraClass=\"gn-ui-editor-textarea\"\n ></gn-ui-text-input>\n <div class=\"flex flex-row gap-2 mt-2\">\n <gn-ui-button type=\"gray\" (buttonClick)=\"handleDelete()\">\n <mat-icon class=\"material-symbols-outlined me-1 text-primary\"\n >delete</mat-icon\n >\n {{ 'input.image.delete' | translate }}\n </gn-ui-button>\n <gn-ui-button\n *ngIf=\"!showAltTextInput\"\n type=\"gray\"\n (buttonClick)=\"toggleAltTextInput()\"\n >\n <mat-icon class=\"material-symbols-outlined me-1 text-primary\"\n >add</mat-icon\n >\n {{ 'input.image.displayAltTextInput' | translate }}\n </gn-ui-button>\n </div>\n </div>\n</ng-template>\n\n<ng-template #withoutImage>\n <div class=\"w-full h-full flex flex-col gap-2\">\n <label\n gnUiFilesDrop\n class=\"flex-1 border-2 border-dashed rounded-lg p-6 flex flex-col items-center justify-center gap-4 transition-colors duration-100\"\n [ngClass]=\"{\n 'border-primary-lighter bg-primary-white': dragFilesOver,\n 'border-gray-300': !dragFilesOver,\n 'cursor-pointer hover:border-gray-500':\n !isUploadInProgress && !uploadError && !showUrlInput\n }\"\n [attr.tabindex]=\"\n isUploadInProgress || uploadError || showUrlInput ? null : 0\n \"\n (keydown.enter)=\"fileInput.click()\"\n (dragFilesOver)=\"handleDragFilesOver($event)\"\n (dropFiles)=\"handleDropFiles($event)\"\n >\n <div\n class=\"w-14 h-14 rounded-md bg-gray-50 grid\"\n *ngIf=\"!isUploadInProgress && !uploadError\"\n >\n <mat-icon\n *ngIf=\"!dragFilesOver\"\n class=\"material-symbols-outlined place-self-center text-primary\"\n >image</mat-icon\n >\n <mat-icon\n *ngIf=\"dragFilesOver\"\n class=\"material-symbols-outlined place-self-center text-primary\"\n >add_box</mat-icon\n >\n </div>\n\n <div\n *ngIf=\"isUploadInProgress && !uploadError\"\n class=\"w-14 h-14 grid items-center justify-center relative\"\n >\n <div class=\"text-gray-100 absolute\">\n <mat-progress-spinner\n class=\"place-self-center\"\n [diameter]=\"56\"\n mode=\"determinate\"\n [value]=\"100\"\n ></mat-progress-spinner>\n </div>\n <div class=\"text-primary absolute\">\n <mat-progress-spinner\n class=\"place-self-center\"\n [diameter]=\"56\"\n mode=\"determinate\"\n [value]=\"uploadProgress\"\n ></mat-progress-spinner>\n </div>\n <span class=\"text-sm text-main font-bold\">{{ uploadProgress }}%</span>\n </div>\n\n <div class=\"w-14 h-14 rounded-md bg-gray-50 grid\" *ngIf=\"uploadError\">\n <mat-icon\n class=\"material-symbols-outlined place-self-center text-rose-500\"\n >broken_image</mat-icon\n >\n </div>\n\n <div class=\"flex flex-col items-center gap-1\">\n <p class=\"font-medium\">{{ getPrimaryText() | translate }}</p>\n <p\n class=\"text-sm\"\n [class]=\"\n isUploadInProgress || uploadError\n ? 'font-bold text-blue-500 cursor-pointer'\n : 'font-medium text-gray-500'\n \"\n (click)=\"handleSecondaryTextClick($event)\"\n >\n {{ getSecondaryText() | translate }}\n </p>\n </div>\n <input\n #fileInput\n type=\"file\"\n class=\"hidden\"\n (change)=\"handleFileInput($event)\"\n [disabled]=\"showUrlInput || isUploadInProgress || uploadError\"\n />\n </label>\n\n <div *ngIf=\"!showUrlInput\" class=\"flex-none mt-2\">\n <gn-ui-button (buttonClick)=\"displayUrlInput()\" type=\"gray\">\n <mat-icon class=\"material-symbols-outlined me-1 text-primary\"\n >link</mat-icon\n >\n {{ 'input.image.displayUrlInput' | translate }}\n </gn-ui-button>\n </div>\n\n <gn-ui-url-input\n *ngIf=\"showUrlInput\"\n class=\"mt-3.5\"\n (valueChange)=\"downloadUrl($event)\"\n [disabled]=\"isUploadInProgress\"\n >\n </gn-ui-url-input>\n </div>\n</ng-template>\n", styles: [":host{--gn-ui-button-padding: 8px 8px;--gn-ui-button-rounded: 8px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: ButtonComponent, selector: "gn-ui-button", inputs: ["type", "disabled", "extraClass"], outputs: ["buttonClick"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: FilesDropDirective, selector: "[gnUiFilesDrop]", outputs: ["dragFilesOver", "dropFiles"] }, { kind: "ngmodule", type: MatProgressSpinnerModule }, { kind: "component", type: i4.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }, { kind: "component", type: UrlInputComponent, selector: "gn-ui-url-input", inputs: ["value", "extraClass", "placeholder", "disabled", "urlCanParse"], outputs: ["valueChange"] }, { kind: "component", type: TextInputComponent, selector: "gn-ui-text-input", inputs: ["value", "extraClass", "placeholder", "required", "disabled"], outputs: ["valueChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
153
153
|
}
|
|
154
154
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ImageInputComponent, decorators: [{
|
|
155
155
|
type: Component,
|
|
@@ -184,4 +184,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
184
184
|
}], altTextChange: [{
|
|
185
185
|
type: Output
|
|
186
186
|
}] } });
|
|
187
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-input.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/inputs/src/lib/image-input/image-input.component.ts","../../../../../../../../libs/ui/inputs/src/lib/image-input/image-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common'\nimport { HttpClient } from '@angular/common/http'\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n} from '@angular/core'\nimport { MatIconModule } from '@angular/material/icon'\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner'\nimport { downgradeImage, megabytesToBytes } from '../../../../../../libs/util/shared/src'\nimport { firstValueFrom } from 'rxjs'\nimport { ButtonComponent } from '../button/button.component'\nimport { FilesDropDirective } from '../files-drop/files-drop.directive'\nimport { TranslateModule } from '@ngx-translate/core'\nimport { marker } from '@biesbjerg/ngx-translate-extract-marker'\nimport { UrlInputComponent } from '../url-input/url-input.component'\nimport { TextInputComponent } from '../text-input/text-input.component'\n\n@Component({\n  selector: 'gn-ui-image-input',\n  templateUrl: './image-input.component.html',\n  styleUrls: ['./image-input.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    ButtonComponent,\n    MatIconModule,\n    FilesDropDirective,\n    MatProgressSpinnerModule,\n    TranslateModule,\n    UrlInputComponent,\n    TextInputComponent,\n  ],\n})\nexport class ImageInputComponent {\n  @Input() maxSizeMB: number\n  @Input() previewUrl?: string\n  @Input() altText?: string\n  @Input() uploadProgress?: number\n  @Input() uploadError?: boolean\n  @Output() fileChange: EventEmitter<File> = new EventEmitter()\n  @Output() urlChange: EventEmitter<string> = new EventEmitter()\n  @Output() uploadCancel: EventEmitter<void> = new EventEmitter()\n  @Output() delete: EventEmitter<void> = new EventEmitter()\n  @Output() altTextChange: EventEmitter<string> = new EventEmitter()\n\n  dragFilesOver = false\n  showUrlInput = false\n  downloadError = false\n  showAltTextInput = false\n\n  lastUploadType?: 'file' | 'url'\n  lastUploadContent?: string | File\n\n  get isUploadInProgress() {\n    return this.uploadProgress !== undefined\n  }\n\n  constructor(private http: HttpClient, private cd: ChangeDetectorRef) {}\n\n  getPrimaryText() {\n    if (this.uploadError) {\n      return marker('input.image.uploadErrorLabel')\n    }\n    if (this.uploadProgress) {\n      return marker('input.image.uploadProgressLabel')\n    }\n    return marker('input.image.selectFileLabel')\n  }\n\n  getSecondaryText() {\n    if (this.uploadError) {\n      return marker('input.image.uploadErrorRetry')\n    }\n    if (this.uploadProgress) {\n      return marker('input.image.uploadProgressCancel')\n    }\n    return marker('input.image.dropFileLabel')\n  }\n\n  handleDragFilesOver(dragFilesOver: boolean) {\n    if (!this.showUrlInput) {\n      this.dragFilesOver = dragFilesOver\n      this.cd.markForCheck()\n    }\n  }\n\n  handleDropFiles(files: File[]) {\n    if (!this.showUrlInput) {\n      const validFiles = this.filterTypeImage(files)\n      if (validFiles.length > 0) {\n        this.resizeAndEmit(validFiles[0])\n      }\n    }\n  }\n\n  handleFileInput(event: Event) {\n    const inputFiles = Array.from((event.target as HTMLInputElement).files)\n    const validFiles = this.filterTypeImage(inputFiles)\n    if (validFiles.length > 0) {\n      this.resizeAndEmit(validFiles[0])\n    }\n  }\n\n  displayUrlInput() {\n    this.uploadCancel.emit()\n    this.showUrlInput = true\n  }\n\n  async downloadUrl(url: string) {\n    this.downloadError = false\n    const name = url.split('/').pop()\n\n    try {\n      const response = await firstValueFrom(\n        this.http.head(url, { observe: 'response' })\n      )\n      if (\n        response.headers.get('content-type')?.startsWith('image/') &&\n        parseInt(response.headers.get('content-length')) <\n          megabytesToBytes(this.maxSizeMB)\n      ) {\n        this.http.get(url, { responseType: 'blob' }).subscribe({\n          next: (blob) => {\n            this.cd.markForCheck()\n            const file = new File([blob], name)\n            this.fileChange.emit(file)\n          },\n          error: () => {\n            this.downloadError = true\n            this.cd.markForCheck()\n            this.urlChange.emit(url)\n          },\n        })\n      }\n    } catch {\n      this.downloadError = true\n      this.cd.markForCheck()\n      return\n    }\n  }\n\n  handleSecondaryTextClick(event: Event) {\n    if (this.uploadError) {\n      this.handleRetry()\n    } else if (this.uploadProgress) {\n      this.handleCancel()\n      event.preventDefault()\n    }\n  }\n\n  handleCancel() {\n    this.uploadCancel.emit()\n  }\n\n  handleRetry() {\n    switch (this.lastUploadType) {\n      case 'file':\n        this.fileChange.emit(this.lastUploadContent as File)\n        break\n      case 'url':\n        this.urlChange.emit(this.lastUploadContent as string)\n        break\n    }\n  }\n\n  handleDelete() {\n    this.delete.emit()\n  }\n\n  toggleAltTextInput() {\n    this.showAltTextInput = !this.showAltTextInput\n  }\n\n  handleAltTextChange(altText: string) {\n    this.altTextChange.emit(altText)\n  }\n\n  private filterTypeImage(files: File[]) {\n    return files.filter((file) => {\n      return file.type.startsWith('image/')\n    })\n  }\n\n  private resizeAndEmit(imageToResize: File) {\n    const maxSizeBytes = megabytesToBytes(this.maxSizeMB)\n    downgradeImage(imageToResize, maxSizeBytes).then((resizedImage) => {\n      const fileToEmit = new File([resizedImage], imageToResize.name)\n      this.fileChange.emit(fileToEmit)\n    })\n  }\n}\n","<ng-container *ngIf=\"previewUrl; then withImage; else withoutImage\">\n</ng-container>\n\n<ng-template #withImage>\n  <div class=\"w-full h-full flex flex-col gap-2\">\n    <div class=\"flex-1 group relative\">\n      <img\n        class=\"w-full object-cover border-2 border-gray-300 rounded-lg h-[172px]\"\n        [alt]=\"altText\"\n        loading=\"lazy\"\n        [src]=\"previewUrl\"\n      />\n      <gn-ui-button\n        type=\"outline\"\n        style=\"--gn-ui-button-height: 40px; --gn-ui-button-width: 40px\"\n        extraClass=\"absolute right-2 bottom-2 invisible group-hover:visible bg-background\"\n        (buttonClick)=\"handleDelete()\"\n      >\n        <mat-icon class=\"material-symbols-outlined\">delete</mat-icon>\n      </gn-ui-button>\n    </div>\n    <gn-ui-text-input\n      *ngIf=\"showAltTextInput\"\n      [placeholder]=\"'input.image.altTextPlaceholder' | translate\"\n      [value]=\"altText ?? ''\"\n      (valueChange)=\"handleAltTextChange($event)\"\n      extraClass=\"gn-ui-editor-textarea\"\n    ></gn-ui-text-input>\n    <div class=\"flex flex-row gap-2 mt-2\">\n      <gn-ui-button type=\"gray\" (buttonClick)=\"handleDelete()\">\n        <mat-icon class=\"material-symbols-outlined me-1 text-primary\"\n          >delete</mat-icon\n        >\n        {{ 'input.image.delete' | translate }}\n      </gn-ui-button>\n      <gn-ui-button\n        *ngIf=\"!showAltTextInput\"\n        type=\"gray\"\n        (buttonClick)=\"toggleAltTextInput()\"\n      >\n        <mat-icon class=\"material-symbols-outlined me-1 text-primary\"\n          >add</mat-icon\n        >\n        {{ 'input.image.displayAltTextInput' | translate }}\n      </gn-ui-button>\n    </div>\n  </div>\n</ng-template>\n\n<ng-template #withoutImage>\n  <div class=\"w-full h-full flex flex-col gap-2\">\n    <label\n      gnUiFilesDrop\n      class=\"flex-1 border-2 border-dashed rounded-lg p-6 flex flex-col items-center justify-center gap-4 transition-colors duration-100\"\n      [ngClass]=\"{\n        'border-primary-lighter bg-primary-white': dragFilesOver,\n        'border-gray-300': !dragFilesOver,\n        'cursor-pointer hover:border-gray-500':\n          !isUploadInProgress && !uploadError && !showUrlInput\n      }\"\n      [attr.tabindex]=\"\n        isUploadInProgress || uploadError || showUrlInput ? null : 0\n      \"\n      (keydown.enter)=\"fileInput.click()\"\n      (dragFilesOver)=\"handleDragFilesOver($event)\"\n      (dropFiles)=\"handleDropFiles($event)\"\n    >\n      <div\n        class=\"w-14 h-14 rounded-md bg-gray-50 grid\"\n        *ngIf=\"!isUploadInProgress && !uploadError\"\n      >\n        <mat-icon\n          *ngIf=\"!dragFilesOver\"\n          class=\"material-symbols-outlined place-self-center text-primary\"\n          >image</mat-icon\n        >\n        <mat-icon\n          *ngIf=\"dragFilesOver\"\n          class=\"material-symbols-outlined place-self-center text-primary\"\n          >add_box</mat-icon\n        >\n      </div>\n\n      <div\n        *ngIf=\"isUploadInProgress && !uploadError\"\n        class=\"w-14 h-14 grid items-center justify-center relative\"\n      >\n        <div class=\"text-gray-100 absolute\">\n          <mat-progress-spinner\n            class=\"place-self-center\"\n            [diameter]=\"56\"\n            mode=\"determinate\"\n            [value]=\"100\"\n          ></mat-progress-spinner>\n        </div>\n        <div class=\"text-primary absolute\">\n          <mat-progress-spinner\n            class=\"place-self-center\"\n            [diameter]=\"56\"\n            mode=\"determinate\"\n            [value]=\"uploadProgress\"\n          ></mat-progress-spinner>\n        </div>\n        <span class=\"text-sm text-main font-bold\">{{ uploadProgress }}%</span>\n      </div>\n\n      <div class=\"w-14 h-14 rounded-md bg-gray-50 grid\" *ngIf=\"uploadError\">\n        <mat-icon\n          class=\"material-symbols-outlined place-self-center text-rose-500\"\n          >broken_image</mat-icon\n        >\n      </div>\n\n      <div class=\"flex flex-col items-center gap-1\">\n        <p class=\"font-medium\">{{ getPrimaryText() | translate }}</p>\n        <p\n          class=\"text-sm\"\n          [class]=\"\n            isUploadInProgress || uploadError\n              ? 'font-bold text-blue-500 cursor-pointer'\n              : 'font-medium text-gray-500'\n          \"\n          (click)=\"handleSecondaryTextClick($event)\"\n        >\n          {{ getSecondaryText() | translate }}\n        </p>\n      </div>\n      <input\n        #fileInput\n        type=\"file\"\n        class=\"hidden\"\n        (change)=\"handleFileInput($event)\"\n        [disabled]=\"showUrlInput || isUploadInProgress || uploadError\"\n      />\n    </label>\n\n    <div *ngIf=\"!showUrlInput\" class=\"flex-none mt-2\">\n      <gn-ui-button (buttonClick)=\"displayUrlInput()\" type=\"gray\">\n        <mat-icon class=\"material-symbols-outlined me-1 text-primary\"\n          >link</mat-icon\n        >\n        {{ 'input.image.displayUrlInput' | translate }}\n      </gn-ui-button>\n    </div>\n\n    <gn-ui-url-input\n      *ngIf=\"showUrlInput\"\n      class=\"mt-3.5\"\n      (valueChange)=\"downloadUrl($event)\"\n      [disabled]=\"isUploadInProgress\"\n    >\n    </gn-ui-url-input>\n  </div>\n</ng-template>\n"]}
|
|
187
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-input.component.js","sourceRoot":"","sources":["../../../../../../../../libs/ui/inputs/src/lib/image-input/image-input.component.ts","../../../../../../../../libs/ui/inputs/src/lib/image-input/image-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common'\nimport { HttpClient } from '@angular/common/http'\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n} from '@angular/core'\nimport { MatIconModule } from '@angular/material/icon'\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner'\nimport { downgradeImage, megabytesToBytes } from '../../../../../../libs/util/shared/src'\nimport { firstValueFrom } from 'rxjs'\nimport { ButtonComponent } from '../button/button.component'\nimport { FilesDropDirective } from '../files-drop/files-drop.directive'\nimport { TranslateModule } from '@ngx-translate/core'\nimport { marker } from '@biesbjerg/ngx-translate-extract-marker'\nimport { UrlInputComponent } from '../url-input/url-input.component'\nimport { TextInputComponent } from '../text-input/text-input.component'\n\n@Component({\n  selector: 'gn-ui-image-input',\n  templateUrl: './image-input.component.html',\n  styleUrls: ['./image-input.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    ButtonComponent,\n    MatIconModule,\n    FilesDropDirective,\n    MatProgressSpinnerModule,\n    TranslateModule,\n    UrlInputComponent,\n    TextInputComponent,\n  ],\n})\nexport class ImageInputComponent {\n  @Input() maxSizeMB: number\n  @Input() previewUrl?: string\n  @Input() altText?: string\n  @Input() uploadProgress?: number\n  @Input() uploadError?: boolean\n  @Output() fileChange: EventEmitter<File> = new EventEmitter()\n  @Output() urlChange: EventEmitter<string> = new EventEmitter()\n  @Output() uploadCancel: EventEmitter<void> = new EventEmitter()\n  @Output() delete: EventEmitter<void> = new EventEmitter()\n  @Output() altTextChange: EventEmitter<string> = new EventEmitter()\n\n  dragFilesOver = false\n  showUrlInput = false\n  downloadError = false\n  showAltTextInput = false\n\n  lastUploadType?: 'file' | 'url'\n  lastUploadContent?: string | File\n\n  get isUploadInProgress() {\n    return this.uploadProgress !== undefined\n  }\n\n  constructor(private http: HttpClient, private cd: ChangeDetectorRef) {}\n\n  getPrimaryText() {\n    if (this.uploadError) {\n      return marker('input.image.uploadErrorLabel')\n    }\n    if (this.uploadProgress) {\n      return marker('input.image.uploadProgressLabel')\n    }\n    return marker('input.image.selectFileLabel')\n  }\n\n  getSecondaryText() {\n    if (this.uploadError) {\n      return marker('input.image.uploadErrorRetry')\n    }\n    if (this.uploadProgress) {\n      return marker('input.image.uploadProgressCancel')\n    }\n    return marker('input.image.dropFileLabel')\n  }\n\n  handleDragFilesOver(dragFilesOver: boolean) {\n    if (!this.showUrlInput) {\n      this.dragFilesOver = dragFilesOver\n      this.cd.markForCheck()\n    }\n  }\n\n  handleDropFiles(files: File[]) {\n    if (!this.showUrlInput) {\n      const validFiles = this.filterTypeImage(files)\n      if (validFiles.length > 0) {\n        this.resizeAndEmit(validFiles[0])\n      }\n    }\n  }\n\n  handleFileInput(event: Event) {\n    const inputFiles = Array.from((event.target as HTMLInputElement).files)\n    const validFiles = this.filterTypeImage(inputFiles)\n    if (validFiles.length > 0) {\n      this.resizeAndEmit(validFiles[0])\n    }\n  }\n\n  displayUrlInput() {\n    this.uploadCancel.emit()\n    this.showUrlInput = true\n  }\n\n  async downloadUrl(url: string) {\n    this.downloadError = false\n    const name = url.split('/').pop()\n\n    try {\n      const response = await firstValueFrom(\n        this.http.head(url, { observe: 'response' })\n      )\n      if (\n        response.headers.get('content-type')?.startsWith('image/') &&\n        parseInt(response.headers.get('content-length')) <\n          megabytesToBytes(this.maxSizeMB)\n      ) {\n        this.http.get(url, { responseType: 'blob' }).subscribe({\n          next: (blob) => {\n            this.cd.markForCheck()\n            const file = new File([blob], name)\n            this.fileChange.emit(file)\n          },\n          error: () => {\n            this.downloadError = true\n            this.cd.markForCheck()\n            this.urlChange.emit(url)\n          },\n        })\n      }\n    } catch {\n      this.downloadError = true\n      this.cd.markForCheck()\n      return\n    }\n  }\n\n  handleSecondaryTextClick(event: Event) {\n    if (this.uploadError) {\n      this.handleRetry()\n    } else if (this.uploadProgress) {\n      this.handleCancel()\n      event.preventDefault()\n    }\n  }\n\n  handleCancel() {\n    this.uploadCancel.emit()\n  }\n\n  handleRetry() {\n    switch (this.lastUploadType) {\n      case 'file':\n        this.fileChange.emit(this.lastUploadContent as File)\n        break\n      case 'url':\n        this.urlChange.emit(this.lastUploadContent as string)\n        break\n    }\n  }\n\n  handleDelete() {\n    this.delete.emit()\n  }\n\n  toggleAltTextInput() {\n    this.showAltTextInput = !this.showAltTextInput\n  }\n\n  handleAltTextChange(altText: string) {\n    this.altTextChange.emit(altText)\n  }\n\n  private filterTypeImage(files: File[]) {\n    return files.filter((file) => {\n      return file.type.startsWith('image/')\n    })\n  }\n\n  private resizeAndEmit(imageToResize: File) {\n    const maxSizeBytes = megabytesToBytes(this.maxSizeMB)\n    downgradeImage(imageToResize, maxSizeBytes).then((resizedImage) => {\n      const fileToEmit = new File([resizedImage], imageToResize.name)\n      this.fileChange.emit(fileToEmit)\n    })\n  }\n}\n","<ng-container *ngIf=\"previewUrl; then withImage; else withoutImage\">\n</ng-container>\n\n<ng-template #withImage>\n  <div class=\"w-full h-full flex flex-col gap-2\">\n    <div class=\"flex-1 group relative\">\n      <img\n        class=\"w-full object-cover border-2 border-gray-300 rounded-lg h-[172px]\"\n        [alt]=\"altText\"\n        loading=\"lazy\"\n        [src]=\"previewUrl\"\n      />\n      <gn-ui-button\n        type=\"outline\"\n        style=\"--gn-ui-button-height: 40px; --gn-ui-button-width: 40px\"\n        extraClass=\"absolute right-2 bottom-2 invisible group-hover:visible bg-background\"\n        (buttonClick)=\"handleDelete()\"\n      >\n        <mat-icon class=\"material-symbols-outlined\">delete</mat-icon>\n      </gn-ui-button>\n    </div>\n    <gn-ui-text-input\n      *ngIf=\"showAltTextInput\"\n      [placeholder]=\"'input.image.altTextPlaceholder' | translate\"\n      [value]=\"altText ?? ''\"\n      (valueChange)=\"handleAltTextChange($event)\"\n      extraClass=\"gn-ui-editor-textarea\"\n    ></gn-ui-text-input>\n    <div class=\"flex flex-row gap-2 mt-2\">\n      <gn-ui-button type=\"gray\" (buttonClick)=\"handleDelete()\">\n        <mat-icon class=\"material-symbols-outlined me-1 text-primary\"\n          >delete</mat-icon\n        >\n        {{ 'input.image.delete' | translate }}\n      </gn-ui-button>\n      <gn-ui-button\n        *ngIf=\"!showAltTextInput\"\n        type=\"gray\"\n        (buttonClick)=\"toggleAltTextInput()\"\n      >\n        <mat-icon class=\"material-symbols-outlined me-1 text-primary\"\n          >add</mat-icon\n        >\n        {{ 'input.image.displayAltTextInput' | translate }}\n      </gn-ui-button>\n    </div>\n  </div>\n</ng-template>\n\n<ng-template #withoutImage>\n  <div class=\"w-full h-full flex flex-col gap-2\">\n    <label\n      gnUiFilesDrop\n      class=\"flex-1 border-2 border-dashed rounded-lg p-6 flex flex-col items-center justify-center gap-4 transition-colors duration-100\"\n      [ngClass]=\"{\n        'border-primary-lighter bg-primary-white': dragFilesOver,\n        'border-gray-300': !dragFilesOver,\n        'cursor-pointer hover:border-gray-500':\n          !isUploadInProgress && !uploadError && !showUrlInput\n      }\"\n      [attr.tabindex]=\"\n        isUploadInProgress || uploadError || showUrlInput ? null : 0\n      \"\n      (keydown.enter)=\"fileInput.click()\"\n      (dragFilesOver)=\"handleDragFilesOver($event)\"\n      (dropFiles)=\"handleDropFiles($event)\"\n    >\n      <div\n        class=\"w-14 h-14 rounded-md bg-gray-50 grid\"\n        *ngIf=\"!isUploadInProgress && !uploadError\"\n      >\n        <mat-icon\n          *ngIf=\"!dragFilesOver\"\n          class=\"material-symbols-outlined place-self-center text-primary\"\n          >image</mat-icon\n        >\n        <mat-icon\n          *ngIf=\"dragFilesOver\"\n          class=\"material-symbols-outlined place-self-center text-primary\"\n          >add_box</mat-icon\n        >\n      </div>\n\n      <div\n        *ngIf=\"isUploadInProgress && !uploadError\"\n        class=\"w-14 h-14 grid items-center justify-center relative\"\n      >\n        <div class=\"text-gray-100 absolute\">\n          <mat-progress-spinner\n            class=\"place-self-center\"\n            [diameter]=\"56\"\n            mode=\"determinate\"\n            [value]=\"100\"\n          ></mat-progress-spinner>\n        </div>\n        <div class=\"text-primary absolute\">\n          <mat-progress-spinner\n            class=\"place-self-center\"\n            [diameter]=\"56\"\n            mode=\"determinate\"\n            [value]=\"uploadProgress\"\n          ></mat-progress-spinner>\n        </div>\n        <span class=\"text-sm text-main font-bold\">{{ uploadProgress }}%</span>\n      </div>\n\n      <div class=\"w-14 h-14 rounded-md bg-gray-50 grid\" *ngIf=\"uploadError\">\n        <mat-icon\n          class=\"material-symbols-outlined place-self-center text-rose-500\"\n          >broken_image</mat-icon\n        >\n      </div>\n\n      <div class=\"flex flex-col items-center gap-1\">\n        <p class=\"font-medium\">{{ getPrimaryText() | translate }}</p>\n        <p\n          class=\"text-sm\"\n          [class]=\"\n            isUploadInProgress || uploadError\n              ? 'font-bold text-blue-500 cursor-pointer'\n              : 'font-medium text-gray-500'\n          \"\n          (click)=\"handleSecondaryTextClick($event)\"\n        >\n          {{ getSecondaryText() | translate }}\n        </p>\n      </div>\n      <input\n        #fileInput\n        type=\"file\"\n        class=\"hidden\"\n        (change)=\"handleFileInput($event)\"\n        [disabled]=\"showUrlInput || isUploadInProgress || uploadError\"\n      />\n    </label>\n\n    <div *ngIf=\"!showUrlInput\" class=\"flex-none mt-2\">\n      <gn-ui-button (buttonClick)=\"displayUrlInput()\" type=\"gray\">\n        <mat-icon class=\"material-symbols-outlined me-1 text-primary\"\n          >link</mat-icon\n        >\n        {{ 'input.image.displayUrlInput' | translate }}\n      </gn-ui-button>\n    </div>\n\n    <gn-ui-url-input\n      *ngIf=\"showUrlInput\"\n      class=\"mt-3.5\"\n      (valueChange)=\"downloadUrl($event)\"\n      [disabled]=\"isUploadInProgress\"\n    >\n    </gn-ui-url-input>\n  </div>\n</ng-template>\n"]}
|