UNPKG

carbon-components-angular

Version:
190 lines 16.7 kB
import { Component, Input, Output, EventEmitter, ViewChild, HostListener } from "@angular/core"; import * as i0 from "@angular/core"; import * as i1 from "carbon-components-angular/i18n"; import * as i2 from "@angular/common"; import * as i3 from "carbon-components-angular/icon"; export class SelectionTile { constructor(i18n) { this.i18n = i18n; /** * @deprecated since v5 - Use `cdsLayer` directive instead * Set to `"light"` to apply the light style */ this.theme = "dark"; /** * The unique id for the input. */ this.id = `tile-${SelectionTile.tileCount}`; /** * Internal event used to notify the containing `TileGroup` of changes. */ this.change = new EventEmitter(); /** * Set to `true` to disable the selection tile. */ this.disabled = false; /** * When `true` with a `decorator`, applies rounded styling. */ this.hasRoundedCorners = false; /** * Set by the containing `TileGroup`. Used for the `name` property on the input. */ this.name = "tile-group-unbound"; /** * Defines whether or not the `SelectionTile` supports selecting multiple tiles as opposed to single * tile selection. */ this.multiple = true; // Set to true because of the way tile group sets it up. // If an initial selected value is set before input exists, we save // the value and check again when input exists in `AfterViewInit`. this._selected = null; SelectionTile.tileCount++; } /** * Updating the state of the input to match the state of the parameter passed in. * Set to `true` if this tile should be selected. */ set selected(value) { // If an initial selected value is set before input exists, we save // the value and check again when input exists in `AfterViewInit`. this._selected = value ? true : null; if (this.input) { this.input.nativeElement.checked = this._selected; } } get selected() { return this.input ? this.input.nativeElement.checked : false; } ngAfterViewInit() { if (this.input) { setTimeout(() => { this.input.nativeElement.checked = this._selected; }); } } keyboardInput(event) { if (event.key === "Enter" || event.key === "Spacebar" || event.key === " ") { this.selected = !this.selected; this.change.emit(event); } } onChange(event) { this.change.emit(event); } } SelectionTile.tileCount = 0; SelectionTile.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: SelectionTile, deps: [{ token: i1.I18n }], target: i0.ɵɵFactoryTarget.Component }); SelectionTile.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: SelectionTile, selector: "cds-selection-tile, ibm-selection-tile", inputs: { theme: "theme", id: "id", selected: "selected", value: "value", disabled: "disabled", decorator: "decorator", hasRoundedCorners: "hasRoundedCorners" }, outputs: { change: "change" }, host: { listeners: { "keydown": "keyboardInput($event)" } }, viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true, static: true }], ngImport: i0, template: ` <input #input [attr.tabindex]="disabled ? null : 0" class="cds--tile-input" [id]="id" [disabled]="disabled" [type]="(multiple ? 'checkbox': 'radio')" [value]="value" [name]="name" (change)="onChange($event)"/> <label class="cds--tile cds--tile--selectable" [for]="id" [ngClass]="{ 'cds--tile--is-selected' : selected, 'cds--tile--light': theme === 'light', 'cds--tile--disabled' : disabled, 'cds--tile--decorator': !!decorator, 'cds--tile--decorator-rounded': !!decorator && hasRoundedCorners }" [attr.aria-label]="i18n.get('TILES.TILE') | async"> <div class="cds--tile__checkmark" [class.cds--tile__checkmark--persistent]="multiple"> <svg *ngIf="!selected; else selectedIcon" [cdsIcon]="multiple ? 'checkbox' : 'checkmark'" size="16"> </svg> <ng-template #selectedIcon> <svg [cdsIcon]="multiple ? 'checkbox--checked--filled' : 'checkmark--filled'" size="16"></svg> </ng-template> </div> <div class="cds--tile-content"> <ng-content></ng-content> </div> <ng-container *ngIf="decorator"> <div class="cds--tile--inner-decorator"> <ng-template [ngTemplateOutlet]="decorator"></ng-template> </div> </ng-container> </label> `, isInline: true, dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.IconDirective, selector: "[cdsIcon], [ibmIcon]", inputs: ["ibmIcon", "cdsIcon", "size", "title", "ariaLabel", "ariaLabelledBy", "ariaHidden", "isFocusable"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: SelectionTile, decorators: [{ type: Component, args: [{ selector: "cds-selection-tile, ibm-selection-tile", template: ` <input #input [attr.tabindex]="disabled ? null : 0" class="cds--tile-input" [id]="id" [disabled]="disabled" [type]="(multiple ? 'checkbox': 'radio')" [value]="value" [name]="name" (change)="onChange($event)"/> <label class="cds--tile cds--tile--selectable" [for]="id" [ngClass]="{ 'cds--tile--is-selected' : selected, 'cds--tile--light': theme === 'light', 'cds--tile--disabled' : disabled, 'cds--tile--decorator': !!decorator, 'cds--tile--decorator-rounded': !!decorator && hasRoundedCorners }" [attr.aria-label]="i18n.get('TILES.TILE') | async"> <div class="cds--tile__checkmark" [class.cds--tile__checkmark--persistent]="multiple"> <svg *ngIf="!selected; else selectedIcon" [cdsIcon]="multiple ? 'checkbox' : 'checkmark'" size="16"> </svg> <ng-template #selectedIcon> <svg [cdsIcon]="multiple ? 'checkbox--checked--filled' : 'checkmark--filled'" size="16"></svg> </ng-template> </div> <div class="cds--tile-content"> <ng-content></ng-content> </div> <ng-container *ngIf="decorator"> <div class="cds--tile--inner-decorator"> <ng-template [ngTemplateOutlet]="decorator"></ng-template> </div> </ng-container> </label> ` }] }], ctorParameters: function () { return [{ type: i1.I18n }]; }, propDecorators: { theme: [{ type: Input }], id: [{ type: Input }], selected: [{ type: Input }], value: [{ type: Input }], change: [{ type: Output }], disabled: [{ type: Input }], decorator: [{ type: Input }], hasRoundedCorners: [{ type: Input }], input: [{ type: ViewChild, args: ["input", { static: true }] }], keyboardInput: [{ type: HostListener, args: ["keydown", ["$event"]] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selection-tile.component.js","sourceRoot":"","sources":["../../../src/tiles/selection-tile.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACN,SAAS,EACT,KAAK,EACL,MAAM,EACN,YAAY,EACZ,SAAS,EACT,YAAY,EAGZ,MAAM,eAAe,CAAC;;;;;AAgDvB,MAAM,OAAO,aAAa;IAuEzB,YAAmB,IAAU;QAAV,SAAI,GAAJ,IAAI,CAAM;QApE7B;;;WAGG;QACM,UAAK,GAAqB,MAAM,CAAC;QAE1C;;WAEG;QACM,OAAE,GAAG,QAAQ,aAAa,CAAC,SAAS,EAAE,CAAC;QAsBhD;;WAEG;QACO,WAAM,GAAwB,IAAI,YAAY,EAAE,CAAC;QAE3D;;WAEG;QACM,aAAQ,GAAG,KAAK,CAAC;QAO1B;;WAEG;QACM,sBAAiB,GAAG,KAAK,CAAC;QAEnC;;WAEG;QACH,SAAI,GAAG,oBAAoB,CAAC;QAC5B;;;WAGG;QACH,aAAQ,GAAG,IAAI,CAAC,CAAC,wDAAwD;QAKzE,mEAAmE;QACnE,kEAAkE;QACxD,cAAS,GAAG,IAAI,CAAC;QAG1B,aAAa,CAAC,SAAS,EAAE,CAAC;IAC3B,CAAC;IA3DD;;;OAGG;IACH,IAAa,QAAQ,CAAC,KAAc;QACnC,mEAAmE;QACnE,kEAAkE;QAClE,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;QACrC,IAAI,IAAI,CAAC,KAAK,EAAE;YACf,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC;SAClD;IACF,CAAC;IAED,IAAI,QAAQ;QACX,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC;IAC9D,CAAC;IA8CD,eAAe;QACd,IAAI,IAAI,CAAC,KAAK,EAAE;YACf,UAAU,CAAC,GAAG,EAAE;gBACf,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC;YACnD,CAAC,CAAC,CAAC;SACH;IACF,CAAC;IAGD,aAAa,CAAC,KAAK;QAClB,IAAI,KAAK,CAAC,GAAG,KAAK,OAAO,IAAI,KAAK,CAAC,GAAG,KAAK,UAAU,IAAI,KAAK,CAAC,GAAG,KAAK,GAAG,EAAE;YAC3E,IAAI,CAAC,QAAQ,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC;YAC/B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACxB;IACF,CAAC;IAED,QAAQ,CAAC,KAAK;QACb,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACzB,CAAC;;AA5FM,uBAAS,GAAG,CAAC,CAAC;0GADT,aAAa;8FAAb,aAAa,0bA3Cf;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAyCT;2FAEW,aAAa;kBA7CzB,SAAS;mBAAC;oBACV,QAAQ,EAAE,wCAAwC;oBAClD,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAyCT;iBACD;2FAQS,KAAK;sBAAb,KAAK;gBAKG,EAAE;sBAAV,KAAK;gBAMO,QAAQ;sBAApB,KAAK;gBAeG,KAAK;sBAAb,KAAK;gBAII,MAAM;sBAAf,MAAM;gBAKE,QAAQ;sBAAhB,KAAK;gBAKG,SAAS;sBAAjB,KAAK;gBAKG,iBAAiB;sBAAzB,KAAK;gBAagC,KAAK;sBAA1C,SAAS;uBAAC,OAAO,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAmBpC,aAAa;sBADZ,YAAY;uBAAC,SAAS,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import {\n\tComponent,\n\tInput,\n\tOutput,\n\tEventEmitter,\n\tViewChild,\n\tHostListener,\n\tAfterViewInit,\n\tTemplateRef\n} from \"@angular/core\";\nimport { I18n } from \"carbon-components-angular/i18n\";\n\n@Component({\n\tselector: \"cds-selection-tile, ibm-selection-tile\",\n\ttemplate: `\n\t\t<input\n\t\t\t#input\n\t\t\t[attr.tabindex]=\"disabled ? null : 0\"\n\t\t\tclass=\"cds--tile-input\"\n\t\t\t[id]=\"id\"\n\t\t\t[disabled]=\"disabled\"\n\t\t\t[type]=\"(multiple ? 'checkbox': 'radio')\"\n\t\t\t[value]=\"value\"\n\t\t\t[name]=\"name\"\n\t\t\t(change)=\"onChange($event)\"/>\n\t\t<label\n\t\t\tclass=\"cds--tile cds--tile--selectable\"\n\t\t\t[for]=\"id\"\n\t\t\t[ngClass]=\"{\n\t\t\t\t'cds--tile--is-selected' : selected,\n\t\t\t\t'cds--tile--light': theme === 'light',\n\t\t\t\t'cds--tile--disabled' : disabled,\n\t\t\t\t'cds--tile--decorator': !!decorator,\n\t\t\t\t'cds--tile--decorator-rounded': !!decorator && hasRoundedCorners\n\t\t\t}\"\n\t\t\t[attr.aria-label]=\"i18n.get('TILES.TILE') | async\">\n\t\t\t<div class=\"cds--tile__checkmark\"\n\t\t\t\t[class.cds--tile__checkmark--persistent]=\"multiple\">\n\t\t\t\t<svg *ngIf=\"!selected; else selectedIcon\"\n\t\t\t\t\t[cdsIcon]=\"multiple ? 'checkbox' : 'checkmark'\"\n\t\t\t\t\tsize=\"16\">\n\t\t\t\t</svg>\n\t\t\t\t<ng-template #selectedIcon>\n\t\t\t\t\t<svg [cdsIcon]=\"multiple ? 'checkbox--checked--filled' : 'checkmark--filled'\" size=\"16\"></svg>\n\t\t\t\t</ng-template>\n\t\t\t</div>\n\t\t\t<div class=\"cds--tile-content\">\n\t\t\t\t<ng-content></ng-content>\n\t\t\t</div>\n\t\t\t<ng-container *ngIf=\"decorator\">\n\t\t\t\t<div class=\"cds--tile--inner-decorator\">\n\t\t\t\t\t<ng-template [ngTemplateOutlet]=\"decorator\"></ng-template>\n\t\t\t\t</div>\n\t\t\t</ng-container>\n\t\t</label>\n\t`\n})\nexport class SelectionTile implements AfterViewInit {\n\tstatic tileCount = 0;\n\n\t/**\n\t * @deprecated since v5 - Use `cdsLayer` directive instead\n\t * Set to `\"light\"` to apply the light style\n\t */\n\t@Input() theme: \"light\" | \"dark\" = \"dark\";\n\n\t/**\n\t * The unique id for the input.\n\t */\n\t@Input() id = `tile-${SelectionTile.tileCount}`;\n\n\t/**\n\t * Updating the state of the input to match the state of the parameter passed in.\n\t * Set to `true` if this tile should be selected.\n\t */\n\t@Input() set selected(value: boolean) {\n\t\t// If an initial selected value is set before input exists, we save\n\t\t// the value and check again when input exists in `AfterViewInit`.\n\t\tthis._selected = value ? true : null;\n\t\tif (this.input) {\n\t\t\tthis.input.nativeElement.checked = this._selected;\n\t\t}\n\t}\n\n\tget selected() {\n\t\treturn this.input ? this.input.nativeElement.checked : false;\n\t}\n\t/**\n\t * The value for the tile. Returned via `ngModel` or `selected` event on the containing `TileGroup`.\n\t */\n\t@Input() value: string;\n\t/**\n\t * Internal event used to notify the containing `TileGroup` of changes.\n\t */\n\t@Output() change: EventEmitter<Event> = new EventEmitter();\n\n\t/**\n\t * Set to `true` to disable the selection tile.\n\t */\n\t@Input() disabled = false;\n\n\t/**\n\t * **Experimental**: Optional decorator (e.g. AI label).\n\t */\n\t@Input() decorator: TemplateRef<any>;\n\n\t/**\n\t * When `true` with a `decorator`, applies rounded styling.\n\t */\n\t@Input() hasRoundedCorners = false;\n\n\t/**\n\t * Set by the containing `TileGroup`. Used for the `name` property on the input.\n\t */\n\tname = \"tile-group-unbound\";\n\t/**\n\t * Defines whether or not the `SelectionTile` supports selecting multiple tiles as opposed to single\n\t * tile selection.\n\t */\n\tmultiple = true;\t// Set to true because of the way tile group sets it up.\n\t\t\t\t\t\t// If it is first undefined then set to true, the type will change from radio to checkbox and deselects the inputs.\n\n\t@ViewChild(\"input\", { static: true }) input;\n\n\t// If an initial selected value is set before input exists, we save\n\t// the value and check again when input exists in `AfterViewInit`.\n\tprotected _selected = null;\n\n\tconstructor(public i18n: I18n) {\n\t\tSelectionTile.tileCount++;\n\t}\n\n\tngAfterViewInit() {\n\t\tif (this.input) {\n\t\t\tsetTimeout(() => {\n\t\t\t\tthis.input.nativeElement.checked = this._selected;\n\t\t\t});\n\t\t}\n\t}\n\n\t@HostListener(\"keydown\", [\"$event\"])\n\tkeyboardInput(event) {\n\t\tif (event.key === \"Enter\" || event.key === \"Spacebar\" || event.key === \" \") {\n\t\t\tthis.selected = !this.selected;\n\t\t\tthis.change.emit(event);\n\t\t}\n\t}\n\n\tonChange(event) {\n\t\tthis.change.emit(event);\n\t}\n}\n\n\n"]}