@junte/ui
Version:
Quality Angular UI components kit
170 lines • 29.5 kB
JavaScript
import { __decorate, __metadata, __read, __spread } from "tslib";
import { Component, ContentChild, ContentChildren, EventEmitter, forwardRef, HostBinding, HostListener, Input, Output, QueryList, TemplateRef } from '@angular/core';
import { ControlValueAccessor, FormBuilder, NG_VALUE_ACCESSOR } from '@angular/forms';
import { NGXLogger } from 'ngx-logger';
import { Subscription } from 'rxjs';
import { debounceTime, filter as filtering, finalize } from 'rxjs/operators';
import { ContentApi, MethodApi, PropertyApi } from '../../core/decorators/api';
import { Feature } from '../../core/enums/feature';
import { UI } from '../../core/enums/ui';
import { I18N_PROVIDERS } from '../../core/i18n/providers';
import { TableColumnComponent } from './table-column';
var FIRST = 10;
var FILTER_DELAY = 500;
var TableComponent = /** @class */ (function () {
function TableComponent(logger, fb) {
var _this = this;
this.logger = logger;
this.fb = fb;
this.ui = UI;
this.subscriptions = { fetcher: new Subscription() };
this.progress = { loading: false };
this.source = [];
this.orderByControl = this.fb.control(null);
this.firstControl = this.fb.control(FIRST);
this.form = this.fb.group({
q: [null],
orderBy: this.orderByControl,
first: this.firstControl,
offset: [0]
});
this.host = 'jnt-table-host';
this.features = [];
this.reloaded = new EventEmitter();
this.onChange = function () { return _this.logger.error('value accessor is not registered'); };
this.onTouched = function () { return _this.logger.error('value accessor is not registered'); };
this.registerOnChange = function (fn) { return _this.onChange = fn; };
this.registerOnTouched = function (fn) { return _this.onTouched = fn; };
this.onBlur = function () { return _this.onTouched(); };
}
TableComponent_1 = TableComponent;
TableComponent.prototype.ngOnInit = function () {
var _this = this;
this.form.valueChanges.pipe(filtering(function () { return !!_this.fetcher; }), debounceTime(FILTER_DELAY)).subscribe(function (_a) {
var q = _a.q, orderBy = _a.orderBy, first = _a.first, offset = _a.offset;
_this.onChange({ q: q, orderBy: orderBy, first: first, offset: offset });
});
};
TableComponent.prototype.ngOnDestroy = function () {
this.subscriptions.fetcher.unsubscribe();
};
TableComponent.prototype.load = function (filter) {
var _this = this;
if (filter === void 0) { filter = this.form.getRawValue(); }
if (!!this.fetcher) {
this.progress.loading = true;
this.subscriptions.fetcher.unsubscribe();
this.subscriptions.fetcher = this.fetcher(filter)
.pipe(finalize(function () { return _this.progress.loading = false; }))
.subscribe(function (resp) {
_this.source = resp.results;
_this.count = resp.count;
});
}
};
TableComponent.prototype.sorting = function (field) {
this.orderByControl.setValue(this.orderByControl.value === field ? "-" + field : field);
};
TableComponent.prototype.writeValue = function (_a) {
var q = _a.q, orderBy = _a.orderBy, first = _a.first, offset = _a.offset;
this.form.patchValue({ q: q, orderBy: orderBy, first: first, offset: offset }, { emitEvent: false });
};
TableComponent.prototype.hideActions = function () {
this.popover.hide();
};
var TableComponent_1;
TableComponent.ctorParameters = function () { return [
{ type: NGXLogger },
{ type: FormBuilder }
]; };
__decorate([
HostBinding('attr.host'),
__metadata("design:type", Object)
], TableComponent.prototype, "host", void 0);
__decorate([
PropertyApi({
description: 'Table features',
path: 'ui.feature',
options: [Feature.search, Feature.reload]
}),
Input(),
__metadata("design:type", Array)
], TableComponent.prototype, "features", void 0);
__decorate([
PropertyApi({
description: 'Table fetch function',
type: 'Function'
}),
Input(),
__metadata("design:type", Function)
], TableComponent.prototype, "fetcher", void 0);
__decorate([
PropertyApi({
description: 'Output event of reload table'
}),
Output(),
__metadata("design:type", Object)
], TableComponent.prototype, "reloaded", void 0);
__decorate([
ContentChildren(TableColumnComponent),
__metadata("design:type", QueryList)
], TableComponent.prototype, "columns", void 0);
__decorate([
ContentApi({
selector: '#tableRowActionsTemplate',
description: 'table row actions template'
}),
ContentChild('tableRowActionsTemplate'),
__metadata("design:type", TemplateRef)
], TableComponent.prototype, "rowActionsTemplate", void 0);
__decorate([
ContentApi({
selector: '#tableActionsTemplate',
description: 'table actions template'
}),
ContentChild('tableActionsTemplate'),
__metadata("design:type", TemplateRef)
], TableComponent.prototype, "actionsTemplate", void 0);
__decorate([
ContentApi({
selector: '#tableFiltersTemplate',
description: 'table filters template'
}),
ContentChild('tableFiltersTemplate'),
__metadata("design:type", TemplateRef)
], TableComponent.prototype, "filtersTemplate", void 0);
__decorate([
HostListener('blur'),
__metadata("design:type", Object)
], TableComponent.prototype, "onBlur", void 0);
__decorate([
MethodApi({ description: 'reload table' }),
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object]),
__metadata("design:returntype", void 0)
], TableComponent.prototype, "load", null);
__decorate([
MethodApi({ description: 'sorting data table by field' }),
__metadata("design:type", Function),
__metadata("design:paramtypes", [String]),
__metadata("design:returntype", void 0)
], TableComponent.prototype, "sorting", null);
TableComponent = TableComponent_1 = __decorate([
Component({
selector: 'jnt-table',
template: "<form child-of=\"jnt-table-host\" [formGroup]=\"form\">\n <jnt-stack child-of=\"jnt-table-host\" [align]=\"ui.align.stretch\" [gutter]=\"ui.gutter.none\">\n <ng-container *jntMinFor=\"ui.breakpoint.desktop\">\n <jnt-stack child-of=\"jnt-table-host\" data-feature *ngIf=\"(features | includes : [ui.feature.reload, ui.feature.search]) || !!actionsTemplate\"\n [orientation]=\"ui.orientation.horizontal\"\n [align]=\"ui.align.center\"\n [justify]=\"ui.justify.between\">\n <jnt-stack child-of=\"jnt-table-host\" *ngIf=\"(features | includes : ui.feature.reload) || !!actionsTemplate\"\n [orientation]=\"ui.orientation.horizontal\"\n [align]=\"ui.align.center\">\n <jnt-button child-of=\"jnt-table-host\" data-button *ngIf=\"features | includes : ui.feature.reload\"\n [text]=\"'action.reload' | translate\"\n [icon]=\"progress.loading ? ui.icons.animated.reload : ui.icons.reload\"\n [outline]=\"ui.outline.transparent\"\n [disabled]=\"progress.loading\"\n (click)=\"load(); reloaded.emit()\">\n </jnt-button>\n <ng-container *ngTemplateOutlet=\"actionsTemplate\"></ng-container>\n </jnt-stack>\n <jnt-input child-of=\"jnt-table-host\" data-search *ngIf=\"features | includes : ui.feature.search\"\n formControlName=\"q\"\n [icon]=\"ui.icons.search\"\n [features]=\"[ui.feature.allowEmpty]\"\n [placeholder]=\"'label.search' | translate\">\n </jnt-input>\n </jnt-stack>\n\n <div child-of=\"jnt-table-host\" data-filters *ngIf=\"!!filtersTemplate\">\n <ng-container *ngTemplateOutlet=\"filtersTemplate\"></ng-container>\n </div>\n </ng-container>\n\n <jnt-stack child-of=\"jnt-table-host\" [align]=\"ui.align.stretch\">\n <div child-of=\"jnt-table-host\" *jntMinFor=\"ui.breakpoint.desktop\" data-table>\n <table child-of=\"jnt-table-host\" >\n <div child-of=\"jnt-table-host\" data-spinner *ngIf=\"source.length && progress.loading\">\n <jnt-spinner child-of=\"jnt-table-host\" [size]=\"ui.size.large\"></jnt-spinner>\n </div>\n\n <thead child-of=\"jnt-table-host\" >\n <tr child-of=\"jnt-table-host\" >\n <th child-of=\"jnt-table-host\" data-actions *ngIf=\"!!rowActionsTemplate\"></th>\n <th child-of=\"jnt-table-host\" *ngFor=\"let column of columns\"\n [attr.data-sortable]=\"!!column.orderBy\"\n [style.text-align]=\"column.align\"\n [style.width]=\"column.width\"\n (click)=\"column.orderBy ? sorting(column.orderBy) : null\">\n <span child-of=\"jnt-table-host\" >\n {{column.title}}\n <i child-of=\"jnt-table-host\" *ngIf=\"!!orderByControl.value && (orderByControl.value === '-' + column.orderBy\n || orderByControl.value === column.orderBy)\"\n [innerHTML]=\"(orderByControl.value === column.orderBy) ? '↑' : '↓'\"></i>\n </span>\n </th>\n </tr>\n </thead>\n\n <tbody child-of=\"jnt-table-host\" >\n <ng-container *ngIf=\"source.length; else noDataTemplate\">\n <tr child-of=\"jnt-table-host\" *ngFor=\"let row of source; let i = index\" [class.even]=\"!(i % 2)\">\n <td child-of=\"jnt-table-host\" *ngIf=\"!!rowActionsTemplate\" data-actions>\n <jnt-button child-of=\"jnt-table-host\" data-trigger\n [outline]=\"ui.outline.transparent\"\n [icon]=\"ui.icons.actions\"\n (attached)=\"popover = $event\"\n [jntPopover]=\"{\n context: 'table-row-action',\n contentTemplate: dropdownTemplate,\n behaviour: ui.behaviour.dropdown,\n trigger: ui.trigger.click,\n padding: ui.gutter.small,\n minWidth: '150px'\n }\">\n </jnt-button>\n <ng-template #dropdownTemplate>\n <ng-container *ngTemplateOutlet=\"rowActionsTemplate;\n context: {row: row, hide: hideActions.bind(this)}\">\n </ng-container>\n </ng-template>\n </td>\n <td child-of=\"jnt-table-host\" *ngFor=\"let column of columns\">\n <ng-container *ngTemplateOutlet=\"column.tableCellTemplate; context: row\"></ng-container>\n </td>\n </tr>\n </ng-container>\n <ng-template #noDataTemplate>\n <ng-container *ngIf=\"!progress.loading; else skeletonTemplate\">\n <tr child-of=\"jnt-table-host\" data-nodata>\n <td child-of=\"jnt-table-host\" [attr.colspan]=\"!!rowActionsTemplate ? columns.length + 1 : columns.length\">\n <jnt-icon child-of=\"jnt-table-host\" [icon]=\"ui.icons.neutral\"></jnt-icon>\n </td>\n </tr>\n </ng-container>\n <ng-template #skeletonTemplate>\n <tr child-of=\"jnt-table-host\" data-loading>\n <td child-of=\"jnt-table-host\" [attr.colspan]=\"!!rowActionsTemplate ? columns.length + 1 : columns.length\">\n <jnt-skeleton child-of=\"jnt-table-host\" [lines]=\"4\"></jnt-skeleton>\n </td>\n </tr>\n </ng-template>\n </ng-template>\n </tbody>\n </table>\n </div>\n\n <jnt-stack child-of=\"jnt-table-host\" *jntMaxFor=\"ui.breakpoint.tablet\" [align]=\"ui.align.stretch\">\n <jnt-stack child-of=\"jnt-table-host\" data-feature [align]=\"ui.align.stretch\">\n <jnt-stack child-of=\"jnt-table-host\" *ngIf=\"(features | includes : ui.feature.reload) || !!actionsTemplate\"\n [orientation]=\"ui.orientation.horizontal\" [wrap]=\"ui.wrap.wrap\">\n <jnt-button child-of=\"jnt-table-host\" data-button *ngIf=\"features | includes : ui.feature.reload\"\n [text]=\"'action.reload' | translate\"\n [icon]=\"progress.loading ? ui.icons.animated.reload : ui.icons.reload\"\n [outline]=\"ui.outline.transparent\"\n [disabled]=\"progress.loading\"\n (click)=\"load(); reloaded.emit()\">\n </jnt-button>\n <jnt-stack child-of=\"jnt-table-host\" *ngIf=\"!!actionsTemplate\" [orientation]=\"ui.orientation.horizontal\" [wrap]=\"ui.wrap.wrap\">\n <ng-container *ngTemplateOutlet=\"actionsTemplate\"></ng-container>\n </jnt-stack>\n </jnt-stack>\n <jnt-input child-of=\"jnt-table-host\" data-search *ngIf=\"features | includes : ui.feature.search\"\n formControlName=\"q\"\n [icon]=\"ui.icons.search\"\n [features]=\"[ui.feature.allowEmpty]\"\n [placeholder]=\"'label.search' | translate\">\n </jnt-input>\n <ng-container *ngIf=\"!!filtersTemplate\">\n <ng-container *ngTemplateOutlet=\"filtersTemplate\"></ng-container>\n </ng-container>\n </jnt-stack>\n <ng-template #noDataCardTemplate>\n <jnt-stack child-of=\"jnt-table-host\" *ngIf=\"!progress.loading; else skeletonCardTemplate\" [align]=\"ui.align.center\">\n <jnt-icon child-of=\"jnt-table-host\" data-nodata [icon]=\"ui.icons.neutral\"></jnt-icon>\n </jnt-stack>\n <ng-template #skeletonCardTemplate>\n <ng-container *ngFor=\"let card of 5 | mockArray\">\n <jnt-skeleton child-of=\"jnt-table-host\" [type]=\"ui.skeleton.type.card\"></jnt-skeleton>\n </ng-container>\n </ng-template>\n </ng-template>\n <div child-of=\"jnt-table-host\" data-spinner *ngIf=\"source.length && progress.loading\">\n <jnt-spinner child-of=\"jnt-table-host\" [size]=\"ui.size.large\"></jnt-spinner>\n </div>\n <ng-container *ngIf=\"source.length; else noDataCardTemplate\">\n <jnt-card child-of=\"jnt-table-host\" *ngFor=\"let row of source; let i = index\">\n <table child-of=\"jnt-table-host\" data-line cellpadding=\"0\" cellspacing=\"0\">\n <tr child-of=\"jnt-table-host\" *ngFor=\"let column of columns\">\n <td child-of=\"jnt-table-host\" >\n <b child-of=\"jnt-table-host\" *ngIf=\"!!column.title\">{{column.title}}</b>\n </td>\n <td child-of=\"jnt-table-host\" >\n <ng-container *ngTemplateOutlet=\"column.tableCellTemplate; context: row\"></ng-container>\n </td>\n </tr>\n </table>\n <ng-template *ngIf=\"!!rowActionsTemplate\" #cardActionsTemplate let-hide=\"hide\">\n <ng-container *ngTemplateOutlet=\"rowActionsTemplate;\n context: {row: row, hide: hideActions.bind(this)}\">\n </ng-container>\n </ng-template>\n </jnt-card>\n </ng-container>\n </jnt-stack>\n\n <ng-container *ngIf=\"!!count\">\n <div child-of=\"jnt-table-host\" data-pagination>\n <jnt-pager child-of=\"jnt-table-host\" data-pages formControlName=\"offset\"\n [count]=\"count\" [pageSize]=\"firstControl.value\">\n </jnt-pager>\n <jnt-select child-of=\"jnt-table-host\" *jntMinFor=\"ui.breakpoint.desktop\" formControlName=\"first\" [size]=\"ui.size.small\">\n <jnt-select-option child-of=\"jnt-table-host\" label=\"10\" key=\"10\"></jnt-select-option>\n <jnt-select-option child-of=\"jnt-table-host\" label=\"20\" key=\"20\"></jnt-select-option>\n <jnt-select-option child-of=\"jnt-table-host\" label=\"30\" key=\"30\"></jnt-select-option>\n </jnt-select>\n </div>\n </ng-container>\n </jnt-stack>\n </jnt-stack>\n</form>",
providers: __spread([
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(function () { return TableComponent_1; }),
multi: true
}
], I18N_PROVIDERS)
}),
__metadata("design:paramtypes", [NGXLogger,
FormBuilder])
], TableComponent);
return TableComponent;
}());
export { TableComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table.component.js","sourceRoot":"ng://@junte/ui/","sources":["lib/collections/table/table.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ContentChild,\n  ContentChildren,\n  EventEmitter,\n  forwardRef,\n  HostBinding,\n  HostListener,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  QueryList,\n  TemplateRef\n} from '@angular/core';\nimport { ControlValueAccessor, FormBuilder, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { NGXLogger } from 'ngx-logger';\nimport { Subscription } from 'rxjs';\nimport { debounceTime, filter as filtering, finalize } from 'rxjs/operators';\nimport { ContentApi, MethodApi, PropertyApi } from '../../core/decorators/api';\nimport { Feature } from '../../core/enums/feature';\nimport { UI } from '../../core/enums/ui';\nimport { I18N_PROVIDERS } from '../../core/i18n/providers';\nimport { PopoverComponent } from '../../overlays/popover/popover.component';\nimport { TableColumnComponent } from './table-column';\nimport { DefaultSearchFilter } from './types';\n\nconst FIRST = 10;\nconst FILTER_DELAY = 500;\n\n@Component({\n  selector: 'jnt-table',\n  templateUrl: './table.encapsulated.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => TableComponent),\n      multi: true\n    }, ...I18N_PROVIDERS\n  ]\n})\nexport class TableComponent implements OnInit, OnDestroy, ControlValueAccessor {\n\n  ui = UI;\n\n  private subscriptions = {fetcher: new Subscription()};\n  popover: PopoverComponent;\n\n  progress = {loading: false};\n  source: Object[] = [];\n  count: number;\n\n  orderByControl = this.fb.control(null);\n  firstControl = this.fb.control(FIRST);\n\n  form = this.fb.group({\n    q: [null],\n    orderBy: this.orderByControl,\n    first: this.firstControl,\n    offset: [0]\n  });\n\n  @HostBinding('attr.host') readonly host = 'jnt-table-host';\n\n  @PropertyApi({\n    description: 'Table features',\n    path: 'ui.feature',\n    options: [Feature.search, Feature.reload]\n  })\n  @Input()\n  features: Feature[] = [];\n\n  @PropertyApi({\n    description: 'Table fetch function',\n    type: 'Function'\n  })\n  @Input()\n  fetcher: Function;\n\n  @PropertyApi({\n    description: 'Output event of reload table'\n  })\n  @Output()\n  reloaded = new EventEmitter<any>();\n\n  @ContentChildren(TableColumnComponent)\n  columns: QueryList<TableColumnComponent>;\n\n  @ContentApi({\n    selector: '#tableRowActionsTemplate',\n    description: 'table row actions template'\n  })\n  @ContentChild('tableRowActionsTemplate')\n  rowActionsTemplate: TemplateRef<any>;\n\n  @ContentApi({\n    selector: '#tableActionsTemplate',\n    description: 'table actions template'\n  })\n  @ContentChild('tableActionsTemplate')\n  actionsTemplate: TemplateRef<any>;\n\n  @ContentApi({\n    selector: '#tableFiltersTemplate',\n    description: 'table filters template'\n  })\n  @ContentChild('tableFiltersTemplate')\n  filtersTemplate: TemplateRef<any>;\n\n  onChange: (filter: DefaultSearchFilter) => void = () => this.logger.error('value accessor is not registered');\n  onTouched: () => void = () => this.logger.error('value accessor is not registered');\n  registerOnChange = fn => this.onChange = fn;\n  registerOnTouched = fn => this.onTouched = fn;\n  @HostListener('blur') onBlur = () => this.onTouched();\n\n  constructor(private logger: NGXLogger,\n              private fb: FormBuilder) {\n  }\n\n  ngOnInit() {\n    this.form.valueChanges.pipe(filtering(() => !!this.fetcher),\n      debounceTime(FILTER_DELAY)).subscribe(({q, orderBy, first, offset}) => {\n      this.onChange({q, orderBy, first, offset});\n    });\n  }\n\n  ngOnDestroy() {\n    this.subscriptions.fetcher.unsubscribe();\n  }\n\n  @MethodApi({description: 'reload table'})\n  load(filter = this.form.getRawValue()) {\n    if (!!this.fetcher) {\n      this.progress.loading = true;\n      this.subscriptions.fetcher.unsubscribe();\n      this.subscriptions.fetcher = this.fetcher(filter)\n        .pipe(finalize(() => this.progress.loading = false))\n        .subscribe(resp => {\n          this.source = resp.results;\n          this.count = resp.count;\n        });\n    }\n  }\n\n  @MethodApi({description: 'sorting data table by field'})\n  sorting(field: string) {\n    this.orderByControl.setValue(this.orderByControl.value === field ? `-${field}` : field);\n  }\n\n  writeValue({q, orderBy, first, offset}: DefaultSearchFilter) {\n    this.form.patchValue({q, orderBy, first, offset},\n      {emitEvent: false});\n  }\n\n  hideActions() {\n    this.popover.hide();\n  }\n}\n"]}