jqwidgets-framework
Version:
jQWidgets is an advanced Angular, Vue, Blazor, React, Web Components, jquery, ASP .NET MVC, Custom Elements and HTML5 UI framework.
60 lines (50 loc) • 2.12 kB
text/typescript
import { Component, ViewChild, AfterViewInit, ElementRef } from '@angular/core';
import { jqxComboBoxComponent } from 'jqwidgets-ng/jqxcombobox';
({
selector: 'app-root',
templateUrl: './app.component.html'
})
export class AppComponent implements AfterViewInit {
('myComboBox', { static: false }) myComboBox: jqxComboBoxComponent;
('selectionlog', { static: false }) selectionlog: ElementRef;
('checkedItemsLog', { static: false }) checkedItemsLog: ElementRef;
ngAfterViewInit(): void {
this.myComboBox.checkIndex(0)
}
source: any =
{
datatype: 'json',
datafields: [
{ name: 'CompanyName' },
{ name: 'ContactName' }
],
id: 'id',
url: './../../../sampledata/customers.txt',
async: false
};
dataAdapter: any = new jqx.dataAdapter(this.source);
myComboBoxOnCheckChange(event: any): void {
if (event.args) {
let item = event.args.item;
if (item) {
let valueElement = document.createElement('div');
valueElement.innerHTML = 'Value: ' + item.value;
let labelElement = document.createElement('div');
labelElement.innerHTML = 'Label: ' + item.label;
let checkedElement = document.createElement('div');
checkedElement.innerHTML = 'Checked: ' + item.checked;
let selectionLog = this.selectionlog.nativeElement;
selectionLog.innerHTML = '';
selectionLog.appendChild(labelElement);
selectionLog.appendChild(valueElement);
selectionLog.appendChild(checkedElement);
let items = this.myComboBox.getCheckedItems();
let checkedItems = '';
for (let obj of items) {
checkedItems += obj.label + ', ';
}
this.checkedItemsLog.nativeElement.innerHTML = checkedItems;
}
}
};
}