angular-bootstrap-md
Version:
Bootstrap 4 & Angular 15 UI KIT - 700+ components, MIT license, simple installation.
206 lines • 27.1 kB
JavaScript
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"]}