UNPKG

carbon-components-angular

Version:
176 lines 16.6 kB
import { ContentChildren, Directive, HostBinding, Input, Optional, SkipSelf } from "@angular/core"; import { Subscription } from "rxjs"; import { GridService } from "./grid.service"; import * as i0 from "@angular/core"; import * as i1 from "./grid.service"; /** * Get started with importing the module: * * ```typescript * import { GridModule } from 'carbon-components-angular'; * ``` * * [See demo](../../?path=/story/components-grid--basic) */ export class GridDirective { constructor(gridService) { this.gridService = gridService; /** * Set to `true` to condense the grid */ this.condensed = false; /** * Set to `true` to use narrow grid */ this.narrow = false; /** * Set to `true` to use the full width */ this.fullWidth = false; this.cssGridEnabled = false; this.isSubgrid = false; this.subscription = new Subscription(); } /** * Set to `true` to use css grid */ set useCssGrid(enable) { this.cssGridEnabled = enable; this.gridService.updateGridType(enable); } // Flex grid get flexGrid() { return !this.cssGridEnabled; } get flexCondensed() { return !this.cssGridEnabled && this.condensed; } get flexNarrow() { return !this.cssGridEnabled && this.narrow; } get flexFullWidth() { return !this.cssGridEnabled && this.fullWidth; } // CSS Grid get ccsGrid() { return this.cssGridEnabled && !this.isSubgrid; } get ccsCondensed() { return this.cssGridEnabled && !this.isSubgrid && this.condensed; } get ccsNarrow() { return this.cssGridEnabled && !this.isSubgrid && this.narrow; } get ccsFullWidth() { return this.cssGridEnabled && !this.isSubgrid && this.fullWidth; } // CSS Sub Grid get subGrid() { return this.cssGridEnabled && this.isSubgrid; } get subCondensed() { return this.cssGridEnabled && this.isSubgrid && this.condensed; } get subNarrow() { return this.cssGridEnabled && this.isSubgrid && this.narrow; } get subFullWidth() { return this.cssGridEnabled && this.isSubgrid && this.fullWidth; } ngOnInit() { this.subscription = this.gridService.gridObservable.subscribe((isCssGrid) => { this.cssGridEnabled = isCssGrid; }); } // Make all children grids a sub grid set cssGridChildren(list) { if (this.cssGridEnabled) { list.forEach((grid) => { // Prevents initial (parent) grid element from being turned into a subgrid if (grid === this) { return; } grid.isSubgrid = true; }); } } /** * Unsubscribe from Grid Service subscription */ ngOnDestroy() { this.subscription.unsubscribe(); } } GridDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: GridDirective, deps: [{ token: i1.GridService }], target: i0.ɵɵFactoryTarget.Directive }); GridDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.3.0", type: GridDirective, selector: "[cdsGrid], [ibmGrid]", inputs: { condensed: "condensed", narrow: "narrow", fullWidth: "fullWidth", useCssGrid: "useCssGrid" }, host: { properties: { "class.cds--grid": "this.flexGrid", "class.cds--grid--condensed": "this.flexCondensed", "class.cds--grid--narrow": "this.flexNarrow", "class.cds--grid--full-width": "this.flexFullWidth", "class.cds--css-grid": "this.ccsGrid", "class.cds--css-grid--condensed": "this.ccsCondensed", "class.cds--css-grid--narrow": "this.ccsNarrow", "class.cds--css-grid--full-width": "this.ccsFullWidth", "class.cds--subgrid": "this.subGrid", "class.cds--subgrid--condensed": "this.subCondensed", "class.cds--subgrid--narrow": "this.subNarrow", "class.cds--subgrid--wide": "this.subFullWidth" } }, providers: [ { provide: GridService, deps: [[new Optional(), new SkipSelf(), GridService]], useFactory: (parentService) => { return parentService || new GridService(); } } ], queries: [{ propertyName: "cssGridChildren", predicate: GridDirective, descendants: true }], ngImport: i0 }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: GridDirective, decorators: [{ type: Directive, args: [{ selector: "[cdsGrid], [ibmGrid]", providers: [ { provide: GridService, deps: [[new Optional(), new SkipSelf(), GridService]], useFactory: (parentService) => { return parentService || new GridService(); } } ] }] }], ctorParameters: function () { return [{ type: i1.GridService }]; }, propDecorators: { condensed: [{ type: Input }], narrow: [{ type: Input }], fullWidth: [{ type: Input }], useCssGrid: [{ type: Input }], flexGrid: [{ type: HostBinding, args: ["class.cds--grid"] }], flexCondensed: [{ type: HostBinding, args: ["class.cds--grid--condensed"] }], flexNarrow: [{ type: HostBinding, args: ["class.cds--grid--narrow"] }], flexFullWidth: [{ type: HostBinding, args: ["class.cds--grid--full-width"] }], ccsGrid: [{ type: HostBinding, args: ["class.cds--css-grid"] }], ccsCondensed: [{ type: HostBinding, args: ["class.cds--css-grid--condensed"] }], ccsNarrow: [{ type: HostBinding, args: ["class.cds--css-grid--narrow"] }], ccsFullWidth: [{ type: HostBinding, args: ["class.cds--css-grid--full-width"] }], subGrid: [{ type: HostBinding, args: ["class.cds--subgrid"] }], subCondensed: [{ type: HostBinding, args: ["class.cds--subgrid--condensed"] }], subNarrow: [{ type: HostBinding, args: ["class.cds--subgrid--narrow"] }], subFullWidth: [{ type: HostBinding, args: ["class.cds--subgrid--wide"] }], cssGridChildren: [{ type: ContentChildren, args: [GridDirective, { descendants: true }] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid.directive.js","sourceRoot":"","sources":["../../../src/grid/grid.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tContentChildren,\n\tDirective,\n\tHostBinding,\n\tInput,\n\tOnDestroy,\n\tOnInit,\n\tOptional,\n\tQueryList,\n\tSkipSelf\n} from \"@angular/core\";\nimport { Subscription } from \"rxjs\";\nimport { GridService } from \"./grid.service\";\n\n/**\n * Get started with importing the module:\n *\n * ```typescript\n * import { GridModule } from 'carbon-components-angular';\n * ```\n *\n * [See demo](../../?path=/story/components-grid--basic)\n */\n@Directive({\n\tselector: \"[cdsGrid], [ibmGrid]\",\n\tproviders: [\n\t\t{\n\t\t\tprovide: GridService,\n\t\t\tdeps: [[new Optional(), new SkipSelf(), GridService]],\n\t\t\tuseFactory: (parentService: GridService) => {\n\t\t\t\treturn parentService || new GridService();\n\t\t\t}\n\t\t}\n\t]\n})\nexport class GridDirective implements OnInit, OnDestroy {\n\t/**\n\t * Set to `true` to condense the grid\n\t */\n\t@Input() condensed = false;\n\t/**\n\t * Set to `true` to use narrow grid\n\t */\n\t@Input() narrow = false;\n\t/**\n\t * Set to `true` to use the full width\n\t */\n\t@Input() fullWidth = false;\n\t/**\n\t * Set to `true` to use css grid\n\t */\n\t@Input() set useCssGrid(enable: boolean) {\n\t\tthis.cssGridEnabled = enable;\n\t\tthis.gridService.updateGridType(enable);\n\t}\n\n\tprivate cssGridEnabled = false;\n\tprivate isSubgrid = false;\n\tprivate subscription = new Subscription();\n\n\t// Flex grid\n\t@HostBinding(\"class.cds--grid\") get flexGrid() {\n\t\treturn !this.cssGridEnabled;\n\t}\n\t@HostBinding(\"class.cds--grid--condensed\") get flexCondensed() {\n\t\treturn !this.cssGridEnabled && this.condensed;\n\t}\n\t@HostBinding(\"class.cds--grid--narrow\") get flexNarrow() {\n\t\treturn !this.cssGridEnabled && this.narrow;\n\t}\n\t@HostBinding(\"class.cds--grid--full-width\") get flexFullWidth() {\n\t\treturn !this.cssGridEnabled && this.fullWidth;\n\t}\n\n\t// CSS Grid\n\t@HostBinding(\"class.cds--css-grid\") get ccsGrid() {\n\t\treturn this.cssGridEnabled && !this.isSubgrid;\n\t}\n\t@HostBinding(\"class.cds--css-grid--condensed\") get ccsCondensed() {\n\t\treturn this.cssGridEnabled && !this.isSubgrid && this.condensed;\n\t}\n\t@HostBinding(\"class.cds--css-grid--narrow\") get ccsNarrow() {\n\t\treturn this.cssGridEnabled && !this.isSubgrid && this.narrow;\n\t}\n\t@HostBinding(\"class.cds--css-grid--full-width\") get ccsFullWidth() {\n\t\treturn this.cssGridEnabled && !this.isSubgrid && this.fullWidth;\n\t}\n\n\t// CSS Sub Grid\n\t@HostBinding(\"class.cds--subgrid\") get subGrid() {\n\t\treturn this.cssGridEnabled && this.isSubgrid;\n\t}\n\t@HostBinding(\"class.cds--subgrid--condensed\") get subCondensed() {\n\t\treturn this.cssGridEnabled && this.isSubgrid && this.condensed;\n\t}\n\t@HostBinding(\"class.cds--subgrid--narrow\") get subNarrow() {\n\t\treturn this.cssGridEnabled && this.isSubgrid && this.narrow;\n\t}\n\t@HostBinding(\"class.cds--subgrid--wide\") get subFullWidth() {\n\t\treturn this.cssGridEnabled && this.isSubgrid && this.fullWidth;\n\t}\n\n\tconstructor(private gridService: GridService) {}\n\n\tngOnInit() {\n\t\tthis.subscription = this.gridService.gridObservable.subscribe((isCssGrid: boolean) => {\n\t\t\tthis.cssGridEnabled = isCssGrid;\n\t\t});\n\t}\n\n\t// Make all children grids a sub grid\n\t@ContentChildren(GridDirective, { descendants: true }) set cssGridChildren(list: QueryList<GridDirective>) {\n\t\tif (this.cssGridEnabled) {\n\t\t\tlist.forEach((grid) => {\n\t\t\t\t// Prevents initial (parent) grid element from being turned into a subgrid\n\t\t\t\tif (grid === this) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tgrid.isSubgrid = true;\n\t\t\t});\n\t\t}\n\t}\n\n\t/**\n\t * Unsubscribe from Grid Service subscription\n\t */\n\tngOnDestroy() {\n\t\tthis.subscription.unsubscribe();\n\t}\n}\n"]}