cax-design-system 1.2.14 → 1.2.16

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.
@@ -51,14 +51,20 @@ export class Navigation {
51
51
  headerContainer;
52
52
  ngOnChanges() {
53
53
  if (this.activeTab == 'notifications') {
54
- if (this.notifications)
54
+ if (this.notifications) {
55
+ this.topNavList?.map((list) => (list.active = false));
56
+ this.bottomNavList?.map((list) => (list.active = false));
55
57
  this.notificationActive = true;
58
+ }
56
59
  else
57
60
  this.topNavList[0].active = true;
58
61
  }
59
62
  else if (this.activeTab == 'help-centre') {
60
- if (this.helpCentre)
63
+ if (this.helpCentre) {
64
+ this.topNavList?.map((list) => (list.active = false));
65
+ this.bottomNavList?.map((list) => (list.active = false));
61
66
  this.helpCentreActive = true;
67
+ }
62
68
  else
63
69
  this.topNavList[0].active = true;
64
70
  }
@@ -175,7 +181,7 @@ export class Navigation {
175
181
  return containerHeight - bottomHeight - headerHeight - 56;
176
182
  }
177
183
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: Navigation, deps: [], target: i0.ɵɵFactoryTarget.Component });
178
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: Navigation, isStandalone: true, selector: "cax-navigation", inputs: { expanded: "expanded", header: "header", topNavList: "topNavList", bottomNavList: "bottomNavList", activeTab: "activeTab", notifications: "notifications", helpCentre: "helpCentre", copyrightYear: "copyrightYear", version: "version", logout: "logout", profile: "profile", settings: "settings", userName: "userName", userImage: "userImage", userRole: "userRole", organisationDetails: "organisationDetails" }, outputs: { onToggleNavigation: "onToggleNavigation", onNavListItemChange: "onNavListItemChange", onNotificationClick: "onNotificationClick", onHelpCentreClick: "onHelpCentreClick", onLogoutClick: "onLogoutClick", onProfileClick: "onProfileClick", onSettingsClick: "onSettingsClick", onPlanChange: "onPlanChange" }, host: { listeners: { "window:resize": "onResize()" }, classAttribute: "cax-element" }, viewQueries: [{ propertyName: "bottomContainer", first: true, predicate: ["bottomContainer"], descendants: true }, { propertyName: "headerContainer", first: true, predicate: ["headerContainer"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div *ngIf=\"accountDetailsActive\" class=\"cax-nav-backdrop\"></div>\r\n<div class=\"cax-nav\" [ngClass]=\"{ 'cax-nav-expand': expanded }\">\r\n <div class=\"cax-nav-toggle\" (click)=\"toggleSidebar()\">\r\n <i class=\"cax cax-alt-arrow-right\"></i>\r\n </div>\r\n <div class=\"cax-nav-header-container\" #headerContainer>\r\n <div [@rightFade] *ngIf=\"!expanded\" class=\"cax-nav-header\">\r\n <cax-logo size=\"xsm\" [iconOnly]=\"true\" />\r\n </div>\r\n <div *ngIf=\"expanded\" class=\"cax-nav-header\" [@leftFade]>\r\n <cax-logo size=\"xsm\" />\r\n <cax-divider layout=\"vertical\"></cax-divider>\r\n <span>{{ header }}</span>\r\n </div>\r\n </div>\r\n <div class=\"cax-nav-list-container\" [style.maxHeight.px]=\"adjustUpDivHeight()\">\r\n <ul>\r\n <li *ngFor=\"let nav of topNavList, let i = index\" [ngClass]=\"{ active: nav.active }\" (click)=\"onItemClick($event, nav, i, 'top')\">\r\n <i *ngIf=\"nav.icon; else imageTemplate\" [class]=\"'cax pi ' + nav.icon\"></i>\r\n <ng-template #imageTemplate>\r\n <cax-image [src]=\"nav.image\" width=\"24px\" height=\"24px\"></cax-image>\r\n </ng-template>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">{{ nav.label }}</span>\r\n </li>\r\n </ul>\r\n </div>\r\n <div class=\"cax-nav-bottom-container\" #bottomContainer>\r\n <div class=\"cax-nav-bottom-list\">\r\n <ul>\r\n <li *ngFor=\"let nav of bottomNavList, let i = index\" [ngClass]=\"{ active: nav.active }\" (click)=\"onItemClick($event, nav, i, 'bottom')\">\r\n <i *ngIf=\"nav.icon; else imageTemplate\" [class]=\"'cax pi ' + nav.icon\"></i>\r\n <ng-template #imageTemplate>\r\n <cax-image [src]=\"nav.image\" width=\"24px\" height=\"24px\"></cax-image>\r\n </ng-template>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">{{ nav.label }}</span>\r\n </li>\r\n <li *ngIf=\"notifications\" (click)=\"emitNotification()\" [ngClass]=\"{ active: notificationActive }\">\r\n <i class=\"cax cax-bell\"></i>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">Notifications</span>\r\n </li>\r\n <li *ngIf=\"helpCentre\" (click)=\"emitHelpCentre()\" [ngClass]=\"{ active: helpCentreActive }\">\r\n <i class=\"cax cax-shield-check\"></i>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">Help Centre</span>\r\n </li>\r\n </ul>\r\n </div>\r\n <div *ngIf=\"userName\" (click)=\"op.toggle($event);\" [ngClass]=\"{ active: accountDetailsActive }\" class=\"cax-nav-account-details\">\r\n <cax-avatar *ngIf=\"userImage\" [image]=\"userImage\" avatarSize=\"lg\"></cax-avatar>\r\n <cax-avatar *ngIf=\"!userImage\" [label]=\"getInitials(userName)\" avatarSize=\"lg\"></cax-avatar>\r\n <div [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-user\">\r\n <span class=\"cax-nav-user-name\">{{ userName }}</span>\r\n <span class=\"cax-nav-user-role\">{{ userRole }}</span>\r\n </div>\r\n <div [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-account-icon\">\r\n <i class=\"cax cax-alt-arrow-up\"></i>\r\n <i class=\"cax cax-alt-arrow-down\"></i>\r\n </div>\r\n <cax-overlayPanel #op (onShow)=\"accountDetailsActive = true\" [styleClass]=\"expanded ? 'cax-nav-overlay-expand' : 'cax-nav-overlay'\" (onHide)=\"accountDetailsActive = false\">\r\n <div *ngIf=\"organisationDetails?.length\" class=\"cax-nav-organisation-list\">\r\n <div *ngFor=\"let org of organisationDetails; let i = index\" class=\"cax-nav-organisation-container\" (click)=\"onPlanClick(org, i)\" [ngClass]=\"{ active: selectedOrganisastionPlan == i }\">\r\n <cax-avatar *ngIf=\"org.image; else labelTemplate\" [image]=\"org.image\" avatarSize=\"lg\"></cax-avatar>\r\n <ng-template #labelTemplate>\r\n <cax-avatar *ngIf=\"org.label; else initialTemplate\" [label]=\"org.label\" avatarSize=\"lg\"></cax-avatar>\r\n </ng-template>\r\n <ng-template #initialTemplate>\r\n <cax-avatar [label]=\"getInitials(org.name)\" avatarSize=\"lg\"></cax-avatar>\r\n </ng-template>\r\n <div class=\"cax-nav-organisation\">\r\n <span class=\"cax-nav-organisation-name\">{{ org.name }}</span>\r\n <span *ngIf=\"org.plan == 'paid'\" class=\"cax-nav-organisation-plan\">\r\n <i class=\"cax cax-wallet\"></i>\r\n Paid Plan\r\n </span>\r\n <span *ngIf=\"org.plan == 'free'\" class=\"cax-nav-organisation-plan\">\r\n <i class=\"cax cax-ticket-sale\"></i>\r\n Free Plan\r\n </span>\r\n <span *ngIf=\"org.plan == 'trial'\" class=\"cax-nav-organisation-plan\">\r\n <i class=\"cax cax-history2\"></i>\r\n Trial Version\r\n </span>\r\n </div>\r\n <cax-radioButton class=\"cax-nav-organisation-radio\" [value]=\"i\" name=\"organisation-plan\" [(ngModel)]=\"selectedOrganisastionPlan\"></cax-radioButton>\r\n </div>\r\n </div>\r\n <div *ngIf=\"settings\" class=\"cax-nav-profile-options\" (click)=\"emitSettings()\">\r\n <i class=\"cax cax-settings\"></i>\r\n <span>Account Settings</span>\r\n </div>\r\n <div *ngIf=\"profile\" class=\"cax-nav-profile-options\" (click)=\"emitProfile()\">\r\n <i class=\"cax cax-user-rounded\"></i>\r\n <span>View Profile</span>\r\n </div>\r\n <div *ngIf=\"logout\" class=\"cax-nav-profile-options cax-nav-logout\" (click)=\"emitLogout()\">\r\n <i class=\"cax cax-logout\"></i>\r\n <span>Logout</span>\r\n </div>\r\n <div class=\"cax-nav-copyright-container\">\r\n <cax-logo width=\"55px\" height=\"17px\"></cax-logo>\r\n <div class=\"cax-nav-copyright\">\r\n <span *ngIf=\"copyrightYear\">&copy; {{ copyrightYear }}</span>\r\n <span *ngIf=\"version\">{{ version }}</span>\r\n </div>\r\n </div>\r\n </cax-overlayPanel>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: ["@layer cax{.cax-nav{width:88px;height:100vh;transition:width .3s ease-in-out;overflow:hidden;padding:16px 8px;position:absolute;left:0;top:0;z-index:1200}.cax-nav.cax-nav-expand{width:264px}.cax-nav.cax-nav-expand .cax-nav-header-container{margin-right:10px}.cax-nav-header-container{display:flex;align-items:center;justify-content:center;height:64px}.cax-nav-header{display:flex;align-items:center;justify-content:center}.cax-nav-header span{font-weight:700;font-size:12px}.cax-nav-toggle{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;position:fixed;cursor:pointer;transition:transform .3s ease-in-out,left .3s ease-in-out}.cax-nav .cax-nav-toggle{left:68px;top:28px}.cax-nav.cax-nav-expand .cax-nav-toggle{left:244px;transform:rotate(180deg)}.cax-nav .cax-divider.cax-divider-vertical{margin:0 8px;height:36px}.cax-nav-list-container,.cax-nav-bottom-list{margin:24px 0}.cax-nav-list-container ul,.cax-nav-bottom-list ul{margin:0;padding:0;list-style-type:none;display:flex;flex-direction:column;gap:16px}.cax-nav-list-container ul li,.cax-nav-bottom-list ul li{padding:12px 24px;border-radius:12px;display:flex;align-items:center;cursor:pointer;height:56px;line-height:24px}.cax-nav-list-container{overflow-y:auto}.cax-nav-list-container::-webkit-scrollbar{display:none}.cax-nav-bottom-container{position:absolute;bottom:16px}.cax-nav-account-details{border-radius:12px;padding:12px;cursor:pointer;transition:width .3s ease-in-out;display:flex;align-items:flex-start}.cax-nav-account-details .cax-nav-account-icon{display:grid;margin-left:auto}.cax-nav.cax-nav-expand .cax-nav-account-details{width:248px}.cax-nav-user{display:grid;margin:0 8px;white-space:nowrap}.cax-nav-user .cax-nav-user-name{font-size:16px;font-weight:500;line-height:24px}.cax-nav-user .cax-nav-user-role{font-size:14px;font-weight:400;line-height:21px}.cax-overlaypanel{width:320px}.cax-overlaypanel .cax-overlaypanel-content{padding:8px}.cax-nav-copyright-container{display:flex;align-items:center;justify-content:space-between}.cax-nav-copyright-container .cax-nav-copyright{font-size:12px;font-weight:500}.cax-nav-copyright-container .cax-nav-copyright span{margin:0 0 0 16px}.cax-nav-profile-options{padding:12px 24px;font-weight:600;line-height:24px;display:flex;align-items:center;cursor:pointer;border-radius:12px;margin-bottom:8px;font-size:16px}.cax-nav-profile-options span{margin-left:8px}.cax-nav-organisation-list{border-radius:12px;padding:8px;margin-bottom:8px}.cax-nav-organisation-container{display:flex;align-items:flex-start;cursor:pointer;padding:12px;border-radius:8px}.cax-nav-organisation-container .cax-nav-organisation-radio{margin-left:auto}.cax-nav-organisation-container:not(:last-child){margin-bottom:8px}.cax-nav-organisation{display:grid;margin:0 8px;white-space:nowrap}.cax-nav-organisation .cax-nav-organisation-name{font-weight:600;font-size:16px;line-height:24px}.cax-nav-organisation .cax-nav-organisation-plan{display:flex;font-size:14px;font-weight:500;line-height:21px}.cax-nav-organisation .cax-nav-organisation-plan i{font-size:20px;margin-right:3px}.cax-nav-overlay-expand{left:270px!important;top:auto!important;bottom:6px}.cax-nav-overlay{left:94px!important;top:auto!important;bottom:6px}}\n"], dependencies: [{ kind: "ngmodule", type: LogoModule }, { kind: "component", type: i1.Logo, selector: "cax-logo", inputs: ["size", "width", "height", "iconOnly", "darkMode"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: DividerModule }, { kind: "component", type: i3.Divider, selector: "cax-divider", inputs: ["style", "styleClass", "layout", "type", "align"] }, { kind: "ngmodule", type: ImageModule }, { kind: "component", type: i4.Image, selector: "cax-image", inputs: ["imageClass", "imageStyle", "styleClass", "style", "src", "srcSet", "sizes", "size", "previewImageSrc", "previewImageSrcSet", "previewImageSizes", "alt", "width", "height", "loading", "appendTo", "preview", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onShow", "onHide", "onImageError"] }, { kind: "ngmodule", type: AvatarModule }, { kind: "component", type: i5.Avatar, selector: "cax-avatar", inputs: ["label", "icon", "image", "avatarSize", "shape", "style", "styleClass", "ariaLabel", "ariaLabelledBy"], outputs: ["onImageError"] }, { kind: "ngmodule", type: OverlayPanelModule }, { kind: "component", type: i6.OverlayPanel, selector: "cax-overlayPanel", inputs: ["ariaLabel", "ariaLabelledBy", "dismissable", "showCloseIcon", "style", "styleClass", "appendTo", "autoZIndex", "ariaCloseLabel", "baseZIndex", "focusOnShow", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onShow", "onHide"] }, { kind: "ngmodule", type: OverlayModule }, { kind: "ngmodule", type: RadioButtonModule }, { kind: "component", type: i7.RadioButton, selector: "cax-radioButton", inputs: ["value", "formControlName", "name", "disabled", "label", "variant", "tabindex", "inputId", "ariaLabelledBy", "ariaLabel", "style", "styleClass", "labelStyleClass", "autofocus"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i8.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], animations: [
184
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: Navigation, isStandalone: true, selector: "cax-navigation", inputs: { expanded: "expanded", header: "header", topNavList: "topNavList", bottomNavList: "bottomNavList", activeTab: "activeTab", notifications: "notifications", helpCentre: "helpCentre", copyrightYear: "copyrightYear", version: "version", logout: "logout", profile: "profile", settings: "settings", userName: "userName", userImage: "userImage", userRole: "userRole", organisationDetails: "organisationDetails" }, outputs: { onToggleNavigation: "onToggleNavigation", onNavListItemChange: "onNavListItemChange", onNotificationClick: "onNotificationClick", onHelpCentreClick: "onHelpCentreClick", onLogoutClick: "onLogoutClick", onProfileClick: "onProfileClick", onSettingsClick: "onSettingsClick", onPlanChange: "onPlanChange" }, host: { listeners: { "window:resize": "onResize()" }, classAttribute: "cax-element" }, viewQueries: [{ propertyName: "bottomContainer", first: true, predicate: ["bottomContainer"], descendants: true }, { propertyName: "headerContainer", first: true, predicate: ["headerContainer"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div *ngIf=\"accountDetailsActive\" class=\"cax-nav-backdrop\"></div>\r\n<div class=\"cax-nav\" [ngClass]=\"{ 'cax-nav-expand': expanded }\">\r\n <div class=\"cax-nav-toggle\" (click)=\"toggleSidebar()\">\r\n <i class=\"cax cax-alt-arrow-right\"></i>\r\n </div>\r\n <div class=\"cax-nav-header-container\" #headerContainer>\r\n <div [@rightFade] *ngIf=\"!expanded\" class=\"cax-nav-header\">\r\n <cax-logo size=\"xsm\" [iconOnly]=\"true\" />\r\n </div>\r\n <div *ngIf=\"expanded\" class=\"cax-nav-header\" [@leftFade]>\r\n <cax-logo size=\"xsm\" />\r\n <cax-divider layout=\"vertical\"></cax-divider>\r\n <span>{{ header }}</span>\r\n </div>\r\n </div>\r\n <div class=\"cax-nav-list-container\" [style.maxHeight.px]=\"adjustUpDivHeight()\">\r\n <ul>\r\n <li *ngFor=\"let nav of topNavList, let i = index\" [ngClass]=\"{ active: nav.active }\" (click)=\"onItemClick($event, nav, i, 'top')\">\r\n <i *ngIf=\"nav.icon; else imageTemplate\" [class]=\"'cax pi ' + nav.icon\"></i>\r\n <ng-template #imageTemplate>\r\n <cax-image [src]=\"nav.image\" width=\"24px\" height=\"24px\"></cax-image>\r\n </ng-template>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">{{ nav.label }}</span>\r\n </li>\r\n </ul>\r\n </div>\r\n <div class=\"cax-nav-bottom-container\" #bottomContainer>\r\n <div class=\"cax-nav-bottom-list\">\r\n <ul>\r\n <li *ngFor=\"let nav of bottomNavList, let i = index\" [ngClass]=\"{ active: nav.active }\" (click)=\"onItemClick($event, nav, i, 'bottom')\">\r\n <i *ngIf=\"nav.icon; else imageTemplate\" [class]=\"'cax pi ' + nav.icon\"></i>\r\n <ng-template #imageTemplate>\r\n <cax-image [src]=\"nav.image\" width=\"24px\" height=\"24px\"></cax-image>\r\n </ng-template>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">{{ nav.label }}</span>\r\n </li>\r\n <li *ngIf=\"notifications\" (click)=\"emitNotification()\" [ngClass]=\"{ active: notificationActive }\">\r\n <i class=\"cax cax-bell\"></i>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">Notifications</span>\r\n </li>\r\n <li *ngIf=\"helpCentre\" (click)=\"emitHelpCentre()\" [ngClass]=\"{ active: helpCentreActive }\">\r\n <i class=\"cax cax-question-circle\"></i>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">Help Centre</span>\r\n </li>\r\n </ul>\r\n </div>\r\n <div *ngIf=\"userName\" (click)=\"op.toggle($event);\" [ngClass]=\"{ active: accountDetailsActive }\" class=\"cax-nav-account-details\">\r\n <cax-avatar *ngIf=\"userImage\" [image]=\"userImage\" avatarSize=\"lg\"></cax-avatar>\r\n <cax-avatar *ngIf=\"!userImage\" [label]=\"getInitials(userName)\" avatarSize=\"lg\"></cax-avatar>\r\n <div [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-user\">\r\n <span class=\"cax-nav-user-name\">{{ userName }}</span>\r\n <span class=\"cax-nav-user-role\">{{ userRole }}</span>\r\n </div>\r\n <div [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-account-icon\">\r\n <i class=\"cax cax-alt-arrow-up\"></i>\r\n <i class=\"cax cax-alt-arrow-down\"></i>\r\n </div>\r\n <cax-overlayPanel #op (onShow)=\"accountDetailsActive = true\" [styleClass]=\"expanded ? 'cax-nav-overlay-expand' : 'cax-nav-overlay'\" (onHide)=\"accountDetailsActive = false\">\r\n <div *ngIf=\"organisationDetails?.length\" class=\"cax-nav-organisation-list\">\r\n <div *ngFor=\"let org of organisationDetails; let i = index\" class=\"cax-nav-organisation-container\" (click)=\"onPlanClick(org, i)\" [ngClass]=\"{ active: selectedOrganisastionPlan == i }\">\r\n <cax-avatar *ngIf=\"org.image; else labelTemplate\" [image]=\"org.image\" avatarSize=\"lg\"></cax-avatar>\r\n <ng-template #labelTemplate>\r\n <cax-avatar *ngIf=\"org.label; else initialTemplate\" [label]=\"org.label\" avatarSize=\"lg\"></cax-avatar>\r\n </ng-template>\r\n <ng-template #initialTemplate>\r\n <cax-avatar [label]=\"getInitials(org.name)\" avatarSize=\"lg\"></cax-avatar>\r\n </ng-template>\r\n <div class=\"cax-nav-organisation\">\r\n <span class=\"cax-nav-organisation-name\">{{ org.name }}</span>\r\n <span *ngIf=\"org.plan == 'paid'\" class=\"cax-nav-organisation-plan\">\r\n <i class=\"cax cax-wallet\"></i>\r\n Paid Plan\r\n </span>\r\n <span *ngIf=\"org.plan == 'free'\" class=\"cax-nav-organisation-plan\">\r\n <i class=\"cax cax-ticket-sale\"></i>\r\n Free Plan\r\n </span>\r\n <span *ngIf=\"org.plan == 'trial'\" class=\"cax-nav-organisation-plan\">\r\n <i class=\"cax cax-history2\"></i>\r\n Trial Version\r\n </span>\r\n </div>\r\n <cax-radioButton class=\"cax-nav-organisation-radio\" [value]=\"i\" name=\"organisation-plan\" [(ngModel)]=\"selectedOrganisastionPlan\"></cax-radioButton>\r\n </div>\r\n </div>\r\n <div *ngIf=\"settings\" class=\"cax-nav-profile-options\" (click)=\"emitSettings()\">\r\n <i class=\"cax cax-settings\"></i>\r\n <span>Account Settings</span>\r\n </div>\r\n <div *ngIf=\"profile\" class=\"cax-nav-profile-options\" (click)=\"emitProfile()\">\r\n <i class=\"cax cax-user-rounded\"></i>\r\n <span>View Profile</span>\r\n </div>\r\n <div *ngIf=\"logout\" class=\"cax-nav-profile-options cax-nav-logout\" (click)=\"emitLogout()\">\r\n <i class=\"cax cax-logout\"></i>\r\n <span>Logout</span>\r\n </div>\r\n <div class=\"cax-nav-copyright-container\">\r\n <cax-logo width=\"55px\" height=\"17px\"></cax-logo>\r\n <div class=\"cax-nav-copyright\">\r\n <span *ngIf=\"copyrightYear\">&copy; {{ copyrightYear }}</span>\r\n <span *ngIf=\"version\">{{ version }}</span>\r\n </div>\r\n </div>\r\n </cax-overlayPanel>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: ["@layer cax{.cax-nav{width:88px;height:100vh;transition:width .3s ease-in-out;overflow:hidden;padding:16px 8px;position:absolute;left:0;top:0;z-index:1200}.cax-nav.cax-nav-expand{width:264px}.cax-nav.cax-nav-expand .cax-nav-header-container{margin-right:10px}.cax-nav-header-container{display:flex;align-items:center;justify-content:center;height:64px}.cax-nav-header{display:flex;align-items:center;justify-content:center}.cax-nav-header span{font-weight:700;font-size:12px}.cax-nav-toggle{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;position:fixed;cursor:pointer;transition:transform .3s ease-in-out,left .3s ease-in-out}.cax-nav .cax-nav-toggle{left:68px;top:28px}.cax-nav.cax-nav-expand .cax-nav-toggle{left:244px;transform:rotate(180deg)}.cax-nav .cax-divider.cax-divider-vertical{margin:0 8px;height:36px}.cax-nav-list-container,.cax-nav-bottom-list{margin:24px 0}.cax-nav-list-container ul,.cax-nav-bottom-list ul{margin:0;padding:0;list-style-type:none;display:flex;flex-direction:column;gap:16px}.cax-nav-list-container ul li,.cax-nav-bottom-list ul li{padding:12px 24px;border-radius:12px;display:flex;align-items:center;cursor:pointer;height:56px;line-height:24px}.cax-nav-list-container{overflow-y:auto}.cax-nav-list-container::-webkit-scrollbar{display:none}.cax-nav-bottom-container{position:absolute;bottom:16px}.cax-nav-account-details{border-radius:12px;padding:12px;cursor:pointer;transition:width .3s ease-in-out;display:flex;align-items:flex-start}.cax-nav-account-details .cax-nav-account-icon{display:grid;margin-left:auto}.cax-nav.cax-nav-expand .cax-nav-account-details{width:248px}.cax-nav-user{display:grid;margin:0 8px;white-space:nowrap}.cax-nav-user .cax-nav-user-name{font-size:16px;font-weight:500;line-height:24px}.cax-nav-user .cax-nav-user-role{font-size:14px;font-weight:400;line-height:21px}.cax-overlaypanel{width:320px}.cax-overlaypanel .cax-overlaypanel-content{padding:8px}.cax-nav-copyright-container{display:flex;align-items:center;justify-content:space-between}.cax-nav-copyright-container .cax-nav-copyright{font-size:12px;font-weight:500}.cax-nav-copyright-container .cax-nav-copyright span{margin:0 0 0 16px}.cax-nav-profile-options{padding:12px 24px;font-weight:600;line-height:24px;display:flex;align-items:center;cursor:pointer;border-radius:12px;margin-bottom:8px;font-size:16px}.cax-nav-profile-options span{margin-left:8px}.cax-nav-organisation-list{border-radius:12px;padding:8px;margin-bottom:8px}.cax-nav-organisation-container{display:flex;align-items:flex-start;cursor:pointer;padding:12px;border-radius:8px}.cax-nav-organisation-container .cax-nav-organisation-radio{margin-left:auto}.cax-nav-organisation-container:not(:last-child){margin-bottom:8px}.cax-nav-organisation{display:grid;margin:0 8px;white-space:nowrap}.cax-nav-organisation .cax-nav-organisation-name{font-weight:600;font-size:16px;line-height:24px}.cax-nav-organisation .cax-nav-organisation-plan{display:flex;font-size:14px;font-weight:500;line-height:21px}.cax-nav-organisation .cax-nav-organisation-plan i{font-size:20px;margin-right:3px}.cax-nav-overlay-expand{left:270px!important;top:auto!important;bottom:6px}.cax-nav-overlay{left:94px!important;top:auto!important;bottom:6px}}\n"], dependencies: [{ kind: "ngmodule", type: LogoModule }, { kind: "component", type: i1.Logo, selector: "cax-logo", inputs: ["size", "width", "height", "iconOnly", "darkMode"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: DividerModule }, { kind: "component", type: i3.Divider, selector: "cax-divider", inputs: ["style", "styleClass", "layout", "type", "align"] }, { kind: "ngmodule", type: ImageModule }, { kind: "component", type: i4.Image, selector: "cax-image", inputs: ["imageClass", "imageStyle", "styleClass", "style", "src", "srcSet", "sizes", "size", "previewImageSrc", "previewImageSrcSet", "previewImageSizes", "alt", "width", "height", "loading", "appendTo", "preview", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onShow", "onHide", "onImageError"] }, { kind: "ngmodule", type: AvatarModule }, { kind: "component", type: i5.Avatar, selector: "cax-avatar", inputs: ["label", "icon", "image", "avatarSize", "shape", "style", "styleClass", "ariaLabel", "ariaLabelledBy"], outputs: ["onImageError"] }, { kind: "ngmodule", type: OverlayPanelModule }, { kind: "component", type: i6.OverlayPanel, selector: "cax-overlayPanel", inputs: ["ariaLabel", "ariaLabelledBy", "dismissable", "showCloseIcon", "style", "styleClass", "appendTo", "autoZIndex", "ariaCloseLabel", "baseZIndex", "focusOnShow", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onShow", "onHide"] }, { kind: "ngmodule", type: OverlayModule }, { kind: "ngmodule", type: RadioButtonModule }, { kind: "component", type: i7.RadioButton, selector: "cax-radioButton", inputs: ["value", "formControlName", "name", "disabled", "label", "variant", "tabindex", "inputId", "ariaLabelledBy", "ariaLabel", "style", "styleClass", "labelStyleClass", "autofocus"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i8.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], animations: [
179
185
  trigger('leftFade', [
180
186
  transition(':enter', [style({ transform: 'translateX(-100%)', opacity: 0 }), animate('300ms', style({ transform: 'translateX(0)', opacity: 1 }))]),
181
187
  transition(':leave', [style({ transform: 'translateX(0)', opacity: 0.5 }), animate('300ms', style({ transform: 'translateX(-100%)', opacity: 0 }))])
@@ -199,7 +205,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
199
205
  ])
200
206
  ], host: {
201
207
  class: 'cax-element'
202
- }, template: "<div *ngIf=\"accountDetailsActive\" class=\"cax-nav-backdrop\"></div>\r\n<div class=\"cax-nav\" [ngClass]=\"{ 'cax-nav-expand': expanded }\">\r\n <div class=\"cax-nav-toggle\" (click)=\"toggleSidebar()\">\r\n <i class=\"cax cax-alt-arrow-right\"></i>\r\n </div>\r\n <div class=\"cax-nav-header-container\" #headerContainer>\r\n <div [@rightFade] *ngIf=\"!expanded\" class=\"cax-nav-header\">\r\n <cax-logo size=\"xsm\" [iconOnly]=\"true\" />\r\n </div>\r\n <div *ngIf=\"expanded\" class=\"cax-nav-header\" [@leftFade]>\r\n <cax-logo size=\"xsm\" />\r\n <cax-divider layout=\"vertical\"></cax-divider>\r\n <span>{{ header }}</span>\r\n </div>\r\n </div>\r\n <div class=\"cax-nav-list-container\" [style.maxHeight.px]=\"adjustUpDivHeight()\">\r\n <ul>\r\n <li *ngFor=\"let nav of topNavList, let i = index\" [ngClass]=\"{ active: nav.active }\" (click)=\"onItemClick($event, nav, i, 'top')\">\r\n <i *ngIf=\"nav.icon; else imageTemplate\" [class]=\"'cax pi ' + nav.icon\"></i>\r\n <ng-template #imageTemplate>\r\n <cax-image [src]=\"nav.image\" width=\"24px\" height=\"24px\"></cax-image>\r\n </ng-template>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">{{ nav.label }}</span>\r\n </li>\r\n </ul>\r\n </div>\r\n <div class=\"cax-nav-bottom-container\" #bottomContainer>\r\n <div class=\"cax-nav-bottom-list\">\r\n <ul>\r\n <li *ngFor=\"let nav of bottomNavList, let i = index\" [ngClass]=\"{ active: nav.active }\" (click)=\"onItemClick($event, nav, i, 'bottom')\">\r\n <i *ngIf=\"nav.icon; else imageTemplate\" [class]=\"'cax pi ' + nav.icon\"></i>\r\n <ng-template #imageTemplate>\r\n <cax-image [src]=\"nav.image\" width=\"24px\" height=\"24px\"></cax-image>\r\n </ng-template>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">{{ nav.label }}</span>\r\n </li>\r\n <li *ngIf=\"notifications\" (click)=\"emitNotification()\" [ngClass]=\"{ active: notificationActive }\">\r\n <i class=\"cax cax-bell\"></i>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">Notifications</span>\r\n </li>\r\n <li *ngIf=\"helpCentre\" (click)=\"emitHelpCentre()\" [ngClass]=\"{ active: helpCentreActive }\">\r\n <i class=\"cax cax-shield-check\"></i>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">Help Centre</span>\r\n </li>\r\n </ul>\r\n </div>\r\n <div *ngIf=\"userName\" (click)=\"op.toggle($event);\" [ngClass]=\"{ active: accountDetailsActive }\" class=\"cax-nav-account-details\">\r\n <cax-avatar *ngIf=\"userImage\" [image]=\"userImage\" avatarSize=\"lg\"></cax-avatar>\r\n <cax-avatar *ngIf=\"!userImage\" [label]=\"getInitials(userName)\" avatarSize=\"lg\"></cax-avatar>\r\n <div [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-user\">\r\n <span class=\"cax-nav-user-name\">{{ userName }}</span>\r\n <span class=\"cax-nav-user-role\">{{ userRole }}</span>\r\n </div>\r\n <div [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-account-icon\">\r\n <i class=\"cax cax-alt-arrow-up\"></i>\r\n <i class=\"cax cax-alt-arrow-down\"></i>\r\n </div>\r\n <cax-overlayPanel #op (onShow)=\"accountDetailsActive = true\" [styleClass]=\"expanded ? 'cax-nav-overlay-expand' : 'cax-nav-overlay'\" (onHide)=\"accountDetailsActive = false\">\r\n <div *ngIf=\"organisationDetails?.length\" class=\"cax-nav-organisation-list\">\r\n <div *ngFor=\"let org of organisationDetails; let i = index\" class=\"cax-nav-organisation-container\" (click)=\"onPlanClick(org, i)\" [ngClass]=\"{ active: selectedOrganisastionPlan == i }\">\r\n <cax-avatar *ngIf=\"org.image; else labelTemplate\" [image]=\"org.image\" avatarSize=\"lg\"></cax-avatar>\r\n <ng-template #labelTemplate>\r\n <cax-avatar *ngIf=\"org.label; else initialTemplate\" [label]=\"org.label\" avatarSize=\"lg\"></cax-avatar>\r\n </ng-template>\r\n <ng-template #initialTemplate>\r\n <cax-avatar [label]=\"getInitials(org.name)\" avatarSize=\"lg\"></cax-avatar>\r\n </ng-template>\r\n <div class=\"cax-nav-organisation\">\r\n <span class=\"cax-nav-organisation-name\">{{ org.name }}</span>\r\n <span *ngIf=\"org.plan == 'paid'\" class=\"cax-nav-organisation-plan\">\r\n <i class=\"cax cax-wallet\"></i>\r\n Paid Plan\r\n </span>\r\n <span *ngIf=\"org.plan == 'free'\" class=\"cax-nav-organisation-plan\">\r\n <i class=\"cax cax-ticket-sale\"></i>\r\n Free Plan\r\n </span>\r\n <span *ngIf=\"org.plan == 'trial'\" class=\"cax-nav-organisation-plan\">\r\n <i class=\"cax cax-history2\"></i>\r\n Trial Version\r\n </span>\r\n </div>\r\n <cax-radioButton class=\"cax-nav-organisation-radio\" [value]=\"i\" name=\"organisation-plan\" [(ngModel)]=\"selectedOrganisastionPlan\"></cax-radioButton>\r\n </div>\r\n </div>\r\n <div *ngIf=\"settings\" class=\"cax-nav-profile-options\" (click)=\"emitSettings()\">\r\n <i class=\"cax cax-settings\"></i>\r\n <span>Account Settings</span>\r\n </div>\r\n <div *ngIf=\"profile\" class=\"cax-nav-profile-options\" (click)=\"emitProfile()\">\r\n <i class=\"cax cax-user-rounded\"></i>\r\n <span>View Profile</span>\r\n </div>\r\n <div *ngIf=\"logout\" class=\"cax-nav-profile-options cax-nav-logout\" (click)=\"emitLogout()\">\r\n <i class=\"cax cax-logout\"></i>\r\n <span>Logout</span>\r\n </div>\r\n <div class=\"cax-nav-copyright-container\">\r\n <cax-logo width=\"55px\" height=\"17px\"></cax-logo>\r\n <div class=\"cax-nav-copyright\">\r\n <span *ngIf=\"copyrightYear\">&copy; {{ copyrightYear }}</span>\r\n <span *ngIf=\"version\">{{ version }}</span>\r\n </div>\r\n </div>\r\n </cax-overlayPanel>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: ["@layer cax{.cax-nav{width:88px;height:100vh;transition:width .3s ease-in-out;overflow:hidden;padding:16px 8px;position:absolute;left:0;top:0;z-index:1200}.cax-nav.cax-nav-expand{width:264px}.cax-nav.cax-nav-expand .cax-nav-header-container{margin-right:10px}.cax-nav-header-container{display:flex;align-items:center;justify-content:center;height:64px}.cax-nav-header{display:flex;align-items:center;justify-content:center}.cax-nav-header span{font-weight:700;font-size:12px}.cax-nav-toggle{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;position:fixed;cursor:pointer;transition:transform .3s ease-in-out,left .3s ease-in-out}.cax-nav .cax-nav-toggle{left:68px;top:28px}.cax-nav.cax-nav-expand .cax-nav-toggle{left:244px;transform:rotate(180deg)}.cax-nav .cax-divider.cax-divider-vertical{margin:0 8px;height:36px}.cax-nav-list-container,.cax-nav-bottom-list{margin:24px 0}.cax-nav-list-container ul,.cax-nav-bottom-list ul{margin:0;padding:0;list-style-type:none;display:flex;flex-direction:column;gap:16px}.cax-nav-list-container ul li,.cax-nav-bottom-list ul li{padding:12px 24px;border-radius:12px;display:flex;align-items:center;cursor:pointer;height:56px;line-height:24px}.cax-nav-list-container{overflow-y:auto}.cax-nav-list-container::-webkit-scrollbar{display:none}.cax-nav-bottom-container{position:absolute;bottom:16px}.cax-nav-account-details{border-radius:12px;padding:12px;cursor:pointer;transition:width .3s ease-in-out;display:flex;align-items:flex-start}.cax-nav-account-details .cax-nav-account-icon{display:grid;margin-left:auto}.cax-nav.cax-nav-expand .cax-nav-account-details{width:248px}.cax-nav-user{display:grid;margin:0 8px;white-space:nowrap}.cax-nav-user .cax-nav-user-name{font-size:16px;font-weight:500;line-height:24px}.cax-nav-user .cax-nav-user-role{font-size:14px;font-weight:400;line-height:21px}.cax-overlaypanel{width:320px}.cax-overlaypanel .cax-overlaypanel-content{padding:8px}.cax-nav-copyright-container{display:flex;align-items:center;justify-content:space-between}.cax-nav-copyright-container .cax-nav-copyright{font-size:12px;font-weight:500}.cax-nav-copyright-container .cax-nav-copyright span{margin:0 0 0 16px}.cax-nav-profile-options{padding:12px 24px;font-weight:600;line-height:24px;display:flex;align-items:center;cursor:pointer;border-radius:12px;margin-bottom:8px;font-size:16px}.cax-nav-profile-options span{margin-left:8px}.cax-nav-organisation-list{border-radius:12px;padding:8px;margin-bottom:8px}.cax-nav-organisation-container{display:flex;align-items:flex-start;cursor:pointer;padding:12px;border-radius:8px}.cax-nav-organisation-container .cax-nav-organisation-radio{margin-left:auto}.cax-nav-organisation-container:not(:last-child){margin-bottom:8px}.cax-nav-organisation{display:grid;margin:0 8px;white-space:nowrap}.cax-nav-organisation .cax-nav-organisation-name{font-weight:600;font-size:16px;line-height:24px}.cax-nav-organisation .cax-nav-organisation-plan{display:flex;font-size:14px;font-weight:500;line-height:21px}.cax-nav-organisation .cax-nav-organisation-plan i{font-size:20px;margin-right:3px}.cax-nav-overlay-expand{left:270px!important;top:auto!important;bottom:6px}.cax-nav-overlay{left:94px!important;top:auto!important;bottom:6px}}\n"] }]
208
+ }, template: "<div *ngIf=\"accountDetailsActive\" class=\"cax-nav-backdrop\"></div>\r\n<div class=\"cax-nav\" [ngClass]=\"{ 'cax-nav-expand': expanded }\">\r\n <div class=\"cax-nav-toggle\" (click)=\"toggleSidebar()\">\r\n <i class=\"cax cax-alt-arrow-right\"></i>\r\n </div>\r\n <div class=\"cax-nav-header-container\" #headerContainer>\r\n <div [@rightFade] *ngIf=\"!expanded\" class=\"cax-nav-header\">\r\n <cax-logo size=\"xsm\" [iconOnly]=\"true\" />\r\n </div>\r\n <div *ngIf=\"expanded\" class=\"cax-nav-header\" [@leftFade]>\r\n <cax-logo size=\"xsm\" />\r\n <cax-divider layout=\"vertical\"></cax-divider>\r\n <span>{{ header }}</span>\r\n </div>\r\n </div>\r\n <div class=\"cax-nav-list-container\" [style.maxHeight.px]=\"adjustUpDivHeight()\">\r\n <ul>\r\n <li *ngFor=\"let nav of topNavList, let i = index\" [ngClass]=\"{ active: nav.active }\" (click)=\"onItemClick($event, nav, i, 'top')\">\r\n <i *ngIf=\"nav.icon; else imageTemplate\" [class]=\"'cax pi ' + nav.icon\"></i>\r\n <ng-template #imageTemplate>\r\n <cax-image [src]=\"nav.image\" width=\"24px\" height=\"24px\"></cax-image>\r\n </ng-template>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">{{ nav.label }}</span>\r\n </li>\r\n </ul>\r\n </div>\r\n <div class=\"cax-nav-bottom-container\" #bottomContainer>\r\n <div class=\"cax-nav-bottom-list\">\r\n <ul>\r\n <li *ngFor=\"let nav of bottomNavList, let i = index\" [ngClass]=\"{ active: nav.active }\" (click)=\"onItemClick($event, nav, i, 'bottom')\">\r\n <i *ngIf=\"nav.icon; else imageTemplate\" [class]=\"'cax pi ' + nav.icon\"></i>\r\n <ng-template #imageTemplate>\r\n <cax-image [src]=\"nav.image\" width=\"24px\" height=\"24px\"></cax-image>\r\n </ng-template>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">{{ nav.label }}</span>\r\n </li>\r\n <li *ngIf=\"notifications\" (click)=\"emitNotification()\" [ngClass]=\"{ active: notificationActive }\">\r\n <i class=\"cax cax-bell\"></i>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">Notifications</span>\r\n </li>\r\n <li *ngIf=\"helpCentre\" (click)=\"emitHelpCentre()\" [ngClass]=\"{ active: helpCentreActive }\">\r\n <i class=\"cax cax-question-circle\"></i>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">Help Centre</span>\r\n </li>\r\n </ul>\r\n </div>\r\n <div *ngIf=\"userName\" (click)=\"op.toggle($event);\" [ngClass]=\"{ active: accountDetailsActive }\" class=\"cax-nav-account-details\">\r\n <cax-avatar *ngIf=\"userImage\" [image]=\"userImage\" avatarSize=\"lg\"></cax-avatar>\r\n <cax-avatar *ngIf=\"!userImage\" [label]=\"getInitials(userName)\" avatarSize=\"lg\"></cax-avatar>\r\n <div [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-user\">\r\n <span class=\"cax-nav-user-name\">{{ userName }}</span>\r\n <span class=\"cax-nav-user-role\">{{ userRole }}</span>\r\n </div>\r\n <div [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-account-icon\">\r\n <i class=\"cax cax-alt-arrow-up\"></i>\r\n <i class=\"cax cax-alt-arrow-down\"></i>\r\n </div>\r\n <cax-overlayPanel #op (onShow)=\"accountDetailsActive = true\" [styleClass]=\"expanded ? 'cax-nav-overlay-expand' : 'cax-nav-overlay'\" (onHide)=\"accountDetailsActive = false\">\r\n <div *ngIf=\"organisationDetails?.length\" class=\"cax-nav-organisation-list\">\r\n <div *ngFor=\"let org of organisationDetails; let i = index\" class=\"cax-nav-organisation-container\" (click)=\"onPlanClick(org, i)\" [ngClass]=\"{ active: selectedOrganisastionPlan == i }\">\r\n <cax-avatar *ngIf=\"org.image; else labelTemplate\" [image]=\"org.image\" avatarSize=\"lg\"></cax-avatar>\r\n <ng-template #labelTemplate>\r\n <cax-avatar *ngIf=\"org.label; else initialTemplate\" [label]=\"org.label\" avatarSize=\"lg\"></cax-avatar>\r\n </ng-template>\r\n <ng-template #initialTemplate>\r\n <cax-avatar [label]=\"getInitials(org.name)\" avatarSize=\"lg\"></cax-avatar>\r\n </ng-template>\r\n <div class=\"cax-nav-organisation\">\r\n <span class=\"cax-nav-organisation-name\">{{ org.name }}</span>\r\n <span *ngIf=\"org.plan == 'paid'\" class=\"cax-nav-organisation-plan\">\r\n <i class=\"cax cax-wallet\"></i>\r\n Paid Plan\r\n </span>\r\n <span *ngIf=\"org.plan == 'free'\" class=\"cax-nav-organisation-plan\">\r\n <i class=\"cax cax-ticket-sale\"></i>\r\n Free Plan\r\n </span>\r\n <span *ngIf=\"org.plan == 'trial'\" class=\"cax-nav-organisation-plan\">\r\n <i class=\"cax cax-history2\"></i>\r\n Trial Version\r\n </span>\r\n </div>\r\n <cax-radioButton class=\"cax-nav-organisation-radio\" [value]=\"i\" name=\"organisation-plan\" [(ngModel)]=\"selectedOrganisastionPlan\"></cax-radioButton>\r\n </div>\r\n </div>\r\n <div *ngIf=\"settings\" class=\"cax-nav-profile-options\" (click)=\"emitSettings()\">\r\n <i class=\"cax cax-settings\"></i>\r\n <span>Account Settings</span>\r\n </div>\r\n <div *ngIf=\"profile\" class=\"cax-nav-profile-options\" (click)=\"emitProfile()\">\r\n <i class=\"cax cax-user-rounded\"></i>\r\n <span>View Profile</span>\r\n </div>\r\n <div *ngIf=\"logout\" class=\"cax-nav-profile-options cax-nav-logout\" (click)=\"emitLogout()\">\r\n <i class=\"cax cax-logout\"></i>\r\n <span>Logout</span>\r\n </div>\r\n <div class=\"cax-nav-copyright-container\">\r\n <cax-logo width=\"55px\" height=\"17px\"></cax-logo>\r\n <div class=\"cax-nav-copyright\">\r\n <span *ngIf=\"copyrightYear\">&copy; {{ copyrightYear }}</span>\r\n <span *ngIf=\"version\">{{ version }}</span>\r\n </div>\r\n </div>\r\n </cax-overlayPanel>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: ["@layer cax{.cax-nav{width:88px;height:100vh;transition:width .3s ease-in-out;overflow:hidden;padding:16px 8px;position:absolute;left:0;top:0;z-index:1200}.cax-nav.cax-nav-expand{width:264px}.cax-nav.cax-nav-expand .cax-nav-header-container{margin-right:10px}.cax-nav-header-container{display:flex;align-items:center;justify-content:center;height:64px}.cax-nav-header{display:flex;align-items:center;justify-content:center}.cax-nav-header span{font-weight:700;font-size:12px}.cax-nav-toggle{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;position:fixed;cursor:pointer;transition:transform .3s ease-in-out,left .3s ease-in-out}.cax-nav .cax-nav-toggle{left:68px;top:28px}.cax-nav.cax-nav-expand .cax-nav-toggle{left:244px;transform:rotate(180deg)}.cax-nav .cax-divider.cax-divider-vertical{margin:0 8px;height:36px}.cax-nav-list-container,.cax-nav-bottom-list{margin:24px 0}.cax-nav-list-container ul,.cax-nav-bottom-list ul{margin:0;padding:0;list-style-type:none;display:flex;flex-direction:column;gap:16px}.cax-nav-list-container ul li,.cax-nav-bottom-list ul li{padding:12px 24px;border-radius:12px;display:flex;align-items:center;cursor:pointer;height:56px;line-height:24px}.cax-nav-list-container{overflow-y:auto}.cax-nav-list-container::-webkit-scrollbar{display:none}.cax-nav-bottom-container{position:absolute;bottom:16px}.cax-nav-account-details{border-radius:12px;padding:12px;cursor:pointer;transition:width .3s ease-in-out;display:flex;align-items:flex-start}.cax-nav-account-details .cax-nav-account-icon{display:grid;margin-left:auto}.cax-nav.cax-nav-expand .cax-nav-account-details{width:248px}.cax-nav-user{display:grid;margin:0 8px;white-space:nowrap}.cax-nav-user .cax-nav-user-name{font-size:16px;font-weight:500;line-height:24px}.cax-nav-user .cax-nav-user-role{font-size:14px;font-weight:400;line-height:21px}.cax-overlaypanel{width:320px}.cax-overlaypanel .cax-overlaypanel-content{padding:8px}.cax-nav-copyright-container{display:flex;align-items:center;justify-content:space-between}.cax-nav-copyright-container .cax-nav-copyright{font-size:12px;font-weight:500}.cax-nav-copyright-container .cax-nav-copyright span{margin:0 0 0 16px}.cax-nav-profile-options{padding:12px 24px;font-weight:600;line-height:24px;display:flex;align-items:center;cursor:pointer;border-radius:12px;margin-bottom:8px;font-size:16px}.cax-nav-profile-options span{margin-left:8px}.cax-nav-organisation-list{border-radius:12px;padding:8px;margin-bottom:8px}.cax-nav-organisation-container{display:flex;align-items:flex-start;cursor:pointer;padding:12px;border-radius:8px}.cax-nav-organisation-container .cax-nav-organisation-radio{margin-left:auto}.cax-nav-organisation-container:not(:last-child){margin-bottom:8px}.cax-nav-organisation{display:grid;margin:0 8px;white-space:nowrap}.cax-nav-organisation .cax-nav-organisation-name{font-weight:600;font-size:16px;line-height:24px}.cax-nav-organisation .cax-nav-organisation-plan{display:flex;font-size:14px;font-weight:500;line-height:21px}.cax-nav-organisation .cax-nav-organisation-plan i{font-size:20px;margin-right:3px}.cax-nav-overlay-expand{left:270px!important;top:auto!important;bottom:6px}.cax-nav-overlay{left:94px!important;top:auto!important;bottom:6px}}\n"] }]
203
209
  }], propDecorators: { expanded: [{
204
210
  type: Input
205
211
  }], header: [{
@@ -258,4 +264,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
258
264
  type: HostListener,
259
265
  args: ['window:resize']
260
266
  }] } });
261
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2aWdhdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hcHAvY29tcG9uZW50cy9uYXZpZ2F0aW9uL25hdmlnYXRpb24udHMiLCIuLi8uLi8uLi9zcmMvYXBwL2NvbXBvbmVudHMvbmF2aWdhdGlvbi9uYXZpZ2F0aW9uLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE9BQU8sRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFFLE9BQU8sRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQzFFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsU0FBUyxFQUFFLHVCQUF1QixFQUFFLGlCQUFpQixFQUFFLEtBQUssRUFBRSxZQUFZLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBYyxZQUFZLEVBQTRCLE1BQU0sZUFBZSxDQUFDO0FBQ2xMLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFFcEQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3RELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUN4RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNwRSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDMUQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDbEUsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDOzs7Ozs7Ozs7O0FBd0I3QyxNQUFNLE9BQU8sVUFBVTtJQUNWLFFBQVEsR0FBWSxJQUFJLENBQUM7SUFDekIsTUFBTSxDQUFxQjtJQUMzQixVQUFVLENBQWdCO0lBQzFCLGFBQWEsQ0FBZ0I7SUFDN0IsU0FBUyxDQUFp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QUNHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csYUFBYTtzQkFBckIsS0FBSztnQkFDRyxVQUFVO3NCQUFsQixLQUFLO2dCQUNHLGFBQWE7c0JBQXJCLEtBQUs7Z0JBQ0csT0FBTztzQkFBZixLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSztnQkFDRyxPQUFPO3NCQUFmLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxRQUFRO3NCQUFoQixLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxtQkFBbUI7c0JBQTNCLEtBQUs7Z0JBRUksa0JBQWtCO3NCQUEzQixNQUFNO2dCQUNHLG1CQUFtQjtzQkFBNUIsTUFBTTtnQkFDRyxtQkFBbUI7c0JBQTVCLE1BQU07Z0JBQ0csaUJBQWlCO3NCQUExQixNQUFNO2dCQUNHLGFBQWE7c0JBQXRCLE1BQU07Z0JBQ0csY0FBYztzQkFBdkIsTUFBTTtnQkFDRyxlQUFlO3NCQUF4QixNQUFNO2dCQUNHLFlBQVk7c0JBQXJCLE1BQU07Z0JBTXVCLGVBQWU7c0JBQTVDLFNBQVM7dUJBQUMsaUJBQWlCO2dCQUNFLGVBQWU7c0JBQTVDLFNBQVM7dUJBQUMsaUJBQWlCO2dCQStHNUIsUUFBUTtzQkFEUCxZQUFZO3VCQUFDLGVBQWUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB0cmlnZ2VyLCB0cmFuc2l0aW9uLCBzdHlsZSwgYW5pbWF0ZSB9IGZyb20gJ0Bhbmd1bGFyL2FuaW1hdGlvbnMnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCwgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIFZpZXdFbmNhcHN1bGF0aW9uLCBJbnB1dCwgRXZlbnRFbWl0dGVyLCBPdXRwdXQsIFZpZXdDaGlsZCwgRWxlbWVudFJlZiwgSG9zdExpc3RlbmVyLCBBZnRlclZpZXdJbml0LCBPbkNoYW5nZXMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERpdmlkZXJNb2R1bGUgfSBmcm9tICdjYXgtZGVzaWduLXN5c3RlbS9kaXZpZGVyJztcbmltcG9ydCB7IExvZ29Nb2R1bGUgfSBmcm9tICdjYXgtZGVzaWduLXN5c3RlbS9sb2dvJztcbmltcG9ydCB7IE5hdkxpc3RJdGVtLCBPcmdhbmlzYXRpb25EZXRhaWxzLCBUYWJJbmRleFR5cGUgfSBmcm9tICcuL25hdmlnYXRpb24uaW50ZXJmYWNlJztcbmltcG9ydCB7IEltYWdlTW9kdWxlIH0gZnJvbSAnY2F4LWRlc2lnbi1zeXN0ZW0vaW1hZ2UnO1xuaW1wb3J0IHsgQXZhdGFyTW9kdWxlIH0gZnJvbSAnY2F4LWRlc2lnbi1zeXN0ZW0vYXZhdGFyJztcbmltcG9ydCB7IE92ZXJsYXlQYW5lbE1vZHVsZSB9IGZyb20gJ2NheC1kZXNpZ24tc3lzdGVtL292ZXJsYXlwYW5lbCc7XG5pbXBvcnQgeyBPdmVybGF5TW9kdWxlIH0gZnJvbSAnY2F4LWRlc2lnbi1zeXN0ZW0vb3ZlcmxheSc7XG5pbXBvcnQgeyBSYWRpb0J1dHRvbk1vZHVsZSB9IGZyb20gJ2NheC1kZXNpZ24tc3lzdGVtL3JhZGlvYnV0dG9uJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2NheC1uYXZpZ2F0aW9uJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vbmF2aWdhdGlvbi5odG1sJyxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICAgIHN0eWxlVXJsczogWycuL25hdmlnYXRpb24uc2NzcyddLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW0xvZ29Nb2R1bGUsIENvbW1vbk1vZHVsZSwgRGl2aWRlck1vZHVsZSwgSW1hZ2VNb2R1bGUsIEF2YXRhck1vZHVsZSwgT3ZlcmxheVBhbmVsTW9kdWxlLCBPdmVybGF5TW9kdWxlLCBSYWRpb0J1dHRvbk1vZHVsZSwgRm9ybXNNb2R1bGVdLFxuICAgIGFuaW1hdGlvbnM6IFtcbiAgICAgICAgdHJpZ2dlcignbGVmdEZhZGUnLCBbXG4gICAgICAgICAgICB0cmFuc2l0aW9uKCc6ZW50ZXInLCBbc3R5bGUoeyB0cmFuc2Zvcm06ICd0cmFuc2xhdGVYKC0xMDAlKScsIG9wYWNpdHk6IDAgfSksIGFuaW1hdGUoJzMwMG1zJywgc3R5bGUoeyB0cmFuc2Zvcm06ICd0cmFuc2xhdGVYKDApJywgb3BhY2l0eTogMSB9KSldKSxcbiAgICAgICAgICAgIHRyYW5zaXRpb24oJzpsZWF2ZScsIFtzdHlsZSh7IHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVgoMCknLCBvcGFjaXR5OiAwLjUgfSksIGFuaW1hdGUoJzMwMG1zJywgc3R5bGUoeyB0cmFuc2Zvcm06ICd0cmFuc2xhdGVYKC0xMDAlKScsIG9wYWNpdHk6IDAgfSkpXSlcbiAgICAgICAgXSksXG4gICAgICAgIHRyaWdnZXIoJ3JpZ2h0RmFkZScsIFtcbiAgICAgICAgICAgIHRyYW5zaXRpb24oJzplbnRlcicsIFtzdHlsZSh7IHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVgoMjAwJSknLCBvcGFjaXR5OiAwIH0pLCBhbmltYXRlKCczMDBtcycsIHN0eWxlKHsgdHJhbnNmb3JtOiAndHJhbnNsYXRlWCgwKScsIG9wYWNpdHk6IDEgfSkpXSksXG4gICAgICAgICAgICB0cmFuc2l0aW9uKCc6bGVhdmUnLCBbc3R5bGUoeyB0cmFuc2Zvcm06ICd0cmFuc2xhdGVYKDApJywgb3BhY2l0eTogMSB9KSwgYW5pbWF0ZSgnMzAwbXMnLCBzdHlsZSh7IHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVgoMTAwJSknLCBvcGFjaXR5OiAwIH0pKV0pXG4gICAgICAgIF0pXG4gICAgXSxcbiAgICBob3N0OiB7XG4gICAgICAgIGNsYXNzOiAnY2F4LWVsZW1lbnQnXG4gICAgfVxufSlcbmV4cG9ydCBjbGFzcyBOYXZpZ2F0aW9uIGltcGxlbWVudHMgT25DaGFuZ2VzLCBBZnRlclZpZXdJbml0IHtcbiAgICBASW5wdXQoKSBleHBhbmRlZDogYm9vbGVhbiA9IHRydWU7XG4gICAgQElucHV0KCkgaGVhZGVyOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gICAgQElucHV0KCkgdG9wTmF2TGlzdDogTmF2TGlzdEl0ZW1bXTtcbiAgICBASW5wdXQoKSBib3R0b21OYXZMaXN0OiBOYXZMaXN0SXRlbVtdO1xuICAgIEBJbnB1dCgpIGFjdGl2ZVRhYjogVGFiSW5kZXhUeXBlIHwgJ25vdGlmaWNhdGlvbnMnIHwgJ2hlbHAtY2VudHJlJztcbiAgICBASW5wdXQoKSBub3RpZmljYXRpb25zOiBib29sZWFuID0gdHJ1ZTtcbiAgICBASW5wdXQoKSBoZWxwQ2VudHJlOiBib29sZWFuID0gdHJ1ZTtcbiAgICBASW5wdXQoKSBjb3B5cmlnaHRZZWFyOiBudW1iZXIgfCB1bmRlZmluZWQgPSBuZXcgRGF0ZSgpLmdldEZ1bGxZZWFyKCk7XG4gICAgQElucHV0KCkgdmVyc2lvbjogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICAgIEBJbnB1dCgpIGxvZ291dDogYm9vbGVhbiA9IHRydWU7XG4gICAgQElucHV0KCkgcHJvZmlsZTogYm9vbGVhbiA9IHRydWU7XG4gICAgQElucHV0KCkgc2V0dGluZ3M6IGJvb2xlYW4gPSB0cnVlO1xuICAgIEBJbnB1dCgpIHVzZXJOYW1lOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gICAgQElucHV0KCkgdXNlckltYWdlOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gICAgQElucHV0KCkgdXNlclJvbGU6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgICBASW5wdXQoKSBvcmdhbmlzYXRpb25EZXRhaWxzOiBPcmdhbmlzYXRpb25EZXRhaWxzW107XG5cbiAgICBAT3V0cHV0KCkgb25Ub2dnbGVOYXZpZ2F0aW9uOiBFdmVudEVtaXR0ZXI8eyBleHBhbmRlZDogYm9vbGVhbiB9PiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcbiAgICBAT3V0cHV0KCkgb25OYXZMaXN0SXRlbUNoYW5nZTogRXZlbnRFbWl0dGVyPHsgYWN0aXZlVGFiOiBUYWJJbmRleFR5cGUgfCAnbm90aWZpY2F0aW9ucycgfCAnaGVscC1jZW50cmUnIH0+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuICAgIEBPdXRwdXQoKSBvbk5vdGlmaWNhdGlvbkNsaWNrOiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcbiAgICBAT3V0cHV0KCkgb25IZWxwQ2VudHJlQ2xpY2s6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuICAgIEBPdXRwdXQoKSBvbkxvZ291dENsaWNrOiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcbiAgICBAT3V0cHV0KCkgb25Qcm9maWxlQ2xpY2s6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuICAgIEBPdXRwdXQoKSBvblNldHRpbmdzQ2xpY2s6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuICAgIEBPdXRwdXQoKSBvblBsYW5DaGFuZ2U6IEV2ZW50RW1pdHRlcjxPcmdhbmlzYXRpb25EZXRhaWxzPiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcblxuICAgIG5vdGlmaWNhdGlvbkFjdGl2ZTogYm9vbGVhbiA9IGZhbHNlO1xuICAgIGhlbHBDZW50cmVBY3RpdmU6IGJvb2xlYW4gPSBmYWxzZTtcbiAgICBhY2NvdW50RGV0YWlsc0FjdGl2ZTogYm9vbGVhbiA9IGZhbHNlO1xuICAgIHNlbGVjdGVkT3JnYW5pc2FzdGlvblBsYW46IG51bWJlcjtcbiAgICBAVmlld0NoaWxkKCdib3R0b21Db250YWluZXInKSBib3R0b21Db250YWluZXIhOiBFbGVtZW50UmVmPEhUTUxEaXZFbGVtZW50PjtcbiAgICBAVmlld0NoaWxkKCdoZWFkZXJDb250YWluZXInKSBoZWFkZXJDb250YWluZXIhOiBFbGVtZW50UmVmPEhUTUxEaXZFbGVtZW50PjtcblxuICAgIG5nT25DaGFuZ2VzKCkge1xuICAgICAgICBpZiAodGhpcy5hY3RpdmVUYWIgPT0gJ25vdGlmaWNhdGlvbnMnKSB7XG4gICAgICAgICAgICBpZiAodGhpcy5ub3RpZmljYXRpb25zKSB0aGlzLm5vdGlmaWNhdGlvbkFjdGl2ZSA9IHRydWU7XG4gICAgICAgICAgICBlbHNlIHRoaXMudG9wTmF2TGlzdFswXS5hY3RpdmUgPSB0cnVlO1xuICAgICAgICB9IGVsc2UgaWYgKHRoaXMuYWN0aXZlVGFiID09ICdoZWxwLWNlbnRyZScpIHtcbiAgICAgICAgICAgIGlmICh0aGlzLmhlbHBDZW50cmUpIHRoaXMuaGVscENlbnRyZUFjdGl2ZSA9IHRydWU7XG4gICAgICAgICAgICBlbHNlIHRoaXMudG9wTmF2TGlzdFswXS5hY3RpdmUgPSB0cnVlO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgaWYgKHRoaXMuYWN0aXZlVGFiPy5wb3NpdGlvbiA9PSAndG9wJykge1xuICAgICAgICAgICAgICAgIGlmICh0aGlzLmFjdGl2ZVRhYi5pbmRleCA+IC0xICYmIHRoaXMuYWN0aXZlVGFiLmluZGV4IDwgdGhpcy50b3BOYXZMaXN0Py5sZW5ndGgpIHtcbiAgICAgICAgICAgICAgICAgICAgdGhpcy50b3BOYXZMaXN0Py5tYXAoKGxpc3Q6IE5hdkxpc3RJdGVtKSA9PiAobGlzdC5hY3RpdmUgPSBmYWxzZSkpO1xuICAgICAgICAgICAgICAgICAgICB0aGlzLnRvcE5hdkxpc3RbdGhpcy5hY3RpdmVUYWIuaW5kZXhdLmFjdGl2ZSA9IHRydWU7XG4gICAgICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgaWYgKHRoaXMudG9wTmF2TGlzdD8uZmlsdGVyKChsaXN0OiBOYXZMaXN0SXRlbSkgPT4gbGlzdC5hY3RpdmUpLmxlbmd0aCA+IDApIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIGxldCBjb3VudCA9IDA7XG4gICAgICAgICAgICAgICAgICAgICAgICB0aGlzLnRvcE5hdkxpc3Q/LmZvckVhY2goKGxpc3Q6IE5hdkxpc3RJdGVtKSA9PiB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgaWYgKGxpc3QuYWN0aXZlICYmIGNvdW50ID09IDApIGNvdW50ID0gY291bnQgKyAxO1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGVsc2UgbGlzdC5hY3RpdmUgPSBmYWxzZTtcbiAgICAgICAgICAgICAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgICAgICAgICB9IGVsc2UgaWYgKCF0aGlzLnRvcE5hdkxpc3Q/LmZpbHRlcigobGlzdDogTmF2TGlzdEl0ZW0pID0+IGxpc3QuYWN0aXZlKS5sZW5ndGgpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHRoaXMudG9wTmF2TGlzdFswXS5hY3RpdmUgPSB0cnVlO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfSBlbHNlIGlmICh0aGlzLmFjdGl2ZVRhYj8ucG9zaXRpb24gPT0gJ2JvdHRvbScpIHtcbiAgICAgICAgICAgICAgICBpZiAodGhpcy5hY3RpdmVUYWIuaW5kZXggPiAtMSAmJiB0aGlzLmFjdGl2ZVRhYi5pbmRleCA8IHRoaXMuYm90dG9tTmF2TGlzdD8ubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgIHRoaXMuYm90dG9tTmF2TGlzdD8ubWFwKChsaXN0OiBOYXZMaXN0SXRlbSkgPT4gKGxpc3QuYWN0aXZlID0gZmFsc2UpKTtcbiAgICAgICAgICAgICAgICAgICAgdGhpcy5ib3R0b21OYXZMaXN0W3RoaXMuYWN0aXZlVGFiLmluZGV4XS5hY3RpdmUgPSB0cnVlO1xuICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgIGlmICh0aGlzLmJvdHRvbU5hdkxpc3Q/LmZpbHRlcigobGlzdDogTmF2TGlzdEl0ZW0pID0+IGxpc3QuYWN0aXZlKS5sZW5ndGggPiAwKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBsZXQgY291bnQgPSAwO1xuICAgICAgICAgICAgICAgICAgICAgICAgdGhpcy5ib3R0b21OYXZMaXN0Py5mb3JFYWNoKChsaXN0OiBOYXZMaXN0SXRlbSkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmIChsaXN0LmFjdGl2ZSAmJiBjb3VudCA9PSAwKSBjb3VudCA9IGNvdW50ICsgMTtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBlbHNlIGxpc3QuYWN0aXZlID0gZmFsc2U7XG4gICAgICAgICAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgICAgICAgICAgfSBlbHNlIGlmICghdGhpcy5ib3R0b21OYXZMaXN0Py5maWx0ZXIoKGxpc3Q6IE5hdkxpc3RJdGVtKSA9PiBsaXN0LmFjdGl2ZSkubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICB0aGlzLmJvdHRvbU5hdkxpc3RbMF0uYWN0aXZlID0gdHJ1ZTtcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgdGhpcy50b3BOYXZMaXN0WzBdLmFjdGl2ZSA9IHRydWU7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgdGhpcy5zZWxlY3RlZE9yZ2FuaXNhc3Rpb25QbGFuID0gMDtcbiAgICB9XG5cbiAgICBuZ0FmdGVyVmlld0luaXQoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuYWRqdXN0VXBEaXZIZWlnaHQoKTtcbiAgICB9XG5cbiAgICB0b2dnbGVTaWRlYmFyKCkge1xuICAgICAgICB0aGlzLmV4cGFuZGVkID0gIXRoaXMuZXhwYW5kZWQ7XG4gICAgICAgIHRoaXMub25Ub2dnbGVOYXZpZ2F0aW9uLmVtaXQoeyBleHBhbmRlZDogdGhpcy5leHBhbmRlZCB9KTtcbiAgICB9XG5cbiAgICBvbkl0ZW1DbGljayhlOiBNb3VzZUV2ZW50LCBpdGVtOiBOYXZMaXN0SXRlbSwgaW5kZXg6IG51bWJlciwgcG9zaXRpb246ICd0b3AnIHwgJ2JvdHRvbScpIHtcbiAgICAgICAgdGhpcy50b3BOYXZMaXN0Py5tYXAoKGxpc3Q6IE5hdkxpc3RJdGVtKSA9PiAobGlzdC5hY3RpdmUgPSBmYWxzZSkpO1xuICAgICAgICB0aGlzLmJvdHRvbU5hdkxpc3Q/Lm1hcCgobGlzdDogTmF2TGlzdEl0ZW0pID0+IChsaXN0LmFjdGl2ZSA9IGZhbHNlKSk7XG4gICAgICAgIHRoaXMubm90aWZpY2F0aW9uQWN0aXZlID0gZmFsc2U7XG4gICAgICAgIHRoaXMuaGVscENlbnRyZUFjdGl2ZSA9IGZhbHNlO1xuICAgICAgICBpZiAocG9zaXRpb24gPT0gJ3RvcCcpIHRoaXMudG9wTmF2TGlzdFtpbmRleF0uYWN0aXZlID0gdHJ1ZTtcbiAgICAgICAgZWxzZSBpZiAocG9zaXRpb24gPT0gJ2JvdHRvbScpIHRoaXMuYm90dG9tTmF2TGlzdFtpbmRleF0uYWN0aXZlID0gdHJ1ZTtcbiAgICAgICAgdGhpcy5vbk5hdkxpc3RJdGVtQ2hhbmdlLmVtaXQoeyBhY3RpdmVUYWI6IHsgcG9zaXRpb246IHBvc2l0aW9uLCBpbmRleDogaW5kZXggfSB9KTtcbiAgICAgICAgaWYgKGl0ZW0uY29tbWFuZCkge1xuICAgICAgICAgICAgaXRlbS5jb21tYW5kKHsgb3JpZ2luYWxFdmVudDogZSwgaXRlbSB9KTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIGdldEluaXRpYWxzKG5hbWU6IHN0cmluZyk6IHN0cmluZyB7XG4gICAgICAgIGlmICghbmFtZSkgcmV0dXJuICcnO1xuICAgICAgICBjb25zdCBuYW1lUGFydHMgPSBuYW1lLnRyaW0oKS5zcGxpdCgvXFxzKy8pO1xuICAgICAgICByZXR1cm4gKG5hbWVQYXJ0c1swXT8uWzBdIHx8ICcnKS50b1VwcGVyQ2FzZSgpICsgKG5hbWVQYXJ0c1tuYW1lUGFydHMubGVuZ3RoIC0gMV0/LlswXSB8fCAnJykudG9VcHBlckNhc2UoKTtcbiAgICB9XG5cbiAgICBlbWl0Tm90aWZpY2F0aW9uKCkge1xuICAgICAgICB0aGlzLnRvcE5hdkxpc3Q/Lm1hcCgobGlzdDogTmF2TGlzdEl0ZW0pID0+IChsaXN0LmFjdGl2ZSA9IGZhbHNlKSk7XG4gICAgICAgIHRoaXMuYm90dG9tTmF2TGlzdD8ubWFwKChsaXN0OiBOYXZMaXN0SXRlbSkgPT4gKGxpc3QuYWN0aXZlID0gZmFsc2UpKTtcbiAgICAgICAgdGhpcy5oZWxwQ2VudHJlQWN0aXZlID0gZmFsc2U7XG4gICAgICAgIHRoaXMubm90aWZpY2F0aW9uQWN0aXZlID0gdHJ1ZTtcbiAgICAgICAgdGhpcy5vbk5hdkxpc3RJdGVtQ2hhbmdlLmVtaXQoeyBhY3RpdmVUYWI6ICdub3RpZmljYXRpb25zJyB9KTtcbiAgICAgICAgdGhpcy5vbk5vdGlmaWNhdGlvbkNsaWNrLmVtaXQoKTtcbiAgICB9XG5cbiAgICBlbWl0SGVscENlbnRyZSgpIHtcbiAgICAgICAgdGhpcy50b3BOYXZMaXN0Py5tYXAoKGxpc3Q6IE5hdkxpc3RJdGVtKSA9PiAobGlzdC5hY3RpdmUgPSBmYWxzZSkpO1xuICAgICAgICB0aGlzLmJvdHRvbU5hdkxpc3Q/Lm1hcCgobGlzdDogTmF2TGlzdEl0ZW0pID0+IChsaXN0LmFjdGl2ZSA9IGZhbHNlKSk7XG4gICAgICAgIHRoaXMuaGVscENlbnRyZUFjdGl2ZSA9IHRydWU7XG4gICAgICAgIHRoaXMubm90aWZpY2F0aW9uQWN0aXZlID0gZmFsc2U7XG4gICAgICAgIHRoaXMub25OYXZMaXN0SXRlbUNoYW5nZS5lbWl0KHsgYWN0aXZlVGFiOiAnaGVscC1jZW50cmUnIH0pO1xuICAgICAgICB0aGlzLm9uSGVscENlbnRyZUNsaWNrLmVtaXQoKTtcbiAgICB9XG5cbiAgICBlbWl0TG9nb3V0KCkge1xuICAgICAgICB0aGlzLm9uTG9nb3V0Q2xpY2suZW1pdCgpO1xuICAgIH1cblxuICAgIGVtaXRQcm9maWxlKCkge1xuICAgICAgICB0aGlzLm9uUHJvZmlsZUNsaWNrLmVtaXQoKTtcbiAgICB9XG5cbiAgICBlbWl0U2V0dGluZ3MoKSB7XG4gICAgICAgIHRoaXMub25TZXR0aW5nc0NsaWNrLmVtaXQoKTtcbiAgICB9XG5cbiAgICBvblBsYW5DbGljayhvcmdEZXRhaWxzOiBPcmdhbmlzYXRpb25EZXRhaWxzLCBpbmRleDogbnVtYmVyKSB7XG4gICAgICAgIHRoaXMuc2VsZWN0ZWRPcmdhbmlzYXN0aW9uUGxhbiA9IGluZGV4O1xuICAgICAgICB0aGlzLm9uUGxhbkNoYW5nZS5lbWl0KG9yZ0RldGFpbHMpO1xuICAgIH1cblxuICAgIEBIb3N0TGlzdGVuZXIoJ3dpbmRvdzpyZXNpemUnKVxuICAgIG9uUmVzaXplKCk6IHZvaWQge1xuICAgICAgICB0aGlzLmFkanVzdFVwRGl2SGVpZ2h0KCk7XG4gICAgfVxuXG4gICAgYWRqdXN0VXBEaXZIZWlnaHQoKSB7XG4gICAgICAgIGNvbnN0IGJvdHRvbUhlaWdodCA9IHRoaXMuYm90dG9tQ29udGFpbmVyPy5uYXRpdmVFbGVtZW50Lm9mZnNldEhlaWdodDtcbiAgICAgICAgY29uc3QgaGVhZGVySGVpZ2h0ID0gdGhpcy5oZWFkZXJDb250YWluZXI/Lm5hdGl2ZUVsZW1lbnQub2Zmc2V0SGVpZ2h0O1xuICAgICAgICBjb25zdCBjb250YWluZXJIZWlnaHQgPSB3aW5kb3cuaW5uZXJIZWlnaHQ7XG4gICAgICAgIHJldHVybiBjb250YWluZXJIZWlnaHQgLSBib3R0b21IZWlnaHQgLSBoZWFkZXJIZWlnaHQgLSA1NjtcbiAgICB9XG59XG4iLCI8ZGl2ICpuZ0lmPVwiYWNjb3VudERldGFpbHNBY3RpdmVcIiBjbGFzcz1cImNheC1uYXYtYmFja2Ryb3BcIj48L2Rpdj5cclxuPGRpdiBjbGFzcz1cImNheC1uYXZcIiBbbmdDbGFzc109XCJ7ICdjYXgtbmF2LWV4cGFuZCc6IGV4cGFuZGVkIH1cIj5cclxuICAgIDxkaXYgY2xhc3M9XCJjYXgtbmF2LXRvZ2dsZVwiIChjbGljayk9XCJ0b2dnbGVTaWRlYmFyKClcIj5cclxuICAgICAgICA8aSBjbGFzcz1cImNheCBjYXgtYWx0LWFycm93LXJpZ2h0XCI+PC9pPlxyXG4gICAgPC9kaXY+XHJcbiAgICA8ZGl2IGNsYXNzPVwiY2F4LW5hdi1oZWFkZXItY29udGFpbmVyXCIgI2hlYWRlckNvbnRhaW5lcj5cclxuICAgICAgICA8ZGl2IFtAcmlnaHRGYWRlXSAqbmdJZj1cIiFleHBhbmRlZFwiIGNsYXNzPVwiY2F4LW5hdi1oZWFkZXJcIj5cclxuICAgICAgICAgICAgPGNheC1sb2dvIHNpemU9XCJ4c21cIiBbaWNvbk9ubHldPVwidHJ1ZVwiIC8+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgPGRpdiAqbmdJZj1cImV4cGFuZGVkXCIgY2xhc3M9XCJjYXgtbmF2LWhlYWRlclwiIFtAbGVmdEZhZGVdPlxyXG4gICAgICAgICAgICA8Y2F4LWxvZ28gc2l6ZT1cInhzbVwiIC8+XHJcbiAgICAgICAgICAgIDxjYXgtZGl2aWRlciBsYXlvdXQ9XCJ2ZXJ0aWNhbFwiPjwvY2F4LWRpdmlkZXI+XHJcbiAgICAgICAgICAgIDxzcGFuPnt7IGhlYWRlciB9fTwvc3Bhbj5cclxuICAgICAgICA8L2Rpdj5cclxuICAgIDwvZGl2PlxyXG4gICAgPGRpdiBjbGFzcz1cImNheC1uYXYtbGlzdC1jb250YWluZXJcIiBbc3R5bGUubWF4SGVpZ2h0LnB4XT1cImFkanVzdFVwRGl2SGVpZ2h0KClcIj5cclxuICAgICAgICA8dWw+XHJcbiAgICAgICAgICAgIDxsaSAqbmdGb3I9XCJsZXQgbmF2IG9mIHRvcE5hdkxpc3QsIGxldCBpID0gaW5kZXhcIiBbbmdDbGFzc109XCJ7IGFjdGl2ZTogbmF2LmFjdGl2ZSB9XCIgKGNsaWNrKT1cIm9uSXRlbUNsaWNrKCRldmVudCwgbmF2LCBpLCAndG9wJylcIj5cclxuICAgICAgICAgICAgICAgIDxpICpuZ0lmPVwibmF2Lmljb247IGVsc2UgaW1hZ2VUZW1wbGF0ZVwiIFtjbGFzc109XCInY2F4IHBpICcgKyBuYXYuaWNvblwiPjwvaT5cclxuICAgICAgICAgICAgICAgIDxuZy10ZW1wbGF0ZSAjaW1hZ2VUZW1wbGF0ZT5cclxuICAgICAgICAgICAgICAgICAgICA8Y2F4LWltYWdlIFtzcmNdPVwibmF2LmltYWdlXCIgd2lkdGg9XCIyNHB4XCIgaGVpZ2h0PVwiMjRweFwiPjwvY2F4LWltYWdlPlxyXG4gICAgICAgICAgICAgICAgPC9uZy10ZW1wbGF0ZT5cclxuICAgICAgICAgICAgICAgIDxzcGFuIFtAbGVmdEZhZGVdICpuZ0lmPVwiZXhwYW5kZWRcIiBjbGFzcz1cImNheC1uYXYtbGlzdC1sYWJlbFwiPnt7IG5hdi5sYWJlbCB9fTwvc3Bhbj5cclxuICAgICAgICAgICAgPC9saT5cclxuICAgICAgICA8L3VsPlxyXG4gICAgPC9kaXY+XHJcbiAgICA8ZGl2IGNsYXNzPVwiY2F4LW5hdi1ib3R0b20tY29udGFpbmVyXCIgI2JvdHRvbUNvbnRhaW5lcj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwiY2F4LW5hdi1ib3R0b20tbGlzdFwiPlxyXG4gICAgICAgICAgICA8dWw+XHJcbiAgICAgICAgICAgICAgICA8bGkgKm5nRm9yPVwibGV0IG5hdiBvZiBib3R0b21OYXZMaXN0LCBsZXQgaSA9IGluZGV4XCIgW25nQ2xhc3NdPVwieyBhY3RpdmU6IG5hdi5hY3RpdmUgfVwiIChjbGljayk9XCJvbkl0ZW1DbGljaygkZXZlbnQsIG5hdiwgaSwgJ2JvdHRvbScpXCI+XHJcbiAgICAgICAgICAgICAgICAgICAgPGkgKm5nSWY9XCJuYXYuaWNvbjsgZWxzZSBpbWFnZVRlbXBsYXRlXCIgW2NsYXNzXT1cIidjYXggcGkgJyArIG5hdi5pY29uXCI+PC9pPlxyXG4gICAgICAgICAgICAgICAgICAgIDxuZy10ZW1wbGF0ZSAjaW1hZ2VUZW1wbGF0ZT5cclxuICAgICAgICAgICAgICAgICAgICAgICAgPGNheC1pbWFnZSBbc3JjXT1cIm5hdi5pbWFnZVwiIHdpZHRoPVwiMjRweFwiIGhlaWdodD1cIjI0cHhcIj48L2NheC1pbWFnZT5cclxuICAgICAgICAgICAgICAgICAgICA8L25nLXRlbXBsYXRlPlxyXG4gICAgICAgICAgICAgICAgICAgIDxzcGFuIFtAbGVmdEZhZGVdICpuZ0lmPVwiZXhwYW5kZWRcIiBjbGFzcz1cImNheC1uYXYtbGlzdC1sYWJlbFwiPnt7IG5hdi5sYWJlbCB9fTwvc3Bhbj5cclxuICAgICAgICAgICAgICAgIDwvbGk+XHJcbiAgICAgICAgICAgICAgICA8bGkgKm5nSWY9XCJub3RpZmljYXRpb25zXCIgKGNsaWNrKT1cImVtaXROb3RpZmljYXRpb24oKVwiIFtuZ0NsYXNzXT1cInsgYWN0aXZlOiBub3RpZmljYXRpb25BY3RpdmUgfVwiPlxyXG4gICAgICAgICAgICAgICAgICAgIDxpIGNsYXNzPVwiY2F4IGNheC1iZWxsXCI+PC9pPlxyXG4gICAgICAgICAgICAgICAgICAgIDxzcGFuIFtAbGVmdEZhZGVdICpuZ0lmPVwiZXhwYW5kZWRcIiBjbGFzcz1cImNheC1uYXYtbGlzdC1sYWJlbFwiPk5vdGlmaWNhdGlvbnM8L3NwYW4+XHJcbiAgICAgICAgICAgICAgICA8L2xpPlxyXG4gICAgICAgICAgICAgICAgPGxpICpuZ0lmPVwiaGVscENlbnRyZVwiIChjbGljayk9XCJlbWl0SGVscENlbnRyZSgpXCIgW25nQ2xhc3NdPVwieyBhY3RpdmU6IGhlbHBDZW50cmVBY3RpdmUgfVwiPlxyXG4gICAgICAgICAgICAgICAgICAgIDxpIGNsYXNzPVwiY2F4IGNheC1zaGllbGQtY2hlY2tcIj48L2k+XHJcbiAgICAgICAgICAgICAgICAgICAgPHNwYW4gW0BsZWZ0RmFkZV0gKm5nSWY9XCJleHBhbmRlZFwiIGNsYXNzPVwiY2F4LW5hdi1saXN0LWxhYmVsXCI+SGVscCBDZW50cmU8L3NwYW4+XHJcbiAgICAgICAgICAgICAgICA8L2xpPlxyXG4gICAgICAgICAgICA8L3VsPlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgICAgIDxkaXYgKm5nSWY9XCJ1c2VyTmFtZVwiIChjbGljayk9XCJvcC50b2dnbGUoJGV2ZW50KTtcIiBbbmdDbGFzc109XCJ7IGFjdGl2ZTogYWNjb3VudERldGFpbHNBY3RpdmUgfVwiIGNsYXNzPVwiY2F4LW5hdi1hY2NvdW50LWRldGFpbHNcIj5cclxuICAgICAgICAgICAgPGNheC1hdmF0YXIgKm5nSWY9XCJ1c2VySW1hZ2VcIiBbaW1hZ2VdPVwidXNlckltYWdlXCIgYXZhdGFyU2l6ZT1cImxnXCI+PC9jYXgtYXZhdGFyPlxyXG4gICAgICAgICAgICA8Y2F4LWF2YXRhciAqbmdJZj1cIiF1c2VySW1hZ2VcIiBbbGFiZWxdPVwiZ2V0SW5pdGlhbHModXNlck5hbWUpXCIgYXZhdGFyU2l6ZT1cImxnXCI+PC9jYXgtYXZhdGFyPlxyXG4gICAgICAgICAgICA8ZGl2IFtAbGVmdEZhZGVdICpuZ0lmPVwiZXhwYW5kZWRcIiBjbGFzcz1cImNheC1uYXYtdXNlclwiPlxyXG4gICAgICAgICAgICAgICAgPHNwYW4gY2xhc3M9XCJjYXgtbmF2LXVzZXItbmFtZVwiPnt7IHVzZXJOYW1lIH19PC9zcGFuPlxyXG4gICAgICAgICAgICAgICAgPHNwYW4gY2xhc3M9XCJjYXgtbmF2LXVzZXItcm9sZVwiPnt7IHVzZXJSb2xlIH19PC9zcGFuPlxyXG4gICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgICAgPGRpdiBbQGxlZnRGYWRlXSAqbmdJZj1cImV4cGFuZGVkXCIgY2xhc3M9XCJjYXgtbmF2LWFjY291bnQtaWNvblwiPlxyXG4gICAgICAgICAgICAgICAgPGkgY2xhc3M9XCJjYXggY2F4LWFsdC1hcnJvdy11cFwiPjwvaT5cclxuICAgICAgICAgICAgICAgIDxpIGNsYXNzPVwiY2F4IGNheC1hbHQtYXJyb3ctZG93blwiPjwvaT5cclxuICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICAgIDxjYXgtb3ZlcmxheVBhbmVsICNvcCAob25TaG93KT1cImFjY291bnREZXRhaWxzQWN0aXZlID0gdHJ1ZVwiIFtzdHlsZUNsYXNzXT1cImV4cGFuZGVkID8gJ2NheC1uYXYtb3ZlcmxheS1leHBhbmQnIDogJ2NheC1uYXYtb3ZlcmxheSdcIiAob25IaWRlKT1cImFjY291bnREZXRhaWxzQWN0aXZlID0gZmFsc2VcIj5cclxuICAgICAgICAgICAgICAgIDxkaXYgKm5nSWY9XCJvcmdhbmlzYXRpb25EZXRhaWxzPy5sZW5ndGhcIiBjbGFzcz1cImNheC1uYXYtb3JnYW5pc2F0aW9uLWxpc3RcIj5cclxuICAgICAgICAgICAgICAgICAgICA8ZGl2ICpuZ0Zvcj1cImxldCBvcmcgb2Ygb3JnYW5pc2F0aW9uRGV0YWlsczsgbGV0IGkgPSBpbmRleFwiIGNsYXNzPVwiY2F4LW5hdi1vcmdhbmlzYXRpb24tY29udGFpbmVyXCIgKGNsaWNrKT1cIm9uUGxhbkNsaWNrKG9yZywgaSlcIiBbbmdDbGFzc109XCJ7IGFjdGl2ZTogc2VsZWN0ZWRPcmdhbmlzYXN0aW9uUGxhbiA9PSBpIH1cIj5cclxuICAgICAgICAgICAgICAgICAgICAgICAgPGNheC1hdmF0YXIgKm5nSWY9XCJvcmcuaW1hZ2U7IGVsc2UgbGFiZWxUZW1wbGF0ZVwiIFtpbWFnZV09XCJvcmcuaW1hZ2VcIiBhdmF0YXJTaXplPVwibGdcIj48L2NheC1hdmF0YXI+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIDxuZy10ZW1wbGF0ZSAjbGFiZWxUZW1wbGF0ZT5cclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxjYXgtYXZhdGFyICpuZ0lmPVwib3JnLmxhYmVsOyBlbHNlIGluaXRpYWxUZW1wbGF0ZVwiIFtsYWJlbF09XCJvcmcubGFiZWxcIiBhdmF0YXJTaXplPVwibGdcIj48L2NheC1hdmF0YXI+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIDwvbmctdGVtcGxhdGU+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIDxuZy10ZW1wbGF0ZSAjaW5pdGlhbFRlbXBsYXRlPlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPGNheC1hdmF0YXIgW2xhYmVsXT1cImdldEluaXRpYWxzKG9yZy5uYW1lKVwiIGF2YXRhclNpemU9XCJsZ1wiPjwvY2F4LWF2YXRhcj5cclxuICAgICAgICAgICAgICAgICAgICAgICAgPC9uZy10ZW1wbGF0ZT5cclxuICAgICAgICAgICAgICAgICAgICAgICAgPGRpdiBjbGFzcz1cImNheC1uYXYtb3JnYW5pc2F0aW9uXCI+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8c3BhbiBjbGFzcz1cImNheC1uYXYtb3JnYW5pc2F0aW9uLW5hbWVcIj57eyBvcmcubmFtZSB9fTwvc3Bhbj5cclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxzcGFuICpuZ0lmPVwib3JnLnBsYW4gPT0gJ3BhaWQnXCIgY2xhc3M9XCJjYXgtbmF2LW9yZ2FuaXNhdGlvbi1wbGFuXCI+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPGkgY2xhc3M9XCJjYXggY2F4LXdhbGxldFwiPjwvaT5cclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBQYWlkIFBsYW5cclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDwvc3Bhbj5cclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxzcGFuICpuZ0lmPVwib3JnLnBsYW4gPT0gJ2ZyZWUnXCIgY2xhc3M9XCJjYXgtbmF2LW9yZ2FuaXNhdGlvbi1wbGFuXCI+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPGkgY2xhc3M9XCJjYXggY2F4LXRpY2tldC1zYWxlXCI+PC9pPlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIEZyZWUgUGxhblxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPC9zcGFuPlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPHNwYW4gKm5nSWY9XCJvcmcucGxhbiA9PSAndHJpYWwnXCIgY2xhc3M9XCJjYXgtbmF2LW9yZ2FuaXNhdGlvbi1wbGFuXCI+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgPGkgY2xhc3M9XCJjYXggY2F4LWhpc3RvcnkyXCI+PC9pPlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFRyaWFsIFZlcnNpb25cclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDwvc3Bhbj5cclxuICAgICAgICAgICAgICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIDxjYXgtcmFkaW9CdXR0b24gY2xhc3M9XCJjYXgtbmF2LW9yZ2FuaXNhdGlvbi1yYWRpb1wiIFt2YWx1ZV09XCJpXCIgbmFtZT1cIm9yZ2FuaXNhdGlvbi1wbGFuXCIgWyhuZ01vZGVsKV09XCJzZWxlY3RlZE9yZ2FuaXNhc3Rpb25QbGFuXCI+PC9jYXgtcmFkaW9CdXR0b24+XHJcbiAgICAgICAgICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgICAgICAgIDxkaXYgKm5nSWY9XCJzZXR0aW5nc1wiIGNsYXNzPVwiY2F4LW5hdi1wcm9maWxlLW9wdGlvbnNcIiAoY2xpY2spPVwiZW1pdFNldHRpbmdzKClcIj5cclxuICAgICAgICAgICAgICAgICAgICA8aSBjbGFzcz1cImNheCBjYXgtc2V0dGluZ3NcIj48L2k+XHJcbiAgICAgICAgICAgICAgICAgICAgPHNwYW4+QWNjb3VudCBTZXR0aW5nczwvc3Bhbj5cclxuICAgICAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgICAgICAgPGRpdiAqbmdJZj1cInByb2ZpbGVcIiBjbGFzcz1cImNheC1uYXYtcHJvZmlsZS1vcHRpb25zXCIgKGNsaWNrKT1cImVtaXRQcm9maWxlKClcIj5cclxuICAgICAgICAgICAgICAgICAgICA8aSBjbGFzcz1cImNheCBjYXgtdXNlci1yb3VuZGVkXCI+PC9pPlxyXG4gICAgICAgICAgICAgICAgICAgIDxzcGFuPlZpZXcgUHJvZmlsZTwvc3Bhbj5cclxuICAgICAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgICAgICAgPGRpdiAqbmdJZj1cImxvZ291dFwiIGNsYXNzPVwiY2F4LW5hdi1wcm9maWxlLW9wdGlvbnMgY2F4LW5hdi1sb2dvdXRcIiAoY2xpY2spPVwiZW1pdExvZ291dCgpXCI+XHJcbiAgICAgICAgICAgICAgICAgICAgPGkgY2xhc3M9XCJjYXggY2F4LWxvZ291dFwiPjwvaT5cclxuICAgICAgICAgICAgICAgICAgICA8c3Bhbj5Mb2dvdXQ8L3NwYW4+XHJcbiAgICAgICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJjYXgtbmF2LWNvcHlyaWdodC1jb250YWluZXJcIj5cclxuICAgICAgICAgICAgICAgICAgICA8Y2F4LWxvZ28gd2lkdGg9XCI1NXB4XCIgaGVpZ2h0PVwiMTdweFwiPjwvY2F4LWxvZ28+XHJcbiAgICAgICAgICAgICAgICAgICAgPGRpdiBjbGFzcz1cImNheC1uYXYtY29weXJpZ2h0XCI+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIDxzcGFuICpuZ0lmPVwiY29weXJpZ2h0WWVhclwiPiZjb3B5OyB7eyBjb3B5cmlnaHRZZWFyIH19PC9zcGFuPlxyXG4gICAgICAgICAgICAgICAgICAgICAgICA8c3BhbiAqbmdJZj1cInZlcnNpb25cIj57eyB2ZXJzaW9uIH19PC9zcGFuPlxyXG4gICAgICAgICAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICAgIDwvY2F4LW92ZXJsYXlQYW5lbD5cclxuICAgICAgICA8L2Rpdj5cclxuICAgIDwvZGl2PlxyXG48L2Rpdj5cclxuIl19
267
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF2aWdhdGlvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hcHAvY29tcG9uZW50cy9uYXZpZ2F0aW9uL25hdmlnYXRpb24udHMiLCIuLi8uLi8uLi9zcmMvYXBwL2NvbXBvbmVudHMvbmF2aWdhdGlvbi9uYXZpZ2F0aW9uLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE9BQU8sRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFFLE9BQU8sRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQzFFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsU0FBUyxFQUFFLHVCQUF1QixFQUFFLGlCQUFpQixFQUFFLEtBQUssRUFBRSxZQUFZLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBYyxZQUFZLEVBQTRCLE1BQU0sZUFBZSxDQUFDO0FBQ2xMLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFFcEQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3RELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUN4RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNwRSxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDMUQsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDbEUsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDOzs7Ozs7Ozs7O0FBd0I3QyxNQUFNLE9BQU8sVUFBVTtJQUNWLFFBQVEsR0FBWSxJQUFJLENBQUM7SUFDekIsTUFBTSxDQUFxQjtJQUMzQixVQUFVLENBQWdCO0lBQzFCLGFBQWEsQ0FBZ0I7SUFDN0IsU0FBUyxDQUFp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QUFlO3NCQUF4QixNQUFNO2dCQUNHLFlBQVk7c0JBQXJCLE1BQU07Z0JBTXVCLGVBQWU7c0JBQTVDLFNBQVM7dUJBQUMsaUJBQWlCO2dCQUNFLGVBQWU7c0JBQTVDLFNBQVM7dUJBQUMsaUJBQWlCO2dCQXFINUIsUUFBUTtzQkFEUCxZQUFZO3VCQUFDLGVBQWUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB0cmlnZ2VyLCB0cmFuc2l0aW9uLCBzdHlsZSwgYW5pbWF0ZSB9IGZyb20gJ0Bhbmd1bGFyL2FuaW1hdGlvbnMnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCwgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIFZpZXdFbmNhcHN1bGF0aW9uLCBJbnB1dCwgRXZlbnRFbWl0dGVyLCBPdXRwdXQsIFZpZXdDaGlsZCwgRWxlbWVudFJlZiwgSG9zdExpc3RlbmVyLCBBZnRlclZpZXdJbml0LCBPbkNoYW5nZXMgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERpdmlkZXJNb2R1bGUgfSBmcm9tICdjYXgtZGVzaWduLXN5c3RlbS9kaXZpZGVyJztcbmltcG9ydCB7IExvZ29Nb2R1bGUgfSBmcm9tICdjYXgtZGVzaWduLXN5c3RlbS9sb2dvJztcbmltcG9ydCB7IE5hdkxpc3RJdGVtLCBPcmdhbmlzYXRpb25EZXRhaWxzLCBUYWJJbmRleFR5cGUgfSBmcm9tICcuL25hdmlnYXRpb24uaW50ZXJmYWNlJztcbmltcG9ydCB7IEltYWdlTW9kdWxlIH0gZnJvbSAnY2F4LWRlc2lnbi1zeXN0ZW0vaW1hZ2UnO1xuaW1wb3J0IHsgQXZhdGFyTW9kdWxlIH0gZnJvbSAnY2F4LWRlc2lnbi1zeXN0ZW0vYXZhdGFyJztcbmltcG9ydCB7IE92ZXJsYXlQYW5lbE1vZHVsZSB9IGZyb20gJ2NheC1kZXNpZ24tc3lzdGVtL292ZXJsYXlwYW5lbCc7XG5pbXBvcnQgeyBPdmVybGF5TW9kdWxlIH0gZnJvbSAnY2F4LWRlc2lnbi1zeXN0ZW0vb3ZlcmxheSc7XG5pbXBvcnQgeyBSYWRpb0J1dHRvbk1vZHVsZSB9IGZyb20gJ2NheC1kZXNpZ24tc3lzdGVtL3JhZGlvYnV0dG9uJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2NheC1uYXZpZ2F0aW9uJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vbmF2aWdhdGlvbi5odG1sJyxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICAgIHN0eWxlVXJsczogWycuL25hdmlnYXRpb24uc2NzcyddLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW0xvZ29Nb2R1bGUsIENvbW1vbk1vZHVsZSwgRGl2aWRlck1vZHVsZSwgSW1hZ2VNb2R1bGUsIEF2YXRhck1vZHVsZSwgT3ZlcmxheVBhbmVsTW9kdWxlLCBPdmVybGF5TW9kdWxlLCBSYWRpb0J1dHRvbk1vZHVsZSwgRm9ybXNNb2R1bGVdLFxuICAgIGFuaW1hdGlvbnM6IFtcbiAgICAgICAgdHJpZ2dlcignbGVmdEZhZGUnLCBbXG4gICAgICAgICAgICB0cmFuc2l0aW9uKCc6ZW50ZXInLCBbc3R5bGUoeyB0cmFuc2Zvcm06ICd0cmFuc2xhdGVYKC0xMDAlKScsIG9wYWNpdHk6IDAgfSksIGFuaW1hdGUoJzMwMG1zJywgc3R5bGUoeyB0cmFuc2Zvcm06ICd0cmFuc2xhdGVYKDApJywgb3BhY2l0eTogMSB9KSldKSxcbiAgICAgICAgICAgIHRyYW5zaXRpb24oJzpsZWF2ZScsIFtzdHlsZSh7IHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVgoMCknLCBvcGFjaXR5OiAwLjUgfSksIGFuaW1hdGUoJzMwMG1zJywgc3R5bGUoeyB0cmFuc2Zvcm06ICd0cmFuc2xhdGVYKC0xMDAlKScsIG9wYWNpdHk6IDAgfSkpXSlcbiAgICAgICAgXSksXG4gICAgICAgIHRyaWdnZXIoJ3JpZ2h0RmFkZScsIFtcbiAgICAgICAgICAgIHRyYW5zaXRpb24oJzplbnRlcicsIFtzdHlsZSh7IHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVgoMjAwJSknLCBvcGFjaXR5OiAwIH0pLCBhbmltYXRlKCczMDBtcycsIHN0eWxlKHsgdHJhbnNmb3JtOiAndHJhbnNsYXRlWCgwKScsIG9wYWNpdHk6IDEgfSkpXSksXG4gICAgICAgICAgICB0cmFuc2l0aW9uKCc6bGVhdmUnLCBbc3R5bGUoeyB0cmFuc2Zvcm06ICd0cmFuc2xhdGVYKDApJywgb3BhY2l0eTogMSB9KSwgYW5pbWF0ZSgnMzAwbXMnLCBzdHlsZSh7IHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVgoMTAwJSknLCBvcGFjaXR5OiAwIH0pKV0pXG4gICAgICAgIF0pXG4gICAgXSxcbiAgICBob3N0OiB7XG4gICAgICAgIGNsYXNzOiAnY2F4LWVsZW1lbnQnXG4gICAgfVxufSlcbmV4cG9ydCBjbGFzcyBOYXZpZ2F0aW9uIGltcGxlbWVudHMgT25DaGFuZ2VzLCBBZnRlclZpZXdJbml0IHtcbiAgICBASW5wdXQoKSBleHBhbmRlZDogYm9vbGVhbiA9IHRydWU7XG4gICAgQElucHV0KCkgaGVhZGVyOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gICAgQElucHV0KCkgdG9wTmF2TGlzdDogTmF2TGlzdEl0ZW1bXTtcbiAgICBASW5wdXQoKSBib3R0b21OYXZMaXN0OiBOYXZMaXN0SXRlbVtdO1xuICAgIEBJbnB1dCgpIGFjdGl2ZVRhYjogVGFiSW5kZXhUeXBlIHwgJ25vdGlmaWNhdGlvbnMnIHwgJ2hlbHAtY2VudHJlJztcbiAgICBASW5wdXQoKSBub3RpZmljYXRpb25zOiBib29sZWFuID0gdHJ1ZTtcbiAgICBASW5wdXQoKSBoZWxwQ2VudHJlOiBib29sZWFuID0gdHJ1ZTtcbiAgICBASW5wdXQoKSBjb3B5cmlnaHRZZWFyOiBudW1iZXIgfCB1bmRlZmluZWQgPSBuZXcgRGF0ZSgpLmdldEZ1bGxZZWFyKCk7XG4gICAgQElucHV0KCkgdmVyc2lvbjogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICAgIEBJbnB1dCgpIGxvZ291dDogYm9vbGVhbiA9IHRydWU7XG4gICAgQElucHV0KCkgcHJvZmlsZTogYm9vbGVhbiA9IHRydWU7XG4gICAgQElucHV0KCkgc2V0dGluZ3M6IGJvb2xlYW4gPSB0cnVlO1xuICAgIEBJbnB1dCgpIHVzZXJOYW1lOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gICAgQElucHV0KCkgdXNlckltYWdlOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gICAgQElucHV0KCkgdXNlclJvbGU6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgICBASW5wdXQoKSBvcmdhbmlzYXRpb25EZXRhaWxzOiBPcmdhbmlzYXRpb25EZXRhaWxzW107XG5cbiAgICBAT3V0cHV0KCkgb25Ub2dnbGVOYXZpZ2F0aW9uOiBFdmVudEVtaXR0ZXI8eyBleHBhbmRlZDogYm9vbGVhbiB9PiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcbiAgICBAT3V0cHV0KCkgb25OYXZMaXN0SXRlbUNoYW5nZTogRXZlbnRFbWl0dGVyPHsgYWN0aXZlVGFiOiBUYWJJbmRleFR5cGUgfCAnbm90aWZpY2F0aW9ucycgfCAnaGVscC1jZW50cmUnIH0+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuICAgIEBPdXRwdXQoKSBvbk5vdGlmaWNhdGlvbkNsaWNrOiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcbiAgICBAT3V0cHV0KCkgb25IZWxwQ2VudHJlQ2xpY2s6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuICAgIEBPdXRwdXQoKSBvbkxvZ291dENsaWNrOiBFdmVudEVtaXR0ZXI8YW55PiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcbiAgICBAT3V0cHV0KCkgb25Qcm9maWxlQ2xpY2s6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuICAgIEBPdXRwdXQoKSBvblNldHRpbmdzQ2xpY2s6IEV2ZW50RW1pdHRlcjxhbnk+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuICAgIEBPdXRwdXQoKSBvblBsYW5DaGFuZ2U6IEV2ZW50RW1pdHRlcjxPcmdhbmlzYXRpb25EZXRhaWxzPiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcblxuICAgIG5vdGlmaWNhdGlvbkFjdGl2ZTogYm9vbGVhbiA9IGZhbHNlO1xuICAgIGhlbHBDZW50cmVBY3RpdmU6IGJvb2xlYW4gPSBmYWxzZTtcbiAgICBhY2NvdW50RGV0YWlsc0FjdGl2ZTogYm9vbGVhbiA9IGZhbHNlO1xuICAgIHNlbGVjdGVkT3JnYW5pc2FzdGlvblBsYW46IG51bWJlcjtcbiAgICBAVmlld0NoaWxkKCdib3R0b21Db250YWluZXInKSBib3R0b21Db250YWluZXIhOiBFbGVtZW50UmVmPEhUTUxEaXZFbGVtZW50PjtcbiAgICBAVmlld0NoaWxkKCdoZWFkZXJDb250YWluZXInKSBoZWFkZXJDb250YWluZXIhOiBFbGVtZW50UmVmPEhUTUxEaXZFbGVtZW50PjtcblxuICAgIG5nT25DaGFuZ2VzKCkge1xuICAgICAgICBpZiAodGhpcy5hY3RpdmVUYWIgPT0gJ25vdGlmaWNhdGlvbnMnKSB7XG4gICAgICAgICAgICBpZiAodGhpcy5ub3RpZmljYXRpb25zKSB7XG4gICAgICAgICAgICAgICAgdGhpcy50b3BOYXZMaXN0Py5tYXAoKGxpc3Q6IE5hdkxpc3RJdGVtKSA9PiAobGlzdC5hY3RpdmUgPSBmYWxzZSkpO1xuICAgICAgICAgICAgICAgIHRoaXMuYm90dG9tTmF2TGlzdD8ubWFwKChsaXN0OiBOYXZMaXN0SXRlbSkgPT4gKGxpc3QuYWN0aXZlID0gZmFsc2UpKTtcbiAgICAgICAgICAgICAgICB0aGlzLm5vdGlmaWNhdGlvbkFjdGl2ZSA9IHRydWU7XG4gICAgICAgICAgICB9IGVsc2UgdGhpcy50b3BOYXZMaXN0WzBdLmFjdGl2ZSA9IHRydWU7XG4gICAgICAgIH0gZWxzZSBpZiAodGhpcy5hY3RpdmVUYWIgPT0gJ2hlbHAtY2VudHJlJykge1xuICAgICAgICAgICAgaWYgKHRoaXMuaGVscENlbnRyZSkge1xuICAgICAgICAgICAgICAgIHRoaXMudG9wTmF2TGlzdD8ubWFwKChsaXN0OiBOYXZMaXN0SXRlbSkgPT4gKGxpc3QuYWN0aXZlID0gZmFsc2UpKTtcbiAgICAgICAgICAgICAgICB0aGlzLmJvdHRvbU5hdkxpc3Q/Lm1hcCgobGlzdDogTmF2TGlzdEl0ZW0pID0+IChsaXN0LmFjdGl2ZSA9IGZhbHNlKSk7XG4gICAgICAgICAgICAgICAgdGhpcy5oZWxwQ2VudHJlQWN0aXZlID0gdHJ1ZTtcbiAgICAgICAgICAgIH0gZWxzZSB0aGlzLnRvcE5hdkxpc3RbMF0uYWN0aXZlID0gdHJ1ZTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIGlmICh0aGlzLmFjdGl2ZVRhYj8ucG9zaXRpb24gPT0gJ3RvcCcpIHtcbiAgICAgICAgICAgICAgICBpZiAodGhpcy5hY3RpdmVUYWIuaW5kZXggPiAtMSAmJiB0aGlzLmFjdGl2ZVRhYi5pbmRleCA8IHRoaXMudG9wTmF2TGlzdD8ubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgIHRoaXMudG9wTmF2TGlzdD8ubWFwKChsaXN0OiBOYXZMaXN0SXRlbSkgPT4gKGxpc3QuYWN0aXZlID0gZmFsc2UpKTtcbiAgICAgICAgICAgICAgICAgICAgdGhpcy50b3BOYXZMaXN0W3RoaXMuYWN0aXZlVGFiLmluZGV4XS5hY3RpdmUgPSB0cnVlO1xuICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgIGlmICh0aGlzLnRvcE5hdkxpc3Q/LmZpbHRlcigobGlzdDogTmF2TGlzdEl0ZW0pID0+IGxpc3QuYWN0aXZlKS5sZW5ndGggPiAwKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBsZXQgY291bnQgPSAwO1xuICAgICAgICAgICAgICAgICAgICAgICAgdGhpcy50b3BOYXZMaXN0Py5mb3JFYWNoKChsaXN0OiBOYXZMaXN0SXRlbSkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmIChsaXN0LmFjdGl2ZSAmJiBjb3VudCA9PSAwKSBjb3VudCA9IGNvdW50ICsgMTtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBlbHNlIGxpc3QuYWN0aXZlID0gZmFsc2U7XG4gICAgICAgICAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgICAgICAgICAgfSBlbHNlIGlmICghdGhpcy50b3BOYXZMaXN0Py5maWx0ZXIoKGxpc3Q6IE5hdkxpc3RJdGVtKSA9PiBsaXN0LmFjdGl2ZSkubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICB0aGlzLnRvcE5hdkxpc3RbMF0uYWN0aXZlID0gdHJ1ZTtcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH0gZWxzZSBpZiAodGhpcy5hY3RpdmVUYWI/LnBvc2l0aW9uID09ICdib3R0b20nKSB7XG4gICAgICAgICAgICAgICAgaWYgKHRoaXMuYWN0aXZlVGFiLmluZGV4ID4gLTEgJiYgdGhpcy5hY3RpdmVUYWIuaW5kZXggPCB0aGlzLmJvdHRvbU5hdkxpc3Q/Lmxlbmd0aCkge1xuICAgICAgICAgICAgICAgICAgICB0aGlzLmJvdHRvbU5hdkxpc3Q/Lm1hcCgobGlzdDogTmF2TGlzdEl0ZW0pID0+IChsaXN0LmFjdGl2ZSA9IGZhbHNlKSk7XG4gICAgICAgICAgICAgICAgICAgIHRoaXMuYm90dG9tTmF2TGlzdFt0aGlzLmFjdGl2ZVRhYi5pbmRleF0uYWN0aXZlID0gdHJ1ZTtcbiAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICBpZiAodGhpcy5ib3R0b21OYXZMaXN0Py5maWx0ZXIoKGxpc3Q6IE5hdkxpc3RJdGVtKSA9PiBsaXN0LmFjdGl2ZSkubGVuZ3RoID4gMCkge1xuICAgICAgICAgICAgICAgICAgICAgICAgbGV0IGNvdW50ID0gMDtcbiAgICAgICAgICAgICAgICAgICAgICAgIHRoaXMuYm90dG9tTmF2TGlzdD8uZm9yRWFjaCgobGlzdDogTmF2TGlzdEl0ZW0pID0+IHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZiAobGlzdC5hY3RpdmUgJiYgY291bnQgPT0gMCkgY291bnQgPSBjb3VudCArIDE7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgZWxzZSBsaXN0LmFjdGl2ZSA9IGZhbHNlO1xuICAgICAgICAgICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICAgICAgICAgIH0gZWxzZSBpZiAoIXRoaXMuYm90dG9tTmF2TGlzdD8uZmlsdGVyKChsaXN0OiBOYXZMaXN0SXRlbSkgPT4gbGlzdC5hY3RpdmUpLmxlbmd0aCkge1xuICAgICAgICAgICAgICAgICAgICAgICAgdGhpcy5ib3R0b21OYXZMaXN0WzBdLmFjdGl2ZSA9IHRydWU7XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgIHRoaXMudG9wTmF2TGlzdFswXS5hY3RpdmUgPSB0cnVlO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIHRoaXMuc2VsZWN0ZWRPcmdhbmlzYXN0aW9uUGxhbiA9IDA7XG4gICAgfVxuXG4gICAgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xuICAgICAgICB0aGlzLmFkanVzdFVwRGl2SGVpZ2h0KCk7XG4gICAgfVxuXG4gICAgdG9nZ2xlU2lkZWJhcigpIHtcbiAgICAgICAgdGhpcy5leHBhbmRlZCA9ICF0aGlzLmV4cGFuZGVkO1xuICAgICAgICB0aGlzLm9uVG9nZ2xlTmF2aWdhdGlvbi5lbWl0KHsgZXhwYW5kZWQ6IHRoaXMuZXhwYW5kZWQgfSk7XG4gICAgfVxuXG4gICAgb25JdGVtQ2xpY2soZTogTW91c2VFdmVudCwgaXRlbTogTmF2TGlzdEl0ZW0sIGluZGV4OiBudW1iZXIsIHBvc2l0aW9uOiAndG9wJyB8ICdib3R0b20nKSB7XG4gICAgICAgIHRoaXMudG9wTmF2TGlzdD8ubWFwKChsaXN0OiBOYXZMaXN0SXRlbSkgPT4gKGxpc3QuYWN0aXZlID0gZmFsc2UpKTtcbiAgICAgICAgdGhpcy5ib3R0b21OYXZMaXN0Py5tYXAoKGxpc3Q6IE5hdkxpc3RJdGVtKSA9PiAobGlzdC5hY3RpdmUgPSBmYWxzZSkpO1xuICAgICAgICB0aGlzLm5vdGlmaWNhdGlvbkFjdGl2ZSA9IGZhbHNlO1xuICAgICAgICB0aGlzLmhlbHBDZW50cmVBY3RpdmUgPSBmYWxzZTtcbiAgICAgICAgaWYgKHBvc2l0aW9uID09ICd0b3AnKSB0aGlzLnRvcE5hdkxpc3RbaW5kZXhdLmFjdGl2ZSA9IHRydWU7XG4gICAgICAgIGVsc2UgaWYgKHBvc2l0aW9uID09ICdib3R0b20nKSB0aGlzLmJvdHRvbU5hdkxpc3RbaW5kZXhdLmFjdGl2ZSA9IHRydWU7XG4gICAgICAgIHRoaXMub25OYXZMaXN0SXRlbUNoYW5nZS5lbWl0KHsgYWN0aXZlVGFiOiB7IHBvc2l0aW9uOiBwb3NpdGlvbiwgaW5kZXg6IGluZGV4IH0gfSk7XG4gICAgICAgIGlmIChpdGVtLmNvbW1hbmQpIHtcbiAgICAgICAgICAgIGl0ZW0uY29tbWFuZCh7IG9yaWdpbmFsRXZlbnQ6IGUsIGl0ZW0gfSk7XG4gICAgICAgIH1cbiAgICB9XG5cbiAgICBnZXRJbml0aWFscyhuYW1lOiBzdHJpbmcpOiBzdHJpbmcge1xuICAgICAgICBpZiAoIW5hbWUpIHJldHVybiAnJztcbiAgICAgICAgY29uc3QgbmFtZVBhcnRzID0gbmFtZS50cmltKCkuc3BsaXQoL1xccysvKTtcbiAgICAgICAgcmV0dXJuIChuYW1lUGFydHNbMF0/LlswXSB8fCAnJykudG9VcHBlckNhc2UoKSArIChuYW1lUGFydHNbbmFtZVBhcnRzLmxlbmd0aCAtIDFdPy5bMF0gfHwgJycpLnRvVXBwZXJDYXNlKCk7XG4gICAgfVxuXG4gICAgZW1pdE5vdGlmaWNhdGlvbigpIHtcbiAgICAgICAgdGhpcy50b3BOYXZMaXN0Py5tYXAoKGxpc3Q6IE5hdkxpc3RJdGVtKSA9PiAobGlzdC5hY3RpdmUgPSBmYWxzZSkpO1xuICAgICAgICB0aGlzLmJvdHRvbU5hdkxpc3Q/Lm1hcCgobGlzdDogTmF2TGlzdEl0ZW0pID0+IChsaXN0LmFjdGl2ZSA9IGZhbHNlKSk7XG4gICAgICAgIHRoaXMuaGVscENlbnRyZUFjdGl2ZSA9IGZhbHNlO1xuICAgICAgICB0aGlzLm5vdGlmaWNhdGlvbkFjdGl2ZSA9IHRydWU7XG4gICAgICAgIHRoaXMub25OYXZMaXN0SXRlbUNoYW5nZS5lbWl0KHsgYWN0aXZlVGFiOiAnbm90aWZpY2F0aW9ucycgfSk7XG4gICAgICAgIHRoaXMub25Ob3RpZmljYXRpb25DbGljay5lbWl0KCk7XG4gICAgfVxuXG4gICAgZW1pdEhlbHBDZW50cmUoKSB7XG4gICAgICAgIHRoaXMudG9wTmF2TGlzdD8ubWFwKChsaXN0OiBOYXZMaXN0SXRlbSkgPT4gKGxpc3QuYWN0aXZlID0gZmFsc2UpKTtcbiAgICAgICAgdGhpcy5ib3R0b21OYXZMaXN0Py5tYXAoKGxpc3Q6IE5hdkxpc3RJdGVtKSA9PiAobGlzdC5hY3RpdmUgPSBmYWxzZSkpO1xuICAgICAgICB0aGlzLmhlbHBDZW50cmVBY3RpdmUgPSB0cnVlO1xuICAgICAgICB0aGlzLm5vdGlmaWNhdGlvbkFjdGl2ZSA9IGZhbHNlO1xuICAgICAgICB0aGlzLm9uTmF2TGlzdEl0ZW1DaGFuZ2UuZW1pdCh7IGFjdGl2ZVRhYjogJ2hlbHAtY2VudHJlJyB9KTtcbiAgICAgICAgdGhpcy5vbkhlbHBDZW50cmVDbGljay5lbWl0KCk7XG4gICAgfVxuXG4gICAgZW1pdExvZ291dCgpIHtcbiAgICAgICAgdGhpcy5vbkxvZ291dENsaWNrLmVtaXQoKTtcbiAgICB9XG5cbiAgICBlbWl0UHJvZmlsZSgpIHtcbiAgICAgICAgdGhpcy5vblByb2ZpbGVDbGljay5lbWl0KCk7XG4gICAgfVxuXG4gICAgZW1pdFNldHRpbmdzKCkge1xuICAgICAgICB0aGlzLm9uU2V0dGluZ3NDbGljay5lbWl0KCk7XG4gICAgfVxuXG4gICAgb25QbGFuQ2xpY2sob3JnRGV0YWlsczogT3JnYW5pc2F0aW9uRGV0YWlscywgaW5kZXg6IG51bWJlcikge1xuICAgICAgICB0aGlzLnNlbGVjdGVkT3JnYW5pc2FzdGlvblBsYW4gPSBpbmRleDtcbiAgICAgICAgdGhpcy5vblBsYW5DaGFuZ2UuZW1pdChvcmdEZXRhaWxzKTtcbiAgICB9XG5cbiAgICBASG9zdExpc3RlbmVyKCd3aW5kb3c6cmVzaXplJylcbiAgICBvblJlc2l6ZSgpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5hZGp1c3RVcERpdkhlaWdodCgpO1xuICAgIH1cblxuICAgIGFkanVzdFVwRGl2SGVpZ2h0KCkge1xuICAgICAgICBjb25zdCBib3R0b21IZWlnaHQgPSB0aGlzLmJvdHRvbUNvbnRhaW5lcj8ubmF0aXZlRWxlbWVudC5vZmZzZXRIZWlnaHQ7XG4gICAgICAgIGNvbnN0IGhlYWRlckhlaWdodCA9IHRoaXMuaGVhZGVyQ29udGFpbmVyPy5uYXRpdmVFbGVtZW50Lm9mZnNldEhlaWdodDtcbiAgICAgICAgY29uc3QgY29udGFpbmVySGVpZ2h0ID0gd2luZG93LmlubmVySGVpZ2h0O1xuICAgICAgICByZXR1cm4gY29udGFpbmVySGVpZ2h0IC0gYm90dG9tSGVpZ2h0IC0gaGVhZGVySGVpZ2h0IC0gNTY7XG4gICAgfVxufVxuIiwiPGRpdiAqbmdJZj1cImFjY291bnREZXRhaWxzQWN0aXZlXCIgY2xhc3M9XCJjYXgtbmF2LWJhY2tkcm9wXCI+PC9kaXY+XHJcbjxkaXYgY2xhc3M9XCJjYXgtbmF2XCIgW25nQ2xhc3NdPVwieyAnY2F4LW5hdi1leHBhbmQnOiBleHBhbmRlZCB9XCI+XHJcbiAgICA8ZGl2IGNsYXNzPVwiY2F4LW5hdi10b2dnbGVcIiAoY2xpY2spPVwidG9nZ2xlU2lkZWJhcigpXCI+XHJcbiAgICAgICAgPGkgY2xhc3M9XCJjYXggY2F4LWFsdC1hcnJvdy1yaWdodFwiPjwvaT5cclxuICAgIDwvZGl2PlxyXG4gICAgPGRpdiBjbGFzcz1cImNheC1uYXYtaGVhZGVyLWNvbnRhaW5lclwiICNoZWFkZXJDb250YWluZXI+XHJcbiAgICAgICAgPGRpdiBbQHJpZ2h0RmFkZV0gKm5nSWY9XCIhZXhwYW5kZWRcIiBjbGFzcz1cImNheC1uYXYtaGVhZGVyXCI+XHJcbiAgICAgICAgICAgIDxjYXgtbG9nbyBzaXplPVwieHNtXCIgW2ljb25Pbmx5XT1cInRydWVcIiAvPlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgICAgIDxkaXYgKm5nSWY9XCJleHBhbmRlZFwiIGNsYXNzPVwiY2F4LW5hdi1oZWFkZXJcIiBbQGxlZnRGYWRlXT5cclxuICAgICAgICAgICAgPGNheC1sb2dvIHNpemU9XCJ4c21cIiAvPlxyXG4gICAgICAgICAgICA8Y2F4LWRpdmlkZXIgbGF5b3V0PVwidmVydGljYWxcIj48L2NheC1kaXZpZGVyPlxyXG4gICAgICAgICAgICA8c3Bhbj57eyBoZWFkZXIgfX08L3NwYW4+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICA8L2Rpdj5cclxuICAgIDxkaXYgY2xhc3M9XCJjYXgtbmF2LWxpc3QtY29udGFpbmVyXCIgW3N0eWxlLm1heEhlaWdodC5weF09XCJhZGp1c3RVcERpdkhlaWdodCgpXCI+XHJcbiAgICAgICAgPHVsPlxyXG4gICAgICAgICAgICA8bGkgKm5nRm9yPVwibGV0IG5hdiBvZiB0b3BOYXZMaXN0LCBsZXQgaSA9IGluZGV4XCIgW25nQ2xhc3NdPVwieyBhY3RpdmU6IG5hdi5hY3RpdmUgfVwiIChjbGljayk9XCJvbkl0ZW1DbGljaygkZXZlbnQsIG5hdiwgaSwgJ3RvcCcpXCI+XHJcbiAgICAgICAgICAgICAgICA8aSAqbmdJZj1cIm5hdi5pY29uOyBlbHNlIGltYWdlVGVtcGxhdGVcIiBbY2xhc3NdPVwiJ2NheCBwaSAnICsgbmF2Lmljb25cIj48L2k+XHJcbiAgICAgICAgICAgICAgICA8bmctdGVtcGxhdGUgI2ltYWdlVGVtcGxhdGU+XHJcbiAgICAgICAgICAgICAgICAgICAgPGNheC1pbWFnZSBbc3JjXT1cIm5hdi5pbWFnZVwiIHdpZHRoPVwiMjRweFwiIGhlaWdodD1cIjI0cHhcIj48L2NheC1pbWFnZT5cclxuICAgICAgICAgICAgICAgIDwvbmctdGVtcGxhdGU+XHJcbiAgICAgICAgICAgICAgICA8c3BhbiBbQGxlZnRGYWRlXSAqbmdJZj1cImV4cGFuZGVkXCIgY2xhc3M9XCJjYXgtbmF2LWxpc3QtbGFiZWxcIj57eyBuYXYubGFiZWwgfX08L3NwYW4+XHJcbiAgICAgICAgICAgIDwvbGk+XHJcbiAgICAgICAgPC91bD5cclxuICAgIDwvZGl2PlxyXG4gICAgPGRpdiBjbGFzcz1cImNheC1uYXYtYm90dG9tLWNvbnRhaW5lclwiICNib3R0b21Db250YWluZXI+XHJcbiAgICAgICAgPGRpdiBjbGFzcz1cImNheC1uYXYtYm90dG9tLWxpc3RcIj5cclxuICAgICAgICAgICAgPHVsPlxyXG4gICAgICAgICAgICAgICAgPGxpICpuZ0Zvcj1cImxldCBuYXYgb2YgYm90dG9tTmF2TGlzdCwgbGV0IGkgPSBpbmRleFwiIFtuZ0NsYXNzXT1cInsgYWN0aXZlOiBuYXYuYWN0aXZlIH1cIiAoY2xpY2spPVwib25JdGVtQ2xpY2soJGV2ZW50LCBuYXYsIGksICdib3R0b20nKVwiPlxyXG4gICAgICAgICAgICAgICAgICAgIDxpICpuZ0lmPVwibmF2Lmljb247IGVsc2UgaW1hZ2VUZW1wbGF0ZVwiIFtjbGFzc109XCInY2F4IHBpICcgKyBuYXYuaWNvblwiPjwvaT5cclxuICAgICAgICAgICAgICAgICAgICA8bmctdGVtcGxhdGUgI2ltYWdlVGVtcGxhdGU+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIDxjYXgtaW1hZ2UgW3NyY109XCJuYXYuaW1hZ2VcIiB3aWR0aD1cIjI0cHhcIiBoZWlnaHQ9XCIyNHB4XCI+PC9jYXgtaW1hZ2U+XHJcbiAgICAgICAgICAgICAgICAgICAgPC9uZy10ZW1wbGF0ZT5cclxuICAgICAgICAgICAgICAgICAgICA8c3BhbiBbQGxlZnRGYWRlXSAqbmdJZj1cImV4cGFuZGVkXCIgY2xhc3M9XCJjYXgtbmF2LWxpc3QtbGFiZWxcIj57eyBuYXYubGFiZWwgfX08L3NwYW4+XHJcbiAgICAgICAgICAgICAgICA8L2xpPlxyXG4gICAgICAgICAgICAgICAgPGxpICpuZ0lmPVwibm90aWZpY2F0aW9uc1wiIChjbGljayk9XCJlbWl0Tm90aWZpY2F0aW9uKClcIiBbbmdDbGFzc109XCJ7IGFjdGl2ZTogbm90aWZpY2F0aW9uQWN0aXZlIH1cIj5cclxuICAgICAgICAgICAgICAgICAgICA8aSBjbGFzcz1cImNheCBjYXgtYmVsbFwiPjwvaT5cclxuICAgICAgICAgICAgICAgICAgICA8c3BhbiBbQGxlZnRGYWRlXSAqbmdJZj1cImV4cGFuZGVkXCIgY2xhc3M9XCJjYXgtbmF2LWxpc3QtbGFiZWxcIj5Ob3RpZmljYXRpb25zPC9zcGFuPlxyXG4gICAgICAgICAgICAgICAgPC9saT5cclxuICAgICAgICAgICAgICAgIDxsaSAqbmdJZj1cImhlbHBDZW50cmVcIiAoY2xpY2spPVwiZW1pdEhlbHBDZW50cmUoKVwiIFtuZ0NsYXNzXT1cInsgYWN0aXZlOiBoZWxwQ2VudHJlQWN0aXZlIH1cIj5cclxuICAgICAgICAgICAgICAgICAgICA8aSBjbGFzcz1cImNheCBjYXgtcXVlc3Rpb24tY2lyY2xlXCI+PC9pPlxyXG4gICAgICAgICAgICAgICAgICAgIDxzcGFuIFtAbGVmdEZhZGVdICpuZ0lmPVwiZXhwYW5kZWRcIiBjbGFzcz1cImNheC1uYXYtbGlzdC1sYWJlbFwiPkhlbHAgQ2VudHJlPC9zcGFuPlxyXG4gICAgICAgICAgICAgICAgPC9saT5cclxuICAgICAgICAgICAgPC91bD5cclxuICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8ZGl2ICpuZ0lmPVwidXNlck5hbWVcIiAoY2xpY2spPVwib3AudG9nZ2xlKCRldmVudCk7XCIgW25nQ2xhc3NdPVwieyBhY3RpdmU6IGFjY291bnREZXRhaWxzQWN0aXZlIH1cIiBjbGFzcz1cImNheC1uYXYtYWNjb3VudC1kZXRhaWxzXCI+XHJcbiAgICAgICAgICAgIDxjYXgtYXZhdGFyICpuZ0lmPVwidXNlckltYWdlXCIgW2ltYWdlXT1cInVzZXJJbWFnZVwiIGF2YXRhclNpemU9XCJsZ1wiPjwvY2F4LWF2YXRhcj5cclxuICAgICAgICAgICAgPGNheC1hdmF0YXIgKm5nSWY9XCIhdXNlckltYWdlXCIgW2xhYmVsXT1cImdldEluaXRpYWxzKHVzZXJOYW1lKVwiIGF2YXRhclNpemU9XCJsZ1wiPjwvY2F4LWF2YXRhcj5cclxuICAgICAgICAgICAgPGRpdiBbQGxlZnRGYWRlXSAqbmdJZj1cImV4cGFuZGVkXCIgY2xhc3M9XCJjYXgtbmF2LXVzZXJcIj5cclxuICAgICAgICAgICAgICAgIDxzcGFuIGNsYXNzPVwiY2F4LW5hdi11c2VyLW5hbWVcIj57eyB1c2VyTmFtZSB9fTwvc3Bhbj5cclxuICAgICAgICAgICAgICAgIDxzcGFuIGNsYXNzPVwiY2F4LW5hdi11c2VyLXJvbGVcIj57eyB1c2VyUm9sZSB9fTwvc3Bhbj5cclxuICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICAgIDxkaXYgW0BsZWZ0RmFkZV0gKm5nSWY9XCJleHBhbmRlZFwiIGNsYXNzPVwiY2F4LW5hdi1hY2NvdW50LWljb25cIj5cclxuICAgICAgICAgICAgICAgIDxpIGNsYXNzPVwiY2F4IGNheC1hbHQtYXJyb3ctdXBcIj48L2k+XHJcbiAgICAgICAgICAgICAgICA8aSBjbGFzcz1cImNheCBjYXgtYWx0LWFycm93LWRvd25cIj48L2k+XHJcbiAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgICA8Y2F4LW92ZXJsYXlQYW5lbCAjb3AgKG9uU2hvdyk9XCJhY2NvdW50RGV0YWlsc0FjdGl2ZSA9IHRydWVcIiBbc3R5bGVDbGFzc109XCJleHBhbmRlZCA/ICdjYXgtbmF2LW92ZXJsYXktZXhwYW5kJyA6ICdjYXgtbmF2LW92ZXJsYXknXCIgKG9uSGlkZSk9XCJhY2NvdW50RGV0YWlsc0FjdGl2ZSA9IGZhbHNlXCI+XHJcbiAgICAgICAgICAgICAgICA8ZGl2ICpuZ0lmPVwib3JnYW5pc2F0aW9uRGV0YWlscz8ubGVuZ3RoXCIgY2xhc3M9XCJjYXgtbmF2LW9yZ2FuaXNhdGlvbi1saXN0XCI+XHJcbiAgICAgICAgICAgICAgICAgICAgPGRpdiAqbmdGb3I9XCJsZXQgb3JnIG9mIG9yZ2FuaXNhdGlvbkRldGFpbHM7IGxldCBpID0gaW5kZXhcIiBjbGFzcz1cImNheC1uYXYtb3JnYW5pc2F0aW9uLWNvbnRhaW5lclwiIChjbGljayk9XCJvblBsYW5DbGljayhvcmcsIGkpXCIgW25nQ2xhc3NdPVwieyBhY3RpdmU6IHNlbGVjdGVkT3JnYW5pc2FzdGlvblBsYW4gPT0gaSB9XCI+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIDxjYXgtYXZhdGFyICpuZ0lmPVwib3JnLmltYWdlOyBlbHNlIGxhYmVsVGVtcGxhdGVcIiBbaW1hZ2VdPVwib3JnLmltYWdlXCIgYXZhdGFyU2l6ZT1cImxnXCI+PC9jYXgtYXZhdGFyPlxyXG4gICAgICAgICAgICAgICAgICAgICAgICA8bmctdGVtcGxhdGUgI2xhYmVsVGVtcGxhdGU+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8Y2F4LWF2YXRhciAqbmdJZj1cIm9yZy5sYWJlbDsgZWxzZSBpbml0aWFsVGVtcGxhdGVcIiBbbGFiZWxdPVwib3JnLmxhYmVsXCIgYXZhdGFyU2l6ZT1cImxnXCI+PC9jYXgtYXZhdGFyPlxyXG4gICAgICAgICAgICAgICAgICAgICAgICA8L25nLXRlbXBsYXRlPlxyXG4gICAgICAgICAgICAgICAgICAgICAgICA8bmctdGVtcGxhdGUgI2luaXRpYWxUZW1wbGF0ZT5cclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxjYXgtYXZhdGFyIFtsYWJlbF09XCJnZXRJbml0aWFscyhvcmcubmFtZSlcIiBhdmF0YXJTaXplPVwibGdcIj48L2NheC1hdmF0YXI+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIDwvbmctdGVtcGxhdGU+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJjYXgtbmF2LW9yZ2FuaXNhdGlvblwiPlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgPHNwYW4gY2xhc3M9XCJjYXgtbmF2LW9yZ2FuaXNhdGlvbi1uYW1lXCI+e3sgb3JnLm5hbWUgfX08L3NwYW4+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8c3BhbiAqbmdJZj1cIm9yZy5wbGFuID09ICdwYWlkJ1wiIGNsYXNzPVwiY2F4LW5hdi1vcmdhbmlzYXRpb24tcGxhblwiPlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxpIGNsYXNzPVwiY2F4IGNheC13YWxsZXRcIj48L2k+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgUGFpZCBQbGFuXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8L3NwYW4+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8c3BhbiAqbmdJZj1cIm9yZy5wbGFuID09ICdmcmVlJ1wiIGNsYXNzPVwiY2F4LW5hdi1vcmdhbmlzYXRpb24tcGxhblwiPlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxpIGNsYXNzPVwiY2F4IGNheC10aWNrZXQtc2FsZVwiPjwvaT5cclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBGcmVlIFBsYW5cclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDwvc3Bhbj5cclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxzcGFuICpuZ0lmPVwib3JnLnBsYW4gPT0gJ3RyaWFsJ1wiIGNsYXNzPVwiY2F4LW5hdi1vcmdhbmlzYXRpb24tcGxhblwiPlxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDxpIGNsYXNzPVwiY2F4IGNheC1oaXN0b3J5MlwiPjwvaT5cclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBUcmlhbCBWZXJzaW9uXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICA8L3NwYW4+XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgICAgICAgICAgICAgICA8Y2F4LXJhZGlvQnV0dG9uIGNsYXNzPVwiY2F4LW5hdi1vcmdhbmlzYXRpb24tcmFkaW9cIiBbdmFsdWVdPVwiaVwiIG5hbWU9XCJvcmdhbmlzYXRpb24tcGxhblwiIFsobmdNb2RlbCldPVwic2VsZWN0ZWRPcmdhbmlzYXN0aW9uUGxhblwiPjwvY2F4LXJhZGlvQnV0dG9uPlxyXG4gICAgICAgICAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICAgICAgICA8ZGl2ICpuZ0lmPVwic2V0dGluZ3NcIiBjbGFzcz1cImNheC1uYXYtcHJvZmlsZS1vcHRpb25zXCIgKGNsaWNrKT1cImVtaXRTZXR0aW5ncygpXCI+XHJcbiAgICAgICAgICAgICAgICAgICAgPGkgY2xhc3M9XCJjYXggY2F4LXNldHRpbmdzXCI+PC9pPlxyXG4gICAgICAgICAgICAgICAgICAgIDxzcGFuPkFjY291bnQgU2V0dGluZ3M8L3NwYW4+XHJcbiAgICAgICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgICAgICAgIDxkaXYgKm5nSWY9XCJwcm9maWxlXCIgY2xhc3M9XCJjYXgtbmF2LXByb2ZpbGUtb3B0aW9uc1wiIChjbGljayk9XCJlbWl0UHJvZmlsZSgpXCI+XHJcbiAgICAgICAgICAgICAgICAgICAgPGkgY2xhc3M9XCJjYXggY2F4LXVzZXItcm91bmRlZFwiPjwvaT5cclxuICAgICAgICAgICAgICAgICAgICA8c3Bhbj5WaWV3IFByb2ZpbGU8L3NwYW4+XHJcbiAgICAgICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgICAgICAgIDxkaXYgKm5nSWY9XCJsb2dvdXRcIiBjbGFzcz1cImNheC1uYXYtcHJvZmlsZS1vcHRpb25zIGNheC1uYXYtbG9nb3V0XCIgKGNsaWNrKT1cImVtaXRMb2dvdXQoKVwiPlxyXG4gICAgICAgICAgICAgICAgICAgIDxpIGNsYXNzPVwiY2F4IGNheC1sb2dvdXRcIj48L2k+XHJcbiAgICAgICAgICAgICAgICAgICAgPHNwYW4+TG9nb3V0PC9zcGFuPlxyXG4gICAgICAgICAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgICAgICAgICA8ZGl2IGNsYXNzPVwiY2F4LW5hdi1jb3B5cmlnaHQtY29udGFpbmVyXCI+XHJcbiAgICAgICAgICAgICAgICAgICAgPGNheC1sb2dvIHdpZHRoPVwiNTVweFwiIGhlaWdodD1cIjE3cHhcIj48L2NheC1sb2dvPlxyXG4gICAgICAgICAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJjYXgtbmF2LWNvcHlyaWdodFwiPlxyXG4gICAgICAgICAgICAgICAgICAgICAgICA8c3BhbiAqbmdJZj1cImNvcHlyaWdodFllYXJcIj4mY29weTsge3sgY29weXJpZ2h0WWVhciB9fTwvc3Bhbj5cclxuICAgICAgICAgICAgICAgICAgICAgICAgPHNwYW4gKm5nSWY9XCJ2ZXJzaW9uXCI+e3sgdmVyc2lvbiB9fTwvc3Bhbj5cclxuICAgICAgICAgICAgICAgICAgICA8L2Rpdj5cclxuICAgICAgICAgICAgICAgIDwvZGl2PlxyXG4gICAgICAgICAgICA8L2NheC1vdmVybGF5UGFuZWw+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICA8L2Rpdj5cclxuPC9kaXY+XHJcbiJdfQ==
@@ -52,14 +52,20 @@ class Navigation {
52
52
  headerContainer;
53
53
  ngOnChanges() {
54
54
  if (this.activeTab == 'notifications') {
55
- if (this.notifications)
55
+ if (this.notifications) {
56
+ this.topNavList?.map((list) => (list.active = false));
57
+ this.bottomNavList?.map((list) => (list.active = false));
56
58
  this.notificationActive = true;
59
+ }
57
60
  else
58
61
  this.topNavList[0].active = true;
59
62
  }
60
63
  else if (this.activeTab == 'help-centre') {
61
- if (this.helpCentre)
64
+ if (this.helpCentre) {
65
+ this.topNavList?.map((list) => (list.active = false));
66
+ this.bottomNavList?.map((list) => (list.active = false));
62
67
  this.helpCentreActive = true;
68
+ }
63
69
  else
64
70
  this.topNavList[0].active = true;
65
71
  }
@@ -176,7 +182,7 @@ class Navigation {
176
182
  return containerHeight - bottomHeight - headerHeight - 56;
177
183
  }
178
184
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.9", ngImport: i0, type: Navigation, deps: [], target: i0.ɵɵFactoryTarget.Component });
179
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: Navigation, isStandalone: true, selector: "cax-navigation", inputs: { expanded: "expanded", header: "header", topNavList: "topNavList", bottomNavList: "bottomNavList", activeTab: "activeTab", notifications: "notifications", helpCentre: "helpCentre", copyrightYear: "copyrightYear", version: "version", logout: "logout", profile: "profile", settings: "settings", userName: "userName", userImage: "userImage", userRole: "userRole", organisationDetails: "organisationDetails" }, outputs: { onToggleNavigation: "onToggleNavigation", onNavListItemChange: "onNavListItemChange", onNotificationClick: "onNotificationClick", onHelpCentreClick: "onHelpCentreClick", onLogoutClick: "onLogoutClick", onProfileClick: "onProfileClick", onSettingsClick: "onSettingsClick", onPlanChange: "onPlanChange" }, host: { listeners: { "window:resize": "onResize()" }, classAttribute: "cax-element" }, viewQueries: [{ propertyName: "bottomContainer", first: true, predicate: ["bottomContainer"], descendants: true }, { propertyName: "headerContainer", first: true, predicate: ["headerContainer"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div *ngIf=\"accountDetailsActive\" class=\"cax-nav-backdrop\"></div>\r\n<div class=\"cax-nav\" [ngClass]=\"{ 'cax-nav-expand': expanded }\">\r\n <div class=\"cax-nav-toggle\" (click)=\"toggleSidebar()\">\r\n <i class=\"cax cax-alt-arrow-right\"></i>\r\n </div>\r\n <div class=\"cax-nav-header-container\" #headerContainer>\r\n <div [@rightFade] *ngIf=\"!expanded\" class=\"cax-nav-header\">\r\n <cax-logo size=\"xsm\" [iconOnly]=\"true\" />\r\n </div>\r\n <div *ngIf=\"expanded\" class=\"cax-nav-header\" [@leftFade]>\r\n <cax-logo size=\"xsm\" />\r\n <cax-divider layout=\"vertical\"></cax-divider>\r\n <span>{{ header }}</span>\r\n </div>\r\n </div>\r\n <div class=\"cax-nav-list-container\" [style.maxHeight.px]=\"adjustUpDivHeight()\">\r\n <ul>\r\n <li *ngFor=\"let nav of topNavList, let i = index\" [ngClass]=\"{ active: nav.active }\" (click)=\"onItemClick($event, nav, i, 'top')\">\r\n <i *ngIf=\"nav.icon; else imageTemplate\" [class]=\"'cax pi ' + nav.icon\"></i>\r\n <ng-template #imageTemplate>\r\n <cax-image [src]=\"nav.image\" width=\"24px\" height=\"24px\"></cax-image>\r\n </ng-template>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">{{ nav.label }}</span>\r\n </li>\r\n </ul>\r\n </div>\r\n <div class=\"cax-nav-bottom-container\" #bottomContainer>\r\n <div class=\"cax-nav-bottom-list\">\r\n <ul>\r\n <li *ngFor=\"let nav of bottomNavList, let i = index\" [ngClass]=\"{ active: nav.active }\" (click)=\"onItemClick($event, nav, i, 'bottom')\">\r\n <i *ngIf=\"nav.icon; else imageTemplate\" [class]=\"'cax pi ' + nav.icon\"></i>\r\n <ng-template #imageTemplate>\r\n <cax-image [src]=\"nav.image\" width=\"24px\" height=\"24px\"></cax-image>\r\n </ng-template>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">{{ nav.label }}</span>\r\n </li>\r\n <li *ngIf=\"notifications\" (click)=\"emitNotification()\" [ngClass]=\"{ active: notificationActive }\">\r\n <i class=\"cax cax-bell\"></i>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">Notifications</span>\r\n </li>\r\n <li *ngIf=\"helpCentre\" (click)=\"emitHelpCentre()\" [ngClass]=\"{ active: helpCentreActive }\">\r\n <i class=\"cax cax-shield-check\"></i>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">Help Centre</span>\r\n </li>\r\n </ul>\r\n </div>\r\n <div *ngIf=\"userName\" (click)=\"op.toggle($event);\" [ngClass]=\"{ active: accountDetailsActive }\" class=\"cax-nav-account-details\">\r\n <cax-avatar *ngIf=\"userImage\" [image]=\"userImage\" avatarSize=\"lg\"></cax-avatar>\r\n <cax-avatar *ngIf=\"!userImage\" [label]=\"getInitials(userName)\" avatarSize=\"lg\"></cax-avatar>\r\n <div [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-user\">\r\n <span class=\"cax-nav-user-name\">{{ userName }}</span>\r\n <span class=\"cax-nav-user-role\">{{ userRole }}</span>\r\n </div>\r\n <div [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-account-icon\">\r\n <i class=\"cax cax-alt-arrow-up\"></i>\r\n <i class=\"cax cax-alt-arrow-down\"></i>\r\n </div>\r\n <cax-overlayPanel #op (onShow)=\"accountDetailsActive = true\" [styleClass]=\"expanded ? 'cax-nav-overlay-expand' : 'cax-nav-overlay'\" (onHide)=\"accountDetailsActive = false\">\r\n <div *ngIf=\"organisationDetails?.length\" class=\"cax-nav-organisation-list\">\r\n <div *ngFor=\"let org of organisationDetails; let i = index\" class=\"cax-nav-organisation-container\" (click)=\"onPlanClick(org, i)\" [ngClass]=\"{ active: selectedOrganisastionPlan == i }\">\r\n <cax-avatar *ngIf=\"org.image; else labelTemplate\" [image]=\"org.image\" avatarSize=\"lg\"></cax-avatar>\r\n <ng-template #labelTemplate>\r\n <cax-avatar *ngIf=\"org.label; else initialTemplate\" [label]=\"org.label\" avatarSize=\"lg\"></cax-avatar>\r\n </ng-template>\r\n <ng-template #initialTemplate>\r\n <cax-avatar [label]=\"getInitials(org.name)\" avatarSize=\"lg\"></cax-avatar>\r\n </ng-template>\r\n <div class=\"cax-nav-organisation\">\r\n <span class=\"cax-nav-organisation-name\">{{ org.name }}</span>\r\n <span *ngIf=\"org.plan == 'paid'\" class=\"cax-nav-organisation-plan\">\r\n <i class=\"cax cax-wallet\"></i>\r\n Paid Plan\r\n </span>\r\n <span *ngIf=\"org.plan == 'free'\" class=\"cax-nav-organisation-plan\">\r\n <i class=\"cax cax-ticket-sale\"></i>\r\n Free Plan\r\n </span>\r\n <span *ngIf=\"org.plan == 'trial'\" class=\"cax-nav-organisation-plan\">\r\n <i class=\"cax cax-history2\"></i>\r\n Trial Version\r\n </span>\r\n </div>\r\n <cax-radioButton class=\"cax-nav-organisation-radio\" [value]=\"i\" name=\"organisation-plan\" [(ngModel)]=\"selectedOrganisastionPlan\"></cax-radioButton>\r\n </div>\r\n </div>\r\n <div *ngIf=\"settings\" class=\"cax-nav-profile-options\" (click)=\"emitSettings()\">\r\n <i class=\"cax cax-settings\"></i>\r\n <span>Account Settings</span>\r\n </div>\r\n <div *ngIf=\"profile\" class=\"cax-nav-profile-options\" (click)=\"emitProfile()\">\r\n <i class=\"cax cax-user-rounded\"></i>\r\n <span>View Profile</span>\r\n </div>\r\n <div *ngIf=\"logout\" class=\"cax-nav-profile-options cax-nav-logout\" (click)=\"emitLogout()\">\r\n <i class=\"cax cax-logout\"></i>\r\n <span>Logout</span>\r\n </div>\r\n <div class=\"cax-nav-copyright-container\">\r\n <cax-logo width=\"55px\" height=\"17px\"></cax-logo>\r\n <div class=\"cax-nav-copyright\">\r\n <span *ngIf=\"copyrightYear\">&copy; {{ copyrightYear }}</span>\r\n <span *ngIf=\"version\">{{ version }}</span>\r\n </div>\r\n </div>\r\n </cax-overlayPanel>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: ["@layer cax{.cax-nav{width:88px;height:100vh;transition:width .3s ease-in-out;overflow:hidden;padding:16px 8px;position:absolute;left:0;top:0;z-index:1200}.cax-nav.cax-nav-expand{width:264px}.cax-nav.cax-nav-expand .cax-nav-header-container{margin-right:10px}.cax-nav-header-container{display:flex;align-items:center;justify-content:center;height:64px}.cax-nav-header{display:flex;align-items:center;justify-content:center}.cax-nav-header span{font-weight:700;font-size:12px}.cax-nav-toggle{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;position:fixed;cursor:pointer;transition:transform .3s ease-in-out,left .3s ease-in-out}.cax-nav .cax-nav-toggle{left:68px;top:28px}.cax-nav.cax-nav-expand .cax-nav-toggle{left:244px;transform:rotate(180deg)}.cax-nav .cax-divider.cax-divider-vertical{margin:0 8px;height:36px}.cax-nav-list-container,.cax-nav-bottom-list{margin:24px 0}.cax-nav-list-container ul,.cax-nav-bottom-list ul{margin:0;padding:0;list-style-type:none;display:flex;flex-direction:column;gap:16px}.cax-nav-list-container ul li,.cax-nav-bottom-list ul li{padding:12px 24px;border-radius:12px;display:flex;align-items:center;cursor:pointer;height:56px;line-height:24px}.cax-nav-list-container{overflow-y:auto}.cax-nav-list-container::-webkit-scrollbar{display:none}.cax-nav-bottom-container{position:absolute;bottom:16px}.cax-nav-account-details{border-radius:12px;padding:12px;cursor:pointer;transition:width .3s ease-in-out;display:flex;align-items:flex-start}.cax-nav-account-details .cax-nav-account-icon{display:grid;margin-left:auto}.cax-nav.cax-nav-expand .cax-nav-account-details{width:248px}.cax-nav-user{display:grid;margin:0 8px;white-space:nowrap}.cax-nav-user .cax-nav-user-name{font-size:16px;font-weight:500;line-height:24px}.cax-nav-user .cax-nav-user-role{font-size:14px;font-weight:400;line-height:21px}.cax-overlaypanel{width:320px}.cax-overlaypanel .cax-overlaypanel-content{padding:8px}.cax-nav-copyright-container{display:flex;align-items:center;justify-content:space-between}.cax-nav-copyright-container .cax-nav-copyright{font-size:12px;font-weight:500}.cax-nav-copyright-container .cax-nav-copyright span{margin:0 0 0 16px}.cax-nav-profile-options{padding:12px 24px;font-weight:600;line-height:24px;display:flex;align-items:center;cursor:pointer;border-radius:12px;margin-bottom:8px;font-size:16px}.cax-nav-profile-options span{margin-left:8px}.cax-nav-organisation-list{border-radius:12px;padding:8px;margin-bottom:8px}.cax-nav-organisation-container{display:flex;align-items:flex-start;cursor:pointer;padding:12px;border-radius:8px}.cax-nav-organisation-container .cax-nav-organisation-radio{margin-left:auto}.cax-nav-organisation-container:not(:last-child){margin-bottom:8px}.cax-nav-organisation{display:grid;margin:0 8px;white-space:nowrap}.cax-nav-organisation .cax-nav-organisation-name{font-weight:600;font-size:16px;line-height:24px}.cax-nav-organisation .cax-nav-organisation-plan{display:flex;font-size:14px;font-weight:500;line-height:21px}.cax-nav-organisation .cax-nav-organisation-plan i{font-size:20px;margin-right:3px}.cax-nav-overlay-expand{left:270px!important;top:auto!important;bottom:6px}.cax-nav-overlay{left:94px!important;top:auto!important;bottom:6px}}\n"], dependencies: [{ kind: "ngmodule", type: LogoModule }, { kind: "component", type: i1.Logo, selector: "cax-logo", inputs: ["size", "width", "height", "iconOnly", "darkMode"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: DividerModule }, { kind: "component", type: i3.Divider, selector: "cax-divider", inputs: ["style", "styleClass", "layout", "type", "align"] }, { kind: "ngmodule", type: ImageModule }, { kind: "component", type: i4.Image, selector: "cax-image", inputs: ["imageClass", "imageStyle", "styleClass", "style", "src", "srcSet", "sizes", "size", "previewImageSrc", "previewImageSrcSet", "previewImageSizes", "alt", "width", "height", "loading", "appendTo", "preview", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onShow", "onHide", "onImageError"] }, { kind: "ngmodule", type: AvatarModule }, { kind: "component", type: i5.Avatar, selector: "cax-avatar", inputs: ["label", "icon", "image", "avatarSize", "shape", "style", "styleClass", "ariaLabel", "ariaLabelledBy"], outputs: ["onImageError"] }, { kind: "ngmodule", type: OverlayPanelModule }, { kind: "component", type: i6.OverlayPanel, selector: "cax-overlayPanel", inputs: ["ariaLabel", "ariaLabelledBy", "dismissable", "showCloseIcon", "style", "styleClass", "appendTo", "autoZIndex", "ariaCloseLabel", "baseZIndex", "focusOnShow", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onShow", "onHide"] }, { kind: "ngmodule", type: OverlayModule }, { kind: "ngmodule", type: RadioButtonModule }, { kind: "component", type: i7.RadioButton, selector: "cax-radioButton", inputs: ["value", "formControlName", "name", "disabled", "label", "variant", "tabindex", "inputId", "ariaLabelledBy", "ariaLabel", "style", "styleClass", "labelStyleClass", "autofocus"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i8.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], animations: [
185
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.9", type: Navigation, isStandalone: true, selector: "cax-navigation", inputs: { expanded: "expanded", header: "header", topNavList: "topNavList", bottomNavList: "bottomNavList", activeTab: "activeTab", notifications: "notifications", helpCentre: "helpCentre", copyrightYear: "copyrightYear", version: "version", logout: "logout", profile: "profile", settings: "settings", userName: "userName", userImage: "userImage", userRole: "userRole", organisationDetails: "organisationDetails" }, outputs: { onToggleNavigation: "onToggleNavigation", onNavListItemChange: "onNavListItemChange", onNotificationClick: "onNotificationClick", onHelpCentreClick: "onHelpCentreClick", onLogoutClick: "onLogoutClick", onProfileClick: "onProfileClick", onSettingsClick: "onSettingsClick", onPlanChange: "onPlanChange" }, host: { listeners: { "window:resize": "onResize()" }, classAttribute: "cax-element" }, viewQueries: [{ propertyName: "bottomContainer", first: true, predicate: ["bottomContainer"], descendants: true }, { propertyName: "headerContainer", first: true, predicate: ["headerContainer"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div *ngIf=\"accountDetailsActive\" class=\"cax-nav-backdrop\"></div>\r\n<div class=\"cax-nav\" [ngClass]=\"{ 'cax-nav-expand': expanded }\">\r\n <div class=\"cax-nav-toggle\" (click)=\"toggleSidebar()\">\r\n <i class=\"cax cax-alt-arrow-right\"></i>\r\n </div>\r\n <div class=\"cax-nav-header-container\" #headerContainer>\r\n <div [@rightFade] *ngIf=\"!expanded\" class=\"cax-nav-header\">\r\n <cax-logo size=\"xsm\" [iconOnly]=\"true\" />\r\n </div>\r\n <div *ngIf=\"expanded\" class=\"cax-nav-header\" [@leftFade]>\r\n <cax-logo size=\"xsm\" />\r\n <cax-divider layout=\"vertical\"></cax-divider>\r\n <span>{{ header }}</span>\r\n </div>\r\n </div>\r\n <div class=\"cax-nav-list-container\" [style.maxHeight.px]=\"adjustUpDivHeight()\">\r\n <ul>\r\n <li *ngFor=\"let nav of topNavList, let i = index\" [ngClass]=\"{ active: nav.active }\" (click)=\"onItemClick($event, nav, i, 'top')\">\r\n <i *ngIf=\"nav.icon; else imageTemplate\" [class]=\"'cax pi ' + nav.icon\"></i>\r\n <ng-template #imageTemplate>\r\n <cax-image [src]=\"nav.image\" width=\"24px\" height=\"24px\"></cax-image>\r\n </ng-template>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">{{ nav.label }}</span>\r\n </li>\r\n </ul>\r\n </div>\r\n <div class=\"cax-nav-bottom-container\" #bottomContainer>\r\n <div class=\"cax-nav-bottom-list\">\r\n <ul>\r\n <li *ngFor=\"let nav of bottomNavList, let i = index\" [ngClass]=\"{ active: nav.active }\" (click)=\"onItemClick($event, nav, i, 'bottom')\">\r\n <i *ngIf=\"nav.icon; else imageTemplate\" [class]=\"'cax pi ' + nav.icon\"></i>\r\n <ng-template #imageTemplate>\r\n <cax-image [src]=\"nav.image\" width=\"24px\" height=\"24px\"></cax-image>\r\n </ng-template>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">{{ nav.label }}</span>\r\n </li>\r\n <li *ngIf=\"notifications\" (click)=\"emitNotification()\" [ngClass]=\"{ active: notificationActive }\">\r\n <i class=\"cax cax-bell\"></i>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">Notifications</span>\r\n </li>\r\n <li *ngIf=\"helpCentre\" (click)=\"emitHelpCentre()\" [ngClass]=\"{ active: helpCentreActive }\">\r\n <i class=\"cax cax-question-circle\"></i>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">Help Centre</span>\r\n </li>\r\n </ul>\r\n </div>\r\n <div *ngIf=\"userName\" (click)=\"op.toggle($event);\" [ngClass]=\"{ active: accountDetailsActive }\" class=\"cax-nav-account-details\">\r\n <cax-avatar *ngIf=\"userImage\" [image]=\"userImage\" avatarSize=\"lg\"></cax-avatar>\r\n <cax-avatar *ngIf=\"!userImage\" [label]=\"getInitials(userName)\" avatarSize=\"lg\"></cax-avatar>\r\n <div [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-user\">\r\n <span class=\"cax-nav-user-name\">{{ userName }}</span>\r\n <span class=\"cax-nav-user-role\">{{ userRole }}</span>\r\n </div>\r\n <div [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-account-icon\">\r\n <i class=\"cax cax-alt-arrow-up\"></i>\r\n <i class=\"cax cax-alt-arrow-down\"></i>\r\n </div>\r\n <cax-overlayPanel #op (onShow)=\"accountDetailsActive = true\" [styleClass]=\"expanded ? 'cax-nav-overlay-expand' : 'cax-nav-overlay'\" (onHide)=\"accountDetailsActive = false\">\r\n <div *ngIf=\"organisationDetails?.length\" class=\"cax-nav-organisation-list\">\r\n <div *ngFor=\"let org of organisationDetails; let i = index\" class=\"cax-nav-organisation-container\" (click)=\"onPlanClick(org, i)\" [ngClass]=\"{ active: selectedOrganisastionPlan == i }\">\r\n <cax-avatar *ngIf=\"org.image; else labelTemplate\" [image]=\"org.image\" avatarSize=\"lg\"></cax-avatar>\r\n <ng-template #labelTemplate>\r\n <cax-avatar *ngIf=\"org.label; else initialTemplate\" [label]=\"org.label\" avatarSize=\"lg\"></cax-avatar>\r\n </ng-template>\r\n <ng-template #initialTemplate>\r\n <cax-avatar [label]=\"getInitials(org.name)\" avatarSize=\"lg\"></cax-avatar>\r\n </ng-template>\r\n <div class=\"cax-nav-organisation\">\r\n <span class=\"cax-nav-organisation-name\">{{ org.name }}</span>\r\n <span *ngIf=\"org.plan == 'paid'\" class=\"cax-nav-organisation-plan\">\r\n <i class=\"cax cax-wallet\"></i>\r\n Paid Plan\r\n </span>\r\n <span *ngIf=\"org.plan == 'free'\" class=\"cax-nav-organisation-plan\">\r\n <i class=\"cax cax-ticket-sale\"></i>\r\n Free Plan\r\n </span>\r\n <span *ngIf=\"org.plan == 'trial'\" class=\"cax-nav-organisation-plan\">\r\n <i class=\"cax cax-history2\"></i>\r\n Trial Version\r\n </span>\r\n </div>\r\n <cax-radioButton class=\"cax-nav-organisation-radio\" [value]=\"i\" name=\"organisation-plan\" [(ngModel)]=\"selectedOrganisastionPlan\"></cax-radioButton>\r\n </div>\r\n </div>\r\n <div *ngIf=\"settings\" class=\"cax-nav-profile-options\" (click)=\"emitSettings()\">\r\n <i class=\"cax cax-settings\"></i>\r\n <span>Account Settings</span>\r\n </div>\r\n <div *ngIf=\"profile\" class=\"cax-nav-profile-options\" (click)=\"emitProfile()\">\r\n <i class=\"cax cax-user-rounded\"></i>\r\n <span>View Profile</span>\r\n </div>\r\n <div *ngIf=\"logout\" class=\"cax-nav-profile-options cax-nav-logout\" (click)=\"emitLogout()\">\r\n <i class=\"cax cax-logout\"></i>\r\n <span>Logout</span>\r\n </div>\r\n <div class=\"cax-nav-copyright-container\">\r\n <cax-logo width=\"55px\" height=\"17px\"></cax-logo>\r\n <div class=\"cax-nav-copyright\">\r\n <span *ngIf=\"copyrightYear\">&copy; {{ copyrightYear }}</span>\r\n <span *ngIf=\"version\">{{ version }}</span>\r\n </div>\r\n </div>\r\n </cax-overlayPanel>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: ["@layer cax{.cax-nav{width:88px;height:100vh;transition:width .3s ease-in-out;overflow:hidden;padding:16px 8px;position:absolute;left:0;top:0;z-index:1200}.cax-nav.cax-nav-expand{width:264px}.cax-nav.cax-nav-expand .cax-nav-header-container{margin-right:10px}.cax-nav-header-container{display:flex;align-items:center;justify-content:center;height:64px}.cax-nav-header{display:flex;align-items:center;justify-content:center}.cax-nav-header span{font-weight:700;font-size:12px}.cax-nav-toggle{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;position:fixed;cursor:pointer;transition:transform .3s ease-in-out,left .3s ease-in-out}.cax-nav .cax-nav-toggle{left:68px;top:28px}.cax-nav.cax-nav-expand .cax-nav-toggle{left:244px;transform:rotate(180deg)}.cax-nav .cax-divider.cax-divider-vertical{margin:0 8px;height:36px}.cax-nav-list-container,.cax-nav-bottom-list{margin:24px 0}.cax-nav-list-container ul,.cax-nav-bottom-list ul{margin:0;padding:0;list-style-type:none;display:flex;flex-direction:column;gap:16px}.cax-nav-list-container ul li,.cax-nav-bottom-list ul li{padding:12px 24px;border-radius:12px;display:flex;align-items:center;cursor:pointer;height:56px;line-height:24px}.cax-nav-list-container{overflow-y:auto}.cax-nav-list-container::-webkit-scrollbar{display:none}.cax-nav-bottom-container{position:absolute;bottom:16px}.cax-nav-account-details{border-radius:12px;padding:12px;cursor:pointer;transition:width .3s ease-in-out;display:flex;align-items:flex-start}.cax-nav-account-details .cax-nav-account-icon{display:grid;margin-left:auto}.cax-nav.cax-nav-expand .cax-nav-account-details{width:248px}.cax-nav-user{display:grid;margin:0 8px;white-space:nowrap}.cax-nav-user .cax-nav-user-name{font-size:16px;font-weight:500;line-height:24px}.cax-nav-user .cax-nav-user-role{font-size:14px;font-weight:400;line-height:21px}.cax-overlaypanel{width:320px}.cax-overlaypanel .cax-overlaypanel-content{padding:8px}.cax-nav-copyright-container{display:flex;align-items:center;justify-content:space-between}.cax-nav-copyright-container .cax-nav-copyright{font-size:12px;font-weight:500}.cax-nav-copyright-container .cax-nav-copyright span{margin:0 0 0 16px}.cax-nav-profile-options{padding:12px 24px;font-weight:600;line-height:24px;display:flex;align-items:center;cursor:pointer;border-radius:12px;margin-bottom:8px;font-size:16px}.cax-nav-profile-options span{margin-left:8px}.cax-nav-organisation-list{border-radius:12px;padding:8px;margin-bottom:8px}.cax-nav-organisation-container{display:flex;align-items:flex-start;cursor:pointer;padding:12px;border-radius:8px}.cax-nav-organisation-container .cax-nav-organisation-radio{margin-left:auto}.cax-nav-organisation-container:not(:last-child){margin-bottom:8px}.cax-nav-organisation{display:grid;margin:0 8px;white-space:nowrap}.cax-nav-organisation .cax-nav-organisation-name{font-weight:600;font-size:16px;line-height:24px}.cax-nav-organisation .cax-nav-organisation-plan{display:flex;font-size:14px;font-weight:500;line-height:21px}.cax-nav-organisation .cax-nav-organisation-plan i{font-size:20px;margin-right:3px}.cax-nav-overlay-expand{left:270px!important;top:auto!important;bottom:6px}.cax-nav-overlay{left:94px!important;top:auto!important;bottom:6px}}\n"], dependencies: [{ kind: "ngmodule", type: LogoModule }, { kind: "component", type: i1.Logo, selector: "cax-logo", inputs: ["size", "width", "height", "iconOnly", "darkMode"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: DividerModule }, { kind: "component", type: i3.Divider, selector: "cax-divider", inputs: ["style", "styleClass", "layout", "type", "align"] }, { kind: "ngmodule", type: ImageModule }, { kind: "component", type: i4.Image, selector: "cax-image", inputs: ["imageClass", "imageStyle", "styleClass", "style", "src", "srcSet", "sizes", "size", "previewImageSrc", "previewImageSrcSet", "previewImageSizes", "alt", "width", "height", "loading", "appendTo", "preview", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onShow", "onHide", "onImageError"] }, { kind: "ngmodule", type: AvatarModule }, { kind: "component", type: i5.Avatar, selector: "cax-avatar", inputs: ["label", "icon", "image", "avatarSize", "shape", "style", "styleClass", "ariaLabel", "ariaLabelledBy"], outputs: ["onImageError"] }, { kind: "ngmodule", type: OverlayPanelModule }, { kind: "component", type: i6.OverlayPanel, selector: "cax-overlayPanel", inputs: ["ariaLabel", "ariaLabelledBy", "dismissable", "showCloseIcon", "style", "styleClass", "appendTo", "autoZIndex", "ariaCloseLabel", "baseZIndex", "focusOnShow", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onShow", "onHide"] }, { kind: "ngmodule", type: OverlayModule }, { kind: "ngmodule", type: RadioButtonModule }, { kind: "component", type: i7.RadioButton, selector: "cax-radioButton", inputs: ["value", "formControlName", "name", "disabled", "label", "variant", "tabindex", "inputId", "ariaLabelledBy", "ariaLabel", "style", "styleClass", "labelStyleClass", "autofocus"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i8.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], animations: [
180
186
  trigger('leftFade', [
181
187
  transition(':enter', [style({ transform: 'translateX(-100%)', opacity: 0 }), animate('300ms', style({ transform: 'translateX(0)', opacity: 1 }))]),
182
188
  transition(':leave', [style({ transform: 'translateX(0)', opacity: 0.5 }), animate('300ms', style({ transform: 'translateX(-100%)', opacity: 0 }))])
@@ -200,7 +206,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.9", ngImpor
200
206
  ])
201
207
  ], host: {
202
208
  class: 'cax-element'
203
- }, template: "<div *ngIf=\"accountDetailsActive\" class=\"cax-nav-backdrop\"></div>\r\n<div class=\"cax-nav\" [ngClass]=\"{ 'cax-nav-expand': expanded }\">\r\n <div class=\"cax-nav-toggle\" (click)=\"toggleSidebar()\">\r\n <i class=\"cax cax-alt-arrow-right\"></i>\r\n </div>\r\n <div class=\"cax-nav-header-container\" #headerContainer>\r\n <div [@rightFade] *ngIf=\"!expanded\" class=\"cax-nav-header\">\r\n <cax-logo size=\"xsm\" [iconOnly]=\"true\" />\r\n </div>\r\n <div *ngIf=\"expanded\" class=\"cax-nav-header\" [@leftFade]>\r\n <cax-logo size=\"xsm\" />\r\n <cax-divider layout=\"vertical\"></cax-divider>\r\n <span>{{ header }}</span>\r\n </div>\r\n </div>\r\n <div class=\"cax-nav-list-container\" [style.maxHeight.px]=\"adjustUpDivHeight()\">\r\n <ul>\r\n <li *ngFor=\"let nav of topNavList, let i = index\" [ngClass]=\"{ active: nav.active }\" (click)=\"onItemClick($event, nav, i, 'top')\">\r\n <i *ngIf=\"nav.icon; else imageTemplate\" [class]=\"'cax pi ' + nav.icon\"></i>\r\n <ng-template #imageTemplate>\r\n <cax-image [src]=\"nav.image\" width=\"24px\" height=\"24px\"></cax-image>\r\n </ng-template>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">{{ nav.label }}</span>\r\n </li>\r\n </ul>\r\n </div>\r\n <div class=\"cax-nav-bottom-container\" #bottomContainer>\r\n <div class=\"cax-nav-bottom-list\">\r\n <ul>\r\n <li *ngFor=\"let nav of bottomNavList, let i = index\" [ngClass]=\"{ active: nav.active }\" (click)=\"onItemClick($event, nav, i, 'bottom')\">\r\n <i *ngIf=\"nav.icon; else imageTemplate\" [class]=\"'cax pi ' + nav.icon\"></i>\r\n <ng-template #imageTemplate>\r\n <cax-image [src]=\"nav.image\" width=\"24px\" height=\"24px\"></cax-image>\r\n </ng-template>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">{{ nav.label }}</span>\r\n </li>\r\n <li *ngIf=\"notifications\" (click)=\"emitNotification()\" [ngClass]=\"{ active: notificationActive }\">\r\n <i class=\"cax cax-bell\"></i>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">Notifications</span>\r\n </li>\r\n <li *ngIf=\"helpCentre\" (click)=\"emitHelpCentre()\" [ngClass]=\"{ active: helpCentreActive }\">\r\n <i class=\"cax cax-shield-check\"></i>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">Help Centre</span>\r\n </li>\r\n </ul>\r\n </div>\r\n <div *ngIf=\"userName\" (click)=\"op.toggle($event);\" [ngClass]=\"{ active: accountDetailsActive }\" class=\"cax-nav-account-details\">\r\n <cax-avatar *ngIf=\"userImage\" [image]=\"userImage\" avatarSize=\"lg\"></cax-avatar>\r\n <cax-avatar *ngIf=\"!userImage\" [label]=\"getInitials(userName)\" avatarSize=\"lg\"></cax-avatar>\r\n <div [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-user\">\r\n <span class=\"cax-nav-user-name\">{{ userName }}</span>\r\n <span class=\"cax-nav-user-role\">{{ userRole }}</span>\r\n </div>\r\n <div [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-account-icon\">\r\n <i class=\"cax cax-alt-arrow-up\"></i>\r\n <i class=\"cax cax-alt-arrow-down\"></i>\r\n </div>\r\n <cax-overlayPanel #op (onShow)=\"accountDetailsActive = true\" [styleClass]=\"expanded ? 'cax-nav-overlay-expand' : 'cax-nav-overlay'\" (onHide)=\"accountDetailsActive = false\">\r\n <div *ngIf=\"organisationDetails?.length\" class=\"cax-nav-organisation-list\">\r\n <div *ngFor=\"let org of organisationDetails; let i = index\" class=\"cax-nav-organisation-container\" (click)=\"onPlanClick(org, i)\" [ngClass]=\"{ active: selectedOrganisastionPlan == i }\">\r\n <cax-avatar *ngIf=\"org.image; else labelTemplate\" [image]=\"org.image\" avatarSize=\"lg\"></cax-avatar>\r\n <ng-template #labelTemplate>\r\n <cax-avatar *ngIf=\"org.label; else initialTemplate\" [label]=\"org.label\" avatarSize=\"lg\"></cax-avatar>\r\n </ng-template>\r\n <ng-template #initialTemplate>\r\n <cax-avatar [label]=\"getInitials(org.name)\" avatarSize=\"lg\"></cax-avatar>\r\n </ng-template>\r\n <div class=\"cax-nav-organisation\">\r\n <span class=\"cax-nav-organisation-name\">{{ org.name }}</span>\r\n <span *ngIf=\"org.plan == 'paid'\" class=\"cax-nav-organisation-plan\">\r\n <i class=\"cax cax-wallet\"></i>\r\n Paid Plan\r\n </span>\r\n <span *ngIf=\"org.plan == 'free'\" class=\"cax-nav-organisation-plan\">\r\n <i class=\"cax cax-ticket-sale\"></i>\r\n Free Plan\r\n </span>\r\n <span *ngIf=\"org.plan == 'trial'\" class=\"cax-nav-organisation-plan\">\r\n <i class=\"cax cax-history2\"></i>\r\n Trial Version\r\n </span>\r\n </div>\r\n <cax-radioButton class=\"cax-nav-organisation-radio\" [value]=\"i\" name=\"organisation-plan\" [(ngModel)]=\"selectedOrganisastionPlan\"></cax-radioButton>\r\n </div>\r\n </div>\r\n <div *ngIf=\"settings\" class=\"cax-nav-profile-options\" (click)=\"emitSettings()\">\r\n <i class=\"cax cax-settings\"></i>\r\n <span>Account Settings</span>\r\n </div>\r\n <div *ngIf=\"profile\" class=\"cax-nav-profile-options\" (click)=\"emitProfile()\">\r\n <i class=\"cax cax-user-rounded\"></i>\r\n <span>View Profile</span>\r\n </div>\r\n <div *ngIf=\"logout\" class=\"cax-nav-profile-options cax-nav-logout\" (click)=\"emitLogout()\">\r\n <i class=\"cax cax-logout\"></i>\r\n <span>Logout</span>\r\n </div>\r\n <div class=\"cax-nav-copyright-container\">\r\n <cax-logo width=\"55px\" height=\"17px\"></cax-logo>\r\n <div class=\"cax-nav-copyright\">\r\n <span *ngIf=\"copyrightYear\">&copy; {{ copyrightYear }}</span>\r\n <span *ngIf=\"version\">{{ version }}</span>\r\n </div>\r\n </div>\r\n </cax-overlayPanel>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: ["@layer cax{.cax-nav{width:88px;height:100vh;transition:width .3s ease-in-out;overflow:hidden;padding:16px 8px;position:absolute;left:0;top:0;z-index:1200}.cax-nav.cax-nav-expand{width:264px}.cax-nav.cax-nav-expand .cax-nav-header-container{margin-right:10px}.cax-nav-header-container{display:flex;align-items:center;justify-content:center;height:64px}.cax-nav-header{display:flex;align-items:center;justify-content:center}.cax-nav-header span{font-weight:700;font-size:12px}.cax-nav-toggle{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;position:fixed;cursor:pointer;transition:transform .3s ease-in-out,left .3s ease-in-out}.cax-nav .cax-nav-toggle{left:68px;top:28px}.cax-nav.cax-nav-expand .cax-nav-toggle{left:244px;transform:rotate(180deg)}.cax-nav .cax-divider.cax-divider-vertical{margin:0 8px;height:36px}.cax-nav-list-container,.cax-nav-bottom-list{margin:24px 0}.cax-nav-list-container ul,.cax-nav-bottom-list ul{margin:0;padding:0;list-style-type:none;display:flex;flex-direction:column;gap:16px}.cax-nav-list-container ul li,.cax-nav-bottom-list ul li{padding:12px 24px;border-radius:12px;display:flex;align-items:center;cursor:pointer;height:56px;line-height:24px}.cax-nav-list-container{overflow-y:auto}.cax-nav-list-container::-webkit-scrollbar{display:none}.cax-nav-bottom-container{position:absolute;bottom:16px}.cax-nav-account-details{border-radius:12px;padding:12px;cursor:pointer;transition:width .3s ease-in-out;display:flex;align-items:flex-start}.cax-nav-account-details .cax-nav-account-icon{display:grid;margin-left:auto}.cax-nav.cax-nav-expand .cax-nav-account-details{width:248px}.cax-nav-user{display:grid;margin:0 8px;white-space:nowrap}.cax-nav-user .cax-nav-user-name{font-size:16px;font-weight:500;line-height:24px}.cax-nav-user .cax-nav-user-role{font-size:14px;font-weight:400;line-height:21px}.cax-overlaypanel{width:320px}.cax-overlaypanel .cax-overlaypanel-content{padding:8px}.cax-nav-copyright-container{display:flex;align-items:center;justify-content:space-between}.cax-nav-copyright-container .cax-nav-copyright{font-size:12px;font-weight:500}.cax-nav-copyright-container .cax-nav-copyright span{margin:0 0 0 16px}.cax-nav-profile-options{padding:12px 24px;font-weight:600;line-height:24px;display:flex;align-items:center;cursor:pointer;border-radius:12px;margin-bottom:8px;font-size:16px}.cax-nav-profile-options span{margin-left:8px}.cax-nav-organisation-list{border-radius:12px;padding:8px;margin-bottom:8px}.cax-nav-organisation-container{display:flex;align-items:flex-start;cursor:pointer;padding:12px;border-radius:8px}.cax-nav-organisation-container .cax-nav-organisation-radio{margin-left:auto}.cax-nav-organisation-container:not(:last-child){margin-bottom:8px}.cax-nav-organisation{display:grid;margin:0 8px;white-space:nowrap}.cax-nav-organisation .cax-nav-organisation-name{font-weight:600;font-size:16px;line-height:24px}.cax-nav-organisation .cax-nav-organisation-plan{display:flex;font-size:14px;font-weight:500;line-height:21px}.cax-nav-organisation .cax-nav-organisation-plan i{font-size:20px;margin-right:3px}.cax-nav-overlay-expand{left:270px!important;top:auto!important;bottom:6px}.cax-nav-overlay{left:94px!important;top:auto!important;bottom:6px}}\n"] }]
209
+ }, template: "<div *ngIf=\"accountDetailsActive\" class=\"cax-nav-backdrop\"></div>\r\n<div class=\"cax-nav\" [ngClass]=\"{ 'cax-nav-expand': expanded }\">\r\n <div class=\"cax-nav-toggle\" (click)=\"toggleSidebar()\">\r\n <i class=\"cax cax-alt-arrow-right\"></i>\r\n </div>\r\n <div class=\"cax-nav-header-container\" #headerContainer>\r\n <div [@rightFade] *ngIf=\"!expanded\" class=\"cax-nav-header\">\r\n <cax-logo size=\"xsm\" [iconOnly]=\"true\" />\r\n </div>\r\n <div *ngIf=\"expanded\" class=\"cax-nav-header\" [@leftFade]>\r\n <cax-logo size=\"xsm\" />\r\n <cax-divider layout=\"vertical\"></cax-divider>\r\n <span>{{ header }}</span>\r\n </div>\r\n </div>\r\n <div class=\"cax-nav-list-container\" [style.maxHeight.px]=\"adjustUpDivHeight()\">\r\n <ul>\r\n <li *ngFor=\"let nav of topNavList, let i = index\" [ngClass]=\"{ active: nav.active }\" (click)=\"onItemClick($event, nav, i, 'top')\">\r\n <i *ngIf=\"nav.icon; else imageTemplate\" [class]=\"'cax pi ' + nav.icon\"></i>\r\n <ng-template #imageTemplate>\r\n <cax-image [src]=\"nav.image\" width=\"24px\" height=\"24px\"></cax-image>\r\n </ng-template>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">{{ nav.label }}</span>\r\n </li>\r\n </ul>\r\n </div>\r\n <div class=\"cax-nav-bottom-container\" #bottomContainer>\r\n <div class=\"cax-nav-bottom-list\">\r\n <ul>\r\n <li *ngFor=\"let nav of bottomNavList, let i = index\" [ngClass]=\"{ active: nav.active }\" (click)=\"onItemClick($event, nav, i, 'bottom')\">\r\n <i *ngIf=\"nav.icon; else imageTemplate\" [class]=\"'cax pi ' + nav.icon\"></i>\r\n <ng-template #imageTemplate>\r\n <cax-image [src]=\"nav.image\" width=\"24px\" height=\"24px\"></cax-image>\r\n </ng-template>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">{{ nav.label }}</span>\r\n </li>\r\n <li *ngIf=\"notifications\" (click)=\"emitNotification()\" [ngClass]=\"{ active: notificationActive }\">\r\n <i class=\"cax cax-bell\"></i>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">Notifications</span>\r\n </li>\r\n <li *ngIf=\"helpCentre\" (click)=\"emitHelpCentre()\" [ngClass]=\"{ active: helpCentreActive }\">\r\n <i class=\"cax cax-question-circle\"></i>\r\n <span [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-list-label\">Help Centre</span>\r\n </li>\r\n </ul>\r\n </div>\r\n <div *ngIf=\"userName\" (click)=\"op.toggle($event);\" [ngClass]=\"{ active: accountDetailsActive }\" class=\"cax-nav-account-details\">\r\n <cax-avatar *ngIf=\"userImage\" [image]=\"userImage\" avatarSize=\"lg\"></cax-avatar>\r\n <cax-avatar *ngIf=\"!userImage\" [label]=\"getInitials(userName)\" avatarSize=\"lg\"></cax-avatar>\r\n <div [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-user\">\r\n <span class=\"cax-nav-user-name\">{{ userName }}</span>\r\n <span class=\"cax-nav-user-role\">{{ userRole }}</span>\r\n </div>\r\n <div [@leftFade] *ngIf=\"expanded\" class=\"cax-nav-account-icon\">\r\n <i class=\"cax cax-alt-arrow-up\"></i>\r\n <i class=\"cax cax-alt-arrow-down\"></i>\r\n </div>\r\n <cax-overlayPanel #op (onShow)=\"accountDetailsActive = true\" [styleClass]=\"expanded ? 'cax-nav-overlay-expand' : 'cax-nav-overlay'\" (onHide)=\"accountDetailsActive = false\">\r\n <div *ngIf=\"organisationDetails?.length\" class=\"cax-nav-organisation-list\">\r\n <div *ngFor=\"let org of organisationDetails; let i = index\" class=\"cax-nav-organisation-container\" (click)=\"onPlanClick(org, i)\" [ngClass]=\"{ active: selectedOrganisastionPlan == i }\">\r\n <cax-avatar *ngIf=\"org.image; else labelTemplate\" [image]=\"org.image\" avatarSize=\"lg\"></cax-avatar>\r\n <ng-template #labelTemplate>\r\n <cax-avatar *ngIf=\"org.label; else initialTemplate\" [label]=\"org.label\" avatarSize=\"lg\"></cax-avatar>\r\n </ng-template>\r\n <ng-template #initialTemplate>\r\n <cax-avatar [label]=\"getInitials(org.name)\" avatarSize=\"lg\"></cax-avatar>\r\n </ng-template>\r\n <div class=\"cax-nav-organisation\">\r\n <span class=\"cax-nav-organisation-name\">{{ org.name }}</span>\r\n <span *ngIf=\"org.plan == 'paid'\" class=\"cax-nav-organisation-plan\">\r\n <i class=\"cax cax-wallet\"></i>\r\n Paid Plan\r\n </span>\r\n <span *ngIf=\"org.plan == 'free'\" class=\"cax-nav-organisation-plan\">\r\n <i class=\"cax cax-ticket-sale\"></i>\r\n Free Plan\r\n </span>\r\n <span *ngIf=\"org.plan == 'trial'\" class=\"cax-nav-organisation-plan\">\r\n <i class=\"cax cax-history2\"></i>\r\n Trial Version\r\n </span>\r\n </div>\r\n <cax-radioButton class=\"cax-nav-organisation-radio\" [value]=\"i\" name=\"organisation-plan\" [(ngModel)]=\"selectedOrganisastionPlan\"></cax-radioButton>\r\n </div>\r\n </div>\r\n <div *ngIf=\"settings\" class=\"cax-nav-profile-options\" (click)=\"emitSettings()\">\r\n <i class=\"cax cax-settings\"></i>\r\n <span>Account Settings</span>\r\n </div>\r\n <div *ngIf=\"profile\" class=\"cax-nav-profile-options\" (click)=\"emitProfile()\">\r\n <i class=\"cax cax-user-rounded\"></i>\r\n <span>View Profile</span>\r\n </div>\r\n <div *ngIf=\"logout\" class=\"cax-nav-profile-options cax-nav-logout\" (click)=\"emitLogout()\">\r\n <i class=\"cax cax-logout\"></i>\r\n <span>Logout</span>\r\n </div>\r\n <div class=\"cax-nav-copyright-container\">\r\n <cax-logo width=\"55px\" height=\"17px\"></cax-logo>\r\n <div class=\"cax-nav-copyright\">\r\n <span *ngIf=\"copyrightYear\">&copy; {{ copyrightYear }}</span>\r\n <span *ngIf=\"version\">{{ version }}</span>\r\n </div>\r\n </div>\r\n </cax-overlayPanel>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: ["@layer cax{.cax-nav{width:88px;height:100vh;transition:width .3s ease-in-out;overflow:hidden;padding:16px 8px;position:absolute;left:0;top:0;z-index:1200}.cax-nav.cax-nav-expand{width:264px}.cax-nav.cax-nav-expand .cax-nav-header-container{margin-right:10px}.cax-nav-header-container{display:flex;align-items:center;justify-content:center;height:64px}.cax-nav-header{display:flex;align-items:center;justify-content:center}.cax-nav-header span{font-weight:700;font-size:12px}.cax-nav-toggle{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;position:fixed;cursor:pointer;transition:transform .3s ease-in-out,left .3s ease-in-out}.cax-nav .cax-nav-toggle{left:68px;top:28px}.cax-nav.cax-nav-expand .cax-nav-toggle{left:244px;transform:rotate(180deg)}.cax-nav .cax-divider.cax-divider-vertical{margin:0 8px;height:36px}.cax-nav-list-container,.cax-nav-bottom-list{margin:24px 0}.cax-nav-list-container ul,.cax-nav-bottom-list ul{margin:0;padding:0;list-style-type:none;display:flex;flex-direction:column;gap:16px}.cax-nav-list-container ul li,.cax-nav-bottom-list ul li{padding:12px 24px;border-radius:12px;display:flex;align-items:center;cursor:pointer;height:56px;line-height:24px}.cax-nav-list-container{overflow-y:auto}.cax-nav-list-container::-webkit-scrollbar{display:none}.cax-nav-bottom-container{position:absolute;bottom:16px}.cax-nav-account-details{border-radius:12px;padding:12px;cursor:pointer;transition:width .3s ease-in-out;display:flex;align-items:flex-start}.cax-nav-account-details .cax-nav-account-icon{display:grid;margin-left:auto}.cax-nav.cax-nav-expand .cax-nav-account-details{width:248px}.cax-nav-user{display:grid;margin:0 8px;white-space:nowrap}.cax-nav-user .cax-nav-user-name{font-size:16px;font-weight:500;line-height:24px}.cax-nav-user .cax-nav-user-role{font-size:14px;font-weight:400;line-height:21px}.cax-overlaypanel{width:320px}.cax-overlaypanel .cax-overlaypanel-content{padding:8px}.cax-nav-copyright-container{display:flex;align-items:center;justify-content:space-between}.cax-nav-copyright-container .cax-nav-copyright{font-size:12px;font-weight:500}.cax-nav-copyright-container .cax-nav-copyright span{margin:0 0 0 16px}.cax-nav-profile-options{padding:12px 24px;font-weight:600;line-height:24px;display:flex;align-items:center;cursor:pointer;border-radius:12px;margin-bottom:8px;font-size:16px}.cax-nav-profile-options span{margin-left:8px}.cax-nav-organisation-list{border-radius:12px;padding:8px;margin-bottom:8px}.cax-nav-organisation-container{display:flex;align-items:flex-start;cursor:pointer;padding:12px;border-radius:8px}.cax-nav-organisation-container .cax-nav-organisation-radio{margin-left:auto}.cax-nav-organisation-container:not(:last-child){margin-bottom:8px}.cax-nav-organisation{display:grid;margin:0 8px;white-space:nowrap}.cax-nav-organisation .cax-nav-organisation-name{font-weight:600;font-size:16px;line-height:24px}.cax-nav-organisation .cax-nav-organisation-plan{display:flex;font-size:14px;font-weight:500;line-height:21px}.cax-nav-organisation .cax-nav-organisation-plan i{font-size:20px;margin-right:3px}.cax-nav-overlay-expand{left:270px!important;top:auto!important;bottom:6px}.cax-nav-overlay{left:94px!important;top:auto!important;bottom:6px}}\n"] }]
204
210
  }], propDecorators: { expanded: [{
205
211
  type: Input
206
212
  }], header: [{