From b6bdd9780fb35ea888e69f9a68e299ca60c101f5 Mon Sep 17 00:00:00 2001
From: jbirddog <100367399+jbirddog@users.noreply.github.com>
Date: Thu, 8 Feb 2024 14:50:31 -0500
Subject: [PATCH] Allow adding a data store at the top level (#1004)
* Show tiles at the top level
* Add a data store from the top level
* Pre pr cleanup
---
.../src/components/DataStoreListTiles.tsx | 7 ++--
.../src/routes/ProcessGroupList.tsx | 32 +++++++++++++++----
2 files changed, 28 insertions(+), 11 deletions(-)
diff --git a/spiffworkflow-frontend/src/components/DataStoreListTiles.tsx b/spiffworkflow-frontend/src/components/DataStoreListTiles.tsx
index d5cd0609..62b2240c 100644
--- a/spiffworkflow-frontend/src/components/DataStoreListTiles.tsx
+++ b/spiffworkflow-frontend/src/components/DataStoreListTiles.tsx
@@ -41,10 +41,9 @@ export default function DataStoreListTiles({
if (defaultDataStores) {
setDataStores(defaultDataStores);
} else {
- let queryParams = '?per_page=1000';
- if (processGroup) {
- queryParams = `${queryParams}&process_group_identifier=${processGroup.id}`;
- }
+ const queryParams = `?per_page=1000&process_group_identifier=${
+ processGroup?.id ?? ''
+ }`;
HttpService.makeCallToBackend({
path: `${targetUris.dataStoreListPath}${queryParams}`,
successCallback: setDataStores,
diff --git a/spiffworkflow-frontend/src/routes/ProcessGroupList.tsx b/spiffworkflow-frontend/src/routes/ProcessGroupList.tsx
index 2840c05b..71c2aabe 100644
--- a/spiffworkflow-frontend/src/routes/ProcessGroupList.tsx
+++ b/spiffworkflow-frontend/src/routes/ProcessGroupList.tsx
@@ -2,6 +2,7 @@ import { useEffect, useState } from 'react';
import { useNavigate } from 'react-router-dom';
import {
Button,
+ Stack,
// @ts-ignore
} from '@carbon/react';
import { Can } from '@casl/react';
@@ -13,6 +14,7 @@ import { useUriListForPermissions } from '../hooks/UriListForPermissions';
import { usePermissionFetcher } from '../hooks/PermissionService';
import ProcessModelSearch from '../components/ProcessModelSearch';
import ProcessGroupListTiles from '../components/ProcessGroupListTiles';
+import DataStoreListTiles from '../components/DataStoreListTiles';
export default function ProcessGroupList() {
const navigate = useNavigate();
@@ -23,6 +25,7 @@ export default function ProcessGroupList() {
const { targetUris } = useUriListForPermissions();
const permissionRequestData: PermissionsToCheck = {
+ [targetUris.dataStoreListPath]: ['POST'],
[targetUris.processGroupListPath]: ['POST'],
};
const { ability } = usePermissionFetcher(permissionRequestData);
@@ -69,17 +72,32 @@ export default function ProcessGroupList() {
return (
<>
-
-
-
-
-
+
+
+
+
+
+
+
+
+
{processModelSearchArea()}
+
+
+ Data Stores}
+ userCanCreateDataStores={ability.can(
+ 'POST',
+ targetUris.dataStoreListPath
+ )}
+ />
>
);
}