diff --git a/src/components/Experiment/Slices.jsx b/src/components/Experiment/Slices.jsx index 3f027e54..3e95099e 100644 --- a/src/components/Experiment/Slices.jsx +++ b/src/components/Experiment/Slices.jsx @@ -5,11 +5,13 @@ import Pagination from "../common/Pagination"; import SearchBoxWithDropdown from "../../components/common/SearchBoxWithDropdown"; import SlicesTable from "../Slice/SlicesTable"; import SpinnerWithText from "../../components/common/SpinnerWithText"; +import DeleteModal from "../../components/common/DeleteModal"; import { getProjects } from "../../services/projectService.js"; import { autoCreateTokens } from "../../utils/manageTokens"; import { getSlices, deleteSlice } from "../../services/sliceService.js"; import { toast } from "react-toastify"; import paginate from "../../utils/paginate"; +import sleep from "../../utils/sleep"; import checkPortalType from "../../utils/checkPortalType"; import { default as portalData } from "../../services/portalData.json"; import _ from "lodash"; @@ -31,29 +33,30 @@ class Slices extends React.Component { searchQuery: "", sortColumn: { path: "name", order: "asc" }, showSpinner: false, + spinnerText: "" }; async componentDidMount() { // Show loading spinner and when waiting API response - this.setState({ showSpinner: true }); + this.setState({ showSpinner: true, spinnerText: "Loading slices..." }); try { if (window.location.href.includes("/projects")) { // call credential manager to generate tokens autoCreateTokens("all").then(async () => { const { data: res } = await getSlices(); const slices = res.data.filter(s => s.project_id === this.props.projectId); - this.setState({ slices, showSpinner: false }); + this.setState({ slices, showSpinner: false, spinnerText: "" }); }); } else { // call PR first to check if the user has project. const { data: res } = await getProjects("myProjects", 0, 200); if (res.results.length === 0) { - this.setState({ hasProject: false, showSpinner: false }); + this.setState({ hasProject: false, showSpinner: false, spinnerText: "" }); } else { // call credential manager to generate tokens autoCreateTokens("all").then(async () => { const { data: res } = await getSlices(); - this.setState({ slices: res.data, showSpinner: false }); + this.setState({ slices: res.data, showSpinner: false, spinnerText: "" }); }); } } @@ -85,7 +88,12 @@ class Slices extends React.Component { handleDeleteAllSlices = async () => { try { + this.setState({ + showSpinner: true, + spinnerText: "Deleting all active slices..." + }) await deleteSlice(); + await sleep(5000); window.location.reload(); } catch (err) { @@ -131,7 +139,8 @@ class Slices extends React.Component { }; render() { - const { hasProject, slices, pageSize, currentPage, sortColumn, searchQuery, filterQuery, showSpinner } = this.state; + const { hasProject, slices, pageSize, currentPage, sortColumn, searchQuery, + filterQuery, showSpinner, spinnerText, includeDeadSlices } = this.state; const { totalCount, data } = this.getPageData(); return ( @@ -159,7 +168,7 @@ class Slices extends React.Component { } { - showSpinner && + showSpinner && } { !showSpinner && !hasProject && @@ -261,18 +270,20 @@ class Slices extends React.Component {
Showing {totalCount} slices. - + { + this.props.parent === "Projects" && totalCount > 0 && !includeDeadSlices && + this.handleDeleteAllSlices} + /> + }
diff --git a/src/pages/SliceViewer.jsx b/src/pages/SliceViewer.jsx index 3d4484da..1ba998cb 100644 --- a/src/pages/SliceViewer.jsx +++ b/src/pages/SliceViewer.jsx @@ -34,11 +34,12 @@ class SliceViewer extends Component { positionAddNode: { x: 100, y: 600 }, leaseEndTime: "", hasProject: true, - showSliceSpinner: false, + showSpinner: false, + spinnerText: "" } async componentDidMount() { - this.setState({ showSliceSpinner: true }); + this.setState({ showSpinner: true, spinnerText: "Loading slice..." }); try { // call credential manager to generate tokens autoCreateTokens(this.props.match.params.project_id).then(async () => { @@ -48,7 +49,8 @@ class SliceViewer extends Component { slice: res.data[0], leaseEndTime: res.data[0].lease_end_time, errors: sliceErrorParser(res.data[0]["model"]), - showSliceSpinner: false + showSpinner: false, + spinnerText: "" }); }); } catch (err) { @@ -95,7 +97,11 @@ class SliceViewer extends Component { this.setState({ leaseEndTime: outputTime }); } - handlExtendSlice = async () => { + handleSliceExtend = async () => { + this.setState({ + showSpinner: true, + spinnerText: "Extending slice..." + }) try { const { slice, leaseEndTime } = this.state; await extendSlice(slice.slice_id, leaseEndTime); @@ -109,14 +115,6 @@ class SliceViewer extends Component { }); } } - - calendarTimeParser = (apiTime) => { - console.log("---API time----"); - console.log(apiTime); - console.log("---parsed calendar time----"); - console.log(utcToLocalTimeParser(apiTime)); - return utcToLocalTimeParser(apiTime); - } render() { const stateColors = { @@ -132,16 +130,16 @@ class SliceViewer extends Component { } const { slice, elements, selectedData, hasProject, - showSliceSpinner, errors, leaseEndTime } = this.state; + showSpinner, spinnerText, errors, leaseEndTime } = this.state; - let showSlice = !showSliceSpinner && hasProject; + let showSlice = !showSpinner && hasProject; return(
{ - showSliceSpinner && + showSpinner &&
- +
} { @@ -163,24 +161,32 @@ class SliceViewer extends Component { -

- Lease End: - +
+

+ Lease End: + { + slice.state !=="StableOK" && utcToLocalTimeParser(leaseEndTime) + } + +

{ - leaseEndTime !== "" && } - -

+ { + slice.state ==="StableOK" && + + } +
{ slice.project_name &&

diff --git a/src/utils/utcToLocalTimeParser.js b/src/utils/utcToLocalTimeParser.js index bd9e143a..be578e6b 100644 --- a/src/utils/utcToLocalTimeParser.js +++ b/src/utils/utcToLocalTimeParser.js @@ -7,8 +7,5 @@ export default function utcToLocalTimeParser(UTCtime) { const stillUtc = moment.utc(utcDateTime).toDate(); const localTime = moment(stillUtc).local().format('YYYY-MM-DD HH:mm:ss'); - console.log("utc to local time: ----") - console.log(localTime) - return localTime; }