Your search did not match any results.
Slideout

Overview

Documentation
The SlideOut widget is a classic slide-out menu paired with a view. A user opens the menu by swiping away the view. This demo shows how to group menu items and how to define custom templates for the view and group headers.
Apply
Reset
<div class="slideout-container"> <dx-slide-out #slideout [dataSource]="dataSource" (onItemClick)="menuVisible = !menuVisible;" [menuGrouped]="true" [(menuVisible)]="menuVisible" [swipeEnabled]="true" > <div *dxTemplate="let product of 'item'"> <dx-toolbar [dataSource]="toolbarItems"> <div *dxTemplate="let data of 'title'"> <p>{{product.text}}</p> </div> </dx-toolbar> <div id="info"> <img src="{{product.src}}"> <h1>{{product.price}}</h1> </div> <div class="dx-fieldset"> <div class="dx-fieldset-header">Options</div> <div class="dx-field"> <div class="dx-field-label">Swipe to reveal the menu</div> <dx-switch class="dx-field-value" [(value)]="slideout.swipeEnabled"> </dx-switch> </div> </div> </div> <div *dxTemplate="let category of 'menuGroup'"> <b>{{category.key}}</b> </div> </dx-slide-out> </div>
import { NgModule, Component } from '@angular/core'; import { BrowserModule } from '@angular/platform-browser'; import { platformBrowserDynamic } from '@angular/platform-browser-dynamic'; import { DxSlideOutModule, DxToolbarModule, DxSwitchModule, DxTemplateModule } from 'devextreme-angular'; import { Category, Service } from './app.service'; @Component({ selector: 'demo-app', templateUrl: 'app/app.component.html', styleUrls: ['app/app.component.css'], providers: [Service] }) export class AppComponent { dataSource: Category[]; menuVisible: boolean; toolbarItems: any[]; constructor(service: Service) { this.menuVisible = true; this.toolbarItems = [ { location: 'before', widget: 'dxButton', options: { icon: 'menu', onClick: () => { this.menuVisible = !this.menuVisible; } } }, { location: 'center', template: 'title' } ]; this.dataSource = service.getProducts(); } } @NgModule({ imports: [ BrowserModule, DxSlideOutModule, DxToolbarModule, DxSwitchModule, DxTemplateModule ], declarations: [AppComponent], bootstrap: [AppComponent] }) export class AppModule { } platformBrowserDynamic().bootstrapModule(AppModule);
/deep/ #info { width: 200px; height: 200px; text-align: center; margin: 0 auto; margin-top: 10px; } /deep/ #info img { width: 100%; } /deep/ .slideout-container { height: auto; position: absolute; top: 0; bottom: 0; width:100%; } /deep/ .dx-field-label { width: 70%; }
import { Injectable } from '@angular/core'; export class Product { text: string; price: string; src: string; } export class Category { key: string; items: Product[]; } let data: Category[] = [ { key: "Televisions", items: [ { text: "SuperLCD 42", price: "$1200", src: "../../../../images/products/7.png" }, { text: "SuperLED 42", price: "$1450", src: "../../../../images/products/5.png" }, { text: "SuperLED 50", price: "$1600", src: "../../../../images/products/4.png" }, { text: "SuperLCD 55", price: "$1350", src: "../../../../images/products/6.png" }, { text: "SuperLCD 70", price: "$4000", src: "../../../../images/products/9.png" } ] }, { key: "Monitors", items: [ { text: "DesktopLCD 19", price: "$160", src: "../../../../images/products/10.png" }, { text: "DesktopLCD 21", price: "$170", src: "../../../../images/products/12.png" }, { text: "DesktopLED 21", price: "$180", src: "../../../../images/products/13.png" } ] }, { key: "Projectors", items: [ { text: "Projector Plus", price: "$550", src: "../../../../images/products/14.png" }, { text: "Projector PlusHD", price: "$750", src: "../../../../images/products/15.png" } ] }, { key: "Video Players", items: [ { text: "HD Video Player", price: "$220", src: "../../../../images/products/1.png" }, { text: "SuperHD Video Player", price: "$270", src: "../../../../images/products/2.png" } ] } ]; @Injectable() export class Service { getProducts(): Category[] { return data; } }
// In real applications, you should not transpile code in the browser. You can see how to create your own application with Angular 2 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@4.0.10/lib/plugin.js', 'typescript': 'npm:typescript@2.0.6/lib/typescript.js', '@angular/core': 'npm:@angular/core@2.4.3/bundles/core.umd.js', '@angular/common': 'npm:@angular/common@2.4.3/bundles/common.umd.js', '@angular/compiler': 'npm:@angular/compiler@2.4.3/bundles/compiler.umd.js', '@angular/platform-browser': 'npm:@angular/platform-browser@2.4.3/bundles/platform-browser.umd.js', '@angular/platform-browser-dynamic': 'npm:@angular/platform-browser-dynamic@2.4.3/bundles/platform-browser-dynamic.umd.js', '@angular/http': 'npm:@angular/http@2.4.3/bundles/http.umd.js', '@angular/router': 'npm:@angular/router@3.4.3/bundles/router.umd.js', '@angular/forms': 'npm:@angular/forms@2.4.3/bundles/forms.umd.js', 'rxjs': 'npm:rxjs@5.0.3', 'devextreme': 'npm:devextreme@16.2', 'jquery': 'npm:jquery@3.1.1/dist/jquery.min.js', 'jszip': 'npm:jszip@3.1.3/dist/jszip.min.js', 'devextreme-angular': 'npm:devextreme-angular@16.2' }, 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/16.2.5/css/dx.spa.css" /> <link rel="stylesheet" type="text/css" href="https://cdn3.devexpress.com/jslib/16.2.5/css/dx.common.css" /> <link rel="dx-theme" data-theme="generic.light" href="https://cdn3.devexpress.com/jslib/16.2.5/css/dx.light.css" /> <link rel="dx-theme" data-theme="android5.light" href="https://cdn3.devexpress.com/jslib/16.2.5/css/dx.android5.light.css" /> <link rel="dx-theme" data-theme="ios7.default" href="https://cdn3.devexpress.com/jslib/16.2.5/css/dx.ios7.default.css" /> <link rel="dx-theme" data-theme="win10.black" href="https://cdn3.devexpress.com/jslib/16.2.5/css/dx.win10.black.css" /> <link rel="dx-theme" data-theme="win10.white" href="https://cdn3.devexpress.com/jslib/16.2.5/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.19.31/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>