@byuhbll/components 4.6.1 → 4.7.0-beta.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/animations/animations.mjs +19 -1
- package/esm2022/lib/button/button.mjs +95 -0
- package/esm2022/lib/button-group/button-group.component.mjs +63 -0
- package/esm2022/lib/contact-utils.mjs +2 -2
- package/esm2022/lib/expand-collapse/expand-collapse.component.mjs +4 -4
- package/esm2022/lib/hbll-footer/hbll-footer.component.mjs +10 -9
- package/esm2022/lib/hbll-header/hbll-header.component.mjs +11 -24
- package/esm2022/lib/hbll-header/nav-bar-dropdown/nav-bar-dropdown.component.mjs +3 -3
- package/esm2022/lib/header-with-impersonation/header-with-impersonation.component.mjs +2 -2
- package/esm2022/lib/impersonation-banner/impersonation-banner.component.mjs +4 -4
- package/esm2022/lib/subatomic-components/button-group-item/button-group-item.component.mjs +29 -0
- package/esm2022/public-api.mjs +3 -1
- package/fesm2022/byuhbll-components.mjs +224 -41
- package/fesm2022/byuhbll-components.mjs.map +1 -1
- package/lib/animations/animations.d.ts +1 -0
- package/lib/button/button.d.ts +139 -0
- package/lib/button-group/button-group.component.d.ts +17 -0
- package/lib/contact-utils.d.ts +1 -1
- package/lib/hbll-footer/hbll-footer.component.d.ts +3 -3
- package/lib/hbll-header/hbll-header.component.d.ts +0 -2
- package/lib/impersonation-banner/impersonation-banner.component.d.ts +2 -2
- package/lib/subatomic-components/button-group-item/button-group-item.component.d.ts +18 -0
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
|
@@ -19,4 +19,22 @@ export const libHbllFadeIn = trigger('libHbllFadeIn', [
|
|
|
19
19
|
export const libHbllFadeOut = trigger('libHbllFadeOut', [
|
|
20
20
|
transition(':leave', [animate('.15s ease-out', style({ opacity: '0' }))]),
|
|
21
21
|
]);
|
|
22
|
-
|
|
22
|
+
export const libHbllSlideInOutRightLeft = trigger('libHbllSlideInOutRightLeft', [
|
|
23
|
+
transition(':enter', [
|
|
24
|
+
style({
|
|
25
|
+
transform: 'translateX({{xOffset}})',
|
|
26
|
+
}),
|
|
27
|
+
animate('200ms ease-in-out', style({
|
|
28
|
+
transform: 'translateX(0)',
|
|
29
|
+
})),
|
|
30
|
+
], { params: { xOffset: '100%' } }),
|
|
31
|
+
transition(':leave', [
|
|
32
|
+
style({
|
|
33
|
+
transform: 'translateX(0)',
|
|
34
|
+
}),
|
|
35
|
+
animate('200ms ease-in-out', style({
|
|
36
|
+
transform: 'translateX({{xOffset}})',
|
|
37
|
+
})),
|
|
38
|
+
], { params: { xOffset: '100%' } }),
|
|
39
|
+
]);
|
|
40
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5pbWF0aW9ucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudHMvc3JjL2xpYi9hbmltYXRpb25zL2FuaW1hdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNILE9BQU8sRUFDUCxVQUFVLEVBQ1YsT0FBTyxFQUNQLEtBQUssRUFDTCxLQUFLLEVBQ0wsS0FBSyxFQUNMLFlBQVksR0FDZixNQUFNLHFCQUFxQixDQUFDO0FBRTdCLE1BQU0sQ0FBQyxNQUFNLHFCQUFxQixHQUFHLE9BQU8sQ0FBQyx1QkFBdUIsRUFBRTtJQUNsRSxVQUFVLENBQUMsWUFBWSxFQUFFLEVBQUUsQ0FBQztJQUM1QixVQUFVLENBQ04sU0FBUyxFQUNUO1FBQ0ksS0FBSyxDQUFDO1lBQ0YsS0FBSyxDQUFDLEVBQUUsTUFBTSxFQUFFLG1CQUFtQixFQUFFLENBQUM7WUFDdEMsS0FBSyxDQUFDLElBQUksRUFBRSxDQUFDLFlBQVksRUFBRSxDQUFDLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLENBQUM7WUFDakQsT0FBTyxDQUFDLGtCQUFrQixDQUFDO1NBQzlCLENBQUM7S0FDTCxFQUNELEVBQUUsTUFBTSxFQUFFLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBRSxFQUFFLENBQ3JDO0NBQ0osQ0FBQyxDQUFDO0FBRUgsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQUcsT0FBTyxDQUFDLGtCQUFrQixFQUFFO0lBQ3hELFVBQVUsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxLQUFLLENBQUMsRUFBRSxPQUFPLEVBQUUsR0FBRyxFQUFFLENBQUMsRUFBRSxPQUFPLENBQUMsZUFBZSxDQUFDLENBQUMsQ0FBQztJQUN6RSxVQUFVLENBQUMsUUFBUSxFQUFFLENBQUMsT0FBTyxDQUFDLGVBQWUsRUFBRSxLQUFLLENBQUMsRUFBRSxPQUFPLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUM7Q0FDNUUsQ0FBQyxDQUFDO0FBRUgsTUFBTSxDQUFDLE1BQU0sYUFBYSxHQUFHLE9BQU8sQ0FBQyxlQUFlLEVBQUU7SUFDbEQsVUFBVSxDQUFDLFFBQVEsRUFBRSxDQUFDLEtBQUssQ0FBQyxFQUFFLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyxFQUFFLE9BQU8sQ0FBQyxlQUFlLENBQUMsQ0FBQyxDQUFDO0NBQzVFLENBQUMsQ0FBQztBQUVILE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRyxPQUFPLENBQUMsZ0JBQWdCLEVBQUU7SUFDcEQsVUFBVSxDQUFDLFFBQVEsRUFBRSxDQUFDLE9BQU8sQ0FBQyxlQUFlLEVBQUUsS0FBSyxDQUFDLEVBQUUsT0FBTyxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO0NBQzVFLENBQUMsQ0FBQztBQUVILE1BQU0sQ0FBQyxNQUFNLDBCQUEwQixHQUFHLE9BQU8sQ0FBQyw0QkFBNEIsRUFBRTtJQUM1RSxVQUFVLENBQ04sUUFBUSxFQUNSO1FBQ0ksS0FBSyxDQUFDO1lBQ0YsU0FBUyxFQUFFLHlCQUF5QjtTQUN2QyxDQUFDO1FBQ0YsT0FBTyxDQUNILG1CQUFtQixFQUNuQixLQUFLLENBQUM7WUFDRixTQUFTLEVBQUUsZUFBZTtTQUM3QixDQUFDLENBQ0w7S0FDSixFQUNELEVBQUUsTUFBTSxFQUFFLEVBQUUsT0FBTyxFQUFFLE1BQU0sRUFBRSxFQUFFLENBQ2xDO0lBQ0QsVUFBVSxDQUNOLFFBQVEsRUFDUjtRQUNJLEtBQUssQ0FBQztZQUNGLFNBQVMsRUFBRSxlQUFlO1NBQzdCLENBQUM7UUFDRixPQUFPLENBQ0gsbUJBQW1CLEVBQ25CLEtBQUssQ0FBQztZQUNGLFNBQVMsRUFBRSx5QkFBeUI7U0FDdkMsQ0FBQyxDQUNMO0tBQ0osRUFDRCxFQUFFLE1BQU0sRUFBRSxFQUFFLE9BQU8sRUFBRSxNQUFNLEVBQUUsRUFBRSxDQUNsQztDQUNKLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgdHJpZ2dlcixcbiAgICB0cmFuc2l0aW9uLFxuICAgIGFuaW1hdGUsXG4gICAgc3R5bGUsXG4gICAgZ3JvdXAsXG4gICAgcXVlcnksXG4gICAgYW5pbWF0ZUNoaWxkLFxufSBmcm9tICdAYW5ndWxhci9hbmltYXRpb25zJztcblxuZXhwb3J0IGNvbnN0IGxpYkhibGxFeHBhbmRDb2xsYXBzZSA9IHRyaWdnZXIoJ2xpYkhibGxFeHBhbmRDb2xsYXBzZScsIFtcbiAgICB0cmFuc2l0aW9uKCd2b2lkIDw9PiAqJywgW10pLFxuICAgIHRyYW5zaXRpb24oXG4gICAgICAgICcqIDw9PiAqJyxcbiAgICAgICAgW1xuICAgICAgICAgICAgZ3JvdXAoW1xuICAgICAgICAgICAgICAgIHN0eWxlKHsgaGVpZ2h0OiAne3tzdGFydEhlaWdodH19cHgnIH0pLFxuICAgICAgICAgICAgICAgIHF1ZXJ5KCdAKicsIFthbmltYXRlQ2hpbGQoKV0sIHsgb3B0aW9uYWw6IHRydWUgfSksXG4gICAgICAgICAgICAgICAgYW5pbWF0ZSgnLjE1cyBlYXNlLWluLW91dCcpLFxuICAgICAgICAgICAgXSksXG4gICAgICAgIF0sXG4gICAgICAgIHsgcGFyYW1zOiB7IHN0YXJ0SGVpZ2h0OiAnMHB4JyB9IH0sXG4gICAgKSxcbl0pO1xuXG5leHBvcnQgY29uc3QgbGliSGJsbEZhZGVJbk91dCA9IHRyaWdnZXIoJ2xpYkhibGxGYWRlSW5PdXQnLCBbXG4gICAgdHJhbnNpdGlvbignOmVudGVyJywgW3N0eWxlKHsgb3BhY2l0eTogJzAnIH0pLCBhbmltYXRlKCcuMTVzIGVhc2Utb3V0JyldKSxcbiAgICB0cmFuc2l0aW9uKCc6bGVhdmUnLCBbYW5pbWF0ZSgnLjE1cyBlYXNlLW91dCcsIHN0eWxlKHsgb3BhY2l0eTogJzAnIH0pKV0pLFxuXSk7XG5cbmV4cG9ydCBjb25zdCBsaWJIYmxsRmFkZUluID0gdHJpZ2dlcignbGliSGJsbEZhZGVJbicsIFtcbiAgICB0cmFuc2l0aW9uKCc6ZW50ZXInLCBbc3R5bGUoeyBvcGFjaXR5OiAnMCcgfSksIGFuaW1hdGUoJy4xNXMgZWFzZS1vdXQnKV0pLFxuXSk7XG5cbmV4cG9ydCBjb25zdCBsaWJIYmxsRmFkZU91dCA9IHRyaWdnZXIoJ2xpYkhibGxGYWRlT3V0JywgW1xuICAgIHRyYW5zaXRpb24oJzpsZWF2ZScsIFthbmltYXRlKCcuMTVzIGVhc2Utb3V0Jywgc3R5bGUoeyBvcGFjaXR5OiAnMCcgfSkpXSksXG5dKTtcblxuZXhwb3J0IGNvbnN0IGxpYkhibGxTbGlkZUluT3V0UmlnaHRMZWZ0ID0gdHJpZ2dlcignbGliSGJsbFNsaWRlSW5PdXRSaWdodExlZnQnLCBbXG4gICAgdHJhbnNpdGlvbihcbiAgICAgICAgJzplbnRlcicsXG4gICAgICAgIFtcbiAgICAgICAgICAgIHN0eWxlKHtcbiAgICAgICAgICAgICAgICB0cmFuc2Zvcm06ICd0cmFuc2xhdGVYKHt7eE9mZnNldH19KScsXG4gICAgICAgICAgICB9KSxcbiAgICAgICAgICAgIGFuaW1hdGUoXG4gICAgICAgICAgICAgICAgJzIwMG1zIGVhc2UtaW4tb3V0JyxcbiAgICAgICAgICAgICAgICBzdHlsZSh7XG4gICAgICAgICAgICAgICAgICAgIHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVgoMCknLFxuICAgICAgICAgICAgICAgIH0pLFxuICAgICAgICAgICAgKSxcbiAgICAgICAgXSxcbiAgICAgICAgeyBwYXJhbXM6IHsgeE9mZnNldDogJzEwMCUnIH0gfSxcbiAgICApLFxuICAgIHRyYW5zaXRpb24oXG4gICAgICAgICc6bGVhdmUnLFxuICAgICAgICBbXG4gICAgICAgICAgICBzdHlsZSh7XG4gICAgICAgICAgICAgICAgdHJhbnNmb3JtOiAndHJhbnNsYXRlWCgwKScsXG4gICAgICAgICAgICB9KSxcbiAgICAgICAgICAgIGFuaW1hdGUoXG4gICAgICAgICAgICAgICAgJzIwMG1zIGVhc2UtaW4tb3V0JyxcbiAgICAgICAgICAgICAgICBzdHlsZSh7XG4gICAgICAgICAgICAgICAgICAgIHRyYW5zZm9ybTogJ3RyYW5zbGF0ZVgoe3t4T2Zmc2V0fX0pJyxcbiAgICAgICAgICAgICAgICB9KSxcbiAgICAgICAgICAgICksXG4gICAgICAgIF0sXG4gICAgICAgIHsgcGFyYW1zOiB7IHhPZmZzZXQ6ICcxMDAlJyB9IH0sXG4gICAgKSxcbl0pO1xuIl19
|
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
import { Component, Input, Output, EventEmitter } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
/**
|
|
6
|
+
* A flexible, reusable button component that supports multiple button types
|
|
7
|
+
* and various content combinations (icon before, title, icon after).
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
* ```html
|
|
11
|
+
* <!-- Primary button with icon and title -->
|
|
12
|
+
* <app-hbll-button-custom-component
|
|
13
|
+
* buttonType="primary"
|
|
14
|
+
* title="Copy Citation"
|
|
15
|
+
* iconBefore="../../assets/copy.svg"
|
|
16
|
+
* iconAlt="Copy icon"
|
|
17
|
+
* (buttonClick)="copyCitation()">
|
|
18
|
+
* </app-hbll-button-custom-component>
|
|
19
|
+
*
|
|
20
|
+
* <!-- Secondary button with title only -->
|
|
21
|
+
* <app-hbll-button-custom-component
|
|
22
|
+
* buttonType="secondary"
|
|
23
|
+
* title="Cancel"
|
|
24
|
+
* (buttonClick)="cancelAction()">
|
|
25
|
+
* </app-hbll-button-custom-component>
|
|
26
|
+
*
|
|
27
|
+
* <!-- Transparent button with icon after title -->
|
|
28
|
+
* <app-hbll-button-custom-component
|
|
29
|
+
* buttonType="transparent"
|
|
30
|
+
* title="Download"
|
|
31
|
+
* iconAfter="../../assets/download.svg"
|
|
32
|
+
* iconAlt="Download icon"
|
|
33
|
+
* (buttonClick)="downloadFile()">
|
|
34
|
+
* </app-hbll-button-custom-component>
|
|
35
|
+
*
|
|
36
|
+
* <!-- Thin button with reduced padding -->
|
|
37
|
+
* <app-hbll-button-custom-component
|
|
38
|
+
* buttonType="primary"
|
|
39
|
+
* title="Submit"
|
|
40
|
+
* [isThin]="true"
|
|
41
|
+
* (buttonClick)="submitForm()">
|
|
42
|
+
* </app-hbll-button-custom-component>
|
|
43
|
+
* ```
|
|
44
|
+
*/
|
|
45
|
+
export class ButtonComponent {
|
|
46
|
+
constructor() {
|
|
47
|
+
/**
|
|
48
|
+
* The visual style of the button
|
|
49
|
+
* @default 'primary'
|
|
50
|
+
*/
|
|
51
|
+
this.buttonType = 'primary';
|
|
52
|
+
/**
|
|
53
|
+
* Whether the button is disabled
|
|
54
|
+
* @default false
|
|
55
|
+
*/
|
|
56
|
+
this.disabled = false;
|
|
57
|
+
/**
|
|
58
|
+
* Whether the button should have thin padding
|
|
59
|
+
* @default false
|
|
60
|
+
*/
|
|
61
|
+
this.isThin = false;
|
|
62
|
+
/**
|
|
63
|
+
* Event emitted when the button is clicked or activated via keyboard
|
|
64
|
+
*/
|
|
65
|
+
this.buttonClick = new EventEmitter();
|
|
66
|
+
}
|
|
67
|
+
onButtonClick() {
|
|
68
|
+
if (!this.disabled) {
|
|
69
|
+
this.buttonClick.emit();
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: ButtonComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
73
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.0", type: ButtonComponent, isStandalone: true, selector: "lib-button", inputs: { buttonType: "buttonType", title: "title", iconBefore: "iconBefore", iconAfter: "iconAfter", iconAlt: "iconAlt", disabled: "disabled", isThin: "isThin" }, outputs: { buttonClick: "buttonClick" }, ngImport: i0, template: "<button\n type=\"button\"\n [class]=\"'btn btn-' + buttonType + (isThin ? ' btn-thin' : '')\"\n [disabled]=\"disabled\"\n [attr.aria-label]=\"title || iconAlt\"\n (click)=\"onButtonClick()\"\n [attr.tabindex]=\"disabled ? -1 : 0\"\n>\n <!-- Icon before title -->\n <span class=\"icon icon-before\" *ngIf=\"iconBefore\">\n <img\n [src]=\"iconBefore\"\n [class]=\"\n disabled\n ? 'disabled-icon'\n : buttonType === 'primary'\n ? 'white-icon'\n : 'dark-icon'\n \"\n [alt]=\"iconAlt || ''\"\n />\n </span>\n\n <!-- Title text -->\n <span class=\"button-title\" *ngIf=\"title\">{{ title }}</span>\n\n <!-- Icon after title -->\n <span class=\"icon icon-after\" *ngIf=\"iconAfter\">\n <img\n [src]=\"iconAfter\"\n [class]=\"\n disabled\n ? 'disabled-icon'\n : buttonType === 'primary'\n ? 'white-icon'\n : 'dark-icon'\n \"\n [alt]=\"iconAlt || ''\"\n />\n </span>\n</button>\n", styles: [".btn{padding:.8rem 2rem;border-radius:.25rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;display:inline-flex;align-items:center;outline:none}.btn.btn-thin{padding:.4rem 2rem;border-radius:.5rem}.btn:disabled{cursor:not-allowed;color:#767676}.btn:disabled:not(.btn-transparent){background-color:#e7e7e7;border:1px solid #767676}.btn:focus{outline:.125rem solid #b967c7;outline-offset:.125rem}.btn .icon{display:flex;align-items:center;justify-content:center}.btn .icon img{height:1.5rem;width:auto}.btn .icon.icon-before{margin-right:.25rem}.btn .icon.icon-after{margin-left:.25rem}.btn .button-title{flex-shrink:0}.btn-primary{background-color:#0047ba;color:#fff;border:1px solid #0047ba}.btn-primary:hover:not(:disabled){background-color:#003995}.btn-secondary{background-color:#fff;color:#00245d;border:1px solid #0047ba}.btn-secondary:hover:not(:disabled){background-color:#e5edf8}.btn-transparent{background-color:transparent;color:#00245d}.btn-transparent:hover:not(:disabled){background-color:#e5edf8}.white-icon{filter:invert(100%) sepia(0%) saturate(7489%) hue-rotate(149deg) brightness(104%) contrast(100%)}.dark-icon{filter:invert(12%) sepia(44%) saturate(3863%) hue-rotate(207deg) brightness(90%) contrast(105%)}.disabled-icon{filter:invert(48%) sepia(0%) saturate(0%) hue-rotate(146deg) brightness(96%) contrast(88%)}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
|
|
74
|
+
}
|
|
75
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: ButtonComponent, decorators: [{
|
|
76
|
+
type: Component,
|
|
77
|
+
args: [{ selector: 'lib-button', standalone: true, imports: [CommonModule], template: "<button\n type=\"button\"\n [class]=\"'btn btn-' + buttonType + (isThin ? ' btn-thin' : '')\"\n [disabled]=\"disabled\"\n [attr.aria-label]=\"title || iconAlt\"\n (click)=\"onButtonClick()\"\n [attr.tabindex]=\"disabled ? -1 : 0\"\n>\n <!-- Icon before title -->\n <span class=\"icon icon-before\" *ngIf=\"iconBefore\">\n <img\n [src]=\"iconBefore\"\n [class]=\"\n disabled\n ? 'disabled-icon'\n : buttonType === 'primary'\n ? 'white-icon'\n : 'dark-icon'\n \"\n [alt]=\"iconAlt || ''\"\n />\n </span>\n\n <!-- Title text -->\n <span class=\"button-title\" *ngIf=\"title\">{{ title }}</span>\n\n <!-- Icon after title -->\n <span class=\"icon icon-after\" *ngIf=\"iconAfter\">\n <img\n [src]=\"iconAfter\"\n [class]=\"\n disabled\n ? 'disabled-icon'\n : buttonType === 'primary'\n ? 'white-icon'\n : 'dark-icon'\n \"\n [alt]=\"iconAlt || ''\"\n />\n </span>\n</button>\n", styles: [".btn{padding:.8rem 2rem;border-radius:.25rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none;display:inline-flex;align-items:center;outline:none}.btn.btn-thin{padding:.4rem 2rem;border-radius:.5rem}.btn:disabled{cursor:not-allowed;color:#767676}.btn:disabled:not(.btn-transparent){background-color:#e7e7e7;border:1px solid #767676}.btn:focus{outline:.125rem solid #b967c7;outline-offset:.125rem}.btn .icon{display:flex;align-items:center;justify-content:center}.btn .icon img{height:1.5rem;width:auto}.btn .icon.icon-before{margin-right:.25rem}.btn .icon.icon-after{margin-left:.25rem}.btn .button-title{flex-shrink:0}.btn-primary{background-color:#0047ba;color:#fff;border:1px solid #0047ba}.btn-primary:hover:not(:disabled){background-color:#003995}.btn-secondary{background-color:#fff;color:#00245d;border:1px solid #0047ba}.btn-secondary:hover:not(:disabled){background-color:#e5edf8}.btn-transparent{background-color:transparent;color:#00245d}.btn-transparent:hover:not(:disabled){background-color:#e5edf8}.white-icon{filter:invert(100%) sepia(0%) saturate(7489%) hue-rotate(149deg) brightness(104%) contrast(100%)}.dark-icon{filter:invert(12%) sepia(44%) saturate(3863%) hue-rotate(207deg) brightness(90%) contrast(105%)}.disabled-icon{filter:invert(48%) sepia(0%) saturate(0%) hue-rotate(146deg) brightness(96%) contrast(88%)}\n"] }]
|
|
78
|
+
}], propDecorators: { buttonType: [{
|
|
79
|
+
type: Input
|
|
80
|
+
}], title: [{
|
|
81
|
+
type: Input
|
|
82
|
+
}], iconBefore: [{
|
|
83
|
+
type: Input
|
|
84
|
+
}], iconAfter: [{
|
|
85
|
+
type: Input
|
|
86
|
+
}], iconAlt: [{
|
|
87
|
+
type: Input
|
|
88
|
+
}], disabled: [{
|
|
89
|
+
type: Input
|
|
90
|
+
}], isThin: [{
|
|
91
|
+
type: Input
|
|
92
|
+
}], buttonClick: [{
|
|
93
|
+
type: Output
|
|
94
|
+
}] } });
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.js","sourceRoot":"","sources":["../../../../../projects/components/src/lib/button/button.ts","../../../../../projects/components/src/lib/button/button.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AACvE,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;;;AA+D/C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAuCG;AAQH,MAAM,OAAO,eAAe;IAP5B;QAQI;;;WAGG;QACM,eAAU,GAAe,SAAS,CAAC;QA0B5C;;;WAGG;QACM,aAAQ,GAAY,KAAK,CAAC;QAEnC;;;WAGG;QACM,WAAM,GAAY,KAAK,CAAC;QAEjC;;WAEG;QACO,gBAAW,GAAG,IAAI,YAAY,EAAQ,CAAC;KAOpD;IALG,aAAa;QACT,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACjB,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC;QAC5B,CAAC;IACL,CAAC;8GApDQ,eAAe;kGAAf,eAAe,mRC/G5B,glCAyCA,k5CDkEc,YAAY;;2FAIb,eAAe;kBAP3B,SAAS;+BACI,YAAY,cACV,IAAI,WACP,CAAC,YAAY,CAAC;8BASd,UAAU;sBAAlB,KAAK;gBAMG,KAAK;sBAAb,KAAK;gBAMG,UAAU;sBAAlB,KAAK;gBAMG,SAAS;sBAAjB,KAAK;gBAMG,OAAO;sBAAf,KAAK;gBAMG,QAAQ;sBAAhB,KAAK;gBAMG,MAAM;sBAAd,KAAK;gBAKI,WAAW;sBAApB,MAAM","sourcesContent":["import { Component, Input, Output, EventEmitter } from '@angular/core';\nimport { CommonModule } from '@angular/common';\n\nexport type ButtonType = 'primary' | 'secondary' | 'transparent';\n\n/**\n * Interface representing all input properties for the ButtonComponent.\n * Use this when a parent component needs to accept button configuration as a parameter.\n *\n * @example\n * ```typescript\n * export class ParentComponent {\n *   @Input() buttonConfig: ButtonInputs = {\n *     buttonType: 'primary',\n *     title: 'Click Me',\n *     disabled: false\n *   };\n * }\n * ```\n */\nexport interface ButtonInputs {\n    /**\n     * The visual style of the button\n     * @default 'primary'\n     */\n    buttonType?: ButtonType;\n\n    /**\n     * The text content displayed on the button\n     * @optional\n     */\n    title?: string;\n\n    /**\n     * Path to an icon image displayed before the title\n     * @optional\n     */\n    iconBefore?: string;\n\n    /**\n     * Path to an icon image displayed after the title\n     * @optional\n     */\n    iconAfter?: string;\n\n    /**\n     * Alternative text for icon accessibility\n     * @optional\n     */\n    iconAlt?: string;\n\n    /**\n     * Whether the button is disabled\n     * @default false\n     */\n    disabled?: boolean;\n\n    /**\n     * Whether the button should have thin padding\n     * @default false\n     */\n    isThin?: boolean;\n}\n\n/**\n * A flexible, reusable button component that supports multiple button types\n * and various content combinations (icon before, title, icon after).\n *\n * @example\n * ```html\n * <!-- Primary button with icon and title -->\n * <app-hbll-button-custom-component\n *   buttonType=\"primary\"\n *   title=\"Copy Citation\"\n *   iconBefore=\"../../assets/copy.svg\"\n *   iconAlt=\"Copy icon\"\n *   (buttonClick)=\"copyCitation()\">\n * </app-hbll-button-custom-component>\n *\n * <!-- Secondary button with title only -->\n * <app-hbll-button-custom-component\n *   buttonType=\"secondary\"\n *   title=\"Cancel\"\n *   (buttonClick)=\"cancelAction()\">\n * </app-hbll-button-custom-component>\n *\n * <!-- Transparent button with icon after title -->\n * <app-hbll-button-custom-component\n *   buttonType=\"transparent\"\n *   title=\"Download\"\n *   iconAfter=\"../../assets/download.svg\"\n *   iconAlt=\"Download icon\"\n *   (buttonClick)=\"downloadFile()\">\n * </app-hbll-button-custom-component>\n *\n * <!-- Thin button with reduced padding -->\n * <app-hbll-button-custom-component\n *   buttonType=\"primary\"\n *   title=\"Submit\"\n *   [isThin]=\"true\"\n *   (buttonClick)=\"submitForm()\">\n * </app-hbll-button-custom-component>\n * ```\n */\n@Component({\n    selector: 'lib-button',\n    standalone: true,\n    imports: [CommonModule],\n    templateUrl: './button.html',\n    styleUrl: './button.scss',\n})\nexport class ButtonComponent {\n    /**\n     * The visual style of the button\n     * @default 'primary'\n     */\n    @Input() buttonType: ButtonType = 'primary';\n\n    /**\n     * The text content displayed on the button\n     * @optional\n     */\n    @Input() title?: string;\n\n    /**\n     * Path to an icon image displayed before the title\n     * @optional\n     */\n    @Input() iconBefore?: string;\n\n    /**\n     * Path to an icon image displayed after the title\n     * @optional\n     */\n    @Input() iconAfter?: string;\n\n    /**\n     * Alternative text for icon accessibility\n     * @optional\n     */\n    @Input() iconAlt?: string;\n\n    /**\n     * Whether the button is disabled\n     * @default false\n     */\n    @Input() disabled: boolean = false;\n\n    /**\n     * Whether the button should have thin padding\n     * @default false\n     */\n    @Input() isThin: boolean = false;\n\n    /**\n     * Event emitted when the button is clicked or activated via keyboard\n     */\n    @Output() buttonClick = new EventEmitter<void>();\n\n    onButtonClick(): void {\n        if (!this.disabled) {\n            this.buttonClick.emit();\n        }\n    }\n}\n","<button\n    type=\"button\"\n    [class]=\"'btn btn-' + buttonType + (isThin ? ' btn-thin' : '')\"\n    [disabled]=\"disabled\"\n    [attr.aria-label]=\"title || iconAlt\"\n    (click)=\"onButtonClick()\"\n    [attr.tabindex]=\"disabled ? -1 : 0\"\n>\n    <!-- Icon before title -->\n    <span class=\"icon icon-before\" *ngIf=\"iconBefore\">\n        <img\n            [src]=\"iconBefore\"\n            [class]=\"\n        disabled\n          ? 'disabled-icon'\n          : buttonType === 'primary'\n          ? 'white-icon'\n          : 'dark-icon'\n      \"\n            [alt]=\"iconAlt || ''\"\n        />\n    </span>\n\n    <!-- Title text -->\n    <span class=\"button-title\" *ngIf=\"title\">{{ title }}</span>\n\n    <!-- Icon after title -->\n    <span class=\"icon icon-after\" *ngIf=\"iconAfter\">\n        <img\n            [src]=\"iconAfter\"\n            [class]=\"\n        disabled\n          ? 'disabled-icon'\n          : buttonType === 'primary'\n          ? 'white-icon'\n          : 'dark-icon'\n      \"\n            [alt]=\"iconAlt || ''\"\n        />\n    </span>\n</button>\n"]}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { Component, Input, Output, EventEmitter, signal, } from '@angular/core';
|
|
2
|
+
import { ButtonGroupItemComponent, } from '../subatomic-components/button-group-item/button-group-item.component';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
export class ButtonGroupComponent {
|
|
5
|
+
constructor() {
|
|
6
|
+
// Input: Whether the button group is disabled
|
|
7
|
+
this.disabled = false;
|
|
8
|
+
// Output: Emits the id of the active button when changed
|
|
9
|
+
this.activeButtonChange = new EventEmitter();
|
|
10
|
+
// Internal state: Currently active button id
|
|
11
|
+
this.activeButtonId = signal('');
|
|
12
|
+
}
|
|
13
|
+
ngOnInit() {
|
|
14
|
+
this.initializeActiveButton();
|
|
15
|
+
}
|
|
16
|
+
ngOnChanges(changes) {
|
|
17
|
+
// When buttons or initialActiveId change (important for web components)
|
|
18
|
+
if (changes['buttons'] || changes['initialActiveId']) {
|
|
19
|
+
this.initializeActiveButton();
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
initializeActiveButton() {
|
|
23
|
+
// Set initial active button
|
|
24
|
+
const initial = this.initialActiveId;
|
|
25
|
+
if (initial) {
|
|
26
|
+
this.activeButtonId.set(initial);
|
|
27
|
+
}
|
|
28
|
+
else {
|
|
29
|
+
// Find the first active button from the config
|
|
30
|
+
const activeButton = this.buttons?.find((btn) => btn.isActive);
|
|
31
|
+
if (activeButton) {
|
|
32
|
+
this.activeButtonId.set(activeButton.id);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
// Handle button click
|
|
37
|
+
onButtonClick(buttonId) {
|
|
38
|
+
if (!this.disabled) {
|
|
39
|
+
this.activeButtonId.set(buttonId);
|
|
40
|
+
this.activeButtonChange.emit(buttonId);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
// Check if a button is active
|
|
44
|
+
isButtonActive(buttonId) {
|
|
45
|
+
return this.activeButtonId() === buttonId;
|
|
46
|
+
}
|
|
47
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: ButtonGroupComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
48
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: ButtonGroupComponent, isStandalone: true, selector: "lib-button-group", inputs: { buttons: "buttons", initialActiveId: "initialActiveId", disabled: "disabled" }, outputs: { activeButtonChange: "activeButtonChange" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"button-group\" role=\"tablist\">\n @for (button of buttons; track button.id) {\n <lib-button-group-item\n [button]=\"button\"\n [isActive]=\"isButtonActive(button.id)\"\n [disabled]=\"disabled\"\n (buttonClick)=\"onButtonClick($event)\"\n class=\"button-group-item\"\n />\n }\n</div>\n", styles: [".button-group{display:flex}.button-group lib-button-group-item:first-child::ng-deep .tab-btn{border-radius:.25rem 0 0 .25rem;border-left:1px solid #d0d0d0}.button-group lib-button-group-item:first-child::ng-deep .tab-btn:disabled{border-left:1px solid #767676}.button-group lib-button-group-item:last-child::ng-deep .tab-btn{border-radius:0 .25rem .25rem 0}@media (max-width: 640px){.button-group{overflow-x:auto;-webkit-overflow-scrolling:touch}}\n"], dependencies: [{ kind: "component", type: ButtonGroupItemComponent, selector: "lib-button-group-item", inputs: ["button", "isActive", "disabled"], outputs: ["buttonClick"] }] }); }
|
|
49
|
+
}
|
|
50
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: ButtonGroupComponent, decorators: [{
|
|
51
|
+
type: Component,
|
|
52
|
+
args: [{ selector: 'lib-button-group', standalone: true, imports: [ButtonGroupItemComponent], template: "<div class=\"button-group\" role=\"tablist\">\n @for (button of buttons; track button.id) {\n <lib-button-group-item\n [button]=\"button\"\n [isActive]=\"isButtonActive(button.id)\"\n [disabled]=\"disabled\"\n (buttonClick)=\"onButtonClick($event)\"\n class=\"button-group-item\"\n />\n }\n</div>\n", styles: [".button-group{display:flex}.button-group lib-button-group-item:first-child::ng-deep .tab-btn{border-radius:.25rem 0 0 .25rem;border-left:1px solid #d0d0d0}.button-group lib-button-group-item:first-child::ng-deep .tab-btn:disabled{border-left:1px solid #767676}.button-group lib-button-group-item:last-child::ng-deep .tab-btn{border-radius:0 .25rem .25rem 0}@media (max-width: 640px){.button-group{overflow-x:auto;-webkit-overflow-scrolling:touch}}\n"] }]
|
|
53
|
+
}], propDecorators: { buttons: [{
|
|
54
|
+
type: Input,
|
|
55
|
+
args: [{ required: true }]
|
|
56
|
+
}], initialActiveId: [{
|
|
57
|
+
type: Input
|
|
58
|
+
}], disabled: [{
|
|
59
|
+
type: Input
|
|
60
|
+
}], activeButtonChange: [{
|
|
61
|
+
type: Output
|
|
62
|
+
}] } });
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnV0dG9uLWdyb3VwLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudHMvc3JjL2xpYi9idXR0b24tZ3JvdXAvYnV0dG9uLWdyb3VwLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudHMvc3JjL2xpYi9idXR0b24tZ3JvdXAvYnV0dG9uLWdyb3VwLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDSCxTQUFTLEVBQ1QsS0FBSyxFQUNMLE1BQU0sRUFDTixZQUFZLEVBQ1osTUFBTSxHQUlULE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFFSCx3QkFBd0IsR0FDM0IsTUFBTSx1RUFBdUUsQ0FBQzs7QUFTL0UsTUFBTSxPQUFPLG9CQUFvQjtJQVBqQztRQWNJLDhDQUE4QztRQUNyQyxhQUFRLEdBQVksS0FBSyxDQUFDO1FBRW5DLHlEQUF5RDtRQUMvQyx1QkFBa0IsR0FBRyxJQUFJLFlBQVksRUFBVSxDQUFDO1FBRTFELDZDQUE2QztRQUM3QyxtQkFBYyxHQUFHLE1BQU0sQ0FBUyxFQUFFLENBQUMsQ0FBQztLQXVDdkM7SUFyQ0csUUFBUTtRQUNKLElBQUksQ0FBQyxzQkFBc0IsRUFBRSxDQUFDO0lBQ2xDLENBQUM7SUFFRCxXQUFXLENBQUMsT0FBc0I7UUFDOUIsd0VBQXdFO1FBQ3hFLElBQUksT0FBTyxDQUFDLFNBQVMsQ0FBQyxJQUFJLE9BQU8sQ0FBQyxpQkFBaUIsQ0FBQyxFQUFFLENBQUM7WUFDbkQsSUFBSSxDQUFDLHNCQUFzQixFQUFFLENBQUM7UUFDbEMsQ0FBQztJQUNMLENBQUM7SUFFTyxzQkFBc0I7UUFDMUIsNEJBQTRCO1FBQzVCLE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxlQUFlLENBQUM7UUFDckMsSUFBSSxPQUFPLEVBQUUsQ0FBQztZQUNWLElBQUksQ0FBQyxjQUFjLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ3JDLENBQUM7YUFBTSxDQUFDO1lBQ0osK0NBQStDO1lBQy9DLE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUUsQ0FBQyxHQUFHLENBQUMsUUFBUSxDQUFDLENBQUM7WUFDL0QsSUFBSSxZQUFZLEVBQUUsQ0FBQztnQkFDZixJQUFJLENBQUMsY0FBYyxDQUFDLEdBQUcsQ0FBQyxZQUFZLENBQUMsRUFBRSxDQUFDLENBQUM7WUFDN0MsQ0FBQztRQUNMLENBQUM7SUFDTCxDQUFDO0lBRUQsc0JBQXNCO0lBQ3RCLGFBQWEsQ0FBQyxRQUFnQjtRQUMxQixJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRSxDQUFDO1lBQ2pCLElBQUksQ0FBQyxjQUFjLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxDQUFDO1lBQ2xDLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDM0MsQ0FBQztJQUNMLENBQUM7SUFFRCw4QkFBOEI7SUFDOUIsY0FBYyxDQUFDLFFBQWdCO1FBQzNCLE9BQU8sSUFBSSxDQUFDLGNBQWMsRUFBRSxLQUFLLFFBQVEsQ0FBQztJQUM5QyxDQUFDOzhHQXBEUSxvQkFBb0I7a0dBQXBCLG9CQUFvQixrUEN0QmpDLHVYQVdBLDJmRE9jLHdCQUF3Qjs7MkZBSXpCLG9CQUFvQjtrQkFQaEMsU0FBUzsrQkFDSSxrQkFBa0IsY0FDaEIsSUFBSSxXQUNQLENBQUMsd0JBQXdCLENBQUM7OEJBTVIsT0FBTztzQkFBakMsS0FBSzt1QkFBQyxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUU7Z0JBR2hCLGVBQWU7c0JBQXZCLEtBQUs7Z0JBR0csUUFBUTtzQkFBaEIsS0FBSztnQkFHSSxrQkFBa0I7c0JBQTNCLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICAgIENvbXBvbmVudCxcbiAgICBJbnB1dCxcbiAgICBPdXRwdXQsXG4gICAgRXZlbnRFbWl0dGVyLFxuICAgIHNpZ25hbCxcbiAgICBPbkluaXQsXG4gICAgT25DaGFuZ2VzLFxuICAgIFNpbXBsZUNoYW5nZXMsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtcbiAgICBCdXR0b25Db25maWcsXG4gICAgQnV0dG9uR3JvdXBJdGVtQ29tcG9uZW50LFxufSBmcm9tICcuLi9zdWJhdG9taWMtY29tcG9uZW50cy9idXR0b24tZ3JvdXAtaXRlbS9idXR0b24tZ3JvdXAtaXRlbS5jb21wb25lbnQnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2xpYi1idXR0b24tZ3JvdXAnLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaW1wb3J0czogW0J1dHRvbkdyb3VwSXRlbUNvbXBvbmVudF0sXG4gICAgdGVtcGxhdGVVcmw6ICcuL2J1dHRvbi1ncm91cC5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmw6ICcuL2J1dHRvbi1ncm91cC5jb21wb25lbnQuc2NzcycsXG59KVxuZXhwb3J0IGNsYXNzIEJ1dHRvbkdyb3VwQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkNoYW5nZXMge1xuICAgIC8vIElucHV0OiBBcnJheSBvZiBidXR0b24gY29uZmlndXJhdGlvbnNcbiAgICBASW5wdXQoeyByZXF1aXJlZDogdHJ1ZSB9KSBidXR0b25zITogQnV0dG9uQ29uZmlnW107XG5cbiAgICAvLyBJbnB1dDogT3B0aW9uYWwgaW5pdGlhbCBhY3RpdmUgYnV0dG9uIGlkXG4gICAgQElucHV0KCkgaW5pdGlhbEFjdGl2ZUlkPzogc3RyaW5nO1xuXG4gICAgLy8gSW5wdXQ6IFdoZXRoZXIgdGhlIGJ1dHRvbiBncm91cCBpcyBkaXNhYmxlZFxuICAgIEBJbnB1dCgpIGRpc2FibGVkOiBib29sZWFuID0gZmFsc2U7XG5cbiAgICAvLyBPdXRwdXQ6IEVtaXRzIHRoZSBpZCBvZiB0aGUgYWN0aXZlIGJ1dHRvbiB3aGVuIGNoYW5nZWRcbiAgICBAT3V0cHV0KCkgYWN0aXZlQnV0dG9uQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxzdHJpbmc+KCk7XG5cbiAgICAvLyBJbnRlcm5hbCBzdGF0ZTogQ3VycmVudGx5IGFjdGl2ZSBidXR0b24gaWRcbiAgICBhY3RpdmVCdXR0b25JZCA9IHNpZ25hbDxzdHJpbmc+KCcnKTtcblxuICAgIG5nT25Jbml0KCk6IHZvaWQge1xuICAgICAgICB0aGlzLmluaXRpYWxpemVBY3RpdmVCdXR0b24oKTtcbiAgICB9XG5cbiAgICBuZ09uQ2hhbmdlcyhjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKTogdm9pZCB7XG4gICAgICAgIC8vIFdoZW4gYnV0dG9ucyBvciBpbml0aWFsQWN0aXZlSWQgY2hhbmdlIChpbXBvcnRhbnQgZm9yIHdlYiBjb21wb25lbnRzKVxuICAgICAgICBpZiAoY2hhbmdlc1snYnV0dG9ucyddIHx8IGNoYW5nZXNbJ2luaXRpYWxBY3RpdmVJZCddKSB7XG4gICAgICAgICAgICB0aGlzLmluaXRpYWxpemVBY3RpdmVCdXR0b24oKTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIHByaXZhdGUgaW5pdGlhbGl6ZUFjdGl2ZUJ1dHRvbigpOiB2b2lkIHtcbiAgICAgICAgLy8gU2V0IGluaXRpYWwgYWN0aXZlIGJ1dHRvblxuICAgICAgICBjb25zdCBpbml0aWFsID0gdGhpcy5pbml0aWFsQWN0aXZlSWQ7XG4gICAgICAgIGlmIChpbml0aWFsKSB7XG4gICAgICAgICAgICB0aGlzLmFjdGl2ZUJ1dHRvbklkLnNldChpbml0aWFsKTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIC8vIEZpbmQgdGhlIGZpcnN0IGFjdGl2ZSBidXR0b24gZnJvbSB0aGUgY29uZmlnXG4gICAgICAgICAgICBjb25zdCBhY3RpdmVCdXR0b24gPSB0aGlzLmJ1dHRvbnM/LmZpbmQoKGJ0bikgPT4gYnRuLmlzQWN0aXZlKTtcbiAgICAgICAgICAgIGlmIChhY3RpdmVCdXR0b24pIHtcbiAgICAgICAgICAgICAgICB0aGlzLmFjdGl2ZUJ1dHRvbklkLnNldChhY3RpdmVCdXR0b24uaWQpO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgfVxuXG4gICAgLy8gSGFuZGxlIGJ1dHRvbiBjbGlja1xuICAgIG9uQnV0dG9uQ2xpY2soYnV0dG9uSWQ6IHN0cmluZyk6IHZvaWQge1xuICAgICAgICBpZiAoIXRoaXMuZGlzYWJsZWQpIHtcbiAgICAgICAgICAgIHRoaXMuYWN0aXZlQnV0dG9uSWQuc2V0KGJ1dHRvbklkKTtcbiAgICAgICAgICAgIHRoaXMuYWN0aXZlQnV0dG9uQ2hhbmdlLmVtaXQoYnV0dG9uSWQpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgLy8gQ2hlY2sgaWYgYSBidXR0b24gaXMgYWN0aXZlXG4gICAgaXNCdXR0b25BY3RpdmUoYnV0dG9uSWQ6IHN0cmluZyk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gdGhpcy5hY3RpdmVCdXR0b25JZCgpID09PSBidXR0b25JZDtcbiAgICB9XG59XG4iLCI8ZGl2IGNsYXNzPVwiYnV0dG9uLWdyb3VwXCIgcm9sZT1cInRhYmxpc3RcIj5cbiAgICBAZm9yIChidXR0b24gb2YgYnV0dG9uczsgdHJhY2sgYnV0dG9uLmlkKSB7XG4gICAgICAgIDxsaWItYnV0dG9uLWdyb3VwLWl0ZW1cbiAgICAgICAgICAgIFtidXR0b25dPVwiYnV0dG9uXCJcbiAgICAgICAgICAgIFtpc0FjdGl2ZV09XCJpc0J1dHRvbkFjdGl2ZShidXR0b24uaWQpXCJcbiAgICAgICAgICAgIFtkaXNhYmxlZF09XCJkaXNhYmxlZFwiXG4gICAgICAgICAgICAoYnV0dG9uQ2xpY2spPVwib25CdXR0b25DbGljaygkZXZlbnQpXCJcbiAgICAgICAgICAgIGNsYXNzPVwiYnV0dG9uLWdyb3VwLWl0ZW1cIlxuICAgICAgICAvPlxuICAgIH1cbjwvZGl2PlxuIl19
|
|
@@ -16,7 +16,7 @@ export const createContactForm = (fb) => fb.nonNullable.group({
|
|
|
16
16
|
message: ['', Validators.required],
|
|
17
17
|
status: [''],
|
|
18
18
|
});
|
|
19
|
-
export const submitEmail = (payload,
|
|
19
|
+
export const submitEmail = (payload, http, apiBaseUrl) => submitContactForm(payload, http, EMAIL_PATH, apiBaseUrl);
|
|
20
20
|
export const submitFeedback = (payload, http, apiBaseUrl) => submitContactForm({ ...payload, origin: location.href }, http, FEEDBACK_PATH, apiBaseUrl);
|
|
21
21
|
const submitContactForm = (payload, http, path, apiBaseUrl) => http.post(`${apiBaseUrl}/${path}`, payload);
|
|
22
22
|
export const getUserStatusFromRoles = (roles) => {
|
|
@@ -38,4 +38,4 @@ export const getUserStatusFromRoles = (roles) => {
|
|
|
38
38
|
}
|
|
39
39
|
return userStatus;
|
|
40
40
|
};
|
|
41
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGFjdC11dGlscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudHMvc3JjL2xpYi9jb250YWN0LXV0aWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBZSxVQUFVLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUV6RCxNQUFNLFVBQVUsR0FBRyxPQUFPLENBQUM7QUFDM0IsTUFBTSxhQUFhLEdBQUcsVUFBVSxDQUFDO0FBRWpDLE1BQU0sQ0FBQyxNQUFNLGFBQWEsR0FBRztJQUN6QixFQUFFO0lBQ0YsZUFBZTtJQUNmLFVBQVU7SUFDVixTQUFTO0lBQ1QsT0FBTztJQUNQLGtCQUFrQjtJQUNsQixPQUFPO0NBQ0QsQ0FBQztBQVdYLE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHLENBQUMsRUFBZSxFQUFFLEVBQUUsQ0FDakQsRUFBRSxDQUFDLFdBQVcsQ0FBQyxLQUFLLENBQUM7SUFDakIsSUFBSSxFQUFFLENBQUMsRUFBRSxDQUFDO0lBQ1YsS0FBSyxFQUFFLENBQUMsRUFBRSxDQUFDO0lBQ1gsT0FBTyxFQUFFLENBQUMsRUFBRSxFQUFFLFVBQVUsQ0FBQyxRQUFRLENBQUM7SUFDbEMsTUFBTSxFQUFFLENBQUMsRUFBOEIsQ0FBQztDQUMzQyxDQUFDLENBQUM7QUFFUCxNQUFNLENBQUMsTUFBTSxXQUFXLEdBQUcsQ0FBQyxPQUF1QixFQUFFLElBQWdCLEVBQUUsVUFBa0IsRUFBRSxFQUFFLENBQ3pGLGlCQUFpQixDQUFDLE9BQU8sRUFBRSxJQUFJLEVBQUUsVUFBVSxFQUFFLFVBQVUsQ0FBQyxDQUFDO0FBRTdELE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBRyxDQUFDLE9BQXVCLEVBQUUsSUFBZ0IsRUFBRSxVQUFrQixFQUFFLEVBQUUsQ0FDNUYsaUJBQWlCLENBQUMsRUFBRSxHQUFHLE9BQU8sRUFBRSxNQUFNLEVBQUUsUUFBUSxDQUFDLElBQUksRUFBRSxFQUFFLElBQUksRUFBRSxhQUFhLEVBQUUsVUFBVSxDQUFDLENBQUM7QUFFOUYsTUFBTSxpQkFBaUIsR0FBRyxDQUN0QixPQUE2QyxFQUM3QyxJQUFnQixFQUNoQixJQUE4QyxFQUM5QyxVQUFrQixFQUNwQixFQUFFLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBVSxHQUFHLFVBQVUsSUFBSSxJQUFJLEVBQUUsRUFBRSxPQUFPLENBQUMsQ0FBQztBQUUxRCxNQUFNLENBQUMsTUFBTSxzQkFBc0IsR0FBRyxDQUFDLEtBQWUsRUFBYyxFQUFFO0lBQ2xFLElBQUksVUFBVSxHQUFlLEVBQUUsQ0FBQztJQUNoQyxJQUFJLEtBQUssQ0FBQyxRQUFRLENBQUMsc0JBQXNCLENBQUMsRUFBRSxDQUFDO1FBQ3pDLFVBQVUsR0FBRyxlQUFlLENBQUM7SUFDakMsQ0FBQztJQUNELElBQUksS0FBSyxDQUFDLFFBQVEsQ0FBQyxpQkFBaUIsQ0FBQyxFQUFFLENBQUM7UUFDcEMsVUFBVSxHQUFHLFVBQVUsQ0FBQztJQUM1QixDQUFDO0lBQ0QsSUFBSSxLQUFLLENBQUMsUUFBUSxDQUFDLGVBQWUsQ0FBQyxFQUFFLENBQUM7UUFDbEMsVUFBVSxHQUFHLE9BQU8sQ0FBQztJQUN6QixDQUFDO0lBQ0QsSUFBSSxLQUFLLENBQUMsUUFBUSxDQUFDLGlCQUFpQixDQUFDLEVBQUUsQ0FBQztRQUNwQyxVQUFVLEdBQUcsU0FBUyxDQUFDO0lBQzNCLENBQUM7SUFDRCxJQUFJLEtBQUssQ0FBQyxRQUFRLENBQUMsaUJBQWlCLENBQUMsRUFBRSxDQUFDO1FBQ3BDLFVBQVUsR0FBRyxrQkFBa0IsQ0FBQztJQUNwQyxDQUFDO0lBQ0QsT0FBTyxVQUFVLENBQUM7QUFDdEIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSHR0cENsaWVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcbmltcG9ydCB7IEZvcm1CdWlsZGVyLCBWYWxpZGF0b3JzIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5jb25zdCBFTUFJTF9QQVRIID0gJ2VtYWlsJztcbmNvbnN0IEZFRURCQUNLX1BBVEggPSAnZmVlZGJhY2snO1xuXG5leHBvcnQgY29uc3QgVVNFUl9TVEFUVVNFUyA9IFtcbiAgICAnJyxcbiAgICAnVW5kZXJncmFkdWF0ZScsXG4gICAgJ0dyYWR1YXRlJyxcbiAgICAnRmFjdWx0eScsXG4gICAgJ1N0YWZmJyxcbiAgICAnTGlicmFyeSBFbXBsb3llZScsXG4gICAgJ090aGVyJyxcbl0gYXMgY29uc3Q7XG5cbmV4cG9ydCB0eXBlIFVzZXJTdGF0dXMgPSAodHlwZW9mIFVTRVJfU1RBVFVTRVMpW251bWJlcl07XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29udGFjdFBheWxvYWQge1xuICAgIGVtYWlsPzogc3RyaW5nO1xuICAgIG1lc3NhZ2U6IHN0cmluZztcbiAgICBuYW1lPzogc3RyaW5nO1xuICAgIHN0YXR1cz86IFVzZXJTdGF0dXM7XG59XG5cbmV4cG9ydCBjb25zdCBjcmVhdGVDb250YWN0Rm9ybSA9IChmYjogRm9ybUJ1aWxkZXIpID0+XG4gICAgZmIubm9uTnVsbGFibGUuZ3JvdXAoe1xuICAgICAgICBuYW1lOiBbJyddLFxuICAgICAgICBlbWFpbDogWycnXSxcbiAgICAgICAgbWVzc2FnZTogWycnLCBWYWxpZGF0b3JzLnJlcXVpcmVkXSxcbiAgICAgICAgc3RhdHVzOiBbJycgYXMgQ29udGFjdFBheWxvYWRbJ3N0YXR1cyddXSxcbiAgICB9KTtcblxuZXhwb3J0IGNvbnN0IHN1Ym1pdEVtYWlsID0gKHBheWxvYWQ6IENvbnRhY3RQYXlsb2FkLCBodHRwOiBIdHRwQ2xpZW50LCBhcGlCYXNlVXJsOiBzdHJpbmcpID0+XG4gICAgc3VibWl0Q29udGFjdEZvcm0ocGF5bG9hZCwgaHR0cCwgRU1BSUxfUEFUSCwgYXBpQmFzZVVybCk7XG5cbmV4cG9ydCBjb25zdCBzdWJtaXRGZWVkYmFjayA9IChwYXlsb2FkOiBDb250YWN0UGF5bG9hZCwgaHR0cDogSHR0cENsaWVudCwgYXBpQmFzZVVybDogc3RyaW5nKSA9PlxuICAgIHN1Ym1pdENvbnRhY3RGb3JtKHsgLi4ucGF5bG9hZCwgb3JpZ2luOiBsb2NhdGlvbi5ocmVmIH0sIGh0dHAsIEZFRURCQUNLX1BBVEgsIGFwaUJhc2VVcmwpO1xuXG5jb25zdCBzdWJtaXRDb250YWN0Rm9ybSA9IChcbiAgICBwYXlsb2FkOiBDb250YWN0UGF5bG9hZCAmIHsgb3JpZ2luPzogc3RyaW5nIH0sXG4gICAgaHR0cDogSHR0cENsaWVudCxcbiAgICBwYXRoOiB0eXBlb2YgRU1BSUxfUEFUSCB8IHR5cGVvZiBGRUVEQkFDS19QQVRILFxuICAgIGFwaUJhc2VVcmw6IHN0cmluZyxcbikgPT4gaHR0cC5wb3N0PHVua25vd24+KGAke2FwaUJhc2VVcmx9LyR7cGF0aH1gLCBwYXlsb2FkKTtcblxuZXhwb3J0IGNvbnN0IGdldFVzZXJTdGF0dXNGcm9tUm9sZXMgPSAocm9sZXM6IHN0cmluZ1tdKTogVXNlclN0YXR1cyA9PiB7XG4gICAgbGV0IHVzZXJTdGF0dXM6IFVzZXJTdGF0dXMgPSAnJztcbiAgICBpZiAocm9sZXMuaW5jbHVkZXMoJ3VuZGVyZ3JhZHVhdGVTdHVkZW50JykpIHtcbiAgICAgICAgdXNlclN0YXR1cyA9ICdVbmRlcmdyYWR1YXRlJztcbiAgICB9XG4gICAgaWYgKHJvbGVzLmluY2x1ZGVzKCdncmFkdWF0ZVN0dWRlbnQnKSkge1xuICAgICAgICB1c2VyU3RhdHVzID0gJ0dyYWR1YXRlJztcbiAgICB9XG4gICAgaWYgKHJvbGVzLmluY2x1ZGVzKCdzdGFmZkVtcGxveWVlJykpIHtcbiAgICAgICAgdXNlclN0YXR1cyA9ICdTdGFmZic7XG4gICAgfVxuICAgIGlmIChyb2xlcy5pbmNsdWRlcygnZmFjdWx0eUVtcGxveWVlJykpIHtcbiAgICAgICAgdXNlclN0YXR1cyA9ICdGYWN1bHR5JztcbiAgICB9XG4gICAgaWYgKHJvbGVzLmluY2x1ZGVzKCdsaWJyYXJ5RW1wbG95ZWUnKSkge1xuICAgICAgICB1c2VyU3RhdHVzID0gJ0xpYnJhcnkgRW1wbG95ZWUnO1xuICAgIH1cbiAgICByZXR1cm4gdXNlclN0YXR1cztcbn07XG4iXX0=
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Component, Input, ViewChild, ChangeDetectionStrategy } from '@angular/core';
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
|
-
import { libHbllExpandCollapse } from '../animations/animations';
|
|
3
|
+
import { libHbllExpandCollapse, libHbllFadeInOut } from '../animations/animations';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
import * as i1 from "@angular/common";
|
|
6
6
|
export class ExpandCollapseComponent {
|
|
@@ -16,11 +16,11 @@ export class ExpandCollapseComponent {
|
|
|
16
16
|
return this._isExpanded;
|
|
17
17
|
}
|
|
18
18
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: ExpandCollapseComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
19
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.0", type: ExpandCollapseComponent, isStandalone: true, selector: "lib-expand-collapse", inputs: { isExpanded: "isExpanded" }, viewQueries: [{ propertyName: "contentRef", first: true, predicate: ["contentRef"], descendants: true }], ngImport: i0, template: "<div\n #contentRef\n
|
|
19
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.0", type: ExpandCollapseComponent, isStandalone: true, selector: "lib-expand-collapse", inputs: { isExpanded: "isExpanded" }, viewQueries: [{ propertyName: "contentRef", first: true, predicate: ["contentRef"], descendants: true }], ngImport: i0, template: "<div\n #contentRef\n [@libHbllExpandCollapse]=\"{\n value: isExpanded,\n params: { startHeight: heightOfContent },\n }\"\n class=\"hbll-expand-collapse-content-wrapper\"\n [ngClass]=\"{ 'hbll-expand-collapse-collapsed': !isExpanded }\"\n>\n <div *ngIf=\"isExpanded\" @libHbllFadeInOut data-testid=\"content\">\n <ng-content></ng-content>\n </div>\n</div>\n", styles: [".hbll-expand-collapse-collapsed{height:0}.hbll-expand-collapse-content-wrapper{overflow:hidden}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], animations: [libHbllExpandCollapse, libHbllFadeInOut], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
20
20
|
}
|
|
21
21
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: ExpandCollapseComponent, decorators: [{
|
|
22
22
|
type: Component,
|
|
23
|
-
args: [{ selector: 'lib-expand-collapse', changeDetection: ChangeDetectionStrategy.OnPush, animations: [libHbllExpandCollapse], standalone: true, imports: [CommonModule], template: "<div\n #contentRef\n
|
|
23
|
+
args: [{ selector: 'lib-expand-collapse', changeDetection: ChangeDetectionStrategy.OnPush, animations: [libHbllExpandCollapse, libHbllFadeInOut], standalone: true, imports: [CommonModule], template: "<div\n #contentRef\n [@libHbllExpandCollapse]=\"{\n value: isExpanded,\n params: { startHeight: heightOfContent },\n }\"\n class=\"hbll-expand-collapse-content-wrapper\"\n [ngClass]=\"{ 'hbll-expand-collapse-collapsed': !isExpanded }\"\n>\n <div *ngIf=\"isExpanded\" @libHbllFadeInOut data-testid=\"content\">\n <ng-content></ng-content>\n </div>\n</div>\n", styles: [".hbll-expand-collapse-collapsed{height:0}.hbll-expand-collapse-content-wrapper{overflow:hidden}\n"] }]
|
|
24
24
|
}], propDecorators: { contentRef: [{
|
|
25
25
|
type: ViewChild,
|
|
26
26
|
args: ['contentRef']
|
|
@@ -28,4 +28,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImpor
|
|
|
28
28
|
type: Input,
|
|
29
29
|
args: [{ required: true }]
|
|
30
30
|
}] } });
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhwYW5kLWNvbGxhcHNlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudHMvc3JjL2xpYi9leHBhbmQtY29sbGFwc2UvZXhwYW5kLWNvbGxhcHNlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudHMvc3JjL2xpYi9leHBhbmQtY29sbGFwc2UvZXhwYW5kLWNvbGxhcHNlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWMsS0FBSyxFQUFFLFNBQVMsRUFBRSx1QkFBdUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLHFCQUFxQixFQUFFLGdCQUFnQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7OztBQVduRixNQUFNLE9BQU8sdUJBQXVCO0lBVHBDO1FBWVksZ0JBQVcsR0FBRyxLQUFLLENBQUM7UUFTbEIsb0JBQWUsR0FBRyxDQUFDLENBQUM7S0FDakM7SUFURyxJQUErQixVQUFVLENBQUMsVUFBbUI7UUFDekQsSUFBSSxDQUFDLGVBQWUsR0FBRyxJQUFJLENBQUMsVUFBVSxFQUFFLGFBQWEsQ0FBQyxZQUFZLENBQUM7UUFDbkUsSUFBSSxDQUFDLFdBQVcsR0FBRyxVQUFVLENBQUM7SUFDbEMsQ0FBQztJQUNELElBQUksVUFBVTtRQUNWLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQztJQUM1QixDQUFDOzhHQVZRLHVCQUF1QjtrR0FBdkIsdUJBQXVCLCtOQ2JwQyxnWkFhQSwwSkRGYyxZQUFZLG1OQUZWLENBQUMscUJBQXFCLEVBQUUsZ0JBQWdCLENBQUM7OzJGQUk1Qyx1QkFBdUI7a0JBVG5DLFNBQVM7K0JBQ0kscUJBQXFCLG1CQUdkLHVCQUF1QixDQUFDLE1BQU0sY0FDbkMsQ0FBQyxxQkFBcUIsRUFBRSxnQkFBZ0IsQ0FBQyxjQUN6QyxJQUFJLFdBQ1AsQ0FBQyxZQUFZLENBQUM7OEJBR1UsVUFBVTtzQkFBMUMsU0FBUzt1QkFBQyxZQUFZO2dCQUdRLFVBQVU7c0JBQXhDLEtBQUs7dUJBQUMsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFbGVtZW50UmVmLCBJbnB1dCwgVmlld0NoaWxkLCBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IGxpYkhibGxFeHBhbmRDb2xsYXBzZSwgbGliSGJsbEZhZGVJbk91dCB9IGZyb20gJy4uL2FuaW1hdGlvbnMvYW5pbWF0aW9ucyc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAnbGliLWV4cGFuZC1jb2xsYXBzZScsXG4gICAgdGVtcGxhdGVVcmw6ICcuL2V4cGFuZC1jb2xsYXBzZS5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vZXhwYW5kLWNvbGxhcHNlLmNvbXBvbmVudC5zY3NzJ10sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gICAgYW5pbWF0aW9uczogW2xpYkhibGxFeHBhbmRDb2xsYXBzZSwgbGliSGJsbEZhZGVJbk91dF0sXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcbn0pXG5leHBvcnQgY2xhc3MgRXhwYW5kQ29sbGFwc2VDb21wb25lbnQge1xuICAgIEBWaWV3Q2hpbGQoJ2NvbnRlbnRSZWYnKSBwcml2YXRlIGNvbnRlbnRSZWYhOiBFbGVtZW50UmVmO1xuXG4gICAgcHJpdmF0ZSBfaXNFeHBhbmRlZCA9IGZhbHNlO1xuICAgIEBJbnB1dCh7IHJlcXVpcmVkOiB0cnVlIH0pIHNldCBpc0V4cGFuZGVkKGlzRXhwYW5kZWQ6IGJvb2xlYW4pIHtcbiAgICAgICAgdGhpcy5oZWlnaHRPZkNvbnRlbnQgPSB0aGlzLmNvbnRlbnRSZWY/Lm5hdGl2ZUVsZW1lbnQuY2xpZW50SGVpZ2h0O1xuICAgICAgICB0aGlzLl9pc0V4cGFuZGVkID0gaXNFeHBhbmRlZDtcbiAgICB9XG4gICAgZ2V0IGlzRXhwYW5kZWQoKSB7XG4gICAgICAgIHJldHVybiB0aGlzLl9pc0V4cGFuZGVkO1xuICAgIH1cblxuICAgIHByb3RlY3RlZCBoZWlnaHRPZkNvbnRlbnQgPSAwO1xufVxuIiwiPGRpdlxuICAgICNjb250ZW50UmVmXG4gICAgW0BsaWJIYmxsRXhwYW5kQ29sbGFwc2VdPVwie1xuICAgICAgICB2YWx1ZTogaXNFeHBhbmRlZCxcbiAgICAgICAgcGFyYW1zOiB7IHN0YXJ0SGVpZ2h0OiBoZWlnaHRPZkNvbnRlbnQgfSxcbiAgICB9XCJcbiAgICBjbGFzcz1cImhibGwtZXhwYW5kLWNvbGxhcHNlLWNvbnRlbnQtd3JhcHBlclwiXG4gICAgW25nQ2xhc3NdPVwieyAnaGJsbC1leHBhbmQtY29sbGFwc2UtY29sbGFwc2VkJzogIWlzRXhwYW5kZWQgfVwiXG4+XG4gICAgPGRpdiAqbmdJZj1cImlzRXhwYW5kZWRcIiBAbGliSGJsbEZhZGVJbk91dCBkYXRhLXRlc3RpZD1cImNvbnRlbnRcIj5cbiAgICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICAgIDwvZGl2PlxuPC9kaXY+XG4iXX0=
|