UNPKG

@formio-tmt/angular

Version:

This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 10.1.4.

109 lines 18.7 kB
import { Component, ViewChild } from '@angular/core'; import { DefaultConfiguration } from '../form-manager.config'; import { FormioGridComponent } from '@formio-tmt/angular/grid'; import { debounce } from 'lodash'; import * as i0 from "@angular/core"; import * as i1 from "../form-manager.service"; import * as i2 from "@angular/router"; import * as i3 from "../form-manager.config"; import * as i4 from "@angular/common"; import * as i5 from "@formio-tmt/angular/grid"; class FormManagerIndexComponent { service; route; router; config; searchElement; formGrid; gridQuery; onSearch; constructor(service, route, router, config) { this.service = service; this.route = route; this.router = router; this.config = config; this.config = { ...DefaultConfiguration, ...this.config }; this.gridQuery = { type: this.config.type, sort: 'title' }; if (this.config.tag) { this.gridQuery.tags = this.config.tag; } this.onSearch = debounce(this._onSearch, 300); } loadGrid() { this.gridQuery = JSON.parse(localStorage.getItem('query')) || this.gridQuery; const currentPage = +localStorage.getItem('currentPage') || 0; this.formGrid .refreshGrid(this.gridQuery) .then(() => this.formGrid.setPage(currentPage - 1)); } ngOnInit() { this.gridQuery = { type: this.config.type, sort: 'title' }; if (this.config.tag) { this.gridQuery.tags = this.config.tag; } this.service.reset(); this.service.ready.then(() => { this.loadGrid(); this.formGrid.footer.pageChanged.subscribe(page => { localStorage.setItem('currentPage', page.page); }); }); } ngAfterViewInit() { this.searchElement.nativeElement.value = localStorage.getItem('searchInput') || ''; } _onSearch() { const search = this.searchElement.nativeElement.value; if (search.length > 0) { this.gridQuery.skip = 0; this.gridQuery.title__regex = '/' + search + '/i'; this.gridQuery.title__regex = '/' + search.trim() + '/i'; } else { delete this.gridQuery.title__regex; } localStorage.setItem('query', JSON.stringify(this.gridQuery)); localStorage.setItem('searchInput', search); this.formGrid.pageChanged({ page: 1, itemPerPage: this.gridQuery.limit }); this.formGrid.refreshGrid(this.gridQuery); } clearSearch() { this.gridQuery = { type: this.config.type, sort: 'title' }; if (this.config.tag) { this.gridQuery.tags = this.config.tag; } localStorage.removeItem('query'); localStorage.removeItem('searchInput'); localStorage.removeItem('currentPage'); if (this.searchElement?.nativeElement) { this.searchElement.nativeElement.value = ''; } this.formGrid.pageChanged({ page: 1 }); this.formGrid.query = {}; this.formGrid.refreshGrid(this.gridQuery); } onAction(action) { this.service.form = null; // Reset previous form data this.router.navigate([action.row._id, action.action], { relativeTo: this.route }); } onSelect(row) { this.router.navigate([row._id], { relativeTo: this.route }); } onCreateItem() { this.router.navigate(['create'], { relativeTo: this.route }); } static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: FormManagerIndexComponent, deps: [{ token: i1.FormManagerService }, { token: i2.ActivatedRoute }, { token: i2.Router }, { token: i3.FormManagerConfig }], target: i0.ɵɵFactoryTarget.Component }); static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.6", type: FormManagerIndexComponent, selector: "ng-component", viewQueries: [{ propertyName: "searchElement", first: true, predicate: ["search"], descendants: true }, { propertyName: "formGrid", first: true, predicate: FormioGridComponent, descendants: true }], ngImport: i0, template: "<div role=\"search\" class=\"input-group mb-3\" *ngIf=\"config.includeSearch\">\r\n <input #search type=\"text\" (keyup)=\"onSearch()\" class=\"form-control\" placeholder=\"Search Forms\" aria-label=\"Search Forms\" aria-describedby=\"button-search\">\r\n <span *ngIf=\"search && search !== ''\" class=\"form-clear input-group-addon\" (click)=\"clearSearch()\"><span class=\"fa fa-times bi bi-x\"></span></span>\r\n</div>\r\n<formio-grid\r\n *ngIf=\"service.ready\"\r\n [formio]=\"service.formio\"\r\n [gridType]=\"'form'\"\r\n [query]=\"gridQuery\"\r\n [isActionAllowed]=\"service.actionAllowed\"\r\n (rowAction)=\"onAction($event)\"\r\n (rowSelect)=\"onSelect($event)\"\r\n (createItem)=\"onCreateItem()\"\r\n></formio-grid>\r\n", styles: [".form-clear{background:#cecece;border-radius:50%;bottom:8px;color:#0000004d;cursor:pointer;display:flex;justify-content:center;align-items:center;padding-bottom:2px;height:24px;position:absolute;right:10px;top:6px;width:24px;z-index:10}.form-clear .fa{font-size:16px;font-weight:500}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.FormioGridComponent, selector: "formio-grid", inputs: ["footerPosition", "src", "items", "onForm", "query", "refresh", "columns", "gridType", "size", "components", "formio", "label", "createText", "isActionAllowed"], outputs: ["select", "rowSelect", "rowAction", "createItem", "error"] }] }); } export { FormManagerIndexComponent }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.6", ngImport: i0, type: FormManagerIndexComponent, decorators: [{ type: Component, args: [{ template: "<div role=\"search\" class=\"input-group mb-3\" *ngIf=\"config.includeSearch\">\r\n <input #search type=\"text\" (keyup)=\"onSearch()\" class=\"form-control\" placeholder=\"Search Forms\" aria-label=\"Search Forms\" aria-describedby=\"button-search\">\r\n <span *ngIf=\"search && search !== ''\" class=\"form-clear input-group-addon\" (click)=\"clearSearch()\"><span class=\"fa fa-times bi bi-x\"></span></span>\r\n</div>\r\n<formio-grid\r\n *ngIf=\"service.ready\"\r\n [formio]=\"service.formio\"\r\n [gridType]=\"'form'\"\r\n [query]=\"gridQuery\"\r\n [isActionAllowed]=\"service.actionAllowed\"\r\n (rowAction)=\"onAction($event)\"\r\n (rowSelect)=\"onSelect($event)\"\r\n (createItem)=\"onCreateItem()\"\r\n></formio-grid>\r\n", styles: [".form-clear{background:#cecece;border-radius:50%;bottom:8px;color:#0000004d;cursor:pointer;display:flex;justify-content:center;align-items:center;padding-bottom:2px;height:24px;position:absolute;right:10px;top:6px;width:24px;z-index:10}.form-clear .fa{font-size:16px;font-weight:500}\n"] }] }], ctorParameters: function () { return [{ type: i1.FormManagerService }, { type: i2.ActivatedRoute }, { type: i2.Router }, { type: i3.FormManagerConfig }]; }, propDecorators: { searchElement: [{ type: ViewChild, args: ['search'] }], formGrid: [{ type: ViewChild, args: [FormioGridComponent, { static: false }] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.component.js","sourceRoot":"","sources":["../../../../../projects/angular-formio/manager/src/index/index.component.ts","../../../../../projects/angular-formio/manager/src/index/index.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, OnInit, ViewChild } from '@angular/core';\r\nimport { Router, ActivatedRoute } from '@angular/router';\r\nimport { FormManagerService } from '../form-manager.service';\r\nimport { DefaultConfiguration, FormManagerConfig } from '../form-manager.config';\r\nimport { FormioGridComponent } from '@formio-tmt/angular/grid';\r\nimport { debounce } from 'lodash';\r\n\r\n@Component({\r\n  templateUrl: './index.component.html',\r\n  styleUrls: ['./index.component.scss']\r\n})\r\nexport class FormManagerIndexComponent implements OnInit, AfterViewInit {\r\n  @ViewChild('search') searchElement: ElementRef;\r\n  @ViewChild(FormioGridComponent, {static: false}) formGrid: FormioGridComponent;\r\n  public gridQuery: any;\r\n  public onSearch;\r\n  constructor(\r\n    public service: FormManagerService,\r\n    public route: ActivatedRoute,\r\n    public router: Router,\r\n    public config: FormManagerConfig\r\n  ) {\r\n    this.config = {...DefaultConfiguration, ...this.config};\r\n    this.gridQuery = {type: this.config.type, sort: 'title'};\r\n    if (this.config.tag) {\r\n      this.gridQuery.tags = this.config.tag;\r\n    }\r\n    this.onSearch = debounce(this._onSearch, 300);\r\n  }\r\n\r\n  loadGrid() {\r\n    this.gridQuery = JSON.parse(localStorage.getItem('query')) || this.gridQuery;\r\n    const currentPage = +localStorage.getItem('currentPage') || 0;\r\n    this.formGrid\r\n      .refreshGrid(this.gridQuery)\r\n      .then(() => this.formGrid.setPage(currentPage - 1));\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.gridQuery = {type: this.config.type, sort: 'title'};\r\n    if (this.config.tag) {\r\n      this.gridQuery.tags = this.config.tag;\r\n    }\r\n    this.service.reset();\r\n    this.service.ready.then(() => {\r\n      this.loadGrid();\r\n      this.formGrid.footer.pageChanged.subscribe(page => {\r\n        localStorage.setItem('currentPage', page.page);\r\n      });\r\n    });\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.searchElement.nativeElement.value = localStorage.getItem('searchInput') || '';\r\n  }\r\n\r\n  _onSearch() {\r\n    const search = this.searchElement.nativeElement.value;\r\n    if (search.length > 0) {\r\n      this.gridQuery.skip = 0;\r\n      this.gridQuery.title__regex = '/' + search + '/i';\r\n      this.gridQuery.title__regex = '/' + search.trim() + '/i';\r\n    } else {\r\n      delete this.gridQuery.title__regex;\r\n    }\r\n    localStorage.setItem('query', JSON.stringify(this.gridQuery));\r\n    localStorage.setItem('searchInput', search);\r\n    this.formGrid.pageChanged({page: 1, itemPerPage: this.gridQuery.limit});\r\n    this.formGrid.refreshGrid(this.gridQuery);\r\n  }\r\n\r\n  clearSearch() {\r\n    this.gridQuery = {type: this.config.type, sort: 'title'};\r\n    if (this.config.tag) {\r\n      this.gridQuery.tags = this.config.tag;\r\n    }\r\n    localStorage.removeItem('query');\r\n    localStorage.removeItem('searchInput');\r\n    localStorage.removeItem('currentPage');\r\n    if (this.searchElement?.nativeElement) {\r\n      this.searchElement.nativeElement.value = '';\r\n    }\r\n    this.formGrid.pageChanged({page: 1});\r\n    this.formGrid.query = {};\r\n    this.formGrid.refreshGrid(this.gridQuery);\r\n  }\r\n\r\n  onAction(action: any) {\r\n    this.service.form = null; // Reset previous form data\r\n    this.router.navigate([action.row._id, action.action], { relativeTo: this.route });\r\n  }\r\n\r\n  onSelect(row: any) {\r\n    this.router.navigate([row._id], { relativeTo: this.route });\r\n  }\r\n\r\n  onCreateItem() {\r\n    this.router.navigate(['create'], { relativeTo: this.route });\r\n  }\r\n}\r\n","<div role=\"search\" class=\"input-group mb-3\" *ngIf=\"config.includeSearch\">\r\n  <input #search type=\"text\" (keyup)=\"onSearch()\" class=\"form-control\" placeholder=\"Search Forms\" aria-label=\"Search Forms\" aria-describedby=\"button-search\">\r\n  <span *ngIf=\"search && search !== ''\" class=\"form-clear input-group-addon\" (click)=\"clearSearch()\"><span class=\"fa fa-times bi bi-x\"></span></span>\r\n</div>\r\n<formio-grid\r\n  *ngIf=\"service.ready\"\r\n  [formio]=\"service.formio\"\r\n  [gridType]=\"'form'\"\r\n  [query]=\"gridQuery\"\r\n  [isActionAllowed]=\"service.actionAllowed\"\r\n  (rowAction)=\"onAction($event)\"\r\n  (rowSelect)=\"onSelect($event)\"\r\n  (createItem)=\"onCreateItem()\"\r\n></formio-grid>\r\n"]}