geonetwork-ui 2.3.0-dev.6e2b8bea → 2.3.0-dev.c3722986
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/data-access/gn4/src/openapi/api/records.api.service.mjs +35 -7
- package/esm2022/libs/data-access/gn4/src/openapi/model/models.mjs +1 -2
- package/esm2022/libs/feature/dataviz/src/lib/service/data.service.mjs +2 -2
- package/esm2022/libs/ui/elements/src/lib/image-overlay-preview/image-overlay-preview.component.mjs +3 -3
- package/esm2022/libs/ui/elements/src/lib/metadata-info/metadata-info.component.mjs +3 -3
- package/esm2022/libs/ui/elements/src/lib/thumbnail/thumbnail.component.mjs +4 -3
- package/esm2022/libs/ui/elements/src/lib/ui-elements.module.mjs +6 -5
- package/esm2022/libs/ui/inputs/src/lib/button/button.component.mjs +2 -1
- package/esm2022/libs/ui/inputs/src/lib/files-drop/files-drop.directive.mjs +59 -0
- package/esm2022/libs/ui/inputs/src/lib/image-input/image-input.component.mjs +183 -0
- package/esm2022/libs/ui/inputs/src/lib/ui-inputs.module.mjs +10 -4
- package/esm2022/libs/util/shared/src/lib/utils/bytes-convert.mjs +4 -0
- package/esm2022/libs/util/shared/src/lib/utils/image-resize.mjs +60 -0
- package/esm2022/libs/util/shared/src/lib/utils/index.mjs +8 -6
- package/esm2022/translations/de.json +10 -0
- package/esm2022/translations/en.json +10 -0
- package/esm2022/translations/es.json +10 -0
- package/esm2022/translations/fr.json +10 -0
- package/esm2022/translations/it.json +10 -0
- package/esm2022/translations/nl.json +10 -0
- package/esm2022/translations/pt.json +10 -0
- package/fesm2022/geonetwork-ui.mjs +495 -115
- package/fesm2022/geonetwork-ui.mjs.map +1 -1
- package/libs/data-access/gn4/src/openapi/api/records.api.service.d.ts +9 -5
- package/libs/data-access/gn4/src/openapi/api/records.api.service.d.ts.map +1 -1
- package/libs/data-access/gn4/src/openapi/model/models.d.ts +0 -1
- package/libs/data-access/gn4/src/openapi/model/models.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/thumbnail/thumbnail.component.d.ts +1 -1
- package/libs/ui/elements/src/lib/thumbnail/thumbnail.component.d.ts.map +1 -1
- package/libs/ui/elements/src/lib/ui-elements.module.d.ts +20 -20
- package/libs/ui/inputs/src/lib/button/button.component.d.ts.map +1 -1
- package/libs/ui/inputs/src/lib/files-drop/files-drop.directive.d.ts +14 -0
- package/libs/ui/inputs/src/lib/files-drop/files-drop.directive.d.ts.map +1 -0
- package/libs/ui/inputs/src/lib/image-input/image-input.component.d.ts +44 -0
- package/libs/ui/inputs/src/lib/image-input/image-input.component.d.ts.map +1 -0
- package/libs/ui/inputs/src/lib/ui-inputs.module.d.ts +2 -1
- package/libs/ui/inputs/src/lib/ui-inputs.module.d.ts.map +1 -1
- package/libs/util/shared/src/lib/utils/bytes-convert.d.ts +2 -0
- package/libs/util/shared/src/lib/utils/bytes-convert.d.ts.map +1 -0
- package/libs/util/shared/src/lib/utils/image-resize.d.ts +3 -0
- package/libs/util/shared/src/lib/utils/image-resize.d.ts.map +1 -0
- package/libs/util/shared/src/lib/utils/index.d.ts +7 -5
- package/libs/util/shared/src/lib/utils/index.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/libs/data-access/gn4/src/openapi/api/records.api.service.ts +43 -12
- package/src/libs/data-access/gn4/src/openapi/model/models.ts +0 -1
- package/src/libs/data-access/gn4/src/spec.yaml +1 -1
- package/src/libs/feature/dataviz/src/lib/service/data.service.ts +1 -1
- package/src/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.css +0 -0
- package/src/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.html +8 -0
- package/src/libs/feature/editor/src/lib/components/overview-upload/overview-upload.component.ts +70 -0
- package/src/libs/ui/elements/src/lib/thumbnail/thumbnail.component.ts +5 -3
- package/src/libs/ui/elements/src/lib/ui-elements.module.ts +1 -1
- package/src/libs/ui/inputs/src/lib/button/button.component.ts +1 -1
- package/src/libs/ui/inputs/src/lib/files-drop/files-drop.directive.ts +45 -0
- package/src/libs/ui/inputs/src/lib/image-input/image-input.component.css +0 -0
- package/src/libs/ui/inputs/src/lib/image-input/image-input.component.html +146 -0
- package/src/libs/ui/inputs/src/lib/image-input/image-input.component.ts +193 -0
- package/src/libs/ui/inputs/src/lib/ui-inputs.module.ts +3 -0
- package/src/libs/util/shared/src/lib/utils/bytes-convert.ts +3 -0
- package/src/libs/util/shared/src/lib/utils/image-resize.ts +72 -0
- package/src/libs/util/shared/src/lib/utils/index.ts +7 -5
- package/translations/de.json +10 -0
- package/translations/en.json +10 -0
- package/translations/es.json +10 -0
- package/translations/fr.json +10 -0
- package/translations/it.json +10 -0
- package/translations/nl.json +10 -0
- package/translations/pt.json +10 -0
- package/translations/sk.json +10 -0
- package/esm2022/libs/data-access/gn4/src/openapi/model/inlineObject3.api.model.mjs +0 -13
- package/libs/data-access/gn4/src/openapi/model/inlineObject3.api.model.d.ts +0 -18
- package/libs/data-access/gn4/src/openapi/model/inlineObject3.api.model.d.ts.map +0 -1
- package/src/libs/data-access/gn4/src/openapi/model/inlineObject3.api.model.ts +0 -18
|
@@ -0,0 +1,183 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { HttpClient } from '@angular/common/http';
|
|
3
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, Input, Output, } from '@angular/core';
|
|
4
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
5
|
+
import { MatProgressSpinnerModule } from '@angular/material/progress-spinner';
|
|
6
|
+
import { downgradeImage, megabytesToBytes } from '../../../../../../libs/util/shared/src';
|
|
7
|
+
import { firstValueFrom } from 'rxjs';
|
|
8
|
+
import { ButtonComponent } from '../button/button.component';
|
|
9
|
+
import { FilesDropDirective } from '../files-drop/files-drop.directive';
|
|
10
|
+
import { TranslateModule } from '@ngx-translate/core';
|
|
11
|
+
import { marker } from '@biesbjerg/ngx-translate-extract-marker';
|
|
12
|
+
import * as i0 from "@angular/core";
|
|
13
|
+
import * as i1 from "@angular/common/http";
|
|
14
|
+
import * as i2 from "@angular/common";
|
|
15
|
+
import * as i3 from "@angular/material/icon";
|
|
16
|
+
import * as i4 from "@angular/material/progress-spinner";
|
|
17
|
+
import * as i5 from "@ngx-translate/core";
|
|
18
|
+
export class ImageInputComponent {
|
|
19
|
+
constructor(http, cd) {
|
|
20
|
+
this.http = http;
|
|
21
|
+
this.cd = cd;
|
|
22
|
+
this.fileChange = new EventEmitter();
|
|
23
|
+
this.urlChange = new EventEmitter();
|
|
24
|
+
this.uploadCancel = new EventEmitter();
|
|
25
|
+
this.delete = new EventEmitter();
|
|
26
|
+
this.altTextChange = new EventEmitter();
|
|
27
|
+
this.dragFilesOver = false;
|
|
28
|
+
this.showUrlInput = false;
|
|
29
|
+
this.downloadError = false;
|
|
30
|
+
this.showAltTextInput = false;
|
|
31
|
+
}
|
|
32
|
+
getPrimaryText() {
|
|
33
|
+
if (this.uploadError) {
|
|
34
|
+
return marker('input.image.uploadErrorLabel');
|
|
35
|
+
}
|
|
36
|
+
if (this.uploadProgress) {
|
|
37
|
+
return marker('input.image.uploadProgressLabel');
|
|
38
|
+
}
|
|
39
|
+
return marker('input.image.selectFileLabel');
|
|
40
|
+
}
|
|
41
|
+
getSecondaryText() {
|
|
42
|
+
if (this.uploadError) {
|
|
43
|
+
return marker('input.image.uploadErrorRetry');
|
|
44
|
+
}
|
|
45
|
+
if (this.uploadProgress) {
|
|
46
|
+
return marker('input.image.uploadProgressCancel');
|
|
47
|
+
}
|
|
48
|
+
return marker('input.image.dropFileLabel');
|
|
49
|
+
}
|
|
50
|
+
handleDragFilesOver(dragFilesOver) {
|
|
51
|
+
if (!this.showUrlInput) {
|
|
52
|
+
this.dragFilesOver = dragFilesOver;
|
|
53
|
+
this.cd.markForCheck();
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
handleDropFiles(files) {
|
|
57
|
+
if (!this.showUrlInput) {
|
|
58
|
+
const validFiles = this.filterTypeImage(files);
|
|
59
|
+
if (validFiles.length > 0) {
|
|
60
|
+
this.resizeAndEmit(validFiles[0]);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
handleFileInput(event) {
|
|
65
|
+
const inputFiles = Array.from(event.target.files);
|
|
66
|
+
const validFiles = this.filterTypeImage(inputFiles);
|
|
67
|
+
if (validFiles.length > 0) {
|
|
68
|
+
this.resizeAndEmit(validFiles[0]);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
displayUrlInput() {
|
|
72
|
+
this.uploadCancel.emit();
|
|
73
|
+
this.showUrlInput = true;
|
|
74
|
+
}
|
|
75
|
+
handleUrlChange(event) {
|
|
76
|
+
this.downloadError = false;
|
|
77
|
+
this.urlInputValue = event.target.value;
|
|
78
|
+
}
|
|
79
|
+
async downloadUrl() {
|
|
80
|
+
const name = this.urlInputValue.split('/').pop();
|
|
81
|
+
try {
|
|
82
|
+
const response = await firstValueFrom(this.http.head(this.urlInputValue, { observe: 'response' }));
|
|
83
|
+
if (response.headers.get('content-type')?.startsWith('image/') &&
|
|
84
|
+
parseInt(response.headers.get('content-length')) <
|
|
85
|
+
megabytesToBytes(this.maxSizeMB)) {
|
|
86
|
+
this.http.get(this.urlInputValue, { responseType: 'blob' }).subscribe({
|
|
87
|
+
next: (blob) => {
|
|
88
|
+
this.cd.markForCheck();
|
|
89
|
+
const file = new File([blob], name);
|
|
90
|
+
this.fileChange.emit(file);
|
|
91
|
+
},
|
|
92
|
+
error: () => {
|
|
93
|
+
this.downloadError = true;
|
|
94
|
+
this.cd.markForCheck();
|
|
95
|
+
this.urlChange.emit(this.urlInputValue);
|
|
96
|
+
},
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
catch {
|
|
101
|
+
this.downloadError = true;
|
|
102
|
+
this.cd.markForCheck();
|
|
103
|
+
return;
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
handleSecondaryTextClick() {
|
|
107
|
+
if (this.uploadError) {
|
|
108
|
+
this.handleRetry();
|
|
109
|
+
}
|
|
110
|
+
else if (this.uploadProgress) {
|
|
111
|
+
this.handleCancel();
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
handleCancel() {
|
|
115
|
+
this.uploadCancel.emit();
|
|
116
|
+
}
|
|
117
|
+
handleRetry() {
|
|
118
|
+
switch (this.lastUploadType) {
|
|
119
|
+
case 'file':
|
|
120
|
+
this.fileChange.emit(this.lastUploadContent);
|
|
121
|
+
break;
|
|
122
|
+
case 'url':
|
|
123
|
+
this.urlChange.emit(this.lastUploadContent);
|
|
124
|
+
break;
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
handleDelete() {
|
|
128
|
+
this.delete.emit();
|
|
129
|
+
}
|
|
130
|
+
toggleAltTextInput() {
|
|
131
|
+
this.showAltTextInput = !this.showAltTextInput;
|
|
132
|
+
}
|
|
133
|
+
handleAltTextChange(event) {
|
|
134
|
+
const input = event.target;
|
|
135
|
+
this.altTextChange.emit(input.value);
|
|
136
|
+
}
|
|
137
|
+
filterTypeImage(files) {
|
|
138
|
+
return files.filter((file) => {
|
|
139
|
+
return file.type.startsWith('image/');
|
|
140
|
+
});
|
|
141
|
+
}
|
|
142
|
+
resizeAndEmit(imageToResize) {
|
|
143
|
+
const maxSizeBytes = megabytesToBytes(this.maxSizeMB);
|
|
144
|
+
downgradeImage(imageToResize, maxSizeBytes).then((resizedImage) => {
|
|
145
|
+
const fileToEmit = new File([resizedImage], imageToResize.name);
|
|
146
|
+
this.fileChange.emit(fileToEmit);
|
|
147
|
+
});
|
|
148
|
+
}
|
|
149
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: ImageInputComponent, deps: [{ token: i1.HttpClient }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
150
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.7", 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 h-full object-cover border-2 border-gray-300 rounded-lg\"\n [alt]=\"altText\"\n loading=\"lazy\"\n [src]=\"previewUrl\"\n />\n <gn-ui-button\n [extraClass]=\"\n 'bg-gray-200 absolute right-2 bottom-2 invisible group-hover:visible'\n \"\n (buttonClick)=\"handleDelete()\"\n >\n <mat-icon class=\"material-symbols-outlined\">delete</mat-icon>\n </gn-ui-button>\n </div>\n <input\n *ngIf=\"showAltTextInput\"\n type=\"text\"\n class=\"py-3 px-2 border-2 border-gray-300 rounded-lg text-sm font-medium\"\n [placeholder]=\"'input.image.altTextPlaceholder' | translate\"\n [value]=\"altText\"\n (change)=\"handleAltTextChange($event)\"\n />\n <div class=\"flex flex-row gap-2\">\n <gn-ui-button\n [extraClass]=\"'bg-gray-200 font-bold'\"\n (buttonClick)=\"handleDelete()\"\n >\n <mat-icon class=\"material-symbols-outlined me-1\">delete</mat-icon>\n {{ 'input.image.delete' | translate }}\n </gn-ui-button>\n <gn-ui-button\n *ngIf=\"!showAltTextInput\"\n [extraClass]=\"'bg-gray-200 font-bold'\"\n (buttonClick)=\"toggleAltTextInput()\"\n >\n <mat-icon class=\"material-symbols-outlined me-1\">add</mat-icon>\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=\"block flex-1 border-2 border-dashed border-gray-300 rounded-lg p-6 flex flex-col items-center justify-center gap-4\"\n (dragFilesOver)=\"handleDragFilesOver($event)\"\n (dropFiles)=\"handleDropFiles($event)\"\n >\n <div class=\"w-14 h-14 rounded-md bg-gray-200 grid\">\n <mat-icon\n *ngIf=\"!dragFilesOver && !uploadProgress && !uploadError\"\n class=\"material-symbols-outlined place-self-center text-blue-500\"\n >image</mat-icon\n >\n <mat-icon\n *ngIf=\"dragFilesOver && !uploadProgress && !uploadError\"\n class=\"material-symbols-outlined place-self-center text-blue-500\"\n >add_box</mat-icon\n >\n <div *ngIf=\"uploadProgress\">\n <mat-progress-spinner\n class=\"place-self-center\"\n [diameter]=\"56\"\n [mode]=\"'determinate'\"\n [value]=\"uploadProgress\"\n ></mat-progress-spinner>\n <span\n class=\"text-sm font-medium relative inline-block width-[30px] bottom-[40px] left-[15px]\"\n >\n {{ uploadProgress }}%\n </span>\n </div>\n <mat-icon\n *ngIf=\"uploadError\"\n class=\"material-symbols-outlined place-self-center text-rose-500\"\n >broken_image</mat-icon\n >\n </div>\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 uploadProgress || uploadError\n ? 'font-bold text-blue-500 cursor-pointer'\n : 'font-medium text-gray-500'\n \"\n (click)=\"handleSecondaryTextClick()\"\n >\n {{ getSecondaryText() | translate }}\n </p>\n </div>\n <input\n type=\"file\"\n class=\"hidden\"\n (change)=\"handleFileInput($event)\"\n [disabled]=\"showUrlInput || uploadProgress || uploadError\"\n />\n </label>\n <div *ngIf=\"!showUrlInput\" class=\"flex-none\">\n <gn-ui-button\n [extraClass]=\"'bg-gray-200 font-bold'\"\n (buttonClick)=\"displayUrlInput()\"\n >\n <mat-icon class=\"material-symbols-outlined me-1\">link</mat-icon>\n {{ 'input.image.displayUrlInput' | translate }}\n </gn-ui-button>\n </div>\n <div *ngIf=\"showUrlInput\" class=\"flex-none flex flex-col gap-2\">\n <div class=\"h-2\"></div>\n <div class=\"flex gap-2 items-center\">\n <div class=\"flex-1 flex rounded-lg\">\n <span\n class=\"material-symbols-outlined px-4 inline-flex items-center min-w-fit rounded-s-lg border-2 border-e-0 border-gray-300\"\n >link</span\n >\n <input\n type=\"text\"\n class=\"py-3 ps-1 block w-full border-2 border-s-0 border-e-0 border-gray-300 text-sm font-medium\"\n placeholder=\"https://exemple.com/image.jpg\"\n (change)=\"handleUrlChange($event)\"\n />\n <gn-ui-button\n class=\"px-1 inline-flex items-center min-w-fit rounded-e-lg border-2 border-s-0 border-gray-300 text-white\"\n [extraClass]=\"\n urlInputValue && !downloadError ? 'bg-blue-500' : 'bg-gray-500'\n \"\n [disabled]=\"!urlInputValue || downloadError\"\n (buttonClick)=\"downloadUrl()\"\n >\n <mat-icon class=\"material-symbols-outlined\">arrow_upward</mat-icon>\n </gn-ui-button>\n </div>\n </div>\n </div>\n </div>\n</ng-template>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { 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" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
151
|
+
}
|
|
152
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: ImageInputComponent, decorators: [{
|
|
153
|
+
type: Component,
|
|
154
|
+
args: [{ selector: 'gn-ui-image-input', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
|
|
155
|
+
CommonModule,
|
|
156
|
+
ButtonComponent,
|
|
157
|
+
MatIconModule,
|
|
158
|
+
FilesDropDirective,
|
|
159
|
+
MatProgressSpinnerModule,
|
|
160
|
+
TranslateModule,
|
|
161
|
+
], 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 h-full object-cover border-2 border-gray-300 rounded-lg\"\n [alt]=\"altText\"\n loading=\"lazy\"\n [src]=\"previewUrl\"\n />\n <gn-ui-button\n [extraClass]=\"\n 'bg-gray-200 absolute right-2 bottom-2 invisible group-hover:visible'\n \"\n (buttonClick)=\"handleDelete()\"\n >\n <mat-icon class=\"material-symbols-outlined\">delete</mat-icon>\n </gn-ui-button>\n </div>\n <input\n *ngIf=\"showAltTextInput\"\n type=\"text\"\n class=\"py-3 px-2 border-2 border-gray-300 rounded-lg text-sm font-medium\"\n [placeholder]=\"'input.image.altTextPlaceholder' | translate\"\n [value]=\"altText\"\n (change)=\"handleAltTextChange($event)\"\n />\n <div class=\"flex flex-row gap-2\">\n <gn-ui-button\n [extraClass]=\"'bg-gray-200 font-bold'\"\n (buttonClick)=\"handleDelete()\"\n >\n <mat-icon class=\"material-symbols-outlined me-1\">delete</mat-icon>\n {{ 'input.image.delete' | translate }}\n </gn-ui-button>\n <gn-ui-button\n *ngIf=\"!showAltTextInput\"\n [extraClass]=\"'bg-gray-200 font-bold'\"\n (buttonClick)=\"toggleAltTextInput()\"\n >\n <mat-icon class=\"material-symbols-outlined me-1\">add</mat-icon>\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=\"block flex-1 border-2 border-dashed border-gray-300 rounded-lg p-6 flex flex-col items-center justify-center gap-4\"\n (dragFilesOver)=\"handleDragFilesOver($event)\"\n (dropFiles)=\"handleDropFiles($event)\"\n >\n <div class=\"w-14 h-14 rounded-md bg-gray-200 grid\">\n <mat-icon\n *ngIf=\"!dragFilesOver && !uploadProgress && !uploadError\"\n class=\"material-symbols-outlined place-self-center text-blue-500\"\n >image</mat-icon\n >\n <mat-icon\n *ngIf=\"dragFilesOver && !uploadProgress && !uploadError\"\n class=\"material-symbols-outlined place-self-center text-blue-500\"\n >add_box</mat-icon\n >\n <div *ngIf=\"uploadProgress\">\n <mat-progress-spinner\n class=\"place-self-center\"\n [diameter]=\"56\"\n [mode]=\"'determinate'\"\n [value]=\"uploadProgress\"\n ></mat-progress-spinner>\n <span\n class=\"text-sm font-medium relative inline-block width-[30px] bottom-[40px] left-[15px]\"\n >\n {{ uploadProgress }}%\n </span>\n </div>\n <mat-icon\n *ngIf=\"uploadError\"\n class=\"material-symbols-outlined place-self-center text-rose-500\"\n >broken_image</mat-icon\n >\n </div>\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 uploadProgress || uploadError\n ? 'font-bold text-blue-500 cursor-pointer'\n : 'font-medium text-gray-500'\n \"\n (click)=\"handleSecondaryTextClick()\"\n >\n {{ getSecondaryText() | translate }}\n </p>\n </div>\n <input\n type=\"file\"\n class=\"hidden\"\n (change)=\"handleFileInput($event)\"\n [disabled]=\"showUrlInput || uploadProgress || uploadError\"\n />\n </label>\n <div *ngIf=\"!showUrlInput\" class=\"flex-none\">\n <gn-ui-button\n [extraClass]=\"'bg-gray-200 font-bold'\"\n (buttonClick)=\"displayUrlInput()\"\n >\n <mat-icon class=\"material-symbols-outlined me-1\">link</mat-icon>\n {{ 'input.image.displayUrlInput' | translate }}\n </gn-ui-button>\n </div>\n <div *ngIf=\"showUrlInput\" class=\"flex-none flex flex-col gap-2\">\n <div class=\"h-2\"></div>\n <div class=\"flex gap-2 items-center\">\n <div class=\"flex-1 flex rounded-lg\">\n <span\n class=\"material-symbols-outlined px-4 inline-flex items-center min-w-fit rounded-s-lg border-2 border-e-0 border-gray-300\"\n >link</span\n >\n <input\n type=\"text\"\n class=\"py-3 ps-1 block w-full border-2 border-s-0 border-e-0 border-gray-300 text-sm font-medium\"\n placeholder=\"https://exemple.com/image.jpg\"\n (change)=\"handleUrlChange($event)\"\n />\n <gn-ui-button\n class=\"px-1 inline-flex items-center min-w-fit rounded-e-lg border-2 border-s-0 border-gray-300 text-white\"\n [extraClass]=\"\n urlInputValue && !downloadError ? 'bg-blue-500' : 'bg-gray-500'\n \"\n [disabled]=\"!urlInputValue || downloadError\"\n (buttonClick)=\"downloadUrl()\"\n >\n <mat-icon class=\"material-symbols-outlined\">arrow_upward</mat-icon>\n </gn-ui-button>\n </div>\n </div>\n </div>\n </div>\n</ng-template>\n" }]
|
|
162
|
+
}], ctorParameters: function () { return [{ type: i1.HttpClient }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { maxSizeMB: [{
|
|
163
|
+
type: Input
|
|
164
|
+
}], previewUrl: [{
|
|
165
|
+
type: Input
|
|
166
|
+
}], altText: [{
|
|
167
|
+
type: Input
|
|
168
|
+
}], uploadProgress: [{
|
|
169
|
+
type: Input
|
|
170
|
+
}], uploadError: [{
|
|
171
|
+
type: Input
|
|
172
|
+
}], fileChange: [{
|
|
173
|
+
type: Output
|
|
174
|
+
}], urlChange: [{
|
|
175
|
+
type: Output
|
|
176
|
+
}], uploadCancel: [{
|
|
177
|
+
type: Output
|
|
178
|
+
}], delete: [{
|
|
179
|
+
type: Output
|
|
180
|
+
}], altTextChange: [{
|
|
181
|
+
type: Output
|
|
182
|
+
}] } });
|
|
183
|
+
//# 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'\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  ],\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  urlInputValue?: string\n  lastUploadType?: 'file' | 'url'\n  lastUploadContent?: string | File\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  handleUrlChange(event: Event) {\n    this.downloadError = false\n    this.urlInputValue = (event.target as HTMLInputElement).value\n  }\n\n  async downloadUrl() {\n    const name = this.urlInputValue.split('/').pop()\n\n    try {\n      const response = await firstValueFrom(\n        this.http.head(this.urlInputValue, { 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(this.urlInputValue, { 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(this.urlInputValue)\n          },\n        })\n      }\n    } catch {\n      this.downloadError = true\n      this.cd.markForCheck()\n      return\n    }\n  }\n\n  handleSecondaryTextClick() {\n    if (this.uploadError) {\n      this.handleRetry()\n    } else if (this.uploadProgress) {\n      this.handleCancel()\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(event: Event) {\n    const input = event.target as HTMLInputElement\n    this.altTextChange.emit(input.value)\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 h-full object-cover border-2 border-gray-300 rounded-lg\"\n        [alt]=\"altText\"\n        loading=\"lazy\"\n        [src]=\"previewUrl\"\n      />\n      <gn-ui-button\n        [extraClass]=\"\n          'bg-gray-200 absolute right-2 bottom-2 invisible group-hover:visible'\n        \"\n        (buttonClick)=\"handleDelete()\"\n      >\n        <mat-icon class=\"material-symbols-outlined\">delete</mat-icon>\n      </gn-ui-button>\n    </div>\n    <input\n      *ngIf=\"showAltTextInput\"\n      type=\"text\"\n      class=\"py-3 px-2 border-2 border-gray-300 rounded-lg text-sm font-medium\"\n      [placeholder]=\"'input.image.altTextPlaceholder' | translate\"\n      [value]=\"altText\"\n      (change)=\"handleAltTextChange($event)\"\n    />\n    <div class=\"flex flex-row gap-2\">\n      <gn-ui-button\n        [extraClass]=\"'bg-gray-200 font-bold'\"\n        (buttonClick)=\"handleDelete()\"\n      >\n        <mat-icon class=\"material-symbols-outlined me-1\">delete</mat-icon>\n        {{ 'input.image.delete' | translate }}\n      </gn-ui-button>\n      <gn-ui-button\n        *ngIf=\"!showAltTextInput\"\n        [extraClass]=\"'bg-gray-200 font-bold'\"\n        (buttonClick)=\"toggleAltTextInput()\"\n      >\n        <mat-icon class=\"material-symbols-outlined me-1\">add</mat-icon>\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=\"block flex-1 border-2 border-dashed border-gray-300 rounded-lg p-6 flex flex-col items-center justify-center gap-4\"\n      (dragFilesOver)=\"handleDragFilesOver($event)\"\n      (dropFiles)=\"handleDropFiles($event)\"\n    >\n      <div class=\"w-14 h-14 rounded-md bg-gray-200 grid\">\n        <mat-icon\n          *ngIf=\"!dragFilesOver && !uploadProgress && !uploadError\"\n          class=\"material-symbols-outlined place-self-center text-blue-500\"\n          >image</mat-icon\n        >\n        <mat-icon\n          *ngIf=\"dragFilesOver && !uploadProgress && !uploadError\"\n          class=\"material-symbols-outlined place-self-center text-blue-500\"\n          >add_box</mat-icon\n        >\n        <div *ngIf=\"uploadProgress\">\n          <mat-progress-spinner\n            class=\"place-self-center\"\n            [diameter]=\"56\"\n            [mode]=\"'determinate'\"\n            [value]=\"uploadProgress\"\n          ></mat-progress-spinner>\n          <span\n            class=\"text-sm font-medium relative inline-block width-[30px] bottom-[40px] left-[15px]\"\n          >\n            {{ uploadProgress }}%\n          </span>\n        </div>\n        <mat-icon\n          *ngIf=\"uploadError\"\n          class=\"material-symbols-outlined place-self-center text-rose-500\"\n          >broken_image</mat-icon\n        >\n      </div>\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            uploadProgress || uploadError\n              ? 'font-bold text-blue-500 cursor-pointer'\n              : 'font-medium text-gray-500'\n          \"\n          (click)=\"handleSecondaryTextClick()\"\n        >\n          {{ getSecondaryText() | translate }}\n        </p>\n      </div>\n      <input\n        type=\"file\"\n        class=\"hidden\"\n        (change)=\"handleFileInput($event)\"\n        [disabled]=\"showUrlInput || uploadProgress || uploadError\"\n      />\n    </label>\n    <div *ngIf=\"!showUrlInput\" class=\"flex-none\">\n      <gn-ui-button\n        [extraClass]=\"'bg-gray-200 font-bold'\"\n        (buttonClick)=\"displayUrlInput()\"\n      >\n        <mat-icon class=\"material-symbols-outlined me-1\">link</mat-icon>\n        {{ 'input.image.displayUrlInput' | translate }}\n      </gn-ui-button>\n    </div>\n    <div *ngIf=\"showUrlInput\" class=\"flex-none flex flex-col gap-2\">\n      <div class=\"h-2\"></div>\n      <div class=\"flex gap-2 items-center\">\n        <div class=\"flex-1 flex rounded-lg\">\n          <span\n            class=\"material-symbols-outlined px-4 inline-flex items-center min-w-fit rounded-s-lg border-2 border-e-0 border-gray-300\"\n            >link</span\n          >\n          <input\n            type=\"text\"\n            class=\"py-3 ps-1 block w-full border-2 border-s-0 border-e-0 border-gray-300 text-sm font-medium\"\n            placeholder=\"https://exemple.com/image.jpg\"\n            (change)=\"handleUrlChange($event)\"\n          />\n          <gn-ui-button\n            class=\"px-1 inline-flex items-center min-w-fit rounded-e-lg border-2 border-s-0 border-gray-300 text-white\"\n            [extraClass]=\"\n              urlInputValue && !downloadError ? 'bg-blue-500' : 'bg-gray-500'\n            \"\n            [disabled]=\"!urlInputValue || downloadError\"\n            (buttonClick)=\"downloadUrl()\"\n          >\n            <mat-icon class=\"material-symbols-outlined\">arrow_upward</mat-icon>\n          </gn-ui-button>\n        </div>\n      </div>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
@@ -33,6 +33,7 @@ import { MatInputModule } from '@angular/material/input';
|
|
|
33
33
|
import { MatDatepickerModule } from '@angular/material/datepicker';
|
|
34
34
|
import { MatNativeDateModule } from '@angular/material/core';
|
|
35
35
|
import { EditableLabelDirective } from './editable-label/editable-label.directive';
|
|
36
|
+
import { ImageInputComponent } from './image-input/image-input.component';
|
|
36
37
|
import * as i0 from "@angular/core";
|
|
37
38
|
import * as i1 from "@ngx-translate/core";
|
|
38
39
|
export class UiInputsModule {
|
|
@@ -75,7 +76,8 @@ export class UiInputsModule {
|
|
|
75
76
|
MatNativeDateModule,
|
|
76
77
|
EditableLabelDirective,
|
|
77
78
|
TextAreaComponent,
|
|
78
|
-
ButtonComponent
|
|
79
|
+
ButtonComponent,
|
|
80
|
+
ImageInputComponent], exports: [DropdownSelectorComponent,
|
|
79
81
|
AutocompleteComponent,
|
|
80
82
|
ButtonComponent,
|
|
81
83
|
TextInputComponent,
|
|
@@ -92,7 +94,8 @@ export class UiInputsModule {
|
|
|
92
94
|
CheckboxComponent,
|
|
93
95
|
SearchInputComponent,
|
|
94
96
|
DateRangePickerComponent,
|
|
95
|
-
EditableLabelDirective
|
|
97
|
+
EditableLabelDirective,
|
|
98
|
+
ImageInputComponent] }); }
|
|
96
99
|
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: UiInputsModule, imports: [CommonModule,
|
|
97
100
|
TranslateModule.forChild(),
|
|
98
101
|
NgxDropzoneModule,
|
|
@@ -109,7 +112,8 @@ export class UiInputsModule {
|
|
|
109
112
|
MatFormFieldModule,
|
|
110
113
|
MatInputModule,
|
|
111
114
|
MatDatepickerModule,
|
|
112
|
-
MatNativeDateModule
|
|
115
|
+
MatNativeDateModule,
|
|
116
|
+
ImageInputComponent] }); }
|
|
113
117
|
}
|
|
114
118
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImport: i0, type: UiInputsModule, decorators: [{
|
|
115
119
|
type: NgModule,
|
|
@@ -159,6 +163,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImpor
|
|
|
159
163
|
EditableLabelDirective,
|
|
160
164
|
TextAreaComponent,
|
|
161
165
|
ButtonComponent,
|
|
166
|
+
ImageInputComponent,
|
|
162
167
|
],
|
|
163
168
|
exports: [
|
|
164
169
|
DropdownSelectorComponent,
|
|
@@ -179,7 +184,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.7", ngImpor
|
|
|
179
184
|
SearchInputComponent,
|
|
180
185
|
DateRangePickerComponent,
|
|
181
186
|
EditableLabelDirective,
|
|
187
|
+
ImageInputComponent,
|
|
182
188
|
],
|
|
183
189
|
}]
|
|
184
190
|
}] });
|
|
185
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-inputs.module.js","sourceRoot":"","sources":["../../../../../../../libs/ui/inputs/src/lib/ui-inputs.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule } from '@angular/core'\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms'\nimport { UtilSharedModule } from '../../../../../libs/util/shared/src'\nimport { TranslateModule } from '@ngx-translate/core'\nimport { TagInputModule } from 'ngx-chips'\nimport { NgxDropzoneModule } from 'ngx-dropzone'\nimport { AutocompleteComponent } from './autocomplete/autocomplete.component'\nimport { ButtonComponent } from './button/button.component'\nimport { ChipsInputComponent } from './chips-input/chips-input.component'\nimport { DragAndDropFileInputComponent } from './drag-and-drop-file-input/drag-and-drop-file-input.component'\nimport { DropdownSelectorComponent } from './dropdown-selector/dropdown-selector.component'\nimport { TextAreaComponent } from './text-area/text-area.component'\nimport { TextInputComponent } from './text-input/text-input.component'\nimport { MatAutocompleteModule } from '@angular/material/autocomplete'\nimport { MatIconModule } from '@angular/material/icon'\nimport { NavigationButtonComponent } from './navigation-button/navigation-button.component'\nimport { StarToggleComponent } from './star-toggle/star-toggle.component'\nimport { DropdownMultiselectComponent } from './dropdown-multiselect/dropdown-multiselect.component'\nimport { UiWidgetsModule } from '../../../../../libs/ui/widgets/src'\nimport { OverlayModule } from '@angular/cdk/overlay'\nimport { MatCheckboxModule } from '@angular/material/checkbox'\nimport { ViewportIntersectorComponent } from './viewport-intersector/viewport-intersector.component'\nimport {\n  FormFieldArrayComponent,\n  FormFieldComponent,\n  FormFieldFileComponent,\n  FormFieldObjectComponent,\n  FormFieldRichComponent,\n  FormFieldSimpleComponent,\n  FormFieldSpatialExtentComponent,\n  FormFieldTemporalExtentComponent,\n} from './form-field'\nimport { CheckToggleComponent } from './check-toggle/check-toggle.component'\nimport { CopyTextButtonComponent } from './copy-text-button/copy-text-button.component'\nimport { MatTooltipModule } from '@angular/material/tooltip'\nimport { CommonModule } from '@angular/common'\nimport { CheckboxComponent } from './checkbox/checkbox.component'\nimport { SearchInputComponent } from './search-input/search-input.component'\nimport { DateRangePickerComponent } from './date-range-picker/date-range-picker.component'\nimport { MatFormFieldModule } from '@angular/material/form-field'\nimport { MatInputModule } from '@angular/material/input'\nimport { MatDatepickerModule } from '@angular/material/datepicker'\nimport { MatNativeDateModule } from '@angular/material/core'\nimport { EditableLabelDirective } from './editable-label/editable-label.directive'\n\n@NgModule({\n  declarations: [\n    DropdownSelectorComponent,\n    AutocompleteComponent,\n    TextInputComponent,\n    DragAndDropFileInputComponent,\n    ChipsInputComponent,\n    NavigationButtonComponent,\n    StarToggleComponent,\n    DropdownMultiselectComponent,\n    ViewportIntersectorComponent,\n    FormFieldComponent,\n    FormFieldSimpleComponent,\n    FormFieldArrayComponent,\n    FormFieldObjectComponent,\n    FormFieldRichComponent,\n    FormFieldFileComponent,\n    FormFieldSpatialExtentComponent,\n    FormFieldTemporalExtentComponent,\n    CheckToggleComponent,\n    CopyTextButtonComponent,\n    CheckboxComponent,\n    SearchInputComponent,\n    DateRangePickerComponent,\n  ],\n  imports: [\n    CommonModule,\n    TranslateModule.forChild(),\n    NgxDropzoneModule,\n    FormsModule,\n    ReactiveFormsModule,\n    TagInputModule,\n    UtilSharedModule,\n    MatAutocompleteModule,\n    MatIconModule,\n    UiWidgetsModule,\n    OverlayModule,\n    MatCheckboxModule,\n    MatTooltipModule,\n    MatFormFieldModule,\n    MatInputModule,\n    MatDatepickerModule,\n    MatNativeDateModule,\n    EditableLabelDirective,\n    TextAreaComponent,\n    ButtonComponent,\n  ],\n  exports: [\n    DropdownSelectorComponent,\n    AutocompleteComponent,\n    ButtonComponent,\n    TextInputComponent,\n    DragAndDropFileInputComponent,\n    TextAreaComponent,\n    ChipsInputComponent,\n    NavigationButtonComponent,\n    StarToggleComponent,\n    DropdownMultiselectComponent,\n    ViewportIntersectorComponent,\n    FormFieldComponent,\n    CheckToggleComponent,\n    CopyTextButtonComponent,\n    CheckboxComponent,\n    SearchInputComponent,\n    DateRangePickerComponent,\n    EditableLabelDirective,\n  ],\n})\nexport class UiInputsModule {}\n"]}
|
|
191
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-inputs.module.js","sourceRoot":"","sources":["../../../../../../../libs/ui/inputs/src/lib/ui-inputs.module.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAA;AACxC,OAAO,EAAE,WAAW,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAA;AACjE,OAAO,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAA;AACtE,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACrD,OAAO,EAAE,cAAc,EAAE,MAAM,WAAW,CAAA;AAC1C,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAA;AAChD,OAAO,EAAE,qBAAqB,EAAE,MAAM,uCAAuC,CAAA;AAC7E,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAC3D,OAAO,EAAE,mBAAmB,EAAE,MAAM,qCAAqC,CAAA;AACzE,OAAO,EAAE,6BAA6B,EAAE,MAAM,+DAA+D,CAAA;AAC7G,OAAO,EAAE,yBAAyB,EAAE,MAAM,iDAAiD,CAAA;AAC3F,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AACnE,OAAO,EAAE,kBAAkB,EAAE,MAAM,mCAAmC,CAAA;AACtE,OAAO,EAAE,qBAAqB,EAAE,MAAM,gCAAgC,CAAA;AACtE,OAAO,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAA;AACtD,OAAO,EAAE,yBAAyB,EAAE,MAAM,iDAAiD,CAAA;AAC3F,OAAO,EAAE,mBAAmB,EAAE,MAAM,qCAAqC,CAAA;AACzE,OAAO,EAAE,4BAA4B,EAAE,MAAM,uDAAuD,CAAA;AACpG,OAAO,EAAE,eAAe,EAAE,MAAM,oCAAoC,CAAA;AACpE,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AACpD,OAAO,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAA;AAC9D,OAAO,EAAE,4BAA4B,EAAE,MAAM,uDAAuD,CAAA;AACpG,OAAO,EACL,uBAAuB,EACvB,kBAAkB,EAClB,sBAAsB,EACtB,wBAAwB,EACxB,sBAAsB,EACtB,wBAAwB,EACxB,+BAA+B,EAC/B,gCAAgC,GACjC,MAAM,cAAc,CAAA;AACrB,OAAO,EAAE,oBAAoB,EAAE,MAAM,uCAAuC,CAAA;AAC5E,OAAO,EAAE,uBAAuB,EAAE,MAAM,+CAA+C,CAAA;AACvF,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAA;AAC5D,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAA;AAC9C,OAAO,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAA;AACjE,OAAO,EAAE,oBAAoB,EAAE,MAAM,uCAAuC,CAAA;AAC5E,OAAO,EAAE,wBAAwB,EAAE,MAAM,iDAAiD,CAAA;AAC1F,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAA;AACjE,OAAO,EAAE,cAAc,EAAE,MAAM,yBAAyB,CAAA;AACxD,OAAO,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAA;AAClE,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAA;AAC5D,OAAO,EAAE,sBAAsB,EAAE,MAAM,2CAA2C,CAAA;AAClF,OAAO,EAAE,mBAAmB,EAAE,MAAM,qCAAqC,CAAA;;;AAwEzE,MAAM,OAAO,cAAc;8GAAd,cAAc;+GAAd,cAAc,iBApEvB,yBAAyB;YACzB,qBAAqB;YACrB,kBAAkB;YAClB,6BAA6B;YAC7B,mBAAmB;YACnB,yBAAyB;YACzB,mBAAmB;YACnB,4BAA4B;YAC5B,4BAA4B;YAC5B,kBAAkB;YAClB,wBAAwB;YACxB,uBAAuB;YACvB,wBAAwB;YACxB,sBAAsB;YACtB,sBAAsB;YACtB,+BAA+B;YAC/B,gCAAgC;YAChC,oBAAoB;YACpB,uBAAuB;YACvB,iBAAiB;YACjB,oBAAoB;YACpB,wBAAwB,aAGxB,YAAY,sBAEZ,iBAAiB;YACjB,WAAW;YACX,mBAAmB;YACnB,cAAc;YACd,gBAAgB;YAChB,qBAAqB;YACrB,aAAa;YACb,eAAe;YACf,aAAa;YACb,iBAAiB;YACjB,gBAAgB;YAChB,kBAAkB;YAClB,cAAc;YACd,mBAAmB;YACnB,mBAAmB;YACnB,sBAAsB;YACtB,iBAAiB;YACjB,eAAe;YACf,mBAAmB,aAGnB,yBAAyB;YACzB,qBAAqB;YACrB,eAAe;YACf,kBAAkB;YAClB,6BAA6B;YAC7B,iBAAiB;YACjB,mBAAmB;YACnB,yBAAyB;YACzB,mBAAmB;YACnB,4BAA4B;YAC5B,4BAA4B;YAC5B,kBAAkB;YAClB,oBAAoB;YACpB,uBAAuB;YACvB,iBAAiB;YACjB,oBAAoB;YACpB,wBAAwB;YACxB,sBAAsB;YACtB,mBAAmB;+GAGV,cAAc,YA5CvB,YAAY;YACZ,eAAe,CAAC,QAAQ,EAAE;YAC1B,iBAAiB;YACjB,WAAW;YACX,mBAAmB;YACnB,cAAc;YACd,gBAAgB;YAChB,qBAAqB;YACrB,aAAa;YACb,eAAe;YACf,aAAa;YACb,iBAAiB;YACjB,gBAAgB;YAChB,kBAAkB;YAClB,cAAc;YACd,mBAAmB;YACnB,mBAAmB;YAInB,mBAAmB;;2FAwBV,cAAc;kBAtE1B,QAAQ;mBAAC;oBACR,YAAY,EAAE;wBACZ,yBAAyB;wBACzB,qBAAqB;wBACrB,kBAAkB;wBAClB,6BAA6B;wBAC7B,mBAAmB;wBACnB,yBAAyB;wBACzB,mBAAmB;wBACnB,4BAA4B;wBAC5B,4BAA4B;wBAC5B,kBAAkB;wBAClB,wBAAwB;wBACxB,uBAAuB;wBACvB,wBAAwB;wBACxB,sBAAsB;wBACtB,sBAAsB;wBACtB,+BAA+B;wBAC/B,gCAAgC;wBAChC,oBAAoB;wBACpB,uBAAuB;wBACvB,iBAAiB;wBACjB,oBAAoB;wBACpB,wBAAwB;qBACzB;oBACD,OAAO,EAAE;wBACP,YAAY;wBACZ,eAAe,CAAC,QAAQ,EAAE;wBAC1B,iBAAiB;wBACjB,WAAW;wBACX,mBAAmB;wBACnB,cAAc;wBACd,gBAAgB;wBAChB,qBAAqB;wBACrB,aAAa;wBACb,eAAe;wBACf,aAAa;wBACb,iBAAiB;wBACjB,gBAAgB;wBAChB,kBAAkB;wBAClB,cAAc;wBACd,mBAAmB;wBACnB,mBAAmB;wBACnB,sBAAsB;wBACtB,iBAAiB;wBACjB,eAAe;wBACf,mBAAmB;qBACpB;oBACD,OAAO,EAAE;wBACP,yBAAyB;wBACzB,qBAAqB;wBACrB,eAAe;wBACf,kBAAkB;wBAClB,6BAA6B;wBAC7B,iBAAiB;wBACjB,mBAAmB;wBACnB,yBAAyB;wBACzB,mBAAmB;wBACnB,4BAA4B;wBAC5B,4BAA4B;wBAC5B,kBAAkB;wBAClB,oBAAoB;wBACpB,uBAAuB;wBACvB,iBAAiB;wBACjB,oBAAoB;wBACpB,wBAAwB;wBACxB,sBAAsB;wBACtB,mBAAmB;qBACpB;iBACF","sourcesContent":["import { NgModule } from '@angular/core'\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms'\nimport { UtilSharedModule } from '../../../../../libs/util/shared/src'\nimport { TranslateModule } from '@ngx-translate/core'\nimport { TagInputModule } from 'ngx-chips'\nimport { NgxDropzoneModule } from 'ngx-dropzone'\nimport { AutocompleteComponent } from './autocomplete/autocomplete.component'\nimport { ButtonComponent } from './button/button.component'\nimport { ChipsInputComponent } from './chips-input/chips-input.component'\nimport { DragAndDropFileInputComponent } from './drag-and-drop-file-input/drag-and-drop-file-input.component'\nimport { DropdownSelectorComponent } from './dropdown-selector/dropdown-selector.component'\nimport { TextAreaComponent } from './text-area/text-area.component'\nimport { TextInputComponent } from './text-input/text-input.component'\nimport { MatAutocompleteModule } from '@angular/material/autocomplete'\nimport { MatIconModule } from '@angular/material/icon'\nimport { NavigationButtonComponent } from './navigation-button/navigation-button.component'\nimport { StarToggleComponent } from './star-toggle/star-toggle.component'\nimport { DropdownMultiselectComponent } from './dropdown-multiselect/dropdown-multiselect.component'\nimport { UiWidgetsModule } from '../../../../../libs/ui/widgets/src'\nimport { OverlayModule } from '@angular/cdk/overlay'\nimport { MatCheckboxModule } from '@angular/material/checkbox'\nimport { ViewportIntersectorComponent } from './viewport-intersector/viewport-intersector.component'\nimport {\n  FormFieldArrayComponent,\n  FormFieldComponent,\n  FormFieldFileComponent,\n  FormFieldObjectComponent,\n  FormFieldRichComponent,\n  FormFieldSimpleComponent,\n  FormFieldSpatialExtentComponent,\n  FormFieldTemporalExtentComponent,\n} from './form-field'\nimport { CheckToggleComponent } from './check-toggle/check-toggle.component'\nimport { CopyTextButtonComponent } from './copy-text-button/copy-text-button.component'\nimport { MatTooltipModule } from '@angular/material/tooltip'\nimport { CommonModule } from '@angular/common'\nimport { CheckboxComponent } from './checkbox/checkbox.component'\nimport { SearchInputComponent } from './search-input/search-input.component'\nimport { DateRangePickerComponent } from './date-range-picker/date-range-picker.component'\nimport { MatFormFieldModule } from '@angular/material/form-field'\nimport { MatInputModule } from '@angular/material/input'\nimport { MatDatepickerModule } from '@angular/material/datepicker'\nimport { MatNativeDateModule } from '@angular/material/core'\nimport { EditableLabelDirective } from './editable-label/editable-label.directive'\nimport { ImageInputComponent } from './image-input/image-input.component'\n\n@NgModule({\n  declarations: [\n    DropdownSelectorComponent,\n    AutocompleteComponent,\n    TextInputComponent,\n    DragAndDropFileInputComponent,\n    ChipsInputComponent,\n    NavigationButtonComponent,\n    StarToggleComponent,\n    DropdownMultiselectComponent,\n    ViewportIntersectorComponent,\n    FormFieldComponent,\n    FormFieldSimpleComponent,\n    FormFieldArrayComponent,\n    FormFieldObjectComponent,\n    FormFieldRichComponent,\n    FormFieldFileComponent,\n    FormFieldSpatialExtentComponent,\n    FormFieldTemporalExtentComponent,\n    CheckToggleComponent,\n    CopyTextButtonComponent,\n    CheckboxComponent,\n    SearchInputComponent,\n    DateRangePickerComponent,\n  ],\n  imports: [\n    CommonModule,\n    TranslateModule.forChild(),\n    NgxDropzoneModule,\n    FormsModule,\n    ReactiveFormsModule,\n    TagInputModule,\n    UtilSharedModule,\n    MatAutocompleteModule,\n    MatIconModule,\n    UiWidgetsModule,\n    OverlayModule,\n    MatCheckboxModule,\n    MatTooltipModule,\n    MatFormFieldModule,\n    MatInputModule,\n    MatDatepickerModule,\n    MatNativeDateModule,\n    EditableLabelDirective,\n    TextAreaComponent,\n    ButtonComponent,\n    ImageInputComponent,\n  ],\n  exports: [\n    DropdownSelectorComponent,\n    AutocompleteComponent,\n    ButtonComponent,\n    TextInputComponent,\n    DragAndDropFileInputComponent,\n    TextAreaComponent,\n    ChipsInputComponent,\n    NavigationButtonComponent,\n    StarToggleComponent,\n    DropdownMultiselectComponent,\n    ViewportIntersectorComponent,\n    FormFieldComponent,\n    CheckToggleComponent,\n    CopyTextButtonComponent,\n    CheckboxComponent,\n    SearchInputComponent,\n    DateRangePickerComponent,\n    EditableLabelDirective,\n    ImageInputComponent,\n  ],\n})\nexport class UiInputsModule {}\n"]}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export function megabytesToBytes(megabytes) {
|
|
2
|
+
return megabytes * 1048576;
|
|
3
|
+
}
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnl0ZXMtY29udmVydC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvdXRpbC9zaGFyZWQvc3JjL2xpYi91dGlscy9ieXRlcy1jb252ZXJ0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sVUFBVSxnQkFBZ0IsQ0FBQyxTQUFTO0lBQ3hDLE9BQU8sU0FBUyxHQUFHLE9BQU8sQ0FBQTtBQUM1QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGZ1bmN0aW9uIG1lZ2FieXRlc1RvQnl0ZXMobWVnYWJ5dGVzKSB7XG4gIHJldHVybiBtZWdhYnl0ZXMgKiAxMDQ4NTc2XG59XG4iXX0=
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
export function downsizeImage(blob, maxWidth, maxHeight) {
|
|
2
|
+
return new Promise((resolve, reject) => {
|
|
3
|
+
const image = new Image();
|
|
4
|
+
image.src = URL.createObjectURL(blob);
|
|
5
|
+
image.onload = () => {
|
|
6
|
+
let width = image.width;
|
|
7
|
+
let height = image.height;
|
|
8
|
+
if (width > maxWidth || height > maxHeight) {
|
|
9
|
+
if (width > height) {
|
|
10
|
+
height = height * (maxWidth / width);
|
|
11
|
+
width = maxWidth;
|
|
12
|
+
}
|
|
13
|
+
else {
|
|
14
|
+
width = width * (maxHeight / height);
|
|
15
|
+
height = maxHeight;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
const canvas = document.createElement('canvas');
|
|
19
|
+
canvas.width = width;
|
|
20
|
+
canvas.height = height;
|
|
21
|
+
const context = canvas.getContext('2d');
|
|
22
|
+
context.drawImage(image, 0, 0, width, height);
|
|
23
|
+
canvas.toBlob(resolve, blob.type);
|
|
24
|
+
};
|
|
25
|
+
image.onerror = reject;
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
export function downgradeImage(blob, maxSizeBytes) {
|
|
29
|
+
return new Promise((resolve, reject) => {
|
|
30
|
+
const image = new Image();
|
|
31
|
+
image.src = URL.createObjectURL(blob);
|
|
32
|
+
image.onload = () => {
|
|
33
|
+
const width = image.width;
|
|
34
|
+
const height = image.height;
|
|
35
|
+
let quality = 1.0;
|
|
36
|
+
const canvas = document.createElement('canvas');
|
|
37
|
+
canvas.width = width;
|
|
38
|
+
canvas.height = height;
|
|
39
|
+
const context = canvas.getContext('2d');
|
|
40
|
+
context.drawImage(image, 0, 0, width, height);
|
|
41
|
+
const compressAndResolveBlob = (blobToCompress) => {
|
|
42
|
+
if (blobToCompress.size <= maxSizeBytes) {
|
|
43
|
+
resolve(blobToCompress);
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
quality -= 0.1;
|
|
47
|
+
if (quality >= 0) {
|
|
48
|
+
canvas.toBlob(compressAndResolveBlob, blob.type, quality);
|
|
49
|
+
}
|
|
50
|
+
else {
|
|
51
|
+
reject('Unable to compress image below max size');
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
};
|
|
55
|
+
canvas.toBlob(compressAndResolveBlob, blob.type, quality);
|
|
56
|
+
};
|
|
57
|
+
image.onerror = reject;
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1hZ2UtcmVzaXplLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy91dGlsL3NoYXJlZC9zcmMvbGliL3V0aWxzL2ltYWdlLXJlc2l6ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLFVBQVUsYUFBYSxDQUMzQixJQUFVLEVBQ1YsUUFBZ0IsRUFDaEIsU0FBaUI7SUFFakIsT0FBTyxJQUFJLE9BQU8sQ0FBQyxDQUFDLE9BQU8sRUFBRSxNQUFNLEVBQUUsRUFBRTtRQUNyQyxNQUFNLEtBQUssR0FBRyxJQUFJLEtBQUssRUFBRSxDQUFBO1FBQ3pCLEtBQUssQ0FBQyxHQUFHLEdBQUcsR0FBRyxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsQ0FBQTtRQUNyQyxLQUFLLENBQUMsTUFBTSxHQUFHLEdBQUcsRUFBRTtZQUNsQixJQUFJLEtBQUssR0FBRyxLQUFLLENBQUMsS0FBSyxDQUFBO1lBQ3ZCLElBQUksTUFBTSxHQUFHLEtBQUssQ0FBQyxNQUFNLENBQUE7WUFFekIsSUFBSSxLQUFLLEdBQUcsUUFBUSxJQUFJLE1BQU0sR0FBRyxTQUFTLEVBQUU7Z0JBQzFDLElBQUksS0FBSyxHQUFHLE1BQU0sRUFBRTtvQkFDbEIsTUFBTSxHQUFHLE1BQU0sR0FBRyxDQUFDLFFBQVEsR0FBRyxLQUFLLENBQUMsQ0FBQTtvQkFDcEMsS0FBSyxHQUFHLFFBQVEsQ0FBQTtpQkFDakI7cUJBQU07b0JBQ0wsS0FBSyxHQUFHLEtBQUssR0FBRyxDQUFDLFNBQVMsR0FBRyxNQUFNLENBQUMsQ0FBQTtvQkFDcEMsTUFBTSxHQUFHLFNBQVMsQ0FBQTtpQkFDbkI7YUFDRjtZQUVELE1BQU0sTUFBTSxHQUFHLFFBQVEsQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLENBQUE7WUFDL0MsTUFBTSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUE7WUFDcEIsTUFBTSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUE7WUFFdEIsTUFBTSxPQUFPLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQTtZQUN2QyxPQUFPLENBQUMsU0FBUyxDQUFDLEtBQUssRUFBRSxDQUFDLEVBQUUsQ0FBQyxFQUFFLEtBQUssRUFBRSxNQUFNLENBQUMsQ0FBQTtZQUU3QyxNQUFNLENBQUMsTUFBTSxDQUFDLE9BQU8sRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUE7UUFDbkMsQ0FBQyxDQUFBO1FBQ0QsS0FBSyxDQUFDLE9BQU8sR0FBRyxNQUFNLENBQUE7SUFDeEIsQ0FBQyxDQUFDLENBQUE7QUFDSixDQUFDO0FBRUQsTUFBTSxVQUFVLGNBQWMsQ0FDNUIsSUFBVSxFQUNWLFlBQW9CO0lBRXBCLE9BQU8sSUFBSSxPQUFPLENBQUMsQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLEVBQUU7UUFDckMsTUFBTSxLQUFLLEdBQUcsSUFBSSxLQUFLLEVBQUUsQ0FBQTtRQUN6QixLQUFLLENBQUMsR0FBRyxHQUFHLEdBQUcsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLENBQUE7UUFDckMsS0FBSyxDQUFDLE1BQU0sR0FBRyxHQUFHLEVBQUU7WUFDbEIsTUFBTSxLQUFLLEdBQUcsS0FBSyxDQUFDLEtBQUssQ0FBQTtZQUN6QixNQUFNLE1BQU0sR0FBRyxLQUFLLENBQUMsTUFBTSxDQUFBO1lBQzNCLElBQUksT0FBTyxHQUFHLEdBQUcsQ0FBQTtZQUVqQixNQUFNLE1BQU0sR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxDQUFBO1lBQy9DLE1BQU0sQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFBO1lBQ3BCLE1BQU0sQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFBO1lBRXRCLE1BQU0sT0FBTyxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUE7WUFDdkMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxFQUFFLENBQUMsRUFBRSxLQUFLLEVBQUUsTUFBTSxDQUFDLENBQUE7WUFFN0MsTUFBTSxzQkFBc0IsR0FBRyxDQUFDLGNBQW9CLEVBQUUsRUFBRTtnQkFDdEQsSUFBSSxjQUFjLENBQUMsSUFBSSxJQUFJLFlBQVksRUFBRTtvQkFDdkMsT0FBTyxDQUFDLGNBQWMsQ0FBQyxDQUFBO2lCQUN4QjtxQkFBTTtvQkFDTCxPQUFPLElBQUksR0FBRyxDQUFBO29CQUNkLElBQUksT0FBTyxJQUFJLENBQUMsRUFBRTt3QkFDaEIsTUFBTSxDQUFDLE1BQU0sQ0FBQyxzQkFBc0IsRUFBRSxJQUFJLENBQUMsSUFBSSxFQUFFLE9BQU8sQ0FBQyxDQUFBO3FCQUMxRDt5QkFBTTt3QkFDTCxNQUFNLENBQUMseUNBQXlDLENBQUMsQ0FBQTtxQkFDbEQ7aUJBQ0Y7WUFDSCxDQUFDLENBQUE7WUFFRCxNQUFNLENBQUMsTUFBTSxDQUFDLHNCQUFzQixFQUFFLElBQUksQ0FBQyxJQUFJLEVBQUUsT0FBTyxDQUFDLENBQUE7UUFDM0QsQ0FBQyxDQUFBO1FBQ0QsS0FBSyxDQUFDLE9BQU8sR0FBRyxNQUFNLENBQUE7SUFDeEIsQ0FBQyxDQUFDLENBQUE7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGZ1bmN0aW9uIGRvd25zaXplSW1hZ2UoXG4gIGJsb2I6IEJsb2IsXG4gIG1heFdpZHRoOiBudW1iZXIsXG4gIG1heEhlaWdodDogbnVtYmVyXG4pOiBQcm9taXNlPEJsb2I+IHtcbiAgcmV0dXJuIG5ldyBQcm9taXNlKChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICBjb25zdCBpbWFnZSA9IG5ldyBJbWFnZSgpXG4gICAgaW1hZ2Uuc3JjID0gVVJMLmNyZWF0ZU9iamVjdFVSTChibG9iKVxuICAgIGltYWdlLm9ubG9hZCA9ICgpID0+IHtcbiAgICAgIGxldCB3aWR0aCA9IGltYWdlLndpZHRoXG4gICAgICBsZXQgaGVpZ2h0ID0gaW1hZ2UuaGVpZ2h0XG5cbiAgICAgIGlmICh3aWR0aCA+IG1heFdpZHRoIHx8IGhlaWdodCA+IG1heEhlaWdodCkge1xuICAgICAgICBpZiAod2lkdGggPiBoZWlnaHQpIHtcbiAgICAgICAgICBoZWlnaHQgPSBoZWlnaHQgKiAobWF4V2lkdGggLyB3aWR0aClcbiAgICAgICAgICB3aWR0aCA9IG1heFdpZHRoXG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgd2lkdGggPSB3aWR0aCAqIChtYXhIZWlnaHQgLyBoZWlnaHQpXG4gICAgICAgICAgaGVpZ2h0ID0gbWF4SGVpZ2h0XG4gICAgICAgIH1cbiAgICAgIH1cblxuICAgICAgY29uc3QgY2FudmFzID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgnY2FudmFzJylcbiAgICAgIGNhbnZhcy53aWR0aCA9IHdpZHRoXG4gICAgICBjYW52YXMuaGVpZ2h0ID0gaGVpZ2h0XG5cbiAgICAgIGNvbnN0IGNvbnRleHQgPSBjYW52YXMuZ2V0Q29udGV4dCgnMmQnKVxuICAgICAgY29udGV4dC5kcmF3SW1hZ2UoaW1hZ2UsIDAsIDAsIHdpZHRoLCBoZWlnaHQpXG5cbiAgICAgIGNhbnZhcy50b0Jsb2IocmVzb2x2ZSwgYmxvYi50eXBlKVxuICAgIH1cbiAgICBpbWFnZS5vbmVycm9yID0gcmVqZWN0XG4gIH0pXG59XG5cbmV4cG9ydCBmdW5jdGlvbiBkb3duZ3JhZGVJbWFnZShcbiAgYmxvYjogQmxvYixcbiAgbWF4U2l6ZUJ5dGVzOiBudW1iZXJcbik6IFByb21pc2U8QmxvYj4ge1xuICByZXR1cm4gbmV3IFByb21pc2UoKHJlc29sdmUsIHJlamVjdCkgPT4ge1xuICAgIGNvbnN0IGltYWdlID0gbmV3IEltYWdlKClcbiAgICBpbWFnZS5zcmMgPSBVUkwuY3JlYXRlT2JqZWN0VVJMKGJsb2IpXG4gICAgaW1hZ2Uub25sb2FkID0gKCkgPT4ge1xuICAgICAgY29uc3Qgd2lkdGggPSBpbWFnZS53aWR0aFxuICAgICAgY29uc3QgaGVpZ2h0ID0gaW1hZ2UuaGVpZ2h0XG4gICAgICBsZXQgcXVhbGl0eSA9IDEuMFxuXG4gICAgICBjb25zdCBjYW52YXMgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KCdjYW52YXMnKVxuICAgICAgY2FudmFzLndpZHRoID0gd2lkdGhcbiAgICAgIGNhbnZhcy5oZWlnaHQgPSBoZWlnaHRcblxuICAgICAgY29uc3QgY29udGV4dCA9IGNhbnZhcy5nZXRDb250ZXh0KCcyZCcpXG4gICAgICBjb250ZXh0LmRyYXdJbWFnZShpbWFnZSwgMCwgMCwgd2lkdGgsIGhlaWdodClcblxuICAgICAgY29uc3QgY29tcHJlc3NBbmRSZXNvbHZlQmxvYiA9IChibG9iVG9Db21wcmVzczogQmxvYikgPT4ge1xuICAgICAgICBpZiAoYmxvYlRvQ29tcHJlc3Muc2l6ZSA8PSBtYXhTaXplQnl0ZXMpIHtcbiAgICAgICAgICByZXNvbHZlKGJsb2JUb0NvbXByZXNzKVxuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIHF1YWxpdHkgLT0gMC4xXG4gICAgICAgICAgaWYgKHF1YWxpdHkgPj0gMCkge1xuICAgICAgICAgICAgY2FudmFzLnRvQmxvYihjb21wcmVzc0FuZFJlc29sdmVCbG9iLCBibG9iLnR5cGUsIHF1YWxpdHkpXG4gICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHJlamVjdCgnVW5hYmxlIHRvIGNvbXByZXNzIGltYWdlIGJlbG93IG1heCBzaXplJylcbiAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgIH1cblxuICAgICAgY2FudmFzLnRvQmxvYihjb21wcmVzc0FuZFJlc29sdmVCbG9iLCBibG9iLnR5cGUsIHF1YWxpdHkpXG4gICAgfVxuICAgIGltYWdlLm9uZXJyb3IgPSByZWplY3RcbiAgfSlcbn1cbiJdfQ==
|
|
@@ -1,10 +1,12 @@
|
|
|
1
|
+
export * from './bytes-convert';
|
|
2
|
+
export * from './event';
|
|
3
|
+
export * from './fuzzy-filter';
|
|
4
|
+
export * from './geojson';
|
|
5
|
+
export * from './image-resize';
|
|
1
6
|
export * from './parse';
|
|
2
|
-
export * from './strip-html';
|
|
3
7
|
export * from './remove-whitespace';
|
|
4
|
-
export * from './geojson';
|
|
5
8
|
export * from './sort-by';
|
|
6
|
-
export * from './
|
|
7
|
-
export * from './event';
|
|
8
|
-
export * from './fuzzy-filter';
|
|
9
|
+
export * from './strip-html';
|
|
9
10
|
export * from './temporal-extent-union';
|
|
10
|
-
|
|
11
|
+
export * from './url';
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL3V0aWwvc2hhcmVkL3NyYy9saWIvdXRpbHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxpQkFBaUIsQ0FBQTtBQUMvQixjQUFjLFNBQVMsQ0FBQTtBQUN2QixjQUFjLGdCQUFnQixDQUFBO0FBQzlCLGNBQWMsV0FBVyxDQUFBO0FBQ3pCLGNBQWMsZ0JBQWdCLENBQUE7QUFDOUIsY0FBYyxTQUFTLENBQUE7QUFDdkIsY0FBYyxxQkFBcUIsQ0FBQTtBQUNuQyxjQUFjLFdBQVcsQ0FBQTtBQUN6QixjQUFjLGNBQWMsQ0FBQTtBQUM1QixjQUFjLHlCQUF5QixDQUFBO0FBQ3ZDLGNBQWMsT0FBTyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9ieXRlcy1jb252ZXJ0J1xuZXhwb3J0ICogZnJvbSAnLi9ldmVudCdcbmV4cG9ydCAqIGZyb20gJy4vZnV6enktZmlsdGVyJ1xuZXhwb3J0ICogZnJvbSAnLi9nZW9qc29uJ1xuZXhwb3J0ICogZnJvbSAnLi9pbWFnZS1yZXNpemUnXG5leHBvcnQgKiBmcm9tICcuL3BhcnNlJ1xuZXhwb3J0ICogZnJvbSAnLi9yZW1vdmUtd2hpdGVzcGFjZSdcbmV4cG9ydCAqIGZyb20gJy4vc29ydC1ieSdcbmV4cG9ydCAqIGZyb20gJy4vc3RyaXAtaHRtbCdcbmV4cG9ydCAqIGZyb20gJy4vdGVtcG9yYWwtZXh0ZW50LXVuaW9uJ1xuZXhwb3J0ICogZnJvbSAnLi91cmwnXG4iXX0=
|
|
@@ -159,6 +159,16 @@
|
|
|
159
159
|
"facets.block.title.tag.default": "Stichwort",
|
|
160
160
|
"facets.block.title.th_regions_tree.default": "Regionen",
|
|
161
161
|
"favorite.not.authenticated.tooltip": "<div><a href=' {link} '>Anmelden</a>, um auf diese Funktion zuzugreifen</div>",
|
|
162
|
+
"input.image.altTextPlaceholder": "",
|
|
163
|
+
"input.image.delete": "",
|
|
164
|
+
"input.image.displayAltTextInput": "",
|
|
165
|
+
"input.image.displayUrlInput": "",
|
|
166
|
+
"input.image.dropFileLabel": "",
|
|
167
|
+
"input.image.selectFileLabel": "",
|
|
168
|
+
"input.image.uploadErrorLabel": "",
|
|
169
|
+
"input.image.uploadErrorRetry": "",
|
|
170
|
+
"input.image.uploadProgressCancel": "",
|
|
171
|
+
"input.image.uploadProgressLabel": "",
|
|
162
172
|
"language.ca": "Katalanisch",
|
|
163
173
|
"language.cs": "Tschechisch",
|
|
164
174
|
"language.de": "Deutsch",
|
|
@@ -159,6 +159,16 @@
|
|
|
159
159
|
"facets.block.title.tag.default": "Tag",
|
|
160
160
|
"facets.block.title.th_regions_tree.default": "Regions",
|
|
161
161
|
"favorite.not.authenticated.tooltip": "<div><a href=' {link} '>Login</a> to access this feature</div>",
|
|
162
|
+
"input.image.altTextPlaceholder": "Image alternate text",
|
|
163
|
+
"input.image.delete": "Delete",
|
|
164
|
+
"input.image.displayAltTextInput": "Alternate text",
|
|
165
|
+
"input.image.displayUrlInput": "Enter a URL",
|
|
166
|
+
"input.image.dropFileLabel": "or drop it here",
|
|
167
|
+
"input.image.selectFileLabel": "Select an image",
|
|
168
|
+
"input.image.uploadErrorLabel": "The image could not be uploaded",
|
|
169
|
+
"input.image.uploadErrorRetry": "Retry",
|
|
170
|
+
"input.image.uploadProgressCancel": "Cancel",
|
|
171
|
+
"input.image.uploadProgressLabel": "Upload in progress...",
|
|
162
172
|
"language.ca": "Catalan",
|
|
163
173
|
"language.cs": "Czech",
|
|
164
174
|
"language.de": "German",
|
|
@@ -159,6 +159,16 @@
|
|
|
159
159
|
"facets.block.title.tag.default": "",
|
|
160
160
|
"facets.block.title.th_regions_tree.default": "",
|
|
161
161
|
"favorite.not.authenticated.tooltip": "",
|
|
162
|
+
"input.image.altTextPlaceholder": "",
|
|
163
|
+
"input.image.delete": "",
|
|
164
|
+
"input.image.displayAltTextInput": "",
|
|
165
|
+
"input.image.displayUrlInput": "",
|
|
166
|
+
"input.image.dropFileLabel": "",
|
|
167
|
+
"input.image.selectFileLabel": "",
|
|
168
|
+
"input.image.uploadErrorLabel": "",
|
|
169
|
+
"input.image.uploadErrorRetry": "",
|
|
170
|
+
"input.image.uploadProgressCancel": "",
|
|
171
|
+
"input.image.uploadProgressLabel": "",
|
|
162
172
|
"language.ca": "Catalán",
|
|
163
173
|
"language.cs": "Checo",
|
|
164
174
|
"language.de": "Alemán",
|
|
@@ -159,6 +159,16 @@
|
|
|
159
159
|
"facets.block.title.tag.default": "Tag",
|
|
160
160
|
"facets.block.title.th_regions_tree.default": "Régions",
|
|
161
161
|
"favorite.not.authenticated.tooltip": "<div><a href=' {link} '>Connectez-vous</a> pour avoir accès à cette fonctionnalité</div>",
|
|
162
|
+
"input.image.altTextPlaceholder": "Texte alternatif de l'image",
|
|
163
|
+
"input.image.delete": "Supprimer",
|
|
164
|
+
"input.image.displayAltTextInput": "Texte alternatif",
|
|
165
|
+
"input.image.displayUrlInput": "Saisir une URL",
|
|
166
|
+
"input.image.dropFileLabel": "ou la glisser ici",
|
|
167
|
+
"input.image.selectFileLabel": "Sélectionner une image",
|
|
168
|
+
"input.image.uploadErrorLabel": "L'image n'a pas pu être chargée",
|
|
169
|
+
"input.image.uploadErrorRetry": "Réessayer",
|
|
170
|
+
"input.image.uploadProgressCancel": "Annuler",
|
|
171
|
+
"input.image.uploadProgressLabel": "Chargement en cours...",
|
|
162
172
|
"language.ca": "Catalan",
|
|
163
173
|
"language.cs": "Tchèque",
|
|
164
174
|
"language.de": "Allemand",
|
|
@@ -159,6 +159,16 @@
|
|
|
159
159
|
"facets.block.title.tag.default": "Tag",
|
|
160
160
|
"facets.block.title.th_regions_tree.default": "Regioni",
|
|
161
161
|
"favorite.not.authenticated.tooltip": "<div><a href=' {link} '>Login</a> per accedere a questa funzionalità</div>",
|
|
162
|
+
"input.image.altTextPlaceholder": "",
|
|
163
|
+
"input.image.delete": "",
|
|
164
|
+
"input.image.displayAltTextInput": "",
|
|
165
|
+
"input.image.displayUrlInput": "",
|
|
166
|
+
"input.image.dropFileLabel": "",
|
|
167
|
+
"input.image.selectFileLabel": "",
|
|
168
|
+
"input.image.uploadErrorLabel": "",
|
|
169
|
+
"input.image.uploadErrorRetry": "",
|
|
170
|
+
"input.image.uploadProgressCancel": "",
|
|
171
|
+
"input.image.uploadProgressLabel": "",
|
|
162
172
|
"language.ca": "Catalano",
|
|
163
173
|
"language.cs": "Ceco",
|
|
164
174
|
"language.de": "Tedesco",
|
|
@@ -159,6 +159,16 @@
|
|
|
159
159
|
"facets.block.title.tag.default": "",
|
|
160
160
|
"facets.block.title.th_regions_tree.default": "",
|
|
161
161
|
"favorite.not.authenticated.tooltip": "",
|
|
162
|
+
"input.image.altTextPlaceholder": "",
|
|
163
|
+
"input.image.delete": "",
|
|
164
|
+
"input.image.displayAltTextInput": "",
|
|
165
|
+
"input.image.displayUrlInput": "",
|
|
166
|
+
"input.image.dropFileLabel": "",
|
|
167
|
+
"input.image.selectFileLabel": "",
|
|
168
|
+
"input.image.uploadErrorLabel": "",
|
|
169
|
+
"input.image.uploadErrorRetry": "",
|
|
170
|
+
"input.image.uploadProgressCancel": "",
|
|
171
|
+
"input.image.uploadProgressLabel": "",
|
|
162
172
|
"language.ca": "Catalaans",
|
|
163
173
|
"language.cs": "Tsjechisch",
|
|
164
174
|
"language.de": "Duits",
|
|
@@ -159,6 +159,16 @@
|
|
|
159
159
|
"facets.block.title.tag.default": "",
|
|
160
160
|
"facets.block.title.th_regions_tree.default": "",
|
|
161
161
|
"favorite.not.authenticated.tooltip": "",
|
|
162
|
+
"input.image.altTextPlaceholder": "",
|
|
163
|
+
"input.image.delete": "",
|
|
164
|
+
"input.image.displayAltTextInput": "",
|
|
165
|
+
"input.image.displayUrlInput": "",
|
|
166
|
+
"input.image.dropFileLabel": "",
|
|
167
|
+
"input.image.selectFileLabel": "",
|
|
168
|
+
"input.image.uploadErrorLabel": "",
|
|
169
|
+
"input.image.uploadErrorRetry": "",
|
|
170
|
+
"input.image.uploadProgressCancel": "",
|
|
171
|
+
"input.image.uploadProgressLabel": "",
|
|
162
172
|
"language.ca": "Catalão",
|
|
163
173
|
"language.cs": "Tcheco",
|
|
164
174
|
"language.de": "Alemão",
|