From 7a6ac8f53f32ba3a9ede18c9553602063e8a46a9 Mon Sep 17 00:00:00 2001 From: Bartosz Prusinowski Date: Tue, 10 Oct 2023 16:31:44 +0200 Subject: [PATCH] feat: Add indication that user is editing published chart --- app/components/chart-selection-tabs.tsx | 56 ++++++++++++++++++++++--- app/configurator/configurator-state.tsx | 3 +- app/locales/de/messages.po | 8 ++++ app/locales/en/messages.po | 8 ++++ app/locales/fr/messages.po | 8 ++++ app/locales/it/messages.po | 8 ++++ app/utils/router/helpers.ts | 4 ++ 7 files changed, 89 insertions(+), 6 deletions(-) diff --git a/app/components/chart-selection-tabs.tsx b/app/components/chart-selection-tabs.tsx index 984bea70e..979574cca 100644 --- a/app/components/chart-selection-tabs.tsx +++ b/app/components/chart-selection-tabs.tsx @@ -1,6 +1,8 @@ -import { Trans } from "@lingui/macro"; -import { Box, Button, Popover, Tab, Tabs, Theme } from "@mui/material"; +import { Trans, t } from "@lingui/macro"; +import { Box, Button, Popover, Tab, Tabs, Theme, Tooltip } from "@mui/material"; import { makeStyles } from "@mui/styles"; +import { useSession } from "next-auth/react"; +import { useRouter } from "next/router"; import React from "react"; import { DragDropContext, Draggable, Droppable } from "react-beautiful-dnd"; @@ -23,7 +25,9 @@ import { } from "@/graphql/query-hooks"; import { Icon, IconName } from "@/icons"; import { useLocale } from "@/src"; +import { fetchChartConfig } from "@/utils/chart-config/api"; import { createChartId } from "@/utils/create-chart-id"; +import { getRouterChartId } from "@/utils/router/helpers"; import useEvent from "@/utils/use-event"; type TabsState = { @@ -277,16 +281,58 @@ const PublishChartButton = () => { } }); - return ( + const [editingPublishedChart, setEditingPublishedChart] = + React.useState(false); + const [loaded, setLoaded] = React.useState(false); + const { asPath } = useRouter(); + const session = useSession(); + const chartId = getRouterChartId(asPath); + + React.useEffect(() => { + const run = async () => { + if (session.data?.user && chartId) { + const config = await fetchChartConfig(chartId); + + if (config?.user_id === session.data.user.id) { + setEditingPublishedChart(true); + } + } + + if (session.status !== "loading") { + setLoaded(true); + } + }; + + run(); + }, [chartId, session]); + + return loaded ? ( - ); + ) : null; }; type TabsInnerProps = { diff --git a/app/configurator/configurator-state.tsx b/app/configurator/configurator-state.tsx index 4a158c2c7..faf65b724 100644 --- a/app/configurator/configurator-state.tsx +++ b/app/configurator/configurator-state.tsx @@ -96,6 +96,7 @@ import { migrateConfiguratorState, } from "@/utils/chart-config/versioning"; import { createChartId } from "@/utils/create-chart-id"; +import { getRouterChartId } from "@/utils/router/helpers"; import { unreachableError } from "@/utils/unreachable"; export type ConfiguratorStateAction = @@ -1527,7 +1528,7 @@ const ConfiguratorStateProviderInternal = ({ (async () => { try { let dbConfig: ParsedConfig | undefined; - const key = asPath.split("?")[0].split("/").pop(); + const key = getRouterChartId(asPath); if (key && user) { const config = await fetchChartConfig(key); diff --git a/app/locales/de/messages.po b/app/locales/de/messages.po index 7190c47a6..1512f3325 100644 --- a/app/locales/de/messages.po +++ b/app/locales/de/messages.po @@ -115,6 +115,14 @@ msgstr "Diese Visualisierung veröffentlichen" msgid "button.share" msgstr "Teilen" +#: app/components/chart-selection-tabs.tsx +msgid "button.update" +msgstr "Diese Visualisierung aktualisieren" + +#: app/components/chart-selection-tabs.tsx +msgid "button.update.warning" +msgstr "Denken Sie daran, dass sich die Aktualisierung dieser Visualisierung auf alle Stellen auswirkt, an denen sie bereits eingebettet ist!" + #: app/configurator/components/field-i18n.ts msgid "chart.map.layers.area" msgstr "Flächen" diff --git a/app/locales/en/messages.po b/app/locales/en/messages.po index 324bb6281..d1eb04374 100644 --- a/app/locales/en/messages.po +++ b/app/locales/en/messages.po @@ -115,6 +115,14 @@ msgstr "Publish this visualization" msgid "button.share" msgstr "Share" +#: app/components/chart-selection-tabs.tsx +msgid "button.update" +msgstr "Update this visualization" + +#: app/components/chart-selection-tabs.tsx +msgid "button.update.warning" +msgstr "Keep in mind that updating this visualization will affect all the places where it might be already embedded!" + #: app/configurator/components/field-i18n.ts msgid "chart.map.layers.area" msgstr "Areas" diff --git a/app/locales/fr/messages.po b/app/locales/fr/messages.po index 1d758fdb7..c358b0150 100644 --- a/app/locales/fr/messages.po +++ b/app/locales/fr/messages.po @@ -115,6 +115,14 @@ msgstr "Publier cette visualisation" msgid "button.share" msgstr "Partager" +#: app/components/chart-selection-tabs.tsx +msgid "button.update" +msgstr "Actualiser cette visualisation" + +#: app/components/chart-selection-tabs.tsx +msgid "button.update.warning" +msgstr "Gardez à l'esprit que la mise à jour de cette visualisation affectera tous les endroits où elle est déjà intégrée !" + #: app/configurator/components/field-i18n.ts msgid "chart.map.layers.area" msgstr "Zones" diff --git a/app/locales/it/messages.po b/app/locales/it/messages.po index 236e77480..9cc5a8572 100644 --- a/app/locales/it/messages.po +++ b/app/locales/it/messages.po @@ -115,6 +115,14 @@ msgstr "Pubblica questa visualizzazione" msgid "button.share" msgstr "Condividi" +#: app/components/chart-selection-tabs.tsx +msgid "button.update" +msgstr "Aggiornare questa visualizzazione" + +#: app/components/chart-selection-tabs.tsx +msgid "button.update.warning" +msgstr "Tenete presente che l'aggiornamento di questa visualizzazione avrà effetto su tutti i luoghi in cui potrebbe essere già incorporata!" + #: app/configurator/components/field-i18n.ts msgid "chart.map.layers.area" msgstr "Aree" diff --git a/app/utils/router/helpers.ts b/app/utils/router/helpers.ts index 86017648e..b5f6b731c 100644 --- a/app/utils/router/helpers.ts +++ b/app/utils/router/helpers.ts @@ -31,3 +31,7 @@ export const setURLParam = (param: string, value: string) => { newUrl ); }; + +export const getRouterChartId = (asPath: string) => { + return asPath.split("?")[0].split("/").pop(); +};