Your search did not match any results.
Documentation

The DropDownBox widget is an editor that consists of a text field and drop-down content. The content can be anything. In this demo, it is the TreeView widget and the DataGrid widget. This demo also illustrates how to implement single selection and how to synchronize the DropDownBox with the nested widgets.The DropDownBox widget is an editor that consists of a text field and drop-down content. The content can be anything. In this demo, it is the TreeView widget and the DataGrid widget. This demo also illustrates how to implement single selection and how to synchronize the DropDownBox with the nested widgets.

Copy to Plunker
Apply
Reset
<div class="dx-fieldset"> <div class="dx-field"> <div class="dx-field-label">DropDownBox with embedded TreeView</div> <div class="dx-field-value"> <dx-drop-down-box [(value)]="treeBoxValue" valueExpr="ID" displayExpr="name" placeholder="Select a value..." [showClearButton]="true" [dataSource]="treeDataSource" (onValueChanged)="syncTreeViewSelection($event)" > <div *dxTemplate="let data of 'content'"> <dx-tree-view [dataSource]="treeDataSource" dataStructure="plain" keyExpr="ID" parentIdExpr="categoryId" selectionMode="single" displayExpr="name" [selectByClick]="true" (onContentReady)="$event.component.selectItem(treeBoxValue)" (onItemSelectionChanged)="treeView_itemSelectionChanged($event)" > </dx-tree-view> </div> </dx-drop-down-box> </div> </div> <div class="dx-field"> <div class="dx-field-label">DropDownBox with embedded DataGrid</div> <div class="dx-field-value"> <dx-drop-down-box [(value)]="gridBoxValue" valueExpr="ID" [displayExpr]="gridBox_displayExpr" placeholder="Select a value..." [showClearButton]="true" [dataSource]="gridDataSource" > <div *dxTemplate="let data of 'content'"> <dx-data-grid [dataSource]="gridDataSource" [columns]="['CompanyName', 'City', 'Phone']" [selection]="{ mode: 'single' }" [hoverStateEnabled]="true" [paging]="{ enabled: true, pageSize: 10 }" [filterRow]="{ visible: true }" [scrolling]="{ mode: 'infinite' }" [height]="345" [(selectedRowKeys)]="gridSelectedRowKeys" > </dx-data-grid> </div> </dx-drop-down-box> </div> </div> </div>
import { NgModule, Component, ViewChild, Inject, enableProdMode } from '@angular/core'; import { BrowserModule } from '@angular/platform-browser'; import { platformBrowserDynamic } from '@angular/platform-browser-dynamic'; import { Http, HttpModule } from '@angular/http'; import 'rxjs/add/operator/toPromise'; import { DxDropDownBoxModule, DxTreeViewModule, DxDataGridModule, DxTreeViewComponent } from 'devextreme-angular'; import CustomStore from 'devextreme/data/custom_store'; if(!/localhost/.test(document.location.host)) { enableProdMode(); } @Component({ selector: 'demo-app', templateUrl: 'app/app.component.html', styleUrls: ['app/app.component.css'] }) export class AppComponent { @ViewChild(DxTreeViewComponent) treeView; treeDataSource: any; treeBoxValue: string; gridDataSource: any; _gridBoxValue: number = 3; _gridSelectedRowKeys: number[] = [3]; constructor(@Inject(Http) http: Http) { this.treeDataSource = this.makeAsyncDataSource(http, "treeProducts.json"); this.gridDataSource = this.makeAsyncDataSource(http, "customers.json"); this.treeBoxValue = "1_1"; } makeAsyncDataSource(http, jsonFile){ return new CustomStore({ loadMode: "raw", key: "ID", load: function() { return http.get('../../../../data/' + jsonFile) .toPromise() .then(response => { return response.json(); }); } }); }; syncTreeViewSelection() { if (!this.treeView) return; if (!this.treeBoxValue) { this.treeView.instance.unselectAll(); } else { this.treeView.instance.selectItem(this.treeBoxValue); } } treeView_itemSelectionChanged(e){ this.treeBoxValue = e.component.getSelectedNodesKeys(); } get gridBoxValue(): number { return this._gridBoxValue; } set gridBoxValue(value: number) { this._gridSelectedRowKeys = value && [value] || []; this._gridBoxValue = value; } get gridSelectedRowKeys(): number[] { return this._gridSelectedRowKeys; } set gridSelectedRowKeys(value: number[]) { this._gridBoxValue = value.length && value[0] || null; this._gridSelectedRowKeys = value; } gridBox_displayExpr(item){ return item && item.CompanyName + " <" + item.Phone + ">"; } } @NgModule({ imports: [ BrowserModule, DxTreeViewModule, DxDropDownBoxModule, HttpModule, DxDataGridModule ], declarations: [AppComponent], bootstrap: [AppComponent] }) export class AppModule { } platformBrowserDynamic().bootstrapModule(AppModule);
:host .dx-fieldset { height: 500px; }
// In real applications, you should not transpile code in the browser. You can see how to create your own application with Angular and DevExtreme here: // https://github.com/DevExpress/devextreme-angular/blob/master/README.md System.config({ transpiler: 'ts', typescriptOptions: { module: "commonjs", emitDecoratorMetadata: true, experimentalDecorators: true }, meta: { 'typescript': { "exports": "ts" } }, paths: { 'npm:': 'https://unpkg.com/' }, map: { 'ts': 'npm:plugin-typescript@7.0.6/lib/plugin.js', 'typescript': 'npm:typescript@2.2.2/lib/typescript.js', '@angular/core': 'npm:@angular/core@5.1.2/bundles/core.umd.js', '@angular/common': 'npm:@angular/common@5.1.2/bundles/common.umd.js', '@angular/compiler': 'npm:@angular/compiler@5.1.2/bundles/compiler.umd.js', '@angular/platform-browser': 'npm:@angular/platform-browser@5.1.2/bundles/platform-browser.umd.js', '@angular/platform-browser-dynamic': 'npm:@angular/platform-browser-dynamic@5.1.2/bundles/platform-browser-dynamic.umd.js', '@angular/http': 'npm:@angular/http@5.1.2/bundles/http.umd.js', '@angular/router': 'npm:@angular/router@5.1.2/bundles/router.umd.js', '@angular/forms': 'npm:@angular/forms@5.1.2/bundles/forms.umd.js', '@angular/common/http': 'npm:@angular/common@5.1.2/bundles/common-http.umd.js', 'tslib': 'npm:tslib/tslib.js', 'rxjs': 'npm:rxjs@5.3.1', 'devextreme': 'npm:devextreme@18.1', 'jszip': 'npm:jszip@3.1.3/dist/jszip.min.js', 'devextreme-angular': 'npm:devextreme-angular@18.1' }, packages: { 'app': { main: './app.component.ts', defaultExtension: 'ts' }, 'devextreme': { defaultExtension: 'js' }, 'devextreme-angular': { main: 'index.js', defaultExtension: 'js' } } });
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <title>DevExtreme Demo</title> <meta http-equiv="X-UA-Compatible" content="IE=edge"/> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0"/> <link rel="stylesheet" type="text/css" href="https://cdn3.devexpress.com/jslib/18.1.3/css/dx.spa.css"/> <link rel="stylesheet" type="text/css" href="https://cdn3.devexpress.com/jslib/18.1.3/css/dx.common.css"/> <link rel="dx-theme" data-theme="generic.light" href="https://cdn3.devexpress.com/jslib/18.1.3/css/dx.light.css"/> <link rel="dx-theme" data-theme="android5.light" href="https://cdn3.devexpress.com/jslib/18.1.3/css/dx.android5.light.css"/> <link rel="dx-theme" data-theme="ios7.default" href="https://cdn3.devexpress.com/jslib/18.1.3/css/dx.ios7.default.css"/> <link rel="dx-theme" data-theme="win10.black" href="https://cdn3.devexpress.com/jslib/18.1.3/css/dx.win10.black.css"/> <link rel="dx-theme" data-theme="win10.white" href="https://cdn3.devexpress.com/jslib/18.1.3/css/dx.win10.white.css"/> <script src="https://unpkg.com/core-js@2.4.1/client/shim.min.js"></script> <script src="https://unpkg.com/zone.js@0.6.25/dist/zone.js"></script> <script src="https://unpkg.com/reflect-metadata@0.1.3/Reflect.js"></script> <script src="https://unpkg.com/systemjs@0.21.3/dist/system.js"></script> <script src="config.js"></script> <script> System.import('app').catch(console.error.bind(console)); </script> </head> <body class="dx-viewport"> <div class="demo-container"> <demo-app>Loading...</demo-app> </div> </body> </html>