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
package/esm2022/libs/feature/editor/src/lib/components/import-record/import-record.component.mjs
CHANGED
|
@@ -77,7 +77,7 @@ export class ImportRecordComponent {
|
|
|
77
77
|
});
|
|
78
78
|
}
|
|
79
79
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ImportRecordComponent, deps: [{ token: i1.Router }, { token: i2.TranslateService }, { token: i0.ChangeDetectorRef }, { token: i3.NotificationsService }, { token: i4.RecordsRepositoryInterface }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
80
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ImportRecordComponent, isStandalone: true, selector: "gn-ui-import-record", outputs: { closeImportMenu: "closeImportMenu" }, ngImport: i0, template: "<ng-container [ngSwitch]=\"sectionDisplayed\">\n <ng-container *ngSwitchCase=\"'mainMenu'\">\n <div\n data-test=\"importMenuMainSection\"\n class=\"mt-2 border border-gray-100 p-2 flex items-center bg-white shadow-2xl rounded-2xl\"\n >\n <ul class=\"flex flex-col gap-2 w-full\">\n <li *ngFor=\"let menuItem of importMenuItems\">\n <gn-ui-button\n [attr.data-test]=\"menuItem.dataTest\"\n type=\"light\"\n extraClass=\"flex flex-row items-center gap-2 w-full justify-start\"\n (buttonClick)=\"menuItem.action()\"\n [disabled]=\"menuItem.disabled\"\n [title]=\"\n (menuItem.disabled ? 'editor.temporary.disabled' : '') | translate\n \"\n ><mat-icon class=\"material-symbols-outlined\">\n {{ menuItem.icon }} </mat-icon\n ><span>{{ menuItem.label }}</span></gn-ui-button\n >\n </li>\n </ul>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'importExternalFile'\">\n <div\n data-test=\"importMenuImportExternalFileSection\"\n class=\"p-6 flex flex-col gap-2 mt-2 border border-gray-100 bg-white shadow-2xl rounded-2xl\"\n >\n <div class=\"flex flex-row items-center gap-2\">\n <gn-ui-button\n data-test=\"importMenuImportExternalFileSectionBackButton\"\n type=\"light\"\n (buttonClick)=\"displayMainMenu()\"\n >\n <mat-icon class=\"material-symbols-outlined\">arrow_back</mat-icon>\n </gn-ui-button>\n <span class=\"font-bold\"> {{ externalImportBackLabel }}</span>\n </div>\n <gn-ui-url-input\n (valueChange)=\"importRecord($event)\"\n [disabled]=\"isRecordImportInProgress\"\n ></gn-ui-url-input>\n </div>\n </ng-container>\n</ng-container>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i5.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: ButtonComponent, selector: "gn-ui-button", inputs: ["type", "disabled", "extraClass"], outputs: ["buttonClick"] }, { kind: "component", type: UrlInputComponent, selector: "gn-ui-url-input", inputs: ["value", "extraClass", "placeholder", "disabled"], outputs: ["valueChange"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
80
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ImportRecordComponent, isStandalone: true, selector: "gn-ui-import-record", outputs: { closeImportMenu: "closeImportMenu" }, ngImport: i0, template: "<ng-container [ngSwitch]=\"sectionDisplayed\">\n <ng-container *ngSwitchCase=\"'mainMenu'\">\n <div\n data-test=\"importMenuMainSection\"\n class=\"mt-2 border border-gray-100 p-2 flex items-center bg-white shadow-2xl rounded-2xl\"\n >\n <ul class=\"flex flex-col gap-2 w-full\">\n <li *ngFor=\"let menuItem of importMenuItems\">\n <gn-ui-button\n [attr.data-test]=\"menuItem.dataTest\"\n type=\"light\"\n extraClass=\"flex flex-row items-center gap-2 w-full justify-start\"\n (buttonClick)=\"menuItem.action()\"\n [disabled]=\"menuItem.disabled\"\n [title]=\"\n (menuItem.disabled ? 'editor.temporary.disabled' : '') | translate\n \"\n ><mat-icon class=\"material-symbols-outlined\">\n {{ menuItem.icon }} </mat-icon\n ><span>{{ menuItem.label }}</span></gn-ui-button\n >\n </li>\n </ul>\n </div>\n </ng-container>\n <ng-container *ngSwitchCase=\"'importExternalFile'\">\n <div\n data-test=\"importMenuImportExternalFileSection\"\n class=\"p-6 flex flex-col gap-2 mt-2 border border-gray-100 bg-white shadow-2xl rounded-2xl\"\n >\n <div class=\"flex flex-row items-center gap-2\">\n <gn-ui-button\n data-test=\"importMenuImportExternalFileSectionBackButton\"\n type=\"light\"\n (buttonClick)=\"displayMainMenu()\"\n >\n <mat-icon class=\"material-symbols-outlined\">arrow_back</mat-icon>\n </gn-ui-button>\n <span class=\"font-bold\"> {{ externalImportBackLabel }}</span>\n </div>\n <gn-ui-url-input\n (valueChange)=\"importRecord($event)\"\n [disabled]=\"isRecordImportInProgress\"\n ></gn-ui-url-input>\n </div>\n </ng-container>\n</ng-container>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i5.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i5.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i6.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: ButtonComponent, selector: "gn-ui-button", inputs: ["type", "disabled", "extraClass"], outputs: ["buttonClick"] }, { kind: "component", type: UrlInputComponent, selector: "gn-ui-url-input", inputs: ["value", "extraClass", "placeholder", "disabled", "urlCanParse"], outputs: ["valueChange"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
81
81
|
}
|
|
82
82
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ImportRecordComponent, decorators: [{
|
|
83
83
|
type: Component,
|
|
@@ -92,4 +92,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
92
92
|
}], ctorParameters: function () { return [{ type: i1.Router }, { type: i2.TranslateService }, { type: i0.ChangeDetectorRef }, { type: i3.NotificationsService }, { type: i4.RecordsRepositoryInterface }]; }, propDecorators: { closeImportMenu: [{
|
|
93
93
|
type: Output
|
|
94
94
|
}] } });
|
|
95
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"import-record.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/feature/editor/src/lib/components/import-record/import-record.component.ts","../../../../../../../../../libs/feature/editor/src/lib/components/import-record/import-record.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Output,\n} from '@angular/core'\nimport { MatIconModule } from '@angular/material/icon'\nimport { CommonModule } from '@angular/common'\nimport { ButtonComponent, UrlInputComponent } from '../../../../../../../libs/ui/inputs/src'\nimport { ThumbnailComponent } from '../../../../../../../libs/ui/elements/src'\nimport { TranslateModule, TranslateService } from '@ngx-translate/core'\nimport { NotificationsService } from '../../../../../../../libs/feature/notifications/src'\nimport { RecordsRepositoryInterface } from '../../../../../../../libs/common/domain/src/lib/repository/records-repository.interface'\nimport { Router } from '@angular/router'\n\ninterface ImportMenuItems {\n  label: string\n  icon: string\n  action: () => any\n  dataTest: string\n  disabled?: boolean\n}\n\ntype ImportMenuPage = 'mainMenu' | 'importExternalFile'\n\n@Component({\n  selector: 'gn-ui-import-record',\n  templateUrl: './import-record.component.html',\n  styleUrls: ['./import-record.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    MatIconModule,\n    ButtonComponent,\n    ThumbnailComponent,\n    UrlInputComponent,\n    TranslateModule,\n  ],\n})\nexport class ImportRecordComponent {\n  @Output() closeImportMenu = new EventEmitter<void>()\n\n  importMenuItems: ImportMenuItems[] = [\n    {\n      label: this.translateService.instant('dashboard.importRecord.useModel'),\n      icon: 'highlight',\n      action: () => null,\n      dataTest: 'useAModelButton',\n      disabled: true,\n    },\n    {\n      label: this.translateService.instant(\n        'dashboard.importRecord.importExternal'\n      ),\n      icon: 'cloud_download',\n      action: this.displayImportExternal.bind(this),\n      dataTest: 'importFromUrlButton',\n    },\n  ]\n\n  isRecordImportInProgress = false\n\n  sectionDisplayed: ImportMenuPage = 'mainMenu'\n\n  externalImportBackLabel = this.translateService.instant(\n    'dashboard.importRecord.importExternalLabel'\n  )\n\n  constructor(\n    private router: Router,\n    private translateService: TranslateService,\n    private cdr: ChangeDetectorRef,\n    private notificationsService: NotificationsService,\n    private recordsRepository: RecordsRepositoryInterface\n  ) {}\n\n  displayMainMenu() {\n    this.sectionDisplayed = 'mainMenu'\n    this.cdr.markForCheck()\n  }\n\n  displayImportExternal() {\n    this.sectionDisplayed = 'importExternalFile'\n    this.cdr.markForCheck()\n  }\n\n  importRecord(url: string) {\n    this.isRecordImportInProgress = true\n\n    this.recordsRepository.duplicateExternalRecord(url).subscribe({\n      next: (recordTempId) => {\n        if (recordTempId) {\n          this.notificationsService.showNotification(\n            {\n              type: 'success',\n              title: this.translateService.instant(\n                'editor.record.importFromExternalFile.success.title'\n              ),\n              text: `${this.translateService.instant(\n                'editor.record.importFromExternalFile.success.body'\n              )}`,\n            },\n            2500\n          )\n\n          this.router\n            .navigate(['/edit', recordTempId])\n            .catch((err) => console.error(err))\n        }\n        this.closeImportMenu.next()\n      },\n      error: (error) => {\n        this.notificationsService.showNotification(\n          {\n            type: 'error',\n            title: this.translateService.instant(\n              'editor.record.importFromExternalFile.failure.title'\n            ),\n            text: `${this.translateService.instant(\n              'editor.record.importFromExternalFile.failure.body'\n            )} ${error.message ?? ''}`,\n          },\n          2500\n        )\n        this.isRecordImportInProgress = false\n        this.cdr.markForCheck()\n      },\n    })\n  }\n}\n","<ng-container [ngSwitch]=\"sectionDisplayed\">\n  <ng-container *ngSwitchCase=\"'mainMenu'\">\n    <div\n      data-test=\"importMenuMainSection\"\n      class=\"mt-2 border border-gray-100 p-2 flex items-center bg-white shadow-2xl rounded-2xl\"\n    >\n      <ul class=\"flex flex-col gap-2 w-full\">\n        <li *ngFor=\"let menuItem of importMenuItems\">\n          <gn-ui-button\n            [attr.data-test]=\"menuItem.dataTest\"\n            type=\"light\"\n            extraClass=\"flex flex-row items-center gap-2 w-full justify-start\"\n            (buttonClick)=\"menuItem.action()\"\n            [disabled]=\"menuItem.disabled\"\n            [title]=\"\n              (menuItem.disabled ? 'editor.temporary.disabled' : '') | translate\n            \"\n            ><mat-icon class=\"material-symbols-outlined\">\n              {{ menuItem.icon }} </mat-icon\n            ><span>{{ menuItem.label }}</span></gn-ui-button\n          >\n        </li>\n      </ul>\n    </div>\n  </ng-container>\n  <ng-container *ngSwitchCase=\"'importExternalFile'\">\n    <div\n      data-test=\"importMenuImportExternalFileSection\"\n      class=\"p-6 flex flex-col gap-2 mt-2 border border-gray-100 bg-white shadow-2xl rounded-2xl\"\n    >\n      <div class=\"flex flex-row items-center gap-2\">\n        <gn-ui-button\n          data-test=\"importMenuImportExternalFileSectionBackButton\"\n          type=\"light\"\n          (buttonClick)=\"displayMainMenu()\"\n        >\n          <mat-icon class=\"material-symbols-outlined\">arrow_back</mat-icon>\n        </gn-ui-button>\n        <span class=\"font-bold\"> {{ externalImportBackLabel }}</span>\n      </div>\n      <gn-ui-url-input\n        (valueChange)=\"importRecord($event)\"\n        [disabled]=\"isRecordImportInProgress\"\n      ></gn-ui-url-input>\n    </div>\n  </ng-container>\n</ng-container>\n"]}
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"import-record.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/feature/editor/src/lib/components/import-record/import-record.component.ts","../../../../../../../../../libs/feature/editor/src/lib/components/import-record/import-record.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Output,\n} from '@angular/core'\nimport { MatIconModule } from '@angular/material/icon'\nimport { CommonModule } from '@angular/common'\nimport { ButtonComponent, UrlInputComponent } from '../../../../../../../libs/ui/inputs/src'\nimport { ThumbnailComponent } from '../../../../../../../libs/ui/elements/src'\nimport { TranslateModule, TranslateService } from '@ngx-translate/core'\nimport { NotificationsService } from '../../../../../../../libs/feature/notifications/src'\nimport { RecordsRepositoryInterface } from '../../../../../../../libs/common/domain/src/lib/repository/records-repository.interface'\nimport { Router } from '@angular/router'\n\ninterface ImportMenuItems {\n  label: string\n  icon: string\n  action: () => any\n  dataTest: string\n  disabled?: boolean\n}\n\ntype ImportMenuPage = 'mainMenu' | 'importExternalFile'\n\n@Component({\n  selector: 'gn-ui-import-record',\n  templateUrl: './import-record.component.html',\n  styleUrls: ['./import-record.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    MatIconModule,\n    ButtonComponent,\n    ThumbnailComponent,\n    UrlInputComponent,\n    TranslateModule,\n  ],\n})\nexport class ImportRecordComponent {\n  @Output() closeImportMenu = new EventEmitter<void>()\n\n  importMenuItems: ImportMenuItems[] = [\n    {\n      label: this.translateService.instant('dashboard.importRecord.useModel'),\n      icon: 'highlight',\n      action: () => null,\n      dataTest: 'useAModelButton',\n      disabled: true,\n    },\n    {\n      label: this.translateService.instant(\n        'dashboard.importRecord.importExternal'\n      ),\n      icon: 'cloud_download',\n      action: this.displayImportExternal.bind(this),\n      dataTest: 'importFromUrlButton',\n    },\n  ]\n\n  isRecordImportInProgress = false\n\n  sectionDisplayed: ImportMenuPage = 'mainMenu'\n\n  externalImportBackLabel = this.translateService.instant(\n    'dashboard.importRecord.importExternalLabel'\n  )\n\n  constructor(\n    private router: Router,\n    private translateService: TranslateService,\n    private cdr: ChangeDetectorRef,\n    private notificationsService: NotificationsService,\n    private recordsRepository: RecordsRepositoryInterface\n  ) {}\n\n  displayMainMenu() {\n    this.sectionDisplayed = 'mainMenu'\n    this.cdr.markForCheck()\n  }\n\n  displayImportExternal() {\n    this.sectionDisplayed = 'importExternalFile'\n    this.cdr.markForCheck()\n  }\n\n  importRecord(url: string) {\n    this.isRecordImportInProgress = true\n\n    this.recordsRepository.duplicateExternalRecord(url).subscribe({\n      next: (recordTempId) => {\n        if (recordTempId) {\n          this.notificationsService.showNotification(\n            {\n              type: 'success',\n              title: this.translateService.instant(\n                'editor.record.importFromExternalFile.success.title'\n              ),\n              text: `${this.translateService.instant(\n                'editor.record.importFromExternalFile.success.body'\n              )}`,\n            },\n            2500\n          )\n\n          this.router\n            .navigate(['/edit', recordTempId])\n            .catch((err) => console.error(err))\n        }\n        this.closeImportMenu.next()\n      },\n      error: (error) => {\n        this.notificationsService.showNotification(\n          {\n            type: 'error',\n            title: this.translateService.instant(\n              'editor.record.importFromExternalFile.failure.title'\n            ),\n            text: `${this.translateService.instant(\n              'editor.record.importFromExternalFile.failure.body'\n            )} ${error.message ?? ''}`,\n          },\n          2500\n        )\n        this.isRecordImportInProgress = false\n        this.cdr.markForCheck()\n      },\n    })\n  }\n}\n","<ng-container [ngSwitch]=\"sectionDisplayed\">\n  <ng-container *ngSwitchCase=\"'mainMenu'\">\n    <div\n      data-test=\"importMenuMainSection\"\n      class=\"mt-2 border border-gray-100 p-2 flex items-center bg-white shadow-2xl rounded-2xl\"\n    >\n      <ul class=\"flex flex-col gap-2 w-full\">\n        <li *ngFor=\"let menuItem of importMenuItems\">\n          <gn-ui-button\n            [attr.data-test]=\"menuItem.dataTest\"\n            type=\"light\"\n            extraClass=\"flex flex-row items-center gap-2 w-full justify-start\"\n            (buttonClick)=\"menuItem.action()\"\n            [disabled]=\"menuItem.disabled\"\n            [title]=\"\n              (menuItem.disabled ? 'editor.temporary.disabled' : '') | translate\n            \"\n            ><mat-icon class=\"material-symbols-outlined\">\n              {{ menuItem.icon }} </mat-icon\n            ><span>{{ menuItem.label }}</span></gn-ui-button\n          >\n        </li>\n      </ul>\n    </div>\n  </ng-container>\n  <ng-container *ngSwitchCase=\"'importExternalFile'\">\n    <div\n      data-test=\"importMenuImportExternalFileSection\"\n      class=\"p-6 flex flex-col gap-2 mt-2 border border-gray-100 bg-white shadow-2xl rounded-2xl\"\n    >\n      <div class=\"flex flex-row items-center gap-2\">\n        <gn-ui-button\n          data-test=\"importMenuImportExternalFileSectionBackButton\"\n          type=\"light\"\n          (buttonClick)=\"displayMainMenu()\"\n        >\n          <mat-icon class=\"material-symbols-outlined\">arrow_back</mat-icon>\n        </gn-ui-button>\n        <span class=\"font-bold\"> {{ externalImportBackLabel }}</span>\n      </div>\n      <gn-ui-url-input\n        (valueChange)=\"importRecord($event)\"\n        [disabled]=\"isRecordImportInProgress\"\n      ></gn-ui-url-input>\n    </div>\n  </ng-container>\n</ng-container>\n"]}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, Input, } from '@angular/core';
|
|
3
|
+
import { FormsModule } from '@angular/forms';
|
|
4
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
5
|
+
import { MatRadioModule } from '@angular/material/radio';
|
|
6
|
+
import { MatTooltipModule } from '@angular/material/tooltip';
|
|
7
|
+
import { marker } from '@biesbjerg/ngx-translate-extract-marker';
|
|
8
|
+
import { TextInputComponent } from '../../../../../../../libs/ui/inputs/src';
|
|
9
|
+
import { TranslateModule } from '@ngx-translate/core';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "@angular/common";
|
|
12
|
+
import * as i2 from "@angular/material/tooltip";
|
|
13
|
+
import * as i3 from "@angular/material/radio";
|
|
14
|
+
import * as i4 from "@angular/forms";
|
|
15
|
+
import * as i5 from "@ngx-translate/core";
|
|
16
|
+
export class OnlineServiceResourceInputComponent {
|
|
17
|
+
constructor() {
|
|
18
|
+
this.protocolOptions = [
|
|
19
|
+
{
|
|
20
|
+
label: 'OGC API',
|
|
21
|
+
value: 'ogcFeatures',
|
|
22
|
+
},
|
|
23
|
+
{
|
|
24
|
+
label: 'WFS',
|
|
25
|
+
value: 'wfs',
|
|
26
|
+
},
|
|
27
|
+
{
|
|
28
|
+
label: 'WMS',
|
|
29
|
+
value: 'wms',
|
|
30
|
+
},
|
|
31
|
+
{
|
|
32
|
+
label: 'WMTS',
|
|
33
|
+
value: 'wmts',
|
|
34
|
+
},
|
|
35
|
+
{
|
|
36
|
+
label: 'WPS',
|
|
37
|
+
value: 'wps',
|
|
38
|
+
},
|
|
39
|
+
{
|
|
40
|
+
label: 'ESRI REST',
|
|
41
|
+
value: 'esriRest',
|
|
42
|
+
},
|
|
43
|
+
{
|
|
44
|
+
label: marker('editor.record.onlineResource.protocol.other'),
|
|
45
|
+
value: 'other',
|
|
46
|
+
},
|
|
47
|
+
];
|
|
48
|
+
}
|
|
49
|
+
ngOnChanges() {
|
|
50
|
+
this.selectedProtocol =
|
|
51
|
+
this.protocolOptions.find((option) => option.value === this.service.accessServiceProtocol)?.value ?? 'other';
|
|
52
|
+
}
|
|
53
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: OnlineServiceResourceInputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
54
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: OnlineServiceResourceInputComponent, isStandalone: true, selector: "gn-ui-online-service-resource-input", inputs: { service: "service", protocolHint: "protocolHint" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"flex flex-row justify-between\">\n <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n editor.record.form.field.onlineResource.edit.protocol\n </h3>\n <span\n *ngIf=\"protocolHint\"\n class=\"material-symbols-outlined m-2 gn-ui-icon-small\"\n [matTooltip]=\"protocolHint\"\n matTooltipPosition=\"above\"\n >\n help\n </span>\n</div>\n<div class=\"flex flex-row items-center gap-[16px] h-[48px]\">\n <mat-radio-group\n aria-labelledby=\"example-radio-group-label\"\n class=\"flex flex-row gap-[8px]\"\n [(ngModel)]=\"service.accessServiceProtocol\"\n >\n <mat-radio-button\n *ngFor=\"let protocolOption of protocolOptions\"\n [value]=\"protocolOption.value\"\n >\n {{ protocolOption.label | translate }}\n </mat-radio-button>\n </mat-radio-group>\n</div>\n<gn-ui-text-input\n [(value)]=\"service.identifierInService\"\n data-cy=\"identifier-in-service\"\n></gn-ui-text-input>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "ngmodule", type: MatTooltipModule }, { kind: "directive", type: i2.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "ngmodule", type: MatRadioModule }, { kind: "directive", type: i3.MatRadioGroup, selector: "mat-radio-group", exportAs: ["matRadioGroup"] }, { kind: "component", type: i3.MatRadioButton, selector: "mat-radio-button", inputs: ["disableRipple", "tabIndex"], exportAs: ["matRadioButton"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: TextInputComponent, selector: "gn-ui-text-input", inputs: ["value", "extraClass", "placeholder", "required", "disabled"], outputs: ["valueChange"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }, { kind: "directive", type: i5.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
55
|
+
}
|
|
56
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: OnlineServiceResourceInputComponent, decorators: [{
|
|
57
|
+
type: Component,
|
|
58
|
+
args: [{ selector: 'gn-ui-online-service-resource-input', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
|
|
59
|
+
CommonModule,
|
|
60
|
+
MatIconModule,
|
|
61
|
+
MatTooltipModule,
|
|
62
|
+
MatRadioModule,
|
|
63
|
+
FormsModule,
|
|
64
|
+
TextInputComponent,
|
|
65
|
+
TranslateModule,
|
|
66
|
+
], template: "<div class=\"flex flex-row justify-between\">\n <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n editor.record.form.field.onlineResource.edit.protocol\n </h3>\n <span\n *ngIf=\"protocolHint\"\n class=\"material-symbols-outlined m-2 gn-ui-icon-small\"\n [matTooltip]=\"protocolHint\"\n matTooltipPosition=\"above\"\n >\n help\n </span>\n</div>\n<div class=\"flex flex-row items-center gap-[16px] h-[48px]\">\n <mat-radio-group\n aria-labelledby=\"example-radio-group-label\"\n class=\"flex flex-row gap-[8px]\"\n [(ngModel)]=\"service.accessServiceProtocol\"\n >\n <mat-radio-button\n *ngFor=\"let protocolOption of protocolOptions\"\n [value]=\"protocolOption.value\"\n >\n {{ protocolOption.label | translate }}\n </mat-radio-button>\n </mat-radio-group>\n</div>\n<gn-ui-text-input\n [(value)]=\"service.identifierInService\"\n data-cy=\"identifier-in-service\"\n></gn-ui-text-input>\n" }]
|
|
67
|
+
}], propDecorators: { service: [{
|
|
68
|
+
type: Input
|
|
69
|
+
}], protocolHint: [{
|
|
70
|
+
type: Input
|
|
71
|
+
}] } });
|
|
72
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib25saW5lLXNlcnZpY2UtcmVzb3VyY2UtaW5wdXQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9mZWF0dXJlL2VkaXRvci9zcmMvbGliL2NvbXBvbmVudHMvb25saW5lLXNlcnZpY2UtcmVzb3VyY2UtaW5wdXQvb25saW5lLXNlcnZpY2UtcmVzb3VyY2UtaW5wdXQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9mZWF0dXJlL2VkaXRvci9zcmMvbGliL2NvbXBvbmVudHMvb25saW5lLXNlcnZpY2UtcmVzb3VyY2UtaW5wdXQvb25saW5lLXNlcnZpY2UtcmVzb3VyY2UtaW5wdXQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFBO0FBQzlDLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULEtBQUssR0FFTixNQUFNLGVBQWUsQ0FBQTtBQUN0QixPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUE7QUFDNUMsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFBO0FBQ3RELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQTtBQUN4RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQTtBQUM1RCxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0seUNBQXlDLENBQUE7QUFLaEUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0seUNBQXlDLENBQUE7QUFDNUUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFBOzs7Ozs7O0FBa0JyRCxNQUFNLE9BQU8sbUNBQW1DO0lBaEJoRDtRQXNCRSxvQkFBZSxHQUdUO1lBQ0o7Z0JBQ0UsS0FBSyxFQUFFLFNBQVM7Z0JBQ2hCLEtBQUssRUFBRSxhQUFhO2FBQ3JCO1lBQ0Q7Z0JBQ0UsS0FBSyxFQUFFLEtBQUs7Z0JBQ1osS0FBSyxFQUFFLEtBQUs7YUFDYjtZQUNEO2dCQUNFLEtBQUssRUFBRSxLQUFLO2dCQUNaLEtBQUssRUFBRSxLQUFLO2FBQ2I7WUFDRDtnQkFDRSxLQUFLLEVBQUUsTUFBTTtnQkFDYixLQUFLLEVBQUUsTUFBTTthQUNkO1lBQ0Q7Z0JBQ0UsS0FBSyxFQUFFLEtBQUs7Z0JBQ1osS0FBSyxFQUFFLEtBQUs7YUFDYjtZQUNEO2dCQUNFLEtBQUssRUFBRSxXQUFXO2dCQUNsQixLQUFLLEVBQUUsVUFBVTthQUNsQjtZQUNEO2dCQUNFLEtBQUssRUFBRSxNQUFNLENBQUMsNkNBQTZDLENBQUM7Z0JBQzVELEtBQUssRUFBRSxPQUFPO2FBQ2Y7U0FDRixDQUFBO0tBUUY7SUFOQyxXQUFXO1FBQ1QsSUFBSSxDQUFDLGdCQUFnQjtZQUNuQixJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FDdkIsQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLE1BQU0sQ0FBQyxLQUFLLEtBQUssSUFBSSxDQUFDLE9BQU8sQ0FBQyxxQkFBcUIsQ0FDaEUsRUFBRSxLQUFLLElBQUksT0FBTyxDQUFBO0lBQ3ZCLENBQUM7K0dBN0NVLG1DQUFtQzttR0FBbkMsbUNBQW1DLGtMQ25DaEQseThCQStCQSx5RERMSSxZQUFZLCtQQUNaLGFBQWEsOEJBQ2IsZ0JBQWdCLDhIQUNoQixjQUFjLDBSQUNkLFdBQVcsK1ZBQ1gsa0JBQWtCLDhKQUNsQixlQUFlOzs0RkFHTixtQ0FBbUM7a0JBaEIvQyxTQUFTOytCQUNFLHFDQUFxQyxtQkFHOUIsdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxJQUFJLFdBQ1A7d0JBQ1AsWUFBWTt3QkFDWixhQUFhO3dCQUNiLGdCQUFnQjt3QkFDaEIsY0FBYzt3QkFDZCxXQUFXO3dCQUNYLGtCQUFrQjt3QkFDbEIsZUFBZTtxQkFDaEI7OEJBR1EsT0FBTztzQkFBZixLQUFLO2dCQUNHLFlBQVk7c0JBQXBCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nXG5pbXBvcnQge1xuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcbiAgQ29tcG9uZW50LFxuICBJbnB1dCxcbiAgT25DaGFuZ2VzLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3JtcydcbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJ1xuaW1wb3J0IHsgTWF0UmFkaW9Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9yYWRpbydcbmltcG9ydCB7IE1hdFRvb2x0aXBNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC90b29sdGlwJ1xuaW1wb3J0IHsgbWFya2VyIH0gZnJvbSAnQGJpZXNiamVyZy9uZ3gtdHJhbnNsYXRlLWV4dHJhY3QtbWFya2VyJ1xuaW1wb3J0IHtcbiAgRGF0YXNldFNlcnZpY2VEaXN0cmlidXRpb24sXG4gIFNlcnZpY2VQcm90b2NvbCxcbn0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jb21tb24vZG9tYWluL3NyYy9saWIvbW9kZWwvcmVjb3JkJ1xuaW1wb3J0IHsgVGV4dElucHV0Q29tcG9uZW50IH0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91aS9pbnB1dHMvc3JjJ1xuaW1wb3J0IHsgVHJhbnNsYXRlTW9kdWxlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSdcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZ24tdWktb25saW5lLXNlcnZpY2UtcmVzb3VyY2UtaW5wdXQnLFxuICB0ZW1wbGF0ZVVybDogJy4vb25saW5lLXNlcnZpY2UtcmVzb3VyY2UtaW5wdXQuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9vbmxpbmUtc2VydmljZS1yZXNvdXJjZS1pbnB1dC5jb21wb25lbnQuY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIE1hdEljb25Nb2R1bGUsXG4gICAgTWF0VG9vbHRpcE1vZHVsZSxcbiAgICBNYXRSYWRpb01vZHVsZSxcbiAgICBGb3Jtc01vZHVsZSxcbiAgICBUZXh0SW5wdXRDb21wb25lbnQsXG4gICAgVHJhbnNsYXRlTW9kdWxlLFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBPbmxpbmVTZXJ2aWNlUmVzb3VyY2VJbnB1dENvbXBvbmVudCBpbXBsZW1lbnRzIE9uQ2hhbmdlcyB7XG4gIEBJbnB1dCgpIHNlcnZpY2U6IE9taXQ8RGF0YXNldFNlcnZpY2VEaXN0cmlidXRpb24sICd1cmwnPlxuICBASW5wdXQoKSBwcm90b2NvbEhpbnQ/OiBzdHJpbmdcblxuICBzZWxlY3RlZFByb3RvY29sOiBTZXJ2aWNlUHJvdG9jb2xcblxuICBwcm90b2NvbE9wdGlvbnM6IHtcbiAgICBsYWJlbDogc3RyaW5nXG4gICAgdmFsdWU6IFNlcnZpY2VQcm90b2NvbFxuICB9W10gPSBbXG4gICAge1xuICAgICAgbGFiZWw6ICdPR0MgQVBJJyxcbiAgICAgIHZhbHVlOiAnb2djRmVhdHVyZXMnLFxuICAgIH0sXG4gICAge1xuICAgICAgbGFiZWw6ICdXRlMnLFxuICAgICAgdmFsdWU6ICd3ZnMnLFxuICAgIH0sXG4gICAge1xuICAgICAgbGFiZWw6ICdXTVMnLFxuICAgICAgdmFsdWU6ICd3bXMnLFxuICAgIH0sXG4gICAge1xuICAgICAgbGFiZWw6ICdXTVRTJyxcbiAgICAgIHZhbHVlOiAnd210cycsXG4gICAgfSxcbiAgICB7XG4gICAgICBsYWJlbDogJ1dQUycsXG4gICAgICB2YWx1ZTogJ3dwcycsXG4gICAgfSxcbiAgICB7XG4gICAgICBsYWJlbDogJ0VTUkkgUkVTVCcsXG4gICAgICB2YWx1ZTogJ2VzcmlSZXN0JyxcbiAgICB9LFxuICAgIHtcbiAgICAgIGxhYmVsOiBtYXJrZXIoJ2VkaXRvci5yZWNvcmQub25saW5lUmVzb3VyY2UucHJvdG9jb2wub3RoZXInKSxcbiAgICAgIHZhbHVlOiAnb3RoZXInLFxuICAgIH0sXG4gIF1cblxuICBuZ09uQ2hhbmdlcygpIHtcbiAgICB0aGlzLnNlbGVjdGVkUHJvdG9jb2wgPVxuICAgICAgdGhpcy5wcm90b2NvbE9wdGlvbnMuZmluZChcbiAgICAgICAgKG9wdGlvbikgPT4gb3B0aW9uLnZhbHVlID09PSB0aGlzLnNlcnZpY2UuYWNjZXNzU2VydmljZVByb3RvY29sXG4gICAgICApPy52YWx1ZSA/PyAnb3RoZXInXG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJmbGV4IGZsZXgtcm93IGp1c3RpZnktYmV0d2VlblwiPlxuICA8aDMgY2xhc3M9XCJ0ZXh0LVsxNnB4XSBmb250LWJvbGQgdGV4dC1tYWluIG1iLVsxMnB4XVwiIHRyYW5zbGF0ZT5cbiAgICBlZGl0b3IucmVjb3JkLmZvcm0uZmllbGQub25saW5lUmVzb3VyY2UuZWRpdC5wcm90b2NvbFxuICA8L2gzPlxuICA8c3BhblxuICAgICpuZ0lmPVwicHJvdG9jb2xIaW50XCJcbiAgICBjbGFzcz1cIm1hdGVyaWFsLXN5bWJvbHMtb3V0bGluZWQgbS0yIGduLXVpLWljb24tc21hbGxcIlxuICAgIFttYXRUb29sdGlwXT1cInByb3RvY29sSGludFwiXG4gICAgbWF0VG9vbHRpcFBvc2l0aW9uPVwiYWJvdmVcIlxuICA+XG4gICAgaGVscFxuICA8L3NwYW4+XG48L2Rpdj5cbjxkaXYgY2xhc3M9XCJmbGV4IGZsZXgtcm93IGl0ZW1zLWNlbnRlciBnYXAtWzE2cHhdIGgtWzQ4cHhdXCI+XG4gIDxtYXQtcmFkaW8tZ3JvdXBcbiAgICBhcmlhLWxhYmVsbGVkYnk9XCJleGFtcGxlLXJhZGlvLWdyb3VwLWxhYmVsXCJcbiAgICBjbGFzcz1cImZsZXggZmxleC1yb3cgZ2FwLVs4cHhdXCJcbiAgICBbKG5nTW9kZWwpXT1cInNlcnZpY2UuYWNjZXNzU2VydmljZVByb3RvY29sXCJcbiAgPlxuICAgIDxtYXQtcmFkaW8tYnV0dG9uXG4gICAgICAqbmdGb3I9XCJsZXQgcHJvdG9jb2xPcHRpb24gb2YgcHJvdG9jb2xPcHRpb25zXCJcbiAgICAgIFt2YWx1ZV09XCJwcm90b2NvbE9wdGlvbi52YWx1ZVwiXG4gICAgPlxuICAgICAge3sgcHJvdG9jb2xPcHRpb24ubGFiZWwgfCB0cmFuc2xhdGUgfX1cbiAgICA8L21hdC1yYWRpby1idXR0b24+XG4gIDwvbWF0LXJhZGlvLWdyb3VwPlxuPC9kaXY+XG48Z24tdWktdGV4dC1pbnB1dFxuICBbKHZhbHVlKV09XCJzZXJ2aWNlLmlkZW50aWZpZXJJblNlcnZpY2VcIlxuICBkYXRhLWN5PVwiaWRlbnRpZmllci1pbi1zZXJ2aWNlXCJcbj48L2duLXVpLXRleHQtaW5wdXQ+XG4iXX0=
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, Output, TemplateRef, ViewChild, } from '@angular/core';
|
|
2
|
-
import { FileInputComponent, TextAreaComponent, TextInputComponent, } from '../../../../../../../../../libs/ui/inputs/src';
|
|
2
|
+
import { FileInputComponent, TextAreaComponent, TextInputComponent, UrlInputComponent, } from '../../../../../../../../../libs/ui/inputs/src';
|
|
3
3
|
import { CommonModule } from '@angular/common';
|
|
4
4
|
import { OnlineResourceCardComponent } from '../../../online-resource-card/online-resource-card.component';
|
|
5
5
|
import { ModalDialogComponent, SortableListComponent, } from '../../../../../../../../../libs/ui/layout/src';
|
|
@@ -101,6 +101,7 @@ export class FormFieldOnlineLinkResourcesComponent {
|
|
|
101
101
|
};
|
|
102
102
|
this.dialog
|
|
103
103
|
.open(ModalDialogComponent, {
|
|
104
|
+
width: '800px',
|
|
104
105
|
data: {
|
|
105
106
|
title: this.translateService.instant('editor.record.form.field.onlineResource.dialogTitle'),
|
|
106
107
|
body: this.dialogTemplate,
|
|
@@ -122,7 +123,7 @@ export class FormFieldOnlineLinkResourcesComponent {
|
|
|
122
123
|
});
|
|
123
124
|
}
|
|
124
125
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FormFieldOnlineLinkResourcesComponent, deps: [{ token: i1.NotificationsService }, { token: i2.TranslateService }, { token: i3.PlatformServiceInterface }, { token: i0.ChangeDetectorRef }, { token: i4.MatDialog }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
125
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: FormFieldOnlineLinkResourcesComponent, isStandalone: true, selector: "gn-ui-form-field-online-link-resources", inputs: { metadataUuid: "metadataUuid", value: "value" }, outputs: { valueChange: "valueChange" }, viewQueries: [{ propertyName: "dialogTemplate", first: true, predicate: ["dialogTemplate"], descendants: true }], ngImport: i0, template: "<gn-ui-file-input\n [maxSizeMB]=\"MAX_UPLOAD_SIZE_MB\"\n (fileChange)=\"handleFileChange($event)\"\n (uploadCancel)=\"handleUploadCancel()\"\n [uploadProgress]=\"uploadProgress\"\n (urlChange)=\"handleUrlChange($event)\"\n></gn-ui-file-input>\n<div class=\"h-[8px]\"></div>\n<gn-ui-sortable-list\n [items]=\"linkResources\"\n (itemsOrderChange)=\"handleResourcesChange($event)\"\n [elementTemplate]=\"template\"\n>\n</gn-ui-sortable-list>\n<ng-template #template let-onlineResource let-index=\"index\">\n <gn-ui-online-resource-card\n [onlineResource]=\"onlineResource\"\n (modifyClick)=\"handleResourceModify(onlineResource, index)\"\n ></gn-ui-online-resource-card>\n</ng-template>\n\n<ng-template #dialogTemplate let-onlineResource>\n <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n
|
|
126
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: FormFieldOnlineLinkResourcesComponent, isStandalone: true, selector: "gn-ui-form-field-online-link-resources", inputs: { metadataUuid: "metadataUuid", value: "value" }, outputs: { valueChange: "valueChange" }, viewQueries: [{ propertyName: "dialogTemplate", first: true, predicate: ["dialogTemplate"], descendants: true }], ngImport: i0, template: "<gn-ui-file-input\n [maxSizeMB]=\"MAX_UPLOAD_SIZE_MB\"\n (fileChange)=\"handleFileChange($event)\"\n (uploadCancel)=\"handleUploadCancel()\"\n [uploadProgress]=\"uploadProgress\"\n (urlChange)=\"handleUrlChange($event)\"\n></gn-ui-file-input>\n<div class=\"h-[8px]\"></div>\n<gn-ui-sortable-list\n [items]=\"linkResources\"\n (itemsOrderChange)=\"handleResourcesChange($event)\"\n [elementTemplate]=\"template\"\n>\n</gn-ui-sortable-list>\n<ng-template #template let-onlineResource let-index=\"index\">\n <gn-ui-online-resource-card\n [onlineResource]=\"onlineResource\"\n (modifyClick)=\"handleResourceModify(onlineResource, index)\"\n ></gn-ui-online-resource-card>\n</ng-template>\n\n<ng-template #dialogTemplate let-onlineResource>\n <div class=\"flex flex-col gap-[16px]\">\n <div>\n <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n editor.record.form.field.onlineResource.edit.title\n </h3>\n <gn-ui-text-input [(value)]=\"onlineResource.name\"></gn-ui-text-input>\n </div>\n <div>\n <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n editor.record.form.field.onlineResource.edit.description\n </h3>\n <gn-ui-text-area [(value)]=\"onlineResource.description\"></gn-ui-text-area>\n </div>\n <span class=\"w-full border-b border-gray-300\"></span>\n <gn-ui-url-input\n class=\"w-full\"\n [disabled]=\"true\"\n [value]=\"onlineResource.url\"\n ></gn-ui-url-input>\n </div>\n</ng-template>\n", styles: [""], dependencies: [{ kind: "component", type: FileInputComponent, selector: "gn-ui-file-input", inputs: ["maxSizeMB", "uploadProgress"], outputs: ["fileChange", "urlChange", "uploadCancel"] }, { kind: "ngmodule", type: CommonModule }, { kind: "component", type: SortableListComponent, selector: "gn-ui-sortable-list", inputs: ["elementTemplate", "items"], outputs: ["itemsOrderChange"] }, { kind: "component", type: OnlineResourceCardComponent, selector: "gn-ui-online-resource-card", inputs: ["onlineResource"], outputs: ["modifyClick"] }, { kind: "component", type: TextInputComponent, selector: "gn-ui-text-input", inputs: ["value", "extraClass", "placeholder", "required", "disabled"], outputs: ["valueChange"] }, { kind: "component", type: TextAreaComponent, selector: "gn-ui-text-area", inputs: ["value", "disabled", "extraClass", "placeholder", "required"], outputs: ["valueChange"] }, { kind: "component", type: UrlInputComponent, selector: "gn-ui-url-input", inputs: ["value", "extraClass", "placeholder", "disabled", "urlCanParse"], outputs: ["valueChange"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "directive", type: i2.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
126
127
|
}
|
|
127
128
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FormFieldOnlineLinkResourcesComponent, decorators: [{
|
|
128
129
|
type: Component,
|
|
@@ -133,8 +134,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
133
134
|
OnlineResourceCardComponent,
|
|
134
135
|
TextInputComponent,
|
|
135
136
|
TextAreaComponent,
|
|
137
|
+
UrlInputComponent,
|
|
136
138
|
TranslateModule,
|
|
137
|
-
], template: "<gn-ui-file-input\n [maxSizeMB]=\"MAX_UPLOAD_SIZE_MB\"\n (fileChange)=\"handleFileChange($event)\"\n (uploadCancel)=\"handleUploadCancel()\"\n [uploadProgress]=\"uploadProgress\"\n (urlChange)=\"handleUrlChange($event)\"\n></gn-ui-file-input>\n<div class=\"h-[8px]\"></div>\n<gn-ui-sortable-list\n [items]=\"linkResources\"\n (itemsOrderChange)=\"handleResourcesChange($event)\"\n [elementTemplate]=\"template\"\n>\n</gn-ui-sortable-list>\n<ng-template #template let-onlineResource let-index=\"index\">\n <gn-ui-online-resource-card\n [onlineResource]=\"onlineResource\"\n (modifyClick)=\"handleResourceModify(onlineResource, index)\"\n ></gn-ui-online-resource-card>\n</ng-template>\n\n<ng-template #dialogTemplate let-onlineResource>\n <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n
|
|
139
|
+
], template: "<gn-ui-file-input\n [maxSizeMB]=\"MAX_UPLOAD_SIZE_MB\"\n (fileChange)=\"handleFileChange($event)\"\n (uploadCancel)=\"handleUploadCancel()\"\n [uploadProgress]=\"uploadProgress\"\n (urlChange)=\"handleUrlChange($event)\"\n></gn-ui-file-input>\n<div class=\"h-[8px]\"></div>\n<gn-ui-sortable-list\n [items]=\"linkResources\"\n (itemsOrderChange)=\"handleResourcesChange($event)\"\n [elementTemplate]=\"template\"\n>\n</gn-ui-sortable-list>\n<ng-template #template let-onlineResource let-index=\"index\">\n <gn-ui-online-resource-card\n [onlineResource]=\"onlineResource\"\n (modifyClick)=\"handleResourceModify(onlineResource, index)\"\n ></gn-ui-online-resource-card>\n</ng-template>\n\n<ng-template #dialogTemplate let-onlineResource>\n <div class=\"flex flex-col gap-[16px]\">\n <div>\n <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n editor.record.form.field.onlineResource.edit.title\n </h3>\n <gn-ui-text-input [(value)]=\"onlineResource.name\"></gn-ui-text-input>\n </div>\n <div>\n <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n editor.record.form.field.onlineResource.edit.description\n </h3>\n <gn-ui-text-area [(value)]=\"onlineResource.description\"></gn-ui-text-area>\n </div>\n <span class=\"w-full border-b border-gray-300\"></span>\n <gn-ui-url-input\n class=\"w-full\"\n [disabled]=\"true\"\n [value]=\"onlineResource.url\"\n ></gn-ui-url-input>\n </div>\n</ng-template>\n" }]
|
|
138
140
|
}], ctorParameters: function () { return [{ type: i1.NotificationsService }, { type: i2.TranslateService }, { type: i3.PlatformServiceInterface }, { type: i0.ChangeDetectorRef }, { type: i4.MatDialog }]; }, propDecorators: { metadataUuid: [{
|
|
139
141
|
type: Input
|
|
140
142
|
}], value: [{
|
|
@@ -145,4 +147,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
145
147
|
type: ViewChild,
|
|
146
148
|
args: ['dialogTemplate']
|
|
147
149
|
}] } });
|
|
148
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-field-online-link-resources.component.js","sourceRoot":"","sources":["../../../../../../../../../../../libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.ts","../../../../../../../../../../../libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core'\nimport {\n  OnlineLinkResource,\n  OnlineResource,\n} from '../../../../../../../../../libs/common/domain/src/lib/model/record'\nimport {\n  FileInputComponent,\n  TextAreaComponent,\n  TextInputComponent,\n} from '../../../../../../../../../libs/ui/inputs/src'\nimport { CommonModule } from '@angular/common'\nimport { OnlineResourceCardComponent } from '../../../online-resource-card/online-resource-card.component'\nimport {\n  ModalDialogComponent,\n  SortableListComponent,\n} from '../../../../../../../../../libs/ui/layout/src'\nimport { NotificationsService } from '../../../../../../../../../libs/feature/notifications/src'\nimport { TranslateModule, TranslateService } from '@ngx-translate/core'\nimport { PlatformServiceInterface } from '../../../../../../../../../libs/common/domain/src/lib/platform.service.interface'\nimport { Subscription } from 'rxjs'\nimport { MatDialog } from '@angular/material/dialog'\nimport { MAX_UPLOAD_SIZE_MB } from '../../../../fields.config'\n\n@Component({\n  selector: 'gn-ui-form-field-online-link-resources',\n  templateUrl: './form-field-online-link-resources.component.html',\n  styleUrls: ['./form-field-online-link-resources.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    FileInputComponent,\n    CommonModule,\n    SortableListComponent,\n    OnlineResourceCardComponent,\n    TextInputComponent,\n    TextAreaComponent,\n    TranslateModule,\n  ],\n})\nexport class FormFieldOnlineLinkResourcesComponent {\n  @Input() metadataUuid: string\n  @Input() set value(onlineResources: Array<OnlineResource>) {\n    this.allResources = onlineResources\n    this.linkResources = onlineResources.filter(\n      (res): res is OnlineLinkResource => res.type === 'link'\n    )\n  }\n  @Output() valueChange: EventEmitter<Array<OnlineResource>> =\n    new EventEmitter()\n\n  @ViewChild('dialogTemplate') dialogTemplate: TemplateRef<OnlineResource>\n\n  private allResources: OnlineResource[] = []\n  linkResources: OnlineLinkResource[] = []\n  uploadProgress = undefined\n  uploadSubscription: Subscription = null\n\n  protected MAX_UPLOAD_SIZE_MB = MAX_UPLOAD_SIZE_MB\n\n  constructor(\n    private notificationsService: NotificationsService,\n    private translateService: TranslateService,\n    private platformService: PlatformServiceInterface,\n    private cd: ChangeDetectorRef,\n    private dialog: MatDialog\n  ) {}\n\n  handleFileChange(file: File) {\n    this.uploadProgress = 0\n    this.uploadSubscription = this.platformService\n      .attachFileToRecord(this.metadataUuid, file)\n      .subscribe({\n        next: (event) => {\n          if (event.type === 'progress') {\n            this.uploadProgress = event.progress\n            this.cd.detectChanges()\n          } else if (event.type === 'success') {\n            this.uploadProgress = undefined\n            this.cd.detectChanges()\n            const newResource: OnlineLinkResource = {\n              type: 'link',\n              url: new URL(event.attachment.url),\n              name: event.attachment.fileName,\n            }\n            this.valueChange.emit([...this.allResources, newResource])\n          }\n        },\n        error: (error: Error) => this.handleError(error.message),\n      })\n  }\n\n  handleUploadCancel() {\n    if (this.uploadSubscription) {\n      this.uploadProgress = undefined\n      this.uploadSubscription.unsubscribe()\n    }\n  }\n\n  handleUrlChange(url: string) {\n    try {\n      const name = url.split('/').pop()\n      const newLink: OnlineLinkResource = {\n        type: 'link',\n        url: new URL(url),\n        name,\n      }\n      this.valueChange.emit([...this.allResources, newLink])\n    } catch (e) {\n      this.handleError((e as Error).message)\n    }\n  }\n\n  handleResourcesChange(items: unknown[]) {\n    const links = items as OnlineResource[]\n    const newResources = [\n      ...this.allResources.filter((r) => r.type !== 'link'),\n      ...links,\n    ]\n    this.valueChange.emit(newResources)\n  }\n\n  handleResourceModify(resource: OnlineLinkResource, index: number) {\n    this.openEditDialog(resource, index)\n  }\n\n  private handleError(error: string) {\n    this.uploadProgress = undefined\n    this.notificationsService.showNotification({\n      type: 'error',\n      title: this.translateService.instant(\n        'editor.record.onlineResourceError.title'\n      ),\n      text: `${this.translateService.instant(\n        'editor.record.onlineResourceError.body'\n      )} ${error}`,\n      closeMessage: this.translateService.instant(\n        'editor.record.onlineResourceError.closeMessage'\n      ),\n    })\n  }\n\n  private openEditDialog(resource: OnlineLinkResource, index: number) {\n    const resourceCopy = {\n      ...resource,\n    }\n    this.dialog\n      .open(ModalDialogComponent, {\n        data: {\n          title: this.translateService.instant(\n            'editor.record.form.field.onlineResource.dialogTitle'\n          ),\n          body: this.dialogTemplate,\n          bodyContext: resourceCopy,\n          confirmText: this.translateService.instant(\n            'editor.record.form.field.onlineResource.confirm'\n          ),\n          cancelText: this.translateService.instant(\n            'editor.record.form.field.onlineResource.cancel'\n          ),\n        },\n      })\n      .afterClosed()\n      .subscribe((confirmed: boolean) => {\n        if (!confirmed) return\n        const newLinks = [...this.linkResources]\n        newLinks.splice(index, 1, resourceCopy)\n        this.valueChange.emit([\n          ...this.allResources.filter((r) => r.type !== 'link'),\n          ...newLinks,\n        ])\n      })\n  }\n}\n","<gn-ui-file-input\n  [maxSizeMB]=\"MAX_UPLOAD_SIZE_MB\"\n  (fileChange)=\"handleFileChange($event)\"\n  (uploadCancel)=\"handleUploadCancel()\"\n  [uploadProgress]=\"uploadProgress\"\n  (urlChange)=\"handleUrlChange($event)\"\n></gn-ui-file-input>\n<div class=\"h-[8px]\"></div>\n<gn-ui-sortable-list\n  [items]=\"linkResources\"\n  (itemsOrderChange)=\"handleResourcesChange($event)\"\n  [elementTemplate]=\"template\"\n>\n</gn-ui-sortable-list>\n<ng-template #template let-onlineResource let-index=\"index\">\n  <gn-ui-online-resource-card\n    [onlineResource]=\"onlineResource\"\n    (modifyClick)=\"handleResourceModify(onlineResource, index)\"\n  ></gn-ui-online-resource-card>\n</ng-template>\n\n<ng-template #dialogTemplate let-onlineResource>\n  <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n    editor.record.form.field.onlineResource.edit.title\n  </h3>\n  <gn-ui-text-input\n    extraClass=\"mb-[16px]\"\n    [(value)]=\"onlineResource.name\"\n  ></gn-ui-text-input>\n  <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n    editor.record.form.field.onlineResource.edit.description\n  </h3>\n  <gn-ui-text-area [(value)]=\"onlineResource.description\"></gn-ui-text-area>\n</ng-template>\n"]}
|
|
150
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-field-online-link-resources.component.js","sourceRoot":"","sources":["../../../../../../../../../../../libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.ts","../../../../../../../../../../../libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-link-resources/form-field-online-link-resources.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core'\nimport {\n  OnlineLinkResource,\n  OnlineResource,\n} from '../../../../../../../../../libs/common/domain/src/lib/model/record'\nimport {\n  FileInputComponent,\n  TextAreaComponent,\n  TextInputComponent,\n  UrlInputComponent,\n} from '../../../../../../../../../libs/ui/inputs/src'\nimport { CommonModule } from '@angular/common'\nimport { OnlineResourceCardComponent } from '../../../online-resource-card/online-resource-card.component'\nimport {\n  ModalDialogComponent,\n  SortableListComponent,\n} from '../../../../../../../../../libs/ui/layout/src'\nimport { NotificationsService } from '../../../../../../../../../libs/feature/notifications/src'\nimport { TranslateModule, TranslateService } from '@ngx-translate/core'\nimport { PlatformServiceInterface } from '../../../../../../../../../libs/common/domain/src/lib/platform.service.interface'\nimport { Subscription } from 'rxjs'\nimport { MatDialog } from '@angular/material/dialog'\nimport { MAX_UPLOAD_SIZE_MB } from '../../../../fields.config'\n\n@Component({\n  selector: 'gn-ui-form-field-online-link-resources',\n  templateUrl: './form-field-online-link-resources.component.html',\n  styleUrls: ['./form-field-online-link-resources.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    FileInputComponent,\n    CommonModule,\n    SortableListComponent,\n    OnlineResourceCardComponent,\n    TextInputComponent,\n    TextAreaComponent,\n    UrlInputComponent,\n    TranslateModule,\n  ],\n})\nexport class FormFieldOnlineLinkResourcesComponent {\n  @Input() metadataUuid: string\n  @Input() set value(onlineResources: Array<OnlineResource>) {\n    this.allResources = onlineResources\n    this.linkResources = onlineResources.filter(\n      (res): res is OnlineLinkResource => res.type === 'link'\n    )\n  }\n  @Output() valueChange: EventEmitter<Array<OnlineResource>> =\n    new EventEmitter()\n\n  @ViewChild('dialogTemplate') dialogTemplate: TemplateRef<OnlineResource>\n\n  private allResources: OnlineResource[] = []\n  linkResources: OnlineLinkResource[] = []\n  uploadProgress = undefined\n  uploadSubscription: Subscription = null\n\n  protected MAX_UPLOAD_SIZE_MB = MAX_UPLOAD_SIZE_MB\n\n  constructor(\n    private notificationsService: NotificationsService,\n    private translateService: TranslateService,\n    private platformService: PlatformServiceInterface,\n    private cd: ChangeDetectorRef,\n    private dialog: MatDialog\n  ) {}\n\n  handleFileChange(file: File) {\n    this.uploadProgress = 0\n    this.uploadSubscription = this.platformService\n      .attachFileToRecord(this.metadataUuid, file)\n      .subscribe({\n        next: (event) => {\n          if (event.type === 'progress') {\n            this.uploadProgress = event.progress\n            this.cd.detectChanges()\n          } else if (event.type === 'success') {\n            this.uploadProgress = undefined\n            this.cd.detectChanges()\n            const newResource: OnlineLinkResource = {\n              type: 'link',\n              url: new URL(event.attachment.url),\n              name: event.attachment.fileName,\n            }\n            this.valueChange.emit([...this.allResources, newResource])\n          }\n        },\n        error: (error: Error) => this.handleError(error.message),\n      })\n  }\n\n  handleUploadCancel() {\n    if (this.uploadSubscription) {\n      this.uploadProgress = undefined\n      this.uploadSubscription.unsubscribe()\n    }\n  }\n\n  handleUrlChange(url: string) {\n    try {\n      const name = url.split('/').pop()\n      const newLink: OnlineLinkResource = {\n        type: 'link',\n        url: new URL(url),\n        name,\n      }\n      this.valueChange.emit([...this.allResources, newLink])\n    } catch (e) {\n      this.handleError((e as Error).message)\n    }\n  }\n\n  handleResourcesChange(items: unknown[]) {\n    const links = items as OnlineResource[]\n    const newResources = [\n      ...this.allResources.filter((r) => r.type !== 'link'),\n      ...links,\n    ]\n    this.valueChange.emit(newResources)\n  }\n\n  handleResourceModify(resource: OnlineLinkResource, index: number) {\n    this.openEditDialog(resource, index)\n  }\n\n  private handleError(error: string) {\n    this.uploadProgress = undefined\n    this.notificationsService.showNotification({\n      type: 'error',\n      title: this.translateService.instant(\n        'editor.record.onlineResourceError.title'\n      ),\n      text: `${this.translateService.instant(\n        'editor.record.onlineResourceError.body'\n      )} ${error}`,\n      closeMessage: this.translateService.instant(\n        'editor.record.onlineResourceError.closeMessage'\n      ),\n    })\n  }\n\n  private openEditDialog(resource: OnlineLinkResource, index: number) {\n    const resourceCopy = {\n      ...resource,\n    }\n    this.dialog\n      .open(ModalDialogComponent, {\n        width: '800px',\n        data: {\n          title: this.translateService.instant(\n            'editor.record.form.field.onlineResource.dialogTitle'\n          ),\n          body: this.dialogTemplate,\n          bodyContext: resourceCopy,\n          confirmText: this.translateService.instant(\n            'editor.record.form.field.onlineResource.confirm'\n          ),\n          cancelText: this.translateService.instant(\n            'editor.record.form.field.onlineResource.cancel'\n          ),\n        },\n      })\n      .afterClosed()\n      .subscribe((confirmed: boolean) => {\n        if (!confirmed) return\n        const newLinks = [...this.linkResources]\n        newLinks.splice(index, 1, resourceCopy)\n        this.valueChange.emit([\n          ...this.allResources.filter((r) => r.type !== 'link'),\n          ...newLinks,\n        ])\n      })\n  }\n}\n","<gn-ui-file-input\n  [maxSizeMB]=\"MAX_UPLOAD_SIZE_MB\"\n  (fileChange)=\"handleFileChange($event)\"\n  (uploadCancel)=\"handleUploadCancel()\"\n  [uploadProgress]=\"uploadProgress\"\n  (urlChange)=\"handleUrlChange($event)\"\n></gn-ui-file-input>\n<div class=\"h-[8px]\"></div>\n<gn-ui-sortable-list\n  [items]=\"linkResources\"\n  (itemsOrderChange)=\"handleResourcesChange($event)\"\n  [elementTemplate]=\"template\"\n>\n</gn-ui-sortable-list>\n<ng-template #template let-onlineResource let-index=\"index\">\n  <gn-ui-online-resource-card\n    [onlineResource]=\"onlineResource\"\n    (modifyClick)=\"handleResourceModify(onlineResource, index)\"\n  ></gn-ui-online-resource-card>\n</ng-template>\n\n<ng-template #dialogTemplate let-onlineResource>\n  <div class=\"flex flex-col gap-[16px]\">\n    <div>\n      <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n        editor.record.form.field.onlineResource.edit.title\n      </h3>\n      <gn-ui-text-input [(value)]=\"onlineResource.name\"></gn-ui-text-input>\n    </div>\n    <div>\n      <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n        editor.record.form.field.onlineResource.edit.description\n      </h3>\n      <gn-ui-text-area [(value)]=\"onlineResource.description\"></gn-ui-text-area>\n    </div>\n    <span class=\"w-full border-b border-gray-300\"></span>\n    <gn-ui-url-input\n      class=\"w-full\"\n      [disabled]=\"true\"\n      [value]=\"onlineResource.url\"\n    ></gn-ui-url-input>\n  </div>\n</ng-template>\n"]}
|
|
@@ -0,0 +1,191 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, Output, TemplateRef, ViewChild, } from '@angular/core';
|
|
3
|
+
import { MatDialog } from '@angular/material/dialog';
|
|
4
|
+
import { marker } from '@biesbjerg/ngx-translate-extract-marker';
|
|
5
|
+
import { PlatformServiceInterface } from '../../../../../../../../../libs/common/domain/src/lib/platform.service.interface';
|
|
6
|
+
import { NotificationsService } from '../../../../../../../../../libs/feature/notifications/src';
|
|
7
|
+
import { FileInputComponent, SwitchToggleComponent, TextAreaComponent, TextInputComponent, UrlInputComponent, } from '../../../../../../../../../libs/ui/inputs/src';
|
|
8
|
+
import { ModalDialogComponent, SortableListComponent, } from '../../../../../../../../../libs/ui/layout/src';
|
|
9
|
+
import { TranslateModule, TranslateService } from '@ngx-translate/core';
|
|
10
|
+
import { MAX_UPLOAD_SIZE_MB } from '../../../../fields.config';
|
|
11
|
+
import { OnlineResourceCardComponent } from '../../../online-resource-card/online-resource-card.component';
|
|
12
|
+
import { OnlineServiceResourceInputComponent } from '../../../online-service-resource-input/online-service-resource-input.component';
|
|
13
|
+
import * as i0 from "@angular/core";
|
|
14
|
+
import * as i1 from "../../../../../../../../../libs/feature/notifications/src";
|
|
15
|
+
import * as i2 from "@ngx-translate/core";
|
|
16
|
+
import * as i3 from "../../../../../../../../../libs/common/domain/src/lib/platform.service.interface";
|
|
17
|
+
import * as i4 from "@angular/material/dialog";
|
|
18
|
+
import * as i5 from "@angular/common";
|
|
19
|
+
export class FormFieldOnlineResourcesComponent {
|
|
20
|
+
set value(onlineResources) {
|
|
21
|
+
this.allResources = onlineResources;
|
|
22
|
+
this.notLinkResources = onlineResources.filter((res) => res.type !== 'link');
|
|
23
|
+
}
|
|
24
|
+
constructor(notificationsService, translateService, platformService, cd, dialog) {
|
|
25
|
+
this.notificationsService = notificationsService;
|
|
26
|
+
this.translateService = translateService;
|
|
27
|
+
this.platformService = platformService;
|
|
28
|
+
this.cd = cd;
|
|
29
|
+
this.dialog = dialog;
|
|
30
|
+
this.valueChange = new EventEmitter();
|
|
31
|
+
this.typeOptions = [
|
|
32
|
+
{
|
|
33
|
+
label: marker('editor.record.form.field.onlineResource.toggle.dataset'),
|
|
34
|
+
value: 'download',
|
|
35
|
+
checked: true,
|
|
36
|
+
},
|
|
37
|
+
{
|
|
38
|
+
label: marker('editor.record.form.field.onlineResource.toggle.service'),
|
|
39
|
+
value: 'service',
|
|
40
|
+
checked: false,
|
|
41
|
+
},
|
|
42
|
+
];
|
|
43
|
+
this.selectedType = 'download';
|
|
44
|
+
this.allResources = [];
|
|
45
|
+
this.notLinkResources = [];
|
|
46
|
+
this.uploadProgress = undefined;
|
|
47
|
+
this.uploadSubscription = null;
|
|
48
|
+
this.newService = {
|
|
49
|
+
type: 'service',
|
|
50
|
+
accessServiceProtocol: 'ogcFeatures',
|
|
51
|
+
identifierInService: '',
|
|
52
|
+
};
|
|
53
|
+
this.MAX_UPLOAD_SIZE_MB = MAX_UPLOAD_SIZE_MB;
|
|
54
|
+
}
|
|
55
|
+
onSelectedTypeChange(selectedType) {
|
|
56
|
+
this.selectedType = selectedType;
|
|
57
|
+
}
|
|
58
|
+
handleFileChange(file) {
|
|
59
|
+
this.uploadProgress = 0;
|
|
60
|
+
this.uploadSubscription = this.platformService
|
|
61
|
+
.attachFileToRecord(this.metadataUuid, file)
|
|
62
|
+
.subscribe({
|
|
63
|
+
next: (event) => {
|
|
64
|
+
if (event.type === 'progress') {
|
|
65
|
+
this.uploadProgress = event.progress;
|
|
66
|
+
this.cd.detectChanges();
|
|
67
|
+
}
|
|
68
|
+
else if (event.type === 'success') {
|
|
69
|
+
this.uploadProgress = undefined;
|
|
70
|
+
this.cd.detectChanges();
|
|
71
|
+
const newResource = {
|
|
72
|
+
type: 'download',
|
|
73
|
+
url: new URL(event.attachment.url),
|
|
74
|
+
name: event.attachment.fileName,
|
|
75
|
+
sizeBytes: event.sizeBytes, // WARNING: this is the only time that sizeBytes is set
|
|
76
|
+
};
|
|
77
|
+
this.valueChange.emit([...this.allResources, newResource]);
|
|
78
|
+
}
|
|
79
|
+
},
|
|
80
|
+
error: (error) => this.handleError(error.message),
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
handleUploadCancel() {
|
|
84
|
+
if (this.uploadSubscription) {
|
|
85
|
+
this.uploadProgress = undefined;
|
|
86
|
+
this.uploadSubscription.unsubscribe();
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
handleDownloadUrlChange(url) {
|
|
90
|
+
try {
|
|
91
|
+
const name = url.split('/').pop();
|
|
92
|
+
const newLink = {
|
|
93
|
+
type: 'download',
|
|
94
|
+
url: new URL(url),
|
|
95
|
+
name,
|
|
96
|
+
};
|
|
97
|
+
this.valueChange.emit([...this.allResources, newLink]);
|
|
98
|
+
}
|
|
99
|
+
catch (e) {
|
|
100
|
+
this.handleError(e.message);
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
handleServiceUrlChange(url) {
|
|
104
|
+
this.valueChange.emit([
|
|
105
|
+
...this.allResources,
|
|
106
|
+
{
|
|
107
|
+
...this.newService,
|
|
108
|
+
url: new URL(url),
|
|
109
|
+
},
|
|
110
|
+
]);
|
|
111
|
+
}
|
|
112
|
+
handleServiceModify(oldService, newService) {
|
|
113
|
+
oldService.accessServiceProtocol = newService.accessServiceProtocol;
|
|
114
|
+
oldService.identifierInService = newService.identifierInService;
|
|
115
|
+
oldService.url = newService.url;
|
|
116
|
+
}
|
|
117
|
+
handleResourcesChange(items) {
|
|
118
|
+
const notLinks = items;
|
|
119
|
+
const newResources = [
|
|
120
|
+
...this.allResources.filter((r) => r.type === 'link'),
|
|
121
|
+
...notLinks,
|
|
122
|
+
];
|
|
123
|
+
this.valueChange.emit(newResources);
|
|
124
|
+
}
|
|
125
|
+
handleResourceModify(resource, index) {
|
|
126
|
+
this.openEditDialog(resource, index);
|
|
127
|
+
}
|
|
128
|
+
handleError(error) {
|
|
129
|
+
this.uploadProgress = undefined;
|
|
130
|
+
this.notificationsService.showNotification({
|
|
131
|
+
type: 'error',
|
|
132
|
+
title: this.translateService.instant('editor.record.onlineResourceError.title'),
|
|
133
|
+
text: `${this.translateService.instant('editor.record.onlineResourceError.body')} ${error}`,
|
|
134
|
+
closeMessage: this.translateService.instant('editor.record.onlineResourceError.closeMessage'),
|
|
135
|
+
});
|
|
136
|
+
}
|
|
137
|
+
openEditDialog(resource, index) {
|
|
138
|
+
const resourceCopy = {
|
|
139
|
+
...resource,
|
|
140
|
+
};
|
|
141
|
+
this.dialog
|
|
142
|
+
.open(ModalDialogComponent, {
|
|
143
|
+
width: '800px',
|
|
144
|
+
data: {
|
|
145
|
+
title: this.translateService.instant('editor.record.form.field.onlineResource.dialogTitle'),
|
|
146
|
+
body: this.dialogTemplate,
|
|
147
|
+
bodyContext: resourceCopy,
|
|
148
|
+
confirmText: this.translateService.instant('editor.record.form.field.onlineResource.confirm'),
|
|
149
|
+
cancelText: this.translateService.instant('editor.record.form.field.onlineResource.cancel'),
|
|
150
|
+
},
|
|
151
|
+
})
|
|
152
|
+
.afterClosed()
|
|
153
|
+
.subscribe((confirmed) => {
|
|
154
|
+
if (!confirmed)
|
|
155
|
+
return;
|
|
156
|
+
const newNotLinks = [...this.notLinkResources];
|
|
157
|
+
newNotLinks.splice(index, 1, resourceCopy);
|
|
158
|
+
this.valueChange.emit([
|
|
159
|
+
...this.allResources.filter((r) => r.type === 'link'),
|
|
160
|
+
...newNotLinks,
|
|
161
|
+
]);
|
|
162
|
+
});
|
|
163
|
+
}
|
|
164
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FormFieldOnlineResourcesComponent, deps: [{ token: i1.NotificationsService }, { token: i2.TranslateService }, { token: i3.PlatformServiceInterface }, { token: i0.ChangeDetectorRef }, { token: i4.MatDialog }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
165
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: FormFieldOnlineResourcesComponent, isStandalone: true, selector: "gn-ui-form-field-online-resources", inputs: { metadataUuid: "metadataUuid", value: "value" }, outputs: { valueChange: "valueChange" }, viewQueries: [{ propertyName: "dialogTemplate", first: true, predicate: ["dialogTemplate"], descendants: true }], ngImport: i0, template: "<gn-ui-switch-toggle\n [options]=\"typeOptions\"\n (selectedValue)=\"onSelectedTypeChange($event.value)\"\n extraClasses=\"grow\"\n data-cy=\"online-resources-type\"\n></gn-ui-switch-toggle>\n<div class=\"h-[8px]\"></div>\n<gn-ui-file-input\n *ngIf=\"selectedType === 'download'\"\n [maxSizeMB]=\"MAX_UPLOAD_SIZE_MB\"\n (fileChange)=\"handleFileChange($event)\"\n (uploadCancel)=\"handleUploadCancel()\"\n [uploadProgress]=\"uploadProgress\"\n (urlChange)=\"handleDownloadUrlChange($event)\"\n></gn-ui-file-input>\n<div\n *ngIf=\"selectedType === 'service'\"\n class=\"w-full border-2 border-dashed rounded-lg p-6 flex flex-col gap-[16px]\"\n>\n <gn-ui-online-service-resource-input\n [service]=\"newService\"\n ></gn-ui-online-service-resource-input>\n <span class=\"w-full border-b border-gray-300\"></span>\n <gn-ui-url-input\n class=\"w-full\"\n [urlCanParse]=\"true\"\n (valueChange)=\"handleServiceUrlChange($event)\"\n ></gn-ui-url-input>\n</div>\n<div class=\"h-[8px]\"></div>\n<gn-ui-sortable-list\n [items]=\"notLinkResources\"\n (itemsOrderChange)=\"handleResourcesChange($event)\"\n [elementTemplate]=\"template\"\n>\n</gn-ui-sortable-list>\n<ng-template #template let-onlineResource let-index=\"index\">\n <gn-ui-online-resource-card\n [onlineResource]=\"onlineResource\"\n (modifyClick)=\"handleResourceModify(onlineResource, index)\"\n ></gn-ui-online-resource-card>\n</ng-template>\n\n<ng-template #dialogTemplate let-onlineResource>\n <div class=\"flex flex-col gap-[16px]\">\n <div>\n <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n editor.record.form.field.onlineResource.edit.title\n </h3>\n <gn-ui-text-input [(value)]=\"onlineResource.name\"></gn-ui-text-input>\n </div>\n <div>\n <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n editor.record.form.field.onlineResource.edit.description\n </h3>\n <gn-ui-text-area [(value)]=\"onlineResource.description\"></gn-ui-text-area>\n </div>\n <ng-container *ngIf=\"onlineResource.type === 'service'\">\n <span class=\"w-full border-b border-gray-300\"></span>\n <gn-ui-online-service-resource-input\n [service]=\"onlineResource\"\n ></gn-ui-online-service-resource-input>\n </ng-container>\n <span class=\"w-full border-b border-gray-300\"></span>\n <gn-ui-url-input\n class=\"w-full\"\n [disabled]=\"true\"\n [value]=\"onlineResource.url\"\n ></gn-ui-url-input>\n </div>\n</ng-template>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: SwitchToggleComponent, selector: "gn-ui-switch-toggle", inputs: ["options", "ariaLabel", "extraClasses"], outputs: ["selectedValue"] }, { kind: "component", type: FileInputComponent, selector: "gn-ui-file-input", inputs: ["maxSizeMB", "uploadProgress"], outputs: ["fileChange", "urlChange", "uploadCancel"] }, { kind: "component", type: OnlineServiceResourceInputComponent, selector: "gn-ui-online-service-resource-input", inputs: ["service", "protocolHint"] }, { kind: "component", type: UrlInputComponent, selector: "gn-ui-url-input", inputs: ["value", "extraClass", "placeholder", "disabled", "urlCanParse"], outputs: ["valueChange"] }, { kind: "component", type: SortableListComponent, selector: "gn-ui-sortable-list", inputs: ["elementTemplate", "items"], outputs: ["itemsOrderChange"] }, { kind: "component", type: OnlineResourceCardComponent, selector: "gn-ui-online-resource-card", inputs: ["onlineResource"], outputs: ["modifyClick"] }, { kind: "component", type: TextInputComponent, selector: "gn-ui-text-input", inputs: ["value", "extraClass", "placeholder", "required", "disabled"], outputs: ["valueChange"] }, { kind: "component", type: TextAreaComponent, selector: "gn-ui-text-area", inputs: ["value", "disabled", "extraClass", "placeholder", "required"], outputs: ["valueChange"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "directive", type: i2.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
166
|
+
}
|
|
167
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: FormFieldOnlineResourcesComponent, decorators: [{
|
|
168
|
+
type: Component,
|
|
169
|
+
args: [{ selector: 'gn-ui-form-field-online-resources', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
|
|
170
|
+
CommonModule,
|
|
171
|
+
SwitchToggleComponent,
|
|
172
|
+
FileInputComponent,
|
|
173
|
+
OnlineServiceResourceInputComponent,
|
|
174
|
+
UrlInputComponent,
|
|
175
|
+
SortableListComponent,
|
|
176
|
+
OnlineResourceCardComponent,
|
|
177
|
+
TextInputComponent,
|
|
178
|
+
TextAreaComponent,
|
|
179
|
+
TranslateModule,
|
|
180
|
+
], template: "<gn-ui-switch-toggle\n [options]=\"typeOptions\"\n (selectedValue)=\"onSelectedTypeChange($event.value)\"\n extraClasses=\"grow\"\n data-cy=\"online-resources-type\"\n></gn-ui-switch-toggle>\n<div class=\"h-[8px]\"></div>\n<gn-ui-file-input\n *ngIf=\"selectedType === 'download'\"\n [maxSizeMB]=\"MAX_UPLOAD_SIZE_MB\"\n (fileChange)=\"handleFileChange($event)\"\n (uploadCancel)=\"handleUploadCancel()\"\n [uploadProgress]=\"uploadProgress\"\n (urlChange)=\"handleDownloadUrlChange($event)\"\n></gn-ui-file-input>\n<div\n *ngIf=\"selectedType === 'service'\"\n class=\"w-full border-2 border-dashed rounded-lg p-6 flex flex-col gap-[16px]\"\n>\n <gn-ui-online-service-resource-input\n [service]=\"newService\"\n ></gn-ui-online-service-resource-input>\n <span class=\"w-full border-b border-gray-300\"></span>\n <gn-ui-url-input\n class=\"w-full\"\n [urlCanParse]=\"true\"\n (valueChange)=\"handleServiceUrlChange($event)\"\n ></gn-ui-url-input>\n</div>\n<div class=\"h-[8px]\"></div>\n<gn-ui-sortable-list\n [items]=\"notLinkResources\"\n (itemsOrderChange)=\"handleResourcesChange($event)\"\n [elementTemplate]=\"template\"\n>\n</gn-ui-sortable-list>\n<ng-template #template let-onlineResource let-index=\"index\">\n <gn-ui-online-resource-card\n [onlineResource]=\"onlineResource\"\n (modifyClick)=\"handleResourceModify(onlineResource, index)\"\n ></gn-ui-online-resource-card>\n</ng-template>\n\n<ng-template #dialogTemplate let-onlineResource>\n <div class=\"flex flex-col gap-[16px]\">\n <div>\n <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n editor.record.form.field.onlineResource.edit.title\n </h3>\n <gn-ui-text-input [(value)]=\"onlineResource.name\"></gn-ui-text-input>\n </div>\n <div>\n <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n editor.record.form.field.onlineResource.edit.description\n </h3>\n <gn-ui-text-area [(value)]=\"onlineResource.description\"></gn-ui-text-area>\n </div>\n <ng-container *ngIf=\"onlineResource.type === 'service'\">\n <span class=\"w-full border-b border-gray-300\"></span>\n <gn-ui-online-service-resource-input\n [service]=\"onlineResource\"\n ></gn-ui-online-service-resource-input>\n </ng-container>\n <span class=\"w-full border-b border-gray-300\"></span>\n <gn-ui-url-input\n class=\"w-full\"\n [disabled]=\"true\"\n [value]=\"onlineResource.url\"\n ></gn-ui-url-input>\n </div>\n</ng-template>\n" }]
|
|
181
|
+
}], ctorParameters: function () { return [{ type: i1.NotificationsService }, { type: i2.TranslateService }, { type: i3.PlatformServiceInterface }, { type: i0.ChangeDetectorRef }, { type: i4.MatDialog }]; }, propDecorators: { metadataUuid: [{
|
|
182
|
+
type: Input
|
|
183
|
+
}], value: [{
|
|
184
|
+
type: Input
|
|
185
|
+
}], valueChange: [{
|
|
186
|
+
type: Output
|
|
187
|
+
}], dialogTemplate: [{
|
|
188
|
+
type: ViewChild,
|
|
189
|
+
args: ['dialogTemplate']
|
|
190
|
+
}] } });
|
|
191
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-field-online-resources.component.js","sourceRoot":"","sources":["../../../../../../../../../../../libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-resources/form-field-online-resources.component.ts","../../../../../../../../../../../libs/feature/editor/src/lib/components/record-form/form-field/form-field-online-resources/form-field-online-resources.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  TemplateRef,\n  ViewChild,\n} from '@angular/core'\nimport { MatDialog } from '@angular/material/dialog'\nimport { marker } from '@biesbjerg/ngx-translate-extract-marker'\nimport {\n  DatasetDownloadDistribution,\n  DatasetServiceDistribution,\n  OnlineResource,\n  ServiceEndpoint,\n} from '../../../../../../../../../libs/common/domain/src/lib/model/record'\nimport { PlatformServiceInterface } from '../../../../../../../../../libs/common/domain/src/lib/platform.service.interface'\nimport { NotificationsService } from '../../../../../../../../../libs/feature/notifications/src'\nimport {\n  FileInputComponent,\n  SwitchToggleComponent,\n  SwitchToggleOption,\n  TextAreaComponent,\n  TextInputComponent,\n  UrlInputComponent,\n} from '../../../../../../../../../libs/ui/inputs/src'\nimport {\n  ModalDialogComponent,\n  SortableListComponent,\n} from '../../../../../../../../../libs/ui/layout/src'\nimport { TranslateModule, TranslateService } from '@ngx-translate/core'\nimport { Subscription } from 'rxjs'\nimport { MAX_UPLOAD_SIZE_MB } from '../../../../fields.config'\nimport { OnlineResourceCardComponent } from '../../../online-resource-card/online-resource-card.component'\nimport { OnlineServiceResourceInputComponent } from '../../../online-service-resource-input/online-service-resource-input.component'\n\ntype OnlineNotLinkResource =\n  | DatasetDownloadDistribution\n  | DatasetServiceDistribution\n  | ServiceEndpoint\n\n@Component({\n  selector: 'gn-ui-form-field-online-resources',\n  templateUrl: './form-field-online-resources.component.html',\n  styleUrls: ['./form-field-online-resources.component.css'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    CommonModule,\n    SwitchToggleComponent,\n    FileInputComponent,\n    OnlineServiceResourceInputComponent,\n    UrlInputComponent,\n    SortableListComponent,\n    OnlineResourceCardComponent,\n    TextInputComponent,\n    TextAreaComponent,\n    TranslateModule,\n  ],\n})\nexport class FormFieldOnlineResourcesComponent {\n  @Input() metadataUuid: string\n  @Input() set value(onlineResources: Array<OnlineResource>) {\n    this.allResources = onlineResources\n    this.notLinkResources = onlineResources.filter(\n      (res): res is OnlineNotLinkResource => res.type !== 'link'\n    )\n  }\n  @Output() valueChange: EventEmitter<Array<OnlineResource>> =\n    new EventEmitter()\n\n  @ViewChild('dialogTemplate') dialogTemplate: TemplateRef<OnlineResource>\n\n  typeOptions: SwitchToggleOption[] = [\n    {\n      label: marker('editor.record.form.field.onlineResource.toggle.dataset'),\n      value: 'download',\n      checked: true,\n    },\n    {\n      label: marker('editor.record.form.field.onlineResource.toggle.service'),\n      value: 'service',\n      checked: false,\n    },\n  ]\n  selectedType: 'download' | 'service' = 'download'\n\n  private allResources: OnlineResource[] = []\n  notLinkResources: OnlineNotLinkResource[] = []\n  uploadProgress = undefined\n  uploadSubscription: Subscription = null\n  newService = {\n    type: 'service',\n    accessServiceProtocol: 'ogcFeatures',\n    identifierInService: '',\n  } as Omit<DatasetServiceDistribution, 'url'>\n\n  protected MAX_UPLOAD_SIZE_MB = MAX_UPLOAD_SIZE_MB\n\n  constructor(\n    private notificationsService: NotificationsService,\n    private translateService: TranslateService,\n    private platformService: PlatformServiceInterface,\n    private cd: ChangeDetectorRef,\n    private dialog: MatDialog\n  ) {}\n\n  onSelectedTypeChange(selectedType: unknown) {\n    this.selectedType = selectedType as 'download' | 'service'\n  }\n\n  handleFileChange(file: File) {\n    this.uploadProgress = 0\n    this.uploadSubscription = this.platformService\n      .attachFileToRecord(this.metadataUuid, file)\n      .subscribe({\n        next: (event) => {\n          if (event.type === 'progress') {\n            this.uploadProgress = event.progress\n            this.cd.detectChanges()\n          } else if (event.type === 'success') {\n            this.uploadProgress = undefined\n            this.cd.detectChanges()\n            const newResource: DatasetDownloadDistribution = {\n              type: 'download',\n              url: new URL(event.attachment.url),\n              name: event.attachment.fileName,\n              sizeBytes: event.sizeBytes, // WARNING: this is the only time that sizeBytes is set\n            }\n            this.valueChange.emit([...this.allResources, newResource])\n          }\n        },\n        error: (error: Error) => this.handleError(error.message),\n      })\n  }\n\n  handleUploadCancel() {\n    if (this.uploadSubscription) {\n      this.uploadProgress = undefined\n      this.uploadSubscription.unsubscribe()\n    }\n  }\n\n  handleDownloadUrlChange(url: string) {\n    try {\n      const name = url.split('/').pop()\n      const newLink: DatasetDownloadDistribution = {\n        type: 'download',\n        url: new URL(url),\n        name,\n      }\n      this.valueChange.emit([...this.allResources, newLink])\n    } catch (e) {\n      this.handleError((e as Error).message)\n    }\n  }\n\n  handleServiceUrlChange(url: string) {\n    this.valueChange.emit([\n      ...this.allResources,\n      {\n        ...this.newService,\n        url: new URL(url),\n      },\n    ])\n  }\n\n  handleServiceModify(\n    oldService: DatasetServiceDistribution,\n    newService: DatasetServiceDistribution\n  ) {\n    oldService.accessServiceProtocol = newService.accessServiceProtocol\n    oldService.identifierInService = newService.identifierInService\n    oldService.url = newService.url\n  }\n\n  handleResourcesChange(items: unknown[]) {\n    const notLinks = items as OnlineNotLinkResource[]\n    const newResources = [\n      ...this.allResources.filter((r) => r.type === 'link'),\n      ...notLinks,\n    ]\n    this.valueChange.emit(newResources)\n  }\n\n  handleResourceModify(resource: OnlineNotLinkResource, index: number) {\n    this.openEditDialog(resource, index)\n  }\n\n  private handleError(error: string) {\n    this.uploadProgress = undefined\n    this.notificationsService.showNotification({\n      type: 'error',\n      title: this.translateService.instant(\n        'editor.record.onlineResourceError.title'\n      ),\n      text: `${this.translateService.instant(\n        'editor.record.onlineResourceError.body'\n      )} ${error}`,\n      closeMessage: this.translateService.instant(\n        'editor.record.onlineResourceError.closeMessage'\n      ),\n    })\n  }\n\n  private openEditDialog(resource: OnlineNotLinkResource, index: number) {\n    const resourceCopy = {\n      ...resource,\n    }\n    this.dialog\n      .open(ModalDialogComponent, {\n        width: '800px',\n        data: {\n          title: this.translateService.instant(\n            'editor.record.form.field.onlineResource.dialogTitle'\n          ),\n          body: this.dialogTemplate,\n          bodyContext: resourceCopy,\n          confirmText: this.translateService.instant(\n            'editor.record.form.field.onlineResource.confirm'\n          ),\n          cancelText: this.translateService.instant(\n            'editor.record.form.field.onlineResource.cancel'\n          ),\n        },\n      })\n      .afterClosed()\n      .subscribe((confirmed: boolean) => {\n        if (!confirmed) return\n        const newNotLinks = [...this.notLinkResources]\n        newNotLinks.splice(index, 1, resourceCopy)\n        this.valueChange.emit([\n          ...this.allResources.filter((r) => r.type === 'link'),\n          ...newNotLinks,\n        ])\n      })\n  }\n}\n","<gn-ui-switch-toggle\n  [options]=\"typeOptions\"\n  (selectedValue)=\"onSelectedTypeChange($event.value)\"\n  extraClasses=\"grow\"\n  data-cy=\"online-resources-type\"\n></gn-ui-switch-toggle>\n<div class=\"h-[8px]\"></div>\n<gn-ui-file-input\n  *ngIf=\"selectedType === 'download'\"\n  [maxSizeMB]=\"MAX_UPLOAD_SIZE_MB\"\n  (fileChange)=\"handleFileChange($event)\"\n  (uploadCancel)=\"handleUploadCancel()\"\n  [uploadProgress]=\"uploadProgress\"\n  (urlChange)=\"handleDownloadUrlChange($event)\"\n></gn-ui-file-input>\n<div\n  *ngIf=\"selectedType === 'service'\"\n  class=\"w-full border-2 border-dashed rounded-lg p-6 flex flex-col gap-[16px]\"\n>\n  <gn-ui-online-service-resource-input\n    [service]=\"newService\"\n  ></gn-ui-online-service-resource-input>\n  <span class=\"w-full border-b border-gray-300\"></span>\n  <gn-ui-url-input\n    class=\"w-full\"\n    [urlCanParse]=\"true\"\n    (valueChange)=\"handleServiceUrlChange($event)\"\n  ></gn-ui-url-input>\n</div>\n<div class=\"h-[8px]\"></div>\n<gn-ui-sortable-list\n  [items]=\"notLinkResources\"\n  (itemsOrderChange)=\"handleResourcesChange($event)\"\n  [elementTemplate]=\"template\"\n>\n</gn-ui-sortable-list>\n<ng-template #template let-onlineResource let-index=\"index\">\n  <gn-ui-online-resource-card\n    [onlineResource]=\"onlineResource\"\n    (modifyClick)=\"handleResourceModify(onlineResource, index)\"\n  ></gn-ui-online-resource-card>\n</ng-template>\n\n<ng-template #dialogTemplate let-onlineResource>\n  <div class=\"flex flex-col gap-[16px]\">\n    <div>\n      <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n        editor.record.form.field.onlineResource.edit.title\n      </h3>\n      <gn-ui-text-input [(value)]=\"onlineResource.name\"></gn-ui-text-input>\n    </div>\n    <div>\n      <h3 class=\"text-[16px] font-bold text-main mb-[12px]\" translate>\n        editor.record.form.field.onlineResource.edit.description\n      </h3>\n      <gn-ui-text-area [(value)]=\"onlineResource.description\"></gn-ui-text-area>\n    </div>\n    <ng-container *ngIf=\"onlineResource.type === 'service'\">\n      <span class=\"w-full border-b border-gray-300\"></span>\n      <gn-ui-online-service-resource-input\n        [service]=\"onlineResource\"\n      ></gn-ui-online-service-resource-input>\n    </ng-container>\n    <span class=\"w-full border-b border-gray-300\"></span>\n    <gn-ui-url-input\n      class=\"w-full\"\n      [disabled]=\"true\"\n      [value]=\"onlineResource.url\"\n    ></gn-ui-url-input>\n  </div>\n</ng-template>\n"]}
|