ngx-material-entity 15.1.3 → 15.1.4

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.
Files changed (90) hide show
  1. package/README.md +100 -0
  2. package/components/confirm-dialog/confirm-dialog.component.d.ts +1 -1
  3. package/components/edit-page/edit-page.component.d.ts +112 -0
  4. package/components/edit-page/page-edit-data.builder.d.ts +17 -0
  5. package/components/input/array/array-date-input/array-date-input.component.d.ts +1 -1
  6. package/components/input/array/array-date-range-input/array-date-range-input.component.d.ts +1 -1
  7. package/components/input/array/array-date-time-input/array-date-time-input.component.d.ts +1 -1
  8. package/components/input/array/array-table.class.d.ts +1 -1
  9. package/components/input/date/date-input/date-input.component.d.ts +1 -1
  10. package/components/input/date/date-time-input/date-time-input.component.d.ts +1 -1
  11. package/components/input/file/file-default-input/file-default-input.component.d.ts +1 -1
  12. package/components/input/file/file-image-input/file-image-input.component.d.ts +1 -1
  13. package/components/input/file/file-input/file-input.component.d.ts +3 -3
  14. package/components/input/input.component.d.ts +3 -3
  15. package/components/input/relations/references-many-input/references-many-input.component.d.ts +1 -1
  16. package/components/input/string/string-password-input/string-password-input.component.d.ts +1 -1
  17. package/components/table/create-dialog/create-entity-dialog-data.builder.d.ts +3 -3
  18. package/components/table/create-dialog/create-entity-dialog-data.d.ts +1 -1
  19. package/components/table/create-dialog/create-entity-dialog.component.d.ts +4 -4
  20. package/components/table/edit-dialog/{edit-dialog-data.builder.d.ts → edit-data.builder.d.ts} +7 -7
  21. package/components/table/edit-dialog/{edit-entity-dialog-data.d.ts → edit-entity-data.d.ts} +5 -5
  22. package/components/table/edit-dialog/edit-entity-dialog.component.d.ts +6 -6
  23. package/components/table/edit-dialog/edit-entity.builder.d.ts +24 -0
  24. package/components/table/table-data.builder.d.ts +9 -7
  25. package/components/table/table-data.d.ts +18 -8
  26. package/components/table/table.component.d.ts +11 -7
  27. package/components/table/table.module.d.ts +4 -3
  28. package/esm2020/classes/entity.model.mjs +2 -2
  29. package/esm2020/components/confirm-dialog/confirm-dialog.component.mjs +4 -4
  30. package/esm2020/components/edit-page/edit-page.component.mjs +203 -0
  31. package/esm2020/components/edit-page/page-edit-data.builder.mjs +32 -0
  32. package/esm2020/components/input/array/array-date-input/array-date-input.component.mjs +4 -4
  33. package/esm2020/components/input/array/array-date-range-input/array-date-range-input.component.mjs +4 -4
  34. package/esm2020/components/input/array/array-date-time-input/array-date-time-input.component.mjs +4 -4
  35. package/esm2020/components/input/array/array-table.class.mjs +3 -3
  36. package/esm2020/components/input/base-input.component.mjs +2 -2
  37. package/esm2020/components/input/date/date-input/date-input.component.mjs +2 -2
  38. package/esm2020/components/input/date/date-range-input/date-range-input.component.mjs +5 -5
  39. package/esm2020/components/input/date/date-time-input/date-time-input.component.mjs +3 -3
  40. package/esm2020/components/input/file/file-default-input/file-default-input.component.mjs +2 -2
  41. package/esm2020/components/input/file/file-image-input/file-image-input.component.mjs +3 -3
  42. package/esm2020/components/input/file/file-input/file-input.component.mjs +5 -5
  43. package/esm2020/components/input/input.component.mjs +6 -6
  44. package/esm2020/components/input/relations/references-many-input/references-many-input.component.mjs +4 -4
  45. package/esm2020/components/input/string/string-password-input/string-password-input.component.mjs +4 -4
  46. package/esm2020/components/table/create-dialog/create-entity-dialog-data.builder.mjs +2 -2
  47. package/esm2020/components/table/create-dialog/create-entity-dialog-data.mjs +1 -1
  48. package/esm2020/components/table/create-dialog/create-entity-dialog.component.mjs +5 -5
  49. package/esm2020/components/table/edit-dialog/edit-data.builder.mjs +41 -0
  50. package/esm2020/components/table/edit-dialog/edit-entity-data.mjs +2 -0
  51. package/esm2020/components/table/edit-dialog/edit-entity-dialog.component.mjs +16 -16
  52. package/esm2020/components/table/edit-dialog/edit-entity.builder.mjs +28 -0
  53. package/esm2020/components/table/table-data.builder.mjs +11 -8
  54. package/esm2020/components/table/table-data.mjs +1 -1
  55. package/esm2020/components/table/table.component.mjs +42 -29
  56. package/esm2020/components/table/table.module.mjs +5 -1
  57. package/esm2020/decorators/array/array-decorator-internal.data.mjs +2 -2
  58. package/esm2020/decorators/base/base-property.decorator.mjs +2 -2
  59. package/esm2020/decorators/date/date-decorator-internal.data.mjs +2 -2
  60. package/esm2020/decorators/date/date.decorator.mjs +2 -2
  61. package/esm2020/decorators/file/file.decorator.mjs +2 -2
  62. package/esm2020/decorators/string/string.decorator.mjs +2 -2
  63. package/esm2020/public-api.mjs +30 -26
  64. package/esm2020/services/entity.service.mjs +236 -0
  65. package/esm2020/services/unsaved-changes.guard.mjs +14 -0
  66. package/esm2020/utilities/date.utilities.mjs +158 -0
  67. package/esm2020/utilities/entity.utilities.mjs +828 -0
  68. package/esm2020/utilities/file.utilities.mjs +163 -0
  69. package/esm2020/utilities/selection.utilities.mjs +50 -0
  70. package/fesm2015/ngx-material-entity.mjs +882 -613
  71. package/fesm2015/ngx-material-entity.mjs.map +1 -1
  72. package/fesm2020/ngx-material-entity.mjs +896 -633
  73. package/fesm2020/ngx-material-entity.mjs.map +1 -1
  74. package/package.json +1 -1
  75. package/public-api.d.ts +27 -25
  76. package/{classes → services}/entity.service.d.ts +18 -1
  77. package/services/unsaved-changes.guard.d.ts +4 -0
  78. package/{classes → utilities}/entity.utilities.d.ts +1 -1
  79. package/components/table/edit-dialog/edit-entity-dialog.builder.d.ts +0 -24
  80. package/esm2020/classes/date.utilities.mjs +0 -158
  81. package/esm2020/classes/entity.service.mjs +0 -213
  82. package/esm2020/classes/entity.utilities.mjs +0 -828
  83. package/esm2020/classes/file.utilities.mjs +0 -163
  84. package/esm2020/classes/selection.utilities.mjs +0 -50
  85. package/esm2020/components/table/edit-dialog/edit-dialog-data.builder.mjs +0 -41
  86. package/esm2020/components/table/edit-dialog/edit-entity-dialog-data.mjs +0 -2
  87. package/esm2020/components/table/edit-dialog/edit-entity-dialog.builder.mjs +0 -28
  88. /package/{classes → utilities}/date.utilities.d.ts +0 -0
  89. /package/{classes → utilities}/file.utilities.d.ts +0 -0
  90. /package/{classes → utilities}/selection.utilities.d.ts +0 -0
@@ -0,0 +1,163 @@
1
+ import { LodashUtilities } from '../encapsulation/lodash.utilities';
2
+ import { JSZipUtilities } from '../encapsulation/jszip.utilities';
3
+ /**
4
+ * Provides functionality regarding files.
5
+ */
6
+ export class FileUtilities {
7
+ /**
8
+ * Gets the accept value for the html input.
9
+ *
10
+ * @param mimeTypes - The mimeTypes to get the accept string from.
11
+ * @returns A comma separated string of all the provided mime types.
12
+ */
13
+ static getAcceptString(mimeTypes) {
14
+ if (!mimeTypes?.length) {
15
+ return '*';
16
+ }
17
+ return mimeTypes.join(', ');
18
+ }
19
+ // TODO: Find a way to use blobs with jest
20
+ /* istanbul ignore next */
21
+ /**
22
+ * Reads a url to display the given file.
23
+ *
24
+ * @param file - The file to get the url from.
25
+ * @returns A promise of the url. Undefined if no file was provided.
26
+ */
27
+ static async getDataURLFromFile(file) {
28
+ if (!file) {
29
+ return undefined;
30
+ }
31
+ return new Promise((resolve, reject) => {
32
+ const reader = new FileReader();
33
+ reader.onload = e => resolve(e.target?.result);
34
+ reader.onerror = e => reject(e);
35
+ reader.readAsDataURL(file);
36
+ });
37
+ }
38
+ // TODO: Find a way to use blobs with jest
39
+ /* istanbul ignore next */
40
+ /**
41
+ * Gets a file from the given url.
42
+ *
43
+ * @param url - The url to get the file from.
44
+ * @returns A promise of the File.
45
+ */
46
+ static async getFileFromUrl(url) {
47
+ const res = await fetch(url);
48
+ if (!res.ok) {
49
+ // TODO make error more robust
50
+ throw new Error(`Error fetching the file from the url ${url}`);
51
+ }
52
+ return await res.blob();
53
+ }
54
+ // TODO: Find a way to use blobs with jest
55
+ /* istanbul ignore next */
56
+ /**
57
+ * Gets the file data with the blob from the given File Data.
58
+ *
59
+ * @param data - The File Data to get the file data with blob from.
60
+ * @returns FileDataWithFile.
61
+ */
62
+ static async getFileData(data) {
63
+ if (data.file) {
64
+ return {
65
+ file: data.file,
66
+ name: data.name,
67
+ url: data.url,
68
+ type: data.type,
69
+ size: data.size
70
+ };
71
+ }
72
+ else {
73
+ return {
74
+ file: await FileUtilities.getFileFromUrl(data.url),
75
+ name: data.name,
76
+ url: data.url,
77
+ type: data.type,
78
+ size: data.size
79
+ };
80
+ }
81
+ }
82
+ // TODO: Find a way to use blobs with jest
83
+ /* istanbul ignore next */
84
+ /**
85
+ * Downloads a single file from the given File Data.
86
+ *
87
+ * @param fileData - The file data. Needs to contain a blob.
88
+ */
89
+ static downloadSingleFile(fileData) {
90
+ const a = document.createElement('a');
91
+ const objectUrl = URL.createObjectURL(fileData.file);
92
+ a.href = objectUrl;
93
+ a.download = fileData.name;
94
+ a.click();
95
+ URL.revokeObjectURL(objectUrl);
96
+ }
97
+ // TODO: Find a way to use blobs with jest
98
+ /* istanbul ignore next */
99
+ /**
100
+ * Downloads multiple files as a zip with the given name.
101
+ *
102
+ * @param name - The name of the zip file to generate.
103
+ * @param multiFileData - The file data array to put in the zip.
104
+ */
105
+ static async downloadMultipleFiles(name, multiFileData) {
106
+ const zip = JSZipUtilities.new();
107
+ for (let i = 0; i < multiFileData.length; i++) {
108
+ multiFileData[i] = await FileUtilities.getFileData(multiFileData[i]);
109
+ zip.file(multiFileData[i].name, multiFileData[i].file);
110
+ }
111
+ const zipBlob = await zip.generateAsync({ type: 'blob' });
112
+ const fileData = {
113
+ name: name,
114
+ file: zipBlob,
115
+ type: 'application/zip',
116
+ size: zipBlob.size
117
+ };
118
+ FileUtilities.downloadSingleFile(fileData);
119
+ }
120
+ /**
121
+ * Checks if the given file has a valid mime type.
122
+ *
123
+ * @param type - The type of the file to check.
124
+ * @param allowedMimeTypes - The allowed mime types.
125
+ * @returns Whether or not the given file has a valid mime type.
126
+ */
127
+ static isMimeTypeValid(type, allowedMimeTypes) {
128
+ if (allowedMimeTypes.includes('*')) {
129
+ return true;
130
+ }
131
+ for (const t of allowedMimeTypes) {
132
+ if (t === type) {
133
+ return true;
134
+ }
135
+ if (t.endsWith('*') && type.startsWith(t.split('*')[0])) {
136
+ return true;
137
+ }
138
+ }
139
+ return false;
140
+ }
141
+ /**
142
+ * Transform the given value to Megabytes.
143
+ *
144
+ * @param value - The original value.
145
+ * @param unit - If the value is B, KB or GB.
146
+ * @returns The given value as bytes.
147
+ */
148
+ static transformToMegaBytes(value, unit) {
149
+ const bytes = this.transformToBytes(LodashUtilities.cloneDeep(value), unit);
150
+ return bytes / 1000000;
151
+ }
152
+ static transformToBytes(value, unit) {
153
+ switch (unit) {
154
+ case 'B':
155
+ return value;
156
+ case 'KB':
157
+ return value * 1000;
158
+ case 'GB':
159
+ return value * 1000000000;
160
+ }
161
+ }
162
+ }
163
+ //# 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 { LodashUtilities } from '../encapsulation/lodash.utilities';\nimport { FileDataWithFile } from '../decorators/file/file-decorator-internal.data';\nimport { FileData } from '../decorators/file/file-decorator.data';\nimport { JSZipUtilities } from '../encapsulation/jszip.utilities';\nimport JSZip from 'jszip';\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        const a: HTMLAnchorElement = document.createElement('a');\n        const objectUrl: string = URL.createObjectURL(fileData.file);\n        a.href = objectUrl;\n        a.download = fileData.name;\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: JSZip = 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}"]}
@@ -0,0 +1,50 @@
1
+ /**
2
+ * Provides functionality around material selections inside of tables.
3
+ */
4
+ export class SelectionUtilities {
5
+ /**
6
+ * Checks if all items in the table have been selected.
7
+ * This is needed to display the "masterToggle"-checkbox correctly.
8
+ *
9
+ * @param selection - The selection to check.
10
+ * @param dataSource - The dataSource of the selection.
11
+ * @returns Whether or not all items in the table have been selected.
12
+ */
13
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
14
+ static isAllSelected(selection, dataSource) {
15
+ const numSelected = selection.selected.length;
16
+ const numRows = dataSource.data.length;
17
+ return numSelected === numRows;
18
+ }
19
+ /**
20
+ * Toggles all items in the table.
21
+ *
22
+ * @param selection - The selection to toggle.
23
+ * @param dataSource - The dataSource of the selection.
24
+ */
25
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
26
+ static masterToggle(selection, dataSource) {
27
+ if (SelectionUtilities.isAllSelected(selection, dataSource)) {
28
+ selection.clear();
29
+ }
30
+ else {
31
+ dataSource.data.forEach(row => selection.select(row));
32
+ }
33
+ }
34
+ /**
35
+ * Removes all selected entries from the array.
36
+ *
37
+ * @param selection - The selection containing the items to remove.
38
+ * @param values - The values of the dataSource.
39
+ * @param dataSource - The dataSource.
40
+ */
41
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
42
+ static remove(selection, values, dataSource) {
43
+ selection.selected.forEach(s => {
44
+ values.splice(values.indexOf(s), 1);
45
+ });
46
+ dataSource.data = values;
47
+ selection.clear();
48
+ }
49
+ }
50
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0aW9uLnV0aWxpdGllcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1tYXRlcmlhbC1lbnRpdHkvc3JjL3V0aWxpdGllcy9zZWxlY3Rpb24udXRpbGl0aWVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdBOztHQUVHO0FBQ0gsTUFBTSxPQUFnQixrQkFBa0I7SUFFcEM7Ozs7Ozs7T0FPRztJQUNILDhEQUE4RDtJQUM5RCxNQUFNLENBQUMsYUFBYSxDQUFDLFNBQThCLEVBQUUsVUFBbUM7UUFDcEYsTUFBTSxXQUFXLEdBQVcsU0FBUyxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUM7UUFDdEQsTUFBTSxPQUFPLEdBQVcsVUFBVSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUM7UUFDL0MsT0FBTyxXQUFXLEtBQUssT0FBTyxDQUFDO0lBQ25DLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNILDhEQUE4RDtJQUM5RCxNQUFNLENBQUMsWUFBWSxDQUFDLFNBQThCLEVBQUUsVUFBbUM7UUFDbkYsSUFBSSxrQkFBa0IsQ0FBQyxhQUFhLENBQUMsU0FBUyxFQUFFLFVBQVUsQ0FBQyxFQUFFO1lBQ3pELFNBQVMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztTQUNyQjthQUNJO1lBQ0QsVUFBVSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7U0FDekQ7SUFDTCxDQUFDO0lBRUQ7Ozs7OztPQU1HO0lBQ0gsOERBQThEO0lBQzlELE1BQU0sQ0FBQyxNQUFNLENBQUMsU0FBOEIsRUFBRSxNQUFhLEVBQUUsVUFBbUM7UUFDNUYsU0FBUyxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEVBQUU7WUFDM0IsTUFBTSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ3hDLENBQUMsQ0FBQyxDQUFDO1FBQ0gsVUFBVSxDQUFDLElBQUksR0FBRyxNQUFNLENBQUM7UUFDekIsU0FBUyxDQUFDLEtBQUssRUFBRSxDQUFDO0lBQ3RCLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFNlbGVjdGlvbk1vZGVsIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2NvbGxlY3Rpb25zJztcbmltcG9ydCB7IE1hdFRhYmxlRGF0YVNvdXJjZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3RhYmxlJztcblxuLyoqXG4gKiBQcm92aWRlcyBmdW5jdGlvbmFsaXR5IGFyb3VuZCBtYXRlcmlhbCBzZWxlY3Rpb25zIGluc2lkZSBvZiB0YWJsZXMuXG4gKi9cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBTZWxlY3Rpb25VdGlsaXRpZXMge1xuXG4gICAgLyoqXG4gICAgICogQ2hlY2tzIGlmIGFsbCBpdGVtcyBpbiB0aGUgdGFibGUgaGF2ZSBiZWVuIHNlbGVjdGVkLlxuICAgICAqIFRoaXMgaXMgbmVlZGVkIHRvIGRpc3BsYXkgdGhlIFwibWFzdGVyVG9nZ2xlXCItY2hlY2tib3ggY29ycmVjdGx5LlxuICAgICAqXG4gICAgICogQHBhcmFtIHNlbGVjdGlvbiAtIFRoZSBzZWxlY3Rpb24gdG8gY2hlY2suXG4gICAgICogQHBhcmFtIGRhdGFTb3VyY2UgLSBUaGUgZGF0YVNvdXJjZSBvZiB0aGUgc2VsZWN0aW9uLlxuICAgICAqIEByZXR1cm5zIFdoZXRoZXIgb3Igbm90IGFsbCBpdGVtcyBpbiB0aGUgdGFibGUgaGF2ZSBiZWVuIHNlbGVjdGVkLlxuICAgICAqL1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55XG4gICAgc3RhdGljIGlzQWxsU2VsZWN0ZWQoc2VsZWN0aW9uOiBTZWxlY3Rpb25Nb2RlbDxhbnk+LCBkYXRhU291cmNlOiBNYXRUYWJsZURhdGFTb3VyY2U8YW55Pik6IGJvb2xlYW4ge1xuICAgICAgICBjb25zdCBudW1TZWxlY3RlZDogbnVtYmVyID0gc2VsZWN0aW9uLnNlbGVjdGVkLmxlbmd0aDtcbiAgICAgICAgY29uc3QgbnVtUm93czogbnVtYmVyID0gZGF0YVNvdXJjZS5kYXRhLmxlbmd0aDtcbiAgICAgICAgcmV0dXJuIG51bVNlbGVjdGVkID09PSBudW1Sb3dzO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIFRvZ2dsZXMgYWxsIGl0ZW1zIGluIHRoZSB0YWJsZS5cbiAgICAgKlxuICAgICAqIEBwYXJhbSBzZWxlY3Rpb24gLSBUaGUgc2VsZWN0aW9uIHRvIHRvZ2dsZS5cbiAgICAgKiBAcGFyYW0gZGF0YVNvdXJjZSAtIFRoZSBkYXRhU291cmNlIG9mIHRoZSBzZWxlY3Rpb24uXG4gICAgICovXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnlcbiAgICBzdGF0aWMgbWFzdGVyVG9nZ2xlKHNlbGVjdGlvbjogU2VsZWN0aW9uTW9kZWw8YW55PiwgZGF0YVNvdXJjZTogTWF0VGFibGVEYXRhU291cmNlPGFueT4pOiB2b2lkIHtcbiAgICAgICAgaWYgKFNlbGVjdGlvblV0aWxpdGllcy5pc0FsbFNlbGVjdGVkKHNlbGVjdGlvbiwgZGF0YVNvdXJjZSkpIHtcbiAgICAgICAgICAgIHNlbGVjdGlvbi5jbGVhcigpO1xuICAgICAgICB9XG4gICAgICAgIGVsc2Uge1xuICAgICAgICAgICAgZGF0YVNvdXJjZS5kYXRhLmZvckVhY2gocm93ID0+IHNlbGVjdGlvbi5zZWxlY3Qocm93KSk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICAvKipcbiAgICAgKiBSZW1vdmVzIGFsbCBzZWxlY3RlZCBlbnRyaWVzIGZyb20gdGhlIGFycmF5LlxuICAgICAqXG4gICAgICogQHBhcmFtIHNlbGVjdGlvbiAtIFRoZSBzZWxlY3Rpb24gY29udGFpbmluZyB0aGUgaXRlbXMgdG8gcmVtb3ZlLlxuICAgICAqIEBwYXJhbSB2YWx1ZXMgLSBUaGUgdmFsdWVzIG9mIHRoZSBkYXRhU291cmNlLlxuICAgICAqIEBwYXJhbSBkYXRhU291cmNlIC0gVGhlIGRhdGFTb3VyY2UuXG4gICAgICovXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnlcbiAgICBzdGF0aWMgcmVtb3ZlKHNlbGVjdGlvbjogU2VsZWN0aW9uTW9kZWw8YW55PiwgdmFsdWVzOiBhbnlbXSwgZGF0YVNvdXJjZTogTWF0VGFibGVEYXRhU291cmNlPGFueT4pOiB2b2lkIHtcbiAgICAgICAgc2VsZWN0aW9uLnNlbGVjdGVkLmZvckVhY2gocyA9PiB7XG4gICAgICAgICAgICB2YWx1ZXMuc3BsaWNlKHZhbHVlcy5pbmRleE9mKHMpLCAxKTtcbiAgICAgICAgfSk7XG4gICAgICAgIGRhdGFTb3VyY2UuZGF0YSA9IHZhbHVlcztcbiAgICAgICAgc2VsZWN0aW9uLmNsZWFyKCk7XG4gICAgfVxufSJdfQ==