Merge branch 'master' into 13765-information-inside-details-panel
[arvados-workbench2.git] / src / services / groups-service / groups-service.ts
index 8c5fd8fa6ce855d9a2cbc052eb924920431b1c9b..2a5a51a851b8e48a0741e085164dbaff9f6c7e8c 100644 (file)
@@ -10,10 +10,9 @@ import { AxiosInstance } from "axios";
 import { GroupResource } from "../../models/group";
 import { CollectionResource } from "../../models/collection";
 import { ProjectResource } from "../../models/project";
-import { WorkflowResource } from "../../models/workflow";
 import { ProcessResource } from "../../models/process";
 
-interface ContensArguments {
+export interface ContentsArguments {
     limit?: number;
     offset?: number;
     order?: OrderBuilder;
@@ -24,16 +23,15 @@ interface ContensArguments {
 export type GroupContentsResource =
     CollectionResource |
     ProjectResource |
-    WorkflowResource |
     ProcessResource;
 
-export default class GroupsService extends CommonResourceService<GroupResource> {
+export default class GroupsService<T extends GroupResource = GroupResource> extends CommonResourceService<T> {
 
     constructor(serverApi: AxiosInstance) {
         super(serverApi, "groups");
     }
 
-    contents(uuid: string, args: ContensArguments = {}): Promise<ListResults<GroupContentsResource>> {
+    contents(uuid: string, args: ContentsArguments = {}): Promise<ListResults<GroupContentsResource>> {
         const { filters, order, ...other } = args;
         const params = {
             ...other,
@@ -46,4 +44,10 @@ export default class GroupsService extends CommonResourceService<GroupResource>
             })
             .then(CommonResourceService.mapResponseKeys);
     }
+}
+
+export enum GroupContentsResourcePrefix {
+    Collection = "collections",
+    Project = "groups",
+    Process = "container_requests"
 }
\ No newline at end of file