@updevs/components 1.0.0-alpha.37 → 1.0.0-alpha.39
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/layout/partials/header/header.component.mjs +2 -1
- package/esm2022/table/directives/table-column.directive.mjs +2 -1
- package/esm2022/table/table.component.mjs +32 -2
- package/fesm2022/updevs-components-layout.mjs +1 -0
- package/fesm2022/updevs-components-layout.mjs.map +1 -1
- package/fesm2022/updevs-components-table.mjs +25 -1
- package/fesm2022/updevs-components-table.mjs.map +1 -1
- package/package.json +19 -19
- package/table/table.component.d.ts +1 -0
|
@@ -99,6 +99,7 @@ export class HeaderComponent extends BaseComponent {
|
|
|
99
99
|
this.currentLanguageKey.set(item.id);
|
|
100
100
|
this.translocoService.setActiveLang(item.id);
|
|
101
101
|
this.preferencesStorage.savePreferences({ ...this.currentPreferences(), currentLanguageCode: item.id });
|
|
102
|
+
this.layoutService.notifyUserChangedLanguage(item.id);
|
|
102
103
|
this.isLanguageSwitcherDropdownOpen = false;
|
|
103
104
|
}
|
|
104
105
|
selectLoggedUserMenuItem(item) {
|
|
@@ -126,4 +127,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImpor
|
|
|
126
127
|
type: HostBinding,
|
|
127
128
|
args: ['class']
|
|
128
129
|
}] } });
|
|
129
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"header.component.js","sourceRoot":"","sources":["../../../../../../../libs/components/layout/src/partials/header/header.component.ts","../../../../../../../libs/components/layout/src/partials/header/header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ViewEncapsulation,\n    HostBinding,\n    OnInit,\n    inject,\n    computed,\n    signal,\n    viewChild,\n    ElementRef, input\n} from '@angular/core';\nimport { TablerIconsType } from '@updevs/icons';\nimport { TextService } from '@updevs/sdk';\nimport { BaseComponent, LayoutService, PreferencesStorage, UpdCoreLayoutConfigService } from '@updevs/sdk/layout';\nimport { DropdownItem } from '@updevs/components/dropdown';\nimport { TranslocoService } from '@jsverse/transloco';\nimport { NotificationModel, NotificationsService } from '@updevs/sdk/notifications';\nimport { SecurityStorage } from '@updevs/sdk/security';\n\nimport { HeaderStyleType } from './header-style.type';\n\n@Component({\n    selector: 'upd-header',\n    templateUrl: './header.component.html',\n    styleUrls: ['./header.component.scss'],\n    encapsulation: ViewEncapsulation.None\n})\nexport class HeaderComponent extends BaseComponent implements OnInit {\n    @HostBinding('class') get classes(): string {\n        return this.wrapperClasses();\n    }\n\n    languageSwitcherRef = viewChild('languageSwitcherBtn', { read: ElementRef });\n    notificationsRef = viewChild('notificationsBtn', { read: ElementRef });\n    loggedUserRef = viewChild('loggedUserBtn', { read: ElementRef });\n\n    isLanguageSwitcherDropdownOpen = false;\n    isNotificationsDropdownOpen = false;\n    isLoggedUserDropdownOpen = false;\n\n    readonly style = input<HeaderStyleType>('light');\n    readonly nextThemeIcon = computed<TablerIconsType>(() => this.currentPreferences()?.isDarkTheme ? 'sun' : 'moon-stars');\n    readonly currentNotificationsIcon = computed<TablerIconsType>(() => this.hasNewNotifications() ? 'bell-ringing' : 'bell');\n    readonly hasNewNotifications = computed(() => this.currentNotifications().some(n => !n.dateRead));\n    readonly languagesOptions = computed<DropdownItem[]>(() => {\n        const allLanguagesOptions: DropdownItem[] = [];\n        const availableLanguages = (this.coreLayoutConfigService.config.availableLanguages || {});\n\n        Object.keys(availableLanguages).forEach(key => {\n            allLanguagesOptions.push({\n                id: key,\n                type: 'default',\n                text: availableLanguages[key],\n                isActive: this.currentLanguageKey() === key\n            });\n        });\n\n        return allLanguagesOptions;\n    });\n    readonly loggedUserOptions = computed<DropdownItem[]>(() => {\n        const userActions: DropdownItem[] = [];\n\n        this.coreLayoutConfigService.config.loggedUserMenuActions.forEach(act => userActions.push({\n            id: act.id!(),\n            text: act.text!(),\n            type: 'default',\n            icon: act.iconModel?.()\n        }));\n\n        return userActions;\n    });\n    readonly userInfo = computed(() => this.securityStorage.getUserInfo());\n    readonly userIdentification = computed(() =>\n        !!this.userInfo() ? this.coreLayoutConfigService.config.getUserName(this.userInfo()!) : ''\n    );\n    readonly userDescription = computed(() =>\n        !!this.coreLayoutConfigService.config.getUserDescription\n            ? this.coreLayoutConfigService.config.getUserDescription(this.userInfo()!)\n            : ''\n    );\n    readonly shouldBlinkIfNewNotifications = computed(() => !!this.coreLayoutConfigService.config.shouldBlinkIfNewNotifications);\n    readonly latestNotifications = computed(() => {\n        const unreadNotifications = this.currentNotifications()\n            .filter(n => !n.dateRead)\n            .sort((a, b) => new Date(b.dateReceived).getTime() - new Date(a.dateReceived).getTime())\n            .slice(0, this.coreLayoutConfigService.config.numberOfLastNotificationsDisplayed);\n        const readNotifications = this.currentNotifications()\n            .filter(n => !!n.dateRead)\n            .sort((a, b) => new Date(b.dateReceived).getTime() - new Date(a.dateReceived).getTime())\n            .slice(0, this.coreLayoutConfigService.config.numberOfLastNotificationsDisplayed);\n\n        return [\n            ...unreadNotifications,\n            ...readNotifications\n        ].slice(0, this.coreLayoutConfigService.config.numberOfLastNotificationsDisplayed);\n    });\n    readonly textService = inject(TextService);\n\n    private readonly securityStorage = inject(SecurityStorage);\n    private readonly coreLayoutConfigService = inject(UpdCoreLayoutConfigService);\n    private readonly layoutService = inject(LayoutService);\n    private readonly translocoService = inject(TranslocoService);\n    private readonly preferencesStorage = inject(PreferencesStorage);\n    private readonly notificationsService = inject(NotificationsService);\n    private readonly currentPreferences = this.preferencesStorage.getPreferences();\n    private readonly currentNotifications = this.notificationsService.notifications;\n    private readonly currentLanguageKey = signal('');\n    private readonly wrapperClasses = computed(() => `navbar navbar-expand-md d-none d-lg-flex d-print-none navbar-${this.style()}`);\n\n    // eslint-disable-next-line @typescript-eslint/member-ordering\n    readonly config = computed(() => this.layoutService.mainHeaderConfig());\n\n    ngOnInit(): void {\n        if (!!this.currentPreferences()?.isDarkTheme) {\n            this.layoutService.setDarkMode();\n        }\n\n        if (!!this.currentPreferences()?.currentLanguageCode) {\n            const code = this.currentPreferences()!.currentLanguageCode!;\n\n            this.currentLanguageKey.set(code);\n            this.translocoService.setActiveLang(code);\n        }\n    }\n\n    switchTheme(): void {\n        this.layoutService.toggleDarkMode();\n    }\n\n    switchLanguage(item: DropdownItem): void {\n        this.currentLanguageKey.set(item.id);\n        this.translocoService.setActiveLang(item.id);\n        this.preferencesStorage.savePreferences({ ...this.currentPreferences(), currentLanguageCode: item.id });\n\n        this.isLanguageSwitcherDropdownOpen = false;\n    }\n\n    selectLoggedUserMenuItem(item: DropdownItem): void {\n        const btn = this.coreLayoutConfigService.config.loggedUserMenuActions.find(b => b.id!() === item.id);\n\n        if (!!btn?.clickFunction) {\n            btn.clickFunction!({ data: this.userInfo() });\n        }\n    }\n\n    readNotification(notification: NotificationModel): void {\n        if (!notification.dateRead) {\n            this.notificationsService.markAsRead(notification.id);\n        }\n\n        this.notificationsService.clickOnNotification(notification);\n    }\n\n    removeNotification(notification: NotificationModel): void {\n        this.notificationsService.removeNotifications(notification.id);\n    }\n}\n","<div class=\"container-xl\">\n    <button class=\"navbar-toggler\" type=\"button\">\n        <span class=\"navbar-toggler-icon\"></span>\n    </button>\n    <div class=\"navbar-nav flex-row order-md-last\">\n        <div class=\"d-none d-md-flex me-3\">\n            @if (!!config().showThemeSwitcher) {\n                <div class=\"nav-item\">\n                    <upd-link [isNavigation]=\"true\" [customClasses]=\"['px-0']\" (clicked)=\"switchTheme()\">\n                        <upd-icon [tablerIcon]=\"nextThemeIcon()\"></upd-icon>\n                    </upd-link>\n                </div>\n            }\n            @if (!!config().showLanguageSwitcher && languagesOptions().length > 0) {\n                <div class=\"nav-item\">\n                    <upd-link [isNavigation]=\"true\" [customClasses]=\"['px-0']\" (clicked)=\"isLanguageSwitcherDropdownOpen=true\"\n                      #languageSwitcherBtn>\n                        <upd-icon tablerIcon=\"language\"></upd-icon>\n                    </upd-link>\n                    <upd-dropdown wrapperClasses=\"mt-1\" [isOpen]=\"isLanguageSwitcherDropdownOpen\"\n                        [dropdownReference]=\"languageSwitcherRef()\" [items]=\"languagesOptions()\" [shouldCloseOnOutsideClick]=\"true\"\n                        (isOpenChange)=\"isLanguageSwitcherDropdownOpen = $event\" (selectedItem)=\"switchLanguage($event)\">\n                    </upd-dropdown>\n                </div>\n            }\n            @if (!!config().showNotifications && !!userInfo()) {\n                <div class=\"nav-item dropdown d-none d-md-flex\">\n                    <upd-link [isNavigation]=\"true\" [customClasses]=\"['px-0']\" (clicked)=\"isNotificationsDropdownOpen = true\"\n                      #notificationsBtn>\n                        <upd-icon [tablerIcon]=\"currentNotificationsIcon()\"></upd-icon>\n                        @if (hasNewNotifications()) {\n                            <span class=\"badge bg-red\" [class.badge-blink]=\"shouldBlinkIfNewNotifications()\"></span>\n                        }\n                    </upd-link>\n                    <upd-dropdown wrapperClasses=\"mt-1 dropdown-menu-card\" [isOpen]=\"isNotificationsDropdownOpen\"\n                        [dropdownReference]=\"notificationsRef()\" [shouldCloseOnOutsideClick]=\"true\"\n                        (isOpenChange)=\"isNotificationsDropdownOpen = $event\" [minWidth]=\"400\" arrowType=\"right\">\n                        <div class=\"card\">\n                            <div class=\"card-header\">\n                                <h3 class=\"card-title\">{{ 'UpDevs.NotificationCenter.Title' | transloco }}</h3>\n                            </div>\n                            @for (notification of latestNotifications(); track notification) {\n                                <div class=\"list-group list-group-flush list-group-hoverable\" (click)=\"readNotification(notification)\">\n                                    <div class=\"list-group-item\">\n                                        <div class=\"row align-items-center\">\n                                            <div class=\"col-auto\">\n                                                @if (!!notification.dateRead) {\n                                                    <span class=\"status-dot d-block\"></span>\n                                                } @else {\n                                                    <span class=\"status-dot status-dot-animated bg-primary d-block\"></span>\n                                                }\n                                            </div>\n                                            <div class=\"col text-truncate\">\n                                                <a href=\"javascript:void(0)\" class=\"text-body d-block\"\n                                                    [class.fw-bold]=\"!notification.dateRead\">\n                                                    {{ textService.getText(notification.title) }}\n                                                </a>\n                                                @if (!!notification.description) {\n                                                    <div class=\"d-block text-secondary text-truncate mt-n1\">\n                                                        {{ textService.getText(notification.description) }}\n                                                    </div>\n                                                }\n                                            </div>\n                                            <div class=\"col-auto\">\n                                                <upd-link [customClasses]=\"['list-group-item-actions']\"\n                                                    (clicked)=\"removeNotification(notification)\">\n                                                    <upd-icon tablerIcon=\"x\"></upd-icon>\n                                                </upd-link>\n                                            </div>\n                                        </div>\n                                    </div>\n                                </div>\n                            } @empty {\n                                <div class=\"empty\">\n                                    <h1 class=\"text-body-tertiary\">{{ 'UpDevs.NotificationCenter.NoNotifications' | transloco }}</h1>\n                                </div>\n                            }\n                        </div>\n                    </upd-dropdown>\n                </div>\n            }\n        </div>\n        @if (!!config().showUserMenu && !!userInfo()) {\n            <div class=\"nav-item dropdown\">\n                <upd-link [isNavigation]=\"true\" [customClasses]=\"['px-0']\" (clicked)=\"isLoggedUserDropdownOpen = true\" #loggedUserBtn>\n                    @if (!!userInfo()!.avatar) {\n                        <span class=\"avatar avatar-sm\" style=\"background-image: url({{userInfo()?.avatar}})\"></span>\n                    }\n\n                    <div class=\"d-none d-xl-block ps-2\">\n                        <div>{{ userIdentification() }}</div>\n                        @if (!!userDescription()) {\n                            <div class=\"mt-1 small text-muted\">{{ userDescription() }}</div>\n                        }\n                    </div>\n                </upd-link>\n                @if (loggedUserOptions().length > 0) {\n                    <upd-dropdown wrapperClasses=\"mt-1\" [isOpen]=\"isLoggedUserDropdownOpen\" [dropdownReference]=\"loggedUserRef()\"\n                        [items]=\"loggedUserOptions()\" [shouldCloseOnOutsideClick]=\"true\" (selectedItem)=\"selectLoggedUserMenuItem($event)\"\n                        (isOpenChange)=\"isLoggedUserDropdownOpen = $event\" arrowType=\"right\">\n                    </upd-dropdown>\n                }\n            </div>\n        }\n    </div>\n    @if (!!config().showSearchBar && !!userInfo()) {\n        <div class=\"collapse navbar-collapse\">\n            <div class=\"me-2\" [class.w-100]=\"config().shouldUseFullSearchBar\">\n                <form autocomplete=\"off\" novalidate>\n                    <div class=\"input-icon\">\n                        <span class=\"input-icon-addon\">\n                            <upd-icon tablerIcon=\"search\"></upd-icon>\n                        </span>\n                        <input type=\"text\" value=\"\" class=\"form-control\" placeholder=\"{{'UpDevs.Header.Search' | transloco}}...\">\n                    </div>\n                </form>\n            </div>\n        </div>\n    } @else {\n        <div></div>\n    }\n</div>\n"]}
|
|
130
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"header.component.js","sourceRoot":"","sources":["../../../../../../../libs/components/layout/src/partials/header/header.component.ts","../../../../../../../libs/components/layout/src/partials/header/header.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ViewEncapsulation,\n    HostBinding,\n    OnInit,\n    inject,\n    computed,\n    signal,\n    viewChild,\n    ElementRef, input\n} from '@angular/core';\nimport { TablerIconsType } from '@updevs/icons';\nimport { TextService } from '@updevs/sdk';\nimport { BaseComponent, LayoutService, PreferencesStorage, UpdCoreLayoutConfigService } from '@updevs/sdk/layout';\nimport { DropdownItem } from '@updevs/components/dropdown';\nimport { TranslocoService } from '@jsverse/transloco';\nimport { NotificationModel, NotificationsService } from '@updevs/sdk/notifications';\nimport { SecurityStorage } from '@updevs/sdk/security';\n\nimport { HeaderStyleType } from './header-style.type';\n\n@Component({\n    selector: 'upd-header',\n    templateUrl: './header.component.html',\n    styleUrls: ['./header.component.scss'],\n    encapsulation: ViewEncapsulation.None\n})\nexport class HeaderComponent extends BaseComponent implements OnInit {\n    @HostBinding('class') get classes(): string {\n        return this.wrapperClasses();\n    }\n\n    languageSwitcherRef = viewChild('languageSwitcherBtn', { read: ElementRef });\n    notificationsRef = viewChild('notificationsBtn', { read: ElementRef });\n    loggedUserRef = viewChild('loggedUserBtn', { read: ElementRef });\n\n    isLanguageSwitcherDropdownOpen = false;\n    isNotificationsDropdownOpen = false;\n    isLoggedUserDropdownOpen = false;\n\n    readonly style = input<HeaderStyleType>('light');\n    readonly nextThemeIcon = computed<TablerIconsType>(() => this.currentPreferences()?.isDarkTheme ? 'sun' : 'moon-stars');\n    readonly currentNotificationsIcon = computed<TablerIconsType>(() => this.hasNewNotifications() ? 'bell-ringing' : 'bell');\n    readonly hasNewNotifications = computed(() => this.currentNotifications().some(n => !n.dateRead));\n    readonly languagesOptions = computed<DropdownItem[]>(() => {\n        const allLanguagesOptions: DropdownItem[] = [];\n        const availableLanguages = (this.coreLayoutConfigService.config.availableLanguages || {});\n\n        Object.keys(availableLanguages).forEach(key => {\n            allLanguagesOptions.push({\n                id: key,\n                type: 'default',\n                text: availableLanguages[key],\n                isActive: this.currentLanguageKey() === key\n            });\n        });\n\n        return allLanguagesOptions;\n    });\n    readonly loggedUserOptions = computed<DropdownItem[]>(() => {\n        const userActions: DropdownItem[] = [];\n\n        this.coreLayoutConfigService.config.loggedUserMenuActions.forEach(act => userActions.push({\n            id: act.id!(),\n            text: act.text!(),\n            type: 'default',\n            icon: act.iconModel?.()\n        }));\n\n        return userActions;\n    });\n    readonly userInfo = computed(() => this.securityStorage.getUserInfo());\n    readonly userIdentification = computed(() =>\n        !!this.userInfo() ? this.coreLayoutConfigService.config.getUserName(this.userInfo()!) : ''\n    );\n    readonly userDescription = computed(() =>\n        !!this.coreLayoutConfigService.config.getUserDescription\n            ? this.coreLayoutConfigService.config.getUserDescription(this.userInfo()!)\n            : ''\n    );\n    readonly shouldBlinkIfNewNotifications = computed(() => !!this.coreLayoutConfigService.config.shouldBlinkIfNewNotifications);\n    readonly latestNotifications = computed(() => {\n        const unreadNotifications = this.currentNotifications()\n            .filter(n => !n.dateRead)\n            .sort((a, b) => new Date(b.dateReceived).getTime() - new Date(a.dateReceived).getTime())\n            .slice(0, this.coreLayoutConfigService.config.numberOfLastNotificationsDisplayed);\n        const readNotifications = this.currentNotifications()\n            .filter(n => !!n.dateRead)\n            .sort((a, b) => new Date(b.dateReceived).getTime() - new Date(a.dateReceived).getTime())\n            .slice(0, this.coreLayoutConfigService.config.numberOfLastNotificationsDisplayed);\n\n        return [\n            ...unreadNotifications,\n            ...readNotifications\n        ].slice(0, this.coreLayoutConfigService.config.numberOfLastNotificationsDisplayed);\n    });\n    readonly textService = inject(TextService);\n\n    private readonly securityStorage = inject(SecurityStorage);\n    private readonly coreLayoutConfigService = inject(UpdCoreLayoutConfigService);\n    private readonly layoutService = inject(LayoutService);\n    private readonly translocoService = inject(TranslocoService);\n    private readonly preferencesStorage = inject(PreferencesStorage);\n    private readonly notificationsService = inject(NotificationsService);\n    private readonly currentPreferences = this.preferencesStorage.getPreferences();\n    private readonly currentNotifications = this.notificationsService.notifications;\n    private readonly currentLanguageKey = signal('');\n    private readonly wrapperClasses = computed(() => `navbar navbar-expand-md d-none d-lg-flex d-print-none navbar-${this.style()}`);\n\n    // eslint-disable-next-line @typescript-eslint/member-ordering\n    readonly config = computed(() => this.layoutService.mainHeaderConfig());\n\n    ngOnInit(): void {\n        if (!!this.currentPreferences()?.isDarkTheme) {\n            this.layoutService.setDarkMode();\n        }\n\n        if (!!this.currentPreferences()?.currentLanguageCode) {\n            const code = this.currentPreferences()!.currentLanguageCode!;\n\n            this.currentLanguageKey.set(code);\n            this.translocoService.setActiveLang(code);\n        }\n    }\n\n    switchTheme(): void {\n        this.layoutService.toggleDarkMode();\n    }\n\n    switchLanguage(item: DropdownItem): void {\n        this.currentLanguageKey.set(item.id);\n        this.translocoService.setActiveLang(item.id);\n        this.preferencesStorage.savePreferences({ ...this.currentPreferences(), currentLanguageCode: item.id });\n        this.layoutService.notifyUserChangedLanguage(item.id);\n\n        this.isLanguageSwitcherDropdownOpen = false;\n    }\n\n    selectLoggedUserMenuItem(item: DropdownItem): void {\n        const btn = this.coreLayoutConfigService.config.loggedUserMenuActions.find(b => b.id!() === item.id);\n\n        if (!!btn?.clickFunction) {\n            btn.clickFunction!({ data: this.userInfo() });\n        }\n    }\n\n    readNotification(notification: NotificationModel): void {\n        if (!notification.dateRead) {\n            this.notificationsService.markAsRead(notification.id);\n        }\n\n        this.notificationsService.clickOnNotification(notification);\n    }\n\n    removeNotification(notification: NotificationModel): void {\n        this.notificationsService.removeNotifications(notification.id);\n    }\n}\n","<div class=\"container-xl\">\n    <button class=\"navbar-toggler\" type=\"button\">\n        <span class=\"navbar-toggler-icon\"></span>\n    </button>\n    <div class=\"navbar-nav flex-row order-md-last\">\n        <div class=\"d-none d-md-flex me-3\">\n            @if (!!config().showThemeSwitcher) {\n                <div class=\"nav-item\">\n                    <upd-link [isNavigation]=\"true\" [customClasses]=\"['px-0']\" (clicked)=\"switchTheme()\">\n                        <upd-icon [tablerIcon]=\"nextThemeIcon()\"></upd-icon>\n                    </upd-link>\n                </div>\n            }\n            @if (!!config().showLanguageSwitcher && languagesOptions().length > 0) {\n                <div class=\"nav-item\">\n                    <upd-link [isNavigation]=\"true\" [customClasses]=\"['px-0']\" (clicked)=\"isLanguageSwitcherDropdownOpen=true\"\n                      #languageSwitcherBtn>\n                        <upd-icon tablerIcon=\"language\"></upd-icon>\n                    </upd-link>\n                    <upd-dropdown wrapperClasses=\"mt-1\" [isOpen]=\"isLanguageSwitcherDropdownOpen\"\n                        [dropdownReference]=\"languageSwitcherRef()\" [items]=\"languagesOptions()\" [shouldCloseOnOutsideClick]=\"true\"\n                        (isOpenChange)=\"isLanguageSwitcherDropdownOpen = $event\" (selectedItem)=\"switchLanguage($event)\">\n                    </upd-dropdown>\n                </div>\n            }\n            @if (!!config().showNotifications && !!userInfo()) {\n                <div class=\"nav-item dropdown d-none d-md-flex\">\n                    <upd-link [isNavigation]=\"true\" [customClasses]=\"['px-0']\" (clicked)=\"isNotificationsDropdownOpen = true\"\n                      #notificationsBtn>\n                        <upd-icon [tablerIcon]=\"currentNotificationsIcon()\"></upd-icon>\n                        @if (hasNewNotifications()) {\n                            <span class=\"badge bg-red\" [class.badge-blink]=\"shouldBlinkIfNewNotifications()\"></span>\n                        }\n                    </upd-link>\n                    <upd-dropdown wrapperClasses=\"mt-1 dropdown-menu-card\" [isOpen]=\"isNotificationsDropdownOpen\"\n                        [dropdownReference]=\"notificationsRef()\" [shouldCloseOnOutsideClick]=\"true\"\n                        (isOpenChange)=\"isNotificationsDropdownOpen = $event\" [minWidth]=\"400\" arrowType=\"right\">\n                        <div class=\"card\">\n                            <div class=\"card-header\">\n                                <h3 class=\"card-title\">{{ 'UpDevs.NotificationCenter.Title' | transloco }}</h3>\n                            </div>\n                            @for (notification of latestNotifications(); track notification) {\n                                <div class=\"list-group list-group-flush list-group-hoverable\" (click)=\"readNotification(notification)\">\n                                    <div class=\"list-group-item\">\n                                        <div class=\"row align-items-center\">\n                                            <div class=\"col-auto\">\n                                                @if (!!notification.dateRead) {\n                                                    <span class=\"status-dot d-block\"></span>\n                                                } @else {\n                                                    <span class=\"status-dot status-dot-animated bg-primary d-block\"></span>\n                                                }\n                                            </div>\n                                            <div class=\"col text-truncate\">\n                                                <a href=\"javascript:void(0)\" class=\"text-body d-block\"\n                                                    [class.fw-bold]=\"!notification.dateRead\">\n                                                    {{ textService.getText(notification.title) }}\n                                                </a>\n                                                @if (!!notification.description) {\n                                                    <div class=\"d-block text-secondary text-truncate mt-n1\">\n                                                        {{ textService.getText(notification.description) }}\n                                                    </div>\n                                                }\n                                            </div>\n                                            <div class=\"col-auto\">\n                                                <upd-link [customClasses]=\"['list-group-item-actions']\"\n                                                    (clicked)=\"removeNotification(notification)\">\n                                                    <upd-icon tablerIcon=\"x\"></upd-icon>\n                                                </upd-link>\n                                            </div>\n                                        </div>\n                                    </div>\n                                </div>\n                            } @empty {\n                                <div class=\"empty\">\n                                    <h1 class=\"text-body-tertiary\">{{ 'UpDevs.NotificationCenter.NoNotifications' | transloco }}</h1>\n                                </div>\n                            }\n                        </div>\n                    </upd-dropdown>\n                </div>\n            }\n        </div>\n        @if (!!config().showUserMenu && !!userInfo()) {\n            <div class=\"nav-item dropdown\">\n                <upd-link [isNavigation]=\"true\" [customClasses]=\"['px-0']\" (clicked)=\"isLoggedUserDropdownOpen = true\" #loggedUserBtn>\n                    @if (!!userInfo()!.avatar) {\n                        <span class=\"avatar avatar-sm\" style=\"background-image: url({{userInfo()?.avatar}})\"></span>\n                    }\n\n                    <div class=\"d-none d-xl-block ps-2\">\n                        <div>{{ userIdentification() }}</div>\n                        @if (!!userDescription()) {\n                            <div class=\"mt-1 small text-muted\">{{ userDescription() }}</div>\n                        }\n                    </div>\n                </upd-link>\n                @if (loggedUserOptions().length > 0) {\n                    <upd-dropdown wrapperClasses=\"mt-1\" [isOpen]=\"isLoggedUserDropdownOpen\" [dropdownReference]=\"loggedUserRef()\"\n                        [items]=\"loggedUserOptions()\" [shouldCloseOnOutsideClick]=\"true\" (selectedItem)=\"selectLoggedUserMenuItem($event)\"\n                        (isOpenChange)=\"isLoggedUserDropdownOpen = $event\" arrowType=\"right\">\n                    </upd-dropdown>\n                }\n            </div>\n        }\n    </div>\n    @if (!!config().showSearchBar && !!userInfo()) {\n        <div class=\"collapse navbar-collapse\">\n            <div class=\"me-2\" [class.w-100]=\"config().shouldUseFullSearchBar\">\n                <form autocomplete=\"off\" novalidate>\n                    <div class=\"input-icon\">\n                        <span class=\"input-icon-addon\">\n                            <upd-icon tablerIcon=\"search\"></upd-icon>\n                        </span>\n                        <input type=\"text\" value=\"\" class=\"form-control\" placeholder=\"{{'UpDevs.Header.Search' | transloco}}...\">\n                    </div>\n                </form>\n            </div>\n        </div>\n    } @else {\n        <div></div>\n    }\n</div>\n"]}
|
|
@@ -30,6 +30,7 @@ export class TableColumnDirective {
|
|
|
30
30
|
// @ts-ignore
|
|
31
31
|
return BooleanColumnComponent;
|
|
32
32
|
case ColumnTypeEnum.Date:
|
|
33
|
+
case ColumnTypeEnum.DateTime:
|
|
33
34
|
// @ts-ignore
|
|
34
35
|
return DateTimeColumnComponent;
|
|
35
36
|
case ColumnTypeEnum.Guid:
|
|
@@ -48,4 +49,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImpor
|
|
|
48
49
|
selector: '[updTableColumn]'
|
|
49
50
|
}]
|
|
50
51
|
}], ctorParameters: () => [] });
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
52
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFibGUtY29sdW1uLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy90YWJsZS9zcmMvZGlyZWN0aXZlcy90YWJsZS1jb2x1bW4uZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbkYsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFLbkUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBQ2xFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHlEQUF5RCxDQUFDO0FBQzlGLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDZEQUE2RCxDQUFDO0FBQ3BHLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLCtEQUErRCxDQUFDO0FBQ3ZHLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLG1FQUFtRSxDQUFDOztBQUs1RyxNQUFNLE9BQU8sb0JBQW9CO0lBTzdCO1FBTkEsV0FBTSxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUMxQixXQUFNLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBVyxDQUFDO1FBRWxCLHFCQUFnQixHQUFHLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1FBQzVDLHlCQUFvQixHQUFHLE1BQU0sQ0FBQyw2QkFBNkIsQ0FBQyxDQUFDO1FBRzFFLE1BQU0sQ0FBQyxHQUFHLEVBQUU7WUFDUixNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsb0JBQW9CLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxFQUFFLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1lBQ2pHLFNBQVMsQ0FBQyxRQUFRLENBQUMsTUFBTSxHQUFHLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUMxQyxTQUFTLENBQUMsUUFBUSxDQUFDLE1BQU0sR0FBRyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDOUMsQ0FBQyxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRUQsZ0JBQWdCO1FBQ1osUUFBUSxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUMsSUFBSSxFQUFFLENBQUM7WUFDekIsS0FBSyxjQUFjLENBQUMsSUFBSTtnQkFDcEIsYUFBYTtnQkFDYixPQUFPLG1CQUFtQixDQUFDO1lBQy9CLEtBQUssY0FBYyxDQUFDLE1BQU07Z0JBQ3RCLGFBQWE7Z0JBQ2IsT0FBTyxxQkFBcUIsQ0FBQztZQUNqQyxLQUFLLGNBQWMsQ0FBQyxPQUFPO2dCQUN2QixhQUFhO2dCQUNiLE9BQU8sc0JBQXNCLENBQUM7WUFDbEMsS0FBSyxjQUFjLENBQUMsSUFBSSxDQUFDO1lBQ3pCLEtBQUssY0FBYyxDQUFDLFFBQVE7Z0JBQ3hCLGFBQWE7Z0JBQ2IsT0FBTyx1QkFBdUIsQ0FBQztZQUNuQyxLQUFLLGNBQWMsQ0FBQyxJQUFJO2dCQUNwQixhQUFhO2dCQUNiLE9BQU8sbUJBQW1CLENBQUM7WUFDL0I7Z0JBQ0ksTUFBTSxLQUFLLEVBQUUsQ0FBQztRQUN0QixDQUFDO0lBQ0wsQ0FBQzs4R0FwQ1Esb0JBQW9CO2tHQUFwQixvQkFBb0I7OzJGQUFwQixvQkFBb0I7a0JBSGhDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLGtCQUFrQjtpQkFDL0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIGlucHV0LCBpbmplY3QsIFZpZXdDb250YWluZXJSZWYsIGVmZmVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRHluYW1pY0NvbXBvbmVudExvYWRlclNlcnZpY2UgfSBmcm9tICdAdXBkZXZzL3Nkay9sYXlvdXQnO1xuaW1wb3J0IHsgQ29tcG9uZW50VHlwZSB9IGZyb20gJ0B1cGRldnMvc2RrL3R5cGVzJztcblxuaW1wb3J0IHsgQmFzZUNvbHVtbk1vZGVsIH0gZnJvbSAnLi4vYWJzdHJhY3Rpb25zL2Jhc2UtY29sdW1uLm1vZGVsJztcbmltcG9ydCB7IEJhc2VDb2x1bW4gfSBmcm9tICcuLi9hYnN0cmFjdGlvbnMvYmFzZS5jb2x1bW4nO1xuaW1wb3J0IHsgQ29sdW1uVHlwZUVudW0gfSBmcm9tICcuLi9tb2RlbHMvZW51bXMvY29sdW1uLXR5cGUuZW51bSc7XG5pbXBvcnQgeyBUZXh0Q29sdW1uQ29tcG9uZW50IH0gZnJvbSAnLi4vY29tcG9uZW50cy9jb2x1bW5zL3RleHQtY29sdW1uL3RleHQtY29sdW1uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBOdW1iZXJDb2x1bW5Db21wb25lbnQgfSBmcm9tICcuLi9jb21wb25lbnRzL2NvbHVtbnMvbnVtYmVyLWNvbHVtbi9udW1iZXItY29sdW1uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBCb29sZWFuQ29sdW1uQ29tcG9uZW50IH0gZnJvbSAnLi4vY29tcG9uZW50cy9jb2x1bW5zL2Jvb2xlYW4tY29sdW1uL2Jvb2xlYW4tY29sdW1uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEYXRlVGltZUNvbHVtbkNvbXBvbmVudCB9IGZyb20gJy4uL2NvbXBvbmVudHMvY29sdW1ucy9kYXRlLXRpbWUtY29sdW1uL2RhdGUtdGltZS1jb2x1bW4uY29tcG9uZW50JztcblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdbdXBkVGFibGVDb2x1bW5dJ1xufSlcbmV4cG9ydCBjbGFzcyBUYWJsZUNvbHVtbkRpcmVjdGl2ZTxUQ29uZmlnIGV4dGVuZHMgQmFzZUNvbHVtbk1vZGVsPiB7XG4gICAgcmVjb3JkID0gaW5wdXQucmVxdWlyZWQoKTtcbiAgICBjb25maWcgPSBpbnB1dC5yZXF1aXJlZDxUQ29uZmlnPigpO1xuXG4gICAgcHJpdmF0ZSByZWFkb25seSB2aWV3Q29udGFpbmVyUmVmID0gaW5qZWN0KFZpZXdDb250YWluZXJSZWYpO1xuICAgIHByaXZhdGUgcmVhZG9ubHkgZHluYW1pY0xvYWRlclNlcnZpY2UgPSBpbmplY3QoRHluYW1pY0NvbXBvbmVudExvYWRlclNlcnZpY2UpO1xuXG4gICAgY29uc3RydWN0b3IoKSB7XG4gICAgICAgIGVmZmVjdCgoKSA9PiB7XG4gICAgICAgICAgICBjb25zdCBjb21wb25lbnQgPSB0aGlzLmR5bmFtaWNMb2FkZXJTZXJ2aWNlLmxvYWQodGhpcy5nZXRDb21wb25lbnRUeXBlKCksIHRoaXMudmlld0NvbnRhaW5lclJlZik7XG4gICAgICAgICAgICBjb21wb25lbnQuaW5zdGFuY2UucmVjb3JkID0gdGhpcy5yZWNvcmQoKTtcbiAgICAgICAgICAgIGNvbXBvbmVudC5pbnN0YW5jZS5jb25maWcgPSB0aGlzLmNvbmZpZygpO1xuICAgICAgICB9KTtcbiAgICB9XG5cbiAgICBnZXRDb21wb25lbnRUeXBlKCk6IENvbXBvbmVudFR5cGU8QmFzZUNvbHVtbjxUQ29uZmlnPj4ge1xuICAgICAgICBzd2l0Y2ggKHRoaXMuY29uZmlnKCkudHlwZSkge1xuICAgICAgICAgICAgY2FzZSBDb2x1bW5UeXBlRW51bS5UZXh0OlxuICAgICAgICAgICAgICAgIC8vIEB0cy1pZ25vcmVcbiAgICAgICAgICAgICAgICByZXR1cm4gVGV4dENvbHVtbkNvbXBvbmVudDtcbiAgICAgICAgICAgIGNhc2UgQ29sdW1uVHlwZUVudW0uTnVtYmVyOlxuICAgICAgICAgICAgICAgIC8vIEB0cy1pZ25vcmVcbiAgICAgICAgICAgICAgICByZXR1cm4gTnVtYmVyQ29sdW1uQ29tcG9uZW50O1xuICAgICAgICAgICAgY2FzZSBDb2x1bW5UeXBlRW51bS5Cb29sZWFuOlxuICAgICAgICAgICAgICAgIC8vIEB0cy1pZ25vcmVcbiAgICAgICAgICAgICAgICByZXR1cm4gQm9vbGVhbkNvbHVtbkNvbXBvbmVudDtcbiAgICAgICAgICAgIGNhc2UgQ29sdW1uVHlwZUVudW0uRGF0ZTpcbiAgICAgICAgICAgIGNhc2UgQ29sdW1uVHlwZUVudW0uRGF0ZVRpbWU6XG4gICAgICAgICAgICAgICAgLy8gQHRzLWlnbm9yZVxuICAgICAgICAgICAgICAgIHJldHVybiBEYXRlVGltZUNvbHVtbkNvbXBvbmVudDtcbiAgICAgICAgICAgIGNhc2UgQ29sdW1uVHlwZUVudW0uR3VpZDpcbiAgICAgICAgICAgICAgICAvLyBAdHMtaWdub3JlXG4gICAgICAgICAgICAgICAgcmV0dXJuIFRleHRDb2x1bW5Db21wb25lbnQ7XG4gICAgICAgICAgICBkZWZhdWx0OlxuICAgICAgICAgICAgICAgIHRocm93IEVycm9yKCk7XG4gICAgICAgIH1cbiAgICB9XG59XG4iXX0=
|
|
@@ -5,6 +5,13 @@ import { BaseComponent, ButtonModel } from '@updevs/sdk/layout';
|
|
|
5
5
|
import { ColumnSort, SortDirectionEnum } from '@updevs/sdk/stores';
|
|
6
6
|
import { ModalService, ModalAlertService } from '@updevs/components/modal';
|
|
7
7
|
import { distinctUntilChanged, tap, switchMap, finalize, Subject, catchError, of } from 'rxjs';
|
|
8
|
+
import { BooleanColumnModel } from './models/columns/boolean-column.model';
|
|
9
|
+
import { DateTimeColumnModel } from './models/columns/date-time-column.model';
|
|
10
|
+
import { GuidColumnModel } from './models/columns/guid-column.model';
|
|
11
|
+
import { ImageColumnModel } from './models/columns/image-column.model';
|
|
12
|
+
import { NumberColumnModel } from './models/columns/number-column.model';
|
|
13
|
+
import { TextColumnModel } from './models/columns/text-column.model';
|
|
14
|
+
import { ColumnTypeEnum } from './models/enums/column-type.enum';
|
|
8
15
|
import { TableConfigModel } from './models/table-config.model';
|
|
9
16
|
import { BaseColumnModel } from './abstractions/base-column.model';
|
|
10
17
|
import { ColumnsManagerComponent } from './components/columns-manager/columns-manager.component';
|
|
@@ -299,7 +306,30 @@ export class TableComponent extends BaseComponent {
|
|
|
299
306
|
return newBtn;
|
|
300
307
|
}
|
|
301
308
|
updateColumns(columns) {
|
|
302
|
-
this.columns.set(columns.filter(c => !c.isHidden).map(c =>
|
|
309
|
+
this.columns.set(columns.filter(c => !c.isHidden).map(c => this.createColumnModel(c)));
|
|
310
|
+
}
|
|
311
|
+
createColumnModel(data) {
|
|
312
|
+
switch (data.type) {
|
|
313
|
+
case ColumnTypeEnum.Text:
|
|
314
|
+
return new TextColumnModel({ ...data });
|
|
315
|
+
case ColumnTypeEnum.Number:
|
|
316
|
+
return new NumberColumnModel({ ...data });
|
|
317
|
+
case ColumnTypeEnum.Boolean:
|
|
318
|
+
return new BooleanColumnModel({ ...data });
|
|
319
|
+
case ColumnTypeEnum.DateTime:
|
|
320
|
+
case ColumnTypeEnum.Date:
|
|
321
|
+
case ColumnTypeEnum.Time:
|
|
322
|
+
return new DateTimeColumnModel({ ...data });
|
|
323
|
+
case ColumnTypeEnum.Image:
|
|
324
|
+
return new ImageColumnModel({ ...data });
|
|
325
|
+
case ColumnTypeEnum.Guid:
|
|
326
|
+
return new GuidColumnModel({ ...data });
|
|
327
|
+
case ColumnTypeEnum.Masked:
|
|
328
|
+
case ColumnTypeEnum.Custom:
|
|
329
|
+
case ColumnTypeEnum.Currency:
|
|
330
|
+
default:
|
|
331
|
+
return new BaseColumnModel(data.type, { ...data });
|
|
332
|
+
}
|
|
303
333
|
}
|
|
304
334
|
getColumnByName(columnName) {
|
|
305
335
|
const col = this.columns().find(c => c.name === columnName);
|
|
@@ -409,4 +439,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImpor
|
|
|
409
439
|
type: Component,
|
|
410
440
|
args: [{ selector: 'upd-table', template: "<ng-container *transloco=\"let t; prefix: 'UpDevs.Table'\">\n <div class=\"card\">\n @if (!!configModel().title || !configModel().canSearch) {\n <div class=\"card-header\">\n @if (!!configModel().title) {\n <h3 class=\"card-title\">{{ textService.getText(configModel().title) }}</h3>\n }\n <ng-template [ngTemplateOutlet]=\"actionsTpl\"></ng-template>\n </div>\n }\n\n @if (configModel().customHeaderActions.length > 0) {\n <div class=\"card-body py-3 d-flex flex-column gap-2\">\n <div class=\"ms-auto d-flex gap-2\">\n @for (btn of configModel().customHeaderActions; track btn) {\n <upd-button customClasses=\"gap-2\" [model]=\"btn\"></upd-button>\n }\n </div>\n </div>\n }\n\n @if (configModel().canSearch) {\n <upd-search-section [actionsTpl]=\"!configModel().title ? actionsTpl : undefined\" [isSearching]=\"isSearching()\"\n [(searchRequest)]=\"searchRequest\" [searchRequestSubject]=\"searchRequestSubject\" [config]=\"configModel()\"\n [(hasChanges)]=\"hasSearchChanged\" [columns]=\"columns()\">\n </upd-search-section>\n }\n\n <div [class.table-responsive]=\"configModel().isResponsive\">\n <!-- TODO: implement pixel sized table -->\n <table class=\"table card-table table-vcenter table-nowrap\" [class.fixed]=\"hasWidth\"\n [class.pixel-sized]=\"isWidthInPixels\">\n <thead [class.sticky-top]=\"configModel().hasStickyHeader\">\n <tr>\n @if (configModel().hasCheckboxColumn) {\n <th class=\"checkbox-selector\">\n <upd-checkbox customClasses=\"m-0 ps-0\" (changed)=\"toggleAllSelection($event)\"\n [(isChecked)]=\"isMainCheckboxChecked\"\n [(isIndeterminate)]=\"isMainCheckboxIndeterminate\"></upd-checkbox>\n </th>\n }\n\n @for (col of columns(); track col) {\n <th [ngClass]=\"col.widthClass\" [style.width.px]=\"col.pixelsSize\">\n {{ textService.getText(col.title) }}\n @if (canSortColumn(col.name)) {\n <upd-icon [tablerIcon]=\"getSortingIcon(col.name)\" tablerIconWeight=\"bold\" colorClass=\"text-body-tertiary\"\n [tablerIconSize]=\"16\" (click)=\"sortByColumn(col.name)\">\n </upd-icon>\n }\n </th>\n }\n\n @if (!!pendingWidthColClass) {\n <th [ngClass]=\"pendingWidthColClass\"></th>\n }\n\n @if (configModel().customActions.length > 0) {\n <th class=\"custom-actions\"></th>\n }\n </tr>\n </thead>\n\n <tbody>\n @if (isSearching()) {\n <tr>\n <td [colSpan]=\"numberOfColumns\">\n <div class=\"empty\">\n <h1 class=\"text-body-tertiary\">{{ t('Loading') }}...</h1>\n <div class=\"progress progress-sm w-25\">\n <div class=\"progress-bar progress-bar-indeterminate bg-body-tertiary\"></div>\n </div>\n </div>\n </td>\n </tr>\n } @else {\n @for (record of data(); track record) {\n <tr>\n @if (configModel().hasCheckboxColumn) {\n <td>\n <upd-checkbox customClasses=\"m-0 ps-0\" (changed)=\"toggleItemSelection(record)\"\n [isChecked]=\"selectionModel().isSelected(record)\"></upd-checkbox>\n </td>\n }\n\n @for (col of columns(); track col) {\n <td>\n <ng-container updTableColumn [record]=\"record\" [config]=\"col\"></ng-container>\n </td>\n }\n\n @if (!!pendingWidthColClass) {\n <td></td>\n }\n\n @if (configModel().customActions.length > 0) {\n <td style=\"overflow: unset\">\n <div class=\"grow-left d-flex\">\n @if (configModel().customActions.length > 1) {\n <upd-button customClasses=\"ca-item\" [iconModel]=\"{tablerIcon:'dots'}\" [isIcon]=\"true\"\n [isLink]=\"true\" size=\"small\"></upd-button>\n\n <div class=\"ca-dropdown-content rounded shadow-sm\">\n @for (btn of configModel().customActions; track btn) {\n <upd-button [model]=\"adaptCustomAction(btn, record)\"></upd-button>\n }\n </div>\n } @else {\n <upd-button [model]=\"adaptCustomAction(configModel().customActions[0], record)\">\n </upd-button>\n }\n </div>\n </td>\n }\n </tr>\n } @empty {\n <tr>\n <td [colSpan]=\"numberOfColumns\">\n <div class=\"empty\">\n <p class=\"empty-title\">{{ t('NoRecordsFoundTitle') }}</p>\n <p class=\"empty-subtitle text-secondary\">{{ t('NoRecordsFoundSubtitle') }}</p>\n </div>\n </td>\n </tr>\n }\n }\n </tbody>\n </table>\n </div>\n <upd-paginator wrapperClasses=\"card-footer\" [shouldDisplayPreviousText]=\"false\" [shouldDisplayNextText]=\"false\"\n [(pageSize)]=\"pageSize\" [shouldDisplayFirstText]=\"false\" [shouldDisplayLastText]=\"false\"\n [(currentPage)]=\"currentPage\"\n [totalRecords]=\"totalRecords()\" (changed)=\"onPageSettingsChanged()\">\n </upd-paginator>\n </div>\n\n <ng-template #actionsTpl>\n <div class=\"ms-auto d-flex gap-2\">\n @if (!!activeSavedView()) {\n @if (activeSavedView()!.isDefault) {\n <div class=\"ribbon ribbon-top ribbon-start\">\n <upd-icon tablerIcon=\"heart\" [tablerIconSize]=\"20\"></upd-icon>\n </div>\n }\n <div class=\"tag align-self-center py-3 text-primary bg-primary-lt border-primary\"\n updPopover=\"{{ t('CurrentSavedView') }}\"\n [updPopoverActAsTooltip]=\"true\">\n <upd-icon tablerIcon=\"list-details\" [tablerIconSize]=\"20\"></upd-icon>\n <span class=\"me-1\">{{ activeSavedView()!.name }}</span>\n </div>\n }\n @if (hiddenColumns() > 0) {\n <div class=\"tag align-self-center py-3 text-orange bg-orange-lt border-orange\"\n updPopover=\"{{ t('HiddenColumnsTooltip') }}\"\n [updPopoverActAsTooltip]=\"true\">\n <upd-icon tablerIcon=\"eye-off\" [tablerIconSize]=\"20\"></upd-icon>\n <span class=\"me-1\">{{ hiddenColumns() }}</span>\n </div>\n }\n @if (!!activeSavedView() || hiddenColumns() > 0) {\n <upd-button (clicked)=\"resetViewState()\" colorStyle=\"danger\" updPopover=\"{{ t('ResetView') }}\"\n [updPopoverActAsTooltip]=\"true\" [isIcon]=\"true\" [isOutline]=\"true\">\n <upd-icon tablerIcon=\"restore\" [tablerIconSize]=\"20\"></upd-icon>\n </upd-button>\n }\n @if (configModel().canSaveViews) {\n <upd-button customClasses=\"gap-2\" [isDisabled]=\"!hasSearchChanged()\" (clicked)=\"openSaveSearchModal()\"\n updPopover=\"{{ t('SaveCurrentView') }}\" [updPopoverActAsTooltip]=\"true\" [isIcon]=\"true\">\n <upd-icon tablerIcon=\"device-floppy\" [tablerIconSize]=\"20\"></upd-icon>\n </upd-button>\n }\n @if (configModel().canManageColumns) {\n <upd-button customClasses=\"gap-2\" (clicked)=\"openColumnsManagerModal()\">\n <upd-icon tablerIcon=\"columns\" [tablerIconSize]=\"20\"></upd-icon>\n {{ t('ColumnsManagerButton') }}\n </upd-button>\n }\n @if (configModel().canSaveViews || configModel().canLoadSavedViews) {\n <upd-button customClasses=\"gap-2\" (clicked)=\"isSavedViewsDropdownOpen = true\" #savedViewsBtn>\n <upd-icon tablerIcon=\"folders\" [tablerIconSize]=\"20\"></upd-icon>\n {{ t('SavedViews.ButtonTitle') }}\n </upd-button>\n <upd-dropdown wrapperClasses=\"overflow-x-hidden mt-1\" [isOpen]=\"isSavedViewsDropdownOpen\"\n [dropdownReference]=\"savedViewsRef()\" [items]=\"savedViewsOptions()\" [shouldCloseOnOutsideClick]=\"true\"\n (isOpenChange)=\"isSavedViewsDropdownOpen = $event\" [minWidth]=\"350\" (selectedItem)=\"selectSavedView($event)\">\n @if (savedViewsOptions().length < 1) {\n <span class=\"m-2\">{{ t('NoSavedViews') }}</span>\n }\n </upd-dropdown>\n }\n </div>\n </ng-template>\n</ng-container>\n", styles: [".fixed{table-layout:fixed!important}.fixed td,.fixed th{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.checkbox-selector{width:52px!important}.custom-actions{width:56px!important}.ca-item{transition:all,.5s}.ca-item:hover{width:400px}.grow-left{direction:rtl}.ca-dropdown-content{display:none;background:var(--upd-secondary-lt)}.grow-left:hover .ca-dropdown-content{display:block}\n"] }]
|
|
411
441
|
}], ctorParameters: () => [] });
|
|
412
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../libs/components/table/src/table.component.ts","../../../../../libs/components/table/src/table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject, signal, computed, effect, OnInit, Signal, model, ElementRef, viewChild } from '@angular/core';\nimport { TablerIconsType } from '@updevs/icons';\nimport { TextService } from '@updevs/sdk';\nimport { SelectionModel, Tools, ServerResponseService } from '@updevs/sdk/core';\nimport { OptionalType, ButtonSizeType } from '@updevs/sdk/types';\nimport { BaseComponent, ButtonModel } from '@updevs/sdk/layout';\nimport { SearchRequestModel, BaseSearchStore, ColumnSort, SortDirectionEnum, SearchResponseModel } from '@updevs/sdk/stores';\nimport { ModalService, ModalRef, ModalAlertService } from '@updevs/components/modal';\nimport { DropdownItem, DropdownActionClickedModel } from '@updevs/components/dropdown';\nimport { distinctUntilChanged, tap, switchMap, finalize, Subject, catchError, of } from 'rxjs';\n\nimport { TableConfig } from './models/table.config';\nimport { TableConfigModel } from './models/table-config.model';\nimport { BaseColumnModel } from './abstractions/base-column.model';\nimport { FilterItemModel } from './models/filter-item.model';\nimport { ColumnsManagerComponent } from './components/columns-manager/columns-manager.component';\nimport { SaveSearchComponent } from './components/save-search/save-search.component';\nimport { SavedViewModel } from './models/saved-view.model';\nimport { SavedViewsStorage } from './services/storages/saved-views.storage';\n\nimport Utils = Tools.Utils;\n\n@Component({\n    selector: 'upd-table',\n    templateUrl: './table.component.html',\n    styleUrl: './table.component.scss'\n})\nexport class TableComponent<T> extends BaseComponent implements OnInit {\n    savedViewsRef = viewChild('savedViewsBtn', { read: ElementRef });\n    config = model.required<TableConfig<T>>();\n    isSearching = signal<boolean>(false);\n    selectedItems = computed<T[]>(() => this.selectionModel().selected());\n    activeSavedView = signal<OptionalType<SavedViewModel>>(undefined);\n    isMainCheckboxChecked = false;\n    isMainCheckboxIndeterminate = false;\n    isSavedViewsDropdownOpen = false;\n\n    get numberOfColumns(): number {\n        return this.columns().length\n            + (this.configModel().hasCheckboxColumn ? 1 : 0)\n            + (this.configModel().customActions.length > 0 ? 1 : 0)\n            + (!!this.pendingWidthColClass ? 1 : 0);\n    }\n    get hasWidth(): boolean {\n        return this.columns().some(rec => !!rec.width);\n    }\n    get pendingWidthColClass(): string {\n        if (!this.hasWidth || this.isWidthInPixels) {\n            return '';\n        }\n\n        const isGrid = this.columns().some(rec => !!rec.width?.gridColumn);\n        const total = isGrid ? 12 : 100;\n        const remainingSize = total - this.columns().reduce((acc, item) => acc + item.widthSize, 0);\n\n        // TODO: add spaces of checkbox and customactions columns\n\n        return remainingSize > 0 ? `${(isGrid ? 'col' : 'w')}-${remainingSize}` : '';\n    }\n    get isWidthInPixels(): boolean {\n        return this.columns().some(rec => !!rec.width?.pixels);\n    }\n\n    readonly searchRequest = model<SearchRequestModel>({});\n    readonly activeFilters = model<FilterItemModel[]>([]);\n    readonly currentPage = model<number>(1);\n    readonly pageSize = model<number>(0);\n    readonly hasSearchChanged = signal(false);\n    readonly totalRecords = signal<number>(0);\n    readonly configModel = computed(() => new TableConfigModel(this.config()));\n    readonly data: Signal<T[]> = computed(() => this.configModel().data.length > 0 ? this.configModel().data : this.currentData());\n    readonly selectionModel = computed(() => new SelectionModel<T>(this.configModel().getIdFunction));\n    readonly currentSorting = signal<OptionalType<ColumnSort>>(undefined);\n    readonly hiddenColumns = computed(() =>\n        this.configModel().canManageColumns ? this.configModel().columns.filter(c => c.isHidden).length : 0\n    );\n    readonly columns = signal<BaseColumnModel[]>([]);\n    readonly searchRequestSubject = new Subject<SearchRequestModel>();\n    readonly textService = inject(TextService);\n    readonly savedViewsOptions = computed<DropdownItem[]>(() => {\n        const allSavedViewsOptions: DropdownItem[] = [];\n        this.allSavedViews().forEach(sv => allSavedViewsOptions.push(this.getSavedViewOption(sv)));\n\n        return allSavedViewsOptions;\n    });\n\n    private get isRemote(): boolean {\n        return !!this.configModel().store;\n    }\n    private get store(): BaseSearchStore<T> {\n        return this.configModel().store!;\n    }\n    private shouldForceSearch = false;\n    private columnsBackup: BaseColumnModel[] = [];\n\n    private readonly currentData = signal<T[]>([]);\n    private readonly currentFavoriteButtons = computed<ButtonModel[]>(() => this.favoriteButtons);\n    private readonly smallSizeSignal = signal<ButtonSizeType>('small');\n    private readonly allSavedViews = computed(() => this.savedViewsStorage.getAll(this.configModel().name)());\n    private readonly favoriteButtons: ButtonModel[] = [];\n    private readonly serverResponseService = inject(ServerResponseService);\n    private readonly savedViewsStorage = inject(SavedViewsStorage);\n    private readonly modalService = inject(ModalService);\n    private readonly modalAlertService = inject(ModalAlertService);\n\n    constructor() {\n        super();\n\n        effect(() => {\n            if (this.data().length > 0 && this.configModel().data.length > 0) {\n                this.setupPreSelected();\n            }\n\n            if (this.selectedItems().length > 0) {\n                if (this.selectedItems().length !== this.data().length) {\n                    this.isMainCheckboxChecked = false;\n                    this.isMainCheckboxIndeterminate = true;\n                } else {\n                    this.isMainCheckboxIndeterminate = false;\n                    this.isMainCheckboxChecked = true;\n                }\n            } else {\n                this.isMainCheckboxChecked = false;\n                this.isMainCheckboxIndeterminate = false;\n            }\n        });\n    }\n\n    ngOnInit(): void {\n        this.columnsBackup = [...this.config().columns];\n        const searchSubjectSub = this.searchRequestSubject\n            .pipe(\n                distinctUntilChanged((prev, curr) => !this.shouldForceSearch ? Utils.areEqual(prev, curr) : false),\n                tap((request) => {\n                    this.isSearching.set(true);\n                    this.currentData.set([]);\n                    this.searchRequest.set(request);\n\n                    if (\n                        (request.filters?.length || 0) > 0\n                        || (request.description || '').length > 0\n                        || (request.sortings?.length || 0) > 0\n                    ) {\n                        this.hasSearchChanged.set(true);\n                    }\n                }),\n                switchMap(() =>\n                    this.store.search(this.searchRequest()).pipe(\n                        catchError(() => of()) // Already handled by the ServerResponseService.\n                    )\n                ),\n                finalize(() => this.shouldForceSearch = false)\n            )\n            .subscribe(resp => this.setupSearchResults(resp));\n        const serverResponseSub = this.serverResponseService.onError.subscribe(error => {\n            if (!!error) {\n                this.isSearching.set(false);\n            }\n        });\n\n        if (this.configModel().shouldAutoSearch && this.isRemote) {\n            this.shouldForceSearch = true;\n            this.searchRequestSubject.next({});\n        }\n\n        this.updateColumns(this.configModel().columns);\n        this.addSubscriptions(searchSubjectSub, serverResponseSub);\n    }\n\n    toggleAllSelection(isChecked: boolean): void {\n        if (isChecked) {\n            this.selectionModel().select(...this.currentData());\n        } else {\n            this.selectionModel().clearSelection();\n        }\n    }\n\n    toggleItemSelection(record: T): void {\n        if (this.selectionModel().isSelected(record)) {\n            this.selectionModel().deselect(record);\n        } else {\n            this.selectionModel().select(record);\n        }\n    }\n\n    canSortColumn(columnName: string): boolean {\n        return this.getColumnByName(columnName).allowSort;\n    }\n\n    sortByColumn(columnName: string): void {\n        if (!this.currentSorting()) {\n            this.currentSorting.set(new ColumnSort({ column: columnName }));\n        } else {\n            this.currentSorting.set(\n                new ColumnSort({\n                    column: columnName,\n                    direction: this.currentSorting()!.column === columnName\n                        ? (this.currentSorting()!.direction === SortDirectionEnum.Asc ? SortDirectionEnum.Desc : SortDirectionEnum.Asc)\n                        : SortDirectionEnum.Asc\n                })\n            );\n        }\n\n        if (this.isRemote) {\n            this.searchRequest.set({\n                ...this.searchRequest(),\n                sortings: [this.currentSorting()!]\n            });\n            this.searchRequestSubject.next(this.searchRequest());\n        } else {\n            const col = this.getColumnByName(columnName);\n            // TODO: local sort\n        }\n    }\n\n    getSortingIcon(columnName: string): TablerIconsType {\n        return !!this.currentSorting() && this.currentSorting()!.column === columnName\n            ? (this.currentSorting()!.direction === SortDirectionEnum.Asc ? 'sort-ascending' : 'sort-descending')\n            : 'arrows-sort';\n    }\n\n    onPageSettingsChanged(): void {\n        this.searchRequest.set({\n            ...this.searchRequest(),\n            pageSize: this.pageSize(),\n            pageIndex: this.currentPage()\n        });\n        this.searchRequestSubject.next(this.searchRequest());\n    }\n\n    getRecordId(record: T): any {\n        return this.configModel().getIdFunction(record);\n    }\n\n    openColumnsManagerModal(): void {\n        const ref: ModalRef = this.modalService.open(undefined, {\n            bodyContentType: ColumnsManagerComponent,\n            showCloseButton: false,\n            showCancelButton: true,\n            data: this.config(),\n            isTextCentered: false,\n            actionButtons: [\n                new ButtonModel({\n                    text: signal({ text: 'UpDevs.Table.ColumnsManager.Apply', isTranslated: false }),\n                    colorStyle: signal('primary'),\n                    iconModel: signal({ tablerIcon: 'checks' }),\n                    clickFunction: () => ref.close()\n                })\n            ]\n        });\n        ref.afterClose = () => {\n            const result = ref.getBodyInstance<ColumnsManagerComponent<T>>()?.columns();\n\n            if (!!result) {\n                const previousVisibleColumnsOrder = this.columns().map(c => c.name);\n                const visibleColumnsNames = result.find(c => c.name === 'visible')?.items().map(i => i.name) || [];\n                const newColumns: BaseColumnModel[] = [];\n\n                this.config.update(config => {\n                    visibleColumnsNames.forEach(name => {\n                        const col = config.columns.find(c => c.name === name)!;\n                        col.isHidden = false;\n\n                        newColumns.push(col);\n                    });\n                    config.columns.forEach(c => {\n                        if (!visibleColumnsNames.includes(c.name)) {\n                            c.isHidden = true;\n                            newColumns.push(c);\n                        }\n                    });\n\n                    return { ...config, columns: [...newColumns] };\n                });\n                this.updateColumns(newColumns);\n\n                const newVisibleColumnsOrder = newColumns.map(c => c.name);\n\n                if (previousVisibleColumnsOrder.length !== newVisibleColumnsOrder.length\n                    || !previousVisibleColumnsOrder.every((v, i) => v === newVisibleColumnsOrder[i])) {\n                    this.hasSearchChanged.set(true);\n                }\n            }\n        };\n    }\n\n    openSaveSearchModal(data?: SavedViewModel): void {\n        data = data || {\n            tableName: this.configModel().name,\n            request: this.searchRequest(),\n            columns: this.configModel().columns\n        };\n        this.modalService.open(SaveSearchComponent, { showCloseButton: false, data });\n    }\n\n    selectSavedView(item: DropdownItem): void {\n        const savedView = this.savedViewsStorage.getById(this.configModel().name, item.id)();\n        this.isSavedViewsDropdownOpen = false;\n\n        if (!!savedView) {\n            this.updateColumns(savedView.columns);\n            this.config.update(curr => {\n                curr.columns = savedView.columns;\n                return { ...curr };\n            });\n            this.activeSavedView.set(savedView);\n            this.searchRequestSubject.next({ ...savedView.request });\n        }\n    }\n\n    resetViewState(): void {\n        this.activeSavedView.set(undefined);\n        this.updateColumns(this.columnsBackup);\n        this.config.update(curr => {\n            curr.columns = this.columnsBackup;\n            return { ...curr };\n        });\n        this.searchRequestSubject.next({});\n    }\n\n    reload(): void {\n        this.shouldForceSearch = true;\n        this.searchRequestSubject.next({});\n    }\n\n    adaptCustomAction(btn: ButtonModel, item: T): ButtonModel {\n        const newBtn = new ButtonModel({\n            id: btn.id,\n            iconModel: btn.iconModel,\n            title: btn.title,\n            isIcon: signal(true),\n            isLink: signal(true),\n            size: signal('small'),\n            text: undefined,\n            colorStyle: btn.colorStyle,\n            isOutline: btn.isOutline\n        });\n        const defaultFunction = btn.clickFunction;\n        newBtn.clickFunction = (evt) => {\n            evt.event?.preventDefault();\n            evt.event?.stopPropagation();\n\n            if (!!defaultFunction) {\n                defaultFunction({ event: evt.event, data: item });\n            }\n        };\n\n        return newBtn;\n    }\n\n    private updateColumns(columns: BaseColumnModel[]): void {\n        this.columns.set(columns.filter(c => !c.isHidden).map(c => new BaseColumnModel(c.type, { ...c })));\n    }\n\n    private getColumnByName(columnName: string): BaseColumnModel {\n        const col = this.columns().find(c => c.name === columnName);\n\n        if (!col) {\n            throw Error('Tried accessing non existing column');\n        }\n\n        return col;\n    }\n\n    private setupPreSelected(): void {\n        this.configModel().preSelectedItems.forEach(item => {\n            const id = this.getRecordId(item);\n\n            if (this.data().find(d => this.getRecordId(d) === id) && !this.selectionModel().isSelected(item)) {\n                this.selectionModel().select(item);\n            }\n        });\n    }\n\n    private setupSearchResults(resp: SearchResponseModel<T>): void {\n        this.isSearching.set(false);\n        this.currentData.set(resp.records);\n        this.totalRecords.set(resp.totalRecords || 0);\n        this.currentPage.set(resp.pageIndex || 0);\n        this.pageSize.set(resp.pageSize || 0);\n        this.setupPreSelected();\n    }\n\n    private getActionButtons(currentFavoriteButtons: Signal<ButtonModel[]>, savedView: SavedViewModel): ButtonModel[] {\n        return [\n            new ButtonModel({\n                isIcon: signal(true),\n                isGhost: signal(true),\n                colorStyle: signal('primary'),\n                size: this.smallSizeSignal,\n                title: signal({ text: 'UpDevs.Table.SavedViews.MarkAsDefault', isTranslated: false }),\n                isActive: signal(savedView.isDefault || false),\n                iconModel: signal({ tablerIcon: 'heart' }),\n                clickFunction: (evt) => {\n                    const btnModel = (evt.data as DropdownActionClickedModel);\n                    const isButtonActive = btnModel.button.isActive();\n\n                    if (!isButtonActive) {\n                        this.savedViewsStorage.resetAllIsDefault(this.configModel().name);\n                    }\n\n                    savedView.isDefault = !isButtonActive;\n\n                    currentFavoriteButtons().forEach(cfb => cfb.isActive.set(false));\n                    btnModel.button.isActive.set(!isButtonActive);\n                    this.savedViewsStorage.saveView(savedView);\n                }\n            }),\n            new ButtonModel({\n                isIcon: signal(true),\n                isGhost: signal(true),\n                colorStyle: signal('secondary'),\n                size: this.smallSizeSignal,\n                title: signal({ text: 'UpDevs.Table.SavedViews.Duplicate', isTranslated: false }),\n                iconModel: signal({ tablerIcon: 'copy' }),\n                clickFunction: () => {\n                    const duplicateView = {\n                        ...savedView,\n                        id: Tools.Guid.generate(),\n                        name: savedView.name +\n                            ` (${this.textService.getText({ text: 'UpDevs.Table.SavedViews.DuplicateSuffix', isTranslated: false })})`\n                    };\n                    this.openSaveSearchModal(duplicateView);\n                }\n            }),\n            new ButtonModel({\n                isIcon: signal(true),\n                isGhost: signal(true),\n                colorStyle: signal('secondary'),\n                size: this.smallSizeSignal,\n                title: signal({ text: 'UpDevs.Table.SavedViews.Edit', isTranslated: false }),\n                iconModel: signal({ tablerIcon: 'edit' }),\n                clickFunction: () => this.openSaveSearchModal(savedView)\n            }),\n            new ButtonModel({\n                isIcon: signal(true),\n                isGhost: signal(true),\n                colorStyle: signal('danger'),\n                size: this.smallSizeSignal,\n                title: signal({ text: 'UpDevs.Table.SavedViews.Remove', isTranslated: false }),\n                iconModel: signal({ tablerIcon: 'x' }),\n                clickFunction: () => {\n                    const title = this.textService.getText(\n                        { text: 'UpDevs.Table.SavedViews.ConfirmRemove', isTranslated: false },\n                        { view: savedView.name }\n                    );\n                    this.modalAlertService.showConfirm({ text: title, isTranslated: true }).subscribe(isConfirmed => {\n                        if (isConfirmed) {\n                            this.savedViewsStorage.removeViews(this.configModel().name, savedView.id!);\n                        }\n                    });\n                }\n            })\n        ];\n    }\n\n    private getSavedViewOption(savedView: SavedViewModel): DropdownItem {\n        const actionButtons = this.getActionButtons(this.currentFavoriteButtons, savedView);\n        this.favoriteButtons.push(actionButtons.find(ab => ab.iconModel?.().tablerIcon === 'heart')!);\n\n        return {\n            id: savedView.id,\n            type: 'with-toolbar',\n            text: { text: savedView.name!, isTranslated: true },\n            toolbarType: 'spaced',\n            isActive: this.activeSavedView()?.id === savedView.id,\n            actionButtons\n        };\n    }\n}\n","<ng-container *transloco=\"let t; prefix: 'UpDevs.Table'\">\n    <div class=\"card\">\n        @if (!!configModel().title || !configModel().canSearch) {\n            <div class=\"card-header\">\n                @if (!!configModel().title) {\n                    <h3 class=\"card-title\">{{ textService.getText(configModel().title) }}</h3>\n                }\n                <ng-template [ngTemplateOutlet]=\"actionsTpl\"></ng-template>\n            </div>\n        }\n\n        @if (configModel().customHeaderActions.length > 0) {\n            <div class=\"card-body py-3 d-flex flex-column gap-2\">\n                <div class=\"ms-auto d-flex gap-2\">\n                    @for (btn of configModel().customHeaderActions; track btn) {\n                        <upd-button customClasses=\"gap-2\" [model]=\"btn\"></upd-button>\n                    }\n                </div>\n            </div>\n        }\n\n        @if (configModel().canSearch) {\n            <upd-search-section [actionsTpl]=\"!configModel().title ? actionsTpl : undefined\" [isSearching]=\"isSearching()\"\n                [(searchRequest)]=\"searchRequest\" [searchRequestSubject]=\"searchRequestSubject\" [config]=\"configModel()\"\n                [(hasChanges)]=\"hasSearchChanged\" [columns]=\"columns()\">\n            </upd-search-section>\n        }\n\n        <div [class.table-responsive]=\"configModel().isResponsive\">\n            <!-- TODO: implement pixel sized table -->\n            <table class=\"table card-table table-vcenter table-nowrap\" [class.fixed]=\"hasWidth\"\n                [class.pixel-sized]=\"isWidthInPixels\">\n                <thead [class.sticky-top]=\"configModel().hasStickyHeader\">\n                <tr>\n                    @if (configModel().hasCheckboxColumn) {\n                        <th class=\"checkbox-selector\">\n                            <upd-checkbox customClasses=\"m-0 ps-0\" (changed)=\"toggleAllSelection($event)\"\n                                [(isChecked)]=\"isMainCheckboxChecked\"\n                                [(isIndeterminate)]=\"isMainCheckboxIndeterminate\"></upd-checkbox>\n                        </th>\n                    }\n\n                    @for (col of columns(); track col) {\n                        <th [ngClass]=\"col.widthClass\" [style.width.px]=\"col.pixelsSize\">\n                            {{ textService.getText(col.title) }}\n                            @if (canSortColumn(col.name)) {\n                                <upd-icon [tablerIcon]=\"getSortingIcon(col.name)\" tablerIconWeight=\"bold\" colorClass=\"text-body-tertiary\"\n                                    [tablerIconSize]=\"16\" (click)=\"sortByColumn(col.name)\">\n                                </upd-icon>\n                            }\n                        </th>\n                    }\n\n                    @if (!!pendingWidthColClass) {\n                        <th [ngClass]=\"pendingWidthColClass\"></th>\n                    }\n\n                    @if (configModel().customActions.length > 0) {\n                        <th class=\"custom-actions\"></th>\n                    }\n                </tr>\n                </thead>\n\n                <tbody>\n                    @if (isSearching()) {\n                        <tr>\n                            <td [colSpan]=\"numberOfColumns\">\n                                <div class=\"empty\">\n                                    <h1 class=\"text-body-tertiary\">{{ t('Loading') }}...</h1>\n                                    <div class=\"progress progress-sm w-25\">\n                                        <div class=\"progress-bar progress-bar-indeterminate bg-body-tertiary\"></div>\n                                    </div>\n                                </div>\n                            </td>\n                        </tr>\n                    } @else {\n                        @for (record of data(); track record) {\n                            <tr>\n                                @if (configModel().hasCheckboxColumn) {\n                                    <td>\n                                        <upd-checkbox customClasses=\"m-0 ps-0\" (changed)=\"toggleItemSelection(record)\"\n                                            [isChecked]=\"selectionModel().isSelected(record)\"></upd-checkbox>\n                                    </td>\n                                }\n\n                                @for (col of columns(); track col) {\n                                    <td>\n                                        <ng-container updTableColumn [record]=\"record\" [config]=\"col\"></ng-container>\n                                    </td>\n                                }\n\n                                @if (!!pendingWidthColClass) {\n                                    <td></td>\n                                }\n\n                                @if (configModel().customActions.length > 0) {\n                                    <td style=\"overflow: unset\">\n                                        <div class=\"grow-left d-flex\">\n                                            @if (configModel().customActions.length > 1) {\n                                                <upd-button customClasses=\"ca-item\" [iconModel]=\"{tablerIcon:'dots'}\" [isIcon]=\"true\"\n                                                    [isLink]=\"true\" size=\"small\"></upd-button>\n\n                                                <div class=\"ca-dropdown-content rounded shadow-sm\">\n                                                    @for (btn of configModel().customActions; track btn) {\n                                                        <upd-button [model]=\"adaptCustomAction(btn, record)\"></upd-button>\n                                                    }\n                                                </div>\n                                            } @else {\n                                                <upd-button [model]=\"adaptCustomAction(configModel().customActions[0], record)\">\n                                                </upd-button>\n                                            }\n                                        </div>\n                                    </td>\n                                }\n                            </tr>\n                        } @empty {\n                            <tr>\n                                <td [colSpan]=\"numberOfColumns\">\n                                    <div class=\"empty\">\n                                        <p class=\"empty-title\">{{ t('NoRecordsFoundTitle') }}</p>\n                                        <p class=\"empty-subtitle text-secondary\">{{ t('NoRecordsFoundSubtitle') }}</p>\n                                    </div>\n                                </td>\n                            </tr>\n                        }\n                    }\n                </tbody>\n            </table>\n        </div>\n        <upd-paginator wrapperClasses=\"card-footer\" [shouldDisplayPreviousText]=\"false\" [shouldDisplayNextText]=\"false\"\n            [(pageSize)]=\"pageSize\" [shouldDisplayFirstText]=\"false\" [shouldDisplayLastText]=\"false\"\n            [(currentPage)]=\"currentPage\"\n            [totalRecords]=\"totalRecords()\" (changed)=\"onPageSettingsChanged()\">\n        </upd-paginator>\n    </div>\n\n    <ng-template #actionsTpl>\n        <div class=\"ms-auto d-flex gap-2\">\n            @if (!!activeSavedView()) {\n                @if (activeSavedView()!.isDefault) {\n                    <div class=\"ribbon ribbon-top ribbon-start\">\n                        <upd-icon tablerIcon=\"heart\" [tablerIconSize]=\"20\"></upd-icon>\n                    </div>\n                }\n                <div class=\"tag align-self-center py-3 text-primary bg-primary-lt border-primary\"\n                    updPopover=\"{{ t('CurrentSavedView') }}\"\n                    [updPopoverActAsTooltip]=\"true\">\n                    <upd-icon tablerIcon=\"list-details\" [tablerIconSize]=\"20\"></upd-icon>\n                    <span class=\"me-1\">{{ activeSavedView()!.name }}</span>\n                </div>\n            }\n            @if (hiddenColumns() > 0) {\n                <div class=\"tag align-self-center py-3 text-orange bg-orange-lt border-orange\"\n                    updPopover=\"{{ t('HiddenColumnsTooltip') }}\"\n                    [updPopoverActAsTooltip]=\"true\">\n                    <upd-icon tablerIcon=\"eye-off\" [tablerIconSize]=\"20\"></upd-icon>\n                    <span class=\"me-1\">{{ hiddenColumns() }}</span>\n                </div>\n            }\n            @if (!!activeSavedView() || hiddenColumns() > 0) {\n                <upd-button (clicked)=\"resetViewState()\" colorStyle=\"danger\" updPopover=\"{{ t('ResetView') }}\"\n                    [updPopoverActAsTooltip]=\"true\" [isIcon]=\"true\" [isOutline]=\"true\">\n                    <upd-icon tablerIcon=\"restore\" [tablerIconSize]=\"20\"></upd-icon>\n                </upd-button>\n            }\n            @if (configModel().canSaveViews) {\n                <upd-button customClasses=\"gap-2\" [isDisabled]=\"!hasSearchChanged()\" (clicked)=\"openSaveSearchModal()\"\n                    updPopover=\"{{ t('SaveCurrentView') }}\" [updPopoverActAsTooltip]=\"true\" [isIcon]=\"true\">\n                    <upd-icon tablerIcon=\"device-floppy\" [tablerIconSize]=\"20\"></upd-icon>\n                </upd-button>\n            }\n            @if (configModel().canManageColumns) {\n                <upd-button customClasses=\"gap-2\" (clicked)=\"openColumnsManagerModal()\">\n                    <upd-icon tablerIcon=\"columns\" [tablerIconSize]=\"20\"></upd-icon>\n                    {{ t('ColumnsManagerButton') }}\n                </upd-button>\n            }\n            @if (configModel().canSaveViews || configModel().canLoadSavedViews) {\n                <upd-button customClasses=\"gap-2\" (clicked)=\"isSavedViewsDropdownOpen = true\" #savedViewsBtn>\n                    <upd-icon tablerIcon=\"folders\" [tablerIconSize]=\"20\"></upd-icon>\n                    {{ t('SavedViews.ButtonTitle') }}\n                </upd-button>\n                <upd-dropdown wrapperClasses=\"overflow-x-hidden mt-1\" [isOpen]=\"isSavedViewsDropdownOpen\"\n                    [dropdownReference]=\"savedViewsRef()\" [items]=\"savedViewsOptions()\" [shouldCloseOnOutsideClick]=\"true\"\n                    (isOpenChange)=\"isSavedViewsDropdownOpen = $event\" [minWidth]=\"350\" (selectedItem)=\"selectSavedView($event)\">\n                    @if (savedViewsOptions().length < 1) {\n                        <span class=\"m-2\">{{ t('NoSavedViews') }}</span>\n                    }\n                </upd-dropdown>\n            }\n        </div>\n    </ng-template>\n</ng-container>\n"]}
|
|
442
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"","sources":["../../../../../libs/components/table/src/table.component.ts","../../../../../libs/components/table/src/table.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAkB,KAAK,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAE1H,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,EAAE,cAAc,EAAE,KAAK,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAC;AAEhF,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAChE,OAAO,EAAuC,UAAU,EAAE,iBAAiB,EAAuB,MAAM,oBAAoB,CAAC;AAC7H,OAAO,EAAE,YAAY,EAAY,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAErF,OAAO,EAAE,oBAAoB,EAAE,GAAG,EAAE,SAAS,EAAE,QAAQ,EAAE,OAAO,EAAE,UAAU,EAAE,EAAE,EAAE,MAAM,MAAM,CAAC;AAE/F,OAAO,EAAE,kBAAkB,EAAE,MAAM,uCAAuC,CAAC;AAC3E,OAAO,EAAE,mBAAmB,EAAE,MAAM,yCAAyC,CAAC;AAC9E,OAAO,EAAE,eAAe,EAAE,MAAM,oCAAoC,CAAC;AACrE,OAAO,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAC;AACvE,OAAO,EAAE,iBAAiB,EAAE,MAAM,sCAAsC,CAAC;AACzE,OAAO,EAAE,eAAe,EAAE,MAAM,oCAAoC,CAAC;AACrE,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AAEjE,OAAO,EAAE,gBAAgB,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AAEnE,OAAO,EAAE,uBAAuB,EAAE,MAAM,wDAAwD,CAAC;AACjG,OAAO,EAAE,mBAAmB,EAAE,MAAM,gDAAgD,CAAC;AAErF,OAAO,EAAE,iBAAiB,EAAE,MAAM,yCAAyC,CAAC;AAE5E,IAAO,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC;;;;;;;;;;;;AAO3B,MAAM,OAAO,cAAkB,SAAQ,aAAa;IAUhD,IAAI,eAAe;QACf,OAAO,IAAI,CAAC,OAAO,EAAE,CAAC,MAAM;cACtB,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;cAC9C,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;cACrD,CAAC,CAAC,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAChD,CAAC;IACD,IAAI,QAAQ;QACR,OAAO,IAAI,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IACnD,CAAC;IACD,IAAI,oBAAoB;QACpB,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YACzC,OAAO,EAAE,CAAC;QACd,CAAC;QAED,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC;QACnE,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC;QAChC,MAAM,aAAa,GAAG,KAAK,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;QAE5F,yDAAyD;QAEzD,OAAO,aAAa,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,aAAa,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;IACjF,CAAC;IACD,IAAI,eAAe;QACf,OAAO,IAAI,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;IAC3D,CAAC;IAyBD,IAAY,QAAQ;QAChB,OAAO,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC;IACtC,CAAC;IACD,IAAY,KAAK;QACb,OAAO,IAAI,CAAC,WAAW,EAAE,CAAC,KAAM,CAAC;IACrC,CAAC;IAcD;QACI,KAAK,EAAE,CAAC;QA9EZ,kBAAa,GAAG,SAAS,CAAC,eAAe,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC;QACjE,WAAM,GAAG,KAAK,CAAC,QAAQ,EAAkB,CAAC;QAC1C,gBAAW,GAAG,MAAM,CAAU,KAAK,CAAC,CAAC;QACrC,kBAAa,GAAG,QAAQ,CAAM,GAAG,EAAE,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,QAAQ,EAAE,CAAC,CAAC;QACtE,oBAAe,GAAG,MAAM,CAA+B,SAAS,CAAC,CAAC;QAClE,0BAAqB,GAAG,KAAK,CAAC;QAC9B,gCAA2B,GAAG,KAAK,CAAC;QACpC,6BAAwB,GAAG,KAAK,CAAC;QA4BxB,kBAAa,GAAG,KAAK,CAAqB,EAAE,CAAC,CAAC;QAC9C,kBAAa,GAAG,KAAK,CAAoB,EAAE,CAAC,CAAC;QAC7C,gBAAW,GAAG,KAAK,CAAS,CAAC,CAAC,CAAC;QAC/B,aAAQ,GAAG,KAAK,CAAS,CAAC,CAAC,CAAC;QAC5B,qBAAgB,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QACjC,iBAAY,GAAG,MAAM,CAAS,CAAC,CAAC,CAAC;QACjC,gBAAW,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,gBAAgB,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QAClE,SAAI,GAAgB,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;QACtH,mBAAc,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,cAAc,CAAI,IAAI,CAAC,WAAW,EAAE,CAAC,aAAa,CAAC,CAAC,CAAC;QACzF,mBAAc,GAAG,MAAM,CAA2B,SAAS,CAAC,CAAC;QAC7D,kBAAa,GAAG,QAAQ,CAAC,GAAG,EAAE,CACnC,IAAI,CAAC,WAAW,EAAE,CAAC,gBAAgB,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CACtG,CAAC;QACO,YAAO,GAAG,MAAM,CAAoB,EAAE,CAAC,CAAC;QACxC,yBAAoB,GAAG,IAAI,OAAO,EAAsB,CAAC;QACzD,gBAAW,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;QAClC,sBAAiB,GAAG,QAAQ,CAAiB,GAAG,EAAE;YACvD,MAAM,oBAAoB,GAAmB,EAAE,CAAC;YAChD,IAAI,CAAC,aAAa,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YAE3F,OAAO,oBAAoB,CAAC;QAChC,CAAC,CAAC,CAAC;QAQK,sBAAiB,GAAG,KAAK,CAAC;QAC1B,kBAAa,GAAsB,EAAE,CAAC;QAE7B,gBAAW,GAAG,MAAM,CAAM,EAAE,CAAC,CAAC;QAC9B,2BAAsB,GAAG,QAAQ,CAAgB,GAAG,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QAC7E,oBAAe,GAAG,MAAM,CAAiB,OAAO,CAAC,CAAC;QAClD,kBAAa,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACzF,oBAAe,GAAkB,EAAE,CAAC;QACpC,0BAAqB,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAC;QACtD,sBAAiB,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAC9C,iBAAY,GAAG,MAAM,CAAC,YAAY,CAAC,CAAC;QACpC,sBAAiB,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAK3D,MAAM,CAAC,GAAG,EAAE;YACR,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC/D,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC5B,CAAC;YAED,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAClC,IAAI,IAAI,CAAC,aAAa,EAAE,CAAC,MAAM,KAAK,IAAI,CAAC,IAAI,EAAE,CAAC,MAAM,EAAE,CAAC;oBACrD,IAAI,CAAC,qBAAqB,GAAG,KAAK,CAAC;oBACnC,IAAI,CAAC,2BAA2B,GAAG,IAAI,CAAC;gBAC5C,CAAC;qBAAM,CAAC;oBACJ,IAAI,CAAC,2BAA2B,GAAG,KAAK,CAAC;oBACzC,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC;gBACtC,CAAC;YACL,CAAC;iBAAM,CAAC;gBACJ,IAAI,CAAC,qBAAqB,GAAG,KAAK,CAAC;gBACnC,IAAI,CAAC,2BAA2B,GAAG,KAAK,CAAC;YAC7C,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,aAAa,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,OAAO,CAAC,CAAC;QAChD,MAAM,gBAAgB,GAAG,IAAI,CAAC,oBAAoB;aAC7C,IAAI,CACD,oBAAoB,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,EAClG,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE;YACZ,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAC3B,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YACzB,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;YAEhC,IACI,CAAC,OAAO,CAAC,OAAO,EAAE,MAAM,IAAI,CAAC,CAAC,GAAG,CAAC;mBAC/B,CAAC,OAAO,CAAC,WAAW,IAAI,EAAE,CAAC,CAAC,MAAM,GAAG,CAAC;mBACtC,CAAC,OAAO,CAAC,QAAQ,EAAE,MAAM,IAAI,CAAC,CAAC,GAAG,CAAC,EACxC,CAAC;gBACC,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YACpC,CAAC;QACL,CAAC,CAAC,EACF,SAAS,CAAC,GAAG,EAAE,CACX,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC,IAAI,CACxC,UAAU,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,gDAAgD;SAC1E,CACJ,EACD,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC,CACjD;aACA,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC,CAAC;QACtD,MAAM,iBAAiB,GAAG,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;YAC3E,IAAI,CAAC,CAAC,KAAK,EAAE,CAAC;gBACV,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YAChC,CAAC;QACL,CAAC,CAAC,CAAC;QAEH,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC,gBAAgB,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YACvD,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;YAC9B,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACvC,CAAC;QAED,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,CAAC;QAC/C,IAAI,CAAC,gBAAgB,CAAC,gBAAgB,EAAE,iBAAiB,CAAC,CAAC;IAC/D,CAAC;IAED,kBAAkB,CAAC,SAAkB;QACjC,IAAI,SAAS,EAAE,CAAC;YACZ,IAAI,CAAC,cAAc,EAAE,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;QACxD,CAAC;aAAM,CAAC;YACJ,IAAI,CAAC,cAAc,EAAE,CAAC,cAAc,EAAE,CAAC;QAC3C,CAAC;IACL,CAAC;IAED,mBAAmB,CAAC,MAAS;QACzB,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;YAC3C,IAAI,CAAC,cAAc,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QAC3C,CAAC;aAAM,CAAC;YACJ,IAAI,CAAC,cAAc,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QACzC,CAAC;IACL,CAAC;IAED,aAAa,CAAC,UAAkB;QAC5B,OAAO,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC,SAAS,CAAC;IACtD,CAAC;IAED,YAAY,CAAC,UAAkB;QAC3B,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,CAAC;YACzB,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,IAAI,UAAU,CAAC,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC;QACpE,CAAC;aAAM,CAAC;YACJ,IAAI,CAAC,cAAc,CAAC,GAAG,CACnB,IAAI,UAAU,CAAC;gBACX,MAAM,EAAE,UAAU;gBAClB,SAAS,EAAE,IAAI,CAAC,cAAc,EAAG,CAAC,MAAM,KAAK,UAAU;oBACnD,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,EAAG,CAAC,SAAS,KAAK,iBAAiB,CAAC,GAAG,CAAC,CAAC,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC,CAAC,iBAAiB,CAAC,GAAG,CAAC;oBAC/G,CAAC,CAAC,iBAAiB,CAAC,GAAG;aAC9B,CAAC,CACL,CAAC;QACN,CAAC;QAED,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAChB,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC;gBACnB,GAAG,IAAI,CAAC,aAAa,EAAE;gBACvB,QAAQ,EAAE,CAAC,IAAI,CAAC,cAAc,EAAG,CAAC;aACrC,CAAC,CAAC;YACH,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC;QACzD,CAAC;aAAM,CAAC;YACJ,MAAM,GAAG,GAAG,IAAI,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;YAC7C,mBAAmB;QACvB,CAAC;IACL,CAAC;IAED,cAAc,CAAC,UAAkB;QAC7B,OAAO,CAAC,CAAC,IAAI,CAAC,cAAc,EAAE,IAAI,IAAI,CAAC,cAAc,EAAG,CAAC,MAAM,KAAK,UAAU;YAC1E,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,EAAG,CAAC,SAAS,KAAK,iBAAiB,CAAC,GAAG,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,iBAAiB,CAAC;YACrG,CAAC,CAAC,aAAa,CAAC;IACxB,CAAC;IAED,qBAAqB;QACjB,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC;YACnB,GAAG,IAAI,CAAC,aAAa,EAAE;YACvB,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE;YACzB,SAAS,EAAE,IAAI,CAAC,WAAW,EAAE;SAChC,CAAC,CAAC;QACH,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC;IACzD,CAAC;IAED,WAAW,CAAC,MAAS;QACjB,OAAO,IAAI,CAAC,WAAW,EAAE,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;IACpD,CAAC;IAED,uBAAuB;QACnB,MAAM,GAAG,GAAa,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,EAAE;YACpD,eAAe,EAAE,uBAAuB;YACxC,eAAe,EAAE,KAAK;YACtB,gBAAgB,EAAE,IAAI;YACtB,IAAI,EAAE,IAAI,CAAC,MAAM,EAAE;YACnB,cAAc,EAAE,KAAK;YACrB,aAAa,EAAE;gBACX,IAAI,WAAW,CAAC;oBACZ,IAAI,EAAE,MAAM,CAAC,EAAE,IAAI,EAAE,mCAAmC,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC;oBAChF,UAAU,EAAE,MAAM,CAAC,SAAS,CAAC;oBAC7B,SAAS,EAAE,MAAM,CAAC,EAAE,UAAU,EAAE,QAAQ,EAAE,CAAC;oBAC3C,aAAa,EAAE,GAAG,EAAE,CAAC,GAAG,CAAC,KAAK,EAAE;iBACnC,CAAC;aACL;SACJ,CAAC,CAAC;QACH,GAAG,CAAC,UAAU,GAAG,GAAG,EAAE;YAClB,MAAM,MAAM,GAAG,GAAG,CAAC,eAAe,EAA8B,EAAE,OAAO,EAAE,CAAC;YAE5E,IAAI,CAAC,CAAC,MAAM,EAAE,CAAC;gBACX,MAAM,2BAA2B,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;gBACpE,MAAM,mBAAmB,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,SAAS,CAAC,EAAE,KAAK,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;gBACnG,MAAM,UAAU,GAAsB,EAAE,CAAC;gBAEzC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE;oBACxB,mBAAmB,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;wBAC/B,MAAM,GAAG,GAAG,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,IAAI,CAAE,CAAC;wBACvD,GAAG,CAAC,QAAQ,GAAG,KAAK,CAAC;wBAErB,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;oBACzB,CAAC,CAAC,CAAC;oBACH,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;wBACvB,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC;4BACxC,CAAC,CAAC,QAAQ,GAAG,IAAI,CAAC;4BAClB,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;wBACvB,CAAC;oBACL,CAAC,CAAC,CAAC;oBAEH,OAAO,EAAE,GAAG,MAAM,EAAE,OAAO,EAAE,CAAC,GAAG,UAAU,CAAC,EAAE,CAAC;gBACnD,CAAC,CAAC,CAAC;gBACH,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;gBAE/B,MAAM,sBAAsB,GAAG,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;gBAE3D,IAAI,2BAA2B,CAAC,MAAM,KAAK,sBAAsB,CAAC,MAAM;uBACjE,CAAC,2BAA2B,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,sBAAsB,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;oBACnF,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;gBACpC,CAAC;YACL,CAAC;QACL,CAAC,CAAC;IACN,CAAC;IAED,mBAAmB,CAAC,IAAqB;QACrC,IAAI,GAAG,IAAI,IAAI;YACX,SAAS,EAAE,IAAI,CAAC,WAAW,EAAE,CAAC,IAAI;YAClC,OAAO,EAAE,IAAI,CAAC,aAAa,EAAE;YAC7B,OAAO,EAAE,IAAI,CAAC,WAAW,EAAE,CAAC,OAAO;SACtC,CAAC;QACF,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,mBAAmB,EAAE,EAAE,eAAe,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;IAClF,CAAC;IAED,eAAe,CAAC,IAAkB;QAC9B,MAAM,SAAS,GAAG,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC;QACrF,IAAI,CAAC,wBAAwB,GAAG,KAAK,CAAC;QAEtC,IAAI,CAAC,CAAC,SAAS,EAAE,CAAC;YACd,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC;YACtC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE;gBACtB,IAAI,CAAC,OAAO,GAAG,SAAS,CAAC,OAAO,CAAC;gBACjC,OAAO,EAAE,GAAG,IAAI,EAAE,CAAC;YACvB,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;YACpC,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAE,GAAG,SAAS,CAAC,OAAO,EAAE,CAAC,CAAC;QAC7D,CAAC;IACL,CAAC;IAED,cAAc;QACV,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QACpC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QACvC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE;YACtB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC;YAClC,OAAO,EAAE,GAAG,IAAI,EAAE,CAAC;QACvB,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACvC,CAAC;IAED,MAAM;QACF,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAC9B,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACvC,CAAC;IAED,iBAAiB,CAAC,GAAgB,EAAE,IAAO;QACvC,MAAM,MAAM,GAAG,IAAI,WAAW,CAAC;YAC3B,EAAE,EAAE,GAAG,CAAC,EAAE;YACV,SAAS,EAAE,GAAG,CAAC,SAAS;YACxB,KAAK,EAAE,GAAG,CAAC,KAAK;YAChB,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC;YACpB,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC;YACpB,IAAI,EAAE,MAAM,CAAC,OAAO,CAAC;YACrB,IAAI,EAAE,SAAS;YACf,UAAU,EAAE,GAAG,CAAC,UAAU;YAC1B,SAAS,EAAE,GAAG,CAAC,SAAS;SAC3B,CAAC,CAAC;QACH,MAAM,eAAe,GAAG,GAAG,CAAC,aAAa,CAAC;QAC1C,MAAM,CAAC,aAAa,GAAG,CAAC,GAAG,EAAE,EAAE;YAC3B,GAAG,CAAC,KAAK,EAAE,cAAc,EAAE,CAAC;YAC5B,GAAG,CAAC,KAAK,EAAE,eAAe,EAAE,CAAC;YAE7B,IAAI,CAAC,CAAC,eAAe,EAAE,CAAC;gBACpB,eAAe,CAAC,EAAE,KAAK,EAAE,GAAG,CAAC,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;YACtD,CAAC;QACL,CAAC,CAAC;QAEF,OAAO,MAAM,CAAC;IAClB,CAAC;IAEO,aAAa,CAAC,OAA0B;QAC5C,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC3F,CAAC;IAEO,iBAAiB,CAAC,IAAqB;QAC3C,QAAQ,IAAI,CAAC,IAAI,EAAE,CAAC;YAChB,KAAK,cAAc,CAAC,IAAI;gBACpB,OAAO,IAAI,eAAe,CAAC,EAAE,GAAG,IAAI,EAAE,CAAC,CAAC;YAC5C,KAAK,cAAc,CAAC,MAAM;gBACtB,OAAO,IAAI,iBAAiB,CAAC,EAAE,GAAG,IAAI,EAAE,CAAC,CAAC;YAC9C,KAAK,cAAc,CAAC,OAAO;gBACvB,OAAO,IAAI,kBAAkB,CAAC,EAAE,GAAG,IAAI,EAAE,CAAC,CAAC;YAC/C,KAAK,cAAc,CAAC,QAAQ,CAAC;YAC7B,KAAK,cAAc,CAAC,IAAI,CAAC;YACzB,KAAK,cAAc,CAAC,IAAI;gBACpB,OAAO,IAAI,mBAAmB,CAAC,EAAE,GAAG,IAAI,EAAE,CAAC,CAAC;YAChD,KAAK,cAAc,CAAC,KAAK;gBACrB,OAAO,IAAI,gBAAgB,CAAC,EAAE,GAAG,IAAI,EAAE,CAAC,CAAC;YAC7C,KAAK,cAAc,CAAC,IAAI;gBACpB,OAAO,IAAI,eAAe,CAAC,EAAE,GAAG,IAAI,EAAE,CAAC,CAAC;YAC5C,KAAK,cAAc,CAAC,MAAM,CAAC;YAC3B,KAAK,cAAc,CAAC,MAAM,CAAC;YAC3B,KAAK,cAAc,CAAC,QAAQ,CAAC;YAC7B;gBACI,OAAO,IAAI,eAAe,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,GAAG,IAAI,EAAE,CAAC,CAAC;QAC3D,CAAC;IACL,CAAC;IAEO,eAAe,CAAC,UAAkB;QACtC,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,UAAU,CAAC,CAAC;QAE5D,IAAI,CAAC,GAAG,EAAE,CAAC;YACP,MAAM,KAAK,CAAC,qCAAqC,CAAC,CAAC;QACvD,CAAC;QAED,OAAO,GAAG,CAAC;IACf,CAAC;IAEO,gBAAgB;QACpB,IAAI,CAAC,WAAW,EAAE,CAAC,gBAAgB,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YAC/C,MAAM,EAAE,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;YAElC,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;gBAC/F,IAAI,CAAC,cAAc,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;YACvC,CAAC;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,kBAAkB,CAAC,IAA4B;QACnD,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAC5B,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACnC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,IAAI,CAAC,CAAC,CAAC;QAC9C,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,CAAC,CAAC;QAC1C,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,CAAC,CAAC;QACtC,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC5B,CAAC;IAEO,gBAAgB,CAAC,sBAA6C,EAAE,SAAyB;QAC7F,OAAO;YACH,IAAI,WAAW,CAAC;gBACZ,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC;gBACpB,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC;gBACrB,UAAU,EAAE,MAAM,CAAC,SAAS,CAAC;gBAC7B,IAAI,EAAE,IAAI,CAAC,eAAe;gBAC1B,KAAK,EAAE,MAAM,CAAC,EAAE,IAAI,EAAE,uCAAuC,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC;gBACrF,QAAQ,EAAE,MAAM,CAAC,SAAS,CAAC,SAAS,IAAI,KAAK,CAAC;gBAC9C,SAAS,EAAE,MAAM,CAAC,EAAE,UAAU,EAAE,OAAO,EAAE,CAAC;gBAC1C,aAAa,EAAE,CAAC,GAAG,EAAE,EAAE;oBACnB,MAAM,QAAQ,GAAI,GAAG,CAAC,IAAmC,CAAC;oBAC1D,MAAM,cAAc,GAAG,QAAQ,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;oBAElD,IAAI,CAAC,cAAc,EAAE,CAAC;wBAClB,IAAI,CAAC,iBAAiB,CAAC,iBAAiB,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,IAAI,CAAC,CAAC;oBACtE,CAAC;oBAED,SAAS,CAAC,SAAS,GAAG,CAAC,cAAc,CAAC;oBAEtC,sBAAsB,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC;oBACjE,QAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,cAAc,CAAC,CAAC;oBAC9C,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;gBAC/C,CAAC;aACJ,CAAC;YACF,IAAI,WAAW,CAAC;gBACZ,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC;gBACpB,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC;gBACrB,UAAU,EAAE,MAAM,CAAC,WAAW,CAAC;gBAC/B,IAAI,EAAE,IAAI,CAAC,eAAe;gBAC1B,KAAK,EAAE,MAAM,CAAC,EAAE,IAAI,EAAE,mCAAmC,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC;gBACjF,SAAS,EAAE,MAAM,CAAC,EAAE,UAAU,EAAE,MAAM,EAAE,CAAC;gBACzC,aAAa,EAAE,GAAG,EAAE;oBAChB,MAAM,aAAa,GAAG;wBAClB,GAAG,SAAS;wBACZ,EAAE,EAAE,KAAK,CAAC,IAAI,CAAC,QAAQ,EAAE;wBACzB,IAAI,EAAE,SAAS,CAAC,IAAI;4BAChB,KAAK,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE,IAAI,EAAE,yCAAyC,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC,GAAG;qBACjH,CAAC;oBACF,IAAI,CAAC,mBAAmB,CAAC,aAAa,CAAC,CAAC;gBAC5C,CAAC;aACJ,CAAC;YACF,IAAI,WAAW,CAAC;gBACZ,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC;gBACpB,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC;gBACrB,UAAU,EAAE,MAAM,CAAC,WAAW,CAAC;gBAC/B,IAAI,EAAE,IAAI,CAAC,eAAe;gBAC1B,KAAK,EAAE,MAAM,CAAC,EAAE,IAAI,EAAE,8BAA8B,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC;gBAC5E,SAAS,EAAE,MAAM,CAAC,EAAE,UAAU,EAAE,MAAM,EAAE,CAAC;gBACzC,aAAa,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,mBAAmB,CAAC,SAAS,CAAC;aAC3D,CAAC;YACF,IAAI,WAAW,CAAC;gBACZ,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC;gBACpB,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC;gBACrB,UAAU,EAAE,MAAM,CAAC,QAAQ,CAAC;gBAC5B,IAAI,EAAE,IAAI,CAAC,eAAe;gBAC1B,KAAK,EAAE,MAAM,CAAC,EAAE,IAAI,EAAE,gCAAgC,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC;gBAC9E,SAAS,EAAE,MAAM,CAAC,EAAE,UAAU,EAAE,GAAG,EAAE,CAAC;gBACtC,aAAa,EAAE,GAAG,EAAE;oBAChB,MAAM,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAClC,EAAE,IAAI,EAAE,uCAAuC,EAAE,YAAY,EAAE,KAAK,EAAE,EACtE,EAAE,IAAI,EAAE,SAAS,CAAC,IAAI,EAAE,CAC3B,CAAC;oBACF,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,YAAY,EAAE,IAAI,EAAE,CAAC,CAAC,SAAS,CAAC,WAAW,CAAC,EAAE;wBAC5F,IAAI,WAAW,EAAE,CAAC;4BACd,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,IAAI,EAAE,SAAS,CAAC,EAAG,CAAC,CAAC;wBAC/E,CAAC;oBACL,CAAC,CAAC,CAAC;gBACP,CAAC;aACJ,CAAC;SACL,CAAC;IACN,CAAC;IAEO,kBAAkB,CAAC,SAAyB;QAChD,MAAM,aAAa,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,sBAAsB,EAAE,SAAS,CAAC,CAAC;QACpF,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,SAAS,EAAE,EAAE,CAAC,UAAU,KAAK,OAAO,CAAE,CAAC,CAAC;QAE9F,OAAO;YACH,EAAE,EAAE,SAAS,CAAC,EAAE;YAChB,IAAI,EAAE,cAAc;YACpB,IAAI,EAAE,EAAE,IAAI,EAAE,SAAS,CAAC,IAAK,EAAE,YAAY,EAAE,IAAI,EAAE;YACnD,WAAW,EAAE,QAAQ;YACrB,QAAQ,EAAE,IAAI,CAAC,eAAe,EAAE,EAAE,EAAE,KAAK,SAAS,CAAC,EAAE;YACrD,aAAa;SAChB,CAAC;IACN,CAAC;8GAjdQ,cAAc;kGAAd,cAAc,4+BAC4B,UAAU,oECnCjE,4mVAiMA;;2FD/Ja,cAAc;kBAL1B,SAAS;+BACI,WAAW","sourcesContent":["import { Component, inject, signal, computed, effect, OnInit, Signal, model, ElementRef, viewChild } from '@angular/core';\nimport { TablerIconsType } from '@updevs/icons';\nimport { TextService } from '@updevs/sdk';\nimport { SelectionModel, Tools, ServerResponseService } from '@updevs/sdk/core';\nimport { OptionalType, ButtonSizeType } from '@updevs/sdk/types';\nimport { BaseComponent, ButtonModel } from '@updevs/sdk/layout';\nimport { SearchRequestModel, BaseSearchStore, ColumnSort, SortDirectionEnum, SearchResponseModel } from '@updevs/sdk/stores';\nimport { ModalService, ModalRef, ModalAlertService } from '@updevs/components/modal';\nimport { DropdownItem, DropdownActionClickedModel } from '@updevs/components/dropdown';\nimport { distinctUntilChanged, tap, switchMap, finalize, Subject, catchError, of } from 'rxjs';\n\nimport { BooleanColumnModel } from './models/columns/boolean-column.model';\nimport { DateTimeColumnModel } from './models/columns/date-time-column.model';\nimport { GuidColumnModel } from './models/columns/guid-column.model';\nimport { ImageColumnModel } from './models/columns/image-column.model';\nimport { NumberColumnModel } from './models/columns/number-column.model';\nimport { TextColumnModel } from './models/columns/text-column.model';\nimport { ColumnTypeEnum } from './models/enums/column-type.enum';\nimport { TableConfig } from './models/table.config';\nimport { TableConfigModel } from './models/table-config.model';\nimport { BaseColumnModel } from './abstractions/base-column.model';\nimport { FilterItemModel } from './models/filter-item.model';\nimport { ColumnsManagerComponent } from './components/columns-manager/columns-manager.component';\nimport { SaveSearchComponent } from './components/save-search/save-search.component';\nimport { SavedViewModel } from './models/saved-view.model';\nimport { SavedViewsStorage } from './services/storages/saved-views.storage';\n\nimport Utils = Tools.Utils;\n\n@Component({\n    selector: 'upd-table',\n    templateUrl: './table.component.html',\n    styleUrl: './table.component.scss'\n})\nexport class TableComponent<T> extends BaseComponent implements OnInit {\n    savedViewsRef = viewChild('savedViewsBtn', { read: ElementRef });\n    config = model.required<TableConfig<T>>();\n    isSearching = signal<boolean>(false);\n    selectedItems = computed<T[]>(() => this.selectionModel().selected());\n    activeSavedView = signal<OptionalType<SavedViewModel>>(undefined);\n    isMainCheckboxChecked = false;\n    isMainCheckboxIndeterminate = false;\n    isSavedViewsDropdownOpen = false;\n\n    get numberOfColumns(): number {\n        return this.columns().length\n            + (this.configModel().hasCheckboxColumn ? 1 : 0)\n            + (this.configModel().customActions.length > 0 ? 1 : 0)\n            + (!!this.pendingWidthColClass ? 1 : 0);\n    }\n    get hasWidth(): boolean {\n        return this.columns().some(rec => !!rec.width);\n    }\n    get pendingWidthColClass(): string {\n        if (!this.hasWidth || this.isWidthInPixels) {\n            return '';\n        }\n\n        const isGrid = this.columns().some(rec => !!rec.width?.gridColumn);\n        const total = isGrid ? 12 : 100;\n        const remainingSize = total - this.columns().reduce((acc, item) => acc + item.widthSize, 0);\n\n        // TODO: add spaces of checkbox and customactions columns\n\n        return remainingSize > 0 ? `${(isGrid ? 'col' : 'w')}-${remainingSize}` : '';\n    }\n    get isWidthInPixels(): boolean {\n        return this.columns().some(rec => !!rec.width?.pixels);\n    }\n\n    readonly searchRequest = model<SearchRequestModel>({});\n    readonly activeFilters = model<FilterItemModel[]>([]);\n    readonly currentPage = model<number>(1);\n    readonly pageSize = model<number>(0);\n    readonly hasSearchChanged = signal(false);\n    readonly totalRecords = signal<number>(0);\n    readonly configModel = computed(() => new TableConfigModel(this.config()));\n    readonly data: Signal<T[]> = computed(() => this.configModel().data.length > 0 ? this.configModel().data : this.currentData());\n    readonly selectionModel = computed(() => new SelectionModel<T>(this.configModel().getIdFunction));\n    readonly currentSorting = signal<OptionalType<ColumnSort>>(undefined);\n    readonly hiddenColumns = computed(() =>\n        this.configModel().canManageColumns ? this.configModel().columns.filter(c => c.isHidden).length : 0\n    );\n    readonly columns = signal<BaseColumnModel[]>([]);\n    readonly searchRequestSubject = new Subject<SearchRequestModel>();\n    readonly textService = inject(TextService);\n    readonly savedViewsOptions = computed<DropdownItem[]>(() => {\n        const allSavedViewsOptions: DropdownItem[] = [];\n        this.allSavedViews().forEach(sv => allSavedViewsOptions.push(this.getSavedViewOption(sv)));\n\n        return allSavedViewsOptions;\n    });\n\n    private get isRemote(): boolean {\n        return !!this.configModel().store;\n    }\n    private get store(): BaseSearchStore<T> {\n        return this.configModel().store!;\n    }\n    private shouldForceSearch = false;\n    private columnsBackup: BaseColumnModel[] = [];\n\n    private readonly currentData = signal<T[]>([]);\n    private readonly currentFavoriteButtons = computed<ButtonModel[]>(() => this.favoriteButtons);\n    private readonly smallSizeSignal = signal<ButtonSizeType>('small');\n    private readonly allSavedViews = computed(() => this.savedViewsStorage.getAll(this.configModel().name)());\n    private readonly favoriteButtons: ButtonModel[] = [];\n    private readonly serverResponseService = inject(ServerResponseService);\n    private readonly savedViewsStorage = inject(SavedViewsStorage);\n    private readonly modalService = inject(ModalService);\n    private readonly modalAlertService = inject(ModalAlertService);\n\n    constructor() {\n        super();\n\n        effect(() => {\n            if (this.data().length > 0 && this.configModel().data.length > 0) {\n                this.setupPreSelected();\n            }\n\n            if (this.selectedItems().length > 0) {\n                if (this.selectedItems().length !== this.data().length) {\n                    this.isMainCheckboxChecked = false;\n                    this.isMainCheckboxIndeterminate = true;\n                } else {\n                    this.isMainCheckboxIndeterminate = false;\n                    this.isMainCheckboxChecked = true;\n                }\n            } else {\n                this.isMainCheckboxChecked = false;\n                this.isMainCheckboxIndeterminate = false;\n            }\n        });\n    }\n\n    ngOnInit(): void {\n        this.columnsBackup = [...this.config().columns];\n        const searchSubjectSub = this.searchRequestSubject\n            .pipe(\n                distinctUntilChanged((prev, curr) => !this.shouldForceSearch ? Utils.areEqual(prev, curr) : false),\n                tap((request) => {\n                    this.isSearching.set(true);\n                    this.currentData.set([]);\n                    this.searchRequest.set(request);\n\n                    if (\n                        (request.filters?.length || 0) > 0\n                        || (request.description || '').length > 0\n                        || (request.sortings?.length || 0) > 0\n                    ) {\n                        this.hasSearchChanged.set(true);\n                    }\n                }),\n                switchMap(() =>\n                    this.store.search(this.searchRequest()).pipe(\n                        catchError(() => of()) // Already handled by the ServerResponseService.\n                    )\n                ),\n                finalize(() => this.shouldForceSearch = false)\n            )\n            .subscribe(resp => this.setupSearchResults(resp));\n        const serverResponseSub = this.serverResponseService.onError.subscribe(error => {\n            if (!!error) {\n                this.isSearching.set(false);\n            }\n        });\n\n        if (this.configModel().shouldAutoSearch && this.isRemote) {\n            this.shouldForceSearch = true;\n            this.searchRequestSubject.next({});\n        }\n\n        this.updateColumns(this.configModel().columns);\n        this.addSubscriptions(searchSubjectSub, serverResponseSub);\n    }\n\n    toggleAllSelection(isChecked: boolean): void {\n        if (isChecked) {\n            this.selectionModel().select(...this.currentData());\n        } else {\n            this.selectionModel().clearSelection();\n        }\n    }\n\n    toggleItemSelection(record: T): void {\n        if (this.selectionModel().isSelected(record)) {\n            this.selectionModel().deselect(record);\n        } else {\n            this.selectionModel().select(record);\n        }\n    }\n\n    canSortColumn(columnName: string): boolean {\n        return this.getColumnByName(columnName).allowSort;\n    }\n\n    sortByColumn(columnName: string): void {\n        if (!this.currentSorting()) {\n            this.currentSorting.set(new ColumnSort({ column: columnName }));\n        } else {\n            this.currentSorting.set(\n                new ColumnSort({\n                    column: columnName,\n                    direction: this.currentSorting()!.column === columnName\n                        ? (this.currentSorting()!.direction === SortDirectionEnum.Asc ? SortDirectionEnum.Desc : SortDirectionEnum.Asc)\n                        : SortDirectionEnum.Asc\n                })\n            );\n        }\n\n        if (this.isRemote) {\n            this.searchRequest.set({\n                ...this.searchRequest(),\n                sortings: [this.currentSorting()!]\n            });\n            this.searchRequestSubject.next(this.searchRequest());\n        } else {\n            const col = this.getColumnByName(columnName);\n            // TODO: local sort\n        }\n    }\n\n    getSortingIcon(columnName: string): TablerIconsType {\n        return !!this.currentSorting() && this.currentSorting()!.column === columnName\n            ? (this.currentSorting()!.direction === SortDirectionEnum.Asc ? 'sort-ascending' : 'sort-descending')\n            : 'arrows-sort';\n    }\n\n    onPageSettingsChanged(): void {\n        this.searchRequest.set({\n            ...this.searchRequest(),\n            pageSize: this.pageSize(),\n            pageIndex: this.currentPage()\n        });\n        this.searchRequestSubject.next(this.searchRequest());\n    }\n\n    getRecordId(record: T): any {\n        return this.configModel().getIdFunction(record);\n    }\n\n    openColumnsManagerModal(): void {\n        const ref: ModalRef = this.modalService.open(undefined, {\n            bodyContentType: ColumnsManagerComponent,\n            showCloseButton: false,\n            showCancelButton: true,\n            data: this.config(),\n            isTextCentered: false,\n            actionButtons: [\n                new ButtonModel({\n                    text: signal({ text: 'UpDevs.Table.ColumnsManager.Apply', isTranslated: false }),\n                    colorStyle: signal('primary'),\n                    iconModel: signal({ tablerIcon: 'checks' }),\n                    clickFunction: () => ref.close()\n                })\n            ]\n        });\n        ref.afterClose = () => {\n            const result = ref.getBodyInstance<ColumnsManagerComponent<T>>()?.columns();\n\n            if (!!result) {\n                const previousVisibleColumnsOrder = this.columns().map(c => c.name);\n                const visibleColumnsNames = result.find(c => c.name === 'visible')?.items().map(i => i.name) || [];\n                const newColumns: BaseColumnModel[] = [];\n\n                this.config.update(config => {\n                    visibleColumnsNames.forEach(name => {\n                        const col = config.columns.find(c => c.name === name)!;\n                        col.isHidden = false;\n\n                        newColumns.push(col);\n                    });\n                    config.columns.forEach(c => {\n                        if (!visibleColumnsNames.includes(c.name)) {\n                            c.isHidden = true;\n                            newColumns.push(c);\n                        }\n                    });\n\n                    return { ...config, columns: [...newColumns] };\n                });\n                this.updateColumns(newColumns);\n\n                const newVisibleColumnsOrder = newColumns.map(c => c.name);\n\n                if (previousVisibleColumnsOrder.length !== newVisibleColumnsOrder.length\n                    || !previousVisibleColumnsOrder.every((v, i) => v === newVisibleColumnsOrder[i])) {\n                    this.hasSearchChanged.set(true);\n                }\n            }\n        };\n    }\n\n    openSaveSearchModal(data?: SavedViewModel): void {\n        data = data || {\n            tableName: this.configModel().name,\n            request: this.searchRequest(),\n            columns: this.configModel().columns\n        };\n        this.modalService.open(SaveSearchComponent, { showCloseButton: false, data });\n    }\n\n    selectSavedView(item: DropdownItem): void {\n        const savedView = this.savedViewsStorage.getById(this.configModel().name, item.id)();\n        this.isSavedViewsDropdownOpen = false;\n\n        if (!!savedView) {\n            this.updateColumns(savedView.columns);\n            this.config.update(curr => {\n                curr.columns = savedView.columns;\n                return { ...curr };\n            });\n            this.activeSavedView.set(savedView);\n            this.searchRequestSubject.next({ ...savedView.request });\n        }\n    }\n\n    resetViewState(): void {\n        this.activeSavedView.set(undefined);\n        this.updateColumns(this.columnsBackup);\n        this.config.update(curr => {\n            curr.columns = this.columnsBackup;\n            return { ...curr };\n        });\n        this.searchRequestSubject.next({});\n    }\n\n    reload(): void {\n        this.shouldForceSearch = true;\n        this.searchRequestSubject.next({});\n    }\n\n    adaptCustomAction(btn: ButtonModel, item: T): ButtonModel {\n        const newBtn = new ButtonModel({\n            id: btn.id,\n            iconModel: btn.iconModel,\n            title: btn.title,\n            isIcon: signal(true),\n            isLink: signal(true),\n            size: signal('small'),\n            text: undefined,\n            colorStyle: btn.colorStyle,\n            isOutline: btn.isOutline\n        });\n        const defaultFunction = btn.clickFunction;\n        newBtn.clickFunction = (evt) => {\n            evt.event?.preventDefault();\n            evt.event?.stopPropagation();\n\n            if (!!defaultFunction) {\n                defaultFunction({ event: evt.event, data: item });\n            }\n        };\n\n        return newBtn;\n    }\n\n    private updateColumns(columns: BaseColumnModel[]): void {\n        this.columns.set(columns.filter(c => !c.isHidden).map(c => this.createColumnModel(c)));\n    }\n\n    private createColumnModel(data: BaseColumnModel): BaseColumnModel {\n        switch (data.type) {\n            case ColumnTypeEnum.Text:\n                return new TextColumnModel({ ...data });\n            case ColumnTypeEnum.Number:\n                return new NumberColumnModel({ ...data });\n            case ColumnTypeEnum.Boolean:\n                return new BooleanColumnModel({ ...data });\n            case ColumnTypeEnum.DateTime:\n            case ColumnTypeEnum.Date:\n            case ColumnTypeEnum.Time:\n                return new DateTimeColumnModel({ ...data });\n            case ColumnTypeEnum.Image:\n                return new ImageColumnModel({ ...data });\n            case ColumnTypeEnum.Guid:\n                return new GuidColumnModel({ ...data });\n            case ColumnTypeEnum.Masked:\n            case ColumnTypeEnum.Custom:\n            case ColumnTypeEnum.Currency:\n            default:\n                return new BaseColumnModel(data.type, { ...data });\n        }\n    }\n\n    private getColumnByName(columnName: string): BaseColumnModel {\n        const col = this.columns().find(c => c.name === columnName);\n\n        if (!col) {\n            throw Error('Tried accessing non existing column');\n        }\n\n        return col;\n    }\n\n    private setupPreSelected(): void {\n        this.configModel().preSelectedItems.forEach(item => {\n            const id = this.getRecordId(item);\n\n            if (this.data().find(d => this.getRecordId(d) === id) && !this.selectionModel().isSelected(item)) {\n                this.selectionModel().select(item);\n            }\n        });\n    }\n\n    private setupSearchResults(resp: SearchResponseModel<T>): void {\n        this.isSearching.set(false);\n        this.currentData.set(resp.records);\n        this.totalRecords.set(resp.totalRecords || 0);\n        this.currentPage.set(resp.pageIndex || 0);\n        this.pageSize.set(resp.pageSize || 0);\n        this.setupPreSelected();\n    }\n\n    private getActionButtons(currentFavoriteButtons: Signal<ButtonModel[]>, savedView: SavedViewModel): ButtonModel[] {\n        return [\n            new ButtonModel({\n                isIcon: signal(true),\n                isGhost: signal(true),\n                colorStyle: signal('primary'),\n                size: this.smallSizeSignal,\n                title: signal({ text: 'UpDevs.Table.SavedViews.MarkAsDefault', isTranslated: false }),\n                isActive: signal(savedView.isDefault || false),\n                iconModel: signal({ tablerIcon: 'heart' }),\n                clickFunction: (evt) => {\n                    const btnModel = (evt.data as DropdownActionClickedModel);\n                    const isButtonActive = btnModel.button.isActive();\n\n                    if (!isButtonActive) {\n                        this.savedViewsStorage.resetAllIsDefault(this.configModel().name);\n                    }\n\n                    savedView.isDefault = !isButtonActive;\n\n                    currentFavoriteButtons().forEach(cfb => cfb.isActive.set(false));\n                    btnModel.button.isActive.set(!isButtonActive);\n                    this.savedViewsStorage.saveView(savedView);\n                }\n            }),\n            new ButtonModel({\n                isIcon: signal(true),\n                isGhost: signal(true),\n                colorStyle: signal('secondary'),\n                size: this.smallSizeSignal,\n                title: signal({ text: 'UpDevs.Table.SavedViews.Duplicate', isTranslated: false }),\n                iconModel: signal({ tablerIcon: 'copy' }),\n                clickFunction: () => {\n                    const duplicateView = {\n                        ...savedView,\n                        id: Tools.Guid.generate(),\n                        name: savedView.name +\n                            ` (${this.textService.getText({ text: 'UpDevs.Table.SavedViews.DuplicateSuffix', isTranslated: false })})`\n                    };\n                    this.openSaveSearchModal(duplicateView);\n                }\n            }),\n            new ButtonModel({\n                isIcon: signal(true),\n                isGhost: signal(true),\n                colorStyle: signal('secondary'),\n                size: this.smallSizeSignal,\n                title: signal({ text: 'UpDevs.Table.SavedViews.Edit', isTranslated: false }),\n                iconModel: signal({ tablerIcon: 'edit' }),\n                clickFunction: () => this.openSaveSearchModal(savedView)\n            }),\n            new ButtonModel({\n                isIcon: signal(true),\n                isGhost: signal(true),\n                colorStyle: signal('danger'),\n                size: this.smallSizeSignal,\n                title: signal({ text: 'UpDevs.Table.SavedViews.Remove', isTranslated: false }),\n                iconModel: signal({ tablerIcon: 'x' }),\n                clickFunction: () => {\n                    const title = this.textService.getText(\n                        { text: 'UpDevs.Table.SavedViews.ConfirmRemove', isTranslated: false },\n                        { view: savedView.name }\n                    );\n                    this.modalAlertService.showConfirm({ text: title, isTranslated: true }).subscribe(isConfirmed => {\n                        if (isConfirmed) {\n                            this.savedViewsStorage.removeViews(this.configModel().name, savedView.id!);\n                        }\n                    });\n                }\n            })\n        ];\n    }\n\n    private getSavedViewOption(savedView: SavedViewModel): DropdownItem {\n        const actionButtons = this.getActionButtons(this.currentFavoriteButtons, savedView);\n        this.favoriteButtons.push(actionButtons.find(ab => ab.iconModel?.().tablerIcon === 'heart')!);\n\n        return {\n            id: savedView.id,\n            type: 'with-toolbar',\n            text: { text: savedView.name!, isTranslated: true },\n            toolbarType: 'spaced',\n            isActive: this.activeSavedView()?.id === savedView.id,\n            actionButtons\n        };\n    }\n}\n","<ng-container *transloco=\"let t; prefix: 'UpDevs.Table'\">\n    <div class=\"card\">\n        @if (!!configModel().title || !configModel().canSearch) {\n            <div class=\"card-header\">\n                @if (!!configModel().title) {\n                    <h3 class=\"card-title\">{{ textService.getText(configModel().title) }}</h3>\n                }\n                <ng-template [ngTemplateOutlet]=\"actionsTpl\"></ng-template>\n            </div>\n        }\n\n        @if (configModel().customHeaderActions.length > 0) {\n            <div class=\"card-body py-3 d-flex flex-column gap-2\">\n                <div class=\"ms-auto d-flex gap-2\">\n                    @for (btn of configModel().customHeaderActions; track btn) {\n                        <upd-button customClasses=\"gap-2\" [model]=\"btn\"></upd-button>\n                    }\n                </div>\n            </div>\n        }\n\n        @if (configModel().canSearch) {\n            <upd-search-section [actionsTpl]=\"!configModel().title ? actionsTpl : undefined\" [isSearching]=\"isSearching()\"\n                [(searchRequest)]=\"searchRequest\" [searchRequestSubject]=\"searchRequestSubject\" [config]=\"configModel()\"\n                [(hasChanges)]=\"hasSearchChanged\" [columns]=\"columns()\">\n            </upd-search-section>\n        }\n\n        <div [class.table-responsive]=\"configModel().isResponsive\">\n            <!-- TODO: implement pixel sized table -->\n            <table class=\"table card-table table-vcenter table-nowrap\" [class.fixed]=\"hasWidth\"\n                [class.pixel-sized]=\"isWidthInPixels\">\n                <thead [class.sticky-top]=\"configModel().hasStickyHeader\">\n                <tr>\n                    @if (configModel().hasCheckboxColumn) {\n                        <th class=\"checkbox-selector\">\n                            <upd-checkbox customClasses=\"m-0 ps-0\" (changed)=\"toggleAllSelection($event)\"\n                                [(isChecked)]=\"isMainCheckboxChecked\"\n                                [(isIndeterminate)]=\"isMainCheckboxIndeterminate\"></upd-checkbox>\n                        </th>\n                    }\n\n                    @for (col of columns(); track col) {\n                        <th [ngClass]=\"col.widthClass\" [style.width.px]=\"col.pixelsSize\">\n                            {{ textService.getText(col.title) }}\n                            @if (canSortColumn(col.name)) {\n                                <upd-icon [tablerIcon]=\"getSortingIcon(col.name)\" tablerIconWeight=\"bold\" colorClass=\"text-body-tertiary\"\n                                    [tablerIconSize]=\"16\" (click)=\"sortByColumn(col.name)\">\n                                </upd-icon>\n                            }\n                        </th>\n                    }\n\n                    @if (!!pendingWidthColClass) {\n                        <th [ngClass]=\"pendingWidthColClass\"></th>\n                    }\n\n                    @if (configModel().customActions.length > 0) {\n                        <th class=\"custom-actions\"></th>\n                    }\n                </tr>\n                </thead>\n\n                <tbody>\n                    @if (isSearching()) {\n                        <tr>\n                            <td [colSpan]=\"numberOfColumns\">\n                                <div class=\"empty\">\n                                    <h1 class=\"text-body-tertiary\">{{ t('Loading') }}...</h1>\n                                    <div class=\"progress progress-sm w-25\">\n                                        <div class=\"progress-bar progress-bar-indeterminate bg-body-tertiary\"></div>\n                                    </div>\n                                </div>\n                            </td>\n                        </tr>\n                    } @else {\n                        @for (record of data(); track record) {\n                            <tr>\n                                @if (configModel().hasCheckboxColumn) {\n                                    <td>\n                                        <upd-checkbox customClasses=\"m-0 ps-0\" (changed)=\"toggleItemSelection(record)\"\n                                            [isChecked]=\"selectionModel().isSelected(record)\"></upd-checkbox>\n                                    </td>\n                                }\n\n                                @for (col of columns(); track col) {\n                                    <td>\n                                        <ng-container updTableColumn [record]=\"record\" [config]=\"col\"></ng-container>\n                                    </td>\n                                }\n\n                                @if (!!pendingWidthColClass) {\n                                    <td></td>\n                                }\n\n                                @if (configModel().customActions.length > 0) {\n                                    <td style=\"overflow: unset\">\n                                        <div class=\"grow-left d-flex\">\n                                            @if (configModel().customActions.length > 1) {\n                                                <upd-button customClasses=\"ca-item\" [iconModel]=\"{tablerIcon:'dots'}\" [isIcon]=\"true\"\n                                                    [isLink]=\"true\" size=\"small\"></upd-button>\n\n                                                <div class=\"ca-dropdown-content rounded shadow-sm\">\n                                                    @for (btn of configModel().customActions; track btn) {\n                                                        <upd-button [model]=\"adaptCustomAction(btn, record)\"></upd-button>\n                                                    }\n                                                </div>\n                                            } @else {\n                                                <upd-button [model]=\"adaptCustomAction(configModel().customActions[0], record)\">\n                                                </upd-button>\n                                            }\n                                        </div>\n                                    </td>\n                                }\n                            </tr>\n                        } @empty {\n                            <tr>\n                                <td [colSpan]=\"numberOfColumns\">\n                                    <div class=\"empty\">\n                                        <p class=\"empty-title\">{{ t('NoRecordsFoundTitle') }}</p>\n                                        <p class=\"empty-subtitle text-secondary\">{{ t('NoRecordsFoundSubtitle') }}</p>\n                                    </div>\n                                </td>\n                            </tr>\n                        }\n                    }\n                </tbody>\n            </table>\n        </div>\n        <upd-paginator wrapperClasses=\"card-footer\" [shouldDisplayPreviousText]=\"false\" [shouldDisplayNextText]=\"false\"\n            [(pageSize)]=\"pageSize\" [shouldDisplayFirstText]=\"false\" [shouldDisplayLastText]=\"false\"\n            [(currentPage)]=\"currentPage\"\n            [totalRecords]=\"totalRecords()\" (changed)=\"onPageSettingsChanged()\">\n        </upd-paginator>\n    </div>\n\n    <ng-template #actionsTpl>\n        <div class=\"ms-auto d-flex gap-2\">\n            @if (!!activeSavedView()) {\n                @if (activeSavedView()!.isDefault) {\n                    <div class=\"ribbon ribbon-top ribbon-start\">\n                        <upd-icon tablerIcon=\"heart\" [tablerIconSize]=\"20\"></upd-icon>\n                    </div>\n                }\n                <div class=\"tag align-self-center py-3 text-primary bg-primary-lt border-primary\"\n                    updPopover=\"{{ t('CurrentSavedView') }}\"\n                    [updPopoverActAsTooltip]=\"true\">\n                    <upd-icon tablerIcon=\"list-details\" [tablerIconSize]=\"20\"></upd-icon>\n                    <span class=\"me-1\">{{ activeSavedView()!.name }}</span>\n                </div>\n            }\n            @if (hiddenColumns() > 0) {\n                <div class=\"tag align-self-center py-3 text-orange bg-orange-lt border-orange\"\n                    updPopover=\"{{ t('HiddenColumnsTooltip') }}\"\n                    [updPopoverActAsTooltip]=\"true\">\n                    <upd-icon tablerIcon=\"eye-off\" [tablerIconSize]=\"20\"></upd-icon>\n                    <span class=\"me-1\">{{ hiddenColumns() }}</span>\n                </div>\n            }\n            @if (!!activeSavedView() || hiddenColumns() > 0) {\n                <upd-button (clicked)=\"resetViewState()\" colorStyle=\"danger\" updPopover=\"{{ t('ResetView') }}\"\n                    [updPopoverActAsTooltip]=\"true\" [isIcon]=\"true\" [isOutline]=\"true\">\n                    <upd-icon tablerIcon=\"restore\" [tablerIconSize]=\"20\"></upd-icon>\n                </upd-button>\n            }\n            @if (configModel().canSaveViews) {\n                <upd-button customClasses=\"gap-2\" [isDisabled]=\"!hasSearchChanged()\" (clicked)=\"openSaveSearchModal()\"\n                    updPopover=\"{{ t('SaveCurrentView') }}\" [updPopoverActAsTooltip]=\"true\" [isIcon]=\"true\">\n                    <upd-icon tablerIcon=\"device-floppy\" [tablerIconSize]=\"20\"></upd-icon>\n                </upd-button>\n            }\n            @if (configModel().canManageColumns) {\n                <upd-button customClasses=\"gap-2\" (clicked)=\"openColumnsManagerModal()\">\n                    <upd-icon tablerIcon=\"columns\" [tablerIconSize]=\"20\"></upd-icon>\n                    {{ t('ColumnsManagerButton') }}\n                </upd-button>\n            }\n            @if (configModel().canSaveViews || configModel().canLoadSavedViews) {\n                <upd-button customClasses=\"gap-2\" (clicked)=\"isSavedViewsDropdownOpen = true\" #savedViewsBtn>\n                    <upd-icon tablerIcon=\"folders\" [tablerIconSize]=\"20\"></upd-icon>\n                    {{ t('SavedViews.ButtonTitle') }}\n                </upd-button>\n                <upd-dropdown wrapperClasses=\"overflow-x-hidden mt-1\" [isOpen]=\"isSavedViewsDropdownOpen\"\n                    [dropdownReference]=\"savedViewsRef()\" [items]=\"savedViewsOptions()\" [shouldCloseOnOutsideClick]=\"true\"\n                    (isOpenChange)=\"isSavedViewsDropdownOpen = $event\" [minWidth]=\"350\" (selectedItem)=\"selectSavedView($event)\">\n                    @if (savedViewsOptions().length < 1) {\n                        <span class=\"m-2\">{{ t('NoSavedViews') }}</span>\n                    }\n                </upd-dropdown>\n            }\n        </div>\n    </ng-template>\n</ng-container>\n"]}
|
|
@@ -207,6 +207,7 @@ class HeaderComponent extends BaseComponent {
|
|
|
207
207
|
this.currentLanguageKey.set(item.id);
|
|
208
208
|
this.translocoService.setActiveLang(item.id);
|
|
209
209
|
this.preferencesStorage.savePreferences({ ...this.currentPreferences(), currentLanguageCode: item.id });
|
|
210
|
+
this.layoutService.notifyUserChangedLanguage(item.id);
|
|
210
211
|
this.isLanguageSwitcherDropdownOpen = false;
|
|
211
212
|
}
|
|
212
213
|
selectLoggedUserMenuItem(item) {
|