From 60235902a76b3256883b6cab5789907c0eb519f7 Mon Sep 17 00:00:00 2001 From: Nabarun Gogoi Date: Tue, 26 Dec 2023 12:47:42 +0530 Subject: [PATCH] Implement layout for Domain tab in project settings (#25) * Implement layout for Domains tab in settings * Handle review changes * Add json file for domains and take values from it * Handle review changes * Rename DomainsCard to DomainCard --------- Co-authored-by: neeraj --- packages/frontend/src/assets/domains.json | 8 ++++ .../projects/project/SettingsTabPanel.tsx | 6 +-- .../projects/project/settings/DomainCard.tsx | 48 +++++++++++++++++++ .../projects/project/settings/Domains.tsx | 36 ++++++++++++++ 4 files changed, 93 insertions(+), 5 deletions(-) create mode 100644 packages/frontend/src/assets/domains.json create mode 100644 packages/frontend/src/components/projects/project/settings/DomainCard.tsx create mode 100644 packages/frontend/src/components/projects/project/settings/Domains.tsx diff --git a/packages/frontend/src/assets/domains.json b/packages/frontend/src/assets/domains.json new file mode 100644 index 0000000..9b8f03b --- /dev/null +++ b/packages/frontend/src/assets/domains.json @@ -0,0 +1,8 @@ +[ + { + "domainid":1, + "projectid":1, + "domain": "randomurl.snowballtools.xyz", + "status": "live" + } +] diff --git a/packages/frontend/src/components/projects/project/SettingsTabPanel.tsx b/packages/frontend/src/components/projects/project/SettingsTabPanel.tsx index 02089c1..eb55520 100644 --- a/packages/frontend/src/components/projects/project/SettingsTabPanel.tsx +++ b/packages/frontend/src/components/projects/project/SettingsTabPanel.tsx @@ -1,5 +1,4 @@ import React, { createElement } from 'react'; - import { Tabs, TabsHeader, @@ -8,12 +7,9 @@ import { TabPanel, } from '@material-tailwind/react'; +import Domains from './settings/Domains'; import GeneralTabPanel from './settings/GeneralTabPanel'; -const Domains = () => { - return
Domains
; -}; - const EnvironmentVariables = () => { return
Environment Variables
; }; diff --git a/packages/frontend/src/components/projects/project/settings/DomainCard.tsx b/packages/frontend/src/components/projects/project/settings/DomainCard.tsx new file mode 100644 index 0000000..6f3d937 --- /dev/null +++ b/packages/frontend/src/components/projects/project/settings/DomainCard.tsx @@ -0,0 +1,48 @@ +import React from 'react'; +import { + Chip, + Typography, + Menu, + MenuHandler, + MenuList, + MenuItem, +} from '@material-tailwind/react'; + +const DomainCard = (props: { domain: string; status: string }) => { + return ( + <> +
+
+ + ^ {props.domain} + + ^} + /> +
+ +
+ + ^ + + + + + + + ^ Edit domain + ^ Delete domain + + +
+
+ Production + + ); +}; + +export default DomainCard; diff --git a/packages/frontend/src/components/projects/project/settings/Domains.tsx b/packages/frontend/src/components/projects/project/settings/Domains.tsx new file mode 100644 index 0000000..ac58da1 --- /dev/null +++ b/packages/frontend/src/components/projects/project/settings/Domains.tsx @@ -0,0 +1,36 @@ +import React from 'react'; +import { useParams } from 'react-router-dom'; +import { Button, Typography } from '@material-tailwind/react'; + +import DomainCard from './DomainCard'; +import domainsData from '../../../../assets/domains.json'; + +const Domains = () => { + const { id } = useParams(); + return ( + <> +
+ Domain + +
+ + {domainsData + .filter((domain) => { + return Number(id) == domain.projectid; + }) + .map((domain) => { + return ( + + ); + })} + + ); +}; + +export default Domains;