From 209b4596917bb9a7c90ea9296fd07d0003e70c56 Mon Sep 17 00:00:00 2001 From: Rahul-538 Date: Tue, 24 Sep 2024 16:09:45 +0530 Subject: [PATCH] "Added metadata in Read-only tab" --- .../api/ProjectDetails/GetProjectDetails.js | 100 +++++++++++------- src/redux/constants.js | 1 + .../component/Tabs/ReadonlyConfigurations.jsx | 100 +++++++++++++++++- 3 files changed, 161 insertions(+), 40 deletions(-) diff --git a/src/redux/actions/api/ProjectDetails/GetProjectDetails.js b/src/redux/actions/api/ProjectDetails/GetProjectDetails.js index 90233575d..a62cd253b 100644 --- a/src/redux/actions/api/ProjectDetails/GetProjectDetails.js +++ b/src/redux/actions/api/ProjectDetails/GetProjectDetails.js @@ -1,42 +1,66 @@ /** * Login API */ - import API from "../../../api"; - import ENDPOINTS from "../../../../config/apiendpoint"; +import API from "../../../api"; +import ENDPOINTS from "../../../../config/apiendpoint"; import constants from "../../../constants"; - - export default class GetProjectDetailsAPI extends API { - constructor(projectId, timeout = 2000) { - super("GET", timeout, false); - this.type = constants.GET_PROJECT_DETAILS; - this.endpoint = `${super.apiEndPointAuto()}${ENDPOINTS.getProjects}${projectId}`; - } - - processResponse(res) { - super.processResponse(res); - if (res) { - this.projectDetails = res; - } - } - - apiEndPoint() { - return this.endpoint; - } - - getBody() {} - - getHeaders() { - this.headers = { - headers: { - "Content-Type": "application/json", - "Authorization":`JWT ${localStorage.getItem('shoonya_access_token')}` - }, - }; - return this.headers; - } - - getPayload() { - return this.projectDetails - } - } - \ No newline at end of file + +export default class GetProjectDetailsAPI extends API { + constructor(projectId, method = 'GET', payload = null, timeout = 2000) { + super(method, timeout, false); + this.projectId = projectId; + this.method = method.toUpperCase(); + this.payload = payload; + + if (this.method === 'GET') { + this.type = constants.GET_PROJECT_DETAILS; + } else if (this.method === 'PATCH') { + this.type = constants.PATCH_PROJECT_DETAILS; + } else { + throw new Error(`Unsupported HTTP method: ${method}`); + } + + this.endpoint = `${super.apiEndPointAuto()}${ENDPOINTS.getProjects}${projectId}${this.method === 'PATCH' ? '/' : ''}`; + } + + processResponse(res) { + super.processResponse(res); + if (res) { + if (this.method === 'GET') { + this.projectDetails = res; + } else if (this.method === 'PATCH') { + this.updatedProjectDetails = res; + } + } + } + + apiEndPoint() { + return this.endpoint; + } + + getBody() { + if (this.method === 'PATCH' && this.payload) { + return JSON.stringify(this.payload); + } + return null; + } + + getHeaders() { + this.headers = { + headers: { + "Content-Type": "application/json", + "Authorization": `JWT ${localStorage.getItem('shoonya_access_token')}`, + }, + }; + return this.headers; + } + + getPayload() { + if (this.method === 'GET') { + return this.projectDetails; + } else if (this.method === 'PATCH') { + return this.updatedProjectDetails; + } + return null; + } +} diff --git a/src/redux/constants.js b/src/redux/constants.js index d2293df1f..28d8c38fc 100644 --- a/src/redux/constants.js +++ b/src/redux/constants.js @@ -118,6 +118,7 @@ const constants = { SUBTITLES: "SUBTITLES", PATCH_ANNOTATION:"PATCH_ANNOTATION", UPDATE_UI_PREFS: "UPDATE_UI_PREFS", + PATCH_PROJECT_DETAILS: 'PATCH_PROJECT_DETAILS', POST_TRANSLITERATION_LOG : "POST_TRANSLITERATION_LOG" }; diff --git a/src/ui/pages/component/Tabs/ReadonlyConfigurations.jsx b/src/ui/pages/component/Tabs/ReadonlyConfigurations.jsx index 371964459..905238489 100644 --- a/src/ui/pages/component/Tabs/ReadonlyConfigurations.jsx +++ b/src/ui/pages/component/Tabs/ReadonlyConfigurations.jsx @@ -1,4 +1,4 @@ -import { Card, Grid, ThemeProvider, Typography } from "@mui/material"; +import { Card, Grid, ThemeProvider, Typography, Button, Dialog, DialogActions, DialogContent, DialogTitle, TextField } from "@mui/material"; import React, { useEffect, useState } from "react"; import themeDefault from "../../../theme/theme"; import DatasetStyle from "../../../styles/Dataset"; @@ -6,12 +6,17 @@ import { useDispatch, useSelector } from "react-redux"; import { Link } from "react-router-dom"; import CustomButton from "../../component/common/Button"; import GetWorkspacesDetailsAPI from "../../../../redux/actions/api/WorkspaceDetails/GetWorkspaceDetails"; +import GetProjectDetailsAPI from "../../../../redux/actions/api/ProjectDetails/GetProjectDetails"; import APITransport from "../../../../redux/actions/apitransport/apitransport"; const ReadonlyConfigurations = (props) => { const classes = DatasetStyle(); const dispatch = useDispatch(); const ProjectDetails = useSelector((state) => state.getProjectDetails.data); + const workspaceDetails = useSelector((state) => state.getWorkspaceDetails.data); + const [metadataDialogOpen, setMetadataDialogOpen] = useState(false); + const [editedMetadata, setEditedMetadata] = useState(""); + const getWorkspaceDetails = () => { const workspaceObj = new GetWorkspacesDetailsAPI(ProjectDetails.workspace_id); dispatch(APITransport(workspaceObj)); @@ -21,7 +26,37 @@ useEffect(() => { getWorkspaceDetails(); }, []); -const workspaceDetails = useSelector(state => state.getWorkspaceDetails.data); + const handleOpenMetadataDialog = () => { + setEditedMetadata(JSON.stringify(ProjectDetails.metadata_json, null, 2)); + setMetadataDialogOpen(true); + }; + + const handleCloseMetadataDialog = () => { + setMetadataDialogOpen(false); + }; + + const handleMetadataChange = (e) => { + setEditedMetadata(e.target.value); + }; + + const handleSaveMetadata = () => { + try { + const parsedMetadata = JSON.parse(editedMetadata); + const patchProjectObj = new GetProjectDetailsAPI( + ProjectDetails.id, + "PATCH", + { metadata_json: parsedMetadata } + ); + + dispatch(APITransport(patchProjectObj)); + setMetadataDialogOpen(false); + alert("Metadata update initiated. Please wait for confirmation."); + dispatch(APITransport(new GetProjectDetailsAPI(ProjectDetails.id))); + } catch (error) { + console.error("Invalid JSON format or network error", error); + alert("Invalid JSON format or network error. Please correct it."); + } + }; return ( @@ -210,8 +245,69 @@ const workspaceDetails = useSelector(state => state.getWorkspaceDetails.data); )} )} + + {/* Metadata Parameters Section */} +
+ + + Metadata Parameters: + + + {ProjectDetails.metadata_json ? JSON.stringify(ProjectDetails.metadata_json, null, 2) : "No Metadata Available"} + + + + +
+ {/* Metadata Editing Dialog */} + + Edit Metadata + + + + + + + + + {ProjectDetails && ProjectDetails?.variable_parameters?.output_language && (