ngx-material-entity 15.1.3 → 15.1.5

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 (98) 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/default.actions.d.ts +21 -0
  21. package/components/table/edit-dialog/{edit-dialog-data.builder.d.ts → edit-data.builder.d.ts} +7 -7
  22. package/components/table/edit-dialog/{edit-entity-dialog-data.d.ts → edit-entity-data.d.ts} +5 -5
  23. package/components/table/edit-dialog/edit-entity-dialog.component.d.ts +6 -6
  24. package/components/table/edit-dialog/edit-entity.builder.d.ts +24 -0
  25. package/components/table/table-data.builder.d.ts +11 -7
  26. package/components/table/table-data.d.ts +29 -8
  27. package/components/table/table.component.d.ts +14 -7
  28. package/components/table/table.module.d.ts +4 -3
  29. package/encapsulation/js-2-xml.utilities.d.ts +15 -0
  30. package/encapsulation/jszip.utilities.d.ts +3 -2
  31. package/encapsulation/lodash.utilities.d.ts +7 -0
  32. package/esm2020/classes/entity.model.mjs +2 -2
  33. package/esm2020/components/confirm-dialog/confirm-dialog.component.mjs +4 -4
  34. package/esm2020/components/edit-page/edit-page.component.mjs +203 -0
  35. package/esm2020/components/edit-page/page-edit-data.builder.mjs +32 -0
  36. package/esm2020/components/input/array/array-date-input/array-date-input.component.mjs +4 -4
  37. package/esm2020/components/input/array/array-date-range-input/array-date-range-input.component.mjs +4 -4
  38. package/esm2020/components/input/array/array-date-time-input/array-date-time-input.component.mjs +4 -4
  39. package/esm2020/components/input/array/array-table.class.mjs +3 -3
  40. package/esm2020/components/input/base-input.component.mjs +2 -2
  41. package/esm2020/components/input/date/date-input/date-input.component.mjs +2 -2
  42. package/esm2020/components/input/date/date-range-input/date-range-input.component.mjs +5 -5
  43. package/esm2020/components/input/date/date-time-input/date-time-input.component.mjs +3 -3
  44. package/esm2020/components/input/file/file-default-input/file-default-input.component.mjs +2 -2
  45. package/esm2020/components/input/file/file-image-input/file-image-input.component.mjs +3 -3
  46. package/esm2020/components/input/file/file-input/file-input.component.mjs +5 -5
  47. package/esm2020/components/input/input.component.mjs +6 -6
  48. package/esm2020/components/input/relations/references-many-input/references-many-input.component.mjs +4 -4
  49. package/esm2020/components/input/string/string-password-input/string-password-input.component.mjs +4 -4
  50. package/esm2020/components/table/create-dialog/create-entity-dialog-data.builder.mjs +2 -2
  51. package/esm2020/components/table/create-dialog/create-entity-dialog-data.mjs +1 -1
  52. package/esm2020/components/table/create-dialog/create-entity-dialog.component.mjs +5 -5
  53. package/esm2020/components/table/default.actions.mjs +65 -0
  54. package/esm2020/components/table/edit-dialog/edit-data.builder.mjs +41 -0
  55. package/esm2020/components/table/edit-dialog/edit-entity-data.mjs +2 -0
  56. package/esm2020/components/table/edit-dialog/edit-entity-dialog.component.mjs +16 -16
  57. package/esm2020/components/table/edit-dialog/edit-entity.builder.mjs +28 -0
  58. package/esm2020/components/table/table-data.builder.mjs +19 -8
  59. package/esm2020/components/table/table-data.mjs +1 -1
  60. package/esm2020/components/table/table.component.mjs +73 -29
  61. package/esm2020/components/table/table.module.mjs +5 -1
  62. package/esm2020/decorators/array/array-decorator-internal.data.mjs +2 -2
  63. package/esm2020/decorators/base/base-property.decorator.mjs +2 -2
  64. package/esm2020/decorators/date/date-decorator-internal.data.mjs +2 -2
  65. package/esm2020/decorators/date/date.decorator.mjs +2 -2
  66. package/esm2020/decorators/file/file.decorator.mjs +2 -2
  67. package/esm2020/decorators/string/string.decorator.mjs +2 -2
  68. package/esm2020/encapsulation/js-2-xml.utilities.mjs +18 -0
  69. package/esm2020/encapsulation/jszip.utilities.mjs +1 -1
  70. package/esm2020/encapsulation/lodash.utilities.mjs +13 -1
  71. package/esm2020/public-api.mjs +31 -26
  72. package/esm2020/services/entity.service.mjs +252 -0
  73. package/esm2020/services/unsaved-changes.guard.mjs +14 -0
  74. package/esm2020/utilities/date.utilities.mjs +158 -0
  75. package/esm2020/utilities/entity.utilities.mjs +828 -0
  76. package/esm2020/utilities/file.utilities.mjs +176 -0
  77. package/esm2020/utilities/selection.utilities.mjs +50 -0
  78. package/fesm2015/ngx-material-entity.mjs +1071 -644
  79. package/fesm2015/ngx-material-entity.mjs.map +1 -1
  80. package/fesm2020/ngx-material-entity.mjs +992 -571
  81. package/fesm2020/ngx-material-entity.mjs.map +1 -1
  82. package/package.json +3 -2
  83. package/public-api.d.ts +28 -25
  84. package/{classes → services}/entity.service.d.ts +25 -1
  85. package/services/unsaved-changes.guard.d.ts +4 -0
  86. package/{classes → utilities}/entity.utilities.d.ts +1 -1
  87. package/{classes → utilities}/file.utilities.d.ts +7 -0
  88. package/components/table/edit-dialog/edit-entity-dialog.builder.d.ts +0 -24
  89. package/esm2020/classes/date.utilities.mjs +0 -158
  90. package/esm2020/classes/entity.service.mjs +0 -213
  91. package/esm2020/classes/entity.utilities.mjs +0 -828
  92. package/esm2020/classes/file.utilities.mjs +0 -163
  93. package/esm2020/classes/selection.utilities.mjs +0 -50
  94. package/esm2020/components/table/edit-dialog/edit-dialog-data.builder.mjs +0 -41
  95. package/esm2020/components/table/edit-dialog/edit-entity-dialog-data.mjs +0 -2
  96. package/esm2020/components/table/edit-dialog/edit-entity-dialog.builder.mjs +0 -28
  97. /package/{classes → utilities}/date.utilities.d.ts +0 -0
  98. /package/{classes → utilities}/selection.utilities.d.ts +0 -0
@@ -0,0 +1,14 @@
1
+ import { Observable } from 'rxjs';
2
+ // eslint-disable-next-line jsdoc/require-jsdoc, @typescript-eslint/no-explicit-any
3
+ export function UnsavedChangesGuard(component) {
4
+ return new Observable((obs) => {
5
+ if (component.canDeactivate()) {
6
+ obs.next(true);
7
+ return;
8
+ }
9
+ component.openConfirmNavigationDialog().subscribe(v => {
10
+ obs.next(v);
11
+ });
12
+ });
13
+ }
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidW5zYXZlZC1jaGFuZ2VzLmd1YXJkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LW1hdGVyaWFsLWVudGl0eS9zcmMvc2VydmljZXMvdW5zYXZlZC1jaGFuZ2VzLmd1YXJkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFHbEMsbUZBQW1GO0FBQ25GLE1BQU0sVUFBVSxtQkFBbUIsQ0FBQyxTQUE2QztJQUM3RSxPQUFPLElBQUksVUFBVSxDQUFvQixDQUFDLEdBQUcsRUFBRSxFQUFFO1FBQzdDLElBQUksU0FBUyxDQUFDLGFBQWEsRUFBRSxFQUFFO1lBQzNCLEdBQUcsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDZixPQUFPO1NBQ1Y7UUFFRCxTQUFTLENBQUMsMkJBQTJCLEVBQUUsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUU7WUFDbEQsR0FBRyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNoQixDQUFDLENBQUMsQ0FBQztJQUNQLENBQUMsQ0FBQyxDQUFDO0FBQ1AsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFVybFRyZWUgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgTmd4TWF0RW50aXR5RWRpdFBhZ2VDb21wb25lbnQgfSBmcm9tICcuLi9jb21wb25lbnRzL2VkaXQtcGFnZS9lZGl0LXBhZ2UuY29tcG9uZW50JztcblxuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGpzZG9jL3JlcXVpcmUtanNkb2MsIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnlcbmV4cG9ydCBmdW5jdGlvbiBVbnNhdmVkQ2hhbmdlc0d1YXJkKGNvbXBvbmVudDogTmd4TWF0RW50aXR5RWRpdFBhZ2VDb21wb25lbnQ8YW55Pik6IE9ic2VydmFibGU8Ym9vbGVhbiB8IFVybFRyZWU+IHtcbiAgICByZXR1cm4gbmV3IE9ic2VydmFibGU8Ym9vbGVhbiB8IFVybFRyZWU+KChvYnMpID0+IHtcbiAgICAgICAgaWYgKGNvbXBvbmVudC5jYW5EZWFjdGl2YXRlKCkpIHtcbiAgICAgICAgICAgIG9icy5uZXh0KHRydWUpO1xuICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgY29tcG9uZW50Lm9wZW5Db25maXJtTmF2aWdhdGlvbkRpYWxvZygpLnN1YnNjcmliZSh2ID0+IHtcbiAgICAgICAgICAgIG9icy5uZXh0KHYpO1xuICAgICAgICB9KTtcbiAgICB9KTtcbn0iXX0=
@@ -0,0 +1,158 @@
1
+ import { LodashUtilities } from '../encapsulation/lodash.utilities';
2
+ const DAY_IN_MS = 1000 * 60 * 60 * 24;
3
+ /**
4
+ * Contains Helper Functions for handling date properties.
5
+ */
6
+ export class DateUtilities {
7
+ /**
8
+ * Gets the given value as a date value.
9
+ *
10
+ * @param value - The value to get as a date.
11
+ * @returns The given value as a date.
12
+ */
13
+ static asDate(value) {
14
+ return value;
15
+ }
16
+ /**
17
+ * Gets the default times used by the DateTime picker when nothing is specified by the user.
18
+ *
19
+ * @param format - The time format. Defaults to 24.
20
+ * @param minuteSteps - The steps from one time value to the next. Defaults to 30.
21
+ * @returns Times in the 24 hour format from 0:00 until 23:30 in 30 minute steps.
22
+ */
23
+ static getDefaultTimes(format = 24, minuteSteps = 30) {
24
+ const res = [{ displayName: '-', value: undefined }];
25
+ for (let hour = 0; hour < 24; hour++) {
26
+ for (let minute = 0; minute < 60; minute += minuteSteps) {
27
+ res.push(DateUtilities.getTimeDropdownValue(format, hour, minute));
28
+ }
29
+ }
30
+ return res;
31
+ }
32
+ static getTimeDropdownValue(format, hour, minute) {
33
+ const displayHour = DateUtilities.getFormattedHour(format, LodashUtilities.cloneDeep(hour));
34
+ const displayMinute = DateUtilities.getFormattedMinute(format, hour, minute);
35
+ return {
36
+ displayName: `${displayHour}:${displayMinute}`,
37
+ value: {
38
+ hours: hour,
39
+ minutes: minute
40
+ }
41
+ };
42
+ }
43
+ static getFormattedHour(format, hour) {
44
+ if (format === 12 && hour > 12) {
45
+ hour -= 12;
46
+ }
47
+ return hour;
48
+ }
49
+ static getFormattedMinute(format, hour, minute) {
50
+ let res = `${minute}`;
51
+ if (format === 12) {
52
+ if (hour > 12) {
53
+ res = `${minute} PM`;
54
+ }
55
+ else {
56
+ res = `${minute} AM`;
57
+ }
58
+ }
59
+ if (minute.toString().length === 1) {
60
+ res = '0'.concat(res);
61
+ }
62
+ return res;
63
+ }
64
+ /**
65
+ * Gets the Time object from the given date.
66
+ *
67
+ * @param value - The date to get the time object from.
68
+ * @returns The Time object build from the date value.
69
+ */
70
+ static getTimeFromDate(value) {
71
+ if (!value) {
72
+ return undefined;
73
+ }
74
+ else {
75
+ return {
76
+ hours: new Date(value).getHours(),
77
+ minutes: new Date(value).getMinutes()
78
+ };
79
+ }
80
+ }
81
+ /**
82
+ * Gets the dates between the two given gates. Does additional filtering based on the provided DateRange metadata.
83
+ *
84
+ * @param startDate - The start date.
85
+ * @param endDate - The end date.
86
+ * @param filter - The custom filter from the metadata.
87
+ * @returns All dates between the two provided dates. Includes start and end date.
88
+ */
89
+ static getDatesBetween(startDate, endDate, filter) {
90
+ const res = [];
91
+ while (startDate.getFullYear() < endDate.getFullYear()
92
+ || startDate.getMonth() < endDate.getMonth()
93
+ || startDate.getDate() <= endDate.getDate()) {
94
+ res.push(new Date(startDate));
95
+ startDate.setTime(startDate.getTime() + DAY_IN_MS);
96
+ }
97
+ if (filter) {
98
+ return res.filter(d => filter(d));
99
+ }
100
+ else {
101
+ return res;
102
+ }
103
+ }
104
+ /**
105
+ * Get all valid times for the dropdown of a datetime property.
106
+ *
107
+ * @param times - All given times to filter.
108
+ * @param date - The date of the datetime.
109
+ * @param min - The function that defines the minimum time.
110
+ * @param max - The function that defines the maximum time.
111
+ * @param filter - A filter function to do more specific time filtering. This could be e.g. The removal of lunch breaks.
112
+ * @returns All valid dropdown values for the datetime property.
113
+ */
114
+ static getValidTimesForDropdown(times, date, min, max, filter) {
115
+ if (min) {
116
+ const minTime = min(date);
117
+ times = times.filter(t => !t.value
118
+ || t.value.hours > minTime.hours
119
+ || (t.value.hours === minTime.hours
120
+ && t.value.minutes >= minTime.minutes));
121
+ }
122
+ if (max) {
123
+ const maxTime = max(date);
124
+ times = times.filter(t => !t.value
125
+ || t.value.hours < maxTime.hours
126
+ || (t.value.hours === maxTime.hours
127
+ && t.value.minutes <= maxTime.minutes));
128
+ }
129
+ if (filter) {
130
+ times = times.filter(t => !t.value || filter(t.value));
131
+ }
132
+ return times;
133
+ }
134
+ /**
135
+ * Checks if the time object has processable hours and minutes properties.
136
+ * Doesn't check custom validators like min/max from the metadata configuration.
137
+ *
138
+ * @param time - The time to check.
139
+ * @returns Whether or not the time object is unprocessable.
140
+ */
141
+ static timeIsUnprocessable(time) {
142
+ if (!time
143
+ || time.hours == null
144
+ || typeof time.hours !== 'number'
145
+ || Number.isNaN(time.hours)
146
+ || time.minutes == null
147
+ || typeof time.minutes !== 'number'
148
+ || Number.isNaN(time.minutes)) {
149
+ return true;
150
+ }
151
+ return false;
152
+ }
153
+ }
154
+ /**
155
+ * The default filter function to user when none was provided by the user.
156
+ */
157
+ DateUtilities.defaultDateFilter = () => true;
158
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date.utilities.js","sourceRoot":"","sources":["../../../../projects/ngx-material-entity/src/utilities/date.utilities.ts"],"names":[],"mappings":"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","sourcesContent":["import { Time } from '@angular/common';\nimport { DateFilterFn } from '@angular/material/datepicker';\nimport { LodashUtilities } from '../encapsulation/lodash.utilities';\nimport { DropdownValue } from '../decorators/base/dropdown-value.interface';\n\nconst DAY_IN_MS: number = 1000 * 60 * 60 * 24;\n\n/**\n * Valid steps from one time value to the next. Needs to be able to divide 60 minutes without remainder.\n */\ntype MinuteSteps = 1 | 2 | 3 | 4 | 5 | 6 | 10 | 12 | 15 | 20 | 30 | 60;\n\n/**\n * Contains Helper Functions for handling date properties.\n */\nexport abstract class DateUtilities {\n\n    /**\n     * The default filter function to user when none was provided by the user.\n     */\n    static defaultDateFilter: DateFilterFn<Date | null | undefined> = () => true;\n\n    /**\n     * Gets the given value as a date value.\n     *\n     * @param value - The value to get as a date.\n     * @returns The given value as a date.\n     */\n    static asDate(value: unknown): Date {\n        return value as Date;\n    }\n\n    /**\n     * Gets the default times used by the DateTime picker when nothing is specified by the user.\n     *\n     * @param format - The time format. Defaults to 24.\n     * @param minuteSteps - The steps from one time value to the next. Defaults to 30.\n     * @returns Times in the 24 hour format from 0:00 until 23:30 in 30 minute steps.\n     */\n    static getDefaultTimes(format: 12 | 24 = 24, minuteSteps: MinuteSteps = 30): DropdownValue<Time>[] {\n        const res: DropdownValue<Time>[] = [{ displayName: '-', value: undefined as unknown as Time }];\n        for (let hour: number = 0; hour < 24; hour++) {\n            for (let minute: number = 0; minute < 60; minute += minuteSteps) {\n                res.push(DateUtilities.getTimeDropdownValue(format, hour, minute));\n            }\n        }\n        return res;\n    }\n\n    private static getTimeDropdownValue(format: 12 | 24, hour: number, minute: number): DropdownValue<Time> {\n        const displayHour: number = DateUtilities.getFormattedHour(format, LodashUtilities.cloneDeep(hour));\n        const displayMinute: string = DateUtilities.getFormattedMinute(format, hour, minute);\n        return {\n            displayName: `${displayHour}:${displayMinute}`,\n            value: {\n                hours: hour,\n                minutes: minute\n            }\n        };\n    }\n\n    private static getFormattedHour(format: 12 | 24, hour: number): number {\n        if (format === 12 && hour > 12) {\n            hour -= 12;\n        }\n        return hour;\n    }\n\n    private static getFormattedMinute(format: 12 | 24, hour: number, minute: number): string {\n        let res: string = `${minute}`;\n        if (format === 12) {\n            if (hour > 12) {\n                res = `${minute} PM`;\n            }\n            else {\n                res = `${minute} AM`;\n            }\n        }\n        if (minute.toString().length === 1) {\n            res = '0'.concat(res);\n        }\n        return res;\n    }\n\n    /**\n     * Gets the Time object from the given date.\n     *\n     * @param value - The date to get the time object from.\n     * @returns The Time object build from the date value.\n     */\n    static getTimeFromDate(value?: Date): Time | undefined {\n        if (!value) {\n            return undefined;\n        }\n        else {\n            return {\n                hours: new Date(value).getHours(),\n                minutes: new Date(value).getMinutes()\n            };\n        }\n    }\n\n    /**\n     * Gets the dates between the two given gates. Does additional filtering based on the provided DateRange metadata.\n     *\n     * @param startDate - The start date.\n     * @param endDate - The end date.\n     * @param filter - The custom filter from the metadata.\n     * @returns All dates between the two provided dates. Includes start and end date.\n     */\n    static getDatesBetween(\n        startDate: Date,\n        endDate: Date,\n        filter?: DateFilterFn<Date>\n    ): Date[] {\n        const res: Date[] = [];\n        while (\n            startDate.getFullYear() < endDate.getFullYear()\n            || startDate.getMonth() < endDate.getMonth()\n            || startDate.getDate() <= endDate.getDate()\n        ) {\n            res.push(new Date(startDate));\n            startDate.setTime(startDate.getTime() + DAY_IN_MS);\n        }\n        if (filter) {\n            return res.filter(d => filter(d));\n        }\n        else {\n            return res;\n        }\n    }\n\n    /**\n     * Get all valid times for the dropdown of a datetime property.\n     *\n     * @param times - All given times to filter.\n     * @param date - The date of the datetime.\n     * @param min - The function that defines the minimum time.\n     * @param max - The function that defines the maximum time.\n     * @param filter - A filter function to do more specific time filtering. This could be e.g. The removal of lunch breaks.\n     * @returns All valid dropdown values for the datetime property.\n     */\n    static getValidTimesForDropdown(\n        times: DropdownValue<Time | undefined>[],\n        date?: Date,\n        min?: (date?: Date) => Time,\n        max?: (date?: Date) => Time,\n        filter?: ((time: Time) => boolean) | (() => boolean)\n    ): DropdownValue<Time | undefined>[] {\n        if (min) {\n            const minTime: Time = min(date);\n            times = times.filter(t =>\n                !t.value\n                || t.value.hours > minTime.hours\n                || (\n                    t.value.hours === minTime.hours\n                    && t.value.minutes >= minTime.minutes\n                )\n            );\n        }\n        if (max) {\n            const maxTime: Time = max(date);\n            times = times.filter(t =>\n                !t.value\n                || t.value.hours < maxTime.hours\n                || (\n                    t.value.hours === maxTime.hours\n                    && t.value.minutes <= maxTime.minutes\n                )\n            );\n        }\n        if (filter) {\n            times = times.filter(t => !t.value || filter(t.value));\n        }\n\n        return times;\n    }\n\n    /**\n     * Checks if the time object has processable hours and minutes properties.\n     * Doesn't check custom validators like min/max from the metadata configuration.\n     *\n     * @param time - The time to check.\n     * @returns Whether or not the time object is unprocessable.\n     */\n    static timeIsUnprocessable(time?: Time): boolean {\n        if (\n            !time\n            || time.hours == null\n            || typeof time.hours !== 'number'\n            || Number.isNaN(time.hours)\n            || time.minutes == null\n            || typeof time.minutes !== 'number'\n            || Number.isNaN(time.minutes)\n        ) {\n            return true;\n        }\n        return false;\n    }\n}"]}