UNPKG

carbon-components-angular

Version:
165 lines 18.6 kB
import { Directive, HostBinding, Input, Optional } from "@angular/core"; import { Subscription } from "rxjs"; import * as i0 from "@angular/core"; import * as i1 from "./grid.service"; export class ColumnDirective { constructor(gridService) { this.gridService = gridService; this.class = ""; /** * Defines columns width for specified breakpoint * Accepts the following formats: * - {[breakpoint]: number} * - {[breakpoint]: "auto"} - css only * - {[breakpoint]: {[start|end]: number}} - css only * * Example: * <div cdsCol [columnNumbers]={md: 3, lg: 4}></div> */ this.columnNumbers = {}; /** * Defines columns offset, which increases the left margin of the column. * This field will only work with flexbox grid. * * Accepts the following formats: * - {[breakpoint]: number} * * Example: * <div cdsCol [offsets]={md: 3, lg: 4}></div> */ this.offsets = {}; /** * Set to `true` to use css grid column hang class * This will only work when `isCss` property is set to true * * Useful when trying to align content across css grid/subgrid */ this.columnHang = false; this._columnClasses = []; this.isCssGrid = false; this.subscription = new Subscription(); } get columnClasses() { return this._columnClasses.join(" "); } set columnClasses(classes) { this._columnClasses = classes.split(" "); } ngOnInit() { if (this.gridService) { this.subscription = this.gridService.gridObservable.subscribe((isCssGrid) => { this.isCssGrid = isCssGrid; this.updateColumnClasses(); }); } else { this.updateColumnClasses(); } } ngOnChanges() { this.updateColumnClasses(); } /** * Unsubscribe from subscription */ ngOnDestroy() { this.subscription.unsubscribe(); } updateColumnClasses() { try { this._columnClasses = []; const columnKeys = Object.keys(this.columnNumbers); // Assign classes based on the type of grid used. if (this.isCssGrid) { // Default css grid class this._columnClasses.push("cds--css-grid-column"); if (this.columnHang) { this._columnClasses.push("cds--grid-column-hang"); } columnKeys.forEach(key => { /** * Passing in `auto` to a breakpoint as such: {'md': 'auto'} * will assign the element which will automatically determine the width of the column * for the breakpoint passed */ if (this.columnNumbers[key] === "auto") { this._columnClasses.push(`cds--${key}:col-span-auto`); } else if (typeof this.columnNumbers[key] === "object") { /** * In css grid, objects can be passed to the keys in the following format: * {'md': {'start': 3}} * * These objects are used to position the column */ if (this.columnNumbers[key]["start"]) { // col-start is simular equivalent of flex offset this._columnClasses.push(`cds--${key}:col-start-${this.columnNumbers[key].start}`); } if (this.columnNumbers[key]["end"]) { this._columnClasses.push(`cds--${key}:col-end-${this.columnNumbers[key].end}`); } if (this.columnNumbers[key]["span"]) { this._columnClasses.push(`cds--${key}:col-span-${this.columnNumbers[key].span}`); } } else { this._columnClasses.push(`cds--${key}:col-span-${this.columnNumbers[key]}`); } }); Object.keys(this.offsets).forEach(key => { this._columnClasses.push(`cds--${key}:col-start-${this.offsets[key]}`); }); } else { // Set column classes for flex grid if (columnKeys.length <= 0) { this._columnClasses.push("cds--col"); } columnKeys.forEach(key => { if (this.columnNumbers[key] === "nobreak") { this._columnClasses.push(`cds--col-${key}`); } else { this._columnClasses.push(`cds--col-${key}-${this.columnNumbers[key]}`); } }); Object.keys(this.offsets).forEach(key => { this._columnClasses.push(`cds--offset-${key}-${this.offsets[key]}`); }); } } catch (err) { console.error(`Malformed \`offsets\` or \`columnNumbers\`: ${err}`); } /** * Append the classes passed so they aren't overriden when we set the column classes * from host binding */ if (this.class) { this._columnClasses.push(this.class); } } } ColumnDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ColumnDirective, deps: [{ token: i1.GridService, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); ColumnDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.3.0", type: ColumnDirective, selector: "[cdsCol], [ibmCol]", inputs: { class: "class", columnNumbers: "columnNumbers", offsets: "offsets", columnHang: "columnHang" }, host: { properties: { "class": "this.columnClasses" } }, usesOnChanges: true, ngImport: i0 }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ColumnDirective, decorators: [{ type: Directive, args: [{ selector: "[cdsCol], [ibmCol]" }] }], ctorParameters: function () { return [{ type: i1.GridService, decorators: [{ type: Optional }] }]; }, propDecorators: { columnClasses: [{ type: HostBinding, args: ["class"] }], class: [{ type: Input }], columnNumbers: [{ type: Input }], offsets: [{ type: Input }], columnHang: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"column.directive.js","sourceRoot":"","sources":["../../../src/grid/column.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tDirective,\n\tHostBinding,\n\tInput,\n\tOnChanges,\n\tOnDestroy,\n\tOnInit,\n\tOptional\n} from \"@angular/core\";\nimport { Subscription } from \"rxjs\";\nimport { GridService } from \"./grid.service\";\n\n@Directive({\n\tselector: \"[cdsCol], [ibmCol]\"\n})\nexport class ColumnDirective implements OnInit, OnChanges, OnDestroy {\n\t@HostBinding(\"class\")\n\tget columnClasses(): string {\n\t\treturn this._columnClasses.join(\" \");\n\t}\n\tset columnClasses(classes: string) {\n\t\tthis._columnClasses = classes.split(\" \");\n\t}\n\n\t@Input() class = \"\";\n\n\t/**\n\t * Defines columns width for specified breakpoint\n\t * Accepts the following formats:\n\t * - {[breakpoint]: number}\n\t * - {[breakpoint]: \"auto\"} - css only\n\t * - {[breakpoint]: {[start|end]: number}} - css only\n\t *\n\t * Example:\n\t * <div cdsCol [columnNumbers]={md: 3, lg: 4}></div>\n\t */\n\t@Input() columnNumbers = {};\n\n\t/**\n\t * Defines columns offset, which increases the left margin of the column.\n\t * This field will only work with flexbox grid.\n\t *\n\t * Accepts the following formats:\n\t * - {[breakpoint]: number}\n\t *\n\t * Example:\n\t * <div cdsCol [offsets]={md: 3, lg: 4}></div>\n\t */\n\t@Input() offsets = {};\n\n\t/**\n\t * Set to `true` to use css grid column hang class\n\t * This will only work when `isCss` property is set to true\n\t *\n\t * Useful when trying to align content across css grid/subgrid\n\t */\n\t@Input() columnHang = false;\n\n\tprotected _columnClasses: string[] = [];\n\n\tprivate isCssGrid = false;\n\tprivate subscription = new Subscription();\n\n\tconstructor(@Optional() private gridService: GridService) {}\n\n\tngOnInit() {\n\t\tif (this.gridService) {\n\t\t\tthis.subscription = this.gridService.gridObservable.subscribe((isCssGrid: boolean) => {\n\t\t\t\tthis.isCssGrid = isCssGrid;\n\t\t\t\tthis.updateColumnClasses();\n\t\t\t});\n\t\t} else {\n\t\t\tthis.updateColumnClasses();\n\t\t}\n\t}\n\n\tngOnChanges() {\n\t\tthis.updateColumnClasses();\n\t}\n\n\t/**\n\t * Unsubscribe from subscription\n\t */\n\tngOnDestroy() {\n\t\tthis.subscription.unsubscribe();\n\t}\n\n\tprivate updateColumnClasses() {\n\t\ttry {\n\t\t\tthis._columnClasses = [];\n\t\t\tconst columnKeys = Object.keys(this.columnNumbers);\n\n\t\t\t// Assign classes based on the type of grid used.\n\t\t\tif (this.isCssGrid) {\n\t\t\t\t// Default css grid class\n\t\t\t\tthis._columnClasses.push(\"cds--css-grid-column\");\n\t\t\t\tif (this.columnHang) {\n\t\t\t\t\tthis._columnClasses.push(\"cds--grid-column-hang\");\n\t\t\t\t}\n\n\t\t\t\tcolumnKeys.forEach(key => {\n\t\t\t\t\t/**\n\t\t\t\t\t * Passing in `auto` to a breakpoint as such: {'md': 'auto'}\n\t\t\t\t\t * will assign the element which will automatically determine the width of the column\n\t\t\t\t\t * for the breakpoint passed\n\t\t\t\t\t */\n\t\t\t\t\tif (this.columnNumbers[key] === \"auto\") {\n\t\t\t\t\t\tthis._columnClasses.push(`cds--${key}:col-span-auto`);\n\t\t\t\t\t} else if (typeof this.columnNumbers[key] === \"object\") {\n\t\t\t\t\t\t/**\n\t\t\t\t\t\t * In css grid, objects can be passed to the keys in the following format:\n\t\t\t\t\t\t * {'md': {'start': 3}}\n\t\t\t\t\t\t *\n\t\t\t\t\t\t * These objects are used to position the column\n\t\t\t\t\t\t */\n\t\t\t\t\t\tif (this.columnNumbers[key][\"start\"]) {\n\t\t\t\t\t\t\t// col-start is simular equivalent of flex offset\n\t\t\t\t\t\t\tthis._columnClasses.push(`cds--${key}:col-start-${this.columnNumbers[key].start}`);\n\t\t\t\t\t\t}\n\t\t\t\t\t\tif (this.columnNumbers[key][\"end\"]) {\n\t\t\t\t\t\t\tthis._columnClasses.push(`cds--${key}:col-end-${this.columnNumbers[key].end}`);\n\t\t\t\t\t\t}\n\t\t\t\t\t\tif (this.columnNumbers[key][\"span\"]) {\n\t\t\t\t\t\t\tthis._columnClasses.push(`cds--${key}:col-span-${this.columnNumbers[key].span}`);\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthis._columnClasses.push(`cds--${key}:col-span-${this.columnNumbers[key]}`);\n\t\t\t\t\t}\n\t\t\t\t});\n\n\t\t\t\tObject.keys(this.offsets).forEach(key => {\n\t\t\t\t\tthis._columnClasses.push(`cds--${key}:col-start-${this.offsets[key]}`);\n\t\t\t\t});\n\t\t\t} else {\n\t\t\t\t// Set column classes for flex grid\n\t\t\t\tif (columnKeys.length <= 0) {\n\t\t\t\t\tthis._columnClasses.push(\"cds--col\");\n\t\t\t\t}\n\n\t\t\t\tcolumnKeys.forEach(key => {\n\t\t\t\t\tif (this.columnNumbers[key] === \"nobreak\") {\n\t\t\t\t\t\tthis._columnClasses.push(`cds--col-${key}`);\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthis._columnClasses.push(`cds--col-${key}-${this.columnNumbers[key]}`);\n\t\t\t\t\t}\n\t\t\t\t});\n\n\t\t\t\tObject.keys(this.offsets).forEach(key => {\n\t\t\t\t\tthis._columnClasses.push(`cds--offset-${key}-${this.offsets[key]}`);\n\t\t\t\t});\n\t\t\t}\n\t\t} catch (err) {\n\t\t\tconsole.error(`Malformed \\`offsets\\` or \\`columnNumbers\\`: ${err}`);\n\t\t}\n\n\t\t/**\n\t\t * Append the classes passed so they aren't overriden when we set the column classes\n\t\t * from host binding\n\t\t */\n\t\tif (this.class) {\n\t\t\tthis._columnClasses.push(this.class);\n\t\t}\n\t}\n}\n"]}