1 import {Pager} from '@eg/share/util/pager';
2 import {Component, Input, ViewChild, OnInit} from '@angular/core';
3 import {Location} from '@angular/common';
4 import {Router, ActivatedRoute} from '@angular/router';
5 import {FormatService} from '@eg/core/format.service';
6 import {IdlService, IdlObject} from '@eg/core/idl.service';
7 import {GridDataSource} from '@eg/share/grid/grid';
8 import {GridComponent} from '@eg/share/grid/grid.component';
9 import {ToastService} from '@eg/share/toast/toast.service';
10 import {PcrudService} from '@eg/core/pcrud.service';
11 import {OrgService} from '@eg/core/org.service';
12 import {PermService} from '@eg/core/perm.service';
13 import {AuthService} from '@eg/core/auth.service';
14 import {AdminPageComponent} from '../../../share/admin-page/admin-page.component';
17 templateUrl: './floating-group.component.html'
20 export class FloatingGroupComponent extends AdminPageComponent implements OnInit {
24 gridDataSource: GridDataSource = new GridDataSource();
26 @ViewChild('grid', {static: true}) grid: GridComponent;
29 route: ActivatedRoute,
31 format: FormatService,
38 private router: Router
40 super(route, ngLocation, format, idl, org, auth, pcrud, perm, toast);
45 this.gridDataSource.getRows = (pager: Pager, sort: any[]) => {
47 const orderBy: any = {};
49 orderBy.cfg = sort[0].name + ' ' + sort[0].dir;
58 return this.pcrud.retrieveAll('cfg', searchOps);
61 this.grid.onRowActivate.subscribe(
62 (idlThing: IdlObject) => {
63 const idToEdit = idlThing.id();
64 this.navigateToEditPage(idToEdit);
69 editSelected = (floatingGroups: IdlObject[]) => {
70 const idToEdit = floatingGroups[0].id();
71 this.navigateToEditPage(idToEdit);
74 deleteSelected = (floatingGroups: IdlObject[]) => {
75 super.deleteSelected(floatingGroups);
78 navigateToEditPage(id: any) {
79 this.router.navigate(['/staff/admin/server/config/floating_group/' + id]);
82 // this was left mostly blank to ensure a modal does not open for edits
83 showEditDialog(idlThing: IdlObject): Promise<any> {