carbon-components-angular
Version:
Next generation components
205 lines (199 loc) • 17.8 kB
JavaScript
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"]}