@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.
- package/esm2022/lib/app/file.service.mjs +45 -2
- package/esm2022/lib/interface/ui.interface.mjs +1 -1
- package/esm2022/lib/store/store.service.mjs +29 -1
- package/esm2022/lib/ui/ui.service.mjs +52 -16
- package/esm2022/public-api.mjs +8 -4
- package/fesm2022/techextensor-tab-sdk.mjs +124 -20
- package/fesm2022/techextensor-tab-sdk.mjs.map +1 -1
- package/lib/app/file.service.d.ts +12 -0
- package/lib/interface/ui.interface.d.ts +1 -1
- package/lib/store/store.service.d.ts +12 -0
- package/lib/ui/ui.service.d.ts +23 -6
- package/package.json +2 -2
- package/public-api.d.ts +4 -0
|
@@ -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(
|
|
82
|
-
TabSdk.util?.
|
|
83
|
-
|
|
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?.
|
|
97
|
+
TabSdk.util?.navigateTo({
|
|
94
98
|
...options,
|
|
95
|
-
type: NavigationType.
|
|
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
|
|
105
|
-
const urlParts = window?.location?.pathname?.split(
|
|
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}"]}
|
package/esm2022/public-api.mjs
CHANGED
|
@@ -1,5 +1,9 @@
|
|
|
1
|
-
|
|
2
|
-
* Public API Surface of tab-sdk
|
|
3
|
-
*/
|
|
1
|
+
// SDK
|
|
4
2
|
export * from './lib/tab-sdk.service';
|
|
5
|
-
|
|
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(
|
|
95
|
-
TabSdk.util?.
|
|
96
|
-
|
|
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?.
|
|
110
|
+
TabSdk.util?.navigateTo({
|
|
107
111
|
...options,
|
|
108
|
-
type: NavigationType.
|
|
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
|
|
118
|
-
const urlParts = window?.location?.pathname?.split(
|
|
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
|