ngx-mat-select-dialog
TypeScript icon, indicating that this package has built-in type declarations

1.0.0 • Public • Published

MatSelectDialog

A ready to use component that promotes data select functionality from a material table with dialog.

alt text

  • single or multi selection modes.
  • pagination supporting local/remote data fetch.

alt text

  • respective to your material theme customization.
  • easy to use !!!!
import { MatSelectDialogModule } from 'ngx-mat-select-dialog';
imports: [
    MatSelectDialogModule,
],
<mat-select-dialog 
    [dataSource]="selectDataSource" 
    (page)="onPage($event)" 
    (filter)="onFilter($event)" 
    (done)="onDone($event)" 
    [dialogWidth]="'640px'" 
    [mode]="'multi'" 
    [customizeDisplayText]="customizeDisplayText"
></mat-select-dialog>

Example:

import { HttpClient } from '@angular/common/http';
import { Component } from '@angular/core';
import { PageEvent } from '@angular/material/paginator';
import { MatSelectDialogDataSource } from 'mat-select-dialog';

@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.scss']
})
export class AppComponent {
  selectedItems: Array<any> = [];
  selectDataSource = new MatSelectDialogDataSource<any>({
    data: [],
    displayedColumns: ['id', 'title', 'completed'],
    paging: {
      enabled: true,
      mode: 'local',
      pageSize: 10,
      pageIndex: 0
    }
  });

  title = 'test-app';

  /**
   *
   */
  constructor(
    private httpClient: HttpClient
  ) {
    httpClient.get<Array<any>>('https://jsonplaceholder.typicode.com/todos').subscribe(res => {
      this.selectDataSource.setData(res);
      this.selectedItems = res;
    })
  }

  onPage(e: PageEvent): void {
    this.httpClient.get<Array<any>>('https://jsonplaceholder.typicode.com/todos').subscribe(res => {
      res.splice(0, 100);
      this.selectDataSource.setData(res);
    });
  }

  onFilter(f: string): void {
    console.log(f);
  }

  onDone(selected: Array<any>): void {
    console.log(selected);
  }

  customizeDisplayText(selected: Array<{title: string}>): string {
    return selected.map(s => s.title).join(', ');
  }
}

Package Sidebar

Install

npm i ngx-mat-select-dialog

Weekly Downloads

29

Version

1.0.0

License

none

Unpacked Size

145 kB

Total Files

20

Last publish

Collaborators

  • oktaykirik