@posiwise/shared-components 0.0.118 → 0.0.120

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.
@@ -17,7 +17,6 @@ export class ProfileImageCropperComponent {
17
17
  this.showCropper = false;
18
18
  }
19
19
  onFileChange(event) {
20
- console.log(this.aspectRatio, this.dynamicData);
21
20
  const input = event.target;
22
21
  if (input.files && input.files.length > 0) {
23
22
  this.imageChangedEvent = event;
@@ -90,4 +89,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
90
89
  }], dynamicData: [{
91
90
  type: Input
92
91
  }] } });
93
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-cropper.component.js","sourceRoot":"","sources":["../../../../../../libs/shared-components/src/lib/image-cropper/image-cropper.component.ts","../../../../../../libs/shared-components/src/lib/image-cropper/image-cropper.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, EventEmitter, Input, Output } from '@angular/core';\n\nimport { ImageCroppedEvent, ImageTransform } from 'ngx-image-cropper';\n\n@Component({\n    selector: 'pw-image-cropper',\n    templateUrl: './image-cropper.component.html',\n    styleUrls: ['./image-cropper.component.scss']\n})\nexport class ProfileImageCropperComponent {\n    imageChangedEvent: Event | string = '';\n    croppedImage = '';\n\n    @Output() imageSelectionEvent: EventEmitter<string> = new EventEmitter<string>();\n    @Output() closeEvent: EventEmitter<void> = new EventEmitter<void>();\n    @Output() fileChangeEvent: EventEmitter<string> = new EventEmitter<string>();\n\n    @Input() aspectRatio = 'auto';\n    @Input() dynamicData;\n\n    transform: ImageTransform = {};\n    canvasRotation = 0;\n    showCropper = false;\n\n    busy: boolean;\n\n    constructor(private readonly cdr: ChangeDetectorRef) {}\n\n    onFileChange(event: Event): void {\n        console.log(this.aspectRatio, this.dynamicData);\n        const input = event.target as HTMLInputElement;\n        if (input.files && input.files.length > 0) {\n            this.imageChangedEvent = event;\n            this.fileChangeEvent.emit(input.files[0].name);\n        }\n    }\n\n    imageCropped(event: ImageCroppedEvent) {\n        const reader = new FileReader();\n        reader.onloadend = () => {\n            this.croppedImage = reader.result as string;\n            this.cdr.detectChanges();\n        };\n        reader.readAsDataURL(event.blob);\n    }\n\n    imageLoaded() {\n        this.showCropper = true;\n    }\n\n    rotateLeft() {\n        this.canvasRotation--;\n        this.flipAfterRotate();\n    }\n\n    rotateRight() {\n        this.canvasRotation++;\n        this.flipAfterRotate();\n    }\n\n    private flipAfterRotate() {\n        const flippedH = this.transform.flipH;\n        const flippedV = this.transform.flipV;\n        this.transform = {\n            ...this.transform,\n            flipH: flippedV,\n            flipV: flippedH\n        };\n    }\n\n    flipHorizontal() {\n        this.transform = {\n            ...this.transform,\n            flipH: !this.transform.flipH\n        };\n    }\n\n    flipVertical() {\n        this.transform = {\n            ...this.transform,\n            flipV: !this.transform.flipV\n        };\n    }\n\n    saveProfilePicture() {\n        if (this.croppedImage) {\n            this.imageSelectionEvent.emit(this.croppedImage);\n            this.busy = true;\n        }\n    }\n\n    onCloseModal() {\n        this.closeEvent.emit();\n    }\n}\n","<section class=\"image-cropper\">\n  <div class=\"row text-start\">\n    <div class=\"col-12\">\n      <div class=\"card-block pb-0\">\n        <div class=\"row\">\n          <div class=\"col-12\">\n            <div class=\"file-upload my-2 float-start\">\n              <label for=\"custom-input\">\n                Upload Pic\n                <input id=\"custom-input\"\n                  type=\"file\"\n                  (change)=\"onFileChange($event)\" />\n              </label>\n            </div>\n\n            <div class=\"float-end m-2\">\n              <button class=\"btn btn-primary btn-sm mx-2\"\n                title=\"Rotate Left\">\n                <i\n                                    class=\"fa fa-undo-alt\"\n                                    (click)=\"rotateLeft()\"\n                                    (keydown.enter)=\"rotateLeft()\"\n                                    aria-hidden=\"true\"\n                                ></i>\n              </button>\n\n              <button class=\"btn btn-primary btn-sm mx-2\"\n                title=\"Rotate Right\">\n                <i\n                                    class=\"fa fa-redo-alt\"\n                                    (click)=\"rotateRight()\"\n                                    (keydown.enter)=\"rotateRight()\"\n                                    aria-hidden=\"true\"\n                                ></i>\n              </button>\n\n              <button class=\"btn btn-primary btn-sm mx-2\"\n                title=\"Flip Horizontal\">\n                <i\n                                    class=\"fa fa-arrows-alt-h\"\n                                    (click)=\"flipHorizontal()\"\n                                    (keydown.enter)=\"flipHorizontal()\"\n                                    aria-hidden=\"true\"\n                                ></i>\n              </button>\n              <button class=\"btn btn-primary btn-sm mx-2\"\n                title=\"Flip Vertical\">\n                <i\n                                    class=\"fa fa-arrows-alt-v\"\n                                    (click)=\"flipVertical()\"\n                                    (keydown.enter)=\"flipVertical()\"\n                                    aria-hidden=\"true\"\n                                ></i>\n              </button>\n            </div>\n          </div>\n        </div>\n\n        <div class=\"row\">\n          <div class=\"col-8\">\n            <div *ngIf=\"aspectRatio === 'auto'\">\n              <image-cropper [imageChangedEvent]=\"imageChangedEvent\"\n                [maintainAspectRatio]=\"true\"\n                [canvasRotation]=\"canvasRotation\"\n                [aspectRatio]=\"4 / 4\"\n                [onlyScaleDown]=\"true\"\n                [transform]=\"transform\"\n                [roundCropper]=\"false\"\n                alignImage=\"center\"\n                outputType=\"base64\"\n                (imageCropped)=\"imageCropped($event)\"\n                (imageLoaded)=\"imageLoaded()\"\n                imageQuality=\"100\"\n                [style.display]=\"showCropper ? null : 'none'\"></image-cropper>\n            </div>\n\n            <div *ngIf=\"aspectRatio === 'fullLogo'\">\n              <image-cropper [imageChangedEvent]=\"imageChangedEvent\"\n                [maintainAspectRatio]=\"true\"\n                [aspectRatio]=\"5 / 1.1\"\n                [onlyScaleDown]=\"true\"\n                [roundCropper]=\"false\"\n                alignImage=\"center\"\n                outputType=\"base64\"\n                (imageCropped)=\"imageCropped($event)\"\n                (imageLoaded)=\"imageLoaded()\"\n                imageQuality=\"100\"\n                [style.display]=\"showCropper ? null : 'none'\"></image-cropper>\n            </div>\n\n            <div *ngIf=\"aspectRatio === 'rectangular'\">\n              <image-cropper\n                [imageChangedEvent]=\"imageChangedEvent\"\n                [maintainAspectRatio]=\"true\"\n                [aspectRatio]=\"3 / 1\"\n                [onlyScaleDown]=\"true\"\n                [canvasRotation]=\"canvasRotation\"\n                [transform]=\"transform\"\n                [roundCropper]=\"false\"\n                alignImage=\"center\"\n                outputType=\"base64\"\n                (imageCropped)=\"imageCropped($event)\"\n                (imageLoaded)=\"imageLoaded()\"\n                imageQuality=\"100\"\n                [style.display]=\"showCropper ? null : 'none'\"></image-cropper>\n            </div>\n\n            <div *ngIf=\"aspectRatio === 'dynamic'\">\n              <image-cropper\n              [imageChangedEvent]=\"imageChangedEvent\"\n              [maintainAspectRatio]=\"false\"\n              [resizeToWidth]=\"0\"\n              [cropperStaticWidth]=\"0\"\n              [cropperStaticHeight]=\"0\"\n              [cropperMinWidth]=\"10\"\n              [cropperMinHeight]=\"10\"\n              [onlyScaleDown]=\"false\"\n              [canvasRotation]=\"canvasRotation\"\n              [transform]=\"transform\"\n              [roundCropper]=\"false\"\n              alignImage=\"center\"\n              outputType=\"base64\"\n              imageQuality=\"100\"\n              (imageCropped)=\"imageCropped($event)\"\n              (imageLoaded)=\"imageLoaded()\"\n              [style.display]=\"showCropper ? null : 'none'\">\n              </image-cropper>\n            </div>\n\n            <div *ngIf=\"aspectRatio === 'custom'\">\n              <image-cropper [imageChangedEvent]=\"imageChangedEvent\"\n                [maintainAspectRatio]=\"true\"\n                [canvasRotation]=\"canvasRotation\"\n                [transform]=\"transform\"\n                [aspectRatio]=\"4 / 3\"\n                [onlyScaleDown]=\"true\"\n                [roundCropper]=\"false\"\n                alignImage=\"center\"\n                outputType=\"base64\"\n                (imageCropped)=\"imageCropped($event)\"\n                (imageLoaded)=\"imageLoaded()\"\n                imageQuality=\"100\"\n                [style.display]=\"showCropper ? null : 'none'\"></image-cropper>\n            </div>\n          </div>\n          <div *ngIf=\"croppedImage\" class=\"col-4 mt-2\">\n            <img [src]=\"croppedImage\"\n            class=\"cropped-image\"\n              alt=\"cropped.png\"\n              width=\"128\" />\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n  <div class=\"card-footer px-3\">\n    <div class=\"float-end mt-2\">\n      <button type=\"button\"\n        class=\"btn btn-outline-default me-2\"\n        (click)=\"onCloseModal()\">\n        Close\n      </button>\n      <button type=\"button\"\n        class=\"btn btn-primary\"\n        (click)=\"saveProfilePicture()\"\n        [buttonBusy]=\"busy\">\n        Save\n      </button>\n    </div>\n  </div>\n</section>\n"]}
92
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-cropper.component.js","sourceRoot":"","sources":["../../../../../../libs/shared-components/src/lib/image-cropper/image-cropper.component.ts","../../../../../../libs/shared-components/src/lib/image-cropper/image-cropper.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, EventEmitter, Input, Output } from '@angular/core';\n\nimport { ImageCroppedEvent, ImageTransform } from 'ngx-image-cropper';\n\n@Component({\n    selector: 'pw-image-cropper',\n    templateUrl: './image-cropper.component.html',\n    styleUrls: ['./image-cropper.component.scss']\n})\nexport class ProfileImageCropperComponent {\n    imageChangedEvent: Event | string = '';\n    croppedImage = '';\n\n    @Output() imageSelectionEvent: EventEmitter<string> = new EventEmitter<string>();\n    @Output() closeEvent: EventEmitter<void> = new EventEmitter<void>();\n    @Output() fileChangeEvent: EventEmitter<string> = new EventEmitter<string>();\n\n    @Input() aspectRatio = 'auto';\n    @Input() dynamicData;\n\n    transform: ImageTransform = {};\n    canvasRotation = 0;\n    showCropper = false;\n\n    busy: boolean;\n\n    constructor(private readonly cdr: ChangeDetectorRef) {}\n\n    onFileChange(event: Event): void {\n        const input = event.target as HTMLInputElement;\n        if (input.files && input.files.length > 0) {\n            this.imageChangedEvent = event;\n            this.fileChangeEvent.emit(input.files[0].name);\n        }\n    }\n\n    imageCropped(event: ImageCroppedEvent) {\n        const reader = new FileReader();\n        reader.onloadend = () => {\n            this.croppedImage = reader.result as string;\n            this.cdr.detectChanges();\n        };\n        reader.readAsDataURL(event.blob);\n    }\n\n    imageLoaded() {\n        this.showCropper = true;\n    }\n\n    rotateLeft() {\n        this.canvasRotation--;\n        this.flipAfterRotate();\n    }\n\n    rotateRight() {\n        this.canvasRotation++;\n        this.flipAfterRotate();\n    }\n\n    private flipAfterRotate() {\n        const flippedH = this.transform.flipH;\n        const flippedV = this.transform.flipV;\n        this.transform = {\n            ...this.transform,\n            flipH: flippedV,\n            flipV: flippedH\n        };\n    }\n\n    flipHorizontal() {\n        this.transform = {\n            ...this.transform,\n            flipH: !this.transform.flipH\n        };\n    }\n\n    flipVertical() {\n        this.transform = {\n            ...this.transform,\n            flipV: !this.transform.flipV\n        };\n    }\n\n    saveProfilePicture() {\n        if (this.croppedImage) {\n            this.imageSelectionEvent.emit(this.croppedImage);\n            this.busy = true;\n        }\n    }\n\n    onCloseModal() {\n        this.closeEvent.emit();\n    }\n}\n","<section class=\"image-cropper\">\n  <div class=\"row text-start\">\n    <div class=\"col-12\">\n      <div class=\"card-block pb-0\">\n        <div class=\"row\">\n          <div class=\"col-12\">\n            <div class=\"file-upload my-2 float-start\">\n              <label for=\"custom-input\">\n                Upload Pic\n                <input id=\"custom-input\"\n                  type=\"file\"\n                  (change)=\"onFileChange($event)\" />\n              </label>\n            </div>\n\n            <div class=\"float-end m-2\">\n              <button class=\"btn btn-primary btn-sm mx-2\"\n                title=\"Rotate Left\">\n                <i\n                                    class=\"fa fa-undo-alt\"\n                                    (click)=\"rotateLeft()\"\n                                    (keydown.enter)=\"rotateLeft()\"\n                                    aria-hidden=\"true\"\n                                ></i>\n              </button>\n\n              <button class=\"btn btn-primary btn-sm mx-2\"\n                title=\"Rotate Right\">\n                <i\n                                    class=\"fa fa-redo-alt\"\n                                    (click)=\"rotateRight()\"\n                                    (keydown.enter)=\"rotateRight()\"\n                                    aria-hidden=\"true\"\n                                ></i>\n              </button>\n\n              <button class=\"btn btn-primary btn-sm mx-2\"\n                title=\"Flip Horizontal\">\n                <i\n                                    class=\"fa fa-arrows-alt-h\"\n                                    (click)=\"flipHorizontal()\"\n                                    (keydown.enter)=\"flipHorizontal()\"\n                                    aria-hidden=\"true\"\n                                ></i>\n              </button>\n              <button class=\"btn btn-primary btn-sm mx-2\"\n                title=\"Flip Vertical\">\n                <i\n                                    class=\"fa fa-arrows-alt-v\"\n                                    (click)=\"flipVertical()\"\n                                    (keydown.enter)=\"flipVertical()\"\n                                    aria-hidden=\"true\"\n                                ></i>\n              </button>\n            </div>\n          </div>\n        </div>\n\n        <div class=\"row\">\n          <div class=\"col-8\">\n            <div *ngIf=\"aspectRatio === 'auto'\">\n              <image-cropper [imageChangedEvent]=\"imageChangedEvent\"\n                [maintainAspectRatio]=\"true\"\n                [canvasRotation]=\"canvasRotation\"\n                [aspectRatio]=\"4 / 4\"\n                [onlyScaleDown]=\"true\"\n                [transform]=\"transform\"\n                [roundCropper]=\"false\"\n                alignImage=\"center\"\n                outputType=\"base64\"\n                (imageCropped)=\"imageCropped($event)\"\n                (imageLoaded)=\"imageLoaded()\"\n                imageQuality=\"100\"\n                [style.display]=\"showCropper ? null : 'none'\"></image-cropper>\n            </div>\n\n            <div *ngIf=\"aspectRatio === 'fullLogo'\">\n              <image-cropper [imageChangedEvent]=\"imageChangedEvent\"\n                [maintainAspectRatio]=\"true\"\n                [aspectRatio]=\"5 / 1.1\"\n                [onlyScaleDown]=\"true\"\n                [roundCropper]=\"false\"\n                alignImage=\"center\"\n                outputType=\"base64\"\n                (imageCropped)=\"imageCropped($event)\"\n                (imageLoaded)=\"imageLoaded()\"\n                imageQuality=\"100\"\n                [style.display]=\"showCropper ? null : 'none'\"></image-cropper>\n            </div>\n\n            <div *ngIf=\"aspectRatio === 'rectangular'\">\n              <image-cropper\n                [imageChangedEvent]=\"imageChangedEvent\"\n                [maintainAspectRatio]=\"true\"\n                [aspectRatio]=\"3 / 1\"\n                [onlyScaleDown]=\"true\"\n                [canvasRotation]=\"canvasRotation\"\n                [transform]=\"transform\"\n                [roundCropper]=\"false\"\n                alignImage=\"center\"\n                outputType=\"base64\"\n                (imageCropped)=\"imageCropped($event)\"\n                (imageLoaded)=\"imageLoaded()\"\n                imageQuality=\"100\"\n                [style.display]=\"showCropper ? null : 'none'\"></image-cropper>\n            </div>\n\n            <div *ngIf=\"aspectRatio === 'dynamic'\">\n              <image-cropper\n              [imageChangedEvent]=\"imageChangedEvent\"\n              [maintainAspectRatio]=\"false\"\n              [resizeToWidth]=\"0\"\n              [cropperStaticWidth]=\"0\"\n              [cropperStaticHeight]=\"0\"\n              [cropperMinWidth]=\"10\"\n              [cropperMinHeight]=\"10\"\n              [onlyScaleDown]=\"false\"\n              [canvasRotation]=\"canvasRotation\"\n              [transform]=\"transform\"\n              [roundCropper]=\"false\"\n              alignImage=\"center\"\n              outputType=\"base64\"\n              imageQuality=\"100\"\n              (imageCropped)=\"imageCropped($event)\"\n              (imageLoaded)=\"imageLoaded()\"\n              [style.display]=\"showCropper ? null : 'none'\">\n              </image-cropper>\n            </div>\n\n            <div *ngIf=\"aspectRatio === 'custom'\">\n              <image-cropper [imageChangedEvent]=\"imageChangedEvent\"\n                [maintainAspectRatio]=\"true\"\n                [canvasRotation]=\"canvasRotation\"\n                [transform]=\"transform\"\n                [aspectRatio]=\"4 / 3\"\n                [onlyScaleDown]=\"true\"\n                [roundCropper]=\"false\"\n                alignImage=\"center\"\n                outputType=\"base64\"\n                (imageCropped)=\"imageCropped($event)\"\n                (imageLoaded)=\"imageLoaded()\"\n                imageQuality=\"100\"\n                [style.display]=\"showCropper ? null : 'none'\"></image-cropper>\n            </div>\n          </div>\n          <div *ngIf=\"croppedImage\" class=\"col-4 mt-2\">\n            <img [src]=\"croppedImage\"\n            class=\"cropped-image\"\n              alt=\"cropped.png\"\n              width=\"128\" />\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n  <div class=\"card-footer px-3\">\n    <div class=\"float-end mt-2\">\n      <button type=\"button\"\n        class=\"btn btn-outline-default me-2\"\n        (click)=\"onCloseModal()\">\n        Close\n      </button>\n      <button type=\"button\"\n        class=\"btn btn-primary\"\n        (click)=\"saveProfilePicture()\"\n        [buttonBusy]=\"busy\">\n        Save\n      </button>\n    </div>\n  </div>\n</section>\n"]}
@@ -45,7 +45,6 @@ export class NumberPickerComponent {
45
45
  this.isInputFocused = false;
46
46
  }
47
47
  onMouseWheel(event) {
48
- console.log(event, 'abc');
49
48
  if (this.isInputFocused) {
50
49
  event.preventDefault();
51
50
  let wheelUp = null;
@@ -302,4 +301,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
302
301
  }], pickDownStopped: [{
303
302
  type: Output
304
303
  }] } });
305
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number-picker.component.js","sourceRoot":"","sources":["../../../../../../libs/shared-components/src/lib/number-picker/number-picker.component.ts","../../../../../../libs/shared-components/src/lib/number-picker/number-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\n\nimport { NumberPickerService } from '@posiwise/common-services';\n\nimport { buttonsOrientationType, CustomClasses, sizeType } from './number-picker.config';\n\n@Component({\n    selector: 'pw-number-picker',\n    templateUrl: './number-picker.component.html',\n    styleUrls: ['./number-picker.component.scss']\n})\nexport class NumberPickerComponent implements OnInit {\n    private precision: number;\n\n    private eventHolder = null;\n\n    private countInterval = null;\n\n    private isInputFocused = false;\n\n    @Input() min: number;\n\n    @Input() showTooltip: boolean;\n\n    @Input() tooltipText: string;\n\n    @Input() max: number;\n\n    @Input() step: number;\n\n    @Input() value: number;\n\n    @Input() pickStartAfter: number;\n\n    @Input() pickTimer: number;\n\n    @Input() prefix: string;\n\n    @Input() postfix: string;\n\n    @Input() placeholder: string;\n\n    @Input() buttonsOrientation: buttonsOrientationType;\n\n    @Input() size: sizeType = 'md';\n\n    @Input() customClass: CustomClasses = {};\n\n    @Input() mouseWheel = false;\n\n    @Input() arrowKeys = true;\n\n    @Input() inputReadOnly = false;\n\n    @Input() showUpButton = true;\n\n    @Input() showDownButton = true;\n\n    @Output() valueChange: EventEmitter<number> = new EventEmitter();\n\n    @Output() minReached: EventEmitter<boolean> = new EventEmitter();\n\n    @Output() maxReached: EventEmitter<boolean> = new EventEmitter();\n\n    @Output() pickStarted: EventEmitter<boolean> = new EventEmitter();\n\n    @Output() pickStopped: EventEmitter<boolean> = new EventEmitter();\n\n    @Output() pickUpStarted: EventEmitter<boolean> = new EventEmitter();\n\n    @Output() pickUpStopped: EventEmitter<boolean> = new EventEmitter();\n\n    @Output() pickDownStarted: EventEmitter<boolean> = new EventEmitter();\n\n    @Output() pickDownStopped: EventEmitter<boolean> = new EventEmitter();\n\n    constructor(private readonly numberPickerService: NumberPickerService) {}\n\n    ngOnInit() {\n        this.initPicker();\n    }\n\n    isHorizontal(): boolean {\n        return this.buttonsOrientation !== 'v' && this.buttonsOrientation !== 'vertical';\n    }\n\n    onFocus(event: FocusEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n        this.isInputFocused = true;\n    }\n\n    onBlur(event: Event) {\n        event.preventDefault();\n        event.stopPropagation();\n        this.isInputFocused = false;\n    }\n\n    onMouseWheel(event: WheelEvent) {\n        console.log(event, 'abc');\n        if (this.isInputFocused) {\n            event.preventDefault();\n            let wheelUp = null;\n            let delta = null;\n\n            if (event.deltaY) {\n                delta = event.deltaY / 60;\n            }\n            if (event.detail) {\n                delta = -event.detail / 2;\n            }\n            if (delta !== null) {\n                wheelUp = delta > 0;\n            }\n\n            this.afterMouseWheels(wheelUp, event);\n            event.stopPropagation();\n        }\n    }\n\n    private afterMouseWheels(wheelUp: boolean, event: WheelEvent) {\n        this.onPickStarted(wheelUp);\n        if (wheelUp) {\n            this.onIncrease(event);\n        } else {\n            this.onDecrease(event);\n        }\n        this.onPickStopped(wheelUp);\n    }\n\n    onValueChange(_event: Event) {\n        if (this.value > this.max) {\n            this.value = this.max;\n        } else if (this.value < this.min) {\n            this.value = this.min;\n        }\n        if (this.parseVal(this.value) === 0 || this.parseVal(this.value)) {\n            this.valueChange.emit(this.value);\n        }\n    }\n\n    onDecrease(event: MouseEvent | WheelEvent | KeyboardEvent) {\n        event.preventDefault();\n        if (this.canDecrease()) {\n            this.value = this.round(this.value > this.min ? this.value - this.step : this.value);\n            this.valueChange.emit(this.value);\n        } else {\n            this.minReached.emit(true);\n        }\n        event.stopPropagation();\n    }\n\n    onIncrease(event: MouseEvent | WheelEvent | KeyboardEvent) {\n        event.preventDefault();\n        if (this.canIncrease()) {\n            this.value = this.round(this.value < this.max ? this.value + this.step : this.value);\n            this.valueChange.emit(this.value);\n        } else {\n            this.maxReached.emit(true);\n        }\n        event.stopPropagation();\n    }\n\n    onMouseDown(event: MouseEvent, increase = true) {\n        this.afterMouseDown(increase, event);\n    }\n\n    private isArrowUpDown(key: string): boolean {\n        return key === 'ArrowUp' || key === 'ArrowDown';\n    }\n\n    private isArrowUp(key: string): boolean {\n        return key === 'ArrowUp';\n    }\n\n    private loopPick(increase: boolean, event: MouseEvent | KeyboardEvent) {\n        this.onPickStarted(increase);\n        this.eventHolder = setTimeout(() => {\n            this.countInterval = setInterval(() => {\n                if (increase) {\n                    this.onIncrease(event);\n                } else {\n                    this.onDecrease(event);\n                }\n            }, this.pickTimer);\n        }, this.pickStartAfter);\n    }\n\n    onMouseUp(event: MouseEvent, increase = true) {\n        this.afterMouseUp(increase, event);\n    }\n\n    onKeyDown(event: KeyboardEvent) {\n        if (this.isArrowUpDown(event.key)) {\n            event.preventDefault();\n            if (!this.eventHolder) {\n                this.loopPick(this.isArrowUp(event.key), event);\n            }\n        }\n        event.stopPropagation();\n    }\n\n    onKeyUp(event: KeyboardEvent) {\n        if (this.isArrowUpDown(event.key)) {\n            event.preventDefault();\n            this.afterPick(this.isArrowUp(event.key));\n        }\n        event.stopPropagation();\n    }\n\n    private afterMouseDown(up: boolean, event: MouseEvent) {\n        event.preventDefault();\n        if (this.isLeftClick(event)) {\n            this.loopPick(up, event);\n        }\n        event.stopPropagation();\n    }\n\n    private afterMouseUp(up: boolean, event: MouseEvent) {\n        event.preventDefault();\n        this.afterPick(up);\n        event.stopPropagation();\n    }\n\n    private afterPick(up: boolean) {\n        this.onPickStopped(up);\n        this.clearTimers();\n    }\n\n    private clearTimers() {\n        clearTimeout(this.eventHolder);\n        clearInterval(this.countInterval);\n        this.eventHolder = null;\n        this.countInterval = null;\n    }\n\n    private parseVal(value: string | number) {\n        if (typeof value === 'number') {\n            return value;\n        }\n\n        return Number.parseFloat(value);\n    }\n\n    private getPrecision(step: number): number {\n        return /^\\d*$/.exec(String(step))[0].length;\n    }\n\n    private round(value: number): number {\n        // eslint-disable-next-line no-restricted-properties\n        return Math.round(value * 10 ** this.precision) / 10 ** this.precision;\n    }\n\n    private canIncrease(): boolean {\n        const canIncrease = this.value <= this.max - this.step;\n        if (!canIncrease) {\n            this.value = this.max;\n        }\n\n        return canIncrease;\n    }\n\n    private canDecrease(): boolean {\n        const canDecrease = this.value >= this.min + this.step;\n        if (!canDecrease) {\n            this.value = this.min;\n        }\n\n        return canDecrease;\n    }\n\n    private onPickStarted(increase: boolean) {\n        const isIncrease = increase;\n        if (isIncrease) {\n            // NOSONAR\n            if (this.canIncrease()) {\n                this.pickStarted.emit(true);\n                this.pickUpStarted.emit(true);\n            }\n        } else if (this.canDecrease()) {\n            this.pickStarted.emit(true);\n            this.pickDownStarted.emit(true);\n        }\n    }\n\n    private onPickStopped(increase: boolean) {\n        const isIncrease = increase;\n        if (isIncrease) {\n            // NOSONAR\n            if (this.canIncrease()) {\n                this.pickUpStopped.emit(true);\n                this.pickStopped.emit(true);\n            }\n        } else if (this.canDecrease()) {\n            this.pickDownStopped.emit(true);\n            this.pickStopped.emit(true);\n        }\n    }\n\n    private isLeftClick(event): boolean {\n        return event.button === 0;\n    }\n\n    private initPicker(): void {\n        this.min = this.parseVal(this.min) || this.numberPickerService.min;\n        this.max = this.parseVal(this.max) || this.numberPickerService.max;\n        this.step = this.parseVal(this.step) || this.numberPickerService.step;\n        this.value = this.parseVal(this.value) || this.numberPickerService.value;\n        this.pickStartAfter =\n            this.parseVal(this.pickStartAfter) || this.numberPickerService.pickStartAfter;\n        this.pickTimer = this.parseVal(this.pickTimer) || this.numberPickerService.pickTimer;\n        this.precision = this.getPrecision(this.step) || this.numberPickerService.precision;\n        this.value = this.round(this.value);\n        this.placeholder = this.placeholder ?? '';\n    }\n}\n","<div class=\"input-group mb-3 input-{{ size }} {{ customClass.container }}\">\n  <!-- Horizontal decrease button orientation -->\n  <span *ngIf=\"isHorizontal() && showDownButton\"\n    class=\"input-group-text decrease {{ customClass.down }}\"\n    (click)=\"onDecrease($event)\"\n    (keydown.enter)=\"onDecrease($event)\"\n    (mouseup)=\"onMouseUp($event, false)\"\n    (mousedown)=\"onMouseDown($event, false)\">-</span>\n  <!-- Input prefix -->\n  <span *ngIf=\"prefix\"\n    class=\"input-group-text {{ customClass.prefix }}\">{{ prefix }}\n  </span>\n  <input type=\"number\"\n    class=\"form-control\"\n    name=\"input-spin-val\"\n    [(ngModel)]=\"value\"\n    [readOnly]=\"inputReadOnly\"\n    (blur)=\"onBlur($event)\"\n    (focus)=\"onFocus($event)\"\n    (wheel)=\"mouseWheel && onMouseWheel($event)\"\n    (keyup)=\"arrowKeys && onKeyUp($event)\"\n    (keydown.enter)=\"arrowKeys && onKeyDown($event)\"\n    (keydown.arrowup)=\"arrowKeys && onIncrease($event)\"\n    (keydown.arrowdown)=\"arrowKeys && onDecrease($event)\"\n    (change)=\"onValueChange($event)\"\n    [placeholder]=\"placeholder\" />\n  <!-- Input postfix -->\n\n  <span *ngIf=\"postfix\"\n    class=\"input-group-text {{ customClass.postfix }}\"\n    [style.borderLeft]=\"'0'\">{{postfix}}\n    <span class=\"tooltip-wrap ms-1\"\n      *ngIf=\"showTooltip && tooltipText\"\n      [pTooltip]=\"tooltipText\"\n      [appendTo]=\"'body'\"\n      [tooltipPosition]=\"tooltipPosition || 'top'\">\n      <i class=\"fas fa-info-circle\"></i>\n    </span>\n  </span>\n\n  <!-- Horizontal increase button orientation -->\n  <span *ngIf=\"isHorizontal() && showUpButton\"\n    class=\"input-group-text increase {{ customClass.up }}\"\n    [style.borderLeft]=\"!postfix ? '0' : ''\"\n    (click)=\"onIncrease($event)\"\n    (keydown.enter)=\"onIncrease($event)\"\n    (mouseup)=\"onMouseUp($event)\"\n    (mousedown)=\"onMouseDown($event)\">+</span>\n  <!-- Vertical buttons orientation -->\n  <span *ngIf=\"!isHorizontal()\"\n    class=\"input-group-text vertical p-0\">\n    <span *ngIf=\"showUpButton\"\n      class=\"{{ customClass.up }}\"\n      (click)=\"onIncrease($event)\"\n      (keydown.enter)=\"onIncrease($event)\"\n      (mouseup)=\"onMouseUp($event)\"\n      (mousedown)=\"onMouseDown($event)\">+</span>\n    <span *ngIf=\"showDownButton\"\n      class=\"{{ customClass.down }}\"\n      (keydown.enter)=\"onDecrease($event)\"\n      (click)=\"onDecrease($event)\"\n      (mouseup)=\"onMouseUp($event, false)\"\n      (mousedown)=\"onMouseDown($event, false)\">-</span>\n  </span>\n</div>\n"]}
304
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number-picker.component.js","sourceRoot":"","sources":["../../../../../../libs/shared-components/src/lib/number-picker/number-picker.component.ts","../../../../../../libs/shared-components/src/lib/number-picker/number-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\n\nimport { NumberPickerService } from '@posiwise/common-services';\n\nimport { buttonsOrientationType, CustomClasses, sizeType } from './number-picker.config';\n\n@Component({\n    selector: 'pw-number-picker',\n    templateUrl: './number-picker.component.html',\n    styleUrls: ['./number-picker.component.scss']\n})\nexport class NumberPickerComponent implements OnInit {\n    private precision: number;\n\n    private eventHolder = null;\n\n    private countInterval = null;\n\n    private isInputFocused = false;\n\n    @Input() min: number;\n\n    @Input() showTooltip: boolean;\n\n    @Input() tooltipText: string;\n\n    @Input() max: number;\n\n    @Input() step: number;\n\n    @Input() value: number;\n\n    @Input() pickStartAfter: number;\n\n    @Input() pickTimer: number;\n\n    @Input() prefix: string;\n\n    @Input() postfix: string;\n\n    @Input() placeholder: string;\n\n    @Input() buttonsOrientation: buttonsOrientationType;\n\n    @Input() size: sizeType = 'md';\n\n    @Input() customClass: CustomClasses = {};\n\n    @Input() mouseWheel = false;\n\n    @Input() arrowKeys = true;\n\n    @Input() inputReadOnly = false;\n\n    @Input() showUpButton = true;\n\n    @Input() showDownButton = true;\n\n    @Output() valueChange: EventEmitter<number> = new EventEmitter();\n\n    @Output() minReached: EventEmitter<boolean> = new EventEmitter();\n\n    @Output() maxReached: EventEmitter<boolean> = new EventEmitter();\n\n    @Output() pickStarted: EventEmitter<boolean> = new EventEmitter();\n\n    @Output() pickStopped: EventEmitter<boolean> = new EventEmitter();\n\n    @Output() pickUpStarted: EventEmitter<boolean> = new EventEmitter();\n\n    @Output() pickUpStopped: EventEmitter<boolean> = new EventEmitter();\n\n    @Output() pickDownStarted: EventEmitter<boolean> = new EventEmitter();\n\n    @Output() pickDownStopped: EventEmitter<boolean> = new EventEmitter();\n\n    constructor(private readonly numberPickerService: NumberPickerService) {}\n\n    ngOnInit() {\n        this.initPicker();\n    }\n\n    isHorizontal(): boolean {\n        return this.buttonsOrientation !== 'v' && this.buttonsOrientation !== 'vertical';\n    }\n\n    onFocus(event: FocusEvent) {\n        event.preventDefault();\n        event.stopPropagation();\n        this.isInputFocused = true;\n    }\n\n    onBlur(event: Event) {\n        event.preventDefault();\n        event.stopPropagation();\n        this.isInputFocused = false;\n    }\n\n    onMouseWheel(event: WheelEvent) {\n        if (this.isInputFocused) {\n            event.preventDefault();\n            let wheelUp = null;\n            let delta = null;\n\n            if (event.deltaY) {\n                delta = event.deltaY / 60;\n            }\n            if (event.detail) {\n                delta = -event.detail / 2;\n            }\n            if (delta !== null) {\n                wheelUp = delta > 0;\n            }\n\n            this.afterMouseWheels(wheelUp, event);\n            event.stopPropagation();\n        }\n    }\n\n    private afterMouseWheels(wheelUp: boolean, event: WheelEvent) {\n        this.onPickStarted(wheelUp);\n        if (wheelUp) {\n            this.onIncrease(event);\n        } else {\n            this.onDecrease(event);\n        }\n        this.onPickStopped(wheelUp);\n    }\n\n    onValueChange(_event: Event) {\n        if (this.value > this.max) {\n            this.value = this.max;\n        } else if (this.value < this.min) {\n            this.value = this.min;\n        }\n        if (this.parseVal(this.value) === 0 || this.parseVal(this.value)) {\n            this.valueChange.emit(this.value);\n        }\n    }\n\n    onDecrease(event: MouseEvent | WheelEvent | KeyboardEvent) {\n        event.preventDefault();\n        if (this.canDecrease()) {\n            this.value = this.round(this.value > this.min ? this.value - this.step : this.value);\n            this.valueChange.emit(this.value);\n        } else {\n            this.minReached.emit(true);\n        }\n        event.stopPropagation();\n    }\n\n    onIncrease(event: MouseEvent | WheelEvent | KeyboardEvent) {\n        event.preventDefault();\n        if (this.canIncrease()) {\n            this.value = this.round(this.value < this.max ? this.value + this.step : this.value);\n            this.valueChange.emit(this.value);\n        } else {\n            this.maxReached.emit(true);\n        }\n        event.stopPropagation();\n    }\n\n    onMouseDown(event: MouseEvent, increase = true) {\n        this.afterMouseDown(increase, event);\n    }\n\n    private isArrowUpDown(key: string): boolean {\n        return key === 'ArrowUp' || key === 'ArrowDown';\n    }\n\n    private isArrowUp(key: string): boolean {\n        return key === 'ArrowUp';\n    }\n\n    private loopPick(increase: boolean, event: MouseEvent | KeyboardEvent) {\n        this.onPickStarted(increase);\n        this.eventHolder = setTimeout(() => {\n            this.countInterval = setInterval(() => {\n                if (increase) {\n                    this.onIncrease(event);\n                } else {\n                    this.onDecrease(event);\n                }\n            }, this.pickTimer);\n        }, this.pickStartAfter);\n    }\n\n    onMouseUp(event: MouseEvent, increase = true) {\n        this.afterMouseUp(increase, event);\n    }\n\n    onKeyDown(event: KeyboardEvent) {\n        if (this.isArrowUpDown(event.key)) {\n            event.preventDefault();\n            if (!this.eventHolder) {\n                this.loopPick(this.isArrowUp(event.key), event);\n            }\n        }\n        event.stopPropagation();\n    }\n\n    onKeyUp(event: KeyboardEvent) {\n        if (this.isArrowUpDown(event.key)) {\n            event.preventDefault();\n            this.afterPick(this.isArrowUp(event.key));\n        }\n        event.stopPropagation();\n    }\n\n    private afterMouseDown(up: boolean, event: MouseEvent) {\n        event.preventDefault();\n        if (this.isLeftClick(event)) {\n            this.loopPick(up, event);\n        }\n        event.stopPropagation();\n    }\n\n    private afterMouseUp(up: boolean, event: MouseEvent) {\n        event.preventDefault();\n        this.afterPick(up);\n        event.stopPropagation();\n    }\n\n    private afterPick(up: boolean) {\n        this.onPickStopped(up);\n        this.clearTimers();\n    }\n\n    private clearTimers() {\n        clearTimeout(this.eventHolder);\n        clearInterval(this.countInterval);\n        this.eventHolder = null;\n        this.countInterval = null;\n    }\n\n    private parseVal(value: string | number) {\n        if (typeof value === 'number') {\n            return value;\n        }\n\n        return Number.parseFloat(value);\n    }\n\n    private getPrecision(step: number): number {\n        return /^\\d*$/.exec(String(step))[0].length;\n    }\n\n    private round(value: number): number {\n        // eslint-disable-next-line no-restricted-properties\n        return Math.round(value * 10 ** this.precision) / 10 ** this.precision;\n    }\n\n    private canIncrease(): boolean {\n        const canIncrease = this.value <= this.max - this.step;\n        if (!canIncrease) {\n            this.value = this.max;\n        }\n\n        return canIncrease;\n    }\n\n    private canDecrease(): boolean {\n        const canDecrease = this.value >= this.min + this.step;\n        if (!canDecrease) {\n            this.value = this.min;\n        }\n\n        return canDecrease;\n    }\n\n    private onPickStarted(increase: boolean) {\n        const isIncrease = increase;\n        if (isIncrease) {\n            // NOSONAR\n            if (this.canIncrease()) {\n                this.pickStarted.emit(true);\n                this.pickUpStarted.emit(true);\n            }\n        } else if (this.canDecrease()) {\n            this.pickStarted.emit(true);\n            this.pickDownStarted.emit(true);\n        }\n    }\n\n    private onPickStopped(increase: boolean) {\n        const isIncrease = increase;\n        if (isIncrease) {\n            // NOSONAR\n            if (this.canIncrease()) {\n                this.pickUpStopped.emit(true);\n                this.pickStopped.emit(true);\n            }\n        } else if (this.canDecrease()) {\n            this.pickDownStopped.emit(true);\n            this.pickStopped.emit(true);\n        }\n    }\n\n    private isLeftClick(event): boolean {\n        return event.button === 0;\n    }\n\n    private initPicker(): void {\n        this.min = this.parseVal(this.min) || this.numberPickerService.min;\n        this.max = this.parseVal(this.max) || this.numberPickerService.max;\n        this.step = this.parseVal(this.step) || this.numberPickerService.step;\n        this.value = this.parseVal(this.value) || this.numberPickerService.value;\n        this.pickStartAfter =\n            this.parseVal(this.pickStartAfter) || this.numberPickerService.pickStartAfter;\n        this.pickTimer = this.parseVal(this.pickTimer) || this.numberPickerService.pickTimer;\n        this.precision = this.getPrecision(this.step) || this.numberPickerService.precision;\n        this.value = this.round(this.value);\n        this.placeholder = this.placeholder ?? '';\n    }\n}\n","<div class=\"input-group mb-3 input-{{ size }} {{ customClass.container }}\">\n  <!-- Horizontal decrease button orientation -->\n  <span *ngIf=\"isHorizontal() && showDownButton\"\n    class=\"input-group-text decrease {{ customClass.down }}\"\n    (click)=\"onDecrease($event)\"\n    (keydown.enter)=\"onDecrease($event)\"\n    (mouseup)=\"onMouseUp($event, false)\"\n    (mousedown)=\"onMouseDown($event, false)\">-</span>\n  <!-- Input prefix -->\n  <span *ngIf=\"prefix\"\n    class=\"input-group-text {{ customClass.prefix }}\">{{ prefix }}\n  </span>\n  <input type=\"number\"\n    class=\"form-control\"\n    name=\"input-spin-val\"\n    [(ngModel)]=\"value\"\n    [readOnly]=\"inputReadOnly\"\n    (blur)=\"onBlur($event)\"\n    (focus)=\"onFocus($event)\"\n    (wheel)=\"mouseWheel && onMouseWheel($event)\"\n    (keyup)=\"arrowKeys && onKeyUp($event)\"\n    (keydown.enter)=\"arrowKeys && onKeyDown($event)\"\n    (keydown.arrowup)=\"arrowKeys && onIncrease($event)\"\n    (keydown.arrowdown)=\"arrowKeys && onDecrease($event)\"\n    (change)=\"onValueChange($event)\"\n    [placeholder]=\"placeholder\" />\n  <!-- Input postfix -->\n\n  <span *ngIf=\"postfix\"\n    class=\"input-group-text {{ customClass.postfix }}\"\n    [style.borderLeft]=\"'0'\">{{postfix}}\n    <span class=\"tooltip-wrap ms-1\"\n      *ngIf=\"showTooltip && tooltipText\"\n      [pTooltip]=\"tooltipText\"\n      [appendTo]=\"'body'\"\n      [tooltipPosition]=\"tooltipPosition || 'top'\">\n      <i class=\"fas fa-info-circle\"></i>\n    </span>\n  </span>\n\n  <!-- Horizontal increase button orientation -->\n  <span *ngIf=\"isHorizontal() && showUpButton\"\n    class=\"input-group-text increase {{ customClass.up }}\"\n    [style.borderLeft]=\"!postfix ? '0' : ''\"\n    (click)=\"onIncrease($event)\"\n    (keydown.enter)=\"onIncrease($event)\"\n    (mouseup)=\"onMouseUp($event)\"\n    (mousedown)=\"onMouseDown($event)\">+</span>\n  <!-- Vertical buttons orientation -->\n  <span *ngIf=\"!isHorizontal()\"\n    class=\"input-group-text vertical p-0\">\n    <span *ngIf=\"showUpButton\"\n      class=\"{{ customClass.up }}\"\n      (click)=\"onIncrease($event)\"\n      (keydown.enter)=\"onIncrease($event)\"\n      (mouseup)=\"onMouseUp($event)\"\n      (mousedown)=\"onMouseDown($event)\">+</span>\n    <span *ngIf=\"showDownButton\"\n      class=\"{{ customClass.down }}\"\n      (keydown.enter)=\"onDecrease($event)\"\n      (click)=\"onDecrease($event)\"\n      (mouseup)=\"onMouseUp($event, false)\"\n      (mousedown)=\"onMouseDown($event, false)\">-</span>\n  </span>\n</div>\n"]}
@@ -4,12 +4,14 @@ import { AppBaseComponent } from '@posiwise/app-base-component';
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "@posiwise/directives";
6
6
  import * as i2 from "@angular/router";
7
+ import * as i3 from "@angular/common";
7
8
  export class ResourceHeaderComponent extends AppBaseComponent {
8
9
  constructor(injector, document) {
9
10
  super(injector);
10
11
  this.document = document;
11
12
  this.isScrolled = false;
12
13
  this.open = false;
14
+ this.navbarItems = this.appConfig?.pages_config?.navbar?.items;
13
15
  }
14
16
  ngOnInit() {
15
17
  this.logo = this.appConfig?.company?.logos?.main_dark?.url;
@@ -31,11 +33,11 @@ export class ResourceHeaderComponent extends AppBaseComponent {
31
33
  }
32
34
  }
33
35
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ResourceHeaderComponent, deps: [{ token: i0.Injector }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Component }); }
34
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: ResourceHeaderComponent, selector: "pw-resource-header", host: { listeners: { "window:scroll": "onScroll()" } }, viewQueries: [{ propertyName: "navbarCollapse", first: true, predicate: ["collapsibleNavbar"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<nav class=\"navbar navbar-expand-lg navbar-dark fixed-top cloudolive-nav-bg-color\" id=\"banner\">\n <div class=\"container container-wrapper banner-section d-flex justify-content-between align-items-center\">\n\n <!-- Mobile: Logo Left, Toggler Right -->\n <div class=\"d-flex align-items-center justify-content-between w-100 d-lg-none\">\n <button class=\"navbar-toggler header-menu-bar\" type=\"button\" aria-label=\"Toggle navigation\" data-bs-toggle=\"collapse\" data-bs-target=\"#collapsibleNavbar\">\n <img src=\"/assets/img/products/trial/navbar-toggle-icon.png\" class=\"img-fluid navbar-toggle-icon\" alt=\"\" />\n </button>\n <div class=\"mb-icon\">\n <img [src]=\"logo\" routerLink=\"/\" alt=\"logo\" class=\"img-fluid logo-img\" />\n </div>\n </div>\n\n <!-- Desktop: Logo Left -->\n <div class=\"d-none d-lg-block mb-1 mt-1\">\n <img [src]=\"logo\" routerLink=\"/\" alt=\"logo\" class=\"img-fluid logo-img header-logo\" />\n </div>\n\n <!-- Center nav links (currently hidden on desktop) -->\n <div class=\"collapse navbar-collapse justify-content-center\" id=\"collapsibleNavbar\" #collapsibleNavbar>\n <ul #anchorLinks class=\"navbar-nav flex gap-4 me-0 wow fadeInUp position-relative\" data-wow-duration=\"2s\">\n <!-- Mobile Login Button -->\n <li class=\"nav-item lg-ms-2 mb-3 d-flex d-lg-none nav-item mt-3 md-mt-0\">\n <button class=\"sign-btn sign-header-btn\" routerLink=\"/login\">Log In</button>\n </li>\n </ul>\n </div>\n\n <!-- Desktop Login Button -->\n <div class=\"d-none d-lg-block mt-1 mb-1\">\n <button class=\"sign-btn sign-header-btn\" routerLink=\"/login\">Log In</button>\n </div>\n\n </div>\n</nav>\n", styles: ["@import\"https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;1,100;1,200;1,300;1,400;1,500;1,600;1,700&display=swap\";:root{--first: rgb(23 105 225);--second: rgb(54 194 131);--third: rgb(255 171 0);--text: rgb(34 34 34);--tabs_bg: rgb(23 105 225);--tabs_sub_bg: rgb(70, 136, 236);--tabs_text: rgb(255 255 255);--titles: rgb(34 34 34);--sidebar_bg: rgb(0, 48, 63);--sidebar_text: rgb(255 255 255)}*{font-family:Montserrat,sans-serif}h2{font-size:32px;font-weight:700;letter-spacing:.03em;line-height:1.1em;text-transform:uppercase}@media (max-width: 1200px){.container-wrapper{padding:0 20px!important}}@media screen and (max-width: 991px){.header-menu-bar{background-color:var(--first);background-image:none;border:1px solid rgb(255,255,255);border-radius:4px;display:block!important;float:right;margin-top:4px;padding:9px 10px;position:relative}}.navbar-custom-background{background-color:#00000080;box-shadow:2px 2px 15px 2px #0000001f;transition:width 2s,height 2s,-webkit-transform 2s;transition:width 2s,height 2s,transform 2s background-color .5s ease;z-index:9999}.fixed-top{position:fixed!important}.primary-button{background-color:#000;border-radius:50px;color:#fff;font: 600 16.3px Montserrat-Regular,sans-serif;padding:5px 16px!important;width:auto;display:flex;gap:15px;align-items:center;justify-content:space-between}.nav-link{color:#000!important;transition:color .3s ease}.nav-link.scrolled-nav-link{color:#fff!important}.navbar-nav{visibility:visible!important}.navbar-nav .nav-item .nav-link{color:#fff;font-size:18px;font-weight:500;letter-spacing:1px;padding:1.1em 1em!important}.navbar-toggle-icon{width:25px}.d-flex img{margin-right:0!important}@media (min-width: 500px){.navbar-nav .nav-item button{margin-top:10px}}@media (max-width: 1200px){.navbar-nav .nav-item .nav-link{font-size:15px!important}}@media (min-width: 1200px){.navbar-nav .nav-item .nav-link{padding-bottom:0!important;padding-top:1.8rem!important}.popup{top:5.4rem!important;background-color:var(--first)!important;left:0;padding:10px;z-index:1000;transition:opacity .3s ease-in-out}.popup ul li{color:#fff;font: 500 14px Montserrat-Regular,sans-serif;cursor:pointer;border-bottom:1px solid #eee}.popup ul li:last-child{border-bottom:none}.router-link-active{color:#000!important}}@media (max-width: 1200px){.popup ul li{color:#fff;font: 500 14px Montserrat-Regular,sans-serif;cursor:pointer;border-bottom:1px solid #eee}.popup ul li:last-child{border-bottom:none}.popup ul li:hover{background-color:#f1f1f1}.mb-icon{width:200px}.container-wrapper{padding:0 20px!important}.popup{top:0%!important;background-color:var(--first)!important;left:10rem;padding:10px;z-index:1000;transition:opacity .3s ease-in-out}}@media (max-width: 991px){.navbar-nav{color:#fff;margin-top:5px;z-index:1}.navbar-nav .nav-item .nav-link{font-size:100%;font-weight:500;padding:.7em 1em!important}}.popup{top:90%;background-color:transparent;padding:10px;z-index:1000}.popup ul{list-style-type:none;padding:0;margin:0}.popup ul li{padding:5px 10px;font: 500 14px Montserrat-Regular,sans-serif}.rotate{transform:rotate(180deg)}@media (max-width: 991px){.logo-img{width:70%!important;margin-left:auto;margin-right:0;display:block;transition:margin .5s ease,width .5s ease}.navbar-nav{color:#fff;margin-top:5px;z-index:1}.navbar-nav .nav-item .nav-link{font-size:100%;font-weight:500;padding:.7em 1em!important}.popup{top:0%!important;background-color:var(--first)!important;left:10rem;padding:10px;opacity:1;z-index:1000;transition:opacity .3s ease-in-out}.popup ul{list-style-type:none;padding:0;margin:0}.rotate{transform:rotate(180deg)}}.logo-img{height:auto!important;width:auto;max-height:40px;max-width:100%;object-fit:contain}@media (min-width: 992px){.banner-section{padding:0 40px}.sign-header-btn{color:#fff;font-weight:700;border:none;border-radius:999px;padding:8px 24px;width:142px;margin-right:.5rem;height:40px}}\n"], dependencies: [{ kind: "directive", type: i1.LazyImgDirective, selector: "img" }, { kind: "directive", type: i2.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }] }); }
36
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: ResourceHeaderComponent, selector: "pw-resource-header", host: { listeners: { "window:scroll": "onScroll()" } }, viewQueries: [{ propertyName: "navbarCollapse", first: true, predicate: ["collapsibleNavbar"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<nav class=\"navbar navbar-expand-md navbar-dark fixed-top cloudolive-nav-bg-color\"\n id=\"banner\">\n <div class=\"container container-wrapper banner-section\">\n <!-- Toggler/collapsibe Button -->\n <button class=\"navbar-toggler header-menu-bar\"\n type=\"button\"\n aria-label=\"Toggle navigation\"\n data-bs-toggle=\"collapse\"\n data-bs-target=\"#collapsibleNavbar\">\n <img src=\"/assets/img/products/trial/navbar-toggle-icon.png\"\n class=\"img-fluid navbar-toggle-icon\"\n alt=\"\" />\n </button>\n\n <!-- Mobile Logo -->\n <div class=\"d-md-none mb-icon\">\n <div>\n <img [src]=\"logo\"\n routerLink=\"/\"\n alt=\"logo\"\n class=\"img-fluid logo_img\" />\n </div>\n </div>\n\n <!-- Navbar links -->\n <div class=\"collapse navbar-collapse mt-3 mt-md-0\"\n id=\"collapsibleNavbar\"\n #collapsibleNavbar>\n <div class=\"row align-items-center w-100\">\n\n <!-- Always occupy 3 columns for logo -->\n <div class=\"col-md-3 d-none d-md-flex align-items-center\">\n <div *ngIf=\"logo\">\n <img [src]=\"logo\"\n (load)=\"logoLoaded = true\"\n (error)=\"logoLoaded = false\"\n routerLink=\"/\"\n alt=\"logo\"\n class=\"img-fluid logo_img\" />\n </div>\n </div>\n\n <div class=\"col-md-6 d-flex justify-content-start\">\n <ul #anchorLinks\n class=\"navbar-nav flex gap-4 me-0 wow fadeInUp position-relative\"\n data-wow-duration=\"2s\">\n <li class=\"nav-item\" *ngFor=\"let item of navbarItems\">\n <a\n class=\"nav-link\"\n href=\"javascript:void(0)\"\n [ngClass]=\"{ 'scrolled-nav-link': isScrolled }\"\n (click)=\"item.subtitles?.length ? (item.open = !item.open) : null\"\n [attr.href]=\"!(item.subtitles?.length) ? item.path : null\"\n >\n {{ item?.title }}\n <i *ngIf=\"item.open\" class=\"fa-solid fa-caret-down\"></i>\n </a>\n <div class=\"popup position-absolute\"\n *ngIf=\"item.subtitles && item.open\">\n <ul>\n <li\n *ngFor=\"let sub of item.subtitles\"\n [routerLink]=\"sub.path\"\n class=\"dropdownItem\"\n >\n {{ sub.title }}\n </li>\n </ul>\n </div>\n </li>\n\n <li class=\"nav-item ms-2 mb-3 d-flex d-md-none\">\n <button class=\"sign-btn sign-header-btn\"\n routerLink=\"/login\">Log In</button>\n </li>\n </ul>\n </div>\n\n <!-- Always 3 columns for login -->\n <div class=\"col-md-3 d-none d-md-flex justify-content-end\">\n <button class=\"sign-btn sign-header-btn\"\n routerLink=\"/login\">Log In</button>\n </div>\n\n </div>\n </div>\n </div>\n</nav>\n", styles: ["@import\"https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;1,100;1,200;1,300;1,400;1,500;1,600;1,700&display=swap\";:root{--first: rgb(23 105 225);--second: rgb(54 194 131);--third: rgb(255 171 0);--text: rgb(34 34 34);--tabs_bg: rgb(23 105 225);--tabs_sub_bg: rgb(70, 136, 236);--tabs_text: rgb(255 255 255);--titles: rgb(34 34 34);--sidebar_bg: rgb(0, 48, 63);--sidebar_text: rgb(255 255 255)}*{font-family:Montserrat,sans-serif}h2{font-size:32px;font-weight:700;letter-spacing:.03em;line-height:1.1em;text-transform:uppercase}@media (max-width: 1200px){.container-wrapper{padding:0 20px!important}}.navbar-custom-background{background-color:#00000080;box-shadow:2px 2px 15px 2px #0000001f;transition:width 2s,height 2s,-webkit-transform 2s;transition:width 2s,height 2s,transform 2s background-color .5s ease;z-index:9999}.fixed-top{position:fixed!important}.primary-button{background-color:#000;border-radius:50px;color:#fff;font: 600 16.3px Montserrat-Regular,sans-serif;padding:5px 16px!important;width:auto;display:flex;gap:15px;align-items:center;justify-content:space-between}.navbar-nav .nav-item .nav-link{color:#fff;font-size:18px;font-weight:500;letter-spacing:1px;padding:1.1em 1em!important}.logo_img{width:60%!important}.navbar-toggle-icon{width:25px}@media (min-width: 500px){.navbar-nav .nav-item button{margin-top:10px}}@media (max-width: 1200px){.navbar-nav .nav-item .nav-link{font-size:15px!important}}.fa-caret-down{font-family:\"Font Awesome 6 Pro\";font-weight:900}@media (min-width: 1200px){.navbar-nav .nav-item .nav-link{padding-bottom:0!important;padding-top:0!important}.popup{top:3.4rem!important;background-color:var(--first)!important;left:0rem;background-color:transparent;padding:10px;z-index:1000;transition:opacity .3s ease-in-out}.popup ul li{color:#fff;font: 500 14px Montserrat-Regular,sans-serif;cursor:pointer;border-bottom:1px solid #eee}.popup ul li:last-child{border-bottom:none}.router-link-active{color:#000!important}}@media (max-width: 1200px){.popup ul li{color:#fff;font: 500 14px Montserrat-Regular,sans-serif;cursor:pointer;border-bottom:1px solid #eee}.popup ul li:last-child{border-bottom:none}.popup ul li:hover{background-color:#f1f1f1}.mb-icon{width:200px}.container-wrapper{padding:10px 20px!important}.popup{top:0%!important;background-color:var(--first)!important;left:10rem;background-color:transparent;padding:10px;z-index:1000;transition:opacity .3s ease-in-out}}@media (max-width: 500px){.navbar-nav{background-color:var(--first);border-top:3px solid rgb(254,209,54);color:#fff;margin-top:5px;z-index:1}.navbar-nav .nav-item .nav-link{font-size:100%;font-weight:500;padding:.7em 1em!important}}.popup{top:90%;background-color:transparent;padding:10px;z-index:1000}.popup ul{list-style-type:none;padding:0;margin:0}.popup ul li{padding:5px 10px;font: 500 14px Montserrat-Regular,sans-serif}.nav-link{color:#000!important;transition:color .3s ease}.nav-link.scrolled-nav-link{color:#fff!important}.dropdownItem{cursor:pointer}.rotate{transform:rotate(180deg)}@media (max-width: 500px){.logo_img{width:60%!important;margin-left:auto;margin-right:0;display:block;transition:margin .5s ease,width .5s ease}.navbar-nav{background-color:var(--first);border-top:3px solid rgb(254,209,54);color:#fff;margin-top:5px;z-index:1}.navbar-nav .nav-item .nav-link{font-size:100%;font-weight:500;padding:.7em 1em!important}.popup{top:0%!important;background-color:var(--first)!important;left:10rem;background-color:transparent;padding:10px;z-index:1000;transition:opacity .3s ease-in-out}.popup ul{list-style-type:none;padding:0;margin:0}.dropdownItem{cursor:pointer}.rotate{transform:rotate(180deg)}.popup.ngIf{opacity:1}}.navbar-nav{visibility:visible!important;display:flex!important}.nav-link{text-transform:uppercase}\n"], dependencies: [{ kind: "directive", type: i1.LazyImgDirective, selector: "img" }, { kind: "directive", type: i2.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
35
37
  }
36
38
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ResourceHeaderComponent, decorators: [{
37
39
  type: Component,
38
- args: [{ selector: 'pw-resource-header', template: "<nav class=\"navbar navbar-expand-lg navbar-dark fixed-top cloudolive-nav-bg-color\" id=\"banner\">\n <div class=\"container container-wrapper banner-section d-flex justify-content-between align-items-center\">\n\n <!-- Mobile: Logo Left, Toggler Right -->\n <div class=\"d-flex align-items-center justify-content-between w-100 d-lg-none\">\n <button class=\"navbar-toggler header-menu-bar\" type=\"button\" aria-label=\"Toggle navigation\" data-bs-toggle=\"collapse\" data-bs-target=\"#collapsibleNavbar\">\n <img src=\"/assets/img/products/trial/navbar-toggle-icon.png\" class=\"img-fluid navbar-toggle-icon\" alt=\"\" />\n </button>\n <div class=\"mb-icon\">\n <img [src]=\"logo\" routerLink=\"/\" alt=\"logo\" class=\"img-fluid logo-img\" />\n </div>\n </div>\n\n <!-- Desktop: Logo Left -->\n <div class=\"d-none d-lg-block mb-1 mt-1\">\n <img [src]=\"logo\" routerLink=\"/\" alt=\"logo\" class=\"img-fluid logo-img header-logo\" />\n </div>\n\n <!-- Center nav links (currently hidden on desktop) -->\n <div class=\"collapse navbar-collapse justify-content-center\" id=\"collapsibleNavbar\" #collapsibleNavbar>\n <ul #anchorLinks class=\"navbar-nav flex gap-4 me-0 wow fadeInUp position-relative\" data-wow-duration=\"2s\">\n <!-- Mobile Login Button -->\n <li class=\"nav-item lg-ms-2 mb-3 d-flex d-lg-none nav-item mt-3 md-mt-0\">\n <button class=\"sign-btn sign-header-btn\" routerLink=\"/login\">Log In</button>\n </li>\n </ul>\n </div>\n\n <!-- Desktop Login Button -->\n <div class=\"d-none d-lg-block mt-1 mb-1\">\n <button class=\"sign-btn sign-header-btn\" routerLink=\"/login\">Log In</button>\n </div>\n\n </div>\n</nav>\n", styles: ["@import\"https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;1,100;1,200;1,300;1,400;1,500;1,600;1,700&display=swap\";:root{--first: rgb(23 105 225);--second: rgb(54 194 131);--third: rgb(255 171 0);--text: rgb(34 34 34);--tabs_bg: rgb(23 105 225);--tabs_sub_bg: rgb(70, 136, 236);--tabs_text: rgb(255 255 255);--titles: rgb(34 34 34);--sidebar_bg: rgb(0, 48, 63);--sidebar_text: rgb(255 255 255)}*{font-family:Montserrat,sans-serif}h2{font-size:32px;font-weight:700;letter-spacing:.03em;line-height:1.1em;text-transform:uppercase}@media (max-width: 1200px){.container-wrapper{padding:0 20px!important}}@media screen and (max-width: 991px){.header-menu-bar{background-color:var(--first);background-image:none;border:1px solid rgb(255,255,255);border-radius:4px;display:block!important;float:right;margin-top:4px;padding:9px 10px;position:relative}}.navbar-custom-background{background-color:#00000080;box-shadow:2px 2px 15px 2px #0000001f;transition:width 2s,height 2s,-webkit-transform 2s;transition:width 2s,height 2s,transform 2s background-color .5s ease;z-index:9999}.fixed-top{position:fixed!important}.primary-button{background-color:#000;border-radius:50px;color:#fff;font: 600 16.3px Montserrat-Regular,sans-serif;padding:5px 16px!important;width:auto;display:flex;gap:15px;align-items:center;justify-content:space-between}.nav-link{color:#000!important;transition:color .3s ease}.nav-link.scrolled-nav-link{color:#fff!important}.navbar-nav{visibility:visible!important}.navbar-nav .nav-item .nav-link{color:#fff;font-size:18px;font-weight:500;letter-spacing:1px;padding:1.1em 1em!important}.navbar-toggle-icon{width:25px}.d-flex img{margin-right:0!important}@media (min-width: 500px){.navbar-nav .nav-item button{margin-top:10px}}@media (max-width: 1200px){.navbar-nav .nav-item .nav-link{font-size:15px!important}}@media (min-width: 1200px){.navbar-nav .nav-item .nav-link{padding-bottom:0!important;padding-top:1.8rem!important}.popup{top:5.4rem!important;background-color:var(--first)!important;left:0;padding:10px;z-index:1000;transition:opacity .3s ease-in-out}.popup ul li{color:#fff;font: 500 14px Montserrat-Regular,sans-serif;cursor:pointer;border-bottom:1px solid #eee}.popup ul li:last-child{border-bottom:none}.router-link-active{color:#000!important}}@media (max-width: 1200px){.popup ul li{color:#fff;font: 500 14px Montserrat-Regular,sans-serif;cursor:pointer;border-bottom:1px solid #eee}.popup ul li:last-child{border-bottom:none}.popup ul li:hover{background-color:#f1f1f1}.mb-icon{width:200px}.container-wrapper{padding:0 20px!important}.popup{top:0%!important;background-color:var(--first)!important;left:10rem;padding:10px;z-index:1000;transition:opacity .3s ease-in-out}}@media (max-width: 991px){.navbar-nav{color:#fff;margin-top:5px;z-index:1}.navbar-nav .nav-item .nav-link{font-size:100%;font-weight:500;padding:.7em 1em!important}}.popup{top:90%;background-color:transparent;padding:10px;z-index:1000}.popup ul{list-style-type:none;padding:0;margin:0}.popup ul li{padding:5px 10px;font: 500 14px Montserrat-Regular,sans-serif}.rotate{transform:rotate(180deg)}@media (max-width: 991px){.logo-img{width:70%!important;margin-left:auto;margin-right:0;display:block;transition:margin .5s ease,width .5s ease}.navbar-nav{color:#fff;margin-top:5px;z-index:1}.navbar-nav .nav-item .nav-link{font-size:100%;font-weight:500;padding:.7em 1em!important}.popup{top:0%!important;background-color:var(--first)!important;left:10rem;padding:10px;opacity:1;z-index:1000;transition:opacity .3s ease-in-out}.popup ul{list-style-type:none;padding:0;margin:0}.rotate{transform:rotate(180deg)}}.logo-img{height:auto!important;width:auto;max-height:40px;max-width:100%;object-fit:contain}@media (min-width: 992px){.banner-section{padding:0 40px}.sign-header-btn{color:#fff;font-weight:700;border:none;border-radius:999px;padding:8px 24px;width:142px;margin-right:.5rem;height:40px}}\n"] }]
40
+ args: [{ selector: 'pw-resource-header', template: "<nav class=\"navbar navbar-expand-md navbar-dark fixed-top cloudolive-nav-bg-color\"\n id=\"banner\">\n <div class=\"container container-wrapper banner-section\">\n <!-- Toggler/collapsibe Button -->\n <button class=\"navbar-toggler header-menu-bar\"\n type=\"button\"\n aria-label=\"Toggle navigation\"\n data-bs-toggle=\"collapse\"\n data-bs-target=\"#collapsibleNavbar\">\n <img src=\"/assets/img/products/trial/navbar-toggle-icon.png\"\n class=\"img-fluid navbar-toggle-icon\"\n alt=\"\" />\n </button>\n\n <!-- Mobile Logo -->\n <div class=\"d-md-none mb-icon\">\n <div>\n <img [src]=\"logo\"\n routerLink=\"/\"\n alt=\"logo\"\n class=\"img-fluid logo_img\" />\n </div>\n </div>\n\n <!-- Navbar links -->\n <div class=\"collapse navbar-collapse mt-3 mt-md-0\"\n id=\"collapsibleNavbar\"\n #collapsibleNavbar>\n <div class=\"row align-items-center w-100\">\n\n <!-- Always occupy 3 columns for logo -->\n <div class=\"col-md-3 d-none d-md-flex align-items-center\">\n <div *ngIf=\"logo\">\n <img [src]=\"logo\"\n (load)=\"logoLoaded = true\"\n (error)=\"logoLoaded = false\"\n routerLink=\"/\"\n alt=\"logo\"\n class=\"img-fluid logo_img\" />\n </div>\n </div>\n\n <div class=\"col-md-6 d-flex justify-content-start\">\n <ul #anchorLinks\n class=\"navbar-nav flex gap-4 me-0 wow fadeInUp position-relative\"\n data-wow-duration=\"2s\">\n <li class=\"nav-item\" *ngFor=\"let item of navbarItems\">\n <a\n class=\"nav-link\"\n href=\"javascript:void(0)\"\n [ngClass]=\"{ 'scrolled-nav-link': isScrolled }\"\n (click)=\"item.subtitles?.length ? (item.open = !item.open) : null\"\n [attr.href]=\"!(item.subtitles?.length) ? item.path : null\"\n >\n {{ item?.title }}\n <i *ngIf=\"item.open\" class=\"fa-solid fa-caret-down\"></i>\n </a>\n <div class=\"popup position-absolute\"\n *ngIf=\"item.subtitles && item.open\">\n <ul>\n <li\n *ngFor=\"let sub of item.subtitles\"\n [routerLink]=\"sub.path\"\n class=\"dropdownItem\"\n >\n {{ sub.title }}\n </li>\n </ul>\n </div>\n </li>\n\n <li class=\"nav-item ms-2 mb-3 d-flex d-md-none\">\n <button class=\"sign-btn sign-header-btn\"\n routerLink=\"/login\">Log In</button>\n </li>\n </ul>\n </div>\n\n <!-- Always 3 columns for login -->\n <div class=\"col-md-3 d-none d-md-flex justify-content-end\">\n <button class=\"sign-btn sign-header-btn\"\n routerLink=\"/login\">Log In</button>\n </div>\n\n </div>\n </div>\n </div>\n</nav>\n", styles: ["@import\"https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;1,100;1,200;1,300;1,400;1,500;1,600;1,700&display=swap\";:root{--first: rgb(23 105 225);--second: rgb(54 194 131);--third: rgb(255 171 0);--text: rgb(34 34 34);--tabs_bg: rgb(23 105 225);--tabs_sub_bg: rgb(70, 136, 236);--tabs_text: rgb(255 255 255);--titles: rgb(34 34 34);--sidebar_bg: rgb(0, 48, 63);--sidebar_text: rgb(255 255 255)}*{font-family:Montserrat,sans-serif}h2{font-size:32px;font-weight:700;letter-spacing:.03em;line-height:1.1em;text-transform:uppercase}@media (max-width: 1200px){.container-wrapper{padding:0 20px!important}}.navbar-custom-background{background-color:#00000080;box-shadow:2px 2px 15px 2px #0000001f;transition:width 2s,height 2s,-webkit-transform 2s;transition:width 2s,height 2s,transform 2s background-color .5s ease;z-index:9999}.fixed-top{position:fixed!important}.primary-button{background-color:#000;border-radius:50px;color:#fff;font: 600 16.3px Montserrat-Regular,sans-serif;padding:5px 16px!important;width:auto;display:flex;gap:15px;align-items:center;justify-content:space-between}.navbar-nav .nav-item .nav-link{color:#fff;font-size:18px;font-weight:500;letter-spacing:1px;padding:1.1em 1em!important}.logo_img{width:60%!important}.navbar-toggle-icon{width:25px}@media (min-width: 500px){.navbar-nav .nav-item button{margin-top:10px}}@media (max-width: 1200px){.navbar-nav .nav-item .nav-link{font-size:15px!important}}.fa-caret-down{font-family:\"Font Awesome 6 Pro\";font-weight:900}@media (min-width: 1200px){.navbar-nav .nav-item .nav-link{padding-bottom:0!important;padding-top:0!important}.popup{top:3.4rem!important;background-color:var(--first)!important;left:0rem;background-color:transparent;padding:10px;z-index:1000;transition:opacity .3s ease-in-out}.popup ul li{color:#fff;font: 500 14px Montserrat-Regular,sans-serif;cursor:pointer;border-bottom:1px solid #eee}.popup ul li:last-child{border-bottom:none}.router-link-active{color:#000!important}}@media (max-width: 1200px){.popup ul li{color:#fff;font: 500 14px Montserrat-Regular,sans-serif;cursor:pointer;border-bottom:1px solid #eee}.popup ul li:last-child{border-bottom:none}.popup ul li:hover{background-color:#f1f1f1}.mb-icon{width:200px}.container-wrapper{padding:10px 20px!important}.popup{top:0%!important;background-color:var(--first)!important;left:10rem;background-color:transparent;padding:10px;z-index:1000;transition:opacity .3s ease-in-out}}@media (max-width: 500px){.navbar-nav{background-color:var(--first);border-top:3px solid rgb(254,209,54);color:#fff;margin-top:5px;z-index:1}.navbar-nav .nav-item .nav-link{font-size:100%;font-weight:500;padding:.7em 1em!important}}.popup{top:90%;background-color:transparent;padding:10px;z-index:1000}.popup ul{list-style-type:none;padding:0;margin:0}.popup ul li{padding:5px 10px;font: 500 14px Montserrat-Regular,sans-serif}.nav-link{color:#000!important;transition:color .3s ease}.nav-link.scrolled-nav-link{color:#fff!important}.dropdownItem{cursor:pointer}.rotate{transform:rotate(180deg)}@media (max-width: 500px){.logo_img{width:60%!important;margin-left:auto;margin-right:0;display:block;transition:margin .5s ease,width .5s ease}.navbar-nav{background-color:var(--first);border-top:3px solid rgb(254,209,54);color:#fff;margin-top:5px;z-index:1}.navbar-nav .nav-item .nav-link{font-size:100%;font-weight:500;padding:.7em 1em!important}.popup{top:0%!important;background-color:var(--first)!important;left:10rem;background-color:transparent;padding:10px;z-index:1000;transition:opacity .3s ease-in-out}.popup ul{list-style-type:none;padding:0;margin:0}.dropdownItem{cursor:pointer}.rotate{transform:rotate(180deg)}.popup.ngIf{opacity:1}}.navbar-nav{visibility:visible!important;display:flex!important}.nav-link{text-transform:uppercase}\n"] }]
39
41
  }], ctorParameters: () => [{ type: i0.Injector }, { type: Document, decorators: [{
40
42
  type: Inject,
41
43
  args: [DOCUMENT]
@@ -46,4 +48,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
46
48
  type: HostListener,
47
49
  args: ['window:scroll', []]
48
50
  }] } });
49
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzb3VyY2UtaGVhZGVyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvc2hhcmVkLWNvbXBvbmVudHMvc3JjL2xpYi9yZXNvdXJjZS1oZWFkZXIvcmVzb3VyY2UtaGVhZGVyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvc2hhcmVkLWNvbXBvbmVudHMvc3JjL2xpYi9yZXNvdXJjZS1oZWFkZXIvcmVzb3VyY2UtaGVhZGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMzQyxPQUFPLEVBQ0gsU0FBUyxFQUNULFVBQVUsRUFDVixZQUFZLEVBQ1osTUFBTSxFQUNOLFFBQVEsRUFFUixTQUFTLEVBQ1osTUFBTSxlQUFlLENBQUM7QUFFdkIsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sOEJBQThCLENBQUM7Ozs7QUFPaEUsTUFBTSxPQUFPLHVCQUF3QixTQUFRLGdCQUFnQjtJQUt6RCxZQUNJLFFBQWtCLEVBQ2lCLFFBQWtCO1FBRXJELEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUZtQixhQUFRLEdBQVIsUUFBUSxDQUFVO1FBTHpELGVBQVUsR0FBRyxLQUFLLENBQUM7UUFDbkIsU0FBSSxHQUFHLEtBQUssQ0FBQztJQU9iLENBQUM7SUFFRCxRQUFRO1FBQ0osSUFBSSxDQUFDLElBQUksR0FBRyxJQUFJLENBQUMsU0FBUyxFQUFFLE9BQU8sRUFBRSxLQUFLLEVBQUUsU0FBUyxFQUFFLEdBQUcsQ0FBQztJQUMvRCxDQUFDO0lBR0QsUUFBUTtRQUNKLElBQUksQ0FBQyxVQUFVLEdBQUcsTUFBTSxDQUFDLE9BQU8sR0FBRyxHQUFHLENBQUM7UUFDdkMsSUFBSSxNQUFNLENBQUMsT0FBTyxHQUFHLEdBQUcsRUFBRSxDQUFDO1lBQ3ZCLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDLFNBQVMsRUFBRSxPQUFPLEVBQUUsS0FBSyxFQUFFLGFBQWEsRUFBRSxHQUFHLENBQUM7UUFDbkUsQ0FBQzthQUFNLElBQUksTUFBTSxDQUFDLE9BQU8sSUFBSSxHQUFHLEVBQUUsQ0FBQztZQUMvQixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxTQUFTLEVBQUUsT0FBTyxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsR0FBRyxDQUFDO1FBQy9ELENBQUM7UUFDRCxJQUFJLE1BQU0sQ0FBQyxVQUFVLEdBQUcsR0FBRyxFQUFFLENBQUM7WUFDMUIsSUFBSSxDQUFDLElBQUksR0FBRyxLQUFLLENBQUM7WUFDbEIsTUFBTSxlQUFlLEdBQUcsSUFBSSxDQUFDLGNBQWMsRUFBRSxhQUFhLENBQUM7WUFDM0QsSUFBSSxlQUFlLEVBQUUsU0FBUyxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDO2dCQUM5QyxlQUFlLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUM3QyxDQUFDO1FBQ0wsQ0FBQztJQUNMLENBQUM7K0dBL0JRLHVCQUF1QiwwQ0FPcEIsUUFBUTttR0FQWCx1QkFBdUIsOFBDbEJwQyxtdURBbUNBOzs0RkRqQmEsdUJBQXVCO2tCQUxuQyxTQUFTOytCQUNJLG9CQUFvQjs7MEJBV3pCLE1BQU07MkJBQUMsUUFBUTt5Q0FOWSxjQUFjO3NCQUE3QyxTQUFTO3VCQUFDLG1CQUFtQjtnQkFnQjlCLFFBQVE7c0JBRFAsWUFBWTt1QkFBQyxlQUFlLEVBQUUsRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERPQ1VNRU5UIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7XG4gICAgQ29tcG9uZW50LFxuICAgIEVsZW1lbnRSZWYsXG4gICAgSG9zdExpc3RlbmVyLFxuICAgIEluamVjdCxcbiAgICBJbmplY3RvcixcbiAgICBPbkluaXQsXG4gICAgVmlld0NoaWxkXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBBcHBCYXNlQ29tcG9uZW50IH0gZnJvbSAnQHBvc2l3aXNlL2FwcC1iYXNlLWNvbXBvbmVudCc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAncHctcmVzb3VyY2UtaGVhZGVyJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vcmVzb3VyY2UtaGVhZGVyLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9yZXNvdXJjZS1oZWFkZXIuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBSZXNvdXJjZUhlYWRlckNvbXBvbmVudCBleHRlbmRzIEFwcEJhc2VDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICAgIEBWaWV3Q2hpbGQoJ2NvbGxhcHNpYmxlTmF2YmFyJykgbmF2YmFyQ29sbGFwc2U6IEVsZW1lbnRSZWY7XG4gICAgaXNTY3JvbGxlZCA9IGZhbHNlO1xuICAgIG9wZW4gPSBmYWxzZTtcbiAgICBsb2dvO1xuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBpbmplY3RvcjogSW5qZWN0b3IsXG4gICAgICAgIEBJbmplY3QoRE9DVU1FTlQpIHByaXZhdGUgcmVhZG9ubHkgZG9jdW1lbnQ6IERvY3VtZW50XG4gICAgKSB7XG4gICAgICAgIHN1cGVyKGluamVjdG9yKTtcbiAgICB9XG5cbiAgICBuZ09uSW5pdCgpIHtcbiAgICAgICAgdGhpcy5sb2dvID0gdGhpcy5hcHBDb25maWc/LmNvbXBhbnk/LmxvZ29zPy5tYWluX2Rhcms/LnVybDtcbiAgICB9XG5cbiAgICBASG9zdExpc3RlbmVyKCd3aW5kb3c6c2Nyb2xsJywgW10pXG4gICAgb25TY3JvbGwoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuaXNTY3JvbGxlZCA9IHdpbmRvdy5zY3JvbGxZID4gMTUwO1xuICAgICAgICBpZiAod2luZG93LnNjcm9sbFkgPiAxNTApIHtcbiAgICAgICAgICAgIHRoaXMubG9nbyA9IHRoaXMuYXBwQ29uZmlnPy5jb21wYW55Py5sb2dvcz8ubWFpbl9jb250cmFzdD8udXJsO1xuICAgICAgICB9IGVsc2UgaWYgKHdpbmRvdy5zY3JvbGxZIDw9IDE1MCkge1xuICAgICAgICAgICAgdGhpcy5sb2dvID0gdGhpcy5hcHBDb25maWc/LmNvbXBhbnk/LmxvZ29zPy5tYWluX2Rhcms/LnVybDtcbiAgICAgICAgfVxuICAgICAgICBpZiAod2luZG93LmlubmVyV2lkdGggPCA3NjgpIHtcbiAgICAgICAgICAgIHRoaXMub3BlbiA9IGZhbHNlO1xuICAgICAgICAgICAgY29uc3QgY29sbGFwc2VFbGVtZW50ID0gdGhpcy5uYXZiYXJDb2xsYXBzZT8ubmF0aXZlRWxlbWVudDtcbiAgICAgICAgICAgIGlmIChjb2xsYXBzZUVsZW1lbnQ/LmNsYXNzTGlzdC5jb250YWlucygnc2hvdycpKSB7XG4gICAgICAgICAgICAgICAgY29sbGFwc2VFbGVtZW50LmNsYXNzTGlzdC5yZW1vdmUoJ3Nob3cnKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgIH1cbn1cbiIsIjxuYXYgY2xhc3M9XCJuYXZiYXIgbmF2YmFyLWV4cGFuZC1sZyBuYXZiYXItZGFyayBmaXhlZC10b3AgY2xvdWRvbGl2ZS1uYXYtYmctY29sb3JcIiBpZD1cImJhbm5lclwiPlxuICA8ZGl2IGNsYXNzPVwiY29udGFpbmVyIGNvbnRhaW5lci13cmFwcGVyIGJhbm5lci1zZWN0aW9uIGQtZmxleCBqdXN0aWZ5LWNvbnRlbnQtYmV0d2VlbiBhbGlnbi1pdGVtcy1jZW50ZXJcIj5cblxuICAgIDwhLS0gTW9iaWxlOiBMb2dvIExlZnQsIFRvZ2dsZXIgUmlnaHQgLS0+XG4gICAgPGRpdiBjbGFzcz1cImQtZmxleCBhbGlnbi1pdGVtcy1jZW50ZXIganVzdGlmeS1jb250ZW50LWJldHdlZW4gdy0xMDAgZC1sZy1ub25lXCI+XG4gICAgICA8YnV0dG9uIGNsYXNzPVwibmF2YmFyLXRvZ2dsZXIgaGVhZGVyLW1lbnUtYmFyXCIgdHlwZT1cImJ1dHRvblwiIGFyaWEtbGFiZWw9XCJUb2dnbGUgbmF2aWdhdGlvblwiIGRhdGEtYnMtdG9nZ2xlPVwiY29sbGFwc2VcIiBkYXRhLWJzLXRhcmdldD1cIiNjb2xsYXBzaWJsZU5hdmJhclwiPlxuICAgICAgICA8aW1nIHNyYz1cIi9hc3NldHMvaW1nL3Byb2R1Y3RzL3RyaWFsL25hdmJhci10b2dnbGUtaWNvbi5wbmdcIiBjbGFzcz1cImltZy1mbHVpZCBuYXZiYXItdG9nZ2xlLWljb25cIiBhbHQ9XCJcIiAvPlxuICAgICAgPC9idXR0b24+XG4gICAgICA8ZGl2IGNsYXNzPVwibWItaWNvblwiPlxuICAgICAgICA8aW1nIFtzcmNdPVwibG9nb1wiIHJvdXRlckxpbms9XCIvXCIgYWx0PVwibG9nb1wiIGNsYXNzPVwiaW1nLWZsdWlkIGxvZ28taW1nXCIgLz5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuXG4gICAgPCEtLSBEZXNrdG9wOiBMb2dvIExlZnQgLS0+XG4gICAgPGRpdiBjbGFzcz1cImQtbm9uZSBkLWxnLWJsb2NrIG1iLTEgbXQtMVwiPlxuICAgICAgPGltZyBbc3JjXT1cImxvZ29cIiByb3V0ZXJMaW5rPVwiL1wiIGFsdD1cImxvZ29cIiBjbGFzcz1cImltZy1mbHVpZCBsb2dvLWltZyBoZWFkZXItbG9nb1wiIC8+XG4gICAgPC9kaXY+XG5cbiAgICA8IS0tIENlbnRlciBuYXYgbGlua3MgKGN1cnJlbnRseSBoaWRkZW4gb24gZGVza3RvcCkgLS0+XG4gICAgPGRpdiBjbGFzcz1cImNvbGxhcHNlIG5hdmJhci1jb2xsYXBzZSBqdXN0aWZ5LWNvbnRlbnQtY2VudGVyXCIgaWQ9XCJjb2xsYXBzaWJsZU5hdmJhclwiICNjb2xsYXBzaWJsZU5hdmJhcj5cbiAgICAgIDx1bCAjYW5jaG9yTGlua3MgY2xhc3M9XCJuYXZiYXItbmF2IGZsZXggZ2FwLTQgbWUtMCB3b3cgZmFkZUluVXAgcG9zaXRpb24tcmVsYXRpdmVcIiBkYXRhLXdvdy1kdXJhdGlvbj1cIjJzXCI+XG4gICAgICAgIDwhLS0gTW9iaWxlIExvZ2luIEJ1dHRvbiAtLT5cbiAgICAgICAgPGxpIGNsYXNzPVwibmF2LWl0ZW0gbGctbXMtMiBtYi0zIGQtZmxleCBkLWxnLW5vbmUgbmF2LWl0ZW0gbXQtMyBtZC1tdC0wXCI+XG4gICAgICAgICAgPGJ1dHRvbiBjbGFzcz1cInNpZ24tYnRuIHNpZ24taGVhZGVyLWJ0blwiIHJvdXRlckxpbms9XCIvbG9naW5cIj5Mb2cgSW48L2J1dHRvbj5cbiAgICAgICAgPC9saT5cbiAgICAgIDwvdWw+XG4gICAgPC9kaXY+XG5cbiAgICA8IS0tIERlc2t0b3AgTG9naW4gQnV0dG9uIC0tPlxuICAgIDxkaXYgY2xhc3M9XCJkLW5vbmUgZC1sZy1ibG9jayBtdC0xIG1iLTFcIj5cbiAgICAgIDxidXR0b24gY2xhc3M9XCJzaWduLWJ0biBzaWduLWhlYWRlci1idG5cIiByb3V0ZXJMaW5rPVwiL2xvZ2luXCI+TG9nIEluPC9idXR0b24+XG4gICAgPC9kaXY+XG5cbiAgPC9kaXY+XG48L25hdj5cbiJdfQ==
51
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resource-header.component.js","sourceRoot":"","sources":["../../../../../../libs/shared-components/src/lib/resource-header/resource-header.component.ts","../../../../../../libs/shared-components/src/lib/resource-header/resource-header.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EACH,SAAS,EACT,UAAU,EACV,YAAY,EACZ,MAAM,EACN,QAAQ,EAER,SAAS,EACZ,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAC;;;;;AAOhE,MAAM,OAAO,uBAAwB,SAAQ,gBAAgB;IAOzD,YACI,QAAkB,EACiB,QAAkB;QAErD,KAAK,CAAC,QAAQ,CAAC,CAAC;QAFmB,aAAQ,GAAR,QAAQ,CAAU;QAPzD,eAAU,GAAG,KAAK,CAAC;QACnB,SAAI,GAAG,KAAK,CAAC;QAEb,gBAAW,GAAG,IAAI,CAAC,SAAS,EAAE,YAAY,EAAE,MAAM,EAAE,KAAK,CAAC;IAO1D,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,EAAE,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,CAAC;IAC/D,CAAC;IAGD,QAAQ;QACJ,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC,OAAO,GAAG,GAAG,CAAC;QACvC,IAAI,MAAM,CAAC,OAAO,GAAG,GAAG,EAAE,CAAC;YACvB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,EAAE,OAAO,EAAE,KAAK,EAAE,aAAa,EAAE,GAAG,CAAC;QACnE,CAAC;aAAM,IAAI,MAAM,CAAC,OAAO,IAAI,GAAG,EAAE,CAAC;YAC/B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,SAAS,EAAE,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,CAAC;QAC/D,CAAC;QACD,IAAI,MAAM,CAAC,UAAU,GAAG,GAAG,EAAE,CAAC;YAC1B,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;YAClB,MAAM,eAAe,GAAG,IAAI,CAAC,cAAc,EAAE,aAAa,CAAC;YAC3D,IAAI,eAAe,EAAE,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;gBAC9C,eAAe,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;YAC7C,CAAC;QACL,CAAC;IACL,CAAC;+GAjCQ,uBAAuB,0CASpB,QAAQ;mGATX,uBAAuB,8PClBpC,+kGAwFA;;4FDtEa,uBAAuB;kBALnC,SAAS;+BACI,oBAAoB;;0BAazB,MAAM;2BAAC,QAAQ;yCARY,cAAc;sBAA7C,SAAS;uBAAC,mBAAmB;gBAkB9B,QAAQ;sBADP,YAAY;uBAAC,eAAe,EAAE,EAAE","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport {\n    Component,\n    ElementRef,\n    HostListener,\n    Inject,\n    Injector,\n    OnInit,\n    ViewChild\n} from '@angular/core';\n\nimport { AppBaseComponent } from '@posiwise/app-base-component';\n\n@Component({\n    selector: 'pw-resource-header',\n    templateUrl: './resource-header.component.html',\n    styleUrls: ['./resource-header.component.scss']\n})\nexport class ResourceHeaderComponent extends AppBaseComponent implements OnInit {\n    @ViewChild('collapsibleNavbar') navbarCollapse: ElementRef;\n    isScrolled = false;\n    open = false;\n    logo;\n    navbarItems = this.appConfig?.pages_config?.navbar?.items;\n\n    constructor(\n        injector: Injector,\n        @Inject(DOCUMENT) private readonly document: Document\n    ) {\n        super(injector);\n    }\n\n    ngOnInit() {\n        this.logo = this.appConfig?.company?.logos?.main_dark?.url;\n    }\n\n    @HostListener('window:scroll', [])\n    onScroll(): void {\n        this.isScrolled = window.scrollY > 150;\n        if (window.scrollY > 150) {\n            this.logo = this.appConfig?.company?.logos?.main_contrast?.url;\n        } else if (window.scrollY <= 150) {\n            this.logo = this.appConfig?.company?.logos?.main_dark?.url;\n        }\n        if (window.innerWidth < 768) {\n            this.open = false;\n            const collapseElement = this.navbarCollapse?.nativeElement;\n            if (collapseElement?.classList.contains('show')) {\n                collapseElement.classList.remove('show');\n            }\n        }\n    }\n}\n","<nav class=\"navbar navbar-expand-md navbar-dark fixed-top cloudolive-nav-bg-color\"\n  id=\"banner\">\n  <div class=\"container container-wrapper banner-section\">\n    <!-- Toggler/collapsibe Button -->\n    <button class=\"navbar-toggler header-menu-bar\"\n      type=\"button\"\n      aria-label=\"Toggle navigation\"\n      data-bs-toggle=\"collapse\"\n      data-bs-target=\"#collapsibleNavbar\">\n      <img src=\"/assets/img/products/trial/navbar-toggle-icon.png\"\n        class=\"img-fluid navbar-toggle-icon\"\n        alt=\"\" />\n    </button>\n\n    <!-- Mobile Logo -->\n    <div class=\"d-md-none mb-icon\">\n      <div>\n        <img [src]=\"logo\"\n          routerLink=\"/\"\n          alt=\"logo\"\n          class=\"img-fluid logo_img\" />\n      </div>\n    </div>\n\n    <!-- Navbar links -->\n    <div class=\"collapse navbar-collapse mt-3 mt-md-0\"\n      id=\"collapsibleNavbar\"\n      #collapsibleNavbar>\n      <div class=\"row align-items-center w-100\">\n\n        <!-- Always occupy 3 columns for logo -->\n        <div class=\"col-md-3 d-none d-md-flex align-items-center\">\n          <div *ngIf=\"logo\">\n            <img [src]=\"logo\"\n              (load)=\"logoLoaded = true\"\n              (error)=\"logoLoaded = false\"\n              routerLink=\"/\"\n              alt=\"logo\"\n              class=\"img-fluid logo_img\" />\n          </div>\n        </div>\n\n        <div class=\"col-md-6 d-flex justify-content-start\">\n          <ul #anchorLinks\n            class=\"navbar-nav flex gap-4 me-0 wow fadeInUp position-relative\"\n            data-wow-duration=\"2s\">\n            <li class=\"nav-item\" *ngFor=\"let item of navbarItems\">\n                <a\n                class=\"nav-link\"\n                  href=\"javascript:void(0)\"\n                  [ngClass]=\"{ 'scrolled-nav-link': isScrolled }\"\n                  (click)=\"item.subtitles?.length ? (item.open = !item.open) : null\"\n                  [attr.href]=\"!(item.subtitles?.length) ? item.path : null\"\n                >\n                  {{ item?.title }}\n                  <i *ngIf=\"item.open\" class=\"fa-solid fa-caret-down\"></i>\n                    </a>\n              <div class=\"popup position-absolute\"\n              *ngIf=\"item.subtitles && item.open\">\n              <ul>\n                <li\n                    *ngFor=\"let sub of item.subtitles\"\n                    [routerLink]=\"sub.path\"\n                    class=\"dropdownItem\"\n                  >\n                    {{ sub.title }}\n                  </li>\n              </ul>\n            </div>\n            </li>\n\n            <li class=\"nav-item ms-2 mb-3 d-flex d-md-none\">\n              <button class=\"sign-btn sign-header-btn\"\n                routerLink=\"/login\">Log In</button>\n            </li>\n          </ul>\n        </div>\n\n        <!-- Always 3 columns for login -->\n        <div class=\"col-md-3 d-none d-md-flex justify-content-end\">\n          <button class=\"sign-btn sign-header-btn\"\n            routerLink=\"/login\">Log In</button>\n        </div>\n\n      </div>\n    </div>\n  </div>\n</nav>\n"]}
@@ -219,7 +219,6 @@ class ProfileImageCropperComponent {
219
219
  this.showCropper = false;
220
220
  }
221
221
  onFileChange(event) {
222
- console.log(this.aspectRatio, this.dynamicData);
223
222
  const input = event.target;
224
223
  if (input.files && input.files.length > 0) {
225
224
  this.imageChangedEvent = event;
@@ -1193,7 +1192,6 @@ class NumberPickerComponent {
1193
1192
  this.isInputFocused = false;
1194
1193
  }
1195
1194
  onMouseWheel(event) {
1196
- console.log(event, 'abc');
1197
1195
  if (this.isInputFocused) {
1198
1196
  event.preventDefault();
1199
1197
  let wheelUp = null;
@@ -1821,6 +1819,7 @@ class ResourceHeaderComponent extends AppBaseComponent {
1821
1819
  this.document = document;
1822
1820
  this.isScrolled = false;
1823
1821
  this.open = false;
1822
+ this.navbarItems = this.appConfig?.pages_config?.navbar?.items;
1824
1823
  }
1825
1824
  ngOnInit() {
1826
1825
  this.logo = this.appConfig?.company?.logos?.main_dark?.url;
@@ -1842,11 +1841,11 @@ class ResourceHeaderComponent extends AppBaseComponent {
1842
1841
  }
1843
1842
  }
1844
1843
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ResourceHeaderComponent, deps: [{ token: i0.Injector }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Component }); }
1845
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: ResourceHeaderComponent, selector: "pw-resource-header", host: { listeners: { "window:scroll": "onScroll()" } }, viewQueries: [{ propertyName: "navbarCollapse", first: true, predicate: ["collapsibleNavbar"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<nav class=\"navbar navbar-expand-lg navbar-dark fixed-top cloudolive-nav-bg-color\" id=\"banner\">\n <div class=\"container container-wrapper banner-section d-flex justify-content-between align-items-center\">\n\n <!-- Mobile: Logo Left, Toggler Right -->\n <div class=\"d-flex align-items-center justify-content-between w-100 d-lg-none\">\n <button class=\"navbar-toggler header-menu-bar\" type=\"button\" aria-label=\"Toggle navigation\" data-bs-toggle=\"collapse\" data-bs-target=\"#collapsibleNavbar\">\n <img src=\"/assets/img/products/trial/navbar-toggle-icon.png\" class=\"img-fluid navbar-toggle-icon\" alt=\"\" />\n </button>\n <div class=\"mb-icon\">\n <img [src]=\"logo\" routerLink=\"/\" alt=\"logo\" class=\"img-fluid logo-img\" />\n </div>\n </div>\n\n <!-- Desktop: Logo Left -->\n <div class=\"d-none d-lg-block mb-1 mt-1\">\n <img [src]=\"logo\" routerLink=\"/\" alt=\"logo\" class=\"img-fluid logo-img header-logo\" />\n </div>\n\n <!-- Center nav links (currently hidden on desktop) -->\n <div class=\"collapse navbar-collapse justify-content-center\" id=\"collapsibleNavbar\" #collapsibleNavbar>\n <ul #anchorLinks class=\"navbar-nav flex gap-4 me-0 wow fadeInUp position-relative\" data-wow-duration=\"2s\">\n <!-- Mobile Login Button -->\n <li class=\"nav-item lg-ms-2 mb-3 d-flex d-lg-none nav-item mt-3 md-mt-0\">\n <button class=\"sign-btn sign-header-btn\" routerLink=\"/login\">Log In</button>\n </li>\n </ul>\n </div>\n\n <!-- Desktop Login Button -->\n <div class=\"d-none d-lg-block mt-1 mb-1\">\n <button class=\"sign-btn sign-header-btn\" routerLink=\"/login\">Log In</button>\n </div>\n\n </div>\n</nav>\n", styles: ["@import\"https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;1,100;1,200;1,300;1,400;1,500;1,600;1,700&display=swap\";:root{--first: rgb(23 105 225);--second: rgb(54 194 131);--third: rgb(255 171 0);--text: rgb(34 34 34);--tabs_bg: rgb(23 105 225);--tabs_sub_bg: rgb(70, 136, 236);--tabs_text: rgb(255 255 255);--titles: rgb(34 34 34);--sidebar_bg: rgb(0, 48, 63);--sidebar_text: rgb(255 255 255)}*{font-family:Montserrat,sans-serif}h2{font-size:32px;font-weight:700;letter-spacing:.03em;line-height:1.1em;text-transform:uppercase}@media (max-width: 1200px){.container-wrapper{padding:0 20px!important}}@media screen and (max-width: 991px){.header-menu-bar{background-color:var(--first);background-image:none;border:1px solid rgb(255,255,255);border-radius:4px;display:block!important;float:right;margin-top:4px;padding:9px 10px;position:relative}}.navbar-custom-background{background-color:#00000080;box-shadow:2px 2px 15px 2px #0000001f;transition:width 2s,height 2s,-webkit-transform 2s;transition:width 2s,height 2s,transform 2s background-color .5s ease;z-index:9999}.fixed-top{position:fixed!important}.primary-button{background-color:#000;border-radius:50px;color:#fff;font: 600 16.3px Montserrat-Regular,sans-serif;padding:5px 16px!important;width:auto;display:flex;gap:15px;align-items:center;justify-content:space-between}.nav-link{color:#000!important;transition:color .3s ease}.nav-link.scrolled-nav-link{color:#fff!important}.navbar-nav{visibility:visible!important}.navbar-nav .nav-item .nav-link{color:#fff;font-size:18px;font-weight:500;letter-spacing:1px;padding:1.1em 1em!important}.navbar-toggle-icon{width:25px}.d-flex img{margin-right:0!important}@media (min-width: 500px){.navbar-nav .nav-item button{margin-top:10px}}@media (max-width: 1200px){.navbar-nav .nav-item .nav-link{font-size:15px!important}}@media (min-width: 1200px){.navbar-nav .nav-item .nav-link{padding-bottom:0!important;padding-top:1.8rem!important}.popup{top:5.4rem!important;background-color:var(--first)!important;left:0;padding:10px;z-index:1000;transition:opacity .3s ease-in-out}.popup ul li{color:#fff;font: 500 14px Montserrat-Regular,sans-serif;cursor:pointer;border-bottom:1px solid #eee}.popup ul li:last-child{border-bottom:none}.router-link-active{color:#000!important}}@media (max-width: 1200px){.popup ul li{color:#fff;font: 500 14px Montserrat-Regular,sans-serif;cursor:pointer;border-bottom:1px solid #eee}.popup ul li:last-child{border-bottom:none}.popup ul li:hover{background-color:#f1f1f1}.mb-icon{width:200px}.container-wrapper{padding:0 20px!important}.popup{top:0%!important;background-color:var(--first)!important;left:10rem;padding:10px;z-index:1000;transition:opacity .3s ease-in-out}}@media (max-width: 991px){.navbar-nav{color:#fff;margin-top:5px;z-index:1}.navbar-nav .nav-item .nav-link{font-size:100%;font-weight:500;padding:.7em 1em!important}}.popup{top:90%;background-color:transparent;padding:10px;z-index:1000}.popup ul{list-style-type:none;padding:0;margin:0}.popup ul li{padding:5px 10px;font: 500 14px Montserrat-Regular,sans-serif}.rotate{transform:rotate(180deg)}@media (max-width: 991px){.logo-img{width:70%!important;margin-left:auto;margin-right:0;display:block;transition:margin .5s ease,width .5s ease}.navbar-nav{color:#fff;margin-top:5px;z-index:1}.navbar-nav .nav-item .nav-link{font-size:100%;font-weight:500;padding:.7em 1em!important}.popup{top:0%!important;background-color:var(--first)!important;left:10rem;padding:10px;opacity:1;z-index:1000;transition:opacity .3s ease-in-out}.popup ul{list-style-type:none;padding:0;margin:0}.rotate{transform:rotate(180deg)}}.logo-img{height:auto!important;width:auto;max-height:40px;max-width:100%;object-fit:contain}@media (min-width: 992px){.banner-section{padding:0 40px}.sign-header-btn{color:#fff;font-weight:700;border:none;border-radius:999px;padding:8px 24px;width:142px;margin-right:.5rem;height:40px}}\n"], dependencies: [{ kind: "directive", type: i1$1.LazyImgDirective, selector: "img" }, { kind: "directive", type: i2$4.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }] }); }
1844
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: ResourceHeaderComponent, selector: "pw-resource-header", host: { listeners: { "window:scroll": "onScroll()" } }, viewQueries: [{ propertyName: "navbarCollapse", first: true, predicate: ["collapsibleNavbar"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<nav class=\"navbar navbar-expand-md navbar-dark fixed-top cloudolive-nav-bg-color\"\n id=\"banner\">\n <div class=\"container container-wrapper banner-section\">\n <!-- Toggler/collapsibe Button -->\n <button class=\"navbar-toggler header-menu-bar\"\n type=\"button\"\n aria-label=\"Toggle navigation\"\n data-bs-toggle=\"collapse\"\n data-bs-target=\"#collapsibleNavbar\">\n <img src=\"/assets/img/products/trial/navbar-toggle-icon.png\"\n class=\"img-fluid navbar-toggle-icon\"\n alt=\"\" />\n </button>\n\n <!-- Mobile Logo -->\n <div class=\"d-md-none mb-icon\">\n <div>\n <img [src]=\"logo\"\n routerLink=\"/\"\n alt=\"logo\"\n class=\"img-fluid logo_img\" />\n </div>\n </div>\n\n <!-- Navbar links -->\n <div class=\"collapse navbar-collapse mt-3 mt-md-0\"\n id=\"collapsibleNavbar\"\n #collapsibleNavbar>\n <div class=\"row align-items-center w-100\">\n\n <!-- Always occupy 3 columns for logo -->\n <div class=\"col-md-3 d-none d-md-flex align-items-center\">\n <div *ngIf=\"logo\">\n <img [src]=\"logo\"\n (load)=\"logoLoaded = true\"\n (error)=\"logoLoaded = false\"\n routerLink=\"/\"\n alt=\"logo\"\n class=\"img-fluid logo_img\" />\n </div>\n </div>\n\n <div class=\"col-md-6 d-flex justify-content-start\">\n <ul #anchorLinks\n class=\"navbar-nav flex gap-4 me-0 wow fadeInUp position-relative\"\n data-wow-duration=\"2s\">\n <li class=\"nav-item\" *ngFor=\"let item of navbarItems\">\n <a\n class=\"nav-link\"\n href=\"javascript:void(0)\"\n [ngClass]=\"{ 'scrolled-nav-link': isScrolled }\"\n (click)=\"item.subtitles?.length ? (item.open = !item.open) : null\"\n [attr.href]=\"!(item.subtitles?.length) ? item.path : null\"\n >\n {{ item?.title }}\n <i *ngIf=\"item.open\" class=\"fa-solid fa-caret-down\"></i>\n </a>\n <div class=\"popup position-absolute\"\n *ngIf=\"item.subtitles && item.open\">\n <ul>\n <li\n *ngFor=\"let sub of item.subtitles\"\n [routerLink]=\"sub.path\"\n class=\"dropdownItem\"\n >\n {{ sub.title }}\n </li>\n </ul>\n </div>\n </li>\n\n <li class=\"nav-item ms-2 mb-3 d-flex d-md-none\">\n <button class=\"sign-btn sign-header-btn\"\n routerLink=\"/login\">Log In</button>\n </li>\n </ul>\n </div>\n\n <!-- Always 3 columns for login -->\n <div class=\"col-md-3 d-none d-md-flex justify-content-end\">\n <button class=\"sign-btn sign-header-btn\"\n routerLink=\"/login\">Log In</button>\n </div>\n\n </div>\n </div>\n </div>\n</nav>\n", styles: ["@import\"https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;1,100;1,200;1,300;1,400;1,500;1,600;1,700&display=swap\";:root{--first: rgb(23 105 225);--second: rgb(54 194 131);--third: rgb(255 171 0);--text: rgb(34 34 34);--tabs_bg: rgb(23 105 225);--tabs_sub_bg: rgb(70, 136, 236);--tabs_text: rgb(255 255 255);--titles: rgb(34 34 34);--sidebar_bg: rgb(0, 48, 63);--sidebar_text: rgb(255 255 255)}*{font-family:Montserrat,sans-serif}h2{font-size:32px;font-weight:700;letter-spacing:.03em;line-height:1.1em;text-transform:uppercase}@media (max-width: 1200px){.container-wrapper{padding:0 20px!important}}.navbar-custom-background{background-color:#00000080;box-shadow:2px 2px 15px 2px #0000001f;transition:width 2s,height 2s,-webkit-transform 2s;transition:width 2s,height 2s,transform 2s background-color .5s ease;z-index:9999}.fixed-top{position:fixed!important}.primary-button{background-color:#000;border-radius:50px;color:#fff;font: 600 16.3px Montserrat-Regular,sans-serif;padding:5px 16px!important;width:auto;display:flex;gap:15px;align-items:center;justify-content:space-between}.navbar-nav .nav-item .nav-link{color:#fff;font-size:18px;font-weight:500;letter-spacing:1px;padding:1.1em 1em!important}.logo_img{width:60%!important}.navbar-toggle-icon{width:25px}@media (min-width: 500px){.navbar-nav .nav-item button{margin-top:10px}}@media (max-width: 1200px){.navbar-nav .nav-item .nav-link{font-size:15px!important}}.fa-caret-down{font-family:\"Font Awesome 6 Pro\";font-weight:900}@media (min-width: 1200px){.navbar-nav .nav-item .nav-link{padding-bottom:0!important;padding-top:0!important}.popup{top:3.4rem!important;background-color:var(--first)!important;left:0rem;background-color:transparent;padding:10px;z-index:1000;transition:opacity .3s ease-in-out}.popup ul li{color:#fff;font: 500 14px Montserrat-Regular,sans-serif;cursor:pointer;border-bottom:1px solid #eee}.popup ul li:last-child{border-bottom:none}.router-link-active{color:#000!important}}@media (max-width: 1200px){.popup ul li{color:#fff;font: 500 14px Montserrat-Regular,sans-serif;cursor:pointer;border-bottom:1px solid #eee}.popup ul li:last-child{border-bottom:none}.popup ul li:hover{background-color:#f1f1f1}.mb-icon{width:200px}.container-wrapper{padding:10px 20px!important}.popup{top:0%!important;background-color:var(--first)!important;left:10rem;background-color:transparent;padding:10px;z-index:1000;transition:opacity .3s ease-in-out}}@media (max-width: 500px){.navbar-nav{background-color:var(--first);border-top:3px solid rgb(254,209,54);color:#fff;margin-top:5px;z-index:1}.navbar-nav .nav-item .nav-link{font-size:100%;font-weight:500;padding:.7em 1em!important}}.popup{top:90%;background-color:transparent;padding:10px;z-index:1000}.popup ul{list-style-type:none;padding:0;margin:0}.popup ul li{padding:5px 10px;font: 500 14px Montserrat-Regular,sans-serif}.nav-link{color:#000!important;transition:color .3s ease}.nav-link.scrolled-nav-link{color:#fff!important}.dropdownItem{cursor:pointer}.rotate{transform:rotate(180deg)}@media (max-width: 500px){.logo_img{width:60%!important;margin-left:auto;margin-right:0;display:block;transition:margin .5s ease,width .5s ease}.navbar-nav{background-color:var(--first);border-top:3px solid rgb(254,209,54);color:#fff;margin-top:5px;z-index:1}.navbar-nav .nav-item .nav-link{font-size:100%;font-weight:500;padding:.7em 1em!important}.popup{top:0%!important;background-color:var(--first)!important;left:10rem;background-color:transparent;padding:10px;z-index:1000;transition:opacity .3s ease-in-out}.popup ul{list-style-type:none;padding:0;margin:0}.dropdownItem{cursor:pointer}.rotate{transform:rotate(180deg)}.popup.ngIf{opacity:1}}.navbar-nav{visibility:visible!important;display:flex!important}.nav-link{text-transform:uppercase}\n"], dependencies: [{ kind: "directive", type: i1$1.LazyImgDirective, selector: "img" }, { kind: "directive", type: i2$4.RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
1846
1845
  }
1847
1846
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: ResourceHeaderComponent, decorators: [{
1848
1847
  type: Component,
1849
- args: [{ selector: 'pw-resource-header', template: "<nav class=\"navbar navbar-expand-lg navbar-dark fixed-top cloudolive-nav-bg-color\" id=\"banner\">\n <div class=\"container container-wrapper banner-section d-flex justify-content-between align-items-center\">\n\n <!-- Mobile: Logo Left, Toggler Right -->\n <div class=\"d-flex align-items-center justify-content-between w-100 d-lg-none\">\n <button class=\"navbar-toggler header-menu-bar\" type=\"button\" aria-label=\"Toggle navigation\" data-bs-toggle=\"collapse\" data-bs-target=\"#collapsibleNavbar\">\n <img src=\"/assets/img/products/trial/navbar-toggle-icon.png\" class=\"img-fluid navbar-toggle-icon\" alt=\"\" />\n </button>\n <div class=\"mb-icon\">\n <img [src]=\"logo\" routerLink=\"/\" alt=\"logo\" class=\"img-fluid logo-img\" />\n </div>\n </div>\n\n <!-- Desktop: Logo Left -->\n <div class=\"d-none d-lg-block mb-1 mt-1\">\n <img [src]=\"logo\" routerLink=\"/\" alt=\"logo\" class=\"img-fluid logo-img header-logo\" />\n </div>\n\n <!-- Center nav links (currently hidden on desktop) -->\n <div class=\"collapse navbar-collapse justify-content-center\" id=\"collapsibleNavbar\" #collapsibleNavbar>\n <ul #anchorLinks class=\"navbar-nav flex gap-4 me-0 wow fadeInUp position-relative\" data-wow-duration=\"2s\">\n <!-- Mobile Login Button -->\n <li class=\"nav-item lg-ms-2 mb-3 d-flex d-lg-none nav-item mt-3 md-mt-0\">\n <button class=\"sign-btn sign-header-btn\" routerLink=\"/login\">Log In</button>\n </li>\n </ul>\n </div>\n\n <!-- Desktop Login Button -->\n <div class=\"d-none d-lg-block mt-1 mb-1\">\n <button class=\"sign-btn sign-header-btn\" routerLink=\"/login\">Log In</button>\n </div>\n\n </div>\n</nav>\n", styles: ["@import\"https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;1,100;1,200;1,300;1,400;1,500;1,600;1,700&display=swap\";:root{--first: rgb(23 105 225);--second: rgb(54 194 131);--third: rgb(255 171 0);--text: rgb(34 34 34);--tabs_bg: rgb(23 105 225);--tabs_sub_bg: rgb(70, 136, 236);--tabs_text: rgb(255 255 255);--titles: rgb(34 34 34);--sidebar_bg: rgb(0, 48, 63);--sidebar_text: rgb(255 255 255)}*{font-family:Montserrat,sans-serif}h2{font-size:32px;font-weight:700;letter-spacing:.03em;line-height:1.1em;text-transform:uppercase}@media (max-width: 1200px){.container-wrapper{padding:0 20px!important}}@media screen and (max-width: 991px){.header-menu-bar{background-color:var(--first);background-image:none;border:1px solid rgb(255,255,255);border-radius:4px;display:block!important;float:right;margin-top:4px;padding:9px 10px;position:relative}}.navbar-custom-background{background-color:#00000080;box-shadow:2px 2px 15px 2px #0000001f;transition:width 2s,height 2s,-webkit-transform 2s;transition:width 2s,height 2s,transform 2s background-color .5s ease;z-index:9999}.fixed-top{position:fixed!important}.primary-button{background-color:#000;border-radius:50px;color:#fff;font: 600 16.3px Montserrat-Regular,sans-serif;padding:5px 16px!important;width:auto;display:flex;gap:15px;align-items:center;justify-content:space-between}.nav-link{color:#000!important;transition:color .3s ease}.nav-link.scrolled-nav-link{color:#fff!important}.navbar-nav{visibility:visible!important}.navbar-nav .nav-item .nav-link{color:#fff;font-size:18px;font-weight:500;letter-spacing:1px;padding:1.1em 1em!important}.navbar-toggle-icon{width:25px}.d-flex img{margin-right:0!important}@media (min-width: 500px){.navbar-nav .nav-item button{margin-top:10px}}@media (max-width: 1200px){.navbar-nav .nav-item .nav-link{font-size:15px!important}}@media (min-width: 1200px){.navbar-nav .nav-item .nav-link{padding-bottom:0!important;padding-top:1.8rem!important}.popup{top:5.4rem!important;background-color:var(--first)!important;left:0;padding:10px;z-index:1000;transition:opacity .3s ease-in-out}.popup ul li{color:#fff;font: 500 14px Montserrat-Regular,sans-serif;cursor:pointer;border-bottom:1px solid #eee}.popup ul li:last-child{border-bottom:none}.router-link-active{color:#000!important}}@media (max-width: 1200px){.popup ul li{color:#fff;font: 500 14px Montserrat-Regular,sans-serif;cursor:pointer;border-bottom:1px solid #eee}.popup ul li:last-child{border-bottom:none}.popup ul li:hover{background-color:#f1f1f1}.mb-icon{width:200px}.container-wrapper{padding:0 20px!important}.popup{top:0%!important;background-color:var(--first)!important;left:10rem;padding:10px;z-index:1000;transition:opacity .3s ease-in-out}}@media (max-width: 991px){.navbar-nav{color:#fff;margin-top:5px;z-index:1}.navbar-nav .nav-item .nav-link{font-size:100%;font-weight:500;padding:.7em 1em!important}}.popup{top:90%;background-color:transparent;padding:10px;z-index:1000}.popup ul{list-style-type:none;padding:0;margin:0}.popup ul li{padding:5px 10px;font: 500 14px Montserrat-Regular,sans-serif}.rotate{transform:rotate(180deg)}@media (max-width: 991px){.logo-img{width:70%!important;margin-left:auto;margin-right:0;display:block;transition:margin .5s ease,width .5s ease}.navbar-nav{color:#fff;margin-top:5px;z-index:1}.navbar-nav .nav-item .nav-link{font-size:100%;font-weight:500;padding:.7em 1em!important}.popup{top:0%!important;background-color:var(--first)!important;left:10rem;padding:10px;opacity:1;z-index:1000;transition:opacity .3s ease-in-out}.popup ul{list-style-type:none;padding:0;margin:0}.rotate{transform:rotate(180deg)}}.logo-img{height:auto!important;width:auto;max-height:40px;max-width:100%;object-fit:contain}@media (min-width: 992px){.banner-section{padding:0 40px}.sign-header-btn{color:#fff;font-weight:700;border:none;border-radius:999px;padding:8px 24px;width:142px;margin-right:.5rem;height:40px}}\n"] }]
1848
+ args: [{ selector: 'pw-resource-header', template: "<nav class=\"navbar navbar-expand-md navbar-dark fixed-top cloudolive-nav-bg-color\"\n id=\"banner\">\n <div class=\"container container-wrapper banner-section\">\n <!-- Toggler/collapsibe Button -->\n <button class=\"navbar-toggler header-menu-bar\"\n type=\"button\"\n aria-label=\"Toggle navigation\"\n data-bs-toggle=\"collapse\"\n data-bs-target=\"#collapsibleNavbar\">\n <img src=\"/assets/img/products/trial/navbar-toggle-icon.png\"\n class=\"img-fluid navbar-toggle-icon\"\n alt=\"\" />\n </button>\n\n <!-- Mobile Logo -->\n <div class=\"d-md-none mb-icon\">\n <div>\n <img [src]=\"logo\"\n routerLink=\"/\"\n alt=\"logo\"\n class=\"img-fluid logo_img\" />\n </div>\n </div>\n\n <!-- Navbar links -->\n <div class=\"collapse navbar-collapse mt-3 mt-md-0\"\n id=\"collapsibleNavbar\"\n #collapsibleNavbar>\n <div class=\"row align-items-center w-100\">\n\n <!-- Always occupy 3 columns for logo -->\n <div class=\"col-md-3 d-none d-md-flex align-items-center\">\n <div *ngIf=\"logo\">\n <img [src]=\"logo\"\n (load)=\"logoLoaded = true\"\n (error)=\"logoLoaded = false\"\n routerLink=\"/\"\n alt=\"logo\"\n class=\"img-fluid logo_img\" />\n </div>\n </div>\n\n <div class=\"col-md-6 d-flex justify-content-start\">\n <ul #anchorLinks\n class=\"navbar-nav flex gap-4 me-0 wow fadeInUp position-relative\"\n data-wow-duration=\"2s\">\n <li class=\"nav-item\" *ngFor=\"let item of navbarItems\">\n <a\n class=\"nav-link\"\n href=\"javascript:void(0)\"\n [ngClass]=\"{ 'scrolled-nav-link': isScrolled }\"\n (click)=\"item.subtitles?.length ? (item.open = !item.open) : null\"\n [attr.href]=\"!(item.subtitles?.length) ? item.path : null\"\n >\n {{ item?.title }}\n <i *ngIf=\"item.open\" class=\"fa-solid fa-caret-down\"></i>\n </a>\n <div class=\"popup position-absolute\"\n *ngIf=\"item.subtitles && item.open\">\n <ul>\n <li\n *ngFor=\"let sub of item.subtitles\"\n [routerLink]=\"sub.path\"\n class=\"dropdownItem\"\n >\n {{ sub.title }}\n </li>\n </ul>\n </div>\n </li>\n\n <li class=\"nav-item ms-2 mb-3 d-flex d-md-none\">\n <button class=\"sign-btn sign-header-btn\"\n routerLink=\"/login\">Log In</button>\n </li>\n </ul>\n </div>\n\n <!-- Always 3 columns for login -->\n <div class=\"col-md-3 d-none d-md-flex justify-content-end\">\n <button class=\"sign-btn sign-header-btn\"\n routerLink=\"/login\">Log In</button>\n </div>\n\n </div>\n </div>\n </div>\n</nav>\n", styles: ["@import\"https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;1,100;1,200;1,300;1,400;1,500;1,600;1,700&display=swap\";:root{--first: rgb(23 105 225);--second: rgb(54 194 131);--third: rgb(255 171 0);--text: rgb(34 34 34);--tabs_bg: rgb(23 105 225);--tabs_sub_bg: rgb(70, 136, 236);--tabs_text: rgb(255 255 255);--titles: rgb(34 34 34);--sidebar_bg: rgb(0, 48, 63);--sidebar_text: rgb(255 255 255)}*{font-family:Montserrat,sans-serif}h2{font-size:32px;font-weight:700;letter-spacing:.03em;line-height:1.1em;text-transform:uppercase}@media (max-width: 1200px){.container-wrapper{padding:0 20px!important}}.navbar-custom-background{background-color:#00000080;box-shadow:2px 2px 15px 2px #0000001f;transition:width 2s,height 2s,-webkit-transform 2s;transition:width 2s,height 2s,transform 2s background-color .5s ease;z-index:9999}.fixed-top{position:fixed!important}.primary-button{background-color:#000;border-radius:50px;color:#fff;font: 600 16.3px Montserrat-Regular,sans-serif;padding:5px 16px!important;width:auto;display:flex;gap:15px;align-items:center;justify-content:space-between}.navbar-nav .nav-item .nav-link{color:#fff;font-size:18px;font-weight:500;letter-spacing:1px;padding:1.1em 1em!important}.logo_img{width:60%!important}.navbar-toggle-icon{width:25px}@media (min-width: 500px){.navbar-nav .nav-item button{margin-top:10px}}@media (max-width: 1200px){.navbar-nav .nav-item .nav-link{font-size:15px!important}}.fa-caret-down{font-family:\"Font Awesome 6 Pro\";font-weight:900}@media (min-width: 1200px){.navbar-nav .nav-item .nav-link{padding-bottom:0!important;padding-top:0!important}.popup{top:3.4rem!important;background-color:var(--first)!important;left:0rem;background-color:transparent;padding:10px;z-index:1000;transition:opacity .3s ease-in-out}.popup ul li{color:#fff;font: 500 14px Montserrat-Regular,sans-serif;cursor:pointer;border-bottom:1px solid #eee}.popup ul li:last-child{border-bottom:none}.router-link-active{color:#000!important}}@media (max-width: 1200px){.popup ul li{color:#fff;font: 500 14px Montserrat-Regular,sans-serif;cursor:pointer;border-bottom:1px solid #eee}.popup ul li:last-child{border-bottom:none}.popup ul li:hover{background-color:#f1f1f1}.mb-icon{width:200px}.container-wrapper{padding:10px 20px!important}.popup{top:0%!important;background-color:var(--first)!important;left:10rem;background-color:transparent;padding:10px;z-index:1000;transition:opacity .3s ease-in-out}}@media (max-width: 500px){.navbar-nav{background-color:var(--first);border-top:3px solid rgb(254,209,54);color:#fff;margin-top:5px;z-index:1}.navbar-nav .nav-item .nav-link{font-size:100%;font-weight:500;padding:.7em 1em!important}}.popup{top:90%;background-color:transparent;padding:10px;z-index:1000}.popup ul{list-style-type:none;padding:0;margin:0}.popup ul li{padding:5px 10px;font: 500 14px Montserrat-Regular,sans-serif}.nav-link{color:#000!important;transition:color .3s ease}.nav-link.scrolled-nav-link{color:#fff!important}.dropdownItem{cursor:pointer}.rotate{transform:rotate(180deg)}@media (max-width: 500px){.logo_img{width:60%!important;margin-left:auto;margin-right:0;display:block;transition:margin .5s ease,width .5s ease}.navbar-nav{background-color:var(--first);border-top:3px solid rgb(254,209,54);color:#fff;margin-top:5px;z-index:1}.navbar-nav .nav-item .nav-link{font-size:100%;font-weight:500;padding:.7em 1em!important}.popup{top:0%!important;background-color:var(--first)!important;left:10rem;background-color:transparent;padding:10px;z-index:1000;transition:opacity .3s ease-in-out}.popup ul{list-style-type:none;padding:0;margin:0}.dropdownItem{cursor:pointer}.rotate{transform:rotate(180deg)}.popup.ngIf{opacity:1}}.navbar-nav{visibility:visible!important;display:flex!important}.nav-link{text-transform:uppercase}\n"] }]
1850
1849
  }], ctorParameters: () => [{ type: i0.Injector }, { type: Document, decorators: [{
1851
1850
  type: Inject,
1852
1851
  args: [DOCUMENT]