Skip to content

Commit

Permalink
Fixed an issue with Novel Editor (#1497)
Browse files Browse the repository at this point in the history
  • Loading branch information
lpeyr authored Feb 10, 2025
1 parent ca7dea9 commit 1575f02
Show file tree
Hide file tree
Showing 6 changed files with 262 additions and 225 deletions.
1 change: 1 addition & 0 deletions app/[lng]/create/create.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -657,6 +657,7 @@ export default function Create(props: Props) {
<ResultDisplayer
font={s.gen_font ?? "default"}
is_generating={isGen}
lng={lng}
res={res}
type={type}
/>
Expand Down
32 changes: 23 additions & 9 deletions app/[lng]/generations/view/viewpage.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -46,11 +46,12 @@ export default function GenerationViewPage({
s = JSON.parse(localStorage.getItem("synapsy_settings") ?? "{}");

const [nbTokens, setNbTokens] = useState(0);
const [nbWords, setNbWords] = useState(el.content.split(" ").length);
const [nbChars, setNbChars] = useState(el.content.length);
const [nbWords] = useState(el.content.split(" ").length);
const [nbChars] = useState(el.content.length);
const [variables, setVariables] = useState<Variable[]>([]);
const [price, setPrice] = useState("$0");
const [content, setContent] = useState(el.content);
const [toggle, setToggle] = useState(false);
useEffect(() => {
try {
if (typeof window !== "undefined") {
Expand Down Expand Up @@ -88,8 +89,8 @@ export default function GenerationViewPage({
c = c.replaceAll(`[${variables[i].name}]`, variables[i].value);
console.log(`[${variables[i].name}]`);
}
console.log(c);
setContent(c);
setToggle(!toggle);
}
return (
<main className="flex min-h-[calc(100vh_-_theme(spacing.16))] flex-1 flex-col gap-4 bg-slate-100/40 p-4 pb-16 dark:bg-transparent sm:pb-0 md:gap-8 md:p-10 print:mt-0 print:bg-white">
Expand Down Expand Up @@ -138,12 +139,25 @@ export default function GenerationViewPage({
className="edit max-w-[800px] rounded-md border bg-white p-0 text-justify shadow-sm dark:bg-slate-900 dark:bg-slate-900/50 print:border-0 print:text-black print:shadow-none"
id="ct"
>
<ResultDisplayer
is_generating={false}
res={content}
type={el.template}
font={s.gen_font ?? "default"}
/>
{toggle ? (
<ResultDisplayer
is_generating={false}
res={content}
type={el.template}
lng={lng}
font={s.gen_font ?? "default"}
/>
) : (
<div>
<ResultDisplayer
is_generating={false}
res={content}
type={el.template}
lng={lng}
font={s.gen_font ?? "default"}
/>
</div>
)}
</div>

<div className="grid gap-6 print:hidden">
Expand Down
1 change: 1 addition & 0 deletions components/chat-box.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@ export default function ChatBox(props: ChatBoxProps) {
{m.role === "assistant" && <Sparkles size={14} color="#6366f1" />}
</p>
<ResultDisplayer
lng={lng}
type="para"
is_generating={i === msg.length - 1 && loading}
res={m.content}
Expand Down
28 changes: 16 additions & 12 deletions components/result-displayer.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,36 +6,41 @@ import { FontType } from "@/lib/settings";
import { defaultExtensions } from "@/lib/editor-extensions";
import { generateJSON } from "@tiptap/html";
import TailwindEditor from "./tailwind-editor";
import { Language } from "@/lib/languages";
import { useState } from "react";

export default function ResultDisplayer(props: {
res: string;
type: Template | string;
is_generating: boolean;
no_padding?: boolean;
font?: FontType;
lng: Language;
}) {
const [content] = useState(props.res);
const options: HTMLReactParserOptions = {
replace: (domNode) => {
if (domNode instanceof Element && domNode.tagName === "body") {
return null;
}
},
};

if (
(props.is_generating && props.type === "ideas") ||
(props.is_generating && props.type === "ph_visual_outline")
) {
return (
<p id="contentp" className={props.no_padding ? "" : "p-4"}>
{props.res}
{content}
<span className="inline-block h-[14px] w-[7px] animate-pulse self-baseline bg-black duration-500 dark:bg-white"></span>
</p>
);
}
switch (props.type) {
case "ideas":
try {
let json: string[] = JSON.parse(props.res);
let json: string[] = JSON.parse(content);
return (
<div id="contentp">
{json.map((el, i) => (
Expand All @@ -52,7 +57,7 @@ export default function ResultDisplayer(props: {
return (
<div id="contentp">
{parse(
props.res.replaceAll("<body>", "").replaceAll("</body>", ""),
content.replaceAll("<body>", "").replaceAll("</body>", ""),
options,
)}
</div>
Expand All @@ -65,7 +70,7 @@ export default function ResultDisplayer(props: {
id="contentp"
>
{parse(
props.res
content
.replaceAll("<body>", "")
.replaceAll("</body>", "")
.replaceAll("<html>", "")
Expand All @@ -80,7 +85,7 @@ export default function ResultDisplayer(props: {
);
case "ph_visual_outline":
try {
const outline: OutlineItem[] = JSON.parse(props.res);
const outline: OutlineItem[] = JSON.parse(content);
return (
<div>
{outline.map((el, i) => (
Expand All @@ -105,7 +110,7 @@ export default function ResultDisplayer(props: {
return (
<p className="p-4 print:text-black" id="contentp">
{parse(
props.res
content
.replaceAll("<body>", "")
.replaceAll("</body>", "")
.replaceAll("<html>", "")
Expand All @@ -130,7 +135,7 @@ export default function ResultDisplayer(props: {
id="contentp"
>
{parse(
props.res
content
.replaceAll("<body>", "")
.replaceAll("</body>", "")
.replaceAll("<html>", "")
Expand All @@ -148,10 +153,10 @@ export default function ResultDisplayer(props: {
</p>
) : (
<TailwindEditor
lng={"en"}
lng={props.lng}
id={-1}
content={generateJSON(
props.res
content
.replaceAll("<body>", "")
.replaceAll("</body>", "")
.replaceAll("<html>", "")
Expand All @@ -164,11 +169,10 @@ export default function ResultDisplayer(props: {
.replaceAll("```html", "")
.replaceAll("```", "")
.replaceAll("<br><br>", ""),
[...defaultExtensions],
{},
defaultExtensions,
)}
enabled={false}
editorOnly={true}
editorOnly
/>
)}
</>
Expand Down
2 changes: 1 addition & 1 deletion components/tailwind-editor.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,6 @@ export default function TailwindEditor(props: EditorProps) {
const [openColor, setOpenColor] = useState<boolean>(false);
const [htmlContent, setHtmlContent] = useState("");
const { t } = useTranslation(props.lng, "common");

function saveContent() {
if (typeof window !== "undefined") {
let history: HistoryItem[] = [];
Expand All @@ -71,6 +70,7 @@ export default function TailwindEditor(props: EditorProps) {
localStorage.setItem("synapsy_write_history", JSON.stringify(history));
}
}

return (
<div className="space-y-2">
{props.editorOnly ? (
Expand Down
Loading

0 comments on commit 1575f02

Please sign in to comment.