import { Component, ViewChild, ViewEncapsulation } from '@angular/core'; import { DataService } from '../../services/data.service'; import { ItemsEnumeration } from '../../items.enum'; import { jqxGridComponent } from 'jqwidgets-framework/jqwidgets-ts/angular_jqxgrid'; import { jqxKanbanComponent } from 'jqwidgets-framework/jqwidgets-ts/angular_jqxkanban'; @Component({ selector: 'taskssel', templateUrl: './tasks.component.html', styleUrls: ['./tasks.component.css'], encapsulation: ViewEncapsulation.None }) export class TasksComponent { @ViewChild('referenceKanbanTasks') myKanban: jqxKanbanComponent; private enumItems = new ItemsEnumeration(); constructor(private _dataServices: DataService) { this._dataServices.getItemData(this.enumItems.taskskanbanvalues) .then(result => { this.source.localdata = result; this.dataAdapter.dataBind(); }) .catch(error => { console.log("Error with 'TasksRecordsComponent'", error); }); } width: string | number = '100%'; height: string | number = 680; theme: string = 'metro'; fields: any[] = [ { name: 'id', type: 'string' }, { name: 'status', map: 'state', type: 'string' }, { name: 'text', map: 'label', type: 'string' }, { name: 'tags', type: 'string' }, { name: 'color', map: 'hex', type: 'string' }, { name: 'resourceId', type: 'number' } ]; source: any = { localData: [], dataType: 'array', dataFields: this.fields }; dataAdapter: any = new jqx.dataAdapter(this.source); resourcesAdapterFunc = (): any => { let resourcesSource = { localData: [ { id: 0, name: 'No name', image: '../assets/styles/images/common.png', common: true }, { id: 1, name: 'Andrew Fuller', image: '../assets/images/andrew.png' }, { id: 2, name: 'Janet Leverling', image: '../assets/images/janet.png' }, { id: 3, name: 'Steven Buchanan', image: '../assets/images/steven.png' }, { id: 4, name: 'Nancy Davolio', image: '../assets/images/nancy.png' }, { id: 5, name: 'Michael Buchanan', image: '../assets/images/michael.png' }, { id: 6, name: 'Margaret Buchanan', image: '../assets/images/margaret.png' }, { id: 7, name: 'Robert Buchanan', image: '../assets/images/robert.png' }, { id: 8, name: 'Laura Buchanan', image: '../assets/images/laura.png' }, { id: 9, name: 'Laura Buchanan', image: '../assets/images/anne.png' } ], dataType: 'array', dataFields: [ { name: 'id', type: 'number' }, { name: 'name', type: 'string' }, { name: 'image', type: 'string' }, { name: 'common', type: 'boolean' } ] }; let resourcesDataAdapter = new jqx.dataAdapter(resourcesSource); return resourcesDataAdapter; } getIconClassName = (): string => { switch (this.theme) { case 'darkblue': case 'black': case 'shinyblack': case 'ui-le-frog': case 'metrodark': case 'orange': case 'darkblue': case 'highcontrast': case 'ui-sunny': case 'ui-darkness': return 'jqx-icon-plus-alt-white '; } return 'jqx-icon-plus-alt'; } columns: any[] = [ { text: 'Backlog', iconClassName: this.getIconClassName(), dataField: 'new', maxItems: 4 }, { text: 'In Progress', iconClassName: this.getIconClassName(), dataField: 'work', maxItems: 2 }, { text: 'Done', iconClassName: this.getIconClassName(), dataField: 'done', maxItems: 5 } ]; template: string = '