ngx-material-entity 15.2.9 → 15.3.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/components/edit-page/edit-page.component.d.ts +3 -1
- package/components/input/array/array-table.class.d.ts +3 -1
- package/components/input/file/file-default-input/file-default-input.component.d.ts +0 -2
- package/components/input/file/file-image-input/file-image-input.component.d.ts +3 -2
- package/components/input/file/file-input/file-input.component.d.ts +3 -1
- package/components/input/input.component.d.ts +7 -3
- package/components/input/input.module.d.ts +2 -1
- package/components/table/edit-dialog/edit-entity-dialog.component.d.ts +3 -1
- package/decorators/base/property-decorator.data.d.ts +2 -2
- package/esm2020/components/edit-page/edit-page.component.mjs +16 -13
- package/esm2020/components/input/array/array-table.class.mjs +8 -5
- package/esm2020/components/input/file/file-default-input/file-default-input.component.mjs +1 -6
- package/esm2020/components/input/file/file-image-input/file-image-input.component.mjs +14 -12
- package/esm2020/components/input/file/file-input/file-input.component.mjs +17 -14
- package/esm2020/components/input/input.component.mjs +57 -48
- package/esm2020/components/input/input.module.mjs +8 -4
- package/esm2020/components/table/edit-dialog/edit-entity-dialog.component.mjs +14 -11
- package/esm2020/decorators/base/property-decorator.data.mjs +1 -1
- package/esm2020/services/entity.service.mjs +6 -6
- package/esm2020/utilities/entity.utilities.mjs +21 -12
- package/esm2020/utilities/file.utilities.mjs +15 -11
- package/fesm2015/ngx-material-entity.mjs +169 -147
- package/fesm2015/ngx-material-entity.mjs.map +1 -1
- package/fesm2020/ngx-material-entity.mjs +169 -147
- package/fesm2020/ngx-material-entity.mjs.map +1 -1
- package/package.json +1 -1
- package/utilities/entity.utilities.d.ts +7 -3
- package/utilities/file.utilities.d.ts +6 -2
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { firstValueFrom } from 'rxjs';
|
|
1
2
|
import { JSZipUtilities } from '../encapsulation/jszip.utilities';
|
|
2
3
|
import { LodashUtilities } from '../encapsulation/lodash.utilities';
|
|
3
4
|
/**
|
|
@@ -41,15 +42,16 @@ export class FileUtilities {
|
|
|
41
42
|
* Gets a file from the given url.
|
|
42
43
|
*
|
|
43
44
|
* @param url - The url to get the file from.
|
|
45
|
+
* @param http - The angular HttpClient. Used to fetch files.
|
|
44
46
|
* @returns A promise of the File.
|
|
45
47
|
*/
|
|
46
|
-
static async getFileFromUrl(url) {
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
48
|
+
static async getFileFromUrl(url, http) {
|
|
49
|
+
try {
|
|
50
|
+
return await firstValueFrom(http.get(url, { responseType: 'blob' }));
|
|
51
|
+
}
|
|
52
|
+
catch (error) {
|
|
53
|
+
throw new Error(`Error fetching the file from the url ${url}:\n ${error}`);
|
|
51
54
|
}
|
|
52
|
-
return await res.blob();
|
|
53
55
|
}
|
|
54
56
|
// TODO: Find a way to use blobs with jest
|
|
55
57
|
/* istanbul ignore next */
|
|
@@ -57,9 +59,10 @@ export class FileUtilities {
|
|
|
57
59
|
* Gets the file data with the blob from the given File Data.
|
|
58
60
|
*
|
|
59
61
|
* @param data - The File Data to get the file data with blob from.
|
|
62
|
+
* @param http - The angular HttpClient. Used to fetch files.
|
|
60
63
|
* @returns FileDataWithFile.
|
|
61
64
|
*/
|
|
62
|
-
static async getFileData(data) {
|
|
65
|
+
static async getFileData(data, http) {
|
|
63
66
|
if (data.file) {
|
|
64
67
|
return {
|
|
65
68
|
file: data.file,
|
|
@@ -71,7 +74,7 @@ export class FileUtilities {
|
|
|
71
74
|
}
|
|
72
75
|
else {
|
|
73
76
|
return {
|
|
74
|
-
file: await FileUtilities.getFileFromUrl(data.url),
|
|
77
|
+
file: await FileUtilities.getFileFromUrl(data.url, http),
|
|
75
78
|
name: data.name,
|
|
76
79
|
url: data.url,
|
|
77
80
|
type: data.type,
|
|
@@ -114,11 +117,12 @@ export class FileUtilities {
|
|
|
114
117
|
*
|
|
115
118
|
* @param name - The name of the zip file to generate.
|
|
116
119
|
* @param multiFileData - The file data array to put in the zip.
|
|
120
|
+
* @param http - The angular HttpClient. Used to fetch files.
|
|
117
121
|
*/
|
|
118
|
-
static async downloadMultipleFiles(name, multiFileData) {
|
|
122
|
+
static async downloadMultipleFiles(name, multiFileData, http) {
|
|
119
123
|
const zip = JSZipUtilities.new();
|
|
120
124
|
for (let i = 0; i < multiFileData.length; i++) {
|
|
121
|
-
multiFileData[i] = await FileUtilities.getFileData(multiFileData[i]);
|
|
125
|
+
multiFileData[i] = await FileUtilities.getFileData(multiFileData[i], http);
|
|
122
126
|
zip.file(multiFileData[i].name, multiFileData[i].file);
|
|
123
127
|
}
|
|
124
128
|
const zipBlob = await zip.generateAsync({ type: 'blob' });
|
|
@@ -173,4 +177,4 @@ export class FileUtilities {
|
|
|
173
177
|
}
|
|
174
178
|
}
|
|
175
179
|
}
|
|
176
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file.utilities.js","sourceRoot":"","sources":["../../../../projects/ngx-material-entity/src/utilities/file.utilities.ts"],"names":[],"mappings":"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","sourcesContent":["import { FileDataWithFile } from '../decorators/file/file-decorator-internal.data';\nimport { FileData } from '../decorators/file/file-decorator.data';\nimport { JSZipUtilities, Zip } from '../encapsulation/jszip.utilities';\nimport { LodashUtilities } from '../encapsulation/lodash.utilities';\n\n/**\n * Provides functionality regarding files.\n */\nexport abstract class FileUtilities {\n    /**\n     * Gets the accept value for the html input.\n     *\n     * @param mimeTypes - The mimeTypes to get the accept string from.\n     * @returns A comma separated string of all the provided mime types.\n     */\n    static getAcceptString(mimeTypes?: string[]): string {\n        if (!mimeTypes?.length) {\n            return '*';\n        }\n        return mimeTypes.join(', ');\n    }\n\n    // TODO: Find a way to use blobs with jest\n    /* istanbul ignore next */\n    /**\n     * Reads a url to display the given file.\n     *\n     * @param file - The file to get the url from.\n     * @returns A promise of the url. Undefined if no file was provided.\n     */\n    static async getDataURLFromFile(file?: Blob): Promise<string | undefined> {\n        if (!file) {\n            return undefined;\n        }\n        return new Promise<string>((resolve, reject) => {\n            const reader: FileReader = new FileReader();\n            reader.onload = e => resolve(e.target?.result as string);\n            reader.onerror = e => reject(e);\n            reader.readAsDataURL(file);\n        });\n    }\n\n    // TODO: Find a way to use blobs with jest\n    /* istanbul ignore next */\n    /**\n     * Gets a file from the given url.\n     *\n     * @param url - The url to get the file from.\n     * @returns A promise of the File.\n     */\n    private static async getFileFromUrl(url: string): Promise<Blob> {\n        const res: Response = await fetch(url);\n        if (!res.ok) {\n            // TODO make error more robust\n            throw new Error(`Error fetching the file from the url ${url}`);\n        }\n        return await res.blob();\n    }\n\n    // TODO: Find a way to use blobs with jest\n    /* istanbul ignore next */\n    /**\n     * Gets the file data with the blob from the given File Data.\n     *\n     * @param data - The File Data to get the file data with blob from.\n     * @returns FileDataWithFile.\n     */\n    static async getFileData(data: FileData): Promise<FileDataWithFile> {\n        if (data.file) {\n            return {\n                file: data.file,\n                name: data.name,\n                url: data.url,\n                type: data.type,\n                size: data.size\n            };\n        }\n        else {\n            return {\n                file: await FileUtilities.getFileFromUrl(data.url as string),\n                name: data.name,\n                url: data.url,\n                type: data.type,\n                size: data.size\n            };\n        }\n    }\n\n    // TODO: Find a way to use blobs with jest\n    /* istanbul ignore next */\n    /**\n     * Downloads a single file from the given File Data.\n     *\n     * @param fileData - The file data. Needs to contain a blob.\n     */\n    static downloadSingleFile(fileData: FileDataWithFile): void {\n        this.downLoadBlob(fileData.file, fileData.name);\n    }\n\n    // TODO: Find a way to use blobs with jest\n    /* istanbul ignore next */\n    /**\n     * Downloads a blob.\n     *\n     * @param blob - The blob to download.\n     * @param name - The name of the downloaded file.\n     */\n    static downLoadBlob(blob: Blob, name?: string): void {\n        const a: HTMLAnchorElement = document.createElement('a');\n        const objectUrl: string = URL.createObjectURL(blob);\n        a.href = objectUrl;\n        if (name) {\n            a.download = name;\n        }\n        a.click();\n        URL.revokeObjectURL(objectUrl);\n    }\n\n    // TODO: Find a way to use blobs with jest\n    /* istanbul ignore next */\n    /**\n     * Downloads multiple files as a zip with the given name.\n     *\n     * @param name - The name of the zip file to generate.\n     * @param multiFileData - The file data array to put in the zip.\n     */\n    static async downloadMultipleFiles(name: string, multiFileData: FileData[]): Promise<void> {\n        const zip: Zip = JSZipUtilities.new();\n        for (let i: number = 0; i < multiFileData.length; i++) {\n            multiFileData[i] = await FileUtilities.getFileData(multiFileData[i]);\n            zip.file(multiFileData[i].name, (multiFileData[i] as FileDataWithFile).file);\n        }\n        const zipBlob: Blob = await zip.generateAsync({ type: 'blob' });\n        const fileData: FileDataWithFile = {\n            name: name,\n            file: zipBlob,\n            type: 'application/zip',\n            size: zipBlob.size\n        };\n        FileUtilities.downloadSingleFile(fileData);\n    }\n\n    /**\n     * Checks if the given file has a valid mime type.\n     *\n     * @param type - The type of the file to check.\n     * @param allowedMimeTypes - The allowed mime types.\n     * @returns Whether or not the given file has a valid mime type.\n     */\n    static isMimeTypeValid(type: string, allowedMimeTypes: string[]): boolean {\n        if (allowedMimeTypes.includes('*')) {\n            return true;\n        }\n        for (const t of allowedMimeTypes) {\n            if (t === type) {\n                return true;\n            }\n            if (t.endsWith('*') && type.startsWith(t.split('*')[0])) {\n                return true;\n            }\n        }\n        return false;\n    }\n\n    /**\n     * Transform the given value to Megabytes.\n     *\n     * @param value - The original value.\n     * @param unit - If the value is B, KB or GB.\n     * @returns The given value as bytes.\n     */\n    static transformToMegaBytes(value: number, unit: 'B' | 'KB' | 'GB'): number {\n        const bytes: number = this.transformToBytes(LodashUtilities.cloneDeep(value), unit);\n        return bytes / 1000000;\n    }\n\n    private static transformToBytes(value: number, unit: 'B' | 'KB' | 'GB'): number {\n        switch (unit) {\n            case 'B':\n                return value;\n            case 'KB':\n                return value * 1000;\n            case 'GB':\n                return value * 1000000000;\n        }\n    }\n}"]}
|
|
180
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file.utilities.js","sourceRoot":"","sources":["../../../../projects/ngx-material-entity/src/utilities/file.utilities.ts"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { firstValueFrom } from 'rxjs';\nimport { FileDataWithFile } from '../decorators/file/file-decorator-internal.data';\nimport { FileData } from '../decorators/file/file-decorator.data';\nimport { JSZipUtilities, Zip } from '../encapsulation/jszip.utilities';\nimport { LodashUtilities } from '../encapsulation/lodash.utilities';\n\n/**\n * Provides functionality regarding files.\n */\nexport abstract class FileUtilities {\n    /**\n     * Gets the accept value for the html input.\n     *\n     * @param mimeTypes - The mimeTypes to get the accept string from.\n     * @returns A comma separated string of all the provided mime types.\n     */\n    static getAcceptString(mimeTypes?: string[]): string {\n        if (!mimeTypes?.length) {\n            return '*';\n        }\n        return mimeTypes.join(', ');\n    }\n\n    // TODO: Find a way to use blobs with jest\n    /* istanbul ignore next */\n    /**\n     * Reads a url to display the given file.\n     *\n     * @param file - The file to get the url from.\n     * @returns A promise of the url. Undefined if no file was provided.\n     */\n    static async getDataURLFromFile(file?: Blob): Promise<string | undefined> {\n        if (!file) {\n            return undefined;\n        }\n        return new Promise<string>((resolve, reject) => {\n            const reader: FileReader = new FileReader();\n            reader.onload = e => resolve(e.target?.result as string);\n            reader.onerror = e => reject(e);\n            reader.readAsDataURL(file);\n        });\n    }\n\n    // TODO: Find a way to use blobs with jest\n    /* istanbul ignore next */\n    /**\n     * Gets a file from the given url.\n     *\n     * @param url - The url to get the file from.\n     * @param http - The angular HttpClient. Used to fetch files.\n     * @returns A promise of the File.\n     */\n    private static async getFileFromUrl(url: string, http: HttpClient): Promise<Blob> {\n        try {\n            return await firstValueFrom(http.get(url, { responseType: 'blob' }));\n        }\n        catch (error) {\n            throw new Error(`Error fetching the file from the url ${url}:\\n ${error}`);\n        }\n    }\n\n    // TODO: Find a way to use blobs with jest\n    /* istanbul ignore next */\n    /**\n     * Gets the file data with the blob from the given File Data.\n     *\n     * @param data - The File Data to get the file data with blob from.\n     * @param http - The angular HttpClient. Used to fetch files.\n     * @returns FileDataWithFile.\n     */\n    static async getFileData(data: FileData, http: HttpClient): Promise<FileDataWithFile> {\n        if (data.file) {\n            return {\n                file: data.file,\n                name: data.name,\n                url: data.url,\n                type: data.type,\n                size: data.size\n            };\n        }\n        else {\n            return {\n                file: await FileUtilities.getFileFromUrl(data.url as string, http),\n                name: data.name,\n                url: data.url,\n                type: data.type,\n                size: data.size\n            };\n        }\n    }\n\n    // TODO: Find a way to use blobs with jest\n    /* istanbul ignore next */\n    /**\n     * Downloads a single file from the given File Data.\n     *\n     * @param fileData - The file data. Needs to contain a blob.\n     */\n    static downloadSingleFile(fileData: FileDataWithFile): void {\n        this.downLoadBlob(fileData.file, fileData.name);\n    }\n\n    // TODO: Find a way to use blobs with jest\n    /* istanbul ignore next */\n    /**\n     * Downloads a blob.\n     *\n     * @param blob - The blob to download.\n     * @param name - The name of the downloaded file.\n     */\n    static downLoadBlob(blob: Blob, name?: string): void {\n        const a: HTMLAnchorElement = document.createElement('a');\n        const objectUrl: string = URL.createObjectURL(blob);\n        a.href = objectUrl;\n        if (name) {\n            a.download = name;\n        }\n        a.click();\n        URL.revokeObjectURL(objectUrl);\n    }\n\n    // TODO: Find a way to use blobs with jest\n    /* istanbul ignore next */\n    /**\n     * Downloads multiple files as a zip with the given name.\n     *\n     * @param name - The name of the zip file to generate.\n     * @param multiFileData - The file data array to put in the zip.\n     * @param http - The angular HttpClient. Used to fetch files.\n     */\n    static async downloadMultipleFiles(name: string, multiFileData: FileData[], http: HttpClient): Promise<void> {\n        const zip: Zip = JSZipUtilities.new();\n        for (let i: number = 0; i < multiFileData.length; i++) {\n            multiFileData[i] = await FileUtilities.getFileData(multiFileData[i], http);\n            zip.file(multiFileData[i].name, (multiFileData[i] as FileDataWithFile).file);\n        }\n        const zipBlob: Blob = await zip.generateAsync({ type: 'blob' });\n        const fileData: FileDataWithFile = {\n            name: name,\n            file: zipBlob,\n            type: 'application/zip',\n            size: zipBlob.size\n        };\n        FileUtilities.downloadSingleFile(fileData);\n    }\n\n    /**\n     * Checks if the given file has a valid mime type.\n     *\n     * @param type - The type of the file to check.\n     * @param allowedMimeTypes - The allowed mime types.\n     * @returns Whether or not the given file has a valid mime type.\n     */\n    static isMimeTypeValid(type: string, allowedMimeTypes: string[]): boolean {\n        if (allowedMimeTypes.includes('*')) {\n            return true;\n        }\n        for (const t of allowedMimeTypes) {\n            if (t === type) {\n                return true;\n            }\n            if (t.endsWith('*') && type.startsWith(t.split('*')[0])) {\n                return true;\n            }\n        }\n        return false;\n    }\n\n    /**\n     * Transform the given value to Megabytes.\n     *\n     * @param value - The original value.\n     * @param unit - If the value is B, KB or GB.\n     * @returns The given value as bytes.\n     */\n    static transformToMegaBytes(value: number, unit: 'B' | 'KB' | 'GB'): number {\n        const bytes: number = this.transformToBytes(LodashUtilities.cloneDeep(value), unit);\n        return bytes / 1000000;\n    }\n\n    private static transformToBytes(value: number, unit: 'B' | 'KB' | 'GB'): number {\n        switch (unit) {\n            case 'B':\n                return value;\n            case 'KB':\n                return value * 1000;\n            case 'GB':\n                return value * 1000000000;\n        }\n    }\n}"]}
|