UNPKG

jqwidgets-framework

Version:

jQWidgets is an advanced Angular, Vue, Blazor, React, Web Components, jquery, ASP .NET MVC, Custom Elements and HTML5 UI framework.

134 lines (118 loc) 5.09 kB
import { Component, ViewChild, ElementRef } from '@angular/core'; @Component({ selector: 'app-root', templateUrl: './app.component.html' }) export class AppComponent { @ViewChild('myLog', { static: false }) myLog: ElementRef; log: any[] = []; 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: [ { id: '1161', state: 'new', label: 'Make a new Dashboard', tags: 'dashboard', hex: '#36c7d0', resourceId: 3 }, { id: '1645', state: 'work', label: 'Prepare new release', tags: 'release', hex: '#ff7878', resourceId: 1 }, { id: '9213', state: 'new', label: 'One item added to the cart', tags: 'cart', hex: '#96c443', resourceId: 3 }, { id: '6546', state: 'done', label: 'Edit Item Price', tags: 'price, edit', hex: '#ff7878', resourceId: 4 }, { id: '9034', state: 'new', label: 'Login 404 issue', tags: 'issue, login', hex: '#96c443' } ], dataType: 'array', dataFields: this.fields }; getWidth() : any { if (document.body.offsetWidth < 850) { return '90%'; } return 850; } dataAdapter: any = new jqx.dataAdapter(this.source); resourcesAdapterFunc = (): any => { let resourcesSource = { localData: [ { id: 0, name: 'No name', image: './../../../jqwidgets/styles/images/common.png', common: true }, { id: 1, name: 'Andrew Fuller', image: './../../../images/andrew.png' }, { id: 2, name: 'Janet Leverling', image: './../../../images/janet.png' }, { id: 3, name: 'Steven Buchanan', image: './../../../images/steven.png' }, { id: 4, name: 'Nancy Davolio', image: './../../../images/nancy.png' }, { id: 5, name: 'Michael Buchanan', image: './../../../images/Michael.png' }, { id: 6, name: 'Margaret Buchanan', image: './../../../images/margaret.png' }, { id: 7, name: 'Robert Buchanan', image: './../../../images/robert.png' }, { id: 8, name: 'Laura Buchanan', image: './../../../images/Laura.png' }, { id: 9, name: 'Laura Buchanan', image: './../../../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; } columns: any[] = [ { text: 'Backlog', dataField: 'new' }, { text: 'In Progress', dataField: 'work' }, { text: 'Done', dataField: 'done' } ]; updateLog(): void { let count = 0; let str = ''; for (let i = this.log.length - 1; i >= 0; i--) { str += this.log[i] + '<br/>'; count++; if (count > 10) break; } this.myLog.nativeElement.innerHTML = str; } myKanbanOnItemMoved(event: any): void { let args = event.args; let itemId = args.itemId; let oldParentId = args.oldParentId; let newParentId = args.newParentId; let itemData = args.itemData; let oldColumn = args.oldColumn; let newColumn = args.newColumn; this.log.push('itemMoved is raised'); this.updateLog(); }; myKanbanOnColumnCollapsed(event: any): void { let args = event.args; let column = args.column; this.log.push('columnCollapsed is raised'); this.updateLog(); }; myKanbanOnColumnExpanded(event: any): void { let args = event.args; let column = args.column; this.log.push('columnExpanded is raised'); this.updateLog(); }; myKanbanOnItemAttrClicked(event: any): void { let args = event.args; let itemId = args.itemId; let attribute = args.attribute; // template, colorStatus, content, keyword, text, avatar this.log.push('itemAttrClicked is raised'); this.updateLog(); }; myKanbanOnColumnAttrClicked(event: any): void { let args = event.args; let column = args.column; let cancelToggle = args.cancelToggle; // false by default. Set to true to cancel toggling dynamically. let attribute = args.attribute; // title, button this.log.push('columnAttrClicked is raised'); this.updateLog(); }; }