carbon-components-angular
Version:
Next generation components
176 lines • 16.6 kB
JavaScript
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"]}