diff --git a/adminSiteClient/ChartEditor.ts b/adminSiteClient/ChartEditor.ts index c059e75ebc..c84d3c5e3f 100644 --- a/adminSiteClient/ChartEditor.ts +++ b/adminSiteClient/ChartEditor.ts @@ -26,8 +26,6 @@ import { References, } from "./AbstractChartEditor.js" import { Admin } from "./Admin.js" -import { Form, Input, Modal } from "antd" -import React, { useState } from "react" export interface Log { userId: number @@ -202,11 +200,6 @@ export class ChartEditor extends AbstractChartEditor { ) } - openNarrativeChartNameModal(): void { - const { grapher } = this - const suggestedName = grapher.title ? slugify(grapher.title) : undefined - } - async saveAsChartView( name: string ): Promise<{ success: boolean; errorMsg?: string }> { diff --git a/adminSiteClient/NarrativeChartNameModal.tsx b/adminSiteClient/NarrativeChartNameModal.tsx new file mode 100644 index 0000000000..81d61c02bd --- /dev/null +++ b/adminSiteClient/NarrativeChartNameModal.tsx @@ -0,0 +1,64 @@ +import { useEffect, useMemo, useRef, useState } from "react" +import { Form, Input, InputRef, Modal, Spin } from "antd" + +export const NarrativeChartNameModal = (props: { + initialName: string + open: "open" | "open-loading" | "closed" + errorMsg?: string + onSubmit: (name: string) => void + onCancel?: () => void +}) => { + const [name, setName] = useState(props.initialName) + const inputField = useRef(null) + const isLoading = useMemo(() => props.open === "open-loading", [props.open]) + const isOpen = useMemo(() => props.open !== "closed", [props.open]) + + useEffect(() => setName(props.initialName), [props.initialName]) + + useEffect(() => { + if (isOpen) { + inputField.current?.focus({ cursor: "all" }) + } + }, [isOpen]) + + return ( + props.onSubmit(name)} + onCancel={props.onCancel} + onClose={props.onCancel} + okButtonProps={{ disabled: !name || isLoading }} + cancelButtonProps={{ disabled: isLoading }} + > +
+

+ This will create a new narrative chart that is linked to + this chart. Any currently pending changes will be applied to + the narrative chart. +

+

+ Please enter a programmatic name for the narrative chart.{" "} + Note that this name cannot be changed later. +

+ + setName(e.target.value)} + value={name} + disabled={isLoading} + /> + + {isLoading && } + {props.errorMsg && ( +
+ {props.errorMsg} +
+ )} +
+
+ ) +} diff --git a/adminSiteClient/SaveButtons.tsx b/adminSiteClient/SaveButtons.tsx index bdae5d157f..0bdbafca27 100644 --- a/adminSiteClient/SaveButtons.tsx +++ b/adminSiteClient/SaveButtons.tsx @@ -1,4 +1,4 @@ -import { Component, useEffect, useMemo, useRef, useState } from "react" +import { Component } from "react" import { ChartEditor, isChartEditorInstance } from "./ChartEditor.js" import { action, computed, observable } from "mobx" import { observer } from "mobx-react" @@ -17,7 +17,7 @@ import { chartViewsFeatureEnabled, isChartViewEditorInstance, } from "./ChartViewEditor.js" -import { Form, Input, InputRef, Modal, Spin } from "antd" +import { NarrativeChartNameModal } from "./NarrativeChartNameModal.js" @observer export class SaveButtons extends Component<{ @@ -273,65 +273,3 @@ class SaveButtonsForChartView extends Component<{ ) } } - -const NarrativeChartNameModal = (props: { - initialName: string - open: "open" | "open-loading" | "closed" - errorMsg?: string - onSubmit: (name: string) => void - onCancel?: () => void -}) => { - const [name, setName] = useState(props.initialName) - const inputField = useRef(null) - const isLoading = useMemo(() => props.open === "open-loading", [props.open]) - const isOpen = useMemo(() => props.open !== "closed", [props.open]) - - useEffect(() => setName(props.initialName), [props.initialName]) - - useEffect(() => { - if (isOpen) { - inputField.current?.focus({ cursor: "all" }) - } - }, [isOpen]) - - return ( - props.onSubmit(name)} - onCancel={props.onCancel} - onClose={props.onCancel} - okButtonProps={{ disabled: !name || isLoading }} - cancelButtonProps={{ disabled: isLoading }} - > -
-

- This will create a new narrative chart that is linked to - this chart. Any currently pending changes will be applied to - the narrative chart. -

-

- Please enter a programmatic name for the narrative chart.{" "} - Note that this name cannot be changed later. -

- - setName(e.target.value)} - value={name} - disabled={isLoading} - /> - - {isLoading && } - {props.errorMsg && ( -
- {props.errorMsg} -
- )} -
-
- ) -}