UNPKG

@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
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"]}