@formio-tmt/angular
Version:
This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 10.1.4.
258 lines • 36.4 kB
JavaScript
import { GridFooterPositions } from './types/grid-footer-positions';
import { Component, EventEmitter, Input, Output, ViewChild, ViewContainerRef } from '@angular/core';
import { each } from 'lodash';
import { Formio } from '@formio-tmt/js';
import FormComponents from './form/index';
import SubmissionComponents from './submission/index';
import { FormioPromiseService } from '@formio-tmt/angular';
import { SortType } from './types/grid-header';
import * as i0 from "@angular/core";
import * as i1 from "@formio-tmt/angular";
import * as i2 from "@angular/common";
class FormioGridComponent {
alerts;
resolver;
ref;
footerPosition = GridFooterPositions.bottom;
src;
items;
onForm;
query;
refresh;
columns;
gridType;
size;
components;
formio;
label;
createText;
isActionAllowed;
select;
rowSelect;
rowAction;
createItem;
error;
headerElement;
bodyElement;
footerElement;
page = 0;
isLoading = false;
initialized = false;
header;
body;
footer;
footerPositions = GridFooterPositions;
constructor(alerts, resolver, ref) {
this.alerts = alerts;
this.resolver = resolver;
this.ref = ref;
this.select = this.rowSelect = new EventEmitter();
this.rowAction = new EventEmitter();
this.createItem = new EventEmitter();
this.error = new EventEmitter();
this.isLoading = true;
}
createComponent(property, component) {
const factory = this.resolver.resolveComponentFactory(component);
const componentRef = property.createComponent(factory);
return componentRef.instance;
}
loadGrid(src) {
// If no source is provided, then skip.
if (!src && !this.formio) {
return;
}
// Do not double load.
if (this.formio && this.src && (src === this.src)) {
return;
}
if (src) {
this.src = src;
this.formio = new FormioPromiseService(this.src, { formOnly: true });
}
// Load the header.
this.header.load(this.formio, {}, this.columns)
.then(() => this.setPage(0))
.catch(error => this.onError(error));
}
ngOnInit() {
// Create our components.
const comps = this.components || ((this.gridType === 'form') ? FormComponents : SubmissionComponents);
this.header = this.createComponent(this.headerElement, comps.header);
this.header.actionAllowed = this.actionAllowed.bind(this);
this.header.sort.subscribe(header => this.sortColumn(header));
this.body = this.createComponent(this.bodyElement, comps.body);
this.body.header = this.header;
this.body.actionAllowed = this.actionAllowed.bind(this);
this.body.rowSelect.subscribe(row => this.rowSelect.emit(row));
this.body.rowAction.subscribe(action => this.rowAction.emit(action));
this.footer = this.createComponent(this.footerElement, comps.footer);
this.footer.header = this.header;
this.footer.body = this.body;
this.footer.actionAllowed = this.actionAllowed.bind(this);
this.footer.createText = this.createText;
this.footer.size = this.size;
this.footer.pageChanged.subscribe(page => this.pageChanged(page));
this.footer.createItem.subscribe(item => this.createItem.emit(item));
}
ngOnChanges(changes) {
if (this.initialized) {
if ((changes.src && changes.src.currentValue) ||
(changes.formio && changes.formio.currentValue)) {
this.loadGrid(changes.src.currentValue);
}
if (changes.items && changes.items.currentValue) {
this.refreshGrid();
}
}
if (this.footer &&
(changes.createText && changes.createText.currentValue)) {
this.footer.createText = changes.createText.currentValue;
}
}
ngAfterViewInit() {
this.alerts.setAlerts([]);
this.query = this.query || {};
if (this.refresh) {
this.refresh.subscribe((query) => this.refreshGrid(query));
}
this.loadGrid(this.src);
this.initialized = true;
this.ref.detectChanges();
}
actionAllowed(action) {
if (this.isActionAllowed) {
return this.isActionAllowed(action);
}
else {
return true;
}
}
onError(error) {
this.isLoading = false;
this.error.emit(error);
if (typeof error === 'string' || error.message) {
this.alerts.setAlert({
type: 'danger',
message: error.message || error
});
}
}
refreshGrid(query) {
this.alerts.setAlerts([]);
this.query = query || this.query;
if (!this.query.hasOwnProperty('limit')) {
this.query.limit = 10;
}
if (!this.query.hasOwnProperty('skip')) {
this.query.skip = 0;
}
this.isLoading = true;
this.ref.detectChanges();
Formio.cache = {};
let loader = null;
if (this.items) {
loader = Promise.resolve(this.body.setRows(this.query, this.items));
}
else {
loader = this.body.load(this.formio, this.query);
}
return loader.then(info => {
this.isLoading = false;
this.initialized = true;
this.ref.detectChanges();
}).catch(error => this.onError(error));
}
setPage(num = -1) {
this.page = num !== -1 ? num : this.page;
if (!this.query.hasOwnProperty('limit')) {
this.query.limit = 10;
}
if (!this.query.hasOwnProperty('skip')) {
this.query.skip = 0;
}
this.query.skip = this.page * this.query.limit;
this.refreshGrid();
}
sortColumn(header) {
// Reset all other column sorts.
each(this.header.headers, (col) => {
if (col.key !== header.key) {
col.sort = '';
}
});
switch (header.sort) {
case 'asc':
header.sort = SortType.DESC;
this.query.sort = '-' + header.key;
break;
case 'desc':
header.sort = undefined;
delete this.query.sort;
break;
case undefined:
header.sort = SortType.ASC;
this.query.sort = header.key;
break;
}
this.refreshGrid();
}
pageChanged(page) {
this.setPage(page.page - 1);
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: FormioGridComponent, deps: [{ token: i1.FormioAlerts }, { token: i0.ComponentFactoryResolver }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: FormioGridComponent, selector: "formio-grid", inputs: { footerPosition: "footerPosition", src: "src", items: "items", onForm: "onForm", query: "query", refresh: "refresh", columns: "columns", gridType: "gridType", size: "size", components: "components", formio: "formio", label: "label", createText: "createText", isActionAllowed: "isActionAllowed" }, outputs: { select: "select", rowSelect: "rowSelect", rowAction: "rowAction", createItem: "createItem", error: "error" }, viewQueries: [{ propertyName: "headerElement", first: true, predicate: ["headerTemplate"], descendants: true, read: ViewContainerRef, static: true }, { propertyName: "bodyElement", first: true, predicate: ["bodyTemplate"], descendants: true, read: ViewContainerRef, static: true }, { propertyName: "footerElement", first: true, predicate: ["footerTemplate"], descendants: true, read: ViewContainerRef, static: true }], usesOnChanges: true, ngImport: i0, template: "<ng-template #headerTemplate></ng-template>\r\n<ng-template #bodyTemplate></ng-template>\r\n<ng-template #footerTemplate></ng-template>\r\n<div class=\"formio-grid\">\r\n <formio-alerts [alerts]=\"alerts\"></formio-alerts>\r\n <table class=\"table table-bordered table-striped table-hover\">\r\n <ng-container *ngIf=\"initialized && [footerPositions.top, footerPositions.both].indexOf(footerPosition) !== -1\"\r\n [ngTemplateOutlet]=\"footer.template\" [ngTemplateOutletContext]=\"{ position: footerPositions.top, label: label }\">\r\n </ng-container>\r\n <ng-container *ngIf=\"initialized\"\r\n [ngTemplateOutlet]=\"header.template\"></ng-container>\r\n <formio-loader [isLoading]=\"isLoading\"></formio-loader>\r\n <ng-container *ngIf=\"initialized\" [ngTemplateOutlet]=\"body.template\"></ng-container>\r\n <ng-container *ngIf=\"initialized && [footerPositions.bottom, footerPositions.both].indexOf(footerPosition) !== -1\"\r\n [ngTemplateOutlet]=\"footer.template\" [ngTemplateOutletContext]=\"{ position: footerPositions.bottom, label: label }\">\r\n </ng-container>\r\n </table>\r\n</div>\r\n", styles: [".formio-grid{position:relative;width:100%}.grid-refresh{height:400px;width:100%}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i1.FormioLoaderComponent, selector: "formio-loader", inputs: ["isLoading"] }, { kind: "component", type: i1.FormioAlertsComponent, selector: "formio-alerts", inputs: ["alerts"], outputs: ["focusComponent"] }] });
}
export { FormioGridComponent };
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: FormioGridComponent, decorators: [{
type: Component,
args: [{ selector: 'formio-grid', template: "<ng-template #headerTemplate></ng-template>\r\n<ng-template #bodyTemplate></ng-template>\r\n<ng-template #footerTemplate></ng-template>\r\n<div class=\"formio-grid\">\r\n <formio-alerts [alerts]=\"alerts\"></formio-alerts>\r\n <table class=\"table table-bordered table-striped table-hover\">\r\n <ng-container *ngIf=\"initialized && [footerPositions.top, footerPositions.both].indexOf(footerPosition) !== -1\"\r\n [ngTemplateOutlet]=\"footer.template\" [ngTemplateOutletContext]=\"{ position: footerPositions.top, label: label }\">\r\n </ng-container>\r\n <ng-container *ngIf=\"initialized\"\r\n [ngTemplateOutlet]=\"header.template\"></ng-container>\r\n <formio-loader [isLoading]=\"isLoading\"></formio-loader>\r\n <ng-container *ngIf=\"initialized\" [ngTemplateOutlet]=\"body.template\"></ng-container>\r\n <ng-container *ngIf=\"initialized && [footerPositions.bottom, footerPositions.both].indexOf(footerPosition) !== -1\"\r\n [ngTemplateOutlet]=\"footer.template\" [ngTemplateOutletContext]=\"{ position: footerPositions.bottom, label: label }\">\r\n </ng-container>\r\n </table>\r\n</div>\r\n", styles: [".formio-grid{position:relative;width:100%}.grid-refresh{height:400px;width:100%}\n"] }]
}], ctorParameters: function () { return [{ type: i1.FormioAlerts }, { type: i0.ComponentFactoryResolver }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { footerPosition: [{
type: Input
}], src: [{
type: Input
}], items: [{
type: Input
}], onForm: [{
type: Input
}], query: [{
type: Input
}], refresh: [{
type: Input
}], columns: [{
type: Input
}], gridType: [{
type: Input
}], size: [{
type: Input
}], components: [{
type: Input
}], formio: [{
type: Input
}], label: [{
type: Input
}], createText: [{
type: Input
}], isActionAllowed: [{
type: Input
}], select: [{
type: Output
}], rowSelect: [{
type: Output
}], rowAction: [{
type: Output
}], createItem: [{
type: Output
}], error: [{
type: Output
}], headerElement: [{
type: ViewChild,
args: ['headerTemplate', { read: ViewContainerRef, static: true }]
}], bodyElement: [{
type: ViewChild,
args: ['bodyTemplate', { read: ViewContainerRef, static: true }]
}], footerElement: [{
type: ViewChild,
args: ['footerTemplate', { read: ViewContainerRef, static: true }]
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid.component.js","sourceRoot":"","sources":["../../../../projects/angular-formio/grid/src/grid.component.ts","../../../../projects/angular-formio/grid/src/grid.component.html"],"names":[],"mappings":"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","sourcesContent":["import { GridFooterPositions } from './types/grid-footer-positions';\r\nimport {\r\n  AfterViewInit,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ComponentFactoryResolver,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  Output,\r\n  ViewChild,\r\n  ViewContainerRef\r\n} from '@angular/core';\r\nimport {FormioAlerts} from '@formio-tmt/angular';\r\nimport {each} from 'lodash';\r\nimport {Formio} from '@formio-tmt/js';\r\nimport {GridHeaderComponent} from './GridHeaderComponent';\r\nimport {GridBodyComponent} from './GridBodyComponent';\r\nimport {GridFooterComponent} from './GridFooterComponent';\r\nimport FormComponents from './form/index';\r\nimport SubmissionComponents from './submission/index';\r\nimport {FormioPromiseService} from '@formio-tmt/angular';\r\nimport {GridColumn} from './types/grid-column';\r\nimport {GridHeader, SortType} from './types/grid-header';\r\n\r\n@Component({\r\n  selector: 'formio-grid',\r\n  styleUrls: ['./grid.component.scss'],\r\n  templateUrl: './grid.component.html'\r\n})\r\nexport class FormioGridComponent implements OnChanges, OnInit, AfterViewInit {\r\n  @Input() footerPosition = GridFooterPositions.bottom;\r\n  @Input() src?: string;\r\n  @Input() items?: Array<any>;\r\n  @Input() onForm?: Promise<any>;\r\n  @Input() query?: any;\r\n  @Input() refresh?: EventEmitter<object>;\r\n  @Input() columns?: Array<GridColumn>;\r\n  @Input() gridType?: string;\r\n  @Input() size?: number;\r\n  @Input() components?: any;\r\n  @Input() formio?: FormioPromiseService;\r\n  @Input() label?: string;\r\n  @Input() createText: String;\r\n  @Input() isActionAllowed: any;\r\n  @Output() select: EventEmitter<object>;\r\n  @Output() rowSelect: EventEmitter<object>;\r\n  @Output() rowAction: EventEmitter<object>;\r\n  @Output() createItem: EventEmitter<any>;\r\n  @Output() error: EventEmitter<any>;\r\n  @ViewChild('headerTemplate', {read: ViewContainerRef, static: true}) headerElement: ViewContainerRef;\r\n  @ViewChild('bodyTemplate', {read: ViewContainerRef, static: true}) bodyElement: ViewContainerRef;\r\n  @ViewChild('footerTemplate', {read: ViewContainerRef, static: true}) footerElement: ViewContainerRef;\r\n\r\n  public page = 0;\r\n  public isLoading = false;\r\n  public initialized = false;\r\n  public header: GridHeaderComponent;\r\n  public body: GridBodyComponent;\r\n  public footer: GridFooterComponent;\r\n  public footerPositions = GridFooterPositions;\r\n\r\n  constructor(\r\n    public alerts: FormioAlerts,\r\n    private resolver: ComponentFactoryResolver,\r\n    private ref: ChangeDetectorRef\r\n  ) {\r\n    this.select = this.rowSelect = new EventEmitter();\r\n    this.rowAction = new EventEmitter();\r\n    this.createItem = new EventEmitter();\r\n    this.error = new EventEmitter();\r\n    this.isLoading = true;\r\n  }\r\n\r\n  createComponent(property, component) {\r\n    const factory = this.resolver.resolveComponentFactory(component);\r\n    const componentRef = property.createComponent(factory);\r\n    return componentRef.instance;\r\n  }\r\n\r\n  loadGrid(src?: string) {\r\n    // If no source is provided, then skip.\r\n    if (!src && !this.formio) {\r\n      return;\r\n    }\r\n    // Do not double load.\r\n    if (this.formio && this.src && (src === this.src)) {\r\n      return;\r\n    }\r\n\r\n    if (src) {\r\n      this.src = src;\r\n      this.formio = new FormioPromiseService(this.src, { formOnly: true });\r\n    }\r\n\r\n    // Load the header.\r\n    this.header.load(this.formio, {}, this.columns)\r\n      .then(() => this.setPage(0))\r\n      .catch(error => this.onError(error));\r\n  }\r\n\r\n  ngOnInit() {\r\n    // Create our components.\r\n    const comps = this.components || ((this.gridType === 'form') ? FormComponents : SubmissionComponents);\r\n\r\n    this.header = this.createComponent(this.headerElement, comps.header);\r\n    this.header.actionAllowed = this.actionAllowed.bind(this);\r\n    this.header.sort.subscribe(header => this.sortColumn(header));\r\n\r\n    this.body = this.createComponent(this.bodyElement, comps.body);\r\n    this.body.header = this.header;\r\n    this.body.actionAllowed = this.actionAllowed.bind(this);\r\n    this.body.rowSelect.subscribe(row => this.rowSelect.emit(row));\r\n    this.body.rowAction.subscribe(action => this.rowAction.emit(action));\r\n\r\n    this.footer = this.createComponent(this.footerElement, comps.footer);\r\n    this.footer.header = this.header;\r\n    this.footer.body = this.body;\r\n    this.footer.actionAllowed = this.actionAllowed.bind(this);\r\n    this.footer.createText = this.createText;\r\n    this.footer.size = this.size;\r\n    this.footer.pageChanged.subscribe(page => this.pageChanged(page));\r\n    this.footer.createItem.subscribe(item => this.createItem.emit(item));\r\n  }\r\n\r\n  ngOnChanges(changes: any) {\r\n    if (this.initialized) {\r\n      if (\r\n        (changes.src && changes.src.currentValue) ||\r\n        (changes.formio && changes.formio.currentValue)\r\n      ) {\r\n        this.loadGrid(changes.src.currentValue);\r\n      }\r\n\r\n      if (changes.items && changes.items.currentValue) {\r\n        this.refreshGrid();\r\n      }\r\n    }\r\n\r\n    if (this.footer &&\r\n        (changes.createText && changes.createText.currentValue)) {\r\n      this.footer.createText = changes.createText.currentValue;\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.alerts.setAlerts([]);\r\n    this.query = this.query || {};\r\n    if (this.refresh) {\r\n      this.refresh.subscribe((query: object) => this.refreshGrid(query));\r\n    }\r\n    this.loadGrid(this.src);\r\n    this.initialized = true;\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  actionAllowed(action) {\r\n    if (this.isActionAllowed) {\r\n      return this.isActionAllowed(action);\r\n    } else {\r\n      return true;\r\n    }\r\n  }\r\n\r\n  onError(error: any) {\r\n    this.isLoading = false;\r\n    this.error.emit(error);\r\n    if (typeof error === 'string' || error.message) {\r\n      this.alerts.setAlert({\r\n        type: 'danger',\r\n        message: error.message || error\r\n      });\r\n    }\r\n  }\r\n\r\n  refreshGrid(query?: any) {\r\n    this.alerts.setAlerts([]);\r\n    this.query = query || this.query;\r\n    if (!this.query.hasOwnProperty('limit')) {\r\n      this.query.limit = 10;\r\n    }\r\n    if (!this.query.hasOwnProperty('skip')) {\r\n      this.query.skip = 0;\r\n    }\r\n    this.isLoading = true;\r\n    this.ref.detectChanges();\r\n    Formio.cache = {};\r\n    let loader = null;\r\n    if (this.items) {\r\n      loader = Promise.resolve(this.body.setRows(this.query, this.items));\r\n    } else {\r\n      loader = this.body.load(this.formio, this.query);\r\n    }\r\n\r\n    return loader.then(info => {\r\n      this.isLoading = false;\r\n      this.initialized = true;\r\n      this.ref.detectChanges();\r\n    }).catch(error => this.onError(error));\r\n  }\r\n\r\n  setPage(num = -1) {\r\n    this.page = num !== -1 ? num : this.page;\r\n    if (!this.query.hasOwnProperty('limit')) {\r\n      this.query.limit = 10;\r\n    }\r\n    if (!this.query.hasOwnProperty('skip')) {\r\n      this.query.skip = 0;\r\n    }\r\n    this.query.skip = this.page * this.query.limit;\r\n    this.refreshGrid();\r\n  }\r\n\r\n  sortColumn(header: GridHeader) {\r\n    // Reset all other column sorts.\r\n    each(this.header.headers, (col: any) => {\r\n      if (col.key !== header.key) {\r\n        col.sort = '';\r\n      }\r\n    });\r\n    switch (header.sort) {\r\n      case 'asc':\r\n        header.sort = SortType.DESC;\r\n        this.query.sort = '-' + header.key;\r\n        break;\r\n      case 'desc':\r\n        header.sort = undefined;\r\n        delete this.query.sort;\r\n        break;\r\n      case undefined:\r\n        header.sort = SortType.ASC;\r\n        this.query.sort = header.key;\r\n        break;\r\n    }\r\n    this.refreshGrid();\r\n  }\r\n\r\n  pageChanged(page: any) {\r\n    this.setPage(page.page - 1);\r\n  }\r\n}\r\n","<ng-template #headerTemplate></ng-template>\r\n<ng-template #bodyTemplate></ng-template>\r\n<ng-template #footerTemplate></ng-template>\r\n<div class=\"formio-grid\">\r\n  <formio-alerts [alerts]=\"alerts\"></formio-alerts>\r\n  <table class=\"table table-bordered table-striped table-hover\">\r\n    <ng-container *ngIf=\"initialized && [footerPositions.top, footerPositions.both].indexOf(footerPosition) !== -1\"\r\n      [ngTemplateOutlet]=\"footer.template\" [ngTemplateOutletContext]=\"{ position: footerPositions.top, label: label }\">\r\n    </ng-container>\r\n    <ng-container *ngIf=\"initialized\"\r\n      [ngTemplateOutlet]=\"header.template\"></ng-container>\r\n    <formio-loader [isLoading]=\"isLoading\"></formio-loader>\r\n    <ng-container *ngIf=\"initialized\" [ngTemplateOutlet]=\"body.template\"></ng-container>\r\n    <ng-container *ngIf=\"initialized && [footerPositions.bottom, footerPositions.both].indexOf(footerPosition) !== -1\"\r\n      [ngTemplateOutlet]=\"footer.template\" [ngTemplateOutletContext]=\"{ position: footerPositions.bottom, label: label }\">\r\n    </ng-container>\r\n  </table>\r\n</div>\r\n"]}