UNPKG

carbon-components-angular

Version:
201 lines 20 kB
import { ChangeDetectionStrategy, Component, ContentChildren, forwardRef, HostBinding, Input, TemplateRef } from "@angular/core"; import { CHECKBOX_GROUP_HOST } from "./checkbox-group-host"; import { Checkbox } from "./checkbox.component"; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; import * as i2 from "carbon-components-angular/icon"; /** * Groups related checkboxes with a shared legend, validation, and optional decorator * (e.g. AI label). * * ```html * <cds-checkbox-group legend="Group label" [decorator]="decoratorTpl"> * <cds-checkbox>Option 1</cds-checkbox> * </cds-checkbox-group> * ``` */ export class CheckboxGroup { constructor(changeDetectorRef) { this.changeDetectorRef = changeDetectorRef; this.hostFormItem = true; this.helperTextId = `checkbox-group-helper-${CheckboxGroup.nextHelperId++}`; this.orientation = "vertical"; this.invalid = false; this.warn = false; this.readOnly = false; } ngOnChanges(changes) { if (changes["readOnly"] || changes["invalid"] || changes["warn"]) { this.notifyCheckboxesHostStateChanged(); } } ngAfterContentInit() { this.checkboxes.changes.subscribe(() => this.notifyCheckboxesHostStateChanged()); } isTemplate(value) { return value instanceof TemplateRef; } notifyCheckboxesHostStateChanged() { Promise.resolve().then(() => { this.checkboxes?.forEach((cb) => cb.markForCheckFromGroup()); this.changeDetectorRef.markForCheck(); }); } } CheckboxGroup.nextHelperId = 0; CheckboxGroup.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CheckboxGroup, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); CheckboxGroup.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: CheckboxGroup, selector: "cds-checkbox-group, ibm-checkbox-group", inputs: { legend: "legend", legendId: "legendId", fieldsetAriaLabelledby: "fieldsetAriaLabelledby", orientation: "orientation", helperText: "helperText", invalid: "invalid", invalidText: "invalidText", warn: "warn", warnText: "warnText", readOnly: "readOnly", decorator: "decorator" }, host: { properties: { "class.cds--form-item": "this.hostFormItem" } }, providers: [ { provide: CHECKBOX_GROUP_HOST, useExisting: CheckboxGroup } ], queries: [{ propertyName: "checkboxes", predicate: i0.forwardRef(function () { return Checkbox; }), descendants: true }], usesOnChanges: true, ngImport: i0, template: ` <fieldset class="cds--checkbox-group" [ngClass]="{ 'cds--checkbox-group--horizontal': orientation === 'horizontal', 'cds--checkbox-group--readonly': readOnly, 'cds--checkbox-group--invalid': !readOnly && invalid, 'cds--checkbox-group--warning': !readOnly && !invalid && warn, 'cds--checkbox-group--decorator': !!decorator }" [attr.data-invalid]="invalid ? true : null" [attr.aria-labelledby]="legendId || fieldsetAriaLabelledby || null" [attr.aria-readonly]="readOnly ? true : null" [attr.aria-describedby]="(helperText && !invalid && !warn) ? helperTextId : null"> <legend *ngIf="legend" class="cds--label" [attr.id]="legendId || null"> <ng-template *ngIf="isTemplate(legend); else legendLabel" [ngTemplateOutlet]="legend"></ng-template> <ng-template #legendLabel>{{legend}}</ng-template> <ng-container *ngIf="decorator"> <div class="cds--checkbox-group-inner--decorator"> <ng-template [ngTemplateOutlet]="decorator"></ng-template> </div> </ng-container> </legend> <ng-content></ng-content> <div class="cds--checkbox-group__validation-msg"> <ng-container *ngIf="!readOnly && invalid"> <svg cdsIcon="warning--filled" size="16" class="cds--checkbox__invalid-icon"> </svg> <div class="cds--form-requirement"> <ng-container *ngIf="!isTemplate(invalidText)">{{ invalidText }}</ng-container> <ng-template *ngIf="isTemplate(invalidText)" [ngTemplateOutlet]="invalidText"></ng-template> </div> </ng-container> <ng-container *ngIf="!readOnly && !invalid && warn"> <svg cdsIcon="warning--alt--filled" size="16" class="cds--checkbox__invalid-icon cds--checkbox__invalid-icon--warning"> </svg> <div class="cds--form-requirement"> <ng-container *ngIf="!isTemplate(warnText)">{{warnText}}</ng-container> <ng-template *ngIf="isTemplate(warnText)" [ngTemplateOutlet]="warnText"></ng-template> </div> </ng-container> </div> <div *ngIf="helperText && !invalid && !warn" class="cds--form__helper-text" [id]="helperTextId"> <ng-container *ngIf="!isTemplate(helperText)">{{helperText}}</ng-container> <ng-template *ngIf="isTemplate(helperText)" [ngTemplateOutlet]="helperText"></ng-template> </div> </fieldset> `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.IconDirective, selector: "[cdsIcon], [ibmIcon]", inputs: ["ibmIcon", "cdsIcon", "size", "title", "ariaLabel", "ariaLabelledBy", "ariaHidden", "isFocusable"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: CheckboxGroup, decorators: [{ type: Component, args: [{ selector: "cds-checkbox-group, ibm-checkbox-group", template: ` <fieldset class="cds--checkbox-group" [ngClass]="{ 'cds--checkbox-group--horizontal': orientation === 'horizontal', 'cds--checkbox-group--readonly': readOnly, 'cds--checkbox-group--invalid': !readOnly && invalid, 'cds--checkbox-group--warning': !readOnly && !invalid && warn, 'cds--checkbox-group--decorator': !!decorator }" [attr.data-invalid]="invalid ? true : null" [attr.aria-labelledby]="legendId || fieldsetAriaLabelledby || null" [attr.aria-readonly]="readOnly ? true : null" [attr.aria-describedby]="(helperText && !invalid && !warn) ? helperTextId : null"> <legend *ngIf="legend" class="cds--label" [attr.id]="legendId || null"> <ng-template *ngIf="isTemplate(legend); else legendLabel" [ngTemplateOutlet]="legend"></ng-template> <ng-template #legendLabel>{{legend}}</ng-template> <ng-container *ngIf="decorator"> <div class="cds--checkbox-group-inner--decorator"> <ng-template [ngTemplateOutlet]="decorator"></ng-template> </div> </ng-container> </legend> <ng-content></ng-content> <div class="cds--checkbox-group__validation-msg"> <ng-container *ngIf="!readOnly && invalid"> <svg cdsIcon="warning--filled" size="16" class="cds--checkbox__invalid-icon"> </svg> <div class="cds--form-requirement"> <ng-container *ngIf="!isTemplate(invalidText)">{{ invalidText }}</ng-container> <ng-template *ngIf="isTemplate(invalidText)" [ngTemplateOutlet]="invalidText"></ng-template> </div> </ng-container> <ng-container *ngIf="!readOnly && !invalid && warn"> <svg cdsIcon="warning--alt--filled" size="16" class="cds--checkbox__invalid-icon cds--checkbox__invalid-icon--warning"> </svg> <div class="cds--form-requirement"> <ng-container *ngIf="!isTemplate(warnText)">{{warnText}}</ng-container> <ng-template *ngIf="isTemplate(warnText)" [ngTemplateOutlet]="warnText"></ng-template> </div> </ng-container> </div> <div *ngIf="helperText && !invalid && !warn" class="cds--form__helper-text" [id]="helperTextId"> <ng-container *ngIf="!isTemplate(helperText)">{{helperText}}</ng-container> <ng-template *ngIf="isTemplate(helperText)" [ngTemplateOutlet]="helperText"></ng-template> </div> </fieldset> `, providers: [ { provide: CHECKBOX_GROUP_HOST, useExisting: CheckboxGroup } ], changeDetection: ChangeDetectionStrategy.OnPush }] }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { hostFormItem: [{ type: HostBinding, args: ["class.cds--form-item"] }], checkboxes: [{ type: ContentChildren, args: [forwardRef(() => Checkbox), { descendants: true }] }], legend: [{ type: Input }], legendId: [{ type: Input }], fieldsetAriaLabelledby: [{ type: Input }], orientation: [{ type: Input }], helperText: [{ type: Input }], invalid: [{ type: Input }], invalidText: [{ type: Input }], warn: [{ type: Input }], warnText: [{ type: Input }], readOnly: [{ type: Input }], decorator: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"checkbox-group.component.js","sourceRoot":"","sources":["../../../src/checkbox/checkbox-group.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEN,uBAAuB,EAEvB,SAAS,EACT,eAAe,EACf,UAAU,EACV,WAAW,EACX,KAAK,EAIL,WAAW,EACX,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;;;;AAEhD;;;;;;;;;GASG;AAiEH,MAAM,OAAO,aAAa;IAwCzB,YAAoB,iBAAoC;QAApC,sBAAiB,GAAjB,iBAAiB,CAAmB;QAtCnB,iBAAY,GAAG,IAAI,CAAC;QAKhD,iBAAY,GAAG,yBAAyB,aAAa,CAAC,YAAY,EAAE,EAAE,CAAC;QAcvE,gBAAW,GAA8B,UAAU,CAAC;QAIpD,YAAO,GAAG,KAAK,CAAC;QAIhB,SAAI,GAAG,KAAK,CAAC;QAIb,aAAQ,GAAG,KAAK,CAAC;IAOiC,CAAC;IAE5D,WAAW,CAAC,OAAsB;QACjC,IAAI,OAAO,CAAC,UAAU,CAAC,IAAI,OAAO,CAAC,SAAS,CAAC,IAAI,OAAO,CAAC,MAAM,CAAC,EAAE;YACjE,IAAI,CAAC,gCAAgC,EAAE,CAAC;SACxC;IACF,CAAC;IAED,kBAAkB;QACjB,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,gCAAgC,EAAE,CAAC,CAAC;IAClF,CAAC;IAED,UAAU,CAAC,KAAU;QACpB,OAAO,KAAK,YAAY,WAAW,CAAC;IACrC,CAAC;IAEO,gCAAgC;QACvC,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;YAC3B,IAAI,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,qBAAqB,EAAE,CAAC,CAAC;YAC7D,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;QACvC,CAAC,CAAC,CAAC;IACJ,CAAC;;AA5Dc,0BAAY,GAAG,CAAE,CAAA;0GADpB,aAAa;8FAAb,aAAa,saALd;QACV,EAAE,OAAO,EAAE,mBAAmB,EAAE,WAAW,EAAE,aAAa,EAAE;KAC5D,wFAQiC,QAAQ,yEAnEhC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAwDT;2FAMW,aAAa;kBAhEzB,SAAS;mBAAC;oBACV,QAAQ,EAAE,wCAAwC;oBAClD,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAwDT;oBACD,SAAS,EAAE;wBACV,EAAE,OAAO,EAAE,mBAAmB,EAAE,WAAW,eAAe,EAAE;qBAC5D;oBACD,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAC/C;wGAGqC,YAAY;sBAAhD,WAAW;uBAAC,sBAAsB;gBAGiC,UAAU;sBAA7E,eAAe;uBAAC,UAAU,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE;gBAIzD,MAAM;sBAAd,KAAK;gBAKG,QAAQ;sBAAhB,KAAK;gBAKG,sBAAsB;sBAA9B,KAAK;gBAEG,WAAW;sBAAnB,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBAEG,OAAO;sBAAf,KAAK;gBAEG,WAAW;sBAAnB,KAAK;gBAEG,IAAI;sBAAZ,KAAK;gBAEG,QAAQ;sBAAhB,KAAK;gBAEG,QAAQ;sBAAhB,KAAK;gBAKG,SAAS;sBAAjB,KAAK","sourcesContent":["import {\r\n\tAfterContentInit,\r\n\tChangeDetectionStrategy,\r\n\tChangeDetectorRef,\r\n\tComponent,\r\n\tContentChildren,\r\n\tforwardRef,\r\n\tHostBinding,\r\n\tInput,\r\n\tOnChanges,\r\n\tQueryList,\r\n\tSimpleChanges,\r\n\tTemplateRef\r\n} from \"@angular/core\";\r\nimport { CHECKBOX_GROUP_HOST } from \"./checkbox-group-host\";\r\nimport { Checkbox } from \"./checkbox.component\";\r\n\r\n/**\r\n * Groups related checkboxes with a shared legend, validation, and optional decorator\r\n * (e.g. AI label).\r\n *\r\n * ```html\r\n * <cds-checkbox-group legend=\"Group label\" [decorator]=\"decoratorTpl\">\r\n *   <cds-checkbox>Option 1</cds-checkbox>\r\n * </cds-checkbox-group>\r\n * ```\r\n */\r\n@Component({\r\n\tselector: \"cds-checkbox-group, ibm-checkbox-group\",\r\n\ttemplate: `\r\n\t\t<fieldset\r\n\t\t\tclass=\"cds--checkbox-group\"\r\n\t\t\t[ngClass]=\"{\r\n\t\t\t\t'cds--checkbox-group--horizontal': orientation === 'horizontal',\r\n\t\t\t\t'cds--checkbox-group--readonly': readOnly,\r\n\t\t\t\t'cds--checkbox-group--invalid': !readOnly && invalid,\r\n\t\t\t\t'cds--checkbox-group--warning': !readOnly && !invalid && warn,\r\n\t\t\t\t'cds--checkbox-group--decorator': !!decorator\r\n\t\t\t}\"\r\n\t\t\t[attr.data-invalid]=\"invalid ? true : null\"\r\n\t\t\t[attr.aria-labelledby]=\"legendId || fieldsetAriaLabelledby || null\"\r\n\t\t\t[attr.aria-readonly]=\"readOnly ? true : null\"\r\n\t\t\t[attr.aria-describedby]=\"(helperText && !invalid && !warn) ? helperTextId : null\">\r\n\t\t\t<legend *ngIf=\"legend\" class=\"cds--label\" [attr.id]=\"legendId || null\">\r\n\t\t\t\t<ng-template *ngIf=\"isTemplate(legend); else legendLabel\" [ngTemplateOutlet]=\"legend\"></ng-template>\r\n\t\t\t\t<ng-template #legendLabel>{{legend}}</ng-template>\r\n\t\t\t\t<ng-container *ngIf=\"decorator\">\r\n\t\t\t\t\t<div class=\"cds--checkbox-group-inner--decorator\">\r\n\t\t\t\t\t\t<ng-template [ngTemplateOutlet]=\"decorator\"></ng-template>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</ng-container>\r\n\t\t\t</legend>\r\n\t\t\t<ng-content></ng-content>\r\n\t\t\t<div class=\"cds--checkbox-group__validation-msg\">\r\n\t\t\t\t<ng-container *ngIf=\"!readOnly && invalid\">\r\n\t\t\t\t\t<svg\r\n\t\t\t\t\t\tcdsIcon=\"warning--filled\"\r\n\t\t\t\t\t\tsize=\"16\"\r\n\t\t\t\t\t\tclass=\"cds--checkbox__invalid-icon\">\r\n\t\t\t\t\t</svg>\r\n\t\t\t\t\t<div class=\"cds--form-requirement\">\r\n\t\t\t\t\t\t<ng-container *ngIf=\"!isTemplate(invalidText)\">{{ invalidText }}</ng-container>\r\n\t\t\t\t\t\t<ng-template *ngIf=\"isTemplate(invalidText)\" [ngTemplateOutlet]=\"invalidText\"></ng-template>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</ng-container>\r\n\t\t\t\t<ng-container *ngIf=\"!readOnly && !invalid && warn\">\r\n\t\t\t\t\t<svg\r\n\t\t\t\t\t\tcdsIcon=\"warning--alt--filled\"\r\n\t\t\t\t\t\tsize=\"16\"\r\n\t\t\t\t\t\tclass=\"cds--checkbox__invalid-icon cds--checkbox__invalid-icon--warning\">\r\n\t\t\t\t\t</svg>\r\n\t\t\t\t\t<div class=\"cds--form-requirement\">\r\n\t\t\t\t\t\t<ng-container *ngIf=\"!isTemplate(warnText)\">{{warnText}}</ng-container>\r\n\t\t\t\t\t\t<ng-template *ngIf=\"isTemplate(warnText)\" [ngTemplateOutlet]=\"warnText\"></ng-template>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</ng-container>\r\n\t\t\t</div>\r\n\t\t\t<div\r\n\t\t\t\t*ngIf=\"helperText && !invalid && !warn\"\r\n\t\t\t\tclass=\"cds--form__helper-text\"\r\n\t\t\t\t[id]=\"helperTextId\">\r\n\t\t\t\t<ng-container *ngIf=\"!isTemplate(helperText)\">{{helperText}}</ng-container>\r\n\t\t\t\t<ng-template *ngIf=\"isTemplate(helperText)\" [ngTemplateOutlet]=\"helperText\"></ng-template>\r\n\t\t\t</div>\r\n\t\t</fieldset>\r\n\t`,\r\n\tproviders: [\r\n\t\t{ provide: CHECKBOX_GROUP_HOST, useExisting: CheckboxGroup }\r\n\t],\r\n\tchangeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class CheckboxGroup implements OnChanges, AfterContentInit {\r\n\tprivate static nextHelperId = 0;\r\n\t@HostBinding(\"class.cds--form-item\") hostFormItem = true;\r\n\r\n\t// tslint:disable-next-line:no-forward-ref\r\n\t@ContentChildren(forwardRef(() => Checkbox), { descendants: true }) checkboxes: QueryList<Checkbox>;\r\n\r\n\treadonly helperTextId = `checkbox-group-helper-${CheckboxGroup.nextHelperId++}`;\r\n\r\n\t@Input() legend: string | TemplateRef<any>;\r\n\r\n\t/**\r\n\t * Optional id for the `<legend>`; referenced by `fieldsetAriaLabelledby` when set.\r\n\t */\r\n\t@Input() legendId: string;\r\n\r\n\t/**\r\n\t * Optional `aria-labelledby` for the `<fieldset>` when not using `legendId`.\r\n\t */\r\n\t@Input() fieldsetAriaLabelledby: string;\r\n\r\n\t@Input() orientation: \"horizontal\" | \"vertical\" = \"vertical\";\r\n\r\n\t@Input() helperText: string | TemplateRef<any>;\r\n\r\n\t@Input() invalid = false;\r\n\r\n\t@Input() invalidText: string | TemplateRef<any>;\r\n\r\n\t@Input() warn = false;\r\n\r\n\t@Input() warnText: string | TemplateRef<any>;\r\n\r\n\t@Input() readOnly = false;\r\n\r\n\t/**\r\n\t * Optional decorator (e.g. AI label) rendered in the legend.\r\n\t */\r\n\t@Input() decorator: TemplateRef<any>;\r\n\r\n\tconstructor(private changeDetectorRef: ChangeDetectorRef) {}\r\n\r\n\tngOnChanges(changes: SimpleChanges) {\r\n\t\tif (changes[\"readOnly\"] || changes[\"invalid\"] || changes[\"warn\"]) {\r\n\t\t\tthis.notifyCheckboxesHostStateChanged();\r\n\t\t}\r\n\t}\r\n\r\n\tngAfterContentInit() {\r\n\t\tthis.checkboxes.changes.subscribe(() => this.notifyCheckboxesHostStateChanged());\r\n\t}\r\n\r\n\tisTemplate(value: any): boolean {\r\n\t\treturn value instanceof TemplateRef;\r\n\t}\r\n\r\n\tprivate notifyCheckboxesHostStateChanged() {\r\n\t\tPromise.resolve().then(() => {\r\n\t\t\tthis.checkboxes?.forEach((cb) => cb.markForCheckFromGroup());\r\n\t\t\tthis.changeDetectorRef.markForCheck();\r\n\t\t});\r\n\t}\r\n}\r\n"]}