UNPKG

angular-bootstrap-md

Version:

Bootstrap 4 & Angular 15 UI KIT - 700+ components, MIT license, simple installation.

206 lines 27.1 kB
import { coerceBooleanProperty } from '@angular/cdk/coercion'; import { Directive, EventEmitter, HostListener, Input, Output, } from '@angular/core'; import * as i0 from "@angular/core"; var SortDirection; (function (SortDirection) { SortDirection["ASC"] = "ascending"; SortDirection["DESC"] = "descending"; SortDirection["CONST"] = "constant"; })(SortDirection || (SortDirection = {})); export class MdbTableSortDirective { constructor(el, renderer) { this.el = el; this.renderer = renderer; this.data = []; this.sortedInto = true; this.order = SortDirection.CONST; this.dataSource = []; this._sortIcon = false; this._resetSortDirection = false; this.sortEnd = new EventEmitter(); this.sorted = new EventEmitter(); } get sortIcon() { return this._sortIcon; } set sortIcon(value) { this._sortIcon = coerceBooleanProperty(value); } get resetSortDirection() { return this._resetSortDirection; } set resetSortDirection(value) { this._resetSortDirection = coerceBooleanProperty(value); } onclick() { this.sortDataBy(this.trimWhiteSigns(this.sortBy.toString())); this.sortEnd.emit(this.dataSource); this.sorted.emit({ data: this.dataSource, sortOrder: this.order, sortBy: this.sortBy, }); this.removeSort(); } trimWhiteSigns(headElement) { return headElement.replace(/ /g, ''); } moveArrayItem(arr, oldIndex, newIndex) { while (oldIndex < 0) { oldIndex += arr.length; } while (newIndex < 0) { newIndex += arr.length; } if (newIndex >= arr.length) { let k = newIndex - arr.length; while (k-- + 1) { arr.push(null); } } arr.splice(newIndex, 0, arr.splice(oldIndex, 1)[0]); return arr; } sortDataBy(key) { let ariaPass = true; const setAria = (sort, id) => { if (ariaPass) { let nextSortType = ''; if (this.resetSortDirection) { if (sort === SortDirection.CONST) { nextSortType = SortDirection.DESC; } else if (sort === SortDirection.DESC) { nextSortType = SortDirection.ASC; } else if (sort === SortDirection.ASC) { nextSortType = SortDirection.CONST; } } else { if (sort === SortDirection.DESC) { nextSortType = SortDirection.ASC; } else if (sort === SortDirection.ASC) { nextSortType = SortDirection.DESC; } } this.renderer.setAttribute(this.el.nativeElement, 'aria-sort', sort); this.renderer.setAttribute(this.el.nativeElement, 'aria-label', `${id}: activate to sort column ${nextSortType}`); ariaPass = false; } }; key = key.split('.'); if (this.resetSortDirection) { const sortFn = (a, b) => { a = a[key]; b = b[key]; return a > b ? -1 : 1; }; if (this.order === SortDirection.CONST) { setAria(SortDirection.DESC, key); this.order = SortDirection.DESC; this.dataSource.sort(sortFn); } else if (this.order === SortDirection.DESC) { setAria(SortDirection.ASC, key); this.order = SortDirection.ASC; this.dataSource.sort(sortFn).reverse(); } else if (this.order === SortDirection.ASC) { setAria(SortDirection.CONST, key); this.order = SortDirection.CONST; this.data.map((el, index) => { this.dataSource[index] = el; }); } } else { this.dataSource.sort((a, b) => { let i = 0; while (i < key.length) { a = a[key[i]]; b = b[key[i]]; i++; } if (a < b) { setAria(SortDirection.ASC, key); this.order = SortDirection.ASC; return this.sortedInto ? 1 : -1; } else if (a > b) { setAria(SortDirection.DESC, key); this.order = SortDirection.DESC; return this.sortedInto ? -1 : 1; } else if (a == null || b == null) { this.order = SortDirection.CONST; return 1; } else { this.order = SortDirection.CONST; return 0; } }); this.sortedInto = !this.sortedInto; } } ngOnInit() { const key = this.trimWhiteSigns(this.sortBy.toString()).split('.'); this.renderer.setAttribute(this.el.nativeElement, 'aria-label', `${key}: activate to sort column descending`); if (this.data.length === 0) { // this.dataSource.map((element: any) => { // this.data.push(element); // }) this.data = Array.from(this.dataSource); } } ngAfterViewInit() { if (this.sortIcon) { this.createIcon(); } } createIcon() { // eslint-disable-next-line max-len const iconUp = `<svg aria-hidden="true" focusable="false" data-prefix="fas" data-icon="arrow-up" class="svg-inline--fa fa-arrow-up fa-w-14 ascending" role="img" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><path fill="currentColor" d="M34.9 289.5l-22.2-22.2c-9.4-9.4-9.4-24.6 0-33.9L207 39c9.4-9.4 24.6-9.4 33.9 0l194.3 194.3c9.4 9.4 9.4 24.6 0 33.9L413 289.4c-9.5 9.5-25 9.3-34.3-.4L264 168.6V456c0 13.3-10.7 24-24 24h-32c-13.3 0-24-10.7-24-24V168.6L69.2 289.1c-9.3 9.8-24.8 10-34.3.4z"></path></svg>`; // eslint-disable-next-line max-len const iconDown = `<svg aria-hidden="true" focusable="false" data-prefix="fas" data-icon="arrow-down" class="svg-inline--fa fa-arrow-down fa-w-14 descending" role="img" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 448 512"><path fill="currentColor" d="M413.1 222.5l22.2 22.2c9.4 9.4 9.4 24.6 0 33.9L241 473c-9.4 9.4-24.6 9.4-33.9 0L12.7 278.6c-9.4-9.4-9.4-24.6 0-33.9l22.2-22.2c9.5-9.5 25-9.3 34.3.4L184 343.4V56c0-13.3 10.7-24 24-24h32c13.3 0 24 10.7 24 24v287.4l114.8-120.5c9.3-9.8 24.8-10 34.3-.4z"></path></svg>`; const title = this.el.nativeElement.innerHTML; this.el.nativeElement.innerHTML = `${title} ${iconUp} ${iconDown}`; } removeSort() { const nodes = this.el.nativeElement.parentElement.childNodes; if (nodes) { Array.from(nodes).map((node) => { if (node !== this.el.nativeElement && node.nodeName !== '#comment') { this.renderer.removeAttribute(node, 'aria-sort'); } }); } } } MdbTableSortDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: MdbTableSortDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive }); MdbTableSortDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "15.1.1", type: MdbTableSortDirective, selector: "[mdbTableSort]", inputs: { dataSource: ["mdbTableSort", "dataSource"], sortBy: "sortBy", sortIcon: "sortIcon", resetSortDirection: "resetSortDirection" }, outputs: { sortEnd: "sortEnd", sorted: "sorted" }, host: { listeners: { "click": "onclick()" } }, ngImport: i0 }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.1", ngImport: i0, type: MdbTableSortDirective, decorators: [{ type: Directive, args: [{ selector: '[mdbTableSort]', }] }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { dataSource: [{ type: Input, args: ['mdbTableSort'] }], sortBy: [{ type: Input }], sortIcon: [{ type: Input }], resetSortDirection: [{ type: Input }], sortEnd: [{ type: Output }], sorted: [{ type: Output }], onclick: [{ type: HostListener, args: ['click'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mdb-table-sort.directive.js","sourceRoot":"","sources":["../../../../../../../projects/angular-bootstrap-md/src/lib/free/tables/directives/mdb-table-sort.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport {\n  AfterViewInit,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnInit,\n  Output,\n  Renderer2,\n} from '@angular/core';\n\nenum SortDirection {\n  ASC = 'ascending',\n  DESC = 'descending',\n  CONST = 'constant',\n}\n\nexport interface SortedData {\n  data: any[];\n  sortOrder: string;\n  sortBy: string;\n}\n\n@Directive({\n  selector: '[mdbTableSort]',\n})\nexport class MdbTableSortDirective implements OnInit, AfterViewInit {\n  data: any[] = [];\n  sortedInto = true;\n  order: SortDirection.ASC | SortDirection.DESC | SortDirection.CONST = SortDirection.CONST;\n\n  @Input('mdbTableSort') dataSource: Array<any> = [];\n  @Input() sortBy: string;\n\n  @Input()\n  get sortIcon(): boolean {\n    return this._sortIcon;\n  }\n  set sortIcon(value: BooleanInput) {\n    this._sortIcon = coerceBooleanProperty(value);\n  }\n  private _sortIcon = false;\n\n  @Input()\n  get resetSortDirection(): boolean {\n    return this._resetSortDirection;\n  }\n  set resetSortDirection(value: BooleanInput) {\n    this._resetSortDirection = coerceBooleanProperty(value);\n  }\n  private _resetSortDirection = false;\n\n  @Output() sortEnd: EventEmitter<any[]> = new EventEmitter<any[]>();\n  @Output() sorted: EventEmitter<SortedData> = new EventEmitter<SortedData>();\n\n  constructor(private el: ElementRef, private renderer: Renderer2) {}\n\n  @HostListener('click') onclick() {\n    this.sortDataBy(this.trimWhiteSigns(this.sortBy.toString()));\n    this.sortEnd.emit(this.dataSource);\n    this.sorted.emit({\n      data: this.dataSource,\n      sortOrder: this.order,\n      sortBy: this.sortBy,\n    });\n\n    this.removeSort();\n  }\n\n  trimWhiteSigns(headElement: any): string {\n    return headElement.replace(/ /g, '');\n  }\n\n  public moveArrayItem(arr: any, oldIndex: number, newIndex: number) {\n    while (oldIndex < 0) {\n      oldIndex += arr.length;\n    }\n    while (newIndex < 0) {\n      newIndex += arr.length;\n    }\n    if (newIndex >= arr.length) {\n      let k = newIndex - arr.length;\n      while (k-- + 1) {\n        arr.push(null);\n      }\n    }\n    arr.splice(newIndex, 0, arr.splice(oldIndex, 1)[0]);\n    return arr;\n  }\n\n  sortDataBy(key: string | any) {\n    let ariaPass = true;\n\n    const setAria = (\n      sort: SortDirection.ASC | SortDirection.CONST | SortDirection.DESC,\n      id: any\n    ) => {\n      if (ariaPass) {\n        let nextSortType = '';\n\n        if (this.resetSortDirection) {\n          if (sort === SortDirection.CONST) {\n            nextSortType = SortDirection.DESC;\n          } else if (sort === SortDirection.DESC) {\n            nextSortType = SortDirection.ASC;\n          } else if (sort === SortDirection.ASC) {\n            nextSortType = SortDirection.CONST;\n          }\n        } else {\n          if (sort === SortDirection.DESC) {\n            nextSortType = SortDirection.ASC;\n          } else if (sort === SortDirection.ASC) {\n            nextSortType = SortDirection.DESC;\n          }\n        }\n\n        this.renderer.setAttribute(this.el.nativeElement, 'aria-sort', sort);\n        this.renderer.setAttribute(\n          this.el.nativeElement,\n          'aria-label',\n          `${id}: activate to sort column ${nextSortType}`\n        );\n        ariaPass = false;\n      }\n    };\n\n    key = key.split('.');\n\n    if (this.resetSortDirection) {\n      const sortFn = (a: any, b: any) => {\n        a = a[key];\n        b = b[key];\n\n        return a > b ? -1 : 1;\n      };\n      if (this.order === SortDirection.CONST) {\n        setAria(SortDirection.DESC, key);\n        this.order = SortDirection.DESC;\n        this.dataSource.sort(sortFn);\n      } else if (this.order === SortDirection.DESC) {\n        setAria(SortDirection.ASC, key);\n        this.order = SortDirection.ASC;\n        this.dataSource.sort(sortFn).reverse();\n      } else if (this.order === SortDirection.ASC) {\n        setAria(SortDirection.CONST, key);\n        this.order = SortDirection.CONST;\n        this.data.map((el: any, index: number) => {\n          this.dataSource[index] = el;\n        });\n      }\n    } else {\n      this.dataSource.sort((a: any, b: any) => {\n        let i = 0;\n        while (i < key.length) {\n          a = a[key[i]];\n          b = b[key[i]];\n          i++;\n        }\n\n        if (a < b) {\n          setAria(SortDirection.ASC, key);\n          this.order = SortDirection.ASC;\n\n          return this.sortedInto ? 1 : -1;\n        } else if (a > b) {\n          setAria(SortDirection.DESC, key);\n          this.order = SortDirection.DESC;\n\n          return this.sortedInto ? -1 : 1;\n        } else if (a == null || b == null) {\n          this.order = SortDirection.CONST;\n          return 1;\n        } else {\n          this.order = SortDirection.CONST;\n          return 0;\n        }\n      });\n\n      this.sortedInto = !this.sortedInto;\n    }\n  }\n\n  ngOnInit() {\n    const key = this.trimWhiteSigns(this.sortBy.toString()).split('.');\n\n    this.renderer.setAttribute(\n      this.el.nativeElement,\n      'aria-label',\n      `${key}: activate to sort column descending`\n    );\n\n    if (this.data.length === 0) {\n      // this.dataSource.map((element: any) => {\n      //   this.data.push(element);\n      // })\n\n      this.data = Array.from(this.dataSource);\n    }\n  }\n\n  ngAfterViewInit() {\n    if (this.sortIcon) {\n      this.createIcon();\n    }\n  }\n\n  createIcon() {\n    // eslint-disable-next-line max-len\n    const iconUp = `<svg aria-hidden=\"true\" focusable=\"false\" data-prefix=\"fas\" data-icon=\"arrow-up\" class=\"svg-inline--fa fa-arrow-up fa-w-14 ascending\" role=\"img\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 448 512\"><path fill=\"currentColor\" d=\"M34.9 289.5l-22.2-22.2c-9.4-9.4-9.4-24.6 0-33.9L207 39c9.4-9.4 24.6-9.4 33.9 0l194.3 194.3c9.4 9.4 9.4 24.6 0 33.9L413 289.4c-9.5 9.5-25 9.3-34.3-.4L264 168.6V456c0 13.3-10.7 24-24 24h-32c-13.3 0-24-10.7-24-24V168.6L69.2 289.1c-9.3 9.8-24.8 10-34.3.4z\"></path></svg>`;\n\n    // eslint-disable-next-line max-len\n    const iconDown = `<svg aria-hidden=\"true\" focusable=\"false\" data-prefix=\"fas\" data-icon=\"arrow-down\" class=\"svg-inline--fa fa-arrow-down fa-w-14 descending\" role=\"img\" xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 448 512\"><path fill=\"currentColor\" d=\"M413.1 222.5l22.2 22.2c9.4 9.4 9.4 24.6 0 33.9L241 473c-9.4 9.4-24.6 9.4-33.9 0L12.7 278.6c-9.4-9.4-9.4-24.6 0-33.9l22.2-22.2c9.5-9.5 25-9.3 34.3.4L184 343.4V56c0-13.3 10.7-24 24-24h32c13.3 0 24 10.7 24 24v287.4l114.8-120.5c9.3-9.8 24.8-10 34.3-.4z\"></path></svg>`;\n\n    const title = this.el.nativeElement.innerHTML;\n    this.el.nativeElement.innerHTML = `${title} ${iconUp} ${iconDown}`;\n  }\n\n  removeSort() {\n    const nodes = this.el.nativeElement.parentElement.childNodes;\n    if (nodes) {\n      Array.from(nodes).map((node: HTMLElement) => {\n        if (node !== this.el.nativeElement && node.nodeName !== '#comment') {\n          this.renderer.removeAttribute(node, 'aria-sort');\n        }\n      });\n    }\n  }\n}\n"]}