diff --git a/ui/public/index.html b/ui/public/index.html
index f054de3d3..55d5ab7f6 100644
--- a/ui/public/index.html
+++ b/ui/public/index.html
@@ -6,7 +6,6 @@
React App
-
-
+
\ No newline at end of file
diff --git a/ui/src/App.css b/ui/src/App.css
index 1780dc194..6ea8eeaaa 100644
--- a/ui/src/App.css
+++ b/ui/src/App.css
@@ -1,6 +1,3 @@
-.App {
- text-align: center;
-}
.App-logo {
height: 40vmin;
@@ -13,16 +10,6 @@
}
}
-.App-header {
- background-color: #282c34;
- min-height: 100vh;
- display: flex;
- flex-direction: column;
- align-items: center;
- justify-content: center;
- font-size: calc(10px + 2vmin);
- color: white;
-}
.App-link {
color: #61dafb;
@@ -40,8 +27,3 @@
html {
background-color: #D6D9DC;
}
-
-body {
- margin: 0px auto;
- width: 100vw;
-}
\ No newline at end of file
diff --git a/ui/src/App.tsx b/ui/src/App.tsx
index 94dae94b6..35fd706ab 100644
--- a/ui/src/App.tsx
+++ b/ui/src/App.tsx
@@ -3,10 +3,8 @@ import View from "./components/View";
function App() {
return (
-
-
);
}
diff --git a/ui/src/components/CreateInstanceForm.tsx b/ui/src/components/CreateInstanceForm.tsx
index 05bd32a7b..1f820f35c 100644
--- a/ui/src/components/CreateInstanceForm.tsx
+++ b/ui/src/components/CreateInstanceForm.tsx
@@ -23,7 +23,7 @@ function CreateInstanceForm(props: any) {
setLoading(true)
axios
.post
(api("service-instances"),
- {name: name, planID: planId})
+ {name: name, service_plan_id: planId})
.then((response) => {
setLoading(false);
// setServiceInstances(response.data);
@@ -45,7 +45,7 @@ function CreateInstanceForm(props: any) {
setName(generateServiceInstanceName(
props.plan?.name,
- props.offering?.catalogName
+ props.offering?.catalog_name
))
setPlanId(props.plan.id)
@@ -59,7 +59,7 @@ function CreateInstanceForm(props: any) {
Name}>
diff --git a/ui/src/components/SecretsView.tsx b/ui/src/components/SecretsView.tsx
index 60e4e5276..3d201b419 100644
--- a/ui/src/components/SecretsView.tsx
+++ b/ui/src/components/SecretsView.tsx
@@ -62,7 +62,7 @@ function SecretsView(props: any) {
return (
<>
{
props.handler(e.target.value);
}}
diff --git a/ui/src/components/ServiceInstancesView.tsx b/ui/src/components/ServiceInstancesView.tsx
index c19dfe520..6b09b0a54 100644
--- a/ui/src/components/ServiceInstancesView.tsx
+++ b/ui/src/components/ServiceInstancesView.tsx
@@ -15,7 +15,7 @@ function ServiceInstancesView() {
const [portal, setPortal] = useState();
useEffect(() => {
- var useTestData = process.env.REACT_APP_USE_TEST_DATA
+ var useTestData = process.env.REACT_APP_USE_TEST_DATA === "true"
if (!useTestData) {
setLoading(true)
axios
@@ -55,7 +55,8 @@ function ServiceInstancesView() {
{
console.log("Row clicked")
- const instanceView =
+ const instanceView =
const portal = createPortal( instanceView, document.getElementById("App")!!)
setPortal(portal)
}}
@@ -78,18 +79,25 @@ function ServiceInstancesView() {
return (
<>
{
+
+
+
+
+ Service Instance
+
+
+
+ Service Namespace
+
+ >
+ }
+ >
+ {renderData()}
+
+
-
-
- Service Instance
-
- >
- }
- >
- {renderData()}
-
}
{portal != null && portal}
diff --git a/ui/src/components/ServiceOfferingsDetailsView.tsx b/ui/src/components/ServiceOfferingsDetailsView.tsx
index cc9371fdc..4c595247a 100644
--- a/ui/src/components/ServiceOfferingsDetailsView.tsx
+++ b/ui/src/components/ServiceOfferingsDetailsView.tsx
@@ -76,7 +76,7 @@ function ServiceOfferingsDetailsView(props: any) {
startContent={
<>
- Create {offering?.catalogName} Service Instance
+ Create {offering?.metadata.displayName} Service Instance
>
}
@@ -96,7 +96,7 @@ function ServiceOfferingsDetailsView(props: any) {
- {offering?.catalogName}
+ {offering?.metadata.displayName}
{offering?.description}
diff --git a/ui/src/components/ServiceOfferingsView.tsx b/ui/src/components/ServiceOfferingsView.tsx
index 43ae89a4c..c7c3aaf17 100644
--- a/ui/src/components/ServiceOfferingsView.tsx
+++ b/ui/src/components/ServiceOfferingsView.tsx
@@ -10,9 +10,10 @@ import "@ui5/webcomponents-fiori/dist/illustrations/NoData.js";
import Ok from "../shared/validator";
import {createPortal} from "react-dom";
import ServiceOfferingsDetailsView from "./ServiceOfferingsDetailsView";
+import { ResponsiveGridLayout } from "@ui5/webcomponents-react";
function ServiceOfferingsView(props: any) {
- const greyImg = ""
+ const greyImg = ""
const [offerings, setOfferings] = useState();
const [loading, setLoading] = useState(true);
const [error, setError] = useState(null);
@@ -66,12 +67,8 @@ function ServiceOfferingsView(props: any) {
const cards = offerings?.items.map((offering, index) => {
// @ts-ignore
return (
- <>
{
setPortal(createPortal( , document.getElementById("App")!!, window.crypto.randomUUID()))
}}
@@ -82,22 +79,29 @@ function ServiceOfferingsView(props: any) {
}
- style={{
- width: "100%"
- }}
- subtitleText={offering.description}
- titleText={offering.catalogName}
+ subtitleText={offering.catalog_name}
+ titleText={offering.metadata.displayName}
status={formatStatus(index, offerings?.numItems)}
interactive
- />
+ />
}
- />
- >
+ >
+
);
});
return <>
- {cards}
+
+
+ {/* */}
+ {cards}
+ {/* */}
+
{portal != null && portal}
>
};
diff --git a/ui/src/components/View.tsx b/ui/src/components/View.tsx
index 30e567d6b..57b4840d9 100644
--- a/ui/src/components/View.tsx
+++ b/ui/src/components/View.tsx
@@ -18,57 +18,49 @@ function Overview(props: any) {
return (
<>
- Service Management UI}
- >
- Service Marketplace
-
+
SAP BTP, Kyma runtime}
startContent={Select your credentials:}
>
- handler(e)} style={{width: "100vw"}} />
+ handler(e)} style={{width: "100%"}} />
+
+
+
+
+
+
<>
-
-
-
- {
- setPageContent();
- }}
- />
- {
- setPageContent();
- }}
- />
-
-
+
+
+
+ {
+ setPageContent();
+ }}
+ />
+ {
+ setPageContent();
+ }}
+ />
+
+
+
+
+
{pageContent}
-
-
-
+
>
+
+
>
);
}
diff --git a/ui/src/index.css b/ui/src/index.css
index ec2585e8c..a3d249f7d 100644
--- a/ui/src/index.css
+++ b/ui/src/index.css
@@ -5,9 +5,56 @@ body {
sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
+ overflow: hidden;
}
code {
font-family: source-code-pro, Menlo, Monaco, Consolas, 'Courier New',
monospace;
}
+
+* {
+ box-sizing: border-box;
+}
+
+#root {
+ position: absolute;
+ top: 0;
+ right: 0;
+ bottom: 0;
+ left: 0;
+ padding: 0.5rem 0.5rem 0 0.5rem;
+}
+
+.flex-container {
+ display: flex;
+}
+
+.flex-column {
+ flex-direction: column;
+ width: 100%;
+}
+
+.flex-row {
+ flex-direction: row;
+ height: 100%;
+}
+
+
+#App {
+ display: flex;
+ min-height: 0;
+ position: relative;
+ height: 100%;
+}
+
+.margin-wrapper {
+ margin: 0.5rem 0.5rem 0 0.5rem;
+ padding: 0.5rem 0.5rem 0 0.5rem;
+}
+
+.scrollable {
+ overflow-y: auto;
+ height: 100%;
+ width: 100%;
+}
diff --git a/ui/src/index.tsx b/ui/src/index.tsx
index 80878705b..018648421 100644
--- a/ui/src/index.tsx
+++ b/ui/src/index.tsx
@@ -1,9 +1,10 @@
-import React from "react";
import ReactDOM from "react-dom/client";
import "./index.css";
import App from "./App";
import { ThemeProvider } from "@ui5/webcomponents-react";
+import '@ui5/webcomponents-react/dist/Assets';
+
const root = ReactDOM.createRoot(
document.getElementById("root") as HTMLElement
);
diff --git a/ui/src/shared/models.tsx b/ui/src/shared/models.tsx
index 655eb5fb8..59a7b4eb7 100644
--- a/ui/src/shared/models.tsx
+++ b/ui/src/shared/models.tsx
@@ -16,7 +16,7 @@ export interface ServiceOffering {
id: string;
description: string;
catalogId: string;
- catalogName: string;
+ catalog_name: string;
metadata: ServiceOfferingMetadata;
}
@@ -48,10 +48,14 @@ export interface ServiceInstance {
name: string;
context: string[];
namespace: string;
- serviceBindings: ServiceInstanceBindings[];
+ serviceBindings: ServiceInstanceBinding[];
}
export interface ServiceInstanceBindings {
+ items: ServiceInstanceBinding[];
+}
+
+export interface ServiceInstanceBinding {
id: string;
name: string;
namespace: string;