@techextensor/tab-sdk 0.0.3 → 0.0.6

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 (47) hide show
  1. package/esm2022/lib/app/analytics.service.mjs +51 -0
  2. package/esm2022/lib/app/app.service.mjs +145 -0
  3. package/esm2022/lib/app/file.service.mjs +41 -0
  4. package/esm2022/lib/app/release.service.mjs +38 -0
  5. package/esm2022/lib/app/report.service.mjs +48 -0
  6. package/esm2022/lib/app/translator.service.mjs +77 -0
  7. package/esm2022/lib/auth/auth.service.mjs +95 -0
  8. package/esm2022/lib/crud/crud.service.mjs +161 -0
  9. package/esm2022/lib/enum/store.enum.mjs +6 -0
  10. package/esm2022/lib/enum/ui.enum.mjs +13 -0
  11. package/esm2022/lib/http/http.service.mjs +58 -0
  12. package/esm2022/lib/interface/http.interface.mjs +2 -0
  13. package/esm2022/lib/interface/ui.interface.mjs +2 -0
  14. package/esm2022/lib/store/store.service.mjs +719 -0
  15. package/esm2022/lib/tab-sdk.service.mjs +52 -18
  16. package/esm2022/lib/ui/form.service.mjs +58 -76
  17. package/esm2022/lib/ui/ui.service.mjs +297 -2
  18. package/esm2022/lib/util/util.service.mjs +53 -0
  19. package/esm2022/lib/workflow/transition.service.mjs +40 -0
  20. package/fesm2022/techextensor-tab-sdk.mjs +1855 -341
  21. package/fesm2022/techextensor-tab-sdk.mjs.map +1 -1
  22. package/lib/app/analytics.service.d.ts +28 -0
  23. package/lib/app/app.service.d.ts +81 -0
  24. package/lib/app/file.service.d.ts +22 -0
  25. package/lib/app/release.service.d.ts +23 -0
  26. package/lib/app/report.service.d.ts +28 -0
  27. package/lib/app/translator.service.d.ts +49 -0
  28. package/lib/auth/auth.service.d.ts +58 -0
  29. package/lib/crud/crud.service.d.ts +88 -0
  30. package/lib/enum/store.enum.d.ts +4 -0
  31. package/lib/enum/ui.enum.d.ts +10 -0
  32. package/lib/http/http.service.d.ts +35 -0
  33. package/lib/interface/http.interface.d.ts +8 -0
  34. package/lib/interface/ui.interface.d.ts +24 -0
  35. package/lib/store/store.service.d.ts +406 -0
  36. package/lib/tab-sdk.service.d.ts +24 -8
  37. package/lib/ui/form.service.d.ts +35 -44
  38. package/lib/ui/ui.service.d.ts +154 -0
  39. package/lib/util/util.service.d.ts +14 -0
  40. package/lib/workflow/transition.service.d.ts +21 -0
  41. package/package.json +2 -2
  42. package/esm2022/lib/common/utils.service.mjs +0 -163
  43. package/esm2022/lib/core/auth.service.mjs +0 -48
  44. package/esm2022/lib/data/data.service.mjs +0 -81
  45. package/lib/common/utils.service.d.ts +0 -58
  46. package/lib/core/auth.service.d.ts +0 -28
  47. package/lib/data/data.service.d.ts +0 -36
@@ -1,6 +1,301 @@
1
- import { Injectable } from "@angular/core";
1
+ import { inject, Injectable } from '@angular/core';
2
+ import { NavigationType, ScreenDisplayMode } from '../enum/ui.enum';
3
+ import { TabSdk } from '../tab-sdk.service';
4
+ import { ConfirmationService, NotificationService, NotificationType } from '@techextensor/tab-core-utility';
2
5
  import * as i0 from "@angular/core";
3
6
  export class UiService {
7
+ _notificationService = inject(NotificationService);
8
+ _confirmationService = inject(ConfirmationService);
9
+ /**
10
+ * Open a screen with the given options. The mode determines how the screen is
11
+ * displayed.
12
+ *
13
+ * @param options The options for opening the screen.
14
+ */
15
+ openScreen(options) {
16
+ const { mode, screenId, reqtokens, submission, title, width, height, customClass } = options;
17
+ switch (mode) {
18
+ case ScreenDisplayMode.Sidebar:
19
+ this.showSidebar({ screenId, reqtokens, submission, title, width, height, customClass });
20
+ break;
21
+ case ScreenDisplayMode.Popup:
22
+ this.showDialog({ screenId, reqtokens, submission, title, width, height, customClass });
23
+ break;
24
+ case ScreenDisplayMode.SameTab:
25
+ this.navigateTo({ screenId, reqtokens });
26
+ break;
27
+ case ScreenDisplayMode.NewTab:
28
+ this.openInNewTab({ screenId, reqtokens });
29
+ break;
30
+ }
31
+ }
32
+ /**
33
+ * Opens a screen in a sidebar.
34
+ *
35
+ * @param options The options for opening the sidebar.
36
+ */
37
+ showSidebar(options) {
38
+ const otherConfiguration = {
39
+ ...(options.title && { title: options.title }),
40
+ ...(options.width && { width: options.width }),
41
+ ...(options.height && { height: options.height }),
42
+ ...(options.customClass && { customClass: options.customClass })
43
+ };
44
+ TabSdk.util?.openScreen(ScreenDisplayMode.Sidebar, options.screenId, options.reqtokens || undefined, options.submission || undefined, Object.keys(otherConfiguration).length > 0 ? otherConfiguration : undefined);
45
+ }
46
+ /**
47
+ * Opens a screen in a popup dialog.
48
+ *
49
+ * @param options The options for opening the dialog.
50
+ */
51
+ showDialog(options) {
52
+ const otherConfiguration = {
53
+ ...(options.title && { title: options.title }),
54
+ ...(options.width && { width: options.width }),
55
+ ...(options.height && { height: options.height }),
56
+ ...(options.customClass && { customClass: options.customClass })
57
+ };
58
+ TabSdk.util?.openScreen(ScreenDisplayMode.Popup, options.screenId, options.reqtokens || undefined, options.submission || undefined, Object.keys(otherConfiguration).length > 0 ? otherConfiguration : undefined);
59
+ }
60
+ /**
61
+ * Navigates to a screen within the same tab.
62
+ *
63
+ * @param options - The options for navigation, including screenId and optional reqtokens.
64
+ */
65
+ navigateTo(options) {
66
+ TabSdk.util?.openScreen(ScreenDisplayMode.SameTab, options.screenId, options.reqtokens || undefined);
67
+ }
68
+ /**
69
+ * Navigates to a screen in a new tab.
70
+ *
71
+ * @param options The options for navigation, including screenId and optional reqtokens.
72
+ */
73
+ openInNewTab(options) {
74
+ TabSdk.util?.openScreen(ScreenDisplayMode.NewTab, options.screenId, options.reqtokens || undefined);
75
+ }
76
+ /**
77
+ * Navigates to the specified URL.
78
+ *
79
+ * @param url - The URL to navigate to.
80
+ */
81
+ navigateToUrl(url) {
82
+ TabSdk.util?.navigateToUrl({
83
+ url,
84
+ type: NavigationType.NavigateToUrl
85
+ });
86
+ }
87
+ /**
88
+ * Navigates to a specified subdomain using the provided options.
89
+ *
90
+ * @param options - The options for navigation, including subDomain, appCode, and url.
91
+ */
92
+ navigateToSubdomain(options) {
93
+ TabSdk.util?.navigateToUrl({
94
+ ...options,
95
+ type: NavigationType.NavigateToUrl
96
+ });
97
+ }
98
+ /**
99
+ * Retrieves the active screen ID from the current URL.
100
+ *
101
+ * @returns The screen ID if present in the URL, otherwise undefined.
102
+ */
103
+ getActiveUrlScreenId() {
104
+ // Split the URL pathname using the app name and '/screen/' as delimiters
105
+ const urlParts = window?.location?.pathname?.split(TabSdk.store.appName + '/screen/');
106
+ // Extract the screen ID part and remove any query parameters
107
+ const screenId = urlParts?.[1]?.split('?')[0];
108
+ // Return the screen ID or undefined if not found
109
+ return screenId;
110
+ }
111
+ /**
112
+ * Show a notification to the user.
113
+ *
114
+ * @param options The options for the notification.
115
+ */
116
+ notify(options) {
117
+ this._notificationService.notify({
118
+ type: options.type,
119
+ message: TabSdk.translator.translate(options.message),
120
+ ...(options?.title ? { title: TabSdk.translator.translate(options.title) } : {}),
121
+ ...(options?.configuration ? { configuration: options.configuration } : {}),
122
+ });
123
+ }
124
+ /**
125
+ * Displays a success notification to the user.
126
+ *
127
+ * @param options - The options for the notification, including message, title, and configuration.
128
+ */
129
+ showSuccess(options) {
130
+ this.notify({
131
+ ...options,
132
+ type: NotificationType.Success,
133
+ title: options?.title ?? 'Success'
134
+ });
135
+ }
136
+ /**
137
+ * Displays a warning notification to the user.
138
+ *
139
+ * @param options - The options for the notification, including message, title, and configuration.
140
+ */
141
+ showWarning(options) {
142
+ this.notify({
143
+ ...options,
144
+ type: NotificationType.Warning,
145
+ title: options?.title ?? 'Warning'
146
+ });
147
+ }
148
+ /**
149
+ * Displays an info notification to the user.
150
+ *
151
+ * @param options - The options for the notification, including message, title, and configuration.
152
+ */
153
+ showInfo(options) {
154
+ this.notify({
155
+ ...options,
156
+ type: NotificationType.Info,
157
+ title: options?.title ?? 'Info'
158
+ });
159
+ }
160
+ /**
161
+ * Displays an error notification to the user.
162
+ *
163
+ * @param options - The options for the notification, including message, title, and configuration.
164
+ */
165
+ showError(options) {
166
+ this.notify({
167
+ ...options,
168
+ type: NotificationType.Error,
169
+ title: options?.title ?? 'Error'
170
+ });
171
+ }
172
+ /**
173
+ * Displays a confirmation dialog to the user and returns a promise that resolves
174
+ * to a boolean indicating whether the user confirmed the action.
175
+ *
176
+ * @param options - The options for the confirmation dialog, including title, message,
177
+ * confirmText, cancelText, and visibility of buttons.
178
+ * @returns A promise that resolves to true if the user confirms, false otherwise.
179
+ */
180
+ confirm(options) {
181
+ return new Promise((resolve) => {
182
+ this._confirmationService.confirm(options)
183
+ ?.subscribe((isConfirmed) => {
184
+ resolve(isConfirmed);
185
+ });
186
+ });
187
+ }
188
+ /**
189
+ * Displays a confirmation dialog to the user with a title and message that indicates
190
+ * the user is about to delete an item. The confirmation dialog has a "Delete" and "Cancel"
191
+ * button.
192
+ *
193
+ * @param options - The options for the confirmation dialog, including the item name and
194
+ * optional message.
195
+ * @returns A promise that resolves to true if the user confirms, false otherwise.
196
+ */
197
+ confirmDelete(options) {
198
+ return this.confirm({
199
+ title: options?.title ?? `Are you sure you want to delete this record`,
200
+ message: options?.message ?? `You are about to delete the selected record. Are you sure you want to proceed?`,
201
+ primaryOption: 'Delete',
202
+ });
203
+ }
204
+ /**
205
+ * Displays a confirmation dialog to the user with a title and message that indicates
206
+ * the user is about to discard changes to an item. The confirmation dialog has a "Discard"
207
+ * and "Cancel" button.
208
+ *
209
+ * @param options - The options for the confirmation dialog, including the item name and
210
+ * optional message.
211
+ * @returns A promise that resolves to true if the user confirms, false otherwise.
212
+ */
213
+ confirmDiscard(options) {
214
+ return this.confirm({
215
+ title: `Are you sure you want to discard your changes`,
216
+ message: options?.message ?? `You are about to discard your changes. Are you sure you want to proceed?`,
217
+ primaryOption: 'Discard',
218
+ });
219
+ }
220
+ /**
221
+ * Closes the confirmation dialog.
222
+ *
223
+ * This method can be used to manually close the confirmation dialog.
224
+ */
225
+ closeConfirmationDialog() {
226
+ // Close the confirmation dialog
227
+ this._confirmationService.closeDialog();
228
+ }
229
+ /**
230
+ * Retrieves the confirmation emitter from the confirmation service.
231
+ *
232
+ * @returns The confirmation emitter used for emitting confirmation events.
233
+ */
234
+ getConformationEmitter() {
235
+ return this._confirmationService.getConformationEmitter();
236
+ }
237
+ /**
238
+ * Retrieves the dialog emitter from the confirmation service.
239
+ *
240
+ * The dialog emitter is an RxJS Subject that emits whenever a confirmation dialog is
241
+ * opened or closed. The value emitted is a boolean indicating whether a dialog is
242
+ * currently open.
243
+ *
244
+ * @returns The dialog emitter used for emitting confirmation dialog events.
245
+ */
246
+ getDialogEmitter() {
247
+ return this._confirmationService.getDialogEmitter();
248
+ }
249
+ /**
250
+ * Retrieves the remove emitter from the confirmation service.
251
+ *
252
+ * The remove emitter is an RxJS Subject that emits whenever a removal confirmation
253
+ * dialog is opened or closed. The value emitted is a boolean indicating whether a
254
+ * removal dialog is currently open.
255
+ *
256
+ * @returns The remove emitter used for emitting removal confirmation dialog events.
257
+ */
258
+ getRemoveEmitter() {
259
+ return this._confirmationService.getRemoveEmitter();
260
+ }
261
+ /**
262
+ * Copies the provided text to the clipboard and displays a success notification.
263
+ *
264
+ * @param text - The text to be copied to the clipboard.
265
+ */
266
+ copyToClipboard(text) {
267
+ // Create a temporary input element to hold the text
268
+ const tempInput = document.createElement("input");
269
+ // Set the input's value to the text to be copied
270
+ tempInput.value = text;
271
+ // Append the temporary input to the document body
272
+ document.body.appendChild(tempInput);
273
+ // Select the text in the input element
274
+ tempInput.select();
275
+ // Execute the copy command
276
+ document.execCommand("copy");
277
+ // Remove the temporary input from the document body
278
+ document.body.removeChild(tempInput);
279
+ // Show a success notification
280
+ this.showSuccess({
281
+ message: "",
282
+ title: "Copied to clipboard!",
283
+ configuration: {
284
+ timeOut: 1000,
285
+ positionClass: 'toast-top-center',
286
+ easing: 'ease-in',
287
+ easeTime: 300,
288
+ extendedTimeOut: 2000,
289
+ }
290
+ });
291
+ }
292
+ /**
293
+ * Copies the current URL to the clipboard and displays a success notification.
294
+ */
295
+ copyCurrentUrlToClipboard() {
296
+ // Use the copyToClipboard method to copy the current window URL
297
+ this.copyToClipboard(window.location.href);
298
+ }
4
299
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: UiService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
5
300
  static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: UiService, providedIn: 'root' });
6
301
  }
@@ -10,4 +305,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
10
305
  providedIn: 'root'
11
306
  }]
12
307
  }] });
13
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidWkuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RhYi1zZGsvc3JjL2xpYi91aS91aS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBSzNDLE1BQU0sT0FBTyxTQUFTO3dHQUFULFNBQVM7NEdBQVQsU0FBUyxjQUZOLE1BQU07OzRGQUVULFNBQVM7a0JBSHJCLFVBQVU7bUJBQUM7b0JBQ1IsVUFBVSxFQUFFLE1BQU07aUJBQ3JCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5cbkBJbmplY3RhYmxlKHtcbiAgICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgVWlTZXJ2aWNlIHt9Il19
308
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui.service.js","sourceRoot":"","sources":["../../../../../projects/tab-sdk/src/lib/ui/ui.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { inject, Injectable } from '@angular/core';\nimport {\n    ScreenOpenOptions,\n    NavigationOptions,\n    BaseScreenOptions,\n    NavigateToSubdomainOptions\n} from '../interface/ui.interface';\nimport { NavigationType, ScreenDisplayMode } from '../enum/ui.enum';\nimport { TabSdk } from '../tab-sdk.service';\nimport { BaseNotificationOptions, ConfirmationOptions, ConfirmationService, NotificationOptions, NotificationService, NotificationType } from '@techextensor/tab-core-utility';\n\n@Injectable({\n    providedIn: 'root'\n})\nexport class UiService {\n    private readonly _notificationService: NotificationService = inject(NotificationService);\n    private readonly _confirmationService: ConfirmationService = inject(ConfirmationService);\n\n    /**\n     * Open a screen with the given options. The mode determines how the screen is\n     * displayed.\n     *\n     * @param options The options for opening the screen.\n     */\n    openScreen(options: ScreenOpenOptions): void {\n        const { mode, screenId, reqtokens, submission, title, width, height, customClass } = options;\n\n        switch (mode) {\n            case ScreenDisplayMode.Sidebar:\n                this.showSidebar({ screenId, reqtokens, submission, title, width, height, customClass });\n                break;\n\n            case ScreenDisplayMode.Popup:\n                this.showDialog({ screenId, reqtokens, submission, title, width, height, customClass });\n                break;\n\n            case ScreenDisplayMode.SameTab:\n                this.navigateTo({ screenId, reqtokens });\n                break;\n\n            case ScreenDisplayMode.NewTab:\n                this.openInNewTab({ screenId, reqtokens });\n                break;\n        }\n    }\n\n    /**\n     * Opens a screen in a sidebar.\n     *\n     * @param options The options for opening the sidebar.\n     */\n    showSidebar(options: BaseScreenOptions): void {\n        const otherConfiguration = {\n            ...(options.title && { title: options.title }),\n            ...(options.width && { width: options.width }),\n            ...(options.height && { height: options.height }),\n            ...(options.customClass && { customClass: options.customClass })\n        };\n\n        TabSdk.util?.openScreen(\n            ScreenDisplayMode.Sidebar,\n            options.screenId,\n            options.reqtokens || undefined,\n            options.submission || undefined,\n            Object.keys(otherConfiguration).length > 0 ? otherConfiguration : undefined\n        );\n    }\n\n    /**\n     * Opens a screen in a popup dialog.\n     *\n     * @param options The options for opening the dialog.\n     */\n    showDialog(options: BaseScreenOptions): void {\n        const otherConfiguration = {\n            ...(options.title && { title: options.title }),\n            ...(options.width && { width: options.width }),\n            ...(options.height && { height: options.height }),\n            ...(options.customClass && { customClass: options.customClass })\n        };\n\n        TabSdk.util?.openScreen(\n            ScreenDisplayMode.Popup,\n            options.screenId,\n            options.reqtokens || undefined,\n            options.submission || undefined,\n            Object.keys(otherConfiguration).length > 0 ? otherConfiguration : undefined\n        );\n    }\n\n    /**\n     * Navigates to a screen within the same tab.\n     *\n     * @param options - The options for navigation, including screenId and optional reqtokens.\n     */\n    navigateTo(options: NavigationOptions): void {\n        TabSdk.util?.openScreen(\n            ScreenDisplayMode.SameTab,\n            options.screenId,\n            options.reqtokens || undefined\n        );\n    }\n\n    /**\n     * Navigates to a screen in a new tab.\n     *\n     * @param options The options for navigation, including screenId and optional reqtokens.\n     */\n    openInNewTab(options: NavigationOptions): void {\n        TabSdk.util?.openScreen(\n            ScreenDisplayMode.NewTab,\n            options.screenId,\n            options.reqtokens || undefined\n        );\n    }\n\n    /**\n     * Navigates to the specified URL.\n     *\n     * @param url - The URL to navigate to.\n     */\n    navigateToUrl(url: string): void {\n        TabSdk.util?.navigateToUrl({\n            url,\n            type: NavigationType.NavigateToUrl\n        })\n    }\n\n    /**\n     * Navigates to a specified subdomain using the provided options.\n     *\n     * @param options - The options for navigation, including subDomain, appCode, and url.\n     */\n    navigateToSubdomain(options: NavigateToSubdomainOptions): void {\n        TabSdk.util?.navigateToUrl({\n            ...options,\n            type: NavigationType.NavigateToUrl\n        })\n    }\n\n    /**\n     * Retrieves the active screen ID from the current URL.\n     *\n     * @returns The screen ID if present in the URL, otherwise undefined.\n     */\n    getActiveUrlScreenId(): string | undefined {\n        // Split the URL pathname using the app name and '/screen/' as delimiters\n        const urlParts = window?.location?.pathname?.split(TabSdk.store.appName + '/screen/');\n        // Extract the screen ID part and remove any query parameters\n        const screenId = urlParts?.[1]?.split('?')[0];\n        // Return the screen ID or undefined if not found\n        return screenId;\n    }\n\n    /**\n     * Show a notification to the user.\n     *\n     * @param options The options for the notification.\n     */\n    notify(options: NotificationOptions): void {\n        this._notificationService.notify({\n            type: options.type,\n            message: TabSdk.translator.translate(options.message),\n            ...(options?.title ? { title: TabSdk.translator.translate(options.title) } : {}),\n            ...(options?.configuration ? { configuration: options.configuration } : {}),\n        });\n    }\n\n    /**\n     * Displays a success notification to the user.\n     *\n     * @param options - The options for the notification, including message, title, and configuration.\n     */\n    showSuccess(options: BaseNotificationOptions): void {\n        this.notify({\n            ...options,\n            type: NotificationType.Success,\n            title: options?.title ?? 'Success'\n        });\n    }\n\n    /**\n     * Displays a warning notification to the user.\n     *\n     * @param options - The options for the notification, including message, title, and configuration.\n     */\n    showWarning(options: BaseNotificationOptions): void {\n        this.notify({\n            ...options,\n            type: NotificationType.Warning,\n            title: options?.title ?? 'Warning'\n        });\n    }\n\n    /**\n     * Displays an info notification to the user.\n     *\n     * @param options - The options for the notification, including message, title, and configuration.\n     */\n    showInfo(options: BaseNotificationOptions): void {\n        this.notify({\n            ...options,\n            type: NotificationType.Info,\n            title: options?.title ?? 'Info'\n        });\n    }\n\n    /**\n     * Displays an error notification to the user.\n     *\n     * @param options - The options for the notification, including message, title, and configuration.\n     */\n    showError(options: BaseNotificationOptions): void {\n        this.notify({\n            ...options,\n            type: NotificationType.Error,\n            title: options?.title ?? 'Error'\n        });\n    }\n\n    /**\n     * Displays a confirmation dialog to the user and returns a promise that resolves\n     * to a boolean indicating whether the user confirmed the action.\n     *\n     * @param options - The options for the confirmation dialog, including title, message,\n     * confirmText, cancelText, and visibility of buttons.\n     * @returns A promise that resolves to true if the user confirms, false otherwise.\n     */\n    confirm(options?: ConfirmationOptions): Promise<boolean> {\n        return new Promise((resolve) => {\n            this._confirmationService.confirm(options)\n                ?.subscribe((isConfirmed: boolean) => {\n                    resolve(isConfirmed);\n                });\n        });\n    }\n\n    /**\n     * Displays a confirmation dialog to the user with a title and message that indicates\n     * the user is about to delete an item. The confirmation dialog has a \"Delete\" and \"Cancel\"\n     * button.\n     *\n     * @param options - The options for the confirmation dialog, including the item name and\n     * optional message.\n     * @returns A promise that resolves to true if the user confirms, false otherwise.\n     */\n    confirmDelete(options?: ConfirmationOptions): Promise<boolean> {\n        return this.confirm({\n            title: options?.title ?? `Are you sure you want to delete this record`,\n            message: options?.message ?? `You are about to delete the selected record. Are you sure you want to proceed?`,\n            primaryOption: 'Delete',\n        });\n    }\n\n    /**\n     * Displays a confirmation dialog to the user with a title and message that indicates\n     * the user is about to discard changes to an item. The confirmation dialog has a \"Discard\"\n     * and \"Cancel\" button.\n     *\n     * @param options - The options for the confirmation dialog, including the item name and\n     * optional message.\n     * @returns A promise that resolves to true if the user confirms, false otherwise.\n     */\n    confirmDiscard(options?: ConfirmationOptions): Promise<boolean> {\n        return this.confirm({\n            title: `Are you sure you want to discard your changes`,\n            message: options?.message ?? `You are about to discard your changes. Are you sure you want to proceed?`,\n            primaryOption: 'Discard',\n        });\n    }\n\n    /**\n     * Closes the confirmation dialog.\n     *\n     * This method can be used to manually close the confirmation dialog.\n     */\n    closeConfirmationDialog() {\n        // Close the confirmation dialog\n        this._confirmationService.closeDialog();\n    }\n\n    /**\n     * Retrieves the confirmation emitter from the confirmation service.\n     * \n     * @returns The confirmation emitter used for emitting confirmation events.\n     */\n    getConformationEmitter() {\n        return this._confirmationService.getConformationEmitter();\n    }\n\n    /**\n     * Retrieves the dialog emitter from the confirmation service.\n     *\n     * The dialog emitter is an RxJS Subject that emits whenever a confirmation dialog is\n     * opened or closed. The value emitted is a boolean indicating whether a dialog is\n     * currently open.\n     *\n     * @returns The dialog emitter used for emitting confirmation dialog events.\n     */\n    getDialogEmitter() {\n        return this._confirmationService.getDialogEmitter();\n    }\n\n    /**\n     * Retrieves the remove emitter from the confirmation service.\n     * \n     * The remove emitter is an RxJS Subject that emits whenever a removal confirmation\n     * dialog is opened or closed. The value emitted is a boolean indicating whether a\n     * removal dialog is currently open.\n     * \n     * @returns The remove emitter used for emitting removal confirmation dialog events.\n     */\n    getRemoveEmitter() {\n        return this._confirmationService.getRemoveEmitter();\n    }\n\n    /**\n     * Copies the provided text to the clipboard and displays a success notification.\n     *\n     * @param text - The text to be copied to the clipboard.\n     */\n    copyToClipboard(text: string) {\n        // Create a temporary input element to hold the text\n        const tempInput = document.createElement(\"input\");\n\n        // Set the input's value to the text to be copied\n        tempInput.value = text;\n\n        // Append the temporary input to the document body\n        document.body.appendChild(tempInput);\n\n        // Select the text in the input element\n        tempInput.select();\n\n        // Execute the copy command\n        document.execCommand(\"copy\");\n\n        // Remove the temporary input from the document body\n        document.body.removeChild(tempInput);\n\n        // Show a success notification\n        this.showSuccess({\n            message: \"\",\n            title: \"Copied to clipboard!\",\n            configuration: {\n                timeOut: 1000,\n                positionClass: 'toast-top-center',\n                easing: 'ease-in',\n                easeTime: 300,\n                extendedTimeOut: 2000,\n            }\n        });\n    }\n\n    /**\n     * Copies the current URL to the clipboard and displays a success notification.\n     */\n    copyCurrentUrlToClipboard() {\n        // Use the copyToClipboard method to copy the current window URL\n        this.copyToClipboard(window.location.href);\n    }\n}"]}
@@ -0,0 +1,53 @@
1
+ import { Injectable } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class UtilService {
4
+ // Will store the services from context
5
+ _context = null;
6
+ _initialized = false;
7
+ /**
8
+ * Initializes the UtilService with context that contains service references
9
+ *
10
+ * @param context The context object containing service references
11
+ * @returns A proxy that intercepts and delegates method calls to the appropriate service
12
+ */
13
+ init(context) {
14
+ if (this._initialized) {
15
+ return this;
16
+ }
17
+ this._context = context;
18
+ this._initialized = true;
19
+ // Return a proxy that will intercept method calls
20
+ return new Proxy(this, {
21
+ get: (target, prop) => {
22
+ // First check if the property exists directly on UtilService
23
+ if (prop in target) {
24
+ return target[prop];
25
+ }
26
+ // Convert symbol to string if needed
27
+ const propName = prop.toString();
28
+ // Check context services first
29
+ if (this._context && Object.keys(this._context).length > 0) {
30
+ // Loop through each service in the context
31
+ for (const serviceName of Object.keys(this._context)) {
32
+ const service = this._context[serviceName];
33
+ if (service && typeof service === 'object' && propName in service && typeof service[propName] === 'function') {
34
+ // Return the bound function from the service
35
+ return service[propName].bind(service);
36
+ }
37
+ }
38
+ }
39
+ // If property not found anywhere, return undefined
40
+ return undefined;
41
+ }
42
+ });
43
+ }
44
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: UtilService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
45
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: UtilService, providedIn: 'root' });
46
+ }
47
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: UtilService, decorators: [{
48
+ type: Injectable,
49
+ args: [{
50
+ providedIn: 'root'
51
+ }]
52
+ }] });
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGFiLXNkay9zcmMvbGliL3V0aWwvdXRpbC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBSzNDLE1BQU0sT0FBTyxXQUFXO0lBQ3BCLHVDQUF1QztJQUMvQixRQUFRLEdBQVEsSUFBSSxDQUFDO0lBQ3JCLFlBQVksR0FBRyxLQUFLLENBQUM7SUFFN0I7Ozs7O09BS0c7SUFDSCxJQUFJLENBQUMsT0FBWTtRQUNiLElBQUksSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO1lBQ3BCLE9BQU8sSUFBSSxDQUFDO1FBQ2hCLENBQUM7UUFFRCxJQUFJLENBQUMsUUFBUSxHQUFHLE9BQU8sQ0FBQztRQUN4QixJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQztRQUV6QixrREFBa0Q7UUFDbEQsT0FBTyxJQUFJLEtBQUssQ0FBQyxJQUFJLEVBQUU7WUFDbkIsR0FBRyxFQUFFLENBQUMsTUFBVyxFQUFFLElBQXFCLEVBQUUsRUFBRTtnQkFDeEMsNkRBQTZEO2dCQUM3RCxJQUFJLElBQUksSUFBSSxNQUFNLEVBQUUsQ0FBQztvQkFDakIsT0FBUSxNQUFjLENBQUMsSUFBSSxDQUFDLENBQUM7Z0JBQ2pDLENBQUM7Z0JBRUQscUNBQXFDO2dCQUNyQyxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUM7Z0JBRWpDLCtCQUErQjtnQkFDL0IsSUFBSSxJQUFJLENBQUMsUUFBUSxJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLE1BQU0sR0FBRyxDQUFDLEVBQUUsQ0FBQztvQkFDekQsMkNBQTJDO29CQUMzQyxLQUFLLE1BQU0sV0FBVyxJQUFJLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUM7d0JBQ25ELE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsV0FBVyxDQUFDLENBQUM7d0JBQzNDLElBQUksT0FBTyxJQUFJLE9BQU8sT0FBTyxLQUFLLFFBQVEsSUFBSSxRQUFRLElBQUksT0FBTyxJQUFJLE9BQU8sT0FBTyxDQUFDLFFBQVEsQ0FBQyxLQUFLLFVBQVUsRUFBRSxDQUFDOzRCQUMzRyw2Q0FBNkM7NEJBQzdDLE9BQU8sT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQzt3QkFDM0MsQ0FBQztvQkFDTCxDQUFDO2dCQUNMLENBQUM7Z0JBRUQsbURBQW1EO2dCQUNuRCxPQUFPLFNBQVMsQ0FBQztZQUNyQixDQUFDO1NBQ0osQ0FBQyxDQUFDO0lBQ1AsQ0FBQzt3R0E5Q1EsV0FBVzs0R0FBWCxXQUFXLGNBRlIsTUFBTTs7NEZBRVQsV0FBVztrQkFIdkIsVUFBVTttQkFBQztvQkFDUixVQUFVLEVBQUUsTUFBTTtpQkFDckIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBJbmplY3RhYmxlKHtcbiAgICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgVXRpbFNlcnZpY2Uge1xuICAgIC8vIFdpbGwgc3RvcmUgdGhlIHNlcnZpY2VzIGZyb20gY29udGV4dFxuICAgIHByaXZhdGUgX2NvbnRleHQ6IGFueSA9IG51bGw7XG4gICAgcHJpdmF0ZSBfaW5pdGlhbGl6ZWQgPSBmYWxzZTtcblxuICAgIC8qKlxuICAgICAqIEluaXRpYWxpemVzIHRoZSBVdGlsU2VydmljZSB3aXRoIGNvbnRleHQgdGhhdCBjb250YWlucyBzZXJ2aWNlIHJlZmVyZW5jZXNcbiAgICAgKiBcbiAgICAgKiBAcGFyYW0gY29udGV4dCBUaGUgY29udGV4dCBvYmplY3QgY29udGFpbmluZyBzZXJ2aWNlIHJlZmVyZW5jZXNcbiAgICAgKiBAcmV0dXJucyBBIHByb3h5IHRoYXQgaW50ZXJjZXB0cyBhbmQgZGVsZWdhdGVzIG1ldGhvZCBjYWxscyB0byB0aGUgYXBwcm9wcmlhdGUgc2VydmljZVxuICAgICAqL1xuICAgIGluaXQoY29udGV4dDogYW55KTogYW55IHtcbiAgICAgICAgaWYgKHRoaXMuX2luaXRpYWxpemVkKSB7XG4gICAgICAgICAgICByZXR1cm4gdGhpcztcbiAgICAgICAgfVxuXG4gICAgICAgIHRoaXMuX2NvbnRleHQgPSBjb250ZXh0O1xuICAgICAgICB0aGlzLl9pbml0aWFsaXplZCA9IHRydWU7XG5cbiAgICAgICAgLy8gUmV0dXJuIGEgcHJveHkgdGhhdCB3aWxsIGludGVyY2VwdCBtZXRob2QgY2FsbHNcbiAgICAgICAgcmV0dXJuIG5ldyBQcm94eSh0aGlzLCB7XG4gICAgICAgICAgICBnZXQ6ICh0YXJnZXQ6IGFueSwgcHJvcDogc3RyaW5nIHwgc3ltYm9sKSA9PiB7XG4gICAgICAgICAgICAgICAgLy8gRmlyc3QgY2hlY2sgaWYgdGhlIHByb3BlcnR5IGV4aXN0cyBkaXJlY3RseSBvbiBVdGlsU2VydmljZVxuICAgICAgICAgICAgICAgIGlmIChwcm9wIGluIHRhcmdldCkge1xuICAgICAgICAgICAgICAgICAgICByZXR1cm4gKHRhcmdldCBhcyBhbnkpW3Byb3BdO1xuICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgIC8vIENvbnZlcnQgc3ltYm9sIHRvIHN0cmluZyBpZiBuZWVkZWRcbiAgICAgICAgICAgICAgICBjb25zdCBwcm9wTmFtZSA9IHByb3AudG9TdHJpbmcoKTtcblxuICAgICAgICAgICAgICAgIC8vIENoZWNrIGNvbnRleHQgc2VydmljZXMgZmlyc3RcbiAgICAgICAgICAgICAgICBpZiAodGhpcy5fY29udGV4dCAmJiBPYmplY3Qua2V5cyh0aGlzLl9jb250ZXh0KS5sZW5ndGggPiAwKSB7XG4gICAgICAgICAgICAgICAgICAgIC8vIExvb3AgdGhyb3VnaCBlYWNoIHNlcnZpY2UgaW4gdGhlIGNvbnRleHRcbiAgICAgICAgICAgICAgICAgICAgZm9yIChjb25zdCBzZXJ2aWNlTmFtZSBvZiBPYmplY3Qua2V5cyh0aGlzLl9jb250ZXh0KSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgY29uc3Qgc2VydmljZSA9IHRoaXMuX2NvbnRleHRbc2VydmljZU5hbWVdO1xuICAgICAgICAgICAgICAgICAgICAgICAgaWYgKHNlcnZpY2UgJiYgdHlwZW9mIHNlcnZpY2UgPT09ICdvYmplY3QnICYmIHByb3BOYW1lIGluIHNlcnZpY2UgJiYgdHlwZW9mIHNlcnZpY2VbcHJvcE5hbWVdID09PSAnZnVuY3Rpb24nKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgLy8gUmV0dXJuIHRoZSBib3VuZCBmdW5jdGlvbiBmcm9tIHRoZSBzZXJ2aWNlXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuIHNlcnZpY2VbcHJvcE5hbWVdLmJpbmQoc2VydmljZSk7XG4gICAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICB9XG5cbiAgICAgICAgICAgICAgICAvLyBJZiBwcm9wZXJ0eSBub3QgZm91bmQgYW55d2hlcmUsIHJldHVybiB1bmRlZmluZWRcbiAgICAgICAgICAgICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgICAgICAgICAgfVxuICAgICAgICB9KTtcbiAgICB9XG59Il19
@@ -0,0 +1,40 @@
1
+ import { inject, Injectable } from '@angular/core';
2
+ import { TabBlueprintService } from '@techextensor/tab-core-utility';
3
+ import { firstValueFrom } from 'rxjs';
4
+ import { TabSdk } from '../tab-sdk.service';
5
+ import * as i0 from "@angular/core";
6
+ export class TransitionService {
7
+ _tabBlueprintService = inject(TabBlueprintService);
8
+ /**
9
+ * Retrieves the next status based on the provided payload.
10
+ *
11
+ * @param payload - The payload containing information to determine the next status.
12
+ * @returns A promise that resolves to the common API response.
13
+ */
14
+ async getNextStatus(payload) {
15
+ // Await the response from the getNextStatus method of the tabBlueprintService
16
+ const response = await firstValueFrom(this._tabBlueprintService.getNextStatus(payload));
17
+ // Return the obtained response
18
+ return response;
19
+ }
20
+ /**
21
+ * Updates the status of an entity based on the provided payload.
22
+ *
23
+ * @param payload - The payload containing information to update the status.
24
+ * @returns A promise that resolves to the common API response.
25
+ */
26
+ async updateStatus(payload) {
27
+ const response = await firstValueFrom(TabSdk.util?.updateStatus(payload));
28
+ // Return the obtained response
29
+ return response;
30
+ }
31
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TransitionService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
32
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TransitionService, providedIn: 'root' });
33
+ }
34
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: TransitionService, decorators: [{
35
+ type: Injectable,
36
+ args: [{
37
+ providedIn: 'root'
38
+ }]
39
+ }] });
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNpdGlvbi5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGFiLXNkay9zcmMvbGliL3dvcmtmbG93L3RyYW5zaXRpb24uc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNuRCxPQUFPLEVBQXdDLG1CQUFtQixFQUF1QixNQUFNLGdDQUFnQyxDQUFDO0FBQ2hJLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDdEMsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLG9CQUFvQixDQUFDOztBQUs1QyxNQUFNLE9BQU8saUJBQWlCO0lBQ1Qsb0JBQW9CLEdBQXdCLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxDQUFDO0lBRXpGOzs7OztPQUtHO0lBQ0gsS0FBSyxDQUFDLGFBQWEsQ0FBQyxPQUEwQjtRQUMxQyw4RUFBOEU7UUFDOUUsTUFBTSxRQUFRLEdBQUcsTUFBTSxjQUFjLENBQ2pDLElBQUksQ0FBQyxvQkFBb0IsQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLENBQ25ELENBQUM7UUFDRiwrQkFBK0I7UUFDL0IsT0FBTyxRQUFRLENBQUM7SUFDcEIsQ0FBQztJQUVEOzs7OztPQUtHO0lBQ0gsS0FBSyxDQUFDLFlBQVksQ0FBQyxPQUE0QjtRQUMzQyxNQUFNLFFBQVEsR0FBRyxNQUFNLGNBQWMsQ0FDakMsTUFBTSxDQUFDLElBQUksRUFBRSxZQUFZLENBQUMsT0FBTyxDQUFDLENBQ3JDLENBQUM7UUFDRiwrQkFBK0I7UUFDL0IsT0FBTyxRQUFRLENBQUM7SUFDcEIsQ0FBQzt3R0E5QlEsaUJBQWlCOzRHQUFqQixpQkFBaUIsY0FGZCxNQUFNOzs0RkFFVCxpQkFBaUI7a0JBSDdCLFVBQVU7bUJBQUM7b0JBQ1IsVUFBVSxFQUFFLE1BQU07aUJBQ3JCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaW5qZWN0LCBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25BcGlSZXNwb25zZSwgTmV4dFN0YXR1c1BheWxvYWQsIFRhYkJsdWVwcmludFNlcnZpY2UsIFVwZGF0ZVN0YXR1c1BheWxvYWQgfSBmcm9tICdAdGVjaGV4dGVuc29yL3RhYi1jb3JlLXV0aWxpdHknO1xuaW1wb3J0IHsgZmlyc3RWYWx1ZUZyb20gfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IFRhYlNkayB9IGZyb20gJy4uL3RhYi1zZGsuc2VydmljZSc7XG5cbkBJbmplY3RhYmxlKHtcbiAgICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG5leHBvcnQgY2xhc3MgVHJhbnNpdGlvblNlcnZpY2Uge1xuICAgIHByaXZhdGUgcmVhZG9ubHkgX3RhYkJsdWVwcmludFNlcnZpY2U6IFRhYkJsdWVwcmludFNlcnZpY2UgPSBpbmplY3QoVGFiQmx1ZXByaW50U2VydmljZSk7XG5cbiAgICAvKipcbiAgICAgKiBSZXRyaWV2ZXMgdGhlIG5leHQgc3RhdHVzIGJhc2VkIG9uIHRoZSBwcm92aWRlZCBwYXlsb2FkLlxuICAgICAqXG4gICAgICogQHBhcmFtIHBheWxvYWQgLSBUaGUgcGF5bG9hZCBjb250YWluaW5nIGluZm9ybWF0aW9uIHRvIGRldGVybWluZSB0aGUgbmV4dCBzdGF0dXMuXG4gICAgICogQHJldHVybnMgQSBwcm9taXNlIHRoYXQgcmVzb2x2ZXMgdG8gdGhlIGNvbW1vbiBBUEkgcmVzcG9uc2UuXG4gICAgICovXG4gICAgYXN5bmMgZ2V0TmV4dFN0YXR1cyhwYXlsb2FkOiBOZXh0U3RhdHVzUGF5bG9hZCk6IFByb21pc2U8Q29tbW9uQXBpUmVzcG9uc2U+IHtcbiAgICAgICAgLy8gQXdhaXQgdGhlIHJlc3BvbnNlIGZyb20gdGhlIGdldE5leHRTdGF0dXMgbWV0aG9kIG9mIHRoZSB0YWJCbHVlcHJpbnRTZXJ2aWNlXG4gICAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgZmlyc3RWYWx1ZUZyb20oXG4gICAgICAgICAgICB0aGlzLl90YWJCbHVlcHJpbnRTZXJ2aWNlLmdldE5leHRTdGF0dXMocGF5bG9hZClcbiAgICAgICAgKTtcbiAgICAgICAgLy8gUmV0dXJuIHRoZSBvYnRhaW5lZCByZXNwb25zZVxuICAgICAgICByZXR1cm4gcmVzcG9uc2U7XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICogVXBkYXRlcyB0aGUgc3RhdHVzIG9mIGFuIGVudGl0eSBiYXNlZCBvbiB0aGUgcHJvdmlkZWQgcGF5bG9hZC5cbiAgICAgKlxuICAgICAqIEBwYXJhbSBwYXlsb2FkIC0gVGhlIHBheWxvYWQgY29udGFpbmluZyBpbmZvcm1hdGlvbiB0byB1cGRhdGUgdGhlIHN0YXR1cy5cbiAgICAgKiBAcmV0dXJucyBBIHByb21pc2UgdGhhdCByZXNvbHZlcyB0byB0aGUgY29tbW9uIEFQSSByZXNwb25zZS5cbiAgICAgKi9cbiAgICBhc3luYyB1cGRhdGVTdGF0dXMocGF5bG9hZDogVXBkYXRlU3RhdHVzUGF5bG9hZCk6IFByb21pc2U8YW55PiB7XG4gICAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgZmlyc3RWYWx1ZUZyb20oXG4gICAgICAgICAgICBUYWJTZGsudXRpbD8udXBkYXRlU3RhdHVzKHBheWxvYWQpXG4gICAgICAgICk7XG4gICAgICAgIC8vIFJldHVybiB0aGUgb2J0YWluZWQgcmVzcG9uc2VcbiAgICAgICAgcmV0dXJuIHJlc3BvbnNlO1xuICAgIH1cbn0iXX0=