diff --git a/src/app/showcase/doc/tree/treedoc.module.ts b/src/app/showcase/doc/tree/treedoc.module.ts index a8a851af322..afe234ab19e 100644 --- a/src/app/showcase/doc/tree/treedoc.module.ts +++ b/src/app/showcase/doc/tree/treedoc.module.ts @@ -22,10 +22,12 @@ import { MultipleDoc } from './multipledoc'; import { SingleDoc } from './singledoc'; import { StyleDoc } from './styledoc'; import { TemplateDoc } from './templatedoc'; +import { VirtualScrollDoc } from './virtualscrolldoc'; +import { LazyVirtualScrollDoc } from './virtualscrolllazydoc'; @NgModule({ imports: [CommonModule, AppCodeModule, AppDocModule, TreeModule, ButtonModule, InputSwitchModule, FormsModule, ToastModule, ContextMenuModule], exports: [AppDocModule], - declarations: [ImportDoc, BasicDoc, ControlledDoc, SingleDoc, MultipleDoc, CheckboxDoc, EventDoc, LazyDoc, TemplateDoc, DragDropDoc, ContextMenuDoc, FilterDoc, StyleDoc, AccessibilityDoc] + declarations: [ImportDoc, BasicDoc, ControlledDoc, SingleDoc, MultipleDoc, CheckboxDoc, EventDoc, LazyDoc, VirtualScrollDoc, LazyVirtualScrollDoc, TemplateDoc, DragDropDoc, ContextMenuDoc, FilterDoc, StyleDoc, AccessibilityDoc] }) export class TreeDocModule {} diff --git a/src/app/showcase/doc/tree/virtualscrolldoc.ts b/src/app/showcase/doc/tree/virtualscrolldoc.ts new file mode 100644 index 00000000000..3655c67a59a --- /dev/null +++ b/src/app/showcase/doc/tree/virtualscrolldoc.ts @@ -0,0 +1,111 @@ +import { ChangeDetectorRef, Component, OnInit } from '@angular/core'; +import { TreeNode } from 'primeng/api'; +import { Code } from '../../domain/code'; +import { NodeService } from '../../service/nodeservice'; + +@Component({ + selector: 'virtual-scroll-doc', + template: ` + +

VirtualScroller is a performance-approach to handle huge data efficiently. Setting virtualScroll property as true and providing a virtualScrollItemSize in pixels would be enough to enable this functionality.

+
+
+ +
+ + ` +}) +export class VirtualScrollDoc implements OnInit { + loading: boolean = false; + + files!: TreeNode[]; + + constructor(private nodeService: NodeService, private cd: ChangeDetectorRef) {} + + ngOnInit() { + this.nodeService.getFiles().then((data) => { + this.files = this.duplicateData(data, 50); + this.cd.markForCheck(); + }); + } + + duplicateData(data: TreeNode[], count: number): TreeNode[] { + let duplicatedData: TreeNode[] = []; + for (let i = 0; i < count; i++) { + duplicatedData = [...duplicatedData, ...data.map((item) => ({ ...item }))]; + } + return duplicatedData; + } + + code: Code = { + basic: ``, + + html: ` +
+ +
`, + + typescript: ` +import { ChangeDetectorRef, Component, OnInit } from '@angular/core'; +import { TreeNode } from 'primeng/api'; +import { NodeService } from '../../service/nodeservice'; + +@Component({ + selector: 'tree-virtual-scroll-demo', + templateUrl: './tree-virtual-scroll-demo.html' +}) +export class TreeVirtualScrollDemo implements OnInit { + loading: boolean = false; + + files!: TreeNode[]; + + constructor(private nodeService: NodeService, private cd: ChangeDetectorRef) {} + + ngOnInit() { + this.nodeService.getFiles().then((data) => { + this.files = this.duplicateData(data, 50); + this.cd.markForCheck(); + }); + } + + duplicateData(data: TreeNode[], count: number): TreeNode[] { + let duplicatedData: TreeNode[] = []; + for (let i = 0; i < count; i++) { + duplicatedData = [...duplicatedData, ...data.map((item) => ({ ...item }))]; + } + return duplicatedData; + } + +}`, +service: ['NodeService'], + +data: ` +/* NodeService */ +{ +key: '0', +label: 'Documents', +data: 'Documents Folder', +icon: 'pi pi-fw pi-inbox', +children: [ +{ + key: '0-0', + label: 'Work', + data: 'Work Folder', + icon: 'pi pi-fw pi-cog', + children: [ + { key: '0-0-0', label: 'Expenses.doc', icon: 'pi pi-fw pi-file', data: 'Expenses Document' }, + { key: '0-0-1', label: 'Resume.doc', icon: 'pi pi-fw pi-file', data: 'Resume Document' } + ] +}, +{ + key: '0-1', + label: 'Home', + data: 'Home Folder', + icon: 'pi pi-fw pi-home', + children: [{ key: '0-1-0', label: 'Invoices.txt', icon: 'pi pi-fw pi-file', data: 'Invoices for this month' }] +} +] +}, +...` + }; +} diff --git a/src/app/showcase/doc/tree/virtualscrolllazydoc.ts b/src/app/showcase/doc/tree/virtualscrolllazydoc.ts new file mode 100644 index 00000000000..6fde95d7ca0 --- /dev/null +++ b/src/app/showcase/doc/tree/virtualscrolllazydoc.ts @@ -0,0 +1,145 @@ +import { ChangeDetectorRef, Component, OnInit } from '@angular/core'; +import { TreeNode } from 'primeng/api'; +import { Code } from '../../domain/code'; +import { NodeService } from '../../service/nodeservice'; + +@Component({ + selector: 'lazy-virtual-scroll-doc', + template: ` + +

VirtualScroller is a performance-approach to handle huge data efficiently. Setting virtualScroll property as true and providing a virtualScrollItemSize in pixels would be enough to enable this functionality.

+
+
+ +
+ + ` +}) +export class LazyVirtualScrollDoc implements OnInit { + loading: boolean = false; + + files!: TreeNode[]; + + virtualFiles!: TreeNode[]; + + constructor(private nodeService: NodeService, private cd: ChangeDetectorRef) {} + + ngOnInit() { + this.loading = true; + setTimeout(() => { + this.nodeService.getLazyFiles().then((files) => (this.files = this.duplicateData(files, 50))); + this.loading = false; + this.cd.markForCheck(); + }, 1000); + } + + duplicateData(data: TreeNode[], count: number): TreeNode[] { + let duplicatedData: TreeNode[] = []; + for (let i = 0; i < count; i++) { + duplicatedData = [...duplicatedData, ...data.map((item) => ({ ...item }))]; + } + return duplicatedData; + } + + nodeExpand(event: any) { + if (event.node) { + this.loading = true; + setTimeout(() => { + this.nodeService.getLazyFiles().then((nodes) => { + event.node.children = nodes; + this.files = [...this.files, event.node.children]; + }); + this.loading = false; + this.cd.markForCheck(); + }, 200); + } + } + + code: Code = { + basic: ``, + + html: `
+ +
`, + + typescript: ` +import { ChangeDetectorRef, Component, OnInit } from '@angular/core'; +import { TreeNode } from 'primeng/api'; +import { NodeService } from '../../service/nodeservice'; + +@Component({ + selector: 'tree-virtual-scroll-lazy-demo', + templateUrl: './tree-virtual-scroll-lazy-demo.html' +}) +export class TreeVirtualScrollLazyDemo implements OnInit { + loading: boolean = false; + + files!: TreeNode[]; + + virtualFiles!: TreeNode[]; + + constructor(private nodeService: NodeService, private cd: ChangeDetectorRef) {} + + ngOnInit() { + this.loading = true; + setTimeout(() => { + this.nodeService.getLazyFiles().then((files) => (this.files = this.duplicateData(files, 50))); + this.loading = false; + this.cd.markForCheck(); + }, 1000); + } + + duplicateData(data: TreeNode[], count: number): TreeNode[] { + let duplicatedData: TreeNode[] = []; + for (let i = 0; i < count; i++) { + duplicatedData = [...duplicatedData, ...data.map((item) => ({ ...item }))]; + } + return duplicatedData; + } + + nodeExpand(event: any) { + if (event.node) { + this.loading = true; + setTimeout(() => { + this.nodeService.getLazyFiles().then((nodes) => { + event.node.children = nodes; + this.files = [...this.files, event.node.children]; + }); + this.loading = false; + this.cd.markForCheck(); + }, 200); + } + } +}`, + service: ['NodeService'], + + data: ` + /* NodeService */ +{ + key: '0', + label: 'Documents', + data: 'Documents Folder', + icon: 'pi pi-fw pi-inbox', + children: [ + { + key: '0-0', + label: 'Work', + data: 'Work Folder', + icon: 'pi pi-fw pi-cog', + children: [ + { key: '0-0-0', label: 'Expenses.doc', icon: 'pi pi-fw pi-file', data: 'Expenses Document' }, + { key: '0-0-1', label: 'Resume.doc', icon: 'pi pi-fw pi-file', data: 'Resume Document' } + ] + }, + { + key: '0-1', + label: 'Home', + data: 'Home Folder', + icon: 'pi pi-fw pi-home', + children: [{ key: '0-1-0', label: 'Invoices.txt', icon: 'pi pi-fw pi-file', data: 'Invoices for this month' }] + } + ] +}, +...` + }; +} diff --git a/src/app/showcase/pages/tree/treedemo.ts b/src/app/showcase/pages/tree/treedemo.ts index 72ed5d4c44e..30538daa466 100644 --- a/src/app/showcase/pages/tree/treedemo.ts +++ b/src/app/showcase/pages/tree/treedemo.ts @@ -13,6 +13,8 @@ import { ContextMenuDoc } from '../../doc/tree/contextmenudoc'; import { FilterDoc } from '../../doc/tree/filterdoc'; import { StyleDoc } from '../../doc/tree/styledoc'; import { AccessibilityDoc } from '../../doc/tree/accessibilitydoc'; +import { VirtualScrollDoc } from '../../doc/tree/virtualscrolldoc'; +import { LazyVirtualScrollDoc } from '../../doc/tree/virtualscrolllazydoc'; @Component({ templateUrl: './treedemo.html' @@ -65,6 +67,22 @@ export class TreeDemo { label: 'Lazy', component: LazyDoc }, + { + id: 'virtualscroll', + label: 'Virtual Scroll', + children:[ + { + id: 'preload', + label: 'Preload', + component: VirtualScrollDoc + }, + { + id: 'lazyvirtualscroll', + label: 'Lazy', + component: LazyVirtualScrollDoc + }, + ] + }, { id: 'template', label: 'Template',