UNPKG

carbon-components-angular

Version:
205 lines (199 loc) 17.8 kB
import { Component, Input, ViewChild } from "@angular/core"; import { merge } from "carbon-components-angular/utils"; 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"; /** * Get started with importing the module: * * ```typescript * import { TilesModule } from 'carbon-components-angular'; * ``` * * [See demo](../../?path=/story/components-tiles-expandable--basic) */ export class ExpandableTile { constructor(i18n, element) { this.i18n = i18n; this.element = element; /** * @deprecated since v5 - Use `cdsLayer` directive instead * Set to `"light"` to apply the light style */ this.theme = "dark"; /** * Controls the expanded state */ this.expanded = false; /** * Controls the interactive state */ this.interactive = false; this.tileMaxHeight = 0; this.currentExpandedHeight = 0; this.expand = this.i18n.getOverridable("TILES.EXPAND"); this.collapse = this.i18n.getOverridable("TILES.COLLAPSE"); } /** * Expects an object that contains some or all of: * ``` * { * "EXPAND": "Expand", * "COLLAPSE": "Collapse", * } * ``` */ set translations(value) { const valueWithDefaults = merge(this.i18n.getMultiple("TILES"), value); this.expand.override(valueWithDefaults.EXPAND); this.collapse.override(valueWithDefaults.COLLAPSE); } ngAfterViewInit() { this.updateMaxHeight(); } get expandedHeight() { const tile = this.element.nativeElement.querySelector(".cds--tile"); const tilePadding = parseInt(getComputedStyle(tile).paddingBottom, 10) + parseInt(getComputedStyle(tile).paddingTop, 10); const expandedHeight = this.tileMaxHeight + tilePadding; if (!isNaN(expandedHeight)) { this.currentExpandedHeight = expandedHeight; } return this.currentExpandedHeight; } updateMaxHeight() { if (this.expanded) { this.tileMaxHeight = this.tileContainer.nativeElement.getBoundingClientRect().height; } else { this.tileMaxHeight = this.element.nativeElement.querySelector(".cds--tile-content__above-the-fold").getBoundingClientRect().height; } } onClick() { this.expanded = !this.expanded; this.updateMaxHeight(); } } ExpandableTile.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ExpandableTile, deps: [{ token: i1.I18n }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); ExpandableTile.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ExpandableTile, selector: "cds-expandable-tile, ibm-expandable-tile", inputs: { theme: "theme", expanded: "expanded", interactive: "interactive", translations: "translations" }, viewQueries: [{ propertyName: "tileContainer", first: true, predicate: ["container"], descendants: true }], ngImport: i0, template: ` <button *ngIf="!interactive" class="cds--tile cds--tile--expandable" [ngClass]="{ 'cds--tile--is-expanded' : expanded, 'cds--tile--light': theme === 'light' }" [ngStyle]="{'max-height': expandedHeight + 'px'}" type="button" (click)="onClick()" [attr.aria-expanded]="expanded" [attr.title]="(expanded ? collapse.subject : expand.subject) | async"> <ng-container *ngTemplateOutlet="expandableTileContent"></ng-container> </button> <div *ngIf="interactive" class="cds--tile cds--tile--expandable cds--tile--expandable--interactive" [ngClass]="{ 'cds--tile--is-expanded' : expanded, 'cds--tile--light': theme === 'light' }" [ngStyle]="{'max-height': expandedHeight + 'px'}" [attr.title]="(expanded ? collapse.subject : expand.subject) | async"> <ng-container *ngTemplateOutlet="expandableTileContent"></ng-container> </div> <ng-template #chevronIcon> <svg cdsIcon="chevron--down" size="16"></svg> </ng-template> <ng-template #expandableTileContent> <div #container> <div class="cds--tile-content"> <ng-content select="[cdsAboveFold],[ibmAboveFold],.cds--tile-content__above-the-fold"></ng-content> </div> <div *ngIf="!interactive" class="cds--tile__chevron"> <ng-container *ngTemplateOutlet="chevronIcon"></ng-container> </div> <button *ngIf="interactive" class="cds--tile__chevron cds--tile__chevron--interactive" type="button" (click)="onClick()" [attr.aria-expanded]="expanded" [attr.aria-label]="(expanded ? collapse.subject : expand.subject) | async"> <ng-container *ngTemplateOutlet="chevronIcon"></ng-container> </button> <div class="cds--tile-content"> <ng-content select="[cdsBelowFold],[ibmBelowFold],.cds--tile-content__below-the-fold"></ng-content> </div> </div> </ng-template> `, 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: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { 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: ExpandableTile, decorators: [{ type: Component, args: [{ selector: "cds-expandable-tile, ibm-expandable-tile", template: ` <button *ngIf="!interactive" class="cds--tile cds--tile--expandable" [ngClass]="{ 'cds--tile--is-expanded' : expanded, 'cds--tile--light': theme === 'light' }" [ngStyle]="{'max-height': expandedHeight + 'px'}" type="button" (click)="onClick()" [attr.aria-expanded]="expanded" [attr.title]="(expanded ? collapse.subject : expand.subject) | async"> <ng-container *ngTemplateOutlet="expandableTileContent"></ng-container> </button> <div *ngIf="interactive" class="cds--tile cds--tile--expandable cds--tile--expandable--interactive" [ngClass]="{ 'cds--tile--is-expanded' : expanded, 'cds--tile--light': theme === 'light' }" [ngStyle]="{'max-height': expandedHeight + 'px'}" [attr.title]="(expanded ? collapse.subject : expand.subject) | async"> <ng-container *ngTemplateOutlet="expandableTileContent"></ng-container> </div> <ng-template #chevronIcon> <svg cdsIcon="chevron--down" size="16"></svg> </ng-template> <ng-template #expandableTileContent> <div #container> <div class="cds--tile-content"> <ng-content select="[cdsAboveFold],[ibmAboveFold],.cds--tile-content__above-the-fold"></ng-content> </div> <div *ngIf="!interactive" class="cds--tile__chevron"> <ng-container *ngTemplateOutlet="chevronIcon"></ng-container> </div> <button *ngIf="interactive" class="cds--tile__chevron cds--tile__chevron--interactive" type="button" (click)="onClick()" [attr.aria-expanded]="expanded" [attr.aria-label]="(expanded ? collapse.subject : expand.subject) | async"> <ng-container *ngTemplateOutlet="chevronIcon"></ng-container> </button> <div class="cds--tile-content"> <ng-content select="[cdsBelowFold],[ibmBelowFold],.cds--tile-content__below-the-fold"></ng-content> </div> </div> </ng-template> ` }] }], ctorParameters: function () { return [{ type: i1.I18n }, { type: i0.ElementRef }]; }, propDecorators: { theme: [{ type: Input }], expanded: [{ type: Input }], interactive: [{ type: Input }], translations: [{ type: Input }], tileContainer: [{ type: ViewChild, args: ["container"] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"expandable-tile.component.js","sourceRoot":"","sources":["../../../src/tiles/expandable-tile.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACN,SAAS,EACT,KAAK,EAGL,SAAS,EACT,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,KAAK,EAAE,MAAM,iCAAiC,CAAC;;;;;AAOxD;;;;;;;;GAQG;AA2DH,MAAM,OAAO,cAAc;IAuC1B,YAAsB,IAAU,EAAY,OAAmB;QAAzC,SAAI,GAAJ,IAAI,CAAM;QAAY,YAAO,GAAP,OAAO,CAAY;QAtC/D;;;WAGG;QACM,UAAK,GAAqB,MAAM,CAAC;QAE1C;;WAEG;QACM,aAAQ,GAAG,KAAK,CAAC;QAC1B;;WAEG;QACM,gBAAW,GAAG,KAAK,CAAC;QAmB7B,kBAAa,GAAG,CAAC,CAAC;QAClB,0BAAqB,GAAG,CAAC,CAAC;QAE1B,WAAM,GAAG,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC;QAClD,aAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,gBAAgB,CAAC,CAAC;IAEY,CAAC;IAxBnE;;;;;;;;OAQG;IACH,IACI,YAAY,CAAC,KAAiC;QACjD,MAAM,iBAAiB,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,EAAE,KAAK,CAAC,CAAC;QACvE,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;QAC/C,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC;IACpD,CAAC;IAYD,eAAe;QACd,IAAI,CAAC,eAAe,EAAE,CAAC;IACxB,CAAC;IAED,IAAI,cAAc;QACjB,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC;QACpE,MAAM,WAAW,GACd,QAAQ,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,aAAa,EAAE,EAAE,CAAC,GAAG,QAAQ,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;QACxG,MAAM,cAAc,GAAG,IAAI,CAAC,aAAa,GAAG,WAAW,CAAC;QACxD,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,EAAE;YAC3B,IAAI,CAAC,qBAAqB,GAAG,cAAc,CAAC;SAC5C;QACD,OAAO,IAAI,CAAC,qBAAqB,CAAC;IACnC,CAAC;IAED,eAAe;QACd,IAAI,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,MAAM,CAAC;SACrF;aAAM;YACN,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,aAAa,CAAC,oCAAoC,CAAC,CAAC,qBAAqB,EAAE,CAAC,MAAM,CAAC;SACnI;IACF,CAAC;IAED,OAAO;QACN,IAAI,CAAC,QAAQ,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC;QAC/B,IAAI,CAAC,eAAe,EAAE,CAAC;IACxB,CAAC;;2GAnEW,cAAc;+FAAd,cAAc,wSAxDhB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAsDT;2FAEW,cAAc;kBA1D1B,SAAS;mBAAC;oBACV,QAAQ,EAAE,0CAA0C;oBACpD,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAsDT;iBACD;oHAMS,KAAK;sBAAb,KAAK;gBAKG,QAAQ;sBAAhB,KAAK;gBAIG,WAAW;sBAAnB,KAAK;gBAWF,YAAY;sBADf,KAAK;gBAOkB,aAAa;sBAApC,SAAS;uBAAC,WAAW","sourcesContent":["import {\n\tComponent,\n\tInput,\n\tElementRef,\n\tAfterViewInit,\n\tViewChild\n} from \"@angular/core\";\nimport { I18n } from \"carbon-components-angular/i18n\";\nimport { merge } from \"carbon-components-angular/utils\";\n\nexport interface ExpandableTileTranslations {\n\tEXPAND: string;\n\tCOLLAPSE: string;\n}\n\n/**\n * Get started with importing the module:\n *\n * ```typescript\n * import { TilesModule } from 'carbon-components-angular';\n * ```\n *\n * [See demo](../../?path=/story/components-tiles-expandable--basic)\n */\n@Component({\n\tselector: \"cds-expandable-tile, ibm-expandable-tile\",\n\ttemplate: `\n\t\t<button\n\t\t\t*ngIf=\"!interactive\"\n\t\t\tclass=\"cds--tile cds--tile--expandable\"\n\t\t\t[ngClass]=\"{\n\t\t\t\t'cds--tile--is-expanded' : expanded,\n\t\t\t\t'cds--tile--light': theme === 'light'\n\t\t\t}\"\n\t\t\t[ngStyle]=\"{'max-height': expandedHeight + 'px'}\"\n\t\t\ttype=\"button\"\n\t\t\t(click)=\"onClick()\"\n\t\t\t[attr.aria-expanded]=\"expanded\"\n\t\t\t[attr.title]=\"(expanded ? collapse.subject : expand.subject) | async\">\n\t\t\t\t<ng-container *ngTemplateOutlet=\"expandableTileContent\"></ng-container>\n\t\t</button>\n\n\t\t<div\n\t\t\t*ngIf=\"interactive\"\n\t\t\tclass=\"cds--tile cds--tile--expandable cds--tile--expandable--interactive\"\n\t\t\t[ngClass]=\"{\n\t\t\t\t'cds--tile--is-expanded' : expanded,\n\t\t\t\t'cds--tile--light': theme === 'light'\n\t\t\t}\"\n\t\t\t[ngStyle]=\"{'max-height': expandedHeight + 'px'}\"\n\t\t\t[attr.title]=\"(expanded ? collapse.subject : expand.subject) | async\">\n\t\t\t<ng-container *ngTemplateOutlet=\"expandableTileContent\"></ng-container>\n\t\t</div>\n\n\t\t<ng-template #chevronIcon>\n\t\t\t<svg cdsIcon=\"chevron--down\" size=\"16\"></svg>\n\t\t</ng-template>\n\n\t\t<ng-template #expandableTileContent>\n\t\t\t<div #container>\n\t\t\t\t<div class=\"cds--tile-content\">\n\t\t\t\t\t<ng-content select=\"[cdsAboveFold],[ibmAboveFold],.cds--tile-content__above-the-fold\"></ng-content>\n\t\t\t\t</div>\n\t\t\t\t<div *ngIf=\"!interactive\" class=\"cds--tile__chevron\">\n\t\t\t\t\t<ng-container *ngTemplateOutlet=\"chevronIcon\"></ng-container>\n\t\t\t\t</div>\n\t\t\t\t<button\n\t\t\t\t\t*ngIf=\"interactive\"\n\t\t\t\t\tclass=\"cds--tile__chevron cds--tile__chevron--interactive\"\n\t\t\t\t\ttype=\"button\"\n\t\t\t\t\t(click)=\"onClick()\"\n\t\t\t\t\t[attr.aria-expanded]=\"expanded\"\n\t\t\t\t\t[attr.aria-label]=\"(expanded ? collapse.subject : expand.subject) | async\">\n\t\t\t\t\t<ng-container *ngTemplateOutlet=\"chevronIcon\"></ng-container>\n\t\t\t\t</button>\n\t\t\t\t<div class=\"cds--tile-content\">\n\t\t\t\t\t<ng-content select=\"[cdsBelowFold],[ibmBelowFold],.cds--tile-content__below-the-fold\"></ng-content>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t</ng-template>\n\t`\n})\nexport class ExpandableTile implements AfterViewInit {\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 * Controls the expanded state\n\t */\n\t@Input() expanded = false;\n\t/**\n\t * Controls the interactive state\n\t */\n\t@Input() interactive = false;\n\t/**\n\t * Expects an object that contains some or all of:\n\t * ```\n\t * {\n\t *\t\t\"EXPAND\": \"Expand\",\n\t *\t\t\"COLLAPSE\": \"Collapse\",\n\t * }\n\t * ```\n\t */\n\t@Input()\n\tset translations(value: ExpandableTileTranslations) {\n\t\tconst valueWithDefaults = merge(this.i18n.getMultiple(\"TILES\"), value);\n\t\tthis.expand.override(valueWithDefaults.EXPAND);\n\t\tthis.collapse.override(valueWithDefaults.COLLAPSE);\n\t}\n\n\t@ViewChild(\"container\") tileContainer: ElementRef;\n\n\ttileMaxHeight = 0;\n\tcurrentExpandedHeight = 0;\n\n\texpand = this.i18n.getOverridable(\"TILES.EXPAND\");\n\tcollapse = this.i18n.getOverridable(\"TILES.COLLAPSE\");\n\n\tconstructor(protected i18n: I18n, protected element: ElementRef) {}\n\n\tngAfterViewInit() {\n\t\tthis.updateMaxHeight();\n\t}\n\n\tget expandedHeight() {\n\t\tconst tile = this.element.nativeElement.querySelector(\".cds--tile\");\n\t\tconst tilePadding\n\t\t\t= parseInt(getComputedStyle(tile).paddingBottom, 10) + parseInt(getComputedStyle(tile).paddingTop, 10);\n\t\tconst expandedHeight = this.tileMaxHeight + tilePadding;\n\t\tif (!isNaN(expandedHeight)) {\n\t\t\tthis.currentExpandedHeight = expandedHeight;\n\t\t}\n\t\treturn this.currentExpandedHeight;\n\t}\n\n\tupdateMaxHeight() {\n\t\tif (this.expanded) {\n\t\t\tthis.tileMaxHeight = this.tileContainer.nativeElement.getBoundingClientRect().height;\n\t\t} else {\n\t\t\tthis.tileMaxHeight = this.element.nativeElement.querySelector(\".cds--tile-content__above-the-fold\").getBoundingClientRect().height;\n\t\t}\n\t}\n\n\tonClick() {\n\t\tthis.expanded = !this.expanded;\n\t\tthis.updateMaxHeight();\n\t}\n}\n"]}