cloud-ide-layout 0.0.1 → 1.0.1
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/README.md +466 -13
- package/esm2022/lib/cloud-ide-layout.routes.mjs +24 -10
- package/esm2022/lib/layout/console/console-wrapper/console-wrapper.component.mjs +6 -6
- package/esm2022/lib/layout/console/console.service.mjs +28 -0
- package/esm2022/lib/layout/footer/footer-wrapper/footer-wrapper.component.mjs +16 -8
- package/esm2022/lib/layout/footer/footer.service.mjs +28 -0
- package/esm2022/lib/layout/header/header-wrapper/header-wrapper.component.mjs +69 -18
- package/esm2022/lib/layout/header/header.service.mjs +17 -6
- package/esm2022/lib/layout/home/home-wrapper/home-wrapper.component.mjs +194 -7
- package/esm2022/lib/layout/layout/layout-wrapper/layout-wrapper.component.mjs +18 -9
- package/esm2022/lib/layout/request/request-wrapper/request-wrapper.component.mjs +54 -6
- package/esm2022/lib/layout/request/request.service.mjs +235 -0
- package/esm2022/lib/layout/request/tab-content/tab-content.component.mjs +84 -0
- package/esm2022/lib/layout/shared/shared-wrapper/shared-wrapper.component.mjs +32 -20
- package/esm2022/lib/layout/shared/shared.service.mjs +490 -14
- package/esm2022/lib/layout/sidebar/sidebar-wrapper/sidebar-wrapper.component.mjs +480 -15
- package/esm2022/lib/layout/sidebar/sidebar.service.mjs +20 -7
- package/esm2022/lib/layout/sidedrawer/cide-lyt-drawer-base.class.mjs +40 -0
- package/esm2022/lib/layout/sidedrawer/drawer-theme/drawer-theme.component.mjs +296 -0
- package/esm2022/lib/layout/sidedrawer/sidedrawer-notes/sidedrawer-notes.component.mjs +175 -0
- package/esm2022/lib/layout/sidedrawer/sidedrawer-notes/sidedrawer-notes.service.mjs +51 -0
- package/esm2022/lib/layout/sidedrawer/sidedrawer-wrapper/sidedrawer-wrapper.component.mjs +254 -9
- package/esm2022/lib/layout/sidedrawer/sidedrawer.service.mjs +70 -0
- package/esm2022/lib/services/app-state/app-state-helper.service.mjs +222 -0
- package/esm2022/lib/services/app-state/app-state.service.mjs +256 -0
- package/esm2022/lib/services/app-state/index.mjs +3 -0
- package/esm2022/lib/services/cache-manager/cache-manager.service.mjs +112 -0
- package/esm2022/lib/services/file-manager/file-manager.service.mjs +7 -7
- package/esm2022/lib/services/tab-state.service.mjs +128 -0
- package/esm2022/lib/services/theme/theme.service.mjs +151 -0
- package/esm2022/lib/services/user-status/user-status.service.mjs +135 -0
- package/esm2022/lib/utils/custom-route-reuse-strategy.mjs +61 -0
- package/esm2022/lib/utils/index.mjs +2 -0
- package/esm2022/public-api.mjs +7 -1
- package/fesm2022/cloud-ide-layout-cloud-ide-layout-DqL3A73V.mjs +2914 -0
- package/fesm2022/cloud-ide-layout-cloud-ide-layout-DqL3A73V.mjs.map +1 -0
- package/fesm2022/cloud-ide-layout-drawer-theme.component-xd8IG3WP.mjs +443 -0
- package/fesm2022/cloud-ide-layout-drawer-theme.component-xd8IG3WP.mjs.map +1 -0
- package/fesm2022/cloud-ide-layout-home-wrapper.component-DEdsEiaq.mjs +197 -0
- package/fesm2022/cloud-ide-layout-home-wrapper.component-DEdsEiaq.mjs.map +1 -0
- package/fesm2022/cloud-ide-layout-sidedrawer-notes.component-ds12wZbh.mjs +260 -0
- package/fesm2022/cloud-ide-layout-sidedrawer-notes.component-ds12wZbh.mjs.map +1 -0
- package/fesm2022/cloud-ide-layout.mjs +1 -261
- package/fesm2022/cloud-ide-layout.mjs.map +1 -1
- package/lib/cloud-ide-layout.routes.d.ts +1 -0
- package/lib/layout/console/console-wrapper/console-wrapper.component.d.ts +3 -3
- package/lib/layout/console/console.service.d.ts +9 -0
- package/lib/layout/footer/footer-wrapper/footer-wrapper.component.d.ts +7 -3
- package/lib/layout/footer/footer.service.d.ts +9 -0
- package/lib/layout/header/header-wrapper/header-wrapper.component.d.ts +17 -9
- package/lib/layout/header/header.service.d.ts +4 -3
- package/lib/layout/home/home-wrapper/home-wrapper.component.d.ts +90 -1
- package/lib/layout/request/request-wrapper/request-wrapper.component.d.ts +10 -1
- package/lib/layout/request/request.service.d.ts +60 -0
- package/lib/layout/request/tab-content/tab-content.component.d.ts +19 -0
- package/lib/layout/shared/shared-wrapper/shared-wrapper.component.d.ts +4 -5
- package/lib/layout/shared/shared.service.d.ts +104 -6
- package/lib/layout/sidebar/sidebar-wrapper/sidebar-wrapper.component.d.ts +135 -6
- package/lib/layout/sidebar/sidebar.service.d.ts +3 -2
- package/lib/layout/sidedrawer/cide-lyt-drawer-base.class.d.ts +16 -0
- package/lib/layout/sidedrawer/drawer-theme/drawer-theme.component.d.ts +71 -0
- package/lib/layout/sidedrawer/sidedrawer-notes/sidedrawer-notes.component.d.ts +48 -0
- package/lib/layout/sidedrawer/sidedrawer-notes/sidedrawer-notes.service.d.ts +13 -0
- package/lib/layout/sidedrawer/sidedrawer-wrapper/sidedrawer-wrapper.component.d.ts +28 -3
- package/lib/layout/sidedrawer/sidedrawer.service.d.ts +30 -0
- package/lib/services/app-state/app-state-helper.service.d.ts +150 -0
- package/lib/services/app-state/app-state.service.d.ts +85 -0
- package/lib/services/app-state/index.d.ts +3 -0
- package/lib/services/cache-manager/cache-manager.service.d.ts +64 -0
- package/lib/services/file-manager/file-manager.service.d.ts +0 -2
- package/lib/services/tab-state.service.d.ts +79 -0
- package/lib/services/theme/theme.service.d.ts +71 -0
- package/lib/services/user-status/user-status.service.d.ts +57 -0
- package/lib/utils/custom-route-reuse-strategy.d.ts +15 -0
- package/lib/utils/index.d.ts +1 -0
- package/package.json +2 -2
- package/public-api.d.ts +4 -0
- package/src/lib/assets/css/cide-lyt-style.scss +182 -0
- package/src/lib/assets/css/cide-lyt-variable.scss +119 -0
- package/fesm2022/cloud-ide-layout-home-wrapper.component-BV7ptL0Y.mjs +0 -14
- package/fesm2022/cloud-ide-layout-home-wrapper.component-BV7ptL0Y.mjs.map +0 -1
|
@@ -1,12 +1,60 @@
|
|
|
1
|
-
import { Component } from '@angular/core';
|
|
1
|
+
import { Component, ViewChildren } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
2
3
|
import { CideIconComponent } from 'cloud-ide-element';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "../request.service";
|
|
6
|
+
import * as i2 from "@angular/common";
|
|
4
7
|
export class CideLytRequestWrapperComponent {
|
|
5
|
-
|
|
6
|
-
|
|
8
|
+
constructor(requestService) {
|
|
9
|
+
this.requestService = requestService;
|
|
10
|
+
// Modern Signal-based access for better performance
|
|
11
|
+
this.requestItems = this.requestService.tabs;
|
|
12
|
+
}
|
|
13
|
+
ngAfterViewInit() {
|
|
14
|
+
// Apply entrance animation to initial items
|
|
15
|
+
this.applyAnimations();
|
|
16
|
+
// Listen for changes in request items and apply animations
|
|
17
|
+
this.requestItemElements.changes.subscribe({
|
|
18
|
+
next: () => {
|
|
19
|
+
this.applyAnimations();
|
|
20
|
+
}
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
// Apply animations to request items
|
|
24
|
+
applyAnimations() {
|
|
25
|
+
if (!this.requestItemElements)
|
|
26
|
+
return;
|
|
27
|
+
this.requestItemElements.forEach((itemEl) => {
|
|
28
|
+
const element = itemEl.nativeElement;
|
|
29
|
+
element.classList.remove('request-item-enter');
|
|
30
|
+
void element.offsetWidth; // Force reflow
|
|
31
|
+
element.classList.add('request-item-enter');
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
// Apply flicker effect to clicked item
|
|
35
|
+
applyFlickerEffect(event) {
|
|
36
|
+
const target = event.currentTarget;
|
|
37
|
+
if (target) {
|
|
38
|
+
// Remove any existing flicker class
|
|
39
|
+
target.classList.remove('request-item-flicker');
|
|
40
|
+
// Force reflow to ensure the class removal is processed
|
|
41
|
+
void target.offsetWidth;
|
|
42
|
+
// Add flicker class to trigger animation
|
|
43
|
+
target.classList.add('request-item-flicker');
|
|
44
|
+
// Remove the class after animation completes
|
|
45
|
+
setTimeout(() => {
|
|
46
|
+
target.classList.remove('request-item-flicker');
|
|
47
|
+
}, 400); // Match the animation duration
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: CideLytRequestWrapperComponent, deps: [{ token: i1.CideLytRequestService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
51
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.7", type: CideLytRequestWrapperComponent, isStandalone: true, selector: "cide-lyt-request-wrapper", viewQueries: [{ propertyName: "requestItemElements", predicate: ["requestItemEl"], descendants: true }], ngImport: i0, template: "<ng-container *ngIf=\"requestItems() as requestItems\">\n <div id=\"cide-lyt-request-wrapper\" class=\"cide-lyt-request tw-w-[inherit]\" [class.cide-lyt-request-wrapper-hide]=\"!requestItems.length\">\n <div class=\"request-content tw-flex tw-items-center tw-overflow-x-auto\">\n <ng-container *ngFor=\"let item of requestItems; let i = index\">\n <div #requestItemEl class=\"request-item\" (keydown.enter)=\"requestService.activateTab(item.id); applyFlickerEffect($event)\"\n [class.active]=\"item.active\" tabindex=\"0\" (click)=\"requestService.activateTab(item.id); applyFlickerEffect($event)\"\n [attr.data-tooltip]=\"item.title\">\n <span class=\"request-title\">{{ item.title }}</span>\n <button class=\"request-action close-action\" \n (click)=\"requestService.closeTab(item.id); $event.stopPropagation();\"\n (keydown.enter)=\"requestService.closeTab(item.id); $event.stopPropagation();\" \n tabindex=\"0\"\n data-tooltip=\"Close this tab\">\n <cide-ele-icon size=\"3xs\">close</cide-ele-icon>\n </button>\n </div>\n <!-- Only add divider between items -->\n <div class=\"request-divider\" *ngIf=\"i < requestItems.length - 1\"></div>\n </ng-container>\n </div>\n </div>\n</ng-container>", styles: [".cide-lyt-request{height:20px;background:linear-gradient(to right,#fff,#f9fafbf2);border-bottom:1px solid rgba(229,231,235,.8);box-shadow:0 2px 6px #0000000d,0 1px 1px #00000008;display:flex;align-items:center;padding:0 .5rem;position:relative;z-index:15;transition:all .2s cubic-bezier(.4,0,.2,1);will-change:transform;-webkit-user-select:none;user-select:none;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px)}.request-content{display:flex;align-items:center;height:100%;width:100%;position:relative;overflow:hidden}.request-item{position:relative;padding:8px 12px;margin:0 4px;border-radius:.375rem;display:flex;align-items:center;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);overflow:hidden;background-color:#fff9;box-shadow:0 1px 2px #00000005;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(229,231,235,.4)}.request-item:hover{background-color:#ffffffe6;transform:translateY(-1px);box-shadow:0 2px 5px #0000000d;border-color:#d1d5db99}.request-item:active{transform:translateY(0);box-shadow:0 1px 2px #00000008}.request-item.active{background:#eff6ffcc;border-color:#3b82f64d;box-shadow:0 2px 6px #3b82f61a,0 0 0 1px #3b82f626;position:relative}@keyframes shimmerGradient{0%{background-position:100% 50%}to{background-position:0% 50%}}.request-title{font-size:.875rem;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .2s ease}.request-item.active .request-title{color:#2563eb;font-weight:500;text-shadow:0 0 1px rgba(37,99,235,.1)}.request-action,.request-add-action{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background-color:transparent;transition:all .2s ease}.request-action:hover,.request-add-action:hover{background-color:#f3f4f6cc;transform:scale(1.1)}.request-action:active,.request-add-action:active{transform:scale(.95)}:host-context(.dark-mode) .cide-lyt-request{background:linear-gradient(to right,#0f172a,#0f172af2);border-bottom-color:#1e293be6;box-shadow:0 2px 6px #00000026,0 1px 1px #0000001a}:host-context(.dark-mode) .request-item{background-color:#1e293b99;border-color:#33415566;box-shadow:0 1px 2px #0000001a}:host-context(.dark-mode) .request-item:hover{background-color:#1e293bcc;border-color:#47556999;box-shadow:0 2px 5px #00000026}:host-context(.dark-mode) .request-title{color:#e2e8f0}:host-context(.dark-mode) .request-item:hover .request-title{color:#f8fafc}:host-context(.dark-mode) .request-item.active{background:#1e3a8a4d;border-color:#3b82f666;box-shadow:0 2px 6px #1e40af40,0 0 0 1px #3b82f633}:host-context(.dark-mode) .request-item.active .request-title{color:#60a5fa;text-shadow:0 0 2px rgba(96,165,250,.2)}:host-context(.dark-mode) .request-action:hover,:host-context(.dark-mode) .request-add-action:hover{background-color:#334155cc}.request-item:hover{transform:translateY(-.5px);box-shadow:0 1px 3px #00000008}.request-item:hover:before{opacity:1}.request-item.active{background:linear-gradient(to right,#eff6ffcc,#dbeafe99);box-shadow:0 1px 3px #3b82f626;transform:translateZ(0)}@keyframes glowEffect{0%{opacity:.6;box-shadow:0 1px 2px #3b82f61a}50%{opacity:1;box-shadow:0 1px 3px #3b82f64d}to{opacity:.6;box-shadow:0 1px 2px #3b82f61a}}.request-title{font-size:.7rem;color:#374151;margin-right:.5rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px;letter-spacing:.01em;transition:all .2s ease;position:relative}.request-item.active .request-title{color:#1e40af;font-weight:600;text-shadow:0 0 .5px rgba(37,99,235,.3);letter-spacing:.015em}.request-action{display:flex;align-items:center;justify-content:center;height:14px;width:14px;border-radius:3px;transition:all .2s ease;cursor:pointer;color:#9ca3af;border:none;background:transparent;padding:0;outline:none;position:relative;overflow:hidden;transform:translateZ(0)}.request-action:hover{background-color:#3b82f614;color:#3b82f6;transform:translateY(-.5px) scale(1.05);box-shadow:0 1px 2px #0000000d}.request-action:active{transform:translateY(.5px) scale(.97);transition:all .1s ease}.request-action:focus-visible{outline:1px solid #3b82f6;outline-offset:1px;box-shadow:0 0 0 2px #3b82f61a}.close-action:hover{background-color:#ef444414;color:#ef4444}.close-action:focus-visible{outline-color:#ef4444;box-shadow:0 0 0 2px #ef44441a}.request-divider{width:1px;height:18px;background:linear-gradient(to bottom,#d1d5db1a,#d1d5db80,#d1d5db1a);margin:0 4px}:host-context(.dark-mode) .request-divider{background:linear-gradient(to bottom,#4755691a,#47556980,#4755691a)}.request-divider:before{content:\"\";position:absolute;top:0;bottom:0;left:-1px;width:3px;background:radial-gradient(ellipse at center,#ffffff80,#fff0 70%);opacity:0;transition:opacity .3s ease}.request-content:hover .request-divider:before{opacity:.7}.request-add-action{display:flex;align-items:center;justify-content:center;height:16px;width:16px;border-radius:3px;transition:all .2s cubic-bezier(.4,0,.2,1);cursor:pointer;color:#6b7280;background-color:transparent;border:none;padding:0;outline:none;position:relative;overflow:hidden}.request-add-action:hover{background-color:#3b82f614;color:#3b82f6;transform:translateY(-.5px) scale(1.05);box-shadow:0 1px 3px #3b82f626}.request-add-action:active{transform:translateY(.5px) scale(.97);transition:all .1s ease}.request-add-action:focus-visible{outline:1px solid #3b82f6;outline-offset:1px;box-shadow:0 0 0 2px #3b82f61a}.request-add-action:after{content:\"\";position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle,#3b82f64d,#3b82f600 70%);opacity:0;transform:scale(0);transition:transform .4s ease,opacity .3s ease}.request-add-action:active:after{opacity:1;transform:scale(3);transition:transform .1s ease,opacity .1s ease}@keyframes subtlePulse{0%{box-shadow:0 0 #3b82f600;transform:scale(1)}50%{box-shadow:0 0 0 3px #3b82f626;transform:scale(1.05)}to{box-shadow:0 0 #3b82f600;transform:scale(1)}}.request-add-action-pulse{animation:subtlePulse 2s cubic-bezier(.4,0,.6,1) infinite}:host-context(.dark-mode) .cide-lyt-request{background:linear-gradient(to right,#111827f2,#1f2937e6);border-bottom:1px solid rgba(55,65,81,.5)}:host-context(.dark-mode) .request-title{color:#e5e7eb}:host-context(.dark-mode) .request-item.active{background:linear-gradient(to right,#1e3a8a26,#2563eb1a)}:host-context(.dark-mode) .request-item.active .request-title{color:#93c5fd}:host-context(.dark-mode) .request-action,:host-context(.dark-mode) .request-add-action{color:#9ca3af}:host-context(.dark-mode) .request-divider{background:linear-gradient(to bottom,#4b55634d,#6b728080,#4b55634d)}@keyframes slideIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}@keyframes slideOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-5px)}}@keyframes flickerEffect{0%{opacity:1;transform:scale(1);box-shadow:0 1px 2px #00000005}25%{opacity:.7;transform:scale(.98);box-shadow:0 2px 8px #3b82f64d}50%{opacity:.9;transform:scale(1.02);box-shadow:0 4px 12px #3b82f666}75%{opacity:.8;transform:scale(.99);box-shadow:0 2px 6px #3b82f633}to{opacity:1;transform:scale(1);box-shadow:0 1px 2px #00000005}}@keyframes flickerEffectDark{0%{opacity:1;transform:scale(1);box-shadow:0 1px 2px #0000001a}25%{opacity:.7;transform:scale(.98);box-shadow:0 2px 8px #60a5fa4d}50%{opacity:.9;transform:scale(1.02);box-shadow:0 4px 12px #60a5fa66}75%{opacity:.8;transform:scale(.99);box-shadow:0 2px 6px #60a5fa33}to{opacity:1;transform:scale(1);box-shadow:0 1px 2px #0000001a}}.request-item-enter{animation:slideIn .2s cubic-bezier(.4,0,.2,1)}.request-item-exit{animation:slideOut .2s cubic-bezier(.4,0,.2,1)}.request-item-flicker{animation:flickerEffect .4s cubic-bezier(.4,0,.2,1)}:host-context(.dark-mode) .request-item-flicker{animation:flickerEffectDark .4s cubic-bezier(.4,0,.2,1)}@media (max-width: 640px){.request-title{max-width:80px}}.request-item:focus,.request-action:focus,.request-add-action:focus{outline:none;box-shadow:0 0 0 2px #3b82f64d}:host-context(.dark-mode) .request-item:focus,:host-context(.dark-mode) .request-action:focus,:host-context(.dark-mode) .request-add-action:focus{box-shadow:0 0 0 2px #60a5fa66}.cide-lyt-request:hover{box-shadow:0 3px 8px #00000012,0 1px 2px #0000000d;transform:translateY(-1px)}.request-content:empty .request-add-action{animation:pulseAttention 2s infinite}@keyframes pulseAttention{0%{box-shadow:0 0 #3b82f666;transform:scale(1)}70%{box-shadow:0 0 0 8px #3b82f600;transform:scale(1.05)}to{box-shadow:0 0 #3b82f600;transform:scale(1)}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: CideIconComponent, selector: "cide-ele-icon", inputs: ["size", "type", "toolTip"] }] }); }
|
|
7
52
|
}
|
|
8
53
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: CideLytRequestWrapperComponent, decorators: [{
|
|
9
54
|
type: Component,
|
|
10
|
-
args: [{ selector: 'cide-lyt-request-wrapper', standalone: true, imports: [CideIconComponent], template: "<div\r\n class=\"cide-request tw-w-[calc(100%-13rem-1.5rem)] tw-left-52 tw-right-6 tw-absolute tw-items-center tw-h-6 tw-border-b-gray-200 tw-border-solid tw-border-b tw-select-none tw-z-[100] tw-top-9 tw-justify-between tw-flex\">\r\n <div class=\"tw-h-full tw-items-center tw-inline-flex tw-text-xs tw-px-2 tw-text-gray-600\">\r\n Item master \r\n <cide-ele-icon class=\"tw-ml-3 tw-mt-[0.1rem]\" size=\"3xs\" type=\"box\">close</cide-ele-icon>\r\n <span class=\"tw-border-gray-100 tw-border-solid tw-border-r-2 tw-my-1 tw-h-4/5 tw-mx-2\"></span>\r\n <cide-ele-icon size=\"2xs\" type=\"box\">add</cide-ele-icon>\r\n </div>\r\n</div>" }]
|
|
11
|
-
}] }
|
|
12
|
-
|
|
55
|
+
args: [{ selector: 'cide-lyt-request-wrapper', standalone: true, imports: [CommonModule, CideIconComponent], template: "<ng-container *ngIf=\"requestItems() as requestItems\">\n <div id=\"cide-lyt-request-wrapper\" class=\"cide-lyt-request tw-w-[inherit]\" [class.cide-lyt-request-wrapper-hide]=\"!requestItems.length\">\n <div class=\"request-content tw-flex tw-items-center tw-overflow-x-auto\">\n <ng-container *ngFor=\"let item of requestItems; let i = index\">\n <div #requestItemEl class=\"request-item\" (keydown.enter)=\"requestService.activateTab(item.id); applyFlickerEffect($event)\"\n [class.active]=\"item.active\" tabindex=\"0\" (click)=\"requestService.activateTab(item.id); applyFlickerEffect($event)\"\n [attr.data-tooltip]=\"item.title\">\n <span class=\"request-title\">{{ item.title }}</span>\n <button class=\"request-action close-action\" \n (click)=\"requestService.closeTab(item.id); $event.stopPropagation();\"\n (keydown.enter)=\"requestService.closeTab(item.id); $event.stopPropagation();\" \n tabindex=\"0\"\n data-tooltip=\"Close this tab\">\n <cide-ele-icon size=\"3xs\">close</cide-ele-icon>\n </button>\n </div>\n <!-- Only add divider between items -->\n <div class=\"request-divider\" *ngIf=\"i < requestItems.length - 1\"></div>\n </ng-container>\n </div>\n </div>\n</ng-container>", styles: [".cide-lyt-request{height:20px;background:linear-gradient(to right,#fff,#f9fafbf2);border-bottom:1px solid rgba(229,231,235,.8);box-shadow:0 2px 6px #0000000d,0 1px 1px #00000008;display:flex;align-items:center;padding:0 .5rem;position:relative;z-index:15;transition:all .2s cubic-bezier(.4,0,.2,1);will-change:transform;-webkit-user-select:none;user-select:none;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px)}.request-content{display:flex;align-items:center;height:100%;width:100%;position:relative;overflow:hidden}.request-item{position:relative;padding:8px 12px;margin:0 4px;border-radius:.375rem;display:flex;align-items:center;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);overflow:hidden;background-color:#fff9;box-shadow:0 1px 2px #00000005;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(229,231,235,.4)}.request-item:hover{background-color:#ffffffe6;transform:translateY(-1px);box-shadow:0 2px 5px #0000000d;border-color:#d1d5db99}.request-item:active{transform:translateY(0);box-shadow:0 1px 2px #00000008}.request-item.active{background:#eff6ffcc;border-color:#3b82f64d;box-shadow:0 2px 6px #3b82f61a,0 0 0 1px #3b82f626;position:relative}@keyframes shimmerGradient{0%{background-position:100% 50%}to{background-position:0% 50%}}.request-title{font-size:.875rem;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .2s ease}.request-item.active .request-title{color:#2563eb;font-weight:500;text-shadow:0 0 1px rgba(37,99,235,.1)}.request-action,.request-add-action{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background-color:transparent;transition:all .2s ease}.request-action:hover,.request-add-action:hover{background-color:#f3f4f6cc;transform:scale(1.1)}.request-action:active,.request-add-action:active{transform:scale(.95)}:host-context(.dark-mode) .cide-lyt-request{background:linear-gradient(to right,#0f172a,#0f172af2);border-bottom-color:#1e293be6;box-shadow:0 2px 6px #00000026,0 1px 1px #0000001a}:host-context(.dark-mode) .request-item{background-color:#1e293b99;border-color:#33415566;box-shadow:0 1px 2px #0000001a}:host-context(.dark-mode) .request-item:hover{background-color:#1e293bcc;border-color:#47556999;box-shadow:0 2px 5px #00000026}:host-context(.dark-mode) .request-title{color:#e2e8f0}:host-context(.dark-mode) .request-item:hover .request-title{color:#f8fafc}:host-context(.dark-mode) .request-item.active{background:#1e3a8a4d;border-color:#3b82f666;box-shadow:0 2px 6px #1e40af40,0 0 0 1px #3b82f633}:host-context(.dark-mode) .request-item.active .request-title{color:#60a5fa;text-shadow:0 0 2px rgba(96,165,250,.2)}:host-context(.dark-mode) .request-action:hover,:host-context(.dark-mode) .request-add-action:hover{background-color:#334155cc}.request-item:hover{transform:translateY(-.5px);box-shadow:0 1px 3px #00000008}.request-item:hover:before{opacity:1}.request-item.active{background:linear-gradient(to right,#eff6ffcc,#dbeafe99);box-shadow:0 1px 3px #3b82f626;transform:translateZ(0)}@keyframes glowEffect{0%{opacity:.6;box-shadow:0 1px 2px #3b82f61a}50%{opacity:1;box-shadow:0 1px 3px #3b82f64d}to{opacity:.6;box-shadow:0 1px 2px #3b82f61a}}.request-title{font-size:.7rem;color:#374151;margin-right:.5rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px;letter-spacing:.01em;transition:all .2s ease;position:relative}.request-item.active .request-title{color:#1e40af;font-weight:600;text-shadow:0 0 .5px rgba(37,99,235,.3);letter-spacing:.015em}.request-action{display:flex;align-items:center;justify-content:center;height:14px;width:14px;border-radius:3px;transition:all .2s ease;cursor:pointer;color:#9ca3af;border:none;background:transparent;padding:0;outline:none;position:relative;overflow:hidden;transform:translateZ(0)}.request-action:hover{background-color:#3b82f614;color:#3b82f6;transform:translateY(-.5px) scale(1.05);box-shadow:0 1px 2px #0000000d}.request-action:active{transform:translateY(.5px) scale(.97);transition:all .1s ease}.request-action:focus-visible{outline:1px solid #3b82f6;outline-offset:1px;box-shadow:0 0 0 2px #3b82f61a}.close-action:hover{background-color:#ef444414;color:#ef4444}.close-action:focus-visible{outline-color:#ef4444;box-shadow:0 0 0 2px #ef44441a}.request-divider{width:1px;height:18px;background:linear-gradient(to bottom,#d1d5db1a,#d1d5db80,#d1d5db1a);margin:0 4px}:host-context(.dark-mode) .request-divider{background:linear-gradient(to bottom,#4755691a,#47556980,#4755691a)}.request-divider:before{content:\"\";position:absolute;top:0;bottom:0;left:-1px;width:3px;background:radial-gradient(ellipse at center,#ffffff80,#fff0 70%);opacity:0;transition:opacity .3s ease}.request-content:hover .request-divider:before{opacity:.7}.request-add-action{display:flex;align-items:center;justify-content:center;height:16px;width:16px;border-radius:3px;transition:all .2s cubic-bezier(.4,0,.2,1);cursor:pointer;color:#6b7280;background-color:transparent;border:none;padding:0;outline:none;position:relative;overflow:hidden}.request-add-action:hover{background-color:#3b82f614;color:#3b82f6;transform:translateY(-.5px) scale(1.05);box-shadow:0 1px 3px #3b82f626}.request-add-action:active{transform:translateY(.5px) scale(.97);transition:all .1s ease}.request-add-action:focus-visible{outline:1px solid #3b82f6;outline-offset:1px;box-shadow:0 0 0 2px #3b82f61a}.request-add-action:after{content:\"\";position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle,#3b82f64d,#3b82f600 70%);opacity:0;transform:scale(0);transition:transform .4s ease,opacity .3s ease}.request-add-action:active:after{opacity:1;transform:scale(3);transition:transform .1s ease,opacity .1s ease}@keyframes subtlePulse{0%{box-shadow:0 0 #3b82f600;transform:scale(1)}50%{box-shadow:0 0 0 3px #3b82f626;transform:scale(1.05)}to{box-shadow:0 0 #3b82f600;transform:scale(1)}}.request-add-action-pulse{animation:subtlePulse 2s cubic-bezier(.4,0,.6,1) infinite}:host-context(.dark-mode) .cide-lyt-request{background:linear-gradient(to right,#111827f2,#1f2937e6);border-bottom:1px solid rgba(55,65,81,.5)}:host-context(.dark-mode) .request-title{color:#e5e7eb}:host-context(.dark-mode) .request-item.active{background:linear-gradient(to right,#1e3a8a26,#2563eb1a)}:host-context(.dark-mode) .request-item.active .request-title{color:#93c5fd}:host-context(.dark-mode) .request-action,:host-context(.dark-mode) .request-add-action{color:#9ca3af}:host-context(.dark-mode) .request-divider{background:linear-gradient(to bottom,#4b55634d,#6b728080,#4b55634d)}@keyframes slideIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}@keyframes slideOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-5px)}}@keyframes flickerEffect{0%{opacity:1;transform:scale(1);box-shadow:0 1px 2px #00000005}25%{opacity:.7;transform:scale(.98);box-shadow:0 2px 8px #3b82f64d}50%{opacity:.9;transform:scale(1.02);box-shadow:0 4px 12px #3b82f666}75%{opacity:.8;transform:scale(.99);box-shadow:0 2px 6px #3b82f633}to{opacity:1;transform:scale(1);box-shadow:0 1px 2px #00000005}}@keyframes flickerEffectDark{0%{opacity:1;transform:scale(1);box-shadow:0 1px 2px #0000001a}25%{opacity:.7;transform:scale(.98);box-shadow:0 2px 8px #60a5fa4d}50%{opacity:.9;transform:scale(1.02);box-shadow:0 4px 12px #60a5fa66}75%{opacity:.8;transform:scale(.99);box-shadow:0 2px 6px #60a5fa33}to{opacity:1;transform:scale(1);box-shadow:0 1px 2px #0000001a}}.request-item-enter{animation:slideIn .2s cubic-bezier(.4,0,.2,1)}.request-item-exit{animation:slideOut .2s cubic-bezier(.4,0,.2,1)}.request-item-flicker{animation:flickerEffect .4s cubic-bezier(.4,0,.2,1)}:host-context(.dark-mode) .request-item-flicker{animation:flickerEffectDark .4s cubic-bezier(.4,0,.2,1)}@media (max-width: 640px){.request-title{max-width:80px}}.request-item:focus,.request-action:focus,.request-add-action:focus{outline:none;box-shadow:0 0 0 2px #3b82f64d}:host-context(.dark-mode) .request-item:focus,:host-context(.dark-mode) .request-action:focus,:host-context(.dark-mode) .request-add-action:focus{box-shadow:0 0 0 2px #60a5fa66}.cide-lyt-request:hover{box-shadow:0 3px 8px #00000012,0 1px 2px #0000000d;transform:translateY(-1px)}.request-content:empty .request-add-action{animation:pulseAttention 2s infinite}@keyframes pulseAttention{0%{box-shadow:0 0 #3b82f666;transform:scale(1)}70%{box-shadow:0 0 0 8px #3b82f600;transform:scale(1.05)}to{box-shadow:0 0 #3b82f600;transform:scale(1)}}\n"] }]
|
|
56
|
+
}], ctorParameters: () => [{ type: i1.CideLytRequestService }], propDecorators: { requestItemElements: [{
|
|
57
|
+
type: ViewChildren,
|
|
58
|
+
args: ['requestItemEl']
|
|
59
|
+
}] } });
|
|
60
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVxdWVzdC13cmFwcGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Nsb3VkLWlkZS1sYXlvdXQvc3JjL2xpYi9sYXlvdXQvcmVxdWVzdC9yZXF1ZXN0LXdyYXBwZXIvcmVxdWVzdC13cmFwcGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Nsb3VkLWlkZS1sYXlvdXQvc3JjL2xpYi9sYXlvdXQvcmVxdWVzdC9yZXF1ZXN0LXdyYXBwZXIvcmVxdWVzdC13cmFwcGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWMsWUFBWSxFQUE0QixNQUFNLGVBQWUsQ0FBQztBQUM5RixPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7Ozs7QUFVdEQsTUFBTSxPQUFPLDhCQUE4QjtJQU16QyxZQUNTLGNBQXFDO1FBQXJDLG1CQUFjLEdBQWQsY0FBYyxDQUF1QjtRQUo5QyxvREFBb0Q7UUFDN0MsaUJBQVksR0FBRyxJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQztJQUk1QyxDQUFDO0lBRUosZUFBZTtRQUNiLDRDQUE0QztRQUM1QyxJQUFJLENBQUMsZUFBZSxFQUFFLENBQUM7UUFFdkIsMkRBQTJEO1FBQzNELElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDO1lBQ3pDLElBQUksRUFBRSxHQUFHLEVBQUU7Z0JBQ1QsSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFDO1lBQ3pCLENBQUM7U0FDRixDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsb0NBQW9DO0lBQzVCLGVBQWU7UUFDckIsSUFBSSxDQUFDLElBQUksQ0FBQyxtQkFBbUI7WUFBRSxPQUFPO1FBRXRDLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxPQUFPLENBQUMsQ0FBQyxNQUFrQixFQUFFLEVBQUU7WUFDdEQsTUFBTSxPQUFPLEdBQUcsTUFBTSxDQUFDLGFBQWEsQ0FBQztZQUNyQyxPQUFPLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO1lBQy9DLEtBQUssT0FBTyxDQUFDLFdBQVcsQ0FBQyxDQUFDLGVBQWU7WUFDekMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsb0JBQW9CLENBQUMsQ0FBQztRQUM5QyxDQUFDLENBQUMsQ0FBQztJQUNMLENBQUM7SUFFRCx1Q0FBdUM7SUFDdkMsa0JBQWtCLENBQUMsS0FBWTtRQUM3QixNQUFNLE1BQU0sR0FBRyxLQUFLLENBQUMsYUFBNEIsQ0FBQztRQUNsRCxJQUFJLE1BQU0sRUFBRSxDQUFDO1lBQ1gsb0NBQW9DO1lBQ3BDLE1BQU0sQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLHNCQUFzQixDQUFDLENBQUM7WUFFaEQsd0RBQXdEO1lBQ3hELEtBQUssTUFBTSxDQUFDLFdBQVcsQ0FBQztZQUV4Qix5Q0FBeUM7WUFDekMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsc0JBQXNCLENBQUMsQ0FBQztZQUU3Qyw2Q0FBNkM7WUFDN0MsVUFBVSxDQUFDLEdBQUcsRUFBRTtnQkFDZCxNQUFNLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxzQkFBc0IsQ0FBQyxDQUFDO1lBQ2xELENBQUMsRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDLCtCQUErQjtRQUMxQyxDQUFDO0lBQ0gsQ0FBQzs4R0FwRFUsOEJBQThCO2tHQUE5Qiw4QkFBOEIsNkxDWjNDLHMrQ0FxQmUsODVRRGJILFlBQVksZ1FBQUUsaUJBQWlCOzsyRkFJOUIsOEJBQThCO2tCQVAxQyxTQUFTOytCQUNFLDBCQUEwQixjQUN4QixJQUFJLFdBQ1AsQ0FBQyxZQUFZLEVBQUUsaUJBQWlCLENBQUM7MEZBS1gsbUJBQW1CO3NCQUFqRCxZQUFZO3VCQUFDLGVBQWUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEVsZW1lbnRSZWYsIFZpZXdDaGlsZHJlbiwgUXVlcnlMaXN0LCBBZnRlclZpZXdJbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ2lkZUljb25Db21wb25lbnQgfSBmcm9tICdjbG91ZC1pZGUtZWxlbWVudCc7XG5pbXBvcnQgeyBDaWRlTHl0UmVxdWVzdFNlcnZpY2UgfSBmcm9tICcuLi9yZXF1ZXN0LnNlcnZpY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdjaWRlLWx5dC1yZXF1ZXN0LXdyYXBwZXInLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBDaWRlSWNvbkNvbXBvbmVudF0sXG4gIHRlbXBsYXRlVXJsOiAnLi9yZXF1ZXN0LXdyYXBwZXIuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybDogJy4vcmVxdWVzdC13cmFwcGVyLmNvbXBvbmVudC5jc3MnXG59KVxuZXhwb3J0IGNsYXNzIENpZGVMeXRSZXF1ZXN0V3JhcHBlckNvbXBvbmVudCBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXQge1xuICBAVmlld0NoaWxkcmVuKCdyZXF1ZXN0SXRlbUVsJykgcmVxdWVzdEl0ZW1FbGVtZW50cyE6IFF1ZXJ5TGlzdDxFbGVtZW50UmVmPjtcbiAgXG4gIC8vIE1vZGVybiBTaWduYWwtYmFzZWQgYWNjZXNzIGZvciBiZXR0ZXIgcGVyZm9ybWFuY2VcbiAgcHVibGljIHJlcXVlc3RJdGVtcyA9IHRoaXMucmVxdWVzdFNlcnZpY2UudGFicztcbiAgXG4gIGNvbnN0cnVjdG9yKFxuICAgIHB1YmxpYyByZXF1ZXN0U2VydmljZTogQ2lkZUx5dFJlcXVlc3RTZXJ2aWNlXG4gICkge31cblxuICBuZ0FmdGVyVmlld0luaXQoKSB7XG4gICAgLy8gQXBwbHkgZW50cmFuY2UgYW5pbWF0aW9uIHRvIGluaXRpYWwgaXRlbXNcbiAgICB0aGlzLmFwcGx5QW5pbWF0aW9ucygpO1xuICAgIFxuICAgIC8vIExpc3RlbiBmb3IgY2hhbmdlcyBpbiByZXF1ZXN0IGl0ZW1zIGFuZCBhcHBseSBhbmltYXRpb25zXG4gICAgdGhpcy5yZXF1ZXN0SXRlbUVsZW1lbnRzLmNoYW5nZXMuc3Vic2NyaWJlKHtcbiAgICAgIG5leHQ6ICgpID0+IHtcbiAgICAgICAgdGhpcy5hcHBseUFuaW1hdGlvbnMoKTtcbiAgICAgIH1cbiAgICB9KTtcbiAgfVxuXG4gIC8vIEFwcGx5IGFuaW1hdGlvbnMgdG8gcmVxdWVzdCBpdGVtc1xuICBwcml2YXRlIGFwcGx5QW5pbWF0aW9ucygpIHtcbiAgICBpZiAoIXRoaXMucmVxdWVzdEl0ZW1FbGVtZW50cykgcmV0dXJuO1xuICAgIFxuICAgIHRoaXMucmVxdWVzdEl0ZW1FbGVtZW50cy5mb3JFYWNoKChpdGVtRWw6IEVsZW1lbnRSZWYpID0+IHtcbiAgICAgIGNvbnN0IGVsZW1lbnQgPSBpdGVtRWwubmF0aXZlRWxlbWVudDtcbiAgICAgIGVsZW1lbnQuY2xhc3NMaXN0LnJlbW92ZSgncmVxdWVzdC1pdGVtLWVudGVyJyk7XG4gICAgICB2b2lkIGVsZW1lbnQub2Zmc2V0V2lkdGg7IC8vIEZvcmNlIHJlZmxvd1xuICAgICAgZWxlbWVudC5jbGFzc0xpc3QuYWRkKCdyZXF1ZXN0LWl0ZW0tZW50ZXInKTtcbiAgICB9KTtcbiAgfVxuXG4gIC8vIEFwcGx5IGZsaWNrZXIgZWZmZWN0IHRvIGNsaWNrZWQgaXRlbVxuICBhcHBseUZsaWNrZXJFZmZlY3QoZXZlbnQ6IEV2ZW50KTogdm9pZCB7XG4gICAgY29uc3QgdGFyZ2V0ID0gZXZlbnQuY3VycmVudFRhcmdldCBhcyBIVE1MRWxlbWVudDtcbiAgICBpZiAodGFyZ2V0KSB7XG4gICAgICAvLyBSZW1vdmUgYW55IGV4aXN0aW5nIGZsaWNrZXIgY2xhc3NcbiAgICAgIHRhcmdldC5jbGFzc0xpc3QucmVtb3ZlKCdyZXF1ZXN0LWl0ZW0tZmxpY2tlcicpO1xuICAgICAgXG4gICAgICAvLyBGb3JjZSByZWZsb3cgdG8gZW5zdXJlIHRoZSBjbGFzcyByZW1vdmFsIGlzIHByb2Nlc3NlZFxuICAgICAgdm9pZCB0YXJnZXQub2Zmc2V0V2lkdGg7XG4gICAgICBcbiAgICAgIC8vIEFkZCBmbGlja2VyIGNsYXNzIHRvIHRyaWdnZXIgYW5pbWF0aW9uXG4gICAgICB0YXJnZXQuY2xhc3NMaXN0LmFkZCgncmVxdWVzdC1pdGVtLWZsaWNrZXInKTtcbiAgICAgIFxuICAgICAgLy8gUmVtb3ZlIHRoZSBjbGFzcyBhZnRlciBhbmltYXRpb24gY29tcGxldGVzXG4gICAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgICAgdGFyZ2V0LmNsYXNzTGlzdC5yZW1vdmUoJ3JlcXVlc3QtaXRlbS1mbGlja2VyJyk7XG4gICAgICB9LCA0MDApOyAvLyBNYXRjaCB0aGUgYW5pbWF0aW9uIGR1cmF0aW9uXG4gICAgfVxuICB9XG59XG4iLCI8bmctY29udGFpbmVyICpuZ0lmPVwicmVxdWVzdEl0ZW1zKCkgYXMgcmVxdWVzdEl0ZW1zXCI+XG4gICAgPGRpdiBpZD1cImNpZGUtbHl0LXJlcXVlc3Qtd3JhcHBlclwiIGNsYXNzPVwiY2lkZS1seXQtcmVxdWVzdCB0dy13LVtpbmhlcml0XVwiIFtjbGFzcy5jaWRlLWx5dC1yZXF1ZXN0LXdyYXBwZXItaGlkZV09XCIhcmVxdWVzdEl0ZW1zLmxlbmd0aFwiPlxuICAgICAgICA8ZGl2IGNsYXNzPVwicmVxdWVzdC1jb250ZW50IHR3LWZsZXggdHctaXRlbXMtY2VudGVyIHR3LW92ZXJmbG93LXgtYXV0b1wiPlxuICAgICAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdGb3I9XCJsZXQgaXRlbSBvZiByZXF1ZXN0SXRlbXM7IGxldCBpID0gaW5kZXhcIj5cbiAgICAgICAgICAgICAgICA8ZGl2ICNyZXF1ZXN0SXRlbUVsIGNsYXNzPVwicmVxdWVzdC1pdGVtXCIgKGtleWRvd24uZW50ZXIpPVwicmVxdWVzdFNlcnZpY2UuYWN0aXZhdGVUYWIoaXRlbS5pZCk7IGFwcGx5RmxpY2tlckVmZmVjdCgkZXZlbnQpXCJcbiAgICAgICAgICAgICAgICAgICAgW2NsYXNzLmFjdGl2ZV09XCJpdGVtLmFjdGl2ZVwiIHRhYmluZGV4PVwiMFwiIChjbGljayk9XCJyZXF1ZXN0U2VydmljZS5hY3RpdmF0ZVRhYihpdGVtLmlkKTsgYXBwbHlGbGlja2VyRWZmZWN0KCRldmVudClcIlxuICAgICAgICAgICAgICAgICAgICBbYXR0ci5kYXRhLXRvb2x0aXBdPVwiaXRlbS50aXRsZVwiPlxuICAgICAgICAgICAgICAgICAgICA8c3BhbiBjbGFzcz1cInJlcXVlc3QtdGl0bGVcIj57eyBpdGVtLnRpdGxlIH19PC9zcGFuPlxuICAgICAgICAgICAgICAgICAgICA8YnV0dG9uIGNsYXNzPVwicmVxdWVzdC1hY3Rpb24gY2xvc2UtYWN0aW9uXCIgXG4gICAgICAgICAgICAgICAgICAgICAgICAoY2xpY2spPVwicmVxdWVzdFNlcnZpY2UuY2xvc2VUYWIoaXRlbS5pZCk7ICRldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcIlxuICAgICAgICAgICAgICAgICAgICAgICAgKGtleWRvd24uZW50ZXIpPVwicmVxdWVzdFNlcnZpY2UuY2xvc2VUYWIoaXRlbS5pZCk7ICRldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcIiBcbiAgICAgICAgICAgICAgICAgICAgICAgIHRhYmluZGV4PVwiMFwiXG4gICAgICAgICAgICAgICAgICAgICAgICBkYXRhLXRvb2x0aXA9XCJDbG9zZSB0aGlzIHRhYlwiPlxuICAgICAgICAgICAgICAgICAgICAgICAgPGNpZGUtZWxlLWljb24gc2l6ZT1cIjN4c1wiPmNsb3NlPC9jaWRlLWVsZS1pY29uPlxuICAgICAgICAgICAgICAgICAgICA8L2J1dHRvbj5cbiAgICAgICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICAgICAgICA8IS0tIE9ubHkgYWRkIGRpdmlkZXIgYmV0d2VlbiBpdGVtcyAtLT5cbiAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVwicmVxdWVzdC1kaXZpZGVyXCIgKm5nSWY9XCJpIDwgcmVxdWVzdEl0ZW1zLmxlbmd0aCAtIDFcIj48L2Rpdj5cbiAgICAgICAgICAgIDwvbmctY29udGFpbmVyPlxuICAgICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbjwvbmctY29udGFpbmVyPiJdfQ==
|
|
@@ -0,0 +1,235 @@
|
|
|
1
|
+
import { Injectable, inject, signal, computed } from '@angular/core';
|
|
2
|
+
import { Router, RouteReuseStrategy } from '@angular/router';
|
|
3
|
+
import { CustomRouteReuseStrategy } from '../../utils/custom-route-reuse-strategy';
|
|
4
|
+
import { TabStateService } from '../../services/tab-state.service';
|
|
5
|
+
import { CideLytSidedrawerService } from '../sidedrawer/sidedrawer.service';
|
|
6
|
+
import { CideLytSharedService } from '../shared/shared.service';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
export class CideLytRequestService {
|
|
9
|
+
constructor() {
|
|
10
|
+
this.requestVisible = false;
|
|
11
|
+
// Modern Angular v20+ pattern: Use Signals instead of BehaviorSubject
|
|
12
|
+
this.tabsSignal = signal([]);
|
|
13
|
+
this.activeTabIdSignal = signal(null);
|
|
14
|
+
// Computed signals for derived state and public readonly access
|
|
15
|
+
this.tabs = computed(() => this.tabsSignal());
|
|
16
|
+
this.activeTabId = computed(() => this.activeTabIdSignal());
|
|
17
|
+
this.activeTab = computed(() => this.tabsSignal().find(tab => tab.active));
|
|
18
|
+
// Use inject() for all dependencies
|
|
19
|
+
this.router = inject(Router);
|
|
20
|
+
this.routeReuseStrategy = inject(RouteReuseStrategy);
|
|
21
|
+
this.tabStateService = inject(TabStateService);
|
|
22
|
+
this.sidedrawerService = inject(CideLytSidedrawerService);
|
|
23
|
+
this.sharedService = inject(CideLytSharedService);
|
|
24
|
+
// Initialize router
|
|
25
|
+
this.router = inject(Router);
|
|
26
|
+
this.router.routeReuseStrategy = new CustomRouteReuseStrategy();
|
|
27
|
+
// Register tab management callback with shared service to avoid circular dependency
|
|
28
|
+
this.sharedService.registerTabManagement(this.handleRouteBasedTabManagement.bind(this));
|
|
29
|
+
// Register request visibility callback
|
|
30
|
+
this.sharedService.registerRequestVisibility(this.handleRequestVisibility.bind(this));
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* Handle request visibility changes from shared service
|
|
34
|
+
*/
|
|
35
|
+
handleRequestVisibility(show) {
|
|
36
|
+
if (show) {
|
|
37
|
+
this.showRequest();
|
|
38
|
+
}
|
|
39
|
+
else {
|
|
40
|
+
this.hideRequest();
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Handle sidebar sync when tab becomes active
|
|
45
|
+
*/
|
|
46
|
+
handleSidebarSync(tabInfo) {
|
|
47
|
+
// The sidebar sync will be handled automatically by the shared service
|
|
48
|
+
// when page data is loaded, so we don't need additional logic here
|
|
49
|
+
console.log('🔗 REQUEST SERVICE: Tab activated, sidebar sync handled by shared service:', tabInfo.title);
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Handle route-based tab management - called by shared service
|
|
53
|
+
* This method checks for existing tabs and creates/activates as needed
|
|
54
|
+
*/
|
|
55
|
+
handleRouteBasedTabManagement(currentRoutePath, queryParams, layout, pageData, pageCode) {
|
|
56
|
+
console.log('handleRouteBasedTabManagement', currentRoutePath, queryParams, layout, pageData, pageCode);
|
|
57
|
+
const currentTabs = this.tabsSignal();
|
|
58
|
+
const tabAlreadyExists = currentTabs.find((t) => {
|
|
59
|
+
const tRoutePath = t.route.startsWith('/') ? t.route : '/' + t.route;
|
|
60
|
+
const tParamsMatch = JSON.stringify(t.params || {}) === JSON.stringify(queryParams || {});
|
|
61
|
+
return tRoutePath === currentRoutePath && tParamsMatch;
|
|
62
|
+
});
|
|
63
|
+
console.log('tabAlreadyExists', tabAlreadyExists);
|
|
64
|
+
if (!tabAlreadyExists) {
|
|
65
|
+
const title = pageData.data?.page?.sypg_title || pageCode.toString() || 'Untitled Tab';
|
|
66
|
+
console.log(`🆕 Adding new tab: ${title}`);
|
|
67
|
+
this.addTab(title, currentRoutePath, queryParams, layout);
|
|
68
|
+
}
|
|
69
|
+
else if (tabAlreadyExists && !tabAlreadyExists.active) {
|
|
70
|
+
console.log(`🔄 Activating existing tab: ${tabAlreadyExists.title}`);
|
|
71
|
+
this.activateTab(tabAlreadyExists.id);
|
|
72
|
+
}
|
|
73
|
+
else if (tabAlreadyExists && tabAlreadyExists.active) {
|
|
74
|
+
console.log(`🔄 Activating existing tab: ${tabAlreadyExists.title}`);
|
|
75
|
+
this.activateTab(tabAlreadyExists.id);
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
addTab(title, route, params, layout) {
|
|
79
|
+
console.log('addTab', title, route, params, layout);
|
|
80
|
+
const id = this.generateId();
|
|
81
|
+
const currentTabs = this.tabsSignal();
|
|
82
|
+
console.log('currentTabs', currentTabs, route);
|
|
83
|
+
// Check if a tab with the same route and params already exists
|
|
84
|
+
const existingTab = currentTabs.find((tab) => {
|
|
85
|
+
const paramsMatch = JSON.stringify(tab.params || {}) === JSON.stringify(params || {});
|
|
86
|
+
return tab.route === route && paramsMatch;
|
|
87
|
+
});
|
|
88
|
+
console.log('existingTab', existingTab);
|
|
89
|
+
if (existingTab) {
|
|
90
|
+
this.activateTab(existingTab.id);
|
|
91
|
+
return existingTab.id;
|
|
92
|
+
}
|
|
93
|
+
// Create new tab
|
|
94
|
+
const newTab = {
|
|
95
|
+
id,
|
|
96
|
+
title,
|
|
97
|
+
route,
|
|
98
|
+
params,
|
|
99
|
+
active: true,
|
|
100
|
+
layout,
|
|
101
|
+
sytm_page_id_sypg: '',
|
|
102
|
+
themeId: ''
|
|
103
|
+
};
|
|
104
|
+
// Deactivate all other tabs
|
|
105
|
+
currentTabs.forEach((tab) => tab.active = false);
|
|
106
|
+
console.log('currentTabs after deactivate', currentTabs, 'activateTab', id);
|
|
107
|
+
// Add new tab
|
|
108
|
+
this.tabsSignal.set([...currentTabs, newTab]);
|
|
109
|
+
this.activeTabIdSignal.set(id);
|
|
110
|
+
// Sync with TabStateService
|
|
111
|
+
this.tabStateService.addTab(title, id);
|
|
112
|
+
// Request visibility is now controlled by layout configuration in setPageData
|
|
113
|
+
// No need to automatically show request wrapper here
|
|
114
|
+
// Navigate to the new route
|
|
115
|
+
if (params) {
|
|
116
|
+
this.router.navigate([route], { queryParams: params });
|
|
117
|
+
}
|
|
118
|
+
else {
|
|
119
|
+
this.router.navigate([route]);
|
|
120
|
+
}
|
|
121
|
+
return id;
|
|
122
|
+
}
|
|
123
|
+
activateTab(tabId) {
|
|
124
|
+
console.log('🔍 REQUEST SERVICE: Activating tab:', tabId);
|
|
125
|
+
const tabs = this.tabsSignal();
|
|
126
|
+
const tabToActivate = tabs.find(tab => tab.id === tabId);
|
|
127
|
+
if (!tabToActivate) {
|
|
128
|
+
console.warn('⚠️ Tab not found:', tabId);
|
|
129
|
+
return;
|
|
130
|
+
}
|
|
131
|
+
// Update tabs: deactivate all, then activate the target
|
|
132
|
+
const updatedTabs = tabs.map(tab => ({
|
|
133
|
+
...tab,
|
|
134
|
+
active: tab.id === tabId
|
|
135
|
+
}));
|
|
136
|
+
this.tabsSignal.set(updatedTabs);
|
|
137
|
+
this.activeTabIdSignal.set(tabId);
|
|
138
|
+
console.log('✅ REQUEST SERVICE: Tab activated:', tabToActivate.title);
|
|
139
|
+
// Navigate to the tab's route
|
|
140
|
+
this.router.navigate([tabToActivate.route], {
|
|
141
|
+
queryParams: tabToActivate.params || {},
|
|
142
|
+
replaceUrl: false
|
|
143
|
+
});
|
|
144
|
+
// Trigger sidebar sync for the activated tab by calling shared service
|
|
145
|
+
// The shared service will handle the sidebar sync when the route loads
|
|
146
|
+
console.log('🔗 REQUEST SERVICE: Sidebar sync will be handled by route change');
|
|
147
|
+
}
|
|
148
|
+
closeTab(id) {
|
|
149
|
+
const currentTabs = this.tabsSignal();
|
|
150
|
+
const tabIndex = currentTabs.findIndex((tab) => tab.id === id);
|
|
151
|
+
if (tabIndex === -1)
|
|
152
|
+
return;
|
|
153
|
+
const tabToClose = currentTabs[tabIndex];
|
|
154
|
+
const wasActive = tabToClose.active;
|
|
155
|
+
// Sync with TabStateService by removing the tab state
|
|
156
|
+
this.tabStateService.removeTab(id);
|
|
157
|
+
// Clear stored route from strategy
|
|
158
|
+
if (this.routeReuseStrategy instanceof CustomRouteReuseStrategy) {
|
|
159
|
+
let pathKey = tabToClose.route.startsWith('/') ? tabToClose.route.substring(1) : tabToClose.route;
|
|
160
|
+
if (tabToClose.params && Object.keys(tabToClose.params).length > 0) {
|
|
161
|
+
const queryParamsString = Object.keys(tabToClose.params)
|
|
162
|
+
.sort()
|
|
163
|
+
.map(key => `${key}=${tabToClose.params[key]}`)
|
|
164
|
+
.join('&');
|
|
165
|
+
pathKey += '?' + queryParamsString;
|
|
166
|
+
}
|
|
167
|
+
this.routeReuseStrategy.clearStoredRoute(pathKey);
|
|
168
|
+
}
|
|
169
|
+
// Remove the tab from this service's list
|
|
170
|
+
const newTabs = currentTabs.filter((tab) => tab.id !== id);
|
|
171
|
+
// If we're closing the active tab, activate the next available tab
|
|
172
|
+
if (wasActive && newTabs.length > 0) {
|
|
173
|
+
const newActiveIndex = Math.max(0, Math.min(tabIndex, newTabs.length - 1));
|
|
174
|
+
const newActiveTab = newTabs[newActiveIndex];
|
|
175
|
+
// Update sidedrawer for the new active tab
|
|
176
|
+
this.sidedrawerService.updateDrawerItems(newActiveTab.layout);
|
|
177
|
+
newTabs[newActiveIndex].active = true;
|
|
178
|
+
this.activeTabIdSignal.set(newActiveTab.id);
|
|
179
|
+
this.tabStateService.setActiveTab(newActiveTab.id);
|
|
180
|
+
// Navigate to the new active tab's route
|
|
181
|
+
if (newActiveTab.params) {
|
|
182
|
+
this.router.navigate([newActiveTab.route], { queryParams: newActiveTab.params });
|
|
183
|
+
}
|
|
184
|
+
else {
|
|
185
|
+
this.router.navigate([newActiveTab.route]);
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
else if (newTabs.length === 0) {
|
|
189
|
+
this.activeTabIdSignal.set(null);
|
|
190
|
+
this.tabStateService.setActiveTab(null);
|
|
191
|
+
// Clear sidedrawer as no tabs are open
|
|
192
|
+
this.sidedrawerService.updateDrawerItems(undefined);
|
|
193
|
+
}
|
|
194
|
+
this.tabsSignal.set(newTabs);
|
|
195
|
+
// Request wrapper visibility is now controlled by layout configuration
|
|
196
|
+
// The wrapper will be hidden/shown based on sytm_layout_request.status in setPageData
|
|
197
|
+
}
|
|
198
|
+
// Hide Request
|
|
199
|
+
hideRequest() {
|
|
200
|
+
console.log('🚫 REQUEST SERVICE - Hiding request wrapper');
|
|
201
|
+
this.requestVisible = false;
|
|
202
|
+
document.querySelector(`#cide-lyt-request-wrapper`)?.classList.add('cide-lyt-request-wrapper-hide');
|
|
203
|
+
document.querySelector(`body`)?.classList.remove('cide-lyt-request-exist');
|
|
204
|
+
}
|
|
205
|
+
// Show Request
|
|
206
|
+
showRequest() {
|
|
207
|
+
console.log('✅ REQUEST SERVICE - Showing request wrapper');
|
|
208
|
+
this.requestVisible = true;
|
|
209
|
+
document.querySelector(`#cide-lyt-request-wrapper`)?.classList.remove('cide-lyt-request-wrapper-hide');
|
|
210
|
+
document.querySelector(`body`)?.classList.add('cide-lyt-request-exist');
|
|
211
|
+
}
|
|
212
|
+
generateId() {
|
|
213
|
+
return 'tab-' + Math.random().toString(36).substr(2, 9);
|
|
214
|
+
}
|
|
215
|
+
updateTabScrollPosition(tabId, scrollTop, scrollLeft) {
|
|
216
|
+
const currentTabs = this.tabsSignal();
|
|
217
|
+
const tabIndex = currentTabs.findIndex((t) => t.id === tabId);
|
|
218
|
+
if (tabIndex !== -1) {
|
|
219
|
+
const tabToUpdate = currentTabs[tabIndex];
|
|
220
|
+
tabToUpdate.scrollTop = scrollTop;
|
|
221
|
+
tabToUpdate.scrollLeft = scrollLeft;
|
|
222
|
+
// Create a new array reference to trigger change detection
|
|
223
|
+
this.tabsSignal.set([...currentTabs]);
|
|
224
|
+
}
|
|
225
|
+
}
|
|
226
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: CideLytRequestService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
227
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: CideLytRequestService, providedIn: 'root' }); }
|
|
228
|
+
}
|
|
229
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: CideLytRequestService, decorators: [{
|
|
230
|
+
type: Injectable,
|
|
231
|
+
args: [{
|
|
232
|
+
providedIn: 'root'
|
|
233
|
+
}]
|
|
234
|
+
}], ctorParameters: () => [] });
|
|
235
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"request.service.js","sourceRoot":"","sources":["../../../../../../projects/cloud-ide-layout/src/lib/layout/request/request.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, inject, signal, WritableSignal, Signal, computed } from '@angular/core';\nimport { Router, RouteReuseStrategy } from '@angular/router';\nimport { CustomRouteReuseStrategy } from '../../utils/custom-route-reuse-strategy';\nimport { TabStateService } from '../../services/tab-state.service';\nimport { CideLytSidedrawerService } from '../sidedrawer/sidedrawer.service';\nimport { CideLytSharedService } from '../shared/shared.service';\nimport { ISytmLayout } from 'cloud-ide-lms-model';\n\nexport interface TabInfo {\n  id: string;\n  title: string;\n  route: string;\n  params?: Record<string, unknown>;\n  active: boolean;\n  sytm_page_id_sypg: string;\n  themeId: string;\n  loadedComponent?: unknown;\n  scrollTop?: number;\n  scrollLeft?: number;\n  layout?: ISytmLayout;\n}\n\n// Interface for page data passed from shared service\ninterface PageDataResponse {\n  data?: {\n    page?: {\n      sypg_title?: string;\n    };\n  };\n}\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class CideLytRequestService {\n  public requestVisible: boolean = false;\n  // Modern Angular v20+ pattern: Use Signals instead of BehaviorSubject\n  public tabsSignal: WritableSignal<TabInfo[]> = signal([]);\n  public activeTabIdSignal: WritableSignal<string | null> = signal(null);\n  \n  // Computed signals for derived state and public readonly access\n  public tabs: Signal<TabInfo[]> = computed(() => this.tabsSignal());\n  public activeTabId: Signal<string | null> = computed(() => this.activeTabIdSignal());\n  public activeTab: Signal<TabInfo | undefined> = computed(() => \n    this.tabsSignal().find(tab => tab.active)\n  );\n\n  // Use inject() for all dependencies\n  private router = inject(Router);\n  private routeReuseStrategy = inject(RouteReuseStrategy);\n  private tabStateService = inject(TabStateService);\n  private sidedrawerService = inject(CideLytSidedrawerService);\n  private sharedService = inject(CideLytSharedService);\n\n  constructor() {\n    // Initialize router\n    this.router = inject(Router);\n    this.router.routeReuseStrategy = new CustomRouteReuseStrategy();\n    \n    // Register tab management callback with shared service to avoid circular dependency\n    this.sharedService.registerTabManagement(this.handleRouteBasedTabManagement.bind(this));\n    \n    // Register request visibility callback\n    this.sharedService.registerRequestVisibility(this.handleRequestVisibility.bind(this));\n  }\n\n  /**\n   * Handle request visibility changes from shared service\n   */\n  private handleRequestVisibility(show: boolean): void {\n    if (show) {\n      this.showRequest();\n    } else {\n      this.hideRequest();\n    }\n  }\n\n  /**\n   * Handle sidebar sync when tab becomes active\n   */\n  private handleSidebarSync(tabInfo: TabInfo): void {\n    // The sidebar sync will be handled automatically by the shared service\n    // when page data is loaded, so we don't need additional logic here\n    console.log('🔗 REQUEST SERVICE: Tab activated, sidebar sync handled by shared service:', tabInfo.title);\n  }\n\n  /**\n   * Handle route-based tab management - called by shared service\n   * This method checks for existing tabs and creates/activates as needed\n   */\n  handleRouteBasedTabManagement(\n    currentRoutePath: string,\n    queryParams: Record<string, unknown>,\n    layout: ISytmLayout,\n    pageData: PageDataResponse,\n    pageCode: string\n  ) {\n    console.log('handleRouteBasedTabManagement', currentRoutePath, queryParams, layout, pageData, pageCode);\n    const currentTabs = this.tabsSignal();\n    const tabAlreadyExists = currentTabs.find((t: TabInfo) => {\n      const tRoutePath = t.route.startsWith('/') ? t.route : '/' + t.route;\n      const tParamsMatch = JSON.stringify(t.params || {}) === JSON.stringify(queryParams || {});\n      return tRoutePath === currentRoutePath && tParamsMatch;\n    });\n    console.log('tabAlreadyExists', tabAlreadyExists);\n    if (!tabAlreadyExists) {\n      const title = pageData.data?.page?.sypg_title || pageCode.toString() || 'Untitled Tab';\n      console.log(`🆕 Adding new tab: ${title}`);\n      this.addTab(title, currentRoutePath, queryParams, layout);\n    } else if (tabAlreadyExists && !tabAlreadyExists.active) {\n      console.log(`🔄 Activating existing tab: ${tabAlreadyExists.title}`);\n      this.activateTab(tabAlreadyExists.id);\n    }else if (tabAlreadyExists && tabAlreadyExists.active) {\n      console.log(`🔄 Activating existing tab: ${tabAlreadyExists.title}`);\n      this.activateTab(tabAlreadyExists.id);\n    }\n  }\n\n  addTab(title: string, route: string, params?: Record<string, unknown>, layout?: ISytmLayout): string {\n    console.log('addTab', title, route, params, layout);\n    const id = this.generateId();\n    const currentTabs = this.tabsSignal();\n    console.log('currentTabs', currentTabs, route);\n    // Check if a tab with the same route and params already exists\n    const existingTab = currentTabs.find((tab: TabInfo) => {\n      const paramsMatch = JSON.stringify(tab.params || {}) === JSON.stringify(params || {});\n      return tab.route === route && paramsMatch;\n    });\n    console.log('existingTab', existingTab);\n    if (existingTab) {\n      this.activateTab(existingTab.id);\n      return existingTab.id;\n    }\n    \n    // Create new tab\n    const newTab: TabInfo = {\n      id,\n      title,\n      route,\n      params,\n      active: true,\n      layout,\n      sytm_page_id_sypg: '',\n      themeId: ''\n    };\n\n    // Deactivate all other tabs\n    currentTabs.forEach((tab: TabInfo) => tab.active = false);\n    console.log('currentTabs after deactivate', currentTabs, 'activateTab', id);\n    // Add new tab\n    this.tabsSignal.set([...currentTabs, newTab]);\n    this.activeTabIdSignal.set(id);\n\n    // Sync with TabStateService\n    this.tabStateService.addTab(title, id);\n    \n    // Request visibility is now controlled by layout configuration in setPageData\n    // No need to automatically show request wrapper here\n    \n    // Navigate to the new route\n    if (params) {\n      this.router.navigate([route], { queryParams: params });\n    } else {\n      this.router.navigate([route]);\n    }\n\n    return id;\n  }\n\n  activateTab(tabId: string): void {\n    console.log('🔍 REQUEST SERVICE: Activating tab:', tabId);\n    const tabs = this.tabsSignal();\n    const tabToActivate = tabs.find(tab => tab.id === tabId);\n    \n    if (!tabToActivate) {\n      console.warn('⚠️ Tab not found:', tabId);\n      return;\n    }\n\n    // Update tabs: deactivate all, then activate the target\n    const updatedTabs = tabs.map(tab => ({\n      ...tab,\n      active: tab.id === tabId\n    }));\n\n    this.tabsSignal.set(updatedTabs);\n    this.activeTabIdSignal.set(tabId);\n    \n    console.log('✅ REQUEST SERVICE: Tab activated:', tabToActivate.title);\n\n    // Navigate to the tab's route\n    this.router.navigate([tabToActivate.route], { \n      queryParams: tabToActivate.params || {},\n      replaceUrl: false \n    });\n    \n    // Trigger sidebar sync for the activated tab by calling shared service\n    // The shared service will handle the sidebar sync when the route loads\n    console.log('🔗 REQUEST SERVICE: Sidebar sync will be handled by route change');\n  }\n\n  closeTab(id: string): void {\n    const currentTabs = this.tabsSignal();\n    const tabIndex = currentTabs.findIndex((tab: TabInfo) => tab.id === id);\n\n    if (tabIndex === -1) return;\n\n    const tabToClose = currentTabs[tabIndex];\n    const wasActive = tabToClose.active;\n\n    // Sync with TabStateService by removing the tab state\n    this.tabStateService.removeTab(id);\n\n    // Clear stored route from strategy\n    if (this.routeReuseStrategy instanceof CustomRouteReuseStrategy) {\n      let pathKey = tabToClose.route.startsWith('/') ? tabToClose.route.substring(1) : tabToClose.route;\n\n      if (tabToClose.params && Object.keys(tabToClose.params).length > 0) {\n        const queryParamsString = Object.keys(tabToClose.params)\n          .sort()\n          .map(key => `${key}=${tabToClose.params![key]}`)\n          .join('&');\n        pathKey += '?' + queryParamsString;\n      }\n\n      (this.routeReuseStrategy as CustomRouteReuseStrategy).clearStoredRoute(pathKey);\n    }\n\n    // Remove the tab from this service's list\n    const newTabs = currentTabs.filter((tab: TabInfo) => tab.id !== id);\n\n    // If we're closing the active tab, activate the next available tab\n    if (wasActive && newTabs.length > 0) {\n      const newActiveIndex = Math.max(0, Math.min(tabIndex, newTabs.length - 1));\n      const newActiveTab = newTabs[newActiveIndex];\n\n      // Update sidedrawer for the new active tab\n      this.sidedrawerService.updateDrawerItems(newActiveTab.layout);\n\n      newTabs[newActiveIndex].active = true;\n      this.activeTabIdSignal.set(newActiveTab.id);\n      this.tabStateService.setActiveTab(newActiveTab.id);\n\n      // Navigate to the new active tab's route\n      if (newActiveTab.params) {\n        this.router.navigate([newActiveTab.route], { queryParams: newActiveTab.params });\n      } else {\n        this.router.navigate([newActiveTab.route]);\n      }\n    } else if (newTabs.length === 0) {\n      this.activeTabIdSignal.set(null);\n      this.tabStateService.setActiveTab(null);\n      // Clear sidedrawer as no tabs are open\n      this.sidedrawerService.updateDrawerItems(undefined);\n    }\n    this.tabsSignal.set(newTabs);\n    // Request wrapper visibility is now controlled by layout configuration\n    // The wrapper will be hidden/shown based on sytm_layout_request.status in setPageData\n  }\n\n  // Hide Request\n  hideRequest() {\n    console.log('🚫 REQUEST SERVICE - Hiding request wrapper');\n    this.requestVisible = false;\n    document.querySelector(`#cide-lyt-request-wrapper`)?.classList.add('cide-lyt-request-wrapper-hide');\n    document.querySelector(`body`)?.classList.remove('cide-lyt-request-exist');\n  }\n\n  // Show Request\n  showRequest() {\n    console.log('✅ REQUEST SERVICE - Showing request wrapper');\n    this.requestVisible = true;\n    document.querySelector(`#cide-lyt-request-wrapper`)?.classList.remove('cide-lyt-request-wrapper-hide');\n    document.querySelector(`body`)?.classList.add('cide-lyt-request-exist');\n  }\n\n  private generateId(): string {\n    return 'tab-' + Math.random().toString(36).substr(2, 9);\n  }\n\n  updateTabScrollPosition(tabId: string, scrollTop: number, scrollLeft: number): void {\n    const currentTabs = this.tabsSignal();\n    const tabIndex = currentTabs.findIndex((t: TabInfo) => t.id === tabId);\n    if (tabIndex !== -1) {\n      const tabToUpdate = currentTabs[tabIndex];\n      tabToUpdate.scrollTop = scrollTop;\n      tabToUpdate.scrollLeft = scrollLeft;\n      // Create a new array reference to trigger change detection\n      this.tabsSignal.set([...currentTabs]);\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { Component, ViewChild, effect } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { NavigationEnd, RouterModule } from '@angular/router';
|
|
4
|
+
import { filter } from 'rxjs/operators';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "../request.service";
|
|
7
|
+
import * as i2 from "@angular/router";
|
|
8
|
+
export class TabContentComponent {
|
|
9
|
+
constructor(requestService, router, // Inject Router to listen for NavigationEnd
|
|
10
|
+
cdr) {
|
|
11
|
+
this.requestService = requestService;
|
|
12
|
+
this.router = router;
|
|
13
|
+
this.cdr = cdr;
|
|
14
|
+
this.currentActiveTabId = null;
|
|
15
|
+
this.isRestoringScroll = false; // Flag to prevent saving scroll during restoration attempts
|
|
16
|
+
// Modern Angular signal pattern: Use effect to react to active tab changes
|
|
17
|
+
effect(() => {
|
|
18
|
+
const activeTab = this.requestService.activeTab();
|
|
19
|
+
if (activeTab && activeTab.id !== this.currentActiveTabId) {
|
|
20
|
+
this.currentActiveTabId = activeTab.id;
|
|
21
|
+
// Delay scroll restoration to ensure DOM is ready
|
|
22
|
+
const delay = (ms) => new Promise(resolve => setTimeout(resolve, ms));
|
|
23
|
+
delay(100).then(() => this.restoreScrollPosition(activeTab));
|
|
24
|
+
}
|
|
25
|
+
});
|
|
26
|
+
// Listen to route changes for scroll restoration
|
|
27
|
+
this.router.events.pipe(filter(event => event instanceof NavigationEnd)).subscribe({
|
|
28
|
+
next: () => {
|
|
29
|
+
// Use signal to get active tab after navigation
|
|
30
|
+
const activeTab = this.requestService.activeTab();
|
|
31
|
+
if (activeTab && activeTab.id !== this.currentActiveTabId) {
|
|
32
|
+
this.currentActiveTabId = activeTab.id;
|
|
33
|
+
const delay = (ms) => new Promise(resolve => setTimeout(resolve, ms));
|
|
34
|
+
delay(150).then(() => this.restoreScrollPosition(activeTab));
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
ngAfterViewInit() {
|
|
40
|
+
// Initial scroll restoration for the active tab
|
|
41
|
+
const activeTab = this.requestService.activeTab();
|
|
42
|
+
if (activeTab) {
|
|
43
|
+
this.currentActiveTabId = activeTab.id;
|
|
44
|
+
const delay = (ms) => new Promise(resolve => setTimeout(resolve, ms));
|
|
45
|
+
delay(50).then(() => this.restoreScrollPosition(activeTab));
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
onScroll() {
|
|
49
|
+
if (this.isRestoringScroll || !this.scrollContainerRef || !this.currentActiveTabId) {
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
const { scrollTop, scrollLeft } = this.scrollContainerRef.nativeElement;
|
|
53
|
+
this.requestService.updateTabScrollPosition(this.currentActiveTabId, scrollTop, scrollLeft);
|
|
54
|
+
}
|
|
55
|
+
restoreScrollPosition(tab) {
|
|
56
|
+
if (tab && this.scrollContainerRef?.nativeElement) {
|
|
57
|
+
this.isRestoringScroll = true;
|
|
58
|
+
const container = this.scrollContainerRef.nativeElement;
|
|
59
|
+
container.scrollTop = tab.scrollTop ?? 0;
|
|
60
|
+
container.scrollLeft = tab.scrollLeft ?? 0;
|
|
61
|
+
// Modern ES2022+ pattern: Use Promise-based delay
|
|
62
|
+
const delay = (ms) => new Promise(resolve => setTimeout(resolve, ms));
|
|
63
|
+
delay(150).then(() => { this.isRestoringScroll = false; }); // Allow scroll event to settle
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: TabContentComponent, deps: [{ token: i1.CideLytRequestService }, { token: i2.Router }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
67
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.7", type: TabContentComponent, isStandalone: true, selector: "cide-lyt-tab-content", viewQueries: [{ propertyName: "scrollContainerRef", first: true, predicate: ["scrollContainer"], descendants: true }], ngImport: i0, template: `
|
|
68
|
+
<div class="tab-content-container" #scrollContainer (scroll)="onScroll()">
|
|
69
|
+
<router-outlet></router-outlet>
|
|
70
|
+
</div>
|
|
71
|
+
`, isInline: true, styles: [":host{height:100%;display:flex;flex-direction:column}.tab-content-container{height:100%;width:100%;position:relative;overflow:auto;display:flex;flex-direction:column;flex:1}::ng-deep router-outlet+*{height:100%;flex:1;display:flex;flex-direction:column}::ng-deep cide-lyt-home-wrapper,::ng-deep cide-adm-home-wrapper,::ng-deep cide-adm-entity,::ng-deep cide-adm-entity-list{height:100%!important;flex:1!important;display:flex!important;flex-direction:column!important}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: RouterModule }, { kind: "directive", type: i2.RouterOutlet, selector: "router-outlet", inputs: ["name"], outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }] }); }
|
|
72
|
+
}
|
|
73
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: TabContentComponent, decorators: [{
|
|
74
|
+
type: Component,
|
|
75
|
+
args: [{ selector: 'cide-lyt-tab-content', standalone: true, imports: [CommonModule, RouterModule], template: `
|
|
76
|
+
<div class="tab-content-container" #scrollContainer (scroll)="onScroll()">
|
|
77
|
+
<router-outlet></router-outlet>
|
|
78
|
+
</div>
|
|
79
|
+
`, styles: [":host{height:100%;display:flex;flex-direction:column}.tab-content-container{height:100%;width:100%;position:relative;overflow:auto;display:flex;flex-direction:column;flex:1}::ng-deep router-outlet+*{height:100%;flex:1;display:flex;flex-direction:column}::ng-deep cide-lyt-home-wrapper,::ng-deep cide-adm-home-wrapper,::ng-deep cide-adm-entity,::ng-deep cide-adm-entity-list{height:100%!important;flex:1!important;display:flex!important;flex-direction:column!important}\n"] }]
|
|
80
|
+
}], ctorParameters: () => [{ type: i1.CideLytRequestService }, { type: i2.Router }, { type: i0.ChangeDetectorRef }], propDecorators: { scrollContainerRef: [{
|
|
81
|
+
type: ViewChild,
|
|
82
|
+
args: ['scrollContainer']
|
|
83
|
+
}] } });
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tab-content.component.js","sourceRoot":"","sources":["../../../../../../../projects/cloud-ide-layout/src/lib/layout/request/tab-content/tab-content.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, ViewChild, AfterViewInit, ChangeDetectorRef, effect } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { NavigationEnd, Router, RouterModule } from '@angular/router';\nimport { CideLytRequestService, TabInfo } from '../request.service';\nimport { filter } from 'rxjs/operators';\n\n@Component({\n  selector: 'cide-lyt-tab-content',\n  standalone: true,\n  imports: [CommonModule, RouterModule],\n  template: `\n    <div class=\"tab-content-container\" #scrollContainer (scroll)=\"onScroll()\">\n      <router-outlet></router-outlet>\n    </div>\n  `,\n  styles: [`\n    :host {\n      height: 100%;\n      display: flex;\n      flex-direction: column;\n    }\n    \n    .tab-content-container {\n      height: 100%;\n      width: 100%;\n      position: relative;\n      overflow: auto;\n      display: flex;\n      flex-direction: column;\n      flex: 1;\n    }\n    \n    /* Ensure router outlet components take full height */\n    ::ng-deep router-outlet + * {\n      height: 100%;\n      flex: 1;\n      display: flex;\n      flex-direction: column;\n    }\n    \n    /* Specific height fixes for common component selectors */\n    ::ng-deep cide-lyt-home-wrapper,\n    ::ng-deep cide-adm-home-wrapper,\n    ::ng-deep cide-adm-entity,\n    ::ng-deep cide-adm-entity-list {\n      height: 100% !important;\n      flex: 1 !important;\n      display: flex !important;\n      flex-direction: column !important;\n    }\n  `]\n})\nexport class TabContentComponent implements AfterViewInit {\n  @ViewChild('scrollContainer') scrollContainerRef!: ElementRef<HTMLDivElement>;\n\n  private currentActiveTabId: string | null = null;\n  private isRestoringScroll = false; // Flag to prevent saving scroll during restoration attempts\n\n  constructor(\n    private requestService: CideLytRequestService,\n    private router: Router, // Inject Router to listen for NavigationEnd\n    private cdr: ChangeDetectorRef\n  ) {\n    // Modern Angular signal pattern: Use effect to react to active tab changes\n    effect(() => {\n      const activeTab = this.requestService.activeTab();\n      if (activeTab && activeTab.id !== this.currentActiveTabId) {\n        this.currentActiveTabId = activeTab.id;\n        // Delay scroll restoration to ensure DOM is ready\n        const delay = (ms: number) => new Promise(resolve => setTimeout(resolve, ms));\n        delay(100).then(() => this.restoreScrollPosition(activeTab));\n      }\n    });\n\n    // Listen to route changes for scroll restoration\n    this.router.events.pipe(\n      filter(event => event instanceof NavigationEnd)\n    ).subscribe({\n      next: () => {\n        // Use signal to get active tab after navigation\n        const activeTab = this.requestService.activeTab();\n        if (activeTab && activeTab.id !== this.currentActiveTabId) {\n          this.currentActiveTabId = activeTab.id;\n          const delay = (ms: number) => new Promise(resolve => setTimeout(resolve, ms));\n          delay(150).then(() => this.restoreScrollPosition(activeTab));\n        }\n      }\n    });\n  }\n\n  ngAfterViewInit(): void {\n    // Initial scroll restoration for the active tab\n    const activeTab = this.requestService.activeTab();\n    if (activeTab) {\n      this.currentActiveTabId = activeTab.id;\n      const delay = (ms: number) => new Promise(resolve => setTimeout(resolve, ms));\n      delay(50).then(() => this.restoreScrollPosition(activeTab));\n    }\n  }\n\n  onScroll(): void {\n    if (this.isRestoringScroll || !this.scrollContainerRef || !this.currentActiveTabId) {\n      return;\n    }\n    const { scrollTop, scrollLeft } = this.scrollContainerRef.nativeElement;\n    this.requestService.updateTabScrollPosition(this.currentActiveTabId, scrollTop, scrollLeft);\n  }\n\n  private restoreScrollPosition(tab: TabInfo | undefined): void {\n    if (tab && this.scrollContainerRef?.nativeElement) {\n      this.isRestoringScroll = true;\n      const container = this.scrollContainerRef.nativeElement;\n      container.scrollTop = tab.scrollTop ?? 0;\n      container.scrollLeft = tab.scrollLeft ?? 0;\n      // Modern ES2022+ pattern: Use Promise-based delay\n      const delay = (ms: number) => new Promise(resolve => setTimeout(resolve, ms));\n      delay(150).then(() => { this.isRestoringScroll = false; }); // Allow scroll event to settle\n    }\n  }\n\n\n}\n"]}
|
|
@@ -1,37 +1,49 @@
|
|
|
1
|
-
import { Component } from '@angular/core';
|
|
1
|
+
import { Component, inject } from '@angular/core';
|
|
2
|
+
import { CideLytSharedService } from '../shared.service';
|
|
3
|
+
import { CideLytSidedrawerService } from '../../sidedrawer/sidedrawer.service';
|
|
4
|
+
import { AppStateHelperService } from '../../../services/app-state/app-state-helper.service';
|
|
2
5
|
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "../shared.service";
|
|
4
6
|
export class CideLytSharedWrapperComponent {
|
|
5
|
-
constructor(
|
|
6
|
-
this.sharedService = sharedService;
|
|
7
|
+
constructor() {
|
|
7
8
|
this.shared_wrapper_setup_param = {};
|
|
8
9
|
this.page_data = {};
|
|
10
|
+
this.sharedService = inject(CideLytSharedService);
|
|
11
|
+
this.sidedrawerService = inject(CideLytSidedrawerService);
|
|
12
|
+
this.appState = inject(AppStateHelperService);
|
|
9
13
|
}
|
|
10
14
|
ngOnInit() {
|
|
11
|
-
// Load
|
|
12
|
-
this.loadPageData();
|
|
13
|
-
}
|
|
14
|
-
loadPageData() {
|
|
15
|
+
// Load and process page data using modern approach
|
|
15
16
|
if (this.shared_wrapper_setup_param?.sypg_page_code) {
|
|
16
|
-
const
|
|
17
|
-
|
|
18
|
-
|
|
17
|
+
const entityId = this.appState.getActiveEntityId();
|
|
18
|
+
const page_data_payload = {
|
|
19
|
+
sypg_page_code: this.shared_wrapper_setup_param?.sypg_page_code,
|
|
20
|
+
sytm_entity_id_syen: entityId || undefined
|
|
21
|
+
};
|
|
22
|
+
console.log('🔍 Page data payload:', page_data_payload);
|
|
23
|
+
this.sharedService.loadAndProcessPageData(page_data_payload, {
|
|
24
|
+
setTitle: true,
|
|
25
|
+
setSidebarContext: true,
|
|
26
|
+
updateLayout: true
|
|
27
|
+
}).subscribe({
|
|
28
|
+
next: (page_data_response) => {
|
|
29
|
+
console.log('✅ SHARED WRAPPER: Page data loaded and processed for:', page_data_payload.sypg_page_code);
|
|
19
30
|
this.page_data = page_data_response?.data || {};
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
31
|
+
// Sidebar context is automatically set by loadAndProcessPageData when setSidebarContext: true
|
|
32
|
+
const pageId = page_data_response?.data?.page?._id || '';
|
|
33
|
+
const themeId = page_data_response?.data?.theme?._id || '';
|
|
34
|
+
this.sidedrawerService.setContext(pageId, themeId);
|
|
35
|
+
},
|
|
36
|
+
error: (err) => {
|
|
37
|
+
console.error('❌ SHARED WRAPPER: Error loading page data:', err);
|
|
23
38
|
}
|
|
24
39
|
});
|
|
25
40
|
}
|
|
26
41
|
}
|
|
27
|
-
|
|
28
|
-
this.sharedService?.titleService.setTitle(title);
|
|
29
|
-
}
|
|
30
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: CideLytSharedWrapperComponent, deps: [{ token: i1.CideLytSharedService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
42
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: CideLytSharedWrapperComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
31
43
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.7", type: CideLytSharedWrapperComponent, isStandalone: true, selector: "cide-lyt-shared-wrapper", ngImport: i0, template: "<p>shared-wrapper works!</p>\r\n", styles: [""] }); }
|
|
32
44
|
}
|
|
33
45
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.7", ngImport: i0, type: CideLytSharedWrapperComponent, decorators: [{
|
|
34
46
|
type: Component,
|
|
35
47
|
args: [{ selector: 'cide-lyt-shared-wrapper', standalone: true, imports: [], template: "<p>shared-wrapper works!</p>\r\n" }]
|
|
36
|
-
}]
|
|
37
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
48
|
+
}] });
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2hhcmVkLXdyYXBwZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2xvdWQtaWRlLWxheW91dC9zcmMvbGliL2xheW91dC9zaGFyZWQvc2hhcmVkLXdyYXBwZXIvc2hhcmVkLXdyYXBwZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2xvdWQtaWRlLWxheW91dC9zcmMvbGliL2xheW91dC9zaGFyZWQvc2hhcmVkLXdyYXBwZXIvc2hhcmVkLXdyYXBwZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBVSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFFekQsT0FBTyxFQUFFLHdCQUF3QixFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDL0UsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sc0RBQXNELENBQUM7O0FBUzdGLE1BQU0sT0FBTyw2QkFBNkI7SUFQMUM7UUFRUywrQkFBMEIsR0FBNEMsRUFBRSxDQUFDO1FBQ3pFLGNBQVMsR0FBNkIsRUFBRSxDQUFDO1FBQ3hDLGtCQUFhLEdBQUcsTUFBTSxDQUFDLG9CQUFvQixDQUFDLENBQUM7UUFDN0Msc0JBQWlCLEdBQUcsTUFBTSxDQUFDLHdCQUF3QixDQUFDLENBQUM7UUFDbkQsYUFBUSxHQUFHLE1BQU0sQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO0tBa0NwRDtJQWhDQyxRQUFRO1FBQ04sbURBQW1EO1FBQ25ELElBQUksSUFBSSxDQUFDLDBCQUEwQixFQUFFLGNBQWMsRUFBRSxDQUFDO1lBQ3BELE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztZQUNuRCxNQUFNLGlCQUFpQixHQUFrQjtnQkFDdkMsY0FBYyxFQUFFLElBQUksQ0FBQywwQkFBMEIsRUFBRSxjQUFjO2dCQUMvRCxtQkFBbUIsRUFBRSxRQUFRLElBQUksU0FBUzthQUMzQyxDQUFDO1lBQ0YsT0FBTyxDQUFDLEdBQUcsQ0FBQyx1QkFBdUIsRUFBRSxpQkFBaUIsQ0FBQyxDQUFDO1lBRXhELElBQUksQ0FBQyxhQUFhLENBQUMsc0JBQXNCLENBQUMsaUJBQWlCLEVBQUU7Z0JBQzNELFFBQVEsRUFBRSxJQUFJO2dCQUNkLGlCQUFpQixFQUFFLElBQUk7Z0JBQ3ZCLFlBQVksRUFBRSxJQUFJO2FBQ25CLENBQUMsQ0FBQyxTQUFTLENBQUM7Z0JBQ1gsSUFBSSxFQUFFLENBQUMsa0JBQWtELEVBQUUsRUFBRTtvQkFDM0QsT0FBTyxDQUFDLEdBQUcsQ0FBQyx1REFBdUQsRUFBRSxpQkFBaUIsQ0FBQyxjQUFjLENBQUMsQ0FBQztvQkFDdkcsSUFBSSxDQUFDLFNBQVMsR0FBRyxrQkFBa0IsRUFBRSxJQUFJLElBQUksRUFBRSxDQUFDO29CQUVoRCw4RkFBOEY7b0JBQzlGLE1BQU0sTUFBTSxHQUFHLGtCQUFrQixFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsR0FBRyxJQUFJLEVBQUUsQ0FBQztvQkFDekQsTUFBTSxPQUFPLEdBQUcsa0JBQWtCLEVBQUUsSUFBSSxFQUFFLEtBQUssRUFBRSxHQUFHLElBQUksRUFBRSxDQUFDO29CQUMzRCxJQUFJLENBQUMsaUJBQWlCLENBQUMsVUFBVSxDQUFDLE1BQU0sRUFBRSxPQUFPLENBQUMsQ0FBQztnQkFDckQsQ0FBQztnQkFDRCxLQUFLLEVBQUUsQ0FBQyxHQUFHLEVBQUUsRUFBRTtvQkFDYixPQUFPLENBQUMsS0FBSyxDQUFDLDRDQUE0QyxFQUFFLEdBQUcsQ0FBQyxDQUFDO2dCQUNuRSxDQUFDO2FBQ0YsQ0FBQyxDQUFDO1FBQ0wsQ0FBQztJQUNILENBQUM7OEdBcENVLDZCQUE2QjtrR0FBN0IsNkJBQTZCLG1GQ2IxQyxrQ0FDQTs7MkZEWWEsNkJBQTZCO2tCQVB6QyxTQUFTOytCQUNFLHlCQUF5QixjQUN2QixJQUFJLFdBQ1AsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0LCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENpZGVMeXRTaGFyZWRTZXJ2aWNlIH0gZnJvbSAnLi4vc2hhcmVkLnNlcnZpY2UnO1xuaW1wb3J0IHsgZGVzaWduQ29uZmlnQ29udHJvbGxlclJlc3BvbnNlLCBkZXNpZ25Db25maWdSZXNwb25zZURhdGEsIE1EZXNpZ25Db25maWcgfSBmcm9tICdjbG91ZC1pZGUtbG1zLW1vZGVsJztcbmltcG9ydCB7IENpZGVMeXRTaWRlZHJhd2VyU2VydmljZSB9IGZyb20gJy4uLy4uL3NpZGVkcmF3ZXIvc2lkZWRyYXdlci5zZXJ2aWNlJztcbmltcG9ydCB7IEFwcFN0YXRlSGVscGVyU2VydmljZSB9IGZyb20gJy4uLy4uLy4uL3NlcnZpY2VzL2FwcC1zdGF0ZS9hcHAtc3RhdGUtaGVscGVyLnNlcnZpY2UnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdjaWRlLWx5dC1zaGFyZWQtd3JhcHBlcicsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtdLFxuICB0ZW1wbGF0ZVVybDogJy4vc2hhcmVkLXdyYXBwZXIuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybDogJy4vc2hhcmVkLXdyYXBwZXIuY29tcG9uZW50LmNzcydcbn0pXG5leHBvcnQgY2xhc3MgQ2lkZUx5dFNoYXJlZFdyYXBwZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBwdWJsaWMgc2hhcmVkX3dyYXBwZXJfc2V0dXBfcGFyYW06IFBhcnRpYWw8Q2lkZUx5dFNoYXJlZFdyYXBwZXJTZXR1cFBhcmFtPiA9IHt9O1xuICBwdWJsaWMgcGFnZV9kYXRhOiBkZXNpZ25Db25maWdSZXNwb25zZURhdGEgPSB7fTtcbiAgcHJpdmF0ZSBzaGFyZWRTZXJ2aWNlID0gaW5qZWN0KENpZGVMeXRTaGFyZWRTZXJ2aWNlKTtcbiAgcHJpdmF0ZSBzaWRlZHJhd2VyU2VydmljZSA9IGluamVjdChDaWRlTHl0U2lkZWRyYXdlclNlcnZpY2UpO1xuICBwcm90ZWN0ZWQgYXBwU3RhdGUgPSBpbmplY3QoQXBwU3RhdGVIZWxwZXJTZXJ2aWNlKTtcblxuICBuZ09uSW5pdCgpIHtcbiAgICAvLyBMb2FkIGFuZCBwcm9jZXNzIHBhZ2UgZGF0YSB1c2luZyBtb2Rlcm4gYXBwcm9hY2hcbiAgICBpZiAodGhpcy5zaGFyZWRfd3JhcHBlcl9zZXR1cF9wYXJhbT8uc3lwZ19wYWdlX2NvZGUpIHtcbiAgICAgIGNvbnN0IGVudGl0eUlkID0gdGhpcy5hcHBTdGF0ZS5nZXRBY3RpdmVFbnRpdHlJZCgpO1xuICAgICAgY29uc3QgcGFnZV9kYXRhX3BheWxvYWQ6IE1EZXNpZ25Db25maWcgPSB7IFxuICAgICAgICBzeXBnX3BhZ2VfY29kZTogdGhpcy5zaGFyZWRfd3JhcHBlcl9zZXR1cF9wYXJhbT8uc3lwZ19wYWdlX2NvZGUsIFxuICAgICAgICBzeXRtX2VudGl0eV9pZF9zeWVuOiBlbnRpdHlJZCB8fCB1bmRlZmluZWQgXG4gICAgICB9O1xuICAgICAgY29uc29sZS5sb2coJ/CflI0gUGFnZSBkYXRhIHBheWxvYWQ6JywgcGFnZV9kYXRhX3BheWxvYWQpO1xuICAgICAgXG4gICAgICB0aGlzLnNoYXJlZFNlcnZpY2UubG9hZEFuZFByb2Nlc3NQYWdlRGF0YShwYWdlX2RhdGFfcGF5bG9hZCwge1xuICAgICAgICBzZXRUaXRsZTogdHJ1ZSxcbiAgICAgICAgc2V0U2lkZWJhckNvbnRleHQ6IHRydWUsXG4gICAgICAgIHVwZGF0ZUxheW91dDogdHJ1ZVxuICAgICAgfSkuc3Vic2NyaWJlKHtcbiAgICAgICAgbmV4dDogKHBhZ2VfZGF0YV9yZXNwb25zZTogZGVzaWduQ29uZmlnQ29udHJvbGxlclJlc3BvbnNlKSA9PiB7XG4gICAgICAgICAgY29uc29sZS5sb2coJ+KchSBTSEFSRUQgV1JBUFBFUjogUGFnZSBkYXRhIGxvYWRlZCBhbmQgcHJvY2Vzc2VkIGZvcjonLCBwYWdlX2RhdGFfcGF5bG9hZC5zeXBnX3BhZ2VfY29kZSk7XG4gICAgICAgICAgdGhpcy5wYWdlX2RhdGEgPSBwYWdlX2RhdGFfcmVzcG9uc2U/LmRhdGEgfHwge307XG4gICAgICAgICAgXG4gICAgICAgICAgLy8gU2lkZWJhciBjb250ZXh0IGlzIGF1dG9tYXRpY2FsbHkgc2V0IGJ5IGxvYWRBbmRQcm9jZXNzUGFnZURhdGEgd2hlbiBzZXRTaWRlYmFyQ29udGV4dDogdHJ1ZVxuICAgICAgICAgIGNvbnN0IHBhZ2VJZCA9IHBhZ2VfZGF0YV9yZXNwb25zZT8uZGF0YT8ucGFnZT8uX2lkIHx8ICcnO1xuICAgICAgICAgIGNvbnN0IHRoZW1lSWQgPSBwYWdlX2RhdGFfcmVzcG9uc2U/LmRhdGE/LnRoZW1lPy5faWQgfHwgJyc7XG4gICAgICAgICAgdGhpcy5zaWRlZHJhd2VyU2VydmljZS5zZXRDb250ZXh0KHBhZ2VJZCwgdGhlbWVJZCk7XG4gICAgICAgIH0sXG4gICAgICAgIGVycm9yOiAoZXJyKSA9PiB7XG4gICAgICAgICAgY29uc29sZS5lcnJvcign4p2MIFNIQVJFRCBXUkFQUEVSOiBFcnJvciBsb2FkaW5nIHBhZ2UgZGF0YTonLCBlcnIpO1xuICAgICAgICB9XG4gICAgICB9KTtcbiAgICB9XG4gIH1cblxuXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2lkZUx5dFNoYXJlZFdyYXBwZXJTZXR1cFBhcmFtIHtcbiAgc3lwZ19wYWdlX2NvZGU6IHN0cmluZ1xufSIsIjxwPnNoYXJlZC13cmFwcGVyIHdvcmtzITwvcD5cclxuIl19
|