@netgrif/components-core
Version:
Netgrif Application engine frontend core Angular library
132 lines • 22.8 kB
JavaScript
import { Component, Inject, Optional } from "@angular/core";
import { TaskRefDashboardConstants } from "../model/task-ref-dashboard-constants";
import { TaskRefDashboardTileConstants } from "../model/task-ref-dashboard-tile-constants";
import { AbstractBaseDataFieldComponent } from "../../base-component/abstract-base-data-field.component";
import { DATA_FIELD_PORTAL_DATA } from "../../models/data-field-portal-data-injection-token";
import * as i0 from "@angular/core";
import * as i1 from "../../../logger/services/logger.service";
export class AbstractTaskRefDashboardFieldComponent extends AbstractBaseDataFieldComponent {
_logger;
dashboardTiles;
constructor(_logger, dataFieldPortalData) {
super(dataFieldPortalData);
this._logger = _logger;
}
ngOnInit() {
this.createDashboardTiles();
}
createDashboardTiles() {
const gridRows = this.dataField.dashboardRows;
if (gridRows === undefined) {
this._logger.error(`TaskRef Dashboard '${this.dataField.stringId}' does not specify grid height! Add a number field with id '${TaskRefDashboardConstants.DASHBOARD_ROWS}' to the same task as the task ref field, to specify the height.`);
}
const gridCols = this.dataField.dashboardCols;
if (gridCols === undefined) {
this._logger.error(`TaskRef Dashboard '${this.dataField.stringId}' does not specify grid width! Add a number field with id '${TaskRefDashboardConstants.DASHBOARD_COLS}' to the same task as the task ref field, to specify the width.`);
}
const occupiedTiles = this.createFlagGrid(gridRows, gridCols);
this.dashboardTiles = [];
if (this.dataField.dashboardTiles && this.dataField.dashboardTiles.length > 0) {
for (const extractedTile of this.dataField.dashboardTiles) {
const tile = this.createDashboardTile(extractedTile);
this.dashboardTiles.push(tile);
this.occupySpace(occupiedTiles, tile.y, tile.x, tile.cols, tile.rows);
}
}
for (let y = 0; y < occupiedTiles.length; y++) {
for (let x = 0; x < occupiedTiles[y].length; x++) {
if (!occupiedTiles[y][x]) {
this.dashboardTiles.push(this.createEmptyDashboardTile(x, y));
}
}
}
}
createFlagGrid(rows = 1, cols = 1) {
const result = [];
for (let r = 0; r < rows; r++) {
result.push(Array(cols).fill(false));
}
return result;
}
createDashboardTile(tile) {
const result = {
dataGroups: tile.dataGroups
};
for (const dg of tile.dataGroups) {
for (const field of dg.fields) {
switch (field.stringId) {
case TaskRefDashboardTileConstants.DASHBOARD_TILE_X:
result.x = field.value;
break;
case TaskRefDashboardTileConstants.DASHBOARD_TILE_Y:
result.y = field.value;
break;
case TaskRefDashboardTileConstants.DASHBOARD_TILE_ROWS:
result.rows = field.value;
break;
case TaskRefDashboardTileConstants.DASHBOARD_TILE_COLS:
result.cols = field.value;
break;
}
}
}
if (result.x === undefined) {
if (tile.dataGroups.length > 0) {
this._logger.error(`Task ref dashboard tile from task '${tile.dataGroups[0].parentTaskId}' transition '${tile.dataGroups[0].parentTransitionId}' case '${tile.dataGroups[0].parentCaseId}' does not specify tile grid X coordinate! Add a number field with ID '${TaskRefDashboardTileConstants.DASHBOARD_TILE_X}' to the referenced task to specify it.`);
}
result.x = 0;
}
if (result.y === undefined) {
if (tile.dataGroups.length > 0) {
this._logger.error(`Task ref dashboard tile from task '${tile.dataGroups[0].parentTaskId}' transition '${tile.dataGroups[0].parentTransitionId}' case '${tile.dataGroups[0].parentCaseId}' does not specify tile grid Y coordinate! Add a number field with ID '${TaskRefDashboardTileConstants.DASHBOARD_TILE_Y}' to the referenced task to specify it.`);
}
result.y = 0;
}
if (result.rows === undefined) {
if (tile.dataGroups.length > 0) {
this._logger.error(`Task ref dashboard tile from task '${tile.dataGroups[0].parentTaskId}' transition '${tile.dataGroups[0].parentTransitionId}' case '${tile.dataGroups[0].parentCaseId}' does not specify tile height coordinate! Add a number field with ID '${TaskRefDashboardTileConstants.DASHBOARD_TILE_ROWS}' to the referenced task to specify it.`);
}
result.rows = 1;
}
if (result.cols === undefined) {
if (tile.dataGroups.length > 0) {
this._logger.error(`Task ref dashboard tile from task '${tile.dataGroups[0].parentTaskId}' transition '${tile.dataGroups[0].parentTransitionId}' case '${tile.dataGroups[0].parentCaseId}' does not specify tile width coordinate! Add a number field with ID '${TaskRefDashboardTileConstants.DASHBOARD_TILE_COLS}' to the referenced task to specify it.`);
}
result.cols = 1;
}
return result;
}
// TODO a modified copy of a method of the same name from AbstractTaskContentComponent
occupySpace(grid, y, x, width, height) {
for (let j = y; j < y + height; j++) {
for (let i = x; i < x + width; i++) {
grid[j][i] = true;
}
}
}
createEmptyDashboardTile(x, y) {
return {
dataGroups: [],
x,
y,
rows: 1,
cols: 1,
isEmpty: true
};
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractTaskRefDashboardFieldComponent, deps: [{ token: i1.LoggerService }, { token: DATA_FIELD_PORTAL_DATA, optional: true }], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AbstractTaskRefDashboardFieldComponent, selector: "ncc-abstract-task-ref-dashboard", usesInheritance: true, ngImport: i0, template: '', isInline: true });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractTaskRefDashboardFieldComponent, decorators: [{
type: Component,
args: [{
selector: 'ncc-abstract-task-ref-dashboard',
template: ''
}]
}], ctorParameters: () => [{ type: i1.LoggerService }, { type: undefined, decorators: [{
type: Optional
}, {
type: Inject,
args: [DATA_FIELD_PORTAL_DATA]
}] }] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-task-ref-dashboard-field.component.js","sourceRoot":"","sources":["../../../../../../../projects/netgrif-components-core/src/lib/data-fields/task-ref-field/task-ref-dashboard-field/abstract-task-ref-dashboard-field.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, Inject, OnInit, Optional} from \"@angular/core\";\nimport {TaskRefField} from \"../model/task-ref-field\";\nimport {TaskRefDashboardTile} from \"../model/task-ref-dashboard-tile\";\nimport {LoggerService} from \"../../../logger/services/logger.service\";\nimport {TaskRefDashboardConstants} from \"../model/task-ref-dashboard-constants\";\nimport {TaskRefDashboardTileConstants} from \"../model/task-ref-dashboard-tile-constants\";\nimport {AbstractBaseDataFieldComponent} from \"../../base-component/abstract-base-data-field.component\";\nimport {DATA_FIELD_PORTAL_DATA, DataFieldPortalData} from \"../../models/data-field-portal-data-injection-token\";\n\n@Component({\n    selector: 'ncc-abstract-task-ref-dashboard',\n    template: ''\n})\nexport abstract class AbstractTaskRefDashboardFieldComponent extends AbstractBaseDataFieldComponent<TaskRefField> implements OnInit {\n\n    dashboardTiles: Array<TaskRefDashboardTile>;\n    protected constructor(protected _logger: LoggerService,\n                          @Optional() @Inject(DATA_FIELD_PORTAL_DATA) dataFieldPortalData: DataFieldPortalData<TaskRefField>) {\n        super(dataFieldPortalData);\n    }\n\n    ngOnInit() {\n        this.createDashboardTiles();\n    }\n\n    protected createDashboardTiles() {\n        const gridRows = this.dataField.dashboardRows;\n        if (gridRows === undefined) {\n            this._logger.error(`TaskRef Dashboard '${this.dataField.stringId}' does not specify grid height! Add a number field with id '${TaskRefDashboardConstants.DASHBOARD_ROWS}' to the same task as the task ref field, to specify the height.`);\n        }\n        const gridCols = this.dataField.dashboardCols;\n        if (gridCols === undefined) {\n            this._logger.error(`TaskRef Dashboard '${this.dataField.stringId}' does not specify grid width! Add a number field with id '${TaskRefDashboardConstants.DASHBOARD_COLS}' to the same task as the task ref field, to specify the width.`);\n        }\n        const occupiedTiles = this.createFlagGrid(gridRows, gridCols);\n        this.dashboardTiles = [];\n        if (this.dataField.dashboardTiles && this.dataField.dashboardTiles.length > 0) {\n            for (const extractedTile of this.dataField.dashboardTiles) {\n                const tile = this.createDashboardTile(extractedTile);\n                this.dashboardTiles.push(tile);\n                this.occupySpace(occupiedTiles, tile.y, tile.x, tile.cols, tile.rows);\n            }\n        }\n        for (let y = 0; y < occupiedTiles.length; y++) {\n            for (let x = 0; x < occupiedTiles[y].length; x++) {\n                if (!occupiedTiles[y][x]) {\n                    this.dashboardTiles.push(this.createEmptyDashboardTile(x, y));\n                }\n            }\n        }\n    }\n\n    protected createFlagGrid(rows: number = 1, cols: number = 1): Array<Array<boolean>> {\n        const result = [];\n        for (let r = 0; r < rows; r++) {\n            result.push(Array(cols).fill(false));\n        }\n        return result;\n    }\n\n    protected createDashboardTile(tile: TaskRefDashboardTile): TaskRefDashboardTile {\n        const result: TaskRefDashboardTile = {\n            dataGroups: tile.dataGroups\n        };\n\n        for (const dg of tile.dataGroups) {\n            for (const field of dg.fields) {\n                switch (field.stringId) {\n                    case TaskRefDashboardTileConstants.DASHBOARD_TILE_X:\n                        result.x = field.value;\n                        break;\n                    case TaskRefDashboardTileConstants.DASHBOARD_TILE_Y:\n                        result.y = field.value;\n                        break;\n                    case TaskRefDashboardTileConstants.DASHBOARD_TILE_ROWS:\n                        result.rows = field.value;\n                        break;\n                    case TaskRefDashboardTileConstants.DASHBOARD_TILE_COLS:\n                        result.cols = field.value;\n                        break;\n\n                }\n            }\n        }\n\n        if (result.x === undefined) {\n            if (tile.dataGroups.length > 0) {\n                this._logger.error(`Task ref dashboard tile from task '${tile.dataGroups[0].parentTaskId}' transition '${tile.dataGroups[0].parentTransitionId}' case '${tile.dataGroups[0].parentCaseId}' does not specify tile grid X coordinate! Add a number field with ID '${TaskRefDashboardTileConstants.DASHBOARD_TILE_X}' to the referenced task to specify it.`);\n            }\n            result.x = 0;\n        }\n        if (result.y === undefined) {\n            if (tile.dataGroups.length > 0) {\n                this._logger.error(`Task ref dashboard tile from task '${tile.dataGroups[0].parentTaskId}' transition '${tile.dataGroups[0].parentTransitionId}' case '${tile.dataGroups[0].parentCaseId}' does not specify tile grid Y coordinate! Add a number field with ID '${TaskRefDashboardTileConstants.DASHBOARD_TILE_Y}' to the referenced task to specify it.`);\n            }\n            result.y = 0;\n        }\n        if (result.rows === undefined) {\n            if (tile.dataGroups.length > 0) {\n                this._logger.error(`Task ref dashboard tile from task '${tile.dataGroups[0].parentTaskId}' transition '${tile.dataGroups[0].parentTransitionId}' case '${tile.dataGroups[0].parentCaseId}' does not specify tile height coordinate! Add a number field with ID '${TaskRefDashboardTileConstants.DASHBOARD_TILE_ROWS}' to the referenced task to specify it.`);\n            }\n            result.rows = 1;\n        }\n        if (result.cols === undefined) {\n            if (tile.dataGroups.length > 0) {\n                this._logger.error(`Task ref dashboard tile from task '${tile.dataGroups[0].parentTaskId}' transition '${tile.dataGroups[0].parentTransitionId}' case '${tile.dataGroups[0].parentCaseId}' does not specify tile width coordinate! Add a number field with ID '${TaskRefDashboardTileConstants.DASHBOARD_TILE_COLS}' to the referenced task to specify it.`);\n            }\n            result.cols = 1;\n        }\n\n        return result;\n    }\n\n    // TODO a modified copy of a method of the same name from AbstractTaskContentComponent\n    protected occupySpace(grid: Array<Array<boolean>>, y: number, x: number, width: number, height: number) {\n        for (let j = y; j < y + height; j++) {\n            for (let i = x; i < x + width; i++) {\n                grid[j][i] = true;\n            }\n        }\n    }\n\n    protected createEmptyDashboardTile(x: number, y: number): TaskRefDashboardTile {\n        return {\n            dataGroups: [],\n            x,\n            y,\n            rows: 1,\n            cols: 1,\n            isEmpty: true\n        }\n    }\n}\n"]}