mirror of https://github.com/usememos/memos
feat: update timeline page
parent
33133ea1a3
commit
1d99dad435
@ -1,105 +0,0 @@
|
|||||||
import { Button, IconButton, Input } from "@mui/joy";
|
|
||||||
import { useEffect, useState } from "react";
|
|
||||||
import { toast } from "react-hot-toast";
|
|
||||||
import { getNormalizedTimeString } from "@/helpers/datetime";
|
|
||||||
import { MemoNamePrefix, useMemoStore } from "@/store/v1";
|
|
||||||
import { useTranslate } from "@/utils/i18n";
|
|
||||||
import { generateDialog } from "./Dialog";
|
|
||||||
import Icon from "./Icon";
|
|
||||||
|
|
||||||
interface Props extends DialogProps {
|
|
||||||
memoId: number;
|
|
||||||
}
|
|
||||||
|
|
||||||
const ChangeMemoCreatedTsDialog: React.FC<Props> = (props: Props) => {
|
|
||||||
const t = useTranslate();
|
|
||||||
const { destroy, memoId } = props;
|
|
||||||
const memoStore = useMemoStore();
|
|
||||||
const [createdAt, setCreatedAt] = useState("");
|
|
||||||
const maxDatetimeValue = getNormalizedTimeString();
|
|
||||||
|
|
||||||
useEffect(() => {
|
|
||||||
memoStore.getOrFetchMemoByName(`${MemoNamePrefix}${memoId}`).then((memo) => {
|
|
||||||
if (memo) {
|
|
||||||
const datetime = getNormalizedTimeString(memo.createTime);
|
|
||||||
setCreatedAt(datetime);
|
|
||||||
} else {
|
|
||||||
toast.error(t("message.memo-not-found"));
|
|
||||||
destroy();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}, []);
|
|
||||||
|
|
||||||
const handleCloseBtnClick = () => {
|
|
||||||
destroy();
|
|
||||||
};
|
|
||||||
|
|
||||||
const handleDatetimeInputChange = (e: React.ChangeEvent<HTMLInputElement>) => {
|
|
||||||
const datetime = e.target.value as string;
|
|
||||||
setCreatedAt(datetime);
|
|
||||||
};
|
|
||||||
|
|
||||||
const handleSaveBtnClick = async () => {
|
|
||||||
try {
|
|
||||||
await memoStore.updateMemo(
|
|
||||||
{
|
|
||||||
name: `${MemoNamePrefix}${memoId}`,
|
|
||||||
createTime: new Date(createdAt),
|
|
||||||
},
|
|
||||||
["created_ts"],
|
|
||||||
);
|
|
||||||
toast.success("Updated memo created time successfully.");
|
|
||||||
handleCloseBtnClick();
|
|
||||||
} catch (error: any) {
|
|
||||||
console.error(error);
|
|
||||||
toast.error(error.response.data.message);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
return (
|
|
||||||
<>
|
|
||||||
<div className="dialog-header-container">
|
|
||||||
<p className="title-text">{t("message.change-memo-created-time")}</p>
|
|
||||||
<IconButton size="sm" onClick={handleCloseBtnClick}>
|
|
||||||
<Icon.X className="w-5 h-auto" />
|
|
||||||
</IconButton>
|
|
||||||
</div>
|
|
||||||
<div className="flex flex-col justify-start items-start !w-72 max-w-full">
|
|
||||||
<Input
|
|
||||||
className="w-full"
|
|
||||||
type="datetime-local"
|
|
||||||
value={createdAt}
|
|
||||||
slotProps={{
|
|
||||||
input: {
|
|
||||||
max: maxDatetimeValue,
|
|
||||||
},
|
|
||||||
}}
|
|
||||||
onChange={handleDatetimeInputChange}
|
|
||||||
/>
|
|
||||||
<div className="flex flex-row justify-end items-center mt-4 w-full gap-x-2">
|
|
||||||
<Button color="neutral" variant="plain" onClick={handleCloseBtnClick}>
|
|
||||||
{t("common.cancel")}
|
|
||||||
</Button>
|
|
||||||
<Button color="primary" onClick={handleSaveBtnClick}>
|
|
||||||
{t("common.save")}
|
|
||||||
</Button>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</>
|
|
||||||
);
|
|
||||||
};
|
|
||||||
|
|
||||||
function showChangeMemoCreatedTsDialog(memoId: number) {
|
|
||||||
generateDialog(
|
|
||||||
{
|
|
||||||
className: "change-memo-created-ts-dialog",
|
|
||||||
dialogName: "change-memo-created-ts-dialog",
|
|
||||||
},
|
|
||||||
ChangeMemoCreatedTsDialog,
|
|
||||||
{
|
|
||||||
memoId,
|
|
||||||
},
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
export default showChangeMemoCreatedTsDialog;
|
|
Loading…
Reference in New Issue