@eui/components 18.2.0-snapshot-1726189861918 → 18.2.0-snapshot-1726671866540
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/docs/components/EuiDatepickerComponent.html +37 -0
- package/docs/components/EuiFilePreviewComponent.html +112 -448
- package/docs/components/EuiFileUploadComponent.html +157 -1
- package/docs/dependencies.html +2 -2
- package/docs/injectables/EuiFileUploadUtilsService.html +70 -0
- package/docs/js/menu-wc.js +9 -9
- package/docs/js/menu-wc_es5.js +1 -1
- package/docs/js/search/search_index.js +2 -2
- package/docs/modules/EuiFileUploadModule.html +9 -0
- package/esm2022/eui-datepicker/eui-datepicker.component.mjs +6 -3
- package/esm2022/eui-file-upload/eui-file-upload.component.mjs +39 -5
- package/esm2022/eui-file-upload/eui-file-upload.module.mjs +6 -5
- package/esm2022/eui-file-upload/file-preview/file-preview.component.mjs +42 -63
- package/esm2022/eui-file-upload/index.mjs +2 -1
- package/esm2022/eui-file-upload/utils/eui-file-upload.utils.mjs +34 -1
- package/eui-datepicker/eui-datepicker.component.d.ts +2 -1
- package/eui-datepicker/eui-datepicker.component.d.ts.map +1 -1
- package/eui-file-upload/eui-file-upload.component.d.ts +31 -3
- package/eui-file-upload/eui-file-upload.component.d.ts.map +1 -1
- package/eui-file-upload/eui-file-upload.module.d.ts +2 -1
- package/eui-file-upload/eui-file-upload.module.d.ts.map +1 -1
- package/eui-file-upload/file-preview/file-preview.component.d.ts +29 -25
- package/eui-file-upload/file-preview/file-preview.component.d.ts.map +1 -1
- package/eui-file-upload/index.d.ts +1 -0
- package/eui-file-upload/index.d.ts.map +1 -1
- package/eui-file-upload/utils/eui-file-upload.utils.d.ts +6 -0
- package/eui-file-upload/utils/eui-file-upload.utils.d.ts.map +1 -1
- package/fesm2022/eui-components-eui-datepicker.mjs +5 -2
- package/fesm2022/eui-components-eui-datepicker.mjs.map +1 -1
- package/fesm2022/eui-components-eui-file-upload.mjs +116 -71
- package/fesm2022/eui-components-eui-file-upload.mjs.map +1 -1
- package/package.json +3 -3
@@ -6,4 +6,5 @@ export * from './eui-file-upload.component';
|
|
6
6
|
export * from './utils/eui-file-upload.utils';
|
7
7
|
export * from './utils/eui-file-upload.validators';
|
8
8
|
export * from './models/uploaded-file.model';
|
9
|
-
|
9
|
+
export * from './pipes/filesize.pipe';
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9ldWktZmlsZS11cGxvYWQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLCtDQUErQyxDQUFDO0FBQzlELGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsdUJBQXVCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2V1aS1maWxlLXVwbG9hZC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9wcm9ncmVzcy9ldWktZmlsZS11cGxvYWQtcHJvZ3Jlc3MuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vZmlsZS1wcmV2aWV3L2ZpbGUtcHJldmlldy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9ldWktZmlsZS11cGxvYWQubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vZXVpLWZpbGUtdXBsb2FkLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3V0aWxzL2V1aS1maWxlLXVwbG9hZC51dGlscyc7XG5leHBvcnQgKiBmcm9tICcuL3V0aWxzL2V1aS1maWxlLXVwbG9hZC52YWxpZGF0b3JzJztcbmV4cG9ydCAqIGZyb20gJy4vbW9kZWxzL3VwbG9hZGVkLWZpbGUubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9waXBlcy9maWxlc2l6ZS5waXBlJztcbiJdfQ==
|
@@ -91,6 +91,39 @@ export class EuiFileUploadUtilsService {
|
|
91
91
|
toResponseBody() {
|
92
92
|
return pipe(filter((event) => event.type === HttpEventType.Response), map((res) => res.body));
|
93
93
|
}
|
94
|
+
/**
|
95
|
+
* Return the icon to be used with eui-icon-svg of the given extension or a default file icon
|
96
|
+
* @param fileExtension
|
97
|
+
* @returns Icon name as string
|
98
|
+
*/
|
99
|
+
getIconForExtension(fileExtension) {
|
100
|
+
const previewAsIconConfig = {
|
101
|
+
avi: 'eui-file-video',
|
102
|
+
html: 'eui-file-html',
|
103
|
+
htm: 'eui-file-code',
|
104
|
+
js: 'eui-file-code',
|
105
|
+
json: 'eui-file-code',
|
106
|
+
mp3: 'eui-file-audio',
|
107
|
+
mp4: 'eui-file-video',
|
108
|
+
pdf: 'eui-file-pdf',
|
109
|
+
png: 'eui-file-image',
|
110
|
+
svg: 'eui-file-image',
|
111
|
+
txt: 'eui-file-text',
|
112
|
+
xml: 'eui-file-code',
|
113
|
+
jpeg: 'eui-file-image',
|
114
|
+
jpg: 'eui-file-image',
|
115
|
+
zip: 'eui-file-archive',
|
116
|
+
doc: 'eui-file-word',
|
117
|
+
docx: 'eui-file-word-o',
|
118
|
+
xls: 'eui-file-excel-o',
|
119
|
+
xlsx: 'eui-file-excel-o',
|
120
|
+
ppt: 'eui-file-powerpoint',
|
121
|
+
csv: 'eui-file-text',
|
122
|
+
rtf: 'eui-file-text',
|
123
|
+
};
|
124
|
+
const f = fileExtension.toLowerCase();
|
125
|
+
return !previewAsIconConfig[f] ? 'eui-file-empty-o' : previewAsIconConfig[f];
|
126
|
+
}
|
94
127
|
// TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html
|
95
128
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
96
129
|
toFormData(formValue) {
|
@@ -131,4 +164,4 @@ export class EuiFileUploadUtilsService {
|
|
131
164
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: EuiFileUploadUtilsService, decorators: [{
|
132
165
|
type: Injectable
|
133
166
|
}], ctorParameters: () => [{ type: i1.HttpClient }] });
|
134
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-file-upload.utils.js","sourceRoot":"","sources":["../../../../eui-file-upload/utils/eui-file-upload.utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { HttpClient, HttpEvent, HttpEventType, HttpResponse } from '@angular/common/http';\nimport { filter, map, tap } from 'rxjs/operators';\nimport { pipe, Observable, UnaryFunction, MonoTypeOperatorFunction } from 'rxjs';\n\n@Injectable()\nexport class EuiFileUploadUtilsService {\n    constructor(private httpClient: HttpClient) {}\n\n    /**\n     * @param data Data to send to backend\n     * @param APIEndPoint Endpoint URL\n     *\n     * @description\n     * Method that will format data in `FormData` and send them to backend.\n     *\n     * @usageNotes\n     * Call the method and log the response in the console.\n     *\n     * ```typescript\n     * this.euiFileUploadUtilsService.sendData(this.form.value, 'http://localhost:3000/api/fake-api').pipe(\n     *     this.euiFileUploadUtilsService.uploadProgress((progress) => {\n     *         console.log(progress);\n     *     }),\n     *     this.euiFileUploadUtilsService.toResponseBody(),\n     * ).subscribe((response) => {\n     *      console.log(response);\n     * });\n     * ```\n     *\n     * @returns The backend response.\n     */\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    public sendData(data: any, APIEndPoint: string): Observable<any> {\n        return this.httpClient.post(APIEndPoint, this.toFormData(data), {\n            reportProgress: true,\n            observe: 'events',\n        });\n    }\n\n    /**\n     * @param cb A method to execute on each progress step.\n     *\n     * @description\n     * Method that will return the upload progress.\n     *\n     * @usageNotes\n     * Call the method and log the progress in the console.\n     *\n     * ```typescript\n     * this.euiFileUploadUtilsService.sendData(this.form.value, 'http://localhost:3000/api/fake-api').pipe(\n     *     this.euiFileUploadUtilsService.uploadProgress((progress) => {\n     *         console.log(progress);\n     *     }),\n     *     this.euiFileUploadUtilsService.toResponseBody(),\n     * ).subscribe((response) => {\n     *      console.log(response);\n     * });\n     * ```\n     *\n     * @returns A number between 0 and 100.\n     */\n    public uploadProgress<T>(cb: (progress: number) => void): MonoTypeOperatorFunction<HttpEvent<T>> {\n        return tap((event: HttpEvent<T>) => {\n            if (event.type === HttpEventType.UploadProgress) {\n                cb(Math.round((100 * event.loaded) / event.total));\n            }\n        });\n    }\n\n    /**\n     * @description\n     * Method that will return only the body of the backend response.\n     *\n     * @usageNotes\n     * Call the method and log the response in the console.\n     *\n     * ```typescript\n     * this.euiFileUploadUtilsService.sendData(this.form.value, 'http://localhost:3000/api/fake-api').pipe(\n     *     this.euiFileUploadUtilsService.uploadProgress((progress) => {\n     *         console.log(progress);\n     *     }),\n     *     this.euiFileUploadUtilsService.toResponseBody(),\n     * ).subscribe((response) => {\n     *      console.log(response);\n     * });\n     * ```\n     *\n     * @returns The backend response.\n     */\n    public toResponseBody<T>(): UnaryFunction<Observable<HttpEvent<T>>, Observable<T>> {\n        return pipe(\n            filter((event: HttpEvent<T>) => event.type === HttpEventType.Response),\n            map((res: HttpResponse<T>) => res.body),\n        );\n    }\n\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    private toFormData(formValue: any): FormData {\n        const formData = new FormData();\n\n        for (const key of Object.keys(formValue)) {\n            if (Array.isArray(formValue[key])) {\n                let fileIndex = 0;\n                // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n                // eslint-disable-next-line @typescript-eslint/no-explicit-any\n                formValue[key].forEach((value: any) => {\n                    if (value instanceof File) {\n                        formData.append(key + fileIndex, value);\n                        fileIndex++;\n                    }\n                });\n\n                const a = [];\n                // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n                // eslint-disable-next-line @typescript-eslint/no-explicit-any\n                formValue[key].forEach((value: any): void => {\n                    a.push(value);\n                });\n\n                formData.append(key, JSON.stringify(a));\n            } else {\n                if (typeof formValue[key] === 'string') {\n                    formData.set(key, formValue[key]);\n                } else {\n                    formData.set(key, JSON.stringify(formValue[key]));\n                }\n            }\n        }\n\n        return formData;\n    }\n}\n"]}
|
167
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eui-file-upload.utils.js","sourceRoot":"","sources":["../../../../eui-file-upload/utils/eui-file-upload.utils.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EAAyB,aAAa,EAAgB,MAAM,sBAAsB,CAAC;AAC1F,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AAClD,OAAO,EAAE,IAAI,EAAuD,MAAM,MAAM,CAAC;;;AAGjF,MAAM,OAAO,yBAAyB;IAClC,YAAoB,UAAsB;QAAtB,eAAU,GAAV,UAAU,CAAY;IAAG,CAAC;IAE9C;;;;;;;;;;;;;;;;;;;;;;OAsBG;IACH,mHAAmH;IACnH,8DAA8D;IACvD,QAAQ,CAAC,IAAS,EAAE,WAAmB;QAC1C,OAAO,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE;YAC5D,cAAc,EAAE,IAAI;YACpB,OAAO,EAAE,QAAQ;SACpB,CAAC,CAAC;IACP,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;OAqBG;IACI,cAAc,CAAI,EAA8B;QACnD,OAAO,GAAG,CAAC,CAAC,KAAmB,EAAE,EAAE;YAC/B,IAAI,KAAK,CAAC,IAAI,KAAK,aAAa,CAAC,cAAc,EAAE,CAAC;gBAC9C,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,GAAG,KAAK,CAAC,MAAM,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;YACvD,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAED;;;;;;;;;;;;;;;;;;;OAmBG;IACI,cAAc;QACjB,OAAO,IAAI,CACP,MAAM,CAAC,CAAC,KAAmB,EAAE,EAAE,CAAC,KAAK,CAAC,IAAI,KAAK,aAAa,CAAC,QAAQ,CAAC,EACtE,GAAG,CAAC,CAAC,GAAoB,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAC1C,CAAC;IACN,CAAC;IAED;;;;OAIG;IACI,mBAAmB,CAAC,aAAqB;QAC5C,MAAM,mBAAmB,GAAG;YACxB,GAAG,EAAE,gBAAgB;YACrB,IAAI,EAAE,eAAe;YACrB,GAAG,EAAE,eAAe;YACpB,EAAE,EAAE,eAAe;YACnB,IAAI,EAAE,eAAe;YACrB,GAAG,EAAE,gBAAgB;YACrB,GAAG,EAAE,gBAAgB;YACrB,GAAG,EAAE,cAAc;YACnB,GAAG,EAAE,gBAAgB;YACrB,GAAG,EAAE,gBAAgB;YACrB,GAAG,EAAE,eAAe;YACpB,GAAG,EAAE,eAAe;YACpB,IAAI,EAAE,gBAAgB;YACtB,GAAG,EAAE,gBAAgB;YACrB,GAAG,EAAE,kBAAkB;YACvB,GAAG,EAAE,eAAe;YACpB,IAAI,EAAE,iBAAiB;YACvB,GAAG,EAAE,kBAAkB;YACvB,IAAI,EAAE,kBAAkB;YACxB,GAAG,EAAE,qBAAqB;YAC1B,GAAG,EAAE,eAAe;YACpB,GAAG,EAAE,eAAe;SACvB,CAAC;QAEF,MAAM,CAAC,GAAG,aAAa,CAAC,WAAW,EAAE,CAAC;QACtC,OAAO,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,mBAAmB,CAAC,CAAC,CAAC,CAAC;IACjF,CAAC;IAED,mHAAmH;IACnH,8DAA8D;IACtD,UAAU,CAAC,SAAc;QAC7B,MAAM,QAAQ,GAAG,IAAI,QAAQ,EAAE,CAAC;QAEhC,KAAK,MAAM,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC;YACvC,IAAI,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;gBAChC,IAAI,SAAS,GAAG,CAAC,CAAC;gBAClB,mHAAmH;gBACnH,8DAA8D;gBAC9D,SAAS,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,KAAU,EAAE,EAAE;oBAClC,IAAI,KAAK,YAAY,IAAI,EAAE,CAAC;wBACxB,QAAQ,CAAC,MAAM,CAAC,GAAG,GAAG,SAAS,EAAE,KAAK,CAAC,CAAC;wBACxC,SAAS,EAAE,CAAC;oBAChB,CAAC;gBACL,CAAC,CAAC,CAAC;gBAEH,MAAM,CAAC,GAAG,EAAE,CAAC;gBACb,mHAAmH;gBACnH,8DAA8D;gBAC9D,SAAS,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,KAAU,EAAQ,EAAE;oBACxC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAClB,CAAC,CAAC,CAAC;gBAEH,QAAQ,CAAC,MAAM,CAAC,GAAG,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;YAC5C,CAAC;iBAAM,CAAC;gBACJ,IAAI,OAAO,SAAS,CAAC,GAAG,CAAC,KAAK,QAAQ,EAAE,CAAC;oBACrC,QAAQ,CAAC,GAAG,CAAC,GAAG,EAAE,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC;gBACtC,CAAC;qBAAM,CAAC;oBACJ,QAAQ,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;gBACtD,CAAC;YACL,CAAC;QACL,CAAC;QAED,OAAO,QAAQ,CAAC;IACpB,CAAC;8GAlKQ,yBAAyB;kHAAzB,yBAAyB;;2FAAzB,yBAAyB;kBADrC,UAAU","sourcesContent":["import { Injectable } from '@angular/core';\nimport { HttpClient, HttpEvent, HttpEventType, HttpResponse } from '@angular/common/http';\nimport { filter, map, tap } from 'rxjs/operators';\nimport { pipe, Observable, UnaryFunction, MonoTypeOperatorFunction } from 'rxjs';\n\n@Injectable()\nexport class EuiFileUploadUtilsService {\n    constructor(private httpClient: HttpClient) {}\n\n    /**\n     * @param data Data to send to backend\n     * @param APIEndPoint Endpoint URL\n     *\n     * @description\n     * Method that will format data in `FormData` and send them to backend.\n     *\n     * @usageNotes\n     * Call the method and log the response in the console.\n     *\n     * ```typescript\n     * this.euiFileUploadUtilsService.sendData(this.form.value, 'http://localhost:3000/api/fake-api').pipe(\n     *     this.euiFileUploadUtilsService.uploadProgress((progress) => {\n     *         console.log(progress);\n     *     }),\n     *     this.euiFileUploadUtilsService.toResponseBody(),\n     * ).subscribe((response) => {\n     *      console.log(response);\n     * });\n     * ```\n     *\n     * @returns The backend response.\n     */\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    public sendData(data: any, APIEndPoint: string): Observable<any> {\n        return this.httpClient.post(APIEndPoint, this.toFormData(data), {\n            reportProgress: true,\n            observe: 'events',\n        });\n    }\n\n    /**\n     * @param cb A method to execute on each progress step.\n     *\n     * @description\n     * Method that will return the upload progress.\n     *\n     * @usageNotes\n     * Call the method and log the progress in the console.\n     *\n     * ```typescript\n     * this.euiFileUploadUtilsService.sendData(this.form.value, 'http://localhost:3000/api/fake-api').pipe(\n     *     this.euiFileUploadUtilsService.uploadProgress((progress) => {\n     *         console.log(progress);\n     *     }),\n     *     this.euiFileUploadUtilsService.toResponseBody(),\n     * ).subscribe((response) => {\n     *      console.log(response);\n     * });\n     * ```\n     *\n     * @returns A number between 0 and 100.\n     */\n    public uploadProgress<T>(cb: (progress: number) => void): MonoTypeOperatorFunction<HttpEvent<T>> {\n        return tap((event: HttpEvent<T>) => {\n            if (event.type === HttpEventType.UploadProgress) {\n                cb(Math.round((100 * event.loaded) / event.total));\n            }\n        });\n    }\n\n    /**\n     * @description\n     * Method that will return only the body of the backend response.\n     *\n     * @usageNotes\n     * Call the method and log the response in the console.\n     *\n     * ```typescript\n     * this.euiFileUploadUtilsService.sendData(this.form.value, 'http://localhost:3000/api/fake-api').pipe(\n     *     this.euiFileUploadUtilsService.uploadProgress((progress) => {\n     *         console.log(progress);\n     *     }),\n     *     this.euiFileUploadUtilsService.toResponseBody(),\n     * ).subscribe((response) => {\n     *      console.log(response);\n     * });\n     * ```\n     *\n     * @returns The backend response.\n     */\n    public toResponseBody<T>(): UnaryFunction<Observable<HttpEvent<T>>, Observable<T>> {\n        return pipe(\n            filter((event: HttpEvent<T>) => event.type === HttpEventType.Response),\n            map((res: HttpResponse<T>) => res.body),\n        );\n    }\n\n    /**\n     * Return the icon to be used with eui-icon-svg of the given extension or a default file icon\n     * @param fileExtension \n     * @returns Icon name as string\n     */\n    public getIconForExtension(fileExtension: string): string {\n        const previewAsIconConfig = {\n            avi: 'eui-file-video',\n            html: 'eui-file-html',\n            htm: 'eui-file-code',\n            js: 'eui-file-code',\n            json: 'eui-file-code',\n            mp3: 'eui-file-audio',\n            mp4: 'eui-file-video',\n            pdf: 'eui-file-pdf',\n            png: 'eui-file-image',\n            svg: 'eui-file-image',\n            txt: 'eui-file-text',\n            xml: 'eui-file-code',\n            jpeg: 'eui-file-image',\n            jpg: 'eui-file-image',\n            zip: 'eui-file-archive',\n            doc: 'eui-file-word',\n            docx: 'eui-file-word-o',\n            xls: 'eui-file-excel-o',\n            xlsx: 'eui-file-excel-o',\n            ppt: 'eui-file-powerpoint',\n            csv: 'eui-file-text',\n            rtf: 'eui-file-text',\n        };\n\n        const f = fileExtension.toLowerCase();\n        return !previewAsIconConfig[f] ? 'eui-file-empty-o' : previewAsIconConfig[f];\n    }\n\n    // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    private toFormData(formValue: any): FormData {\n        const formData = new FormData();\n\n        for (const key of Object.keys(formValue)) {\n            if (Array.isArray(formValue[key])) {\n                let fileIndex = 0;\n                // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n                // eslint-disable-next-line @typescript-eslint/no-explicit-any\n                formValue[key].forEach((value: any) => {\n                    if (value instanceof File) {\n                        formData.append(key + fileIndex, value);\n                        fileIndex++;\n                    }\n                });\n\n                const a = [];\n                // TODO: find the correct type or turn into a generic, https://www.typescriptlang.org/docs/handbook/2/generics.html\n                // eslint-disable-next-line @typescript-eslint/no-explicit-any\n                formValue[key].forEach((value: any): void => {\n                    a.push(value);\n                });\n\n                formData.append(key, JSON.stringify(a));\n            } else {\n                if (typeof formValue[key] === 'string') {\n                    formData.set(key, formValue[key]);\n                } else {\n                    formData.set(key, JSON.stringify(formValue[key]));\n                }\n            }\n        }\n\n        return formData;\n    }\n}\n"]}
|
@@ -1,4 +1,4 @@
|
|
1
|
-
import { ApplicationRef, ComponentFactoryResolver, EventEmitter, Injector, OnChanges, OnDestroy, DoCheck, OnInit, SimpleChanges, AfterViewInit, TemplateRef, ViewContainerRef } from '@angular/core';
|
1
|
+
import { ApplicationRef, ComponentFactoryResolver, EventEmitter, Injector, OnChanges, OnDestroy, DoCheck, OnInit, SimpleChanges, AfterViewInit, TemplateRef, ViewContainerRef, ElementRef } from '@angular/core';
|
2
2
|
import { ControlValueAccessor, FormControl, NgControl } from '@angular/forms';
|
3
3
|
import { DateAdapter } from '@angular/material/core';
|
4
4
|
import { MatCalendarCellClassFunction, MatDatepicker, MatDatepickerInputEvent } from '@angular/material/datepicker';
|
@@ -30,6 +30,7 @@ export declare class EuiDatepickerComponent implements OnInit, AfterViewInit, Co
|
|
30
30
|
timePickerInstance: EuiTimepickerComponent;
|
31
31
|
calendar: MatDatepicker<any>;
|
32
32
|
templatePortalRef: TemplateRef<EuiActionButtonsDirective>;
|
33
|
+
inputRef: ElementRef<HTMLInputElement>;
|
33
34
|
euiActionButtons: EuiActionButtonsDirective;
|
34
35
|
inputChange: EventEmitter<any>;
|
35
36
|
dateSelect: EventEmitter<any>;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"eui-datepicker.component.d.ts","sourceRoot":"","sources":["../../eui-datepicker/eui-datepicker.component.ts"],"names":[],"mappings":"AACA,OAAO,EACH,cAAc,EAEd,wBAAwB,EACxB,YAAY,EAEZ,QAAQ,EAER,SAAS,EACT,SAAS,EACT,OAAO,EACP,MAAM,EAIN,aAAa,EAQb,aAAa,EACb,WAAW,EACX,gBAAgB,
|
1
|
+
{"version":3,"file":"eui-datepicker.component.d.ts","sourceRoot":"","sources":["../../eui-datepicker/eui-datepicker.component.ts"],"names":[],"mappings":"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"}
|
@@ -1,8 +1,9 @@
|
|
1
|
-
import { ElementRef, OnInit, QueryList, EventEmitter } from '@angular/core';
|
1
|
+
import { ElementRef, OnInit, QueryList, EventEmitter, AfterViewInit, TemplateRef } from '@angular/core';
|
2
2
|
import { ControlValueAccessor } from '@angular/forms';
|
3
|
+
import { EuiTemplateDirective } from '@eui/components/directives';
|
3
4
|
import { EuiUploadedFileInterface } from './models/uploaded-file.model';
|
4
5
|
import * as i0 from "@angular/core";
|
5
|
-
export declare class EuiFileUploadComponent implements ControlValueAccessor, OnInit {
|
6
|
+
export declare class EuiFileUploadComponent implements ControlValueAccessor, OnInit, AfterViewInit {
|
6
7
|
e2eAttr: string;
|
7
8
|
progress: number;
|
8
9
|
accept: string;
|
@@ -15,7 +16,22 @@ export declare class EuiFileUploadComponent implements ControlValueAccessor, OnI
|
|
15
16
|
randomNumberId: number;
|
16
17
|
uploadedFiles: EuiUploadedFileInterface[];
|
17
18
|
dragEntered: boolean;
|
19
|
+
templates: QueryList<EuiTemplateDirective>;
|
18
20
|
fileInputs: QueryList<ElementRef<HTMLInputElement>>;
|
21
|
+
uploadedFileTemplate: TemplateRef<{
|
22
|
+
$implicit: {
|
23
|
+
file: EuiUploadedFileInterface;
|
24
|
+
index: number;
|
25
|
+
isFileObject: boolean;
|
26
|
+
};
|
27
|
+
}>;
|
28
|
+
browseButtonTemplate: TemplateRef<HTMLElement>;
|
29
|
+
resetButtonTemplate: TemplateRef<HTMLElement>;
|
30
|
+
progressBarTemplate: TemplateRef<{
|
31
|
+
$implicit: {
|
32
|
+
progress: number;
|
33
|
+
};
|
34
|
+
}>;
|
19
35
|
isMultiple: boolean;
|
20
36
|
hasProgressBar: boolean;
|
21
37
|
hasPreview: boolean;
|
@@ -29,10 +45,22 @@ export declare class EuiFileUploadComponent implements ControlValueAccessor, OnI
|
|
29
45
|
get showResetBtn(): boolean;
|
30
46
|
get isDropAreaDisabled(): boolean;
|
31
47
|
ngOnInit(): void;
|
48
|
+
ngAfterViewInit(): void;
|
32
49
|
onDragEnter(): void;
|
33
50
|
onDragLeave(): void;
|
51
|
+
/**
|
52
|
+
* Remove a file from the array of files choosen by the user.
|
53
|
+
* @param index Index of the file to remove in the array.
|
54
|
+
*/
|
34
55
|
removeFromList(index: number): void;
|
56
|
+
/**
|
57
|
+
* Remove a file from the array of files provided to the component as existing values.
|
58
|
+
* @param index Index of the file to remove in the array.
|
59
|
+
*/
|
35
60
|
removeFromUploadedList(index: number): void;
|
61
|
+
/**
|
62
|
+
* Reset the list of files in the component.
|
63
|
+
*/
|
36
64
|
resetList(): void;
|
37
65
|
openBrowseWindow(): void;
|
38
66
|
onItemClick(e: Blob | EuiUploadedFileInterface | any): void;
|
@@ -42,7 +70,7 @@ export declare class EuiFileUploadComponent implements ControlValueAccessor, OnI
|
|
42
70
|
private onChange;
|
43
71
|
private getTotalSize;
|
44
72
|
static ɵfac: i0.ɵɵFactoryDeclaration<EuiFileUploadComponent, never>;
|
45
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<EuiFileUploadComponent, "eui-file-upload", never, { "e2eAttr": { "alias": "e2eAttr"; "required": false; }; "progress": { "alias": "progress"; "required": false; }; "accept": { "alias": "accept"; "required": false; }; "maxFiles": { "alias": "maxFiles"; "required": false; }; "isMultiple": { "alias": "isMultiple"; "required": false; }; "hasProgressBar": { "alias": "hasProgressBar"; "required": false; }; "hasPreview": { "alias": "hasPreview"; "required": false; }; "hasPreviewAsImage": { "alias": "hasPreviewAsImage"; "required": false; }; "hasPreviewAsIcon": { "alias": "hasPreviewAsIcon"; "required": false; }; "hasTotalSizeDisplayed": { "alias": "hasTotalSizeDisplayed"; "required": false; }; "hasResetButton": { "alias": "hasResetButton"; "required": false; }; "hasDragArea": { "alias": "hasDragArea"; "required": false; }; "isItemsClickable": { "alias": "isItemsClickable"; "required": false; }; }, { "fileDrop": "fileDrop"; "itemClick": "itemClick"; },
|
73
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<EuiFileUploadComponent, "eui-file-upload", never, { "e2eAttr": { "alias": "e2eAttr"; "required": false; }; "progress": { "alias": "progress"; "required": false; }; "accept": { "alias": "accept"; "required": false; }; "maxFiles": { "alias": "maxFiles"; "required": false; }; "isMultiple": { "alias": "isMultiple"; "required": false; }; "hasProgressBar": { "alias": "hasProgressBar"; "required": false; }; "hasPreview": { "alias": "hasPreview"; "required": false; }; "hasPreviewAsImage": { "alias": "hasPreviewAsImage"; "required": false; }; "hasPreviewAsIcon": { "alias": "hasPreviewAsIcon"; "required": false; }; "hasTotalSizeDisplayed": { "alias": "hasTotalSizeDisplayed"; "required": false; }; "hasResetButton": { "alias": "hasResetButton"; "required": false; }; "hasDragArea": { "alias": "hasDragArea"; "required": false; }; "isItemsClickable": { "alias": "isItemsClickable"; "required": false; }; }, { "fileDrop": "fileDrop"; "itemClick": "itemClick"; }, ["templates"], ["*"], false, never>;
|
46
74
|
static ngAcceptInputType_isMultiple: unknown;
|
47
75
|
static ngAcceptInputType_hasProgressBar: unknown;
|
48
76
|
static ngAcceptInputType_hasPreview: unknown;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"eui-file-upload.component.d.ts","sourceRoot":"","sources":["../../eui-file-upload/eui-file-upload.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEH,UAAU,EAKV,MAAM,EAEN,SAAS,EAET,YAAY,
|
1
|
+
{"version":3,"file":"eui-file-upload.component.d.ts","sourceRoot":"","sources":["../../eui-file-upload/eui-file-upload.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEH,UAAU,EAKV,MAAM,EAEN,SAAS,EAET,YAAY,EAEZ,aAAa,EAEb,WAAW,EACd,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,oBAAoB,EAAqB,MAAM,gBAAgB,CAAC;AAEzE,OAAO,EAAE,oBAAoB,EAAE,MAAM,4BAA4B,CAAC;AAElE,OAAO,EAAE,wBAAwB,EAAE,MAAM,8BAA8B,CAAC;;AAExE,qBAaa,sBAAuB,YAAW,oBAAoB,EAAE,MAAM,EAAE,aAAa;IAC7E,OAAO,SAAqB;IAC5B,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,SAAO;IACb,QAAQ,EAAE,MAAM,CAAC;IAChB,QAAQ,oBAAsB;IAG9B,SAAS,oBAA6D;IAEhF,IACW,UAAU,IAAI,MAAM,CAM9B;IAEM,KAAK,EAAE,IAAI,EAAE,CAAM;IACnB,cAAc,SAAK;IACnB,cAAc,SAAqC;IACnD,aAAa,EAAE,wBAAwB,EAAE,CAAM;IAC/C,WAAW,UAAS;IAEY,SAAS,EAAE,SAAS,CAAC,oBAAoB,CAAC,CAAC;IAE3D,UAAU,EAAE,SAAS,CAAC,UAAU,CAAC,gBAAgB,CAAC,CAAC,CAAC;IAEpE,oBAAoB,EAAE,WAAW,CAAC;QAAE,SAAS,EAAE;YAAE,IAAI,EAAE,wBAAwB,CAAC;YAAC,KAAK,EAAE,MAAM,CAAC;YAAC,YAAY,EAAE,OAAO,CAAA;SAAE,CAAA;KAAE,CAAC,CAAC;IAC3H,oBAAoB,EAAE,WAAW,CAAC,WAAW,CAAC,CAAC;IAC/C,mBAAmB,EAAE,WAAW,CAAC,WAAW,CAAC,CAAC;IAC9C,mBAAmB,EAAE,WAAW,CAAC;QAAE,SAAS,EAAE;YAAE,QAAQ,EAAE,MAAM,CAAA;SAAE,CAAA;KAAE,CAAC,CAAC;IAErC,UAAU,UAAQ;IAClB,cAAc,UAAQ;IACtB,UAAU,UAAQ;IAClB,iBAAiB,UAAQ;IACzB,gBAAgB,UAAS;IACzB,qBAAqB,UAAQ;IAC7B,cAAc,UAAQ;IACtB,WAAW,UAAS;IACpB,gBAAgB,UAAS;IAEhB,SAAS,CAAC,QAAQ,EAAE,QAAQ,GAAG,IAAI;IA2BpF,IAAI,YAAY,IAAI,OAAO,CAE1B;IAED,IAAI,kBAAkB,IAAI,OAAO,CAEhC;IAED,QAAQ,IAAI,IAAI;IAMhB,eAAe,IAAI,IAAI;IAoBvB,WAAW,IAAI,IAAI;IAMnB,WAAW,IAAI,IAAI;IAInB;;;OAGG;IACI,cAAc,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAU1C;;;OAGG;IACI,sBAAsB,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAWlD;;OAEG;IACI,SAAS,IAAI,IAAI;IAQjB,gBAAgB,IAAI,IAAI;IAMxB,WAAW,CAAC,CAAC,EAAE,IAAI,GAAG,wBAAwB,GAAG,GAAG,GAAG,IAAI;IAMlE,UAAU,CAAC,KAAK,EAAE,GAAG,GAAG,IAAI;IAQ5B,gBAAgB,CAAC,EAAE,EAAE,GAAG,GAAG,IAAI;IAM/B,iBAAiB,CAAC,EAAE,EAAE,GAAG,GAAG,IAAI;IAIhC,OAAO,CAAC,QAAQ,CAAsD;IAEtE,OAAO,CAAC,YAAY;yCA3LX,sBAAsB;2CAAtB,sBAAsB;yCAkMkz2B,OAAQ;6CAAR,OAAQ;yCAAR,OAAQ;gDAAR,OAAQ;+CAAR,OAAQ;oDAAR,OAAQ;6CAAR,OAAQ;0CAAR,OAAQ;+CAAR,OAAQ;CAD512B"}
|
@@ -7,9 +7,10 @@ import * as i5 from "@angular/common";
|
|
7
7
|
import * as i6 from "@eui/components/eui-button";
|
8
8
|
import * as i7 from "@eui/components/eui-icon";
|
9
9
|
import * as i8 from "@ngx-translate/core";
|
10
|
+
import * as i9 from "@eui/components/directives";
|
10
11
|
export declare class EuiFileUploadModule {
|
11
12
|
static ɵfac: i0.ɵɵFactoryDeclaration<EuiFileUploadModule, never>;
|
12
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<EuiFileUploadModule, [typeof i1.EuiFileUploadComponent, typeof i2.EuiFileUploadProgressComponent, typeof i3.EuiFilePreviewComponent, typeof i4.EuiFileSizePipe], [typeof i5.CommonModule, typeof i6.EuiButtonModule, typeof i7.EuiIconModule, typeof i8.TranslateModule], [typeof i1.EuiFileUploadComponent]>;
|
13
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<EuiFileUploadModule, [typeof i1.EuiFileUploadComponent, typeof i2.EuiFileUploadProgressComponent, typeof i3.EuiFilePreviewComponent, typeof i4.EuiFileSizePipe], [typeof i5.CommonModule, typeof i6.EuiButtonModule, typeof i7.EuiIconModule, typeof i8.TranslateModule, typeof i9.EuiTemplateDirectiveModule], [typeof i1.EuiFileUploadComponent, typeof i4.EuiFileSizePipe, typeof i9.EuiTemplateDirectiveModule]>;
|
13
14
|
static ɵinj: i0.ɵɵInjectorDeclaration<EuiFileUploadModule>;
|
14
15
|
}
|
15
16
|
//# sourceMappingURL=eui-file-upload.module.d.ts.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"eui-file-upload.module.d.ts","sourceRoot":"","sources":["../../eui-file-upload/eui-file-upload.module.ts"],"names":[],"mappings":"
|
1
|
+
{"version":3,"file":"eui-file-upload.module.d.ts","sourceRoot":"","sources":["../../eui-file-upload/eui-file-upload.module.ts"],"names":[],"mappings":";;;;;;;;;;AAcA,qBAMa,mBAAmB;yCAAnB,mBAAmB;0CAAnB,mBAAmB;0CAAnB,mBAAmB;CAAG"}
|
@@ -1,10 +1,17 @@
|
|
1
|
-
import { OnInit, ChangeDetectorRef, EventEmitter } from '@angular/core';
|
2
|
-
import {
|
1
|
+
import { OnInit, ChangeDetectorRef, EventEmitter, QueryList, TemplateRef, AfterViewInit } from '@angular/core';
|
2
|
+
import { EuiTemplateDirective } from '@eui/components/directives';
|
3
3
|
import { EuiUploadedFileInterface } from '../models/uploaded-file.model';
|
4
4
|
import * as i0 from "@angular/core";
|
5
|
-
export declare class EuiFilePreviewComponent implements OnInit {
|
5
|
+
export declare class EuiFilePreviewComponent implements OnInit, AfterViewInit {
|
6
6
|
private cd;
|
7
7
|
file: Blob | EuiUploadedFileInterface | any;
|
8
|
+
uploadedFileTemplate: TemplateRef<{
|
9
|
+
$implicit: {
|
10
|
+
file: EuiUploadedFileInterface;
|
11
|
+
index: number;
|
12
|
+
isFileObject: boolean;
|
13
|
+
};
|
14
|
+
}>;
|
8
15
|
index: number;
|
9
16
|
previewAsIconConfig: {
|
10
17
|
avi: string;
|
@@ -40,35 +47,32 @@ export declare class EuiFilePreviewComponent implements OnInit {
|
|
40
47
|
};
|
41
48
|
isLoading: boolean;
|
42
49
|
itemClick: EventEmitter<any>;
|
43
|
-
|
44
|
-
|
45
|
-
|
46
|
-
|
47
|
-
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
get isFiletypeDisplayed(): boolean;
|
53
|
-
set isFiletypeDisplayed(value: BooleanInput);
|
54
|
-
private _isFiletypeDisplayed;
|
55
|
-
get hasPreviewAsImage(): boolean;
|
56
|
-
set hasPreviewAsImage(value: BooleanInput);
|
57
|
-
private _hasPreviewAsImage;
|
58
|
-
get hasPreviewAsIcon(): boolean;
|
59
|
-
set hasPreviewAsIcon(value: BooleanInput);
|
60
|
-
private _hasPreviewAsIcon;
|
61
|
-
get isItemsClickable(): boolean;
|
62
|
-
set isItemsClickable(value: BooleanInput);
|
63
|
-
private _isItemsClickable;
|
50
|
+
hasPreview: boolean;
|
51
|
+
isFilenameDisplayed: boolean;
|
52
|
+
isFilesizeDisplayed: boolean;
|
53
|
+
isFiletypeDisplayed: boolean;
|
54
|
+
hasPreviewAsImage: boolean;
|
55
|
+
hasPreviewAsIcon: boolean;
|
56
|
+
isItemsClickable: boolean;
|
57
|
+
isFileObject: boolean;
|
58
|
+
templates: QueryList<EuiTemplateDirective>;
|
64
59
|
constructor(cd: ChangeDetectorRef);
|
65
60
|
ngOnInit(): void;
|
61
|
+
ngAfterViewInit(): void;
|
66
62
|
onRemoveFromList(): void;
|
67
63
|
onItemClick(e: Event): void;
|
68
64
|
private getFileExtension;
|
69
65
|
private getPreviewForMime;
|
70
66
|
private getIconForMime;
|
71
67
|
static ɵfac: i0.ɵɵFactoryDeclaration<EuiFilePreviewComponent, never>;
|
72
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<EuiFilePreviewComponent, "eui-file-preview", never, { "file": { "alias": "file"; "required": false; }; "index": { "alias": "index"; "required": false; }; "previewAsIconConfig": { "alias": "previewAsIconConfig"; "required": false; }; "hasPreview": { "alias": "hasPreview"; "required": false; }; "isFilenameDisplayed": { "alias": "isFilenameDisplayed"; "required": false; }; "isFilesizeDisplayed": { "alias": "isFilesizeDisplayed"; "required": false; }; "isFiletypeDisplayed": { "alias": "isFiletypeDisplayed"; "required": false; }; "hasPreviewAsImage": { "alias": "hasPreviewAsImage"; "required": false; }; "hasPreviewAsIcon": { "alias": "hasPreviewAsIcon"; "required": false; }; "isItemsClickable": { "alias": "isItemsClickable"; "required": false; }; }, { "removeFromList": "removeFromList"; "itemClick": "itemClick"; },
|
68
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<EuiFilePreviewComponent, "eui-file-preview", never, { "file": { "alias": "file"; "required": false; }; "uploadedFileTemplate": { "alias": "uploadedFileTemplate"; "required": false; }; "index": { "alias": "index"; "required": false; }; "previewAsIconConfig": { "alias": "previewAsIconConfig"; "required": false; }; "hasPreview": { "alias": "hasPreview"; "required": false; }; "isFilenameDisplayed": { "alias": "isFilenameDisplayed"; "required": false; }; "isFilesizeDisplayed": { "alias": "isFilesizeDisplayed"; "required": false; }; "isFiletypeDisplayed": { "alias": "isFiletypeDisplayed"; "required": false; }; "hasPreviewAsImage": { "alias": "hasPreviewAsImage"; "required": false; }; "hasPreviewAsIcon": { "alias": "hasPreviewAsIcon"; "required": false; }; "isItemsClickable": { "alias": "isItemsClickable"; "required": false; }; "isFileObject": { "alias": "isFileObject"; "required": false; }; }, { "removeFromList": "removeFromList"; "itemClick": "itemClick"; }, ["templates"], never, false, never>;
|
69
|
+
static ngAcceptInputType_hasPreview: unknown;
|
70
|
+
static ngAcceptInputType_isFilenameDisplayed: unknown;
|
71
|
+
static ngAcceptInputType_isFilesizeDisplayed: unknown;
|
72
|
+
static ngAcceptInputType_isFiletypeDisplayed: unknown;
|
73
|
+
static ngAcceptInputType_hasPreviewAsImage: unknown;
|
74
|
+
static ngAcceptInputType_hasPreviewAsIcon: unknown;
|
75
|
+
static ngAcceptInputType_isItemsClickable: unknown;
|
76
|
+
static ngAcceptInputType_isFileObject: unknown;
|
73
77
|
}
|
74
78
|
//# sourceMappingURL=file-preview.component.d.ts.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"file-preview.component.d.ts","sourceRoot":"","sources":["../../../eui-file-upload/file-preview/file-preview.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEH,MAAM,EAIN,iBAAiB,EAEjB,YAAY,
|
1
|
+
{"version":3,"file":"file-preview.component.d.ts","sourceRoot":"","sources":["../../../eui-file-upload/file-preview/file-preview.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEH,MAAM,EAIN,iBAAiB,EAEjB,YAAY,EAEZ,SAAS,EACT,WAAW,EAEX,aAAa,EAChB,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,oBAAoB,EAAE,MAAM,4BAA4B,CAAC;AAElE,OAAO,EAAE,wBAAwB,EAAE,MAAM,+BAA+B,CAAC;;AAEzE,qBAMa,uBAAwB,YAAW,MAAM,EAAE,aAAa;IAuDrD,OAAO,CAAC,EAAE;IApDb,IAAI,EAAE,IAAI,GAAG,wBAAwB,GAAG,GAAG,CAAC;IAC5C,oBAAoB,EAAE,WAAW,CAAC;QAAE,SAAS,EAAE;YAAE,IAAI,EAAE,wBAAwB,CAAC;YAAC,KAAK,EAAE,MAAM,CAAC;YAAC,YAAY,EAAE,OAAO,CAAA;SAAE,CAAA;KAAE,CAAC,CAAC;IAC3H,KAAK,EAAE,MAAM,CAAC;IAEd,mBAAmB;;;;;;;;;;;;;;;;;;;;;;;MAuB1B;IAEQ,cAAc,uBAA8B;IAE/C,GAAG,EAAE,MAAM,CAAC;IACZ,IAAI,EAAE,MAAM,CAAC;IACb,aAAa,EAAE,MAAM,CAAC;IACtB,WAAW,EAAE;QAAE,KAAK,EAAE,OAAO,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC;IACjD,SAAS,UAAS;IAIf,SAAS,oBAA6D;IAExC,UAAU,UAAQ;IAClB,mBAAmB,UAAQ;IAC3B,mBAAmB,UAAQ;IAC3B,mBAAmB,UAAQ;IAC3B,iBAAiB,UAAQ;IACzB,gBAAgB,UAAS;IACzB,gBAAgB,UAAS;IACzB,YAAY,UAAS;IAEtB,SAAS,EAAE,SAAS,CAAC,oBAAoB,CAAC,CAAC;gBAE9D,EAAE,EAAE,iBAAiB;IAEzC,QAAQ,IAAI,IAAI;IA0ChB,eAAe,IAAI,IAAI;IAQhB,gBAAgB,IAAI,IAAI;IAIxB,WAAW,CAAC,CAAC,EAAE,KAAK,GAAG,IAAI;IAKlC,OAAO,CAAC,gBAAgB;IAMxB,OAAO,CAAC,iBAAiB;IAQzB,OAAO,CAAC,cAAc;yCAlIb,uBAAuB;2CAAvB,uBAAuB;yCAuI8l7B,OAAQ;kDAAR,OAAQ;kDAAR,OAAQ;kDAAR,OAAQ;gDAAR,OAAQ;+CAAR,OAAQ;+CAAR,OAAQ;2CAAR,OAAQ;CADzo7B"}
|
@@ -6,4 +6,5 @@ export * from './eui-file-upload.component';
|
|
6
6
|
export * from './utils/eui-file-upload.utils';
|
7
7
|
export * from './utils/eui-file-upload.validators';
|
8
8
|
export * from './models/uploaded-file.model';
|
9
|
+
export * from './pipes/filesize.pipe';
|
9
10
|
//# sourceMappingURL=index.d.ts.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../eui-file-upload/index.ts"],"names":[],"mappings":"AAAA,cAAc,6BAA6B,CAAC;AAC5C,cAAc,+CAA+C,CAAC;AAC9D,cAAc,uCAAuC,CAAC;AACtD,cAAc,0BAA0B,CAAC;AACzC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,+BAA+B,CAAC;AAC9C,cAAc,oCAAoC,CAAC;AACnD,cAAc,8BAA8B,CAAC"}
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../eui-file-upload/index.ts"],"names":[],"mappings":"AAAA,cAAc,6BAA6B,CAAC;AAC5C,cAAc,+CAA+C,CAAC;AAC9D,cAAc,uCAAuC,CAAC;AACtD,cAAc,0BAA0B,CAAC;AACzC,cAAc,6BAA6B,CAAC;AAC5C,cAAc,+BAA+B,CAAC;AAC9C,cAAc,oCAAoC,CAAC;AACnD,cAAc,8BAA8B,CAAC;AAC7C,cAAc,uBAAuB,CAAC"}
|
@@ -72,6 +72,12 @@ export declare class EuiFileUploadUtilsService {
|
|
72
72
|
* @returns The backend response.
|
73
73
|
*/
|
74
74
|
toResponseBody<T>(): UnaryFunction<Observable<HttpEvent<T>>, Observable<T>>;
|
75
|
+
/**
|
76
|
+
* Return the icon to be used with eui-icon-svg of the given extension or a default file icon
|
77
|
+
* @param fileExtension
|
78
|
+
* @returns Icon name as string
|
79
|
+
*/
|
80
|
+
getIconForExtension(fileExtension: string): string;
|
75
81
|
private toFormData;
|
76
82
|
static ɵfac: i0.ɵɵFactoryDeclaration<EuiFileUploadUtilsService, never>;
|
77
83
|
static ɵprov: i0.ɵɵInjectableDeclaration<EuiFileUploadUtilsService>;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"eui-file-upload.utils.d.ts","sourceRoot":"","sources":["../../../eui-file-upload/utils/eui-file-upload.utils.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,SAAS,EAA+B,MAAM,sBAAsB,CAAC;AAE1F,OAAO,EAAQ,UAAU,EAAE,aAAa,EAAE,wBAAwB,EAAE,MAAM,MAAM,CAAC;;AAEjF,qBACa,yBAAyB;IACtB,OAAO,CAAC,UAAU;gBAAV,UAAU,EAAE,UAAU;IAE1C;;;;;;;;;;;;;;;;;;;;;;OAsBG;IAGI,QAAQ,CAAC,IAAI,EAAE,GAAG,EAAE,WAAW,EAAE,MAAM,GAAG,UAAU,CAAC,GAAG,CAAC;IAOhE;;;;;;;;;;;;;;;;;;;;;OAqBG;IACI,cAAc,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,QAAQ,EAAE,MAAM,KAAK,IAAI,GAAG,wBAAwB,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;IAQhG;;;;;;;;;;;;;;;;;;;OAmBG;IACI,cAAc,CAAC,CAAC,KAAK,aAAa,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC;
|
1
|
+
{"version":3,"file":"eui-file-upload.utils.d.ts","sourceRoot":"","sources":["../../../eui-file-upload/utils/eui-file-upload.utils.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,SAAS,EAA+B,MAAM,sBAAsB,CAAC;AAE1F,OAAO,EAAQ,UAAU,EAAE,aAAa,EAAE,wBAAwB,EAAE,MAAM,MAAM,CAAC;;AAEjF,qBACa,yBAAyB;IACtB,OAAO,CAAC,UAAU;gBAAV,UAAU,EAAE,UAAU;IAE1C;;;;;;;;;;;;;;;;;;;;;;OAsBG;IAGI,QAAQ,CAAC,IAAI,EAAE,GAAG,EAAE,WAAW,EAAE,MAAM,GAAG,UAAU,CAAC,GAAG,CAAC;IAOhE;;;;;;;;;;;;;;;;;;;;;OAqBG;IACI,cAAc,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,QAAQ,EAAE,MAAM,KAAK,IAAI,GAAG,wBAAwB,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;IAQhG;;;;;;;;;;;;;;;;;;;OAmBG;IACI,cAAc,CAAC,CAAC,KAAK,aAAa,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC;IAOlF;;;;OAIG;IACI,mBAAmB,CAAC,aAAa,EAAE,MAAM,GAAG,MAAM;IAgCzD,OAAO,CAAC,UAAU;yCAjIT,yBAAyB;6CAAzB,yBAAyB;CAmKrC"}
|
@@ -1,5 +1,5 @@
|
|
1
1
|
import * as i0 from '@angular/core';
|
2
|
-
import { EventEmitter, inject, Injector, forwardRef, booleanAttribute, Component, ViewEncapsulation, Optional, Inject, Self, HostBinding, Input, ViewChild, ContentChild, Output, Directive, NgModule } from '@angular/core';
|
2
|
+
import { EventEmitter, inject, Injector, forwardRef, booleanAttribute, ElementRef, Component, ViewEncapsulation, Optional, Inject, Self, HostBinding, Input, ViewChild, ContentChild, Output, Directive, NgModule } from '@angular/core';
|
3
3
|
import * as i6 from '@angular/common';
|
4
4
|
import { CommonModule } from '@angular/common';
|
5
5
|
import * as i7 from '@angular/material/datepicker';
|
@@ -585,7 +585,7 @@ class EuiDatepickerComponent {
|
|
585
585
|
this.hasAriaRequiredAttribute = control?.control?.hasValidator(Validators.required);
|
586
586
|
}
|
587
587
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: EuiDatepickerComponent, deps: [{ token: i1.DateAdapter }, { token: i2.TranslateService }, { token: i3.LocaleService }, { token: i3.EuiAppShellService }, { token: i0.ComponentFactoryResolver }, { token: i0.Injector }, { token: i0.ApplicationRef }, { token: i0.ViewContainerRef }, { token: i4.BaseStatesDirective }, { token: forwardRef(() => EuiLetterFormatDirective), optional: true }, { token: i5.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
588
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.2.1", type: EuiDatepickerComponent, selector: "eui-datepicker", inputs: { e2eAttr: "e2eAttr", value: "value", togglerIconSvg: "togglerIconSvg", togglerLabel: "togglerLabel", placeholder: "placeholder", type: "type", startView: "startView", minDate: "minDate", maxDate: "maxDate", datepickerFilter: "datepickerFilter", dateOutputFormat: "dateOutputFormat", customHeader: "customHeader", dateClass: "dateClass", stepHours: "stepHours", stepMinutes: "stepMinutes", stepSeconds: "stepSeconds", inputId: "inputId", isDatetimepicker: ["isDatetimepicker", "isDatetimepicker", booleanAttribute], hasSeconds: ["hasSeconds", "hasSeconds", booleanAttribute], isOneInputField: ["isOneInputField", "isOneInputField", booleanAttribute], hasNoButton: ["hasNoButton", "hasNoButton", booleanAttribute], isDatepickerBlock: ["isDatepickerBlock", "isDatepickerBlock", booleanAttribute], isReadOnly: ["isReadOnly", "isReadOnly", booleanAttribute], isDisabled: ["isDisabled", "isDisabled", booleanAttribute], isInputDisabled: ["isInputDisabled", "isInputDisabled", booleanAttribute], isButtonDisabled: ["isButtonDisabled", "isButtonDisabled", booleanAttribute], isPickerDisabled: ["isPickerDisabled", "isPickerDisabled", booleanAttribute], isClearable: "isClearable", restrictToRegex: "restrictToRegex" }, outputs: { inputChange: "inputChange", dateSelect: "dateSelect" }, host: { properties: { "class": "this.cssClasses", "attr.data-e2e": "this.e2eAttr" } }, queries: [{ propertyName: "euiActionButtons", first: true, predicate: i0.forwardRef(() => EuiActionButtonsDirective), descendants: true }], viewQueries: [{ propertyName: "calendar", first: true, predicate: ["calendar"], descendants: true, static: true }, { propertyName: "templatePortalRef", first: true, predicate: ["templatePortalRef"], descendants: true }], usesOnChanges: true, hostDirectives: [{ directive: i4.BaseStatesDirective, inputs: ["euiSuccess", "euiSuccess", "euiInfo", "euiInfo", "euiWarning", "euiWarning", "euiDanger", "euiDanger", "euiVariant", "euiVariant"] }], ngImport: i0, template: "<div euiInputGroup>\n <div class=\"eui-input-group-addon\">\n <input\n #input\n euiInputText\n [id]=\"inputId\"\n [readonly]=\"isReadOnly\"\n [euiClearable]=\"isClearable\"\n (clear)=\"onClear()\"\n [class.eui-datepicker--no-button]=\"hasNoButton\"\n [class.eui-datepicker--long-format]=\"!isDatepickerBlock && (isDatetimepicker || euiLetterFormat)\"\n [class.eui-datepicker--block]=\"isDatepickerBlock\"\n [attr.aria-required]=\"hasAriaRequiredAttribute ? 'true' : null\"\n [formControl]=\"inputFormControl\"\n [matDatepicker]=\"calendar\"\n placeholder=\"{{ placeholder }}\"\n (dateInput)=\"onDateInput($event)\"\n (dateChange)=\"onDateChange($event)\"\n [min]=\"minDate\"\n [max]=\"maxDate\"\n [matDatepickerFilter]=\"datepickerFilter\"\n (click)=\"openCalendar()\"\n autocomplete=\"off\"\n aria-label=\"Date Input Field\"\n (keypress)=\"onKeypress($event)\"\n (focusout)=\"onFocusOut()\"\n (change)=\"isDatetimepicker ? changedInput($event) : null\" />\n <mat-datepicker\n #calendar\n panelClass=\"mat-calendar-{{ type }}\"\n [startView]=\"type === 'regular' ? (startView ? startView : convTypeToStartView(type)) : convTypeToStartView(type)\"\n (yearSelected)=\"type === 'year' ? chosenDateHandler($event, calendar) : null\"\n (monthSelected)=\"type === 'month' ? chosenDateHandler($event, calendar) : null\"\n [touchUi]=\"breakpointsValue.isTablet || breakpointsValue.isMobile\"\n [panelClass]=\"isDatetimepicker ? 'eui-datepicker--container-height-large' : null\"\n [disabled]=\"isPickerDisabled\"\n [calendarHeaderComponent]=\"customHeader\"\n [dateClass]=\"dateClass\"\n (opened)=\"onOpened()\">\n </mat-datepicker>\n <button\n *ngIf=\"!hasNoButton && showDateButton\"\n (click)=\"openCalendar()\"\n euiButton\n type=\"button\"\n euiSecondary\n [euiIconButton]=\"!togglerLabel\"\n [euiDisabled]=\"isButtonDisabled\"\n aria-haspopup=\"dialog\">\n <ng-container *ngIf=\"!togglerLabel\">\n <eui-icon-svg icon=\"{{ togglerIconSvg }}\" aria-label=\"Open Calendar\" size=\"s\"></eui-icon-svg>\n </ng-container>\n <span *ngIf=\"togglerLabel\">{{ togglerLabel }}</span>\n </button>\n </div>\n</div>\n\n\n<ng-template #templatePortalRef>\n <ng-content select=\"eui-action-buttons\"></ng-content>\n</ng-template>\n", styles: [".eui-18 .eui-datepicker{display:flex}.eui-18 .eui-datepicker:not(.eui-datepicker--responsive) .eui-input-group-addon{width:unset}.eui-18 .eui-datepicker:not(.eui-datepicker--responsive) input{border-bottom-right-radius:0;border-top-right-radius:0;width:calc(8.5 * var(--eui-s-m))}.eui-18 .eui-datepicker:not(.eui-datepicker--responsive) input.eui-input-text--clearable{width:calc(9 * var(--eui-s-m))}.eui-18 .eui-datepicker:not(.eui-datepicker--responsive) input.eui-datepicker--long-format{width:calc(12.5 * var(--eui-s-m))}.eui-18 .eui-datepicker:not(.eui-datepicker--responsive) input.eui-datepicker--block{width:100%}.eui-18 .eui-datepicker:not(.eui-datepicker--responsive) input.eui-datepicker--no-button{border-bottom-right-radius:var(--eui-br-m);border-top-right-radius:var(--eui-br-m)}.eui-18 .eui-datepicker .eui-input-group{margin-bottom:0}.eui-18 .eui-datepicker--responsive,.eui-18 .eui-datepicker--responsive .eui-input-group-addon{width:100%}.eui-18 .eui-datepicker--container-height-large{height:auto!important}.eui-18 .eui-datepicker__action-buttons{display:flex;justify-content:flex-end;align-items:center;padding:0 var(--eui-s-xs) var(--eui-s-xs) var(--eui-s-xs)}.eui-18 .eui-datepicker__actions-cancel-button{margin-right:var(--eui-s-m)}.eui-18 .mat-calendar.mat-calendar-year .mat-calendar-period-button{display:none}.eui-18 .mat-datepicker-dialog .mat-datepicker-content-touch{max-height:none}.eui-18 .mat-datepicker-content-touch .mat-datepicker-content-container{height:auto!important;max-height:fit-content!important}.eui-18 .mat-mdc-icon-button:disabled{color:var(--eui-c-neutral-lighter)!important}.eui-18 .eui-datepicker--primary input{background-color:var(--eui-c-primary-bg)}.eui-18 .eui-datepicker--secondary input{background-color:var(--eui-c-neutral-bg-light)}.eui-18 .eui-datepicker--info input{background-color:var(--eui-c-info-bg)}.eui-18 .eui-datepicker--success input{background-color:var(--eui-c-success-bg)}.eui-18 .eui-datepicker--warning input{background-color:var(--eui-c-warning-bg)}.eui-18 .eui-datepicker--danger input{background-color:var(--eui-c-danger-bg)}.eui-18 .eui-datepicker--accent input{background-color:var(--eui-c-accent-bg)}\n"], dependencies: [{ kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i7.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i7.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i8.EuiButtonComponent, selector: "button[euiButton], a[euiButton]", inputs: ["e2eAttr", "id", "euiBasicButton", "euiButtonCall", "euiBlockButton", "euiIconButton", "euiLineWrap", "isChecked", "euiDisabled"], outputs: ["buttonClick"] }, { kind: "component", type: i9.EuiIconSvgComponent, selector: "eui-icon-svg, span[euiIconSvg], i[euiIconSvg]", inputs: ["icon", "fillColor", "set", "size", "style", "iconUrl", "transform", "euiVariant", "aria-label", "ariaHidden", "focusable", "isLoading", "isInputIcon", "euiStart", "euiEnd"] }, { kind: "component", type: i10.EuiInputTextComponent, selector: "input[euiInputText]", inputs: ["isInvalid"] }, { kind: "component", type: i11.EuiInputGroupComponent, selector: "div[euiInputGroup]", inputs: ["e2eAttr"] }], encapsulation: i0.ViewEncapsulation.None }); }
|
588
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "18.2.1", type: EuiDatepickerComponent, selector: "eui-datepicker", inputs: { e2eAttr: "e2eAttr", value: "value", togglerIconSvg: "togglerIconSvg", togglerLabel: "togglerLabel", placeholder: "placeholder", type: "type", startView: "startView", minDate: "minDate", maxDate: "maxDate", datepickerFilter: "datepickerFilter", dateOutputFormat: "dateOutputFormat", customHeader: "customHeader", dateClass: "dateClass", stepHours: "stepHours", stepMinutes: "stepMinutes", stepSeconds: "stepSeconds", inputId: "inputId", isDatetimepicker: ["isDatetimepicker", "isDatetimepicker", booleanAttribute], hasSeconds: ["hasSeconds", "hasSeconds", booleanAttribute], isOneInputField: ["isOneInputField", "isOneInputField", booleanAttribute], hasNoButton: ["hasNoButton", "hasNoButton", booleanAttribute], isDatepickerBlock: ["isDatepickerBlock", "isDatepickerBlock", booleanAttribute], isReadOnly: ["isReadOnly", "isReadOnly", booleanAttribute], isDisabled: ["isDisabled", "isDisabled", booleanAttribute], isInputDisabled: ["isInputDisabled", "isInputDisabled", booleanAttribute], isButtonDisabled: ["isButtonDisabled", "isButtonDisabled", booleanAttribute], isPickerDisabled: ["isPickerDisabled", "isPickerDisabled", booleanAttribute], isClearable: "isClearable", restrictToRegex: "restrictToRegex" }, outputs: { inputChange: "inputChange", dateSelect: "dateSelect" }, host: { properties: { "class": "this.cssClasses", "attr.data-e2e": "this.e2eAttr" } }, queries: [{ propertyName: "euiActionButtons", first: true, predicate: i0.forwardRef(() => EuiActionButtonsDirective), descendants: true }], viewQueries: [{ propertyName: "calendar", first: true, predicate: ["calendar"], descendants: true, static: true }, { propertyName: "templatePortalRef", first: true, predicate: ["templatePortalRef"], descendants: true }, { propertyName: "inputRef", first: true, predicate: ["input"], descendants: true, read: ElementRef }], usesOnChanges: true, hostDirectives: [{ directive: i4.BaseStatesDirective, inputs: ["euiSuccess", "euiSuccess", "euiInfo", "euiInfo", "euiWarning", "euiWarning", "euiDanger", "euiDanger", "euiVariant", "euiVariant"] }], ngImport: i0, template: "<div euiInputGroup>\n <div class=\"eui-input-group-addon\">\n <input\n #input\n euiInputText\n [id]=\"inputId\"\n [readonly]=\"isReadOnly\"\n [euiClearable]=\"isClearable\"\n (clear)=\"onClear()\"\n [class.eui-datepicker--no-button]=\"hasNoButton\"\n [class.eui-datepicker--long-format]=\"!isDatepickerBlock && (isDatetimepicker || euiLetterFormat)\"\n [class.eui-datepicker--block]=\"isDatepickerBlock\"\n [attr.aria-required]=\"hasAriaRequiredAttribute ? 'true' : null\"\n [formControl]=\"inputFormControl\"\n [matDatepicker]=\"calendar\"\n placeholder=\"{{ placeholder }}\"\n (dateInput)=\"onDateInput($event)\"\n (dateChange)=\"onDateChange($event)\"\n [min]=\"minDate\"\n [max]=\"maxDate\"\n [matDatepickerFilter]=\"datepickerFilter\"\n (click)=\"openCalendar()\"\n autocomplete=\"off\"\n aria-label=\"Date Input Field\"\n (keypress)=\"onKeypress($event)\"\n (focusout)=\"onFocusOut()\"\n (change)=\"isDatetimepicker ? changedInput($event) : null\" />\n <mat-datepicker\n #calendar\n panelClass=\"mat-calendar-{{ type }}\"\n [startView]=\"type === 'regular' ? (startView ? startView : convTypeToStartView(type)) : convTypeToStartView(type)\"\n (yearSelected)=\"type === 'year' ? chosenDateHandler($event, calendar) : null\"\n (monthSelected)=\"type === 'month' ? chosenDateHandler($event, calendar) : null\"\n [touchUi]=\"breakpointsValue.isTablet || breakpointsValue.isMobile\"\n [panelClass]=\"isDatetimepicker ? 'eui-datepicker--container-height-large' : null\"\n [disabled]=\"isPickerDisabled\"\n [calendarHeaderComponent]=\"customHeader\"\n [dateClass]=\"dateClass\"\n (opened)=\"onOpened()\">\n </mat-datepicker>\n <button\n *ngIf=\"!hasNoButton && showDateButton\"\n (click)=\"openCalendar()\"\n euiButton\n type=\"button\"\n euiSecondary\n [euiIconButton]=\"!togglerLabel\"\n [euiDisabled]=\"isButtonDisabled\"\n aria-haspopup=\"dialog\">\n <ng-container *ngIf=\"!togglerLabel\">\n <eui-icon-svg icon=\"{{ togglerIconSvg }}\" aria-label=\"Open Calendar\" size=\"s\"></eui-icon-svg>\n </ng-container>\n <span *ngIf=\"togglerLabel\">{{ togglerLabel }}</span>\n </button>\n </div>\n</div>\n\n\n<ng-template #templatePortalRef>\n <ng-content select=\"eui-action-buttons\"></ng-content>\n</ng-template>\n", styles: [".eui-18 .eui-datepicker{display:flex}.eui-18 .eui-datepicker:not(.eui-datepicker--responsive) .eui-input-group-addon{width:unset}.eui-18 .eui-datepicker:not(.eui-datepicker--responsive) input{border-bottom-right-radius:0;border-top-right-radius:0;width:calc(8.5 * var(--eui-s-m))}.eui-18 .eui-datepicker:not(.eui-datepicker--responsive) input.eui-input-text--clearable{width:calc(9 * var(--eui-s-m))}.eui-18 .eui-datepicker:not(.eui-datepicker--responsive) input.eui-datepicker--long-format{width:calc(12.5 * var(--eui-s-m))}.eui-18 .eui-datepicker:not(.eui-datepicker--responsive) input.eui-datepicker--block{width:100%}.eui-18 .eui-datepicker:not(.eui-datepicker--responsive) input.eui-datepicker--no-button{border-bottom-right-radius:var(--eui-br-m);border-top-right-radius:var(--eui-br-m)}.eui-18 .eui-datepicker .eui-input-group{margin-bottom:0}.eui-18 .eui-datepicker--responsive,.eui-18 .eui-datepicker--responsive .eui-input-group-addon{width:100%}.eui-18 .eui-datepicker--container-height-large{height:auto!important}.eui-18 .eui-datepicker__action-buttons{display:flex;justify-content:flex-end;align-items:center;padding:0 var(--eui-s-xs) var(--eui-s-xs) var(--eui-s-xs)}.eui-18 .eui-datepicker__actions-cancel-button{margin-right:var(--eui-s-m)}.eui-18 .mat-calendar.mat-calendar-year .mat-calendar-period-button{display:none}.eui-18 .mat-datepicker-dialog .mat-datepicker-content-touch{max-height:none}.eui-18 .mat-datepicker-content-touch .mat-datepicker-content-container{height:auto!important;max-height:fit-content!important}.eui-18 .mat-mdc-icon-button:disabled{color:var(--eui-c-neutral-lighter)!important}.eui-18 .eui-datepicker--primary input{background-color:var(--eui-c-primary-bg)}.eui-18 .eui-datepicker--secondary input{background-color:var(--eui-c-neutral-bg-light)}.eui-18 .eui-datepicker--info input{background-color:var(--eui-c-info-bg)}.eui-18 .eui-datepicker--success input{background-color:var(--eui-c-success-bg)}.eui-18 .eui-datepicker--warning input{background-color:var(--eui-c-warning-bg)}.eui-18 .eui-datepicker--danger input{background-color:var(--eui-c-danger-bg)}.eui-18 .eui-datepicker--accent input{background-color:var(--eui-c-accent-bg)}\n"], dependencies: [{ kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i7.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i7.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i8.EuiButtonComponent, selector: "button[euiButton], a[euiButton]", inputs: ["e2eAttr", "id", "euiBasicButton", "euiButtonCall", "euiBlockButton", "euiIconButton", "euiLineWrap", "isChecked", "euiDisabled"], outputs: ["buttonClick"] }, { kind: "component", type: i9.EuiIconSvgComponent, selector: "eui-icon-svg, span[euiIconSvg], i[euiIconSvg]", inputs: ["icon", "fillColor", "set", "size", "style", "iconUrl", "transform", "euiVariant", "aria-label", "ariaHidden", "focusable", "isLoading", "isInputIcon", "euiStart", "euiEnd"] }, { kind: "component", type: i10.EuiInputTextComponent, selector: "input[euiInputText]", inputs: ["isInvalid"] }, { kind: "component", type: i11.EuiInputGroupComponent, selector: "div[euiInputGroup]", inputs: ["e2eAttr"] }], encapsulation: i0.ViewEncapsulation.None }); }
|
589
589
|
}
|
590
590
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImport: i0, type: EuiDatepickerComponent, decorators: [{
|
591
591
|
type: Component,
|
@@ -624,6 +624,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.1", ngImpor
|
|
624
624
|
}], templatePortalRef: [{
|
625
625
|
type: ViewChild,
|
626
626
|
args: ['templatePortalRef']
|
627
|
+
}], inputRef: [{
|
628
|
+
type: ViewChild,
|
629
|
+
args: ['input', { read: ElementRef }]
|
627
630
|
}], euiActionButtons: [{
|
628
631
|
type: ContentChild,
|
629
632
|
args: [forwardRef(() => EuiActionButtonsDirective)]
|