@techextensor/tab-sdk 0.0.6 → 0.0.8

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.
@@ -39,7 +39,9 @@ export class UiService {
39
39
  ...(options.title && { title: options.title }),
40
40
  ...(options.width && { width: options.width }),
41
41
  ...(options.height && { height: options.height }),
42
- ...(options.customClass && { customClass: options.customClass })
42
+ ...(options.customClass && { customClass: options.customClass }),
43
+ ...(options.refresher && { refresher: options.refresher }),
44
+ ...(options.closer && { closer: options.closer })
43
45
  };
44
46
  TabSdk.util?.openScreen(ScreenDisplayMode.Sidebar, options.screenId, options.reqtokens || undefined, options.submission || undefined, Object.keys(otherConfiguration).length > 0 ? otherConfiguration : undefined);
45
47
  }
@@ -53,7 +55,9 @@ export class UiService {
53
55
  ...(options.title && { title: options.title }),
54
56
  ...(options.width && { width: options.width }),
55
57
  ...(options.height && { height: options.height }),
56
- ...(options.customClass && { customClass: options.customClass })
58
+ ...(options.customClass && { customClass: options.customClass }),
59
+ ...(options.refresher && { refresher: options.refresher }),
60
+ ...(options.closer && { closer: options.closer })
57
61
  };
58
62
  TabSdk.util?.openScreen(ScreenDisplayMode.Popup, options.screenId, options.reqtokens || undefined, options.submission || undefined, Object.keys(otherConfiguration).length > 0 ? otherConfiguration : undefined);
59
63
  }
@@ -78,9 +82,9 @@ export class UiService {
78
82
  *
79
83
  * @param url - The URL to navigate to.
80
84
  */
81
- navigateToUrl(url) {
82
- TabSdk.util?.navigateToUrl({
83
- url,
85
+ navigateToUrl(params) {
86
+ TabSdk.util?.navigateTo({
87
+ ...params,
84
88
  type: NavigationType.NavigateToUrl
85
89
  });
86
90
  }
@@ -90,9 +94,9 @@ export class UiService {
90
94
  * @param options - The options for navigation, including subDomain, appCode, and url.
91
95
  */
92
96
  navigateToSubdomain(options) {
93
- TabSdk.util?.navigateToUrl({
97
+ TabSdk.util?.navigateTo({
94
98
  ...options,
95
- type: NavigationType.NavigateToUrl
99
+ type: NavigationType.NavigateToSubdomain
96
100
  });
97
101
  }
98
102
  /**
@@ -101,20 +105,43 @@ export class UiService {
101
105
  * @returns The screen ID if present in the URL, otherwise undefined.
102
106
  */
103
107
  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/');
108
+ // Split the URL pathname into parts using the '/' character as a delimiter
109
+ const urlParts = window?.location?.pathname?.split('/');
106
110
  // Extract the screen ID part and remove any query parameters
107
- const screenId = urlParts?.[1]?.split('?')[0];
111
+ const screenId = urlParts?.length > 1 ? urlParts?.[urlParts?.length - 1]?.split('?')[0] : undefined;
108
112
  // Return the screen ID or undefined if not found
109
113
  return screenId;
110
114
  }
115
+ /**
116
+ * Retrieves the active redirect URL by combining the active screen ID and any query parameters.
117
+ *
118
+ * @returns The constructed redirect URL or undefined if no screen ID is present.
119
+ */
120
+ getActiveRedirectUrl() {
121
+ // Get the active screen ID from the current URL
122
+ const screenId = this.getActiveUrlScreenId();
123
+ let redirectURL;
124
+ // Check if the current URL contains a screen ID
125
+ if (screenId) {
126
+ // Initialize the redirect URL with the screen ID
127
+ redirectURL = screenId;
128
+ // Parse the current URL's query parameters
129
+ const queryParams = new URLSearchParams(window.location.search);
130
+ // If there are query parameters, append them to the redirect URL
131
+ if (queryParams.toString()) {
132
+ redirectURL += `&${queryParams.toString()}`;
133
+ }
134
+ }
135
+ // Return the constructed redirect URL or undefined
136
+ return redirectURL;
137
+ }
111
138
  /**
112
139
  * Show a notification to the user.
113
140
  *
114
141
  * @param options The options for the notification.
115
142
  */
116
143
  notify(options) {
117
- this._notificationService.notify({
144
+ return this._notificationService.notify({
118
145
  type: options.type,
119
146
  message: TabSdk.translator.translate(options.message),
120
147
  ...(options?.title ? { title: TabSdk.translator.translate(options.title) } : {}),
@@ -127,7 +154,7 @@ export class UiService {
127
154
  * @param options - The options for the notification, including message, title, and configuration.
128
155
  */
129
156
  showSuccess(options) {
130
- this.notify({
157
+ return this.notify({
131
158
  ...options,
132
159
  type: NotificationType.Success,
133
160
  title: options?.title ?? 'Success'
@@ -139,7 +166,7 @@ export class UiService {
139
166
  * @param options - The options for the notification, including message, title, and configuration.
140
167
  */
141
168
  showWarning(options) {
142
- this.notify({
169
+ return this.notify({
143
170
  ...options,
144
171
  type: NotificationType.Warning,
145
172
  title: options?.title ?? 'Warning'
@@ -151,7 +178,7 @@ export class UiService {
151
178
  * @param options - The options for the notification, including message, title, and configuration.
152
179
  */
153
180
  showInfo(options) {
154
- this.notify({
181
+ return this.notify({
155
182
  ...options,
156
183
  type: NotificationType.Info,
157
184
  title: options?.title ?? 'Info'
@@ -163,12 +190,21 @@ export class UiService {
163
190
  * @param options - The options for the notification, including message, title, and configuration.
164
191
  */
165
192
  showError(options) {
166
- this.notify({
193
+ return this.notify({
167
194
  ...options,
168
195
  type: NotificationType.Error,
169
196
  title: options?.title ?? 'Error'
170
197
  });
171
198
  }
199
+ /**
200
+ * Clears a notification by ID.
201
+ *
202
+ * @param notificationId - The ID of the notification to clear.
203
+ * @returns The cleared notification, or null if the notification doesn't exist.
204
+ */
205
+ clearNotification(notificationId) {
206
+ return this._notificationService.clearNotification(notificationId);
207
+ }
172
208
  /**
173
209
  * Displays a confirmation dialog to the user and returns a promise that resolves
174
210
  * to a boolean indicating whether the user confirmed the action.
@@ -305,4 +341,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
305
341
  providedIn: 'root'
306
342
  }]
307
343
  }] });
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}"]}
344
+ //# 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            ...(options.refresher && { refresher: options.refresher }),\n            ...(options.closer && { closer: options.closer })\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            ...(options.refresher && { refresher: options.refresher }),\n            ...(options.closer && { closer: options.closer })\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(params: { url: string, extras?: any, replaceUrl?: boolean }): void {\n        TabSdk.util?.navigateTo({\n            ...params,\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?.navigateTo({\n            ...options,\n            type: NavigationType.NavigateToSubdomain\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 into parts using the '/' character as a delimiter\n        const urlParts = window?.location?.pathname?.split('/');\n        // Extract the screen ID part and remove any query parameters\n        const screenId = urlParts?.length > 1 ? urlParts?.[urlParts?.length - 1]?.split('?')[0] : undefined;\n        // Return the screen ID or undefined if not found\n        return screenId;\n    }\n\n    /**\n     * Retrieves the active redirect URL by combining the active screen ID and any query parameters.\n     *\n     * @returns The constructed redirect URL or undefined if no screen ID is present.\n     */\n    getActiveRedirectUrl(): string | undefined {\n        // Get the active screen ID from the current URL\n        const screenId = this.getActiveUrlScreenId();\n        let redirectURL;\n\n        // Check if the current URL contains a screen ID\n        if (screenId) {\n            // Initialize the redirect URL with the screen ID\n            redirectURL = screenId;\n\n            // Parse the current URL's query parameters\n            const queryParams = new URLSearchParams(window.location.search);\n\n            // If there are query parameters, append them to the redirect URL\n            if (queryParams.toString()) {\n                redirectURL += `&${queryParams.toString()}`;\n            }\n        }\n\n        // Return the constructed redirect URL or undefined\n        return redirectURL;\n    }\n\n    /**\n     * Show a notification to the user.\n     *\n     * @param options The options for the notification.\n     */\n    notify(options: NotificationOptions) {\n        return 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) {\n        return 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) {\n        return 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) {\n        return 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) {\n        return this.notify({\n            ...options,\n            type: NotificationType.Error,\n            title: options?.title ?? 'Error'\n        });\n    }\n\n    /**\n     * Clears a notification by ID.\n     *\n     * @param notificationId - The ID of the notification to clear.\n     * @returns The cleared notification, or null if the notification doesn't exist.\n     */\n    clearNotification(notificationId: number) {\n        return this._notificationService.clearNotification(notificationId);\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}"]}
@@ -1,5 +1,9 @@
1
- /*
2
- * Public API Surface of tab-sdk
3
- */
1
+ // SDK
4
2
  export * from './lib/tab-sdk.service';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL3RhYi1zZGsvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLHVCQUF1QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiB0YWItc2RrXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9saWIvdGFiLXNkay5zZXJ2aWNlJztcbiJdfQ==
3
+ // Enums
4
+ export * from './lib/enum/ui.enum';
5
+ export * from './lib/enum/store.enum';
6
+ // Interfaces
7
+ export * from './lib/interface/ui.interface';
8
+ export * from './lib/interface/http.interface';
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL3RhYi1zZGsvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTTtBQUNOLGNBQWMsdUJBQXVCLENBQUM7QUFFdEMsUUFBUTtBQUNSLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyx1QkFBdUIsQ0FBQztBQUV0QyxhQUFhO0FBQ2IsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLGdDQUFnQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gU0RLXG5leHBvcnQgKiBmcm9tICcuL2xpYi90YWItc2RrLnNlcnZpY2UnO1xuXG4vLyBFbnVtc1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZW51bS91aS5lbnVtJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VudW0vc3RvcmUuZW51bSc7XG5cbi8vIEludGVyZmFjZXNcbmV4cG9ydCAqIGZyb20gJy4vbGliL2ludGVyZmFjZS91aS5pbnRlcmZhY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvaW50ZXJmYWNlL2h0dHAuaW50ZXJmYWNlJzsiXX0=
@@ -1,6 +1,6 @@
1
1
  import * as i0 from '@angular/core';
2
2
  import { inject, Injectable } from '@angular/core';
3
- import { NotificationService, ConfirmationService, NotificationType, AuthService, TabFormioService, TemplateHelper, TabBlueprintService, AppHelper, MediaUploadHelper, TabReleaseService, TranslationService, TabCrudService, TabGetService, LocalStorageService, SessionStorageService, StorageConstants, MetadataHelper } from '@techextensor/tab-core-utility';
3
+ import { NotificationService, ConfirmationService, NotificationType, AuthService, TabFormioService, TemplateHelper, TabBlueprintService, AppHelper, MediaUploadHelper, ApiService, TabReleaseService, TranslationService, TabCrudService, TabGetService, LocalStorageService, SessionStorageService, StorageConstants, MetadataHelper } from '@techextensor/tab-core-utility';
4
4
  import { firstValueFrom } from 'rxjs';
5
5
 
6
6
  var ScreenDisplayMode;
@@ -52,7 +52,9 @@ class UiService {
52
52
  ...(options.title && { title: options.title }),
53
53
  ...(options.width && { width: options.width }),
54
54
  ...(options.height && { height: options.height }),
55
- ...(options.customClass && { customClass: options.customClass })
55
+ ...(options.customClass && { customClass: options.customClass }),
56
+ ...(options.refresher && { refresher: options.refresher }),
57
+ ...(options.closer && { closer: options.closer })
56
58
  };
57
59
  TabSdk.util?.openScreen(ScreenDisplayMode.Sidebar, options.screenId, options.reqtokens || undefined, options.submission || undefined, Object.keys(otherConfiguration).length > 0 ? otherConfiguration : undefined);
58
60
  }
@@ -66,7 +68,9 @@ class UiService {
66
68
  ...(options.title && { title: options.title }),
67
69
  ...(options.width && { width: options.width }),
68
70
  ...(options.height && { height: options.height }),
69
- ...(options.customClass && { customClass: options.customClass })
71
+ ...(options.customClass && { customClass: options.customClass }),
72
+ ...(options.refresher && { refresher: options.refresher }),
73
+ ...(options.closer && { closer: options.closer })
70
74
  };
71
75
  TabSdk.util?.openScreen(ScreenDisplayMode.Popup, options.screenId, options.reqtokens || undefined, options.submission || undefined, Object.keys(otherConfiguration).length > 0 ? otherConfiguration : undefined);
72
76
  }
@@ -91,9 +95,9 @@ class UiService {
91
95
  *
92
96
  * @param url - The URL to navigate to.
93
97
  */
94
- navigateToUrl(url) {
95
- TabSdk.util?.navigateToUrl({
96
- url,
98
+ navigateToUrl(params) {
99
+ TabSdk.util?.navigateTo({
100
+ ...params,
97
101
  type: NavigationType.NavigateToUrl
98
102
  });
99
103
  }
@@ -103,9 +107,9 @@ class UiService {
103
107
  * @param options - The options for navigation, including subDomain, appCode, and url.
104
108
  */
105
109
  navigateToSubdomain(options) {
106
- TabSdk.util?.navigateToUrl({
110
+ TabSdk.util?.navigateTo({
107
111
  ...options,
108
- type: NavigationType.NavigateToUrl
112
+ type: NavigationType.NavigateToSubdomain
109
113
  });
110
114
  }
111
115
  /**
@@ -114,20 +118,43 @@ class UiService {
114
118
  * @returns The screen ID if present in the URL, otherwise undefined.
115
119
  */
116
120
  getActiveUrlScreenId() {
117
- // Split the URL pathname using the app name and '/screen/' as delimiters
118
- const urlParts = window?.location?.pathname?.split(TabSdk.store.appName + '/screen/');
121
+ // Split the URL pathname into parts using the '/' character as a delimiter
122
+ const urlParts = window?.location?.pathname?.split('/');
119
123
  // Extract the screen ID part and remove any query parameters
120
- const screenId = urlParts?.[1]?.split('?')[0];
124
+ const screenId = urlParts?.length > 1 ? urlParts?.[urlParts?.length - 1]?.split('?')[0] : undefined;
121
125
  // Return the screen ID or undefined if not found
122
126
  return screenId;
123
127
  }
128
+ /**
129
+ * Retrieves the active redirect URL by combining the active screen ID and any query parameters.
130
+ *
131
+ * @returns The constructed redirect URL or undefined if no screen ID is present.
132
+ */
133
+ getActiveRedirectUrl() {
134
+ // Get the active screen ID from the current URL
135
+ const screenId = this.getActiveUrlScreenId();
136
+ let redirectURL;
137
+ // Check if the current URL contains a screen ID
138
+ if (screenId) {
139
+ // Initialize the redirect URL with the screen ID
140
+ redirectURL = screenId;
141
+ // Parse the current URL's query parameters
142
+ const queryParams = new URLSearchParams(window.location.search);
143
+ // If there are query parameters, append them to the redirect URL
144
+ if (queryParams.toString()) {
145
+ redirectURL += `&${queryParams.toString()}`;
146
+ }
147
+ }
148
+ // Return the constructed redirect URL or undefined
149
+ return redirectURL;
150
+ }
124
151
  /**
125
152
  * Show a notification to the user.
126
153
  *
127
154
  * @param options The options for the notification.
128
155
  */
129
156
  notify(options) {
130
- this._notificationService.notify({
157
+ return this._notificationService.notify({
131
158
  type: options.type,
132
159
  message: TabSdk.translator.translate(options.message),
133
160
  ...(options?.title ? { title: TabSdk.translator.translate(options.title) } : {}),
@@ -140,7 +167,7 @@ class UiService {
140
167
  * @param options - The options for the notification, including message, title, and configuration.
141
168
  */
142
169
  showSuccess(options) {
143
- this.notify({
170
+ return this.notify({
144
171
  ...options,
145
172
  type: NotificationType.Success,
146
173
  title: options?.title ?? 'Success'
@@ -152,7 +179,7 @@ class UiService {
152
179
  * @param options - The options for the notification, including message, title, and configuration.
153
180
  */
154
181
  showWarning(options) {
155
- this.notify({
182
+ return this.notify({
156
183
  ...options,
157
184
  type: NotificationType.Warning,
158
185
  title: options?.title ?? 'Warning'
@@ -164,7 +191,7 @@ class UiService {
164
191
  * @param options - The options for the notification, including message, title, and configuration.
165
192
  */
166
193
  showInfo(options) {
167
- this.notify({
194
+ return this.notify({
168
195
  ...options,
169
196
  type: NotificationType.Info,
170
197
  title: options?.title ?? 'Info'
@@ -176,12 +203,21 @@ class UiService {
176
203
  * @param options - The options for the notification, including message, title, and configuration.
177
204
  */
178
205
  showError(options) {
179
- this.notify({
206
+ return this.notify({
180
207
  ...options,
181
208
  type: NotificationType.Error,
182
209
  title: options?.title ?? 'Error'
183
210
  });
184
211
  }
212
+ /**
213
+ * Clears a notification by ID.
214
+ *
215
+ * @param notificationId - The ID of the notification to clear.
216
+ * @returns The cleared notification, or null if the notification doesn't exist.
217
+ */
218
+ clearNotification(notificationId) {
219
+ return this._notificationService.clearNotification(notificationId);
220
+ }
185
221
  /**
186
222
  * Displays a confirmation dialog to the user and returns a promise that resolves
187
223
  * to a boolean indicating whether the user confirmed the action.
@@ -663,6 +699,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
663
699
 
664
700
  class FileService {
665
701
  _mediaUploadHelper = inject(MediaUploadHelper);
702
+ apiService = inject(ApiService);
666
703
  /**
667
704
  * Uploads media files using the provided payload and optional headers.
668
705
  *
@@ -688,6 +725,47 @@ class FileService {
688
725
  // Return the response from the server
689
726
  return response;
690
727
  }
728
+ /**
729
+ * Processes an FTP URL and returns a processed URL.
730
+ *
731
+ * @param params - The parameters containing data, an optional defaultHeader, and an optional imgElement.
732
+ * @returns A promise that resolves to the processed URL or null if an error occurs.
733
+ */
734
+ async processFtpUrl(params) {
735
+ // Return null if the data is invalid
736
+ if (!params?.data || params?.data === 'null' || params?.data === 'undefined')
737
+ return null;
738
+ try {
739
+ let url = params.data;
740
+ // Extract the value from a JSON string if it contains 'value'
741
+ if (url?.includes('value')) {
742
+ url = JSON.parse(url).value;
743
+ }
744
+ // Check if the URL is an image from the FileManager service
745
+ if (url.includes('FileManager/GetImage')) {
746
+ const options = { responseType: 'blob' };
747
+ // Add default headers if specified
748
+ if (params.defaultHeader) {
749
+ options.headers = TabSdk.util?.getDefaultAppHeaders();
750
+ }
751
+ // Fetch the image as a blob
752
+ const blob = await firstValueFrom(this.apiService.getByUrl(url, options));
753
+ // Create an object URL from the blob
754
+ url = URL.createObjectURL(blob);
755
+ }
756
+ // Set the image element's source to the processed URL
757
+ if (params.imgElement) {
758
+ params.imgElement.src = url;
759
+ params.imgElement.onload = null;
760
+ }
761
+ return url;
762
+ }
763
+ catch (e) {
764
+ // Log any errors that occur during processing
765
+ console.error("Error processing FTP", e);
766
+ return null;
767
+ }
768
+ }
691
769
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FileService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
692
770
  static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: FileService, providedIn: 'root' });
693
771
  }
@@ -1180,6 +1258,34 @@ class StoreService {
1180
1258
  // Save the updated organization info back to storage
1181
1259
  this.setOrgInfo(orgInfo);
1182
1260
  }
1261
+ /**
1262
+ * Retrieves the locale settings from the organization info.
1263
+ *
1264
+ * @returns The locale settings if they exist, otherwise `null`.
1265
+ */
1266
+ get orgLocaleSettings() {
1267
+ // Retrieve the locale settings from the organization info
1268
+ let localSettings = this.getOrgInfo()?.LocaleSettings;
1269
+ // If the locale settings are a string, parse them as JSON
1270
+ if (typeof localSettings === 'string') {
1271
+ localSettings = JSON.parse(localSettings);
1272
+ }
1273
+ // Return the locale settings
1274
+ return localSettings;
1275
+ }
1276
+ /**
1277
+ * Sets the locale settings in the organization info.
1278
+ *
1279
+ * @param value - The locale settings to set.
1280
+ */
1281
+ set orgLocaleSettings(value) {
1282
+ // Retrieve the existing organization info or initialize a new object
1283
+ const orgInfo = this.getOrgInfo() || {};
1284
+ // Update the locale settings value
1285
+ orgInfo.LocaleSettings = value;
1286
+ // Save the updated organization info back to storage
1287
+ this.setOrgInfo(orgInfo);
1288
+ }
1183
1289
  /**
1184
1290
  * Retrieves the app ID from the app info.
1185
1291
  *
@@ -1945,13 +2051,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
1945
2051
  }]
1946
2052
  }] });
1947
2053
 
1948
- /*
1949
- * Public API Surface of tab-sdk
1950
- */
2054
+ // SDK
1951
2055
 
1952
2056
  /**
1953
2057
  * Generated bundle index. Do not edit.
1954
2058
  */
1955
2059
 
1956
- export { TabSdk };
2060
+ export { NavigationType, ScreenDisplayMode, StorageType, TabSdk };
1957
2061
  //# sourceMappingURL=techextensor-tab-sdk.mjs.map