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;