1 import {Pager} from '@eg/share/util/pager';
2 import {Component, Input, ViewChild, OnInit} from '@angular/core';
3 import {Router, ActivatedRoute} from '@angular/router';
4 import {IdlService, IdlObject} from '@eg/core/idl.service';
5 import {GridDataSource} from '@eg/share/grid/grid';
6 import {GridComponent} from '@eg/share/grid/grid.component';
7 import {ToastService} from '@eg/share/toast/toast.service';
8 import {PcrudService} from '@eg/core/pcrud.service';
9 import {OrgService} from '@eg/core/org.service';
10 import {PermService} from '@eg/core/perm.service';
11 import {AuthService} from '@eg/core/auth.service';
12 import {AdminPageComponent} from '../../../share/admin-page/admin-page.component';
15 templateUrl: './floating-group.component.html'
18 export class FloatingGroupComponent extends AdminPageComponent implements OnInit {
22 gridDataSource: GridDataSource = new GridDataSource();
24 @ViewChild('grid', {static: true}) grid: GridComponent;
27 route: ActivatedRoute,
34 private router: Router
36 super(route, idl, org, auth, pcrud, perm, toast);
41 this.gridDataSource.getRows = (pager: Pager, sort: any[]) => {
43 const orderBy: any = {};
45 orderBy.cfg = sort[0].name + ' ' + sort[0].dir;
54 return this.pcrud.retrieveAll('cfg', searchOps);
57 this.grid.onRowActivate.subscribe(
58 (idlThing: IdlObject) => {
59 const idToEdit = idlThing.id();
60 this.navigateToEditPage(idToEdit);
65 editSelected = (floatingGroups: IdlObject[]) => {
66 const idToEdit = floatingGroups[0].id();
67 this.navigateToEditPage(idToEdit);
70 deleteSelected = (floatingGroups: IdlObject[]) => {
71 super.deleteSelected(floatingGroups);
74 navigateToEditPage(id: any) {
75 this.router.navigate(['/staff/admin/server/config/floating_group/' + id]);
78 // this was left mostly blank to ensure a modal does not open for edits
79 showEditDialog(idlThing: IdlObject): Promise<any> {