patching cors issue with modifcations

This commit is contained in:
caranicas 2022-09-16 11:32:36 -04:00
parent 972473f1af
commit b21ec7a302
27 changed files with 311 additions and 1418 deletions

View File

@ -1,7 +1,7 @@
import { ReactLocation, Router } from "@tanstack/react-location"; import { ReactLocation, Router } from "@tanstack/react-location";
import Home from "./components/layouts/Home"; import Home from "./pages/Home";
import Settings from "./components/layouts/Settings"; import Settings from "./pages/Settings";
const location = new ReactLocation(); const location = new ReactLocation();

View File

@ -2,7 +2,7 @@
* basic server health * basic server health
*/ */
import type { ImageRequest } from "../store/imageCreateStore"; import type { ImageRequest } from "../stores/imageCreateStore";
// when we are on dev we want to specifiy 9000 as the port for the backend // when we are on dev we want to specifiy 9000 as the port for the backend
// when we are on prod we want be realtive to the current url // when we are on prod we want be realtive to the current url

View File

@ -1,5 +1,5 @@
import React from "react"; import React from "react";
import { useImageCreate } from "../../../store/imageCreateStore"; import { useImageCreate } from "../../../stores/imageCreateStore";
type ModifierTagProps = { type ModifierTagProps = {
name: string; name: string;

View File

@ -1,49 +0,0 @@
import React, { useEffect, useState } from "react";
import {
AppLayout,
HeaderLayout,
CreateLayout,
DisplayLayout,
FooterLayout, // @ts-ignore
} from "./home.css.ts";
import { useQuery } from "@tanstack/react-query";
import { getSaveDirectory } from "../../../api";
import { useImageCreate } from "../../../store/imageCreateStore";
// Todo - import components here
import HeaderDisplay from "../../organisms/headerDisplay";
import CreationPanel from "../../organisms/creationPanel";
import DisplayPanel from "../../organisms/displayPanel";
import FooterDisplay from "../../organisms/footerDisplay";
function Editor() {
// Get the original save directory
const setRequestOption = useImageCreate((state) => state.setRequestOptions);
const { status, data } = useQuery(["SaveDir"], getSaveDirectory);
useEffect(() => {
if (status === "success") {
setRequestOption("save_to_disk_path", data);
}
}, [setRequestOption, status, data]);
return (
<div className={AppLayout}>
<header className={HeaderLayout}>
<HeaderDisplay></HeaderDisplay>
</header>
<nav className={CreateLayout}>
<CreationPanel></CreationPanel>
</nav>
<main className={DisplayLayout}>
<DisplayPanel></DisplayPanel>
</main>
<footer className={FooterLayout}>
<FooterDisplay></FooterDisplay>
</footer>
</div>
);
}
export default Editor;

View File

@ -3,7 +3,7 @@ import React, { useCallback } from "react";
import { import {
ImageRequest, ImageRequest,
useImageCreate, useImageCreate,
} from "../../../store/imageCreateStore"; } from "../../../stores/imageCreateStore";
import { import {
generatedImage, generatedImage,

View File

@ -1,5 +1,9 @@
import React, { useState } from "react"; import React from "react";
import { useImageCreate } from "../../../../../store/imageCreateStore"; import { useImageCreate } from "../../../../../stores/imageCreateStore";
import { useCreateUI } from "../../creationPanelUIStore";
import { import {
MenuButton, //@ts-ignore MenuButton, //@ts-ignore
@ -16,11 +20,8 @@ export default function GpuSettings() {
const setRequestOption = useImageCreate((state) => state.setRequestOptions); const setRequestOption = useImageCreate((state) => state.setRequestOptions);
const [gpuOpen, setGpuOpen] = useState(false); const gpuOpen = useCreateUI((state) => state.isOpenAdvGPUSettings);
const toggleGpuOpen = useCreateUI((state) => state.toggleAdvGPUSettings);
const toggleGpuOpen = () => {
setGpuOpen(!gpuOpen);
};
return ( return (
<div> <div>

View File

@ -1,5 +1,8 @@
import React, { useState } from "react"; import React from "react";
import { useImageCreate } from "../../../../../store/imageCreateStore"; import { useImageCreate } from "../../../../../stores/imageCreateStore";
import { useCreateUI } from "../../creationPanelUIStore";
import { import {
MenuButton, //@ts-ignore MenuButton, //@ts-ignore
@ -30,11 +33,8 @@ export default function ImprovementSettings() {
const setRequestOption = useImageCreate((state) => state.setRequestOptions); const setRequestOption = useImageCreate((state) => state.setRequestOptions);
const [improvementOpen, setImprovementOpen] = useState(true); const improvementOpen = useCreateUI((state) => state.isOpenAdvImprovementSettings);
const toggleImprovementOpen = useCreateUI((state) => state.toggleAdvImprovementSettings);
const toggleImprovementOpen = () => {
setImprovementOpen(!improvementOpen);
};
return ( return (
<div> <div>

View File

@ -1,5 +1,6 @@
import React, { useEffect } from "react"; import React, { useEffect } from "react";
import { useImageCreate } from "../../../../store/imageCreateStore"; import { useCreateUI } from "../creationPanelUIStore";
import { import {
AdvancedSettingsList, AdvancedSettingsList,
AdvancedSettingItem, // @ts-ignore AdvancedSettingItem, // @ts-ignore
@ -30,12 +31,13 @@ function SettingsList() {
} }
export default function AdvancedSettings() { export default function AdvancedSettings() {
const advancedSettingsIsOpen = useImageCreate(
(state) => state.uiOptions.advancedSettingsIsOpen const advancedSettingsIsOpen = useCreateUI(
(state) => state.isOpenAdvancedSettings
); );
const toggleAdvancedSettingsIsOpen = useImageCreate( const toggleAdvancedSettingsIsOpen = useCreateUI(
(state) => state.toggleAdvancedSettingsIsOpen (state) => state.toggleAdvancedSettings
); );
return ( return (

View File

@ -1,5 +1,6 @@
import React, { useState } from "react"; import React, { useState } from "react";
import { useImageCreate } from "../../../../../store/imageCreateStore"; import { useImageCreate } from "../../../../../stores/imageCreateStore";
import { useCreateUI } from "../../creationPanelUIStore";
import { import {
MenuButton, //@ts-ignore MenuButton, //@ts-ignore
@ -45,11 +46,8 @@ export default function PropertySettings() {
state.getValueForRequestKey("height") state.getValueForRequestKey("height")
); );
const [propertyOpen, setPropertyOpen] = useState(true); const propertyOpen = useCreateUI((state) => state.isOpenAdvPropertySettings);
const togglePropertyOpen = useCreateUI((state) => state.toggleAdvPropertySettings);
const togglePropertyOpen = () => {
setPropertyOpen(!propertyOpen);
};
return ( return (
<div> <div>

View File

@ -1,5 +1,7 @@
import React, { useState } from "react"; import React from "react";
import { useImageCreate } from "../../../../../store/imageCreateStore"; import { useImageCreate } from "../../../../../stores/imageCreateStore";
import { useCreateUI } from "../../creationPanelUIStore";
import { import {
MenuButton, //@ts-ignore MenuButton, //@ts-ignore
@ -23,11 +25,10 @@ export default function WorkflowSettings() {
(state) => state.toggleSoundEnabled (state) => state.toggleSoundEnabled
); );
const [workflowOpen, setWorkflowOpen] = useState(true); const workflowOpen = useCreateUI((state) => state.isOpenAdvWorkflowSettings);
const toggleWorkflowOpen = useCreateUI((state) => state.toggleAdvWorkflowSettings);
const toggleWorkflowOpen = () => {
setWorkflowOpen(!workflowOpen);
};
return ( return (
<div> <div>

View File

@ -1,6 +1,6 @@
import React from "react"; import React from "react";
import { useImageCreate } from "../../../../../store/imageCreateStore"; import { useImageCreate } from "../../../../../stores/imageCreateStore";
import ModifierTag from "../../../../atoms/modifierTag"; import ModifierTag from "../../../../atoms/modifierTag";
export default function ActiveTags() { export default function ActiveTags() {

View File

@ -1,5 +1,5 @@
import React, { ChangeEvent } from "react"; import React, { ChangeEvent } from "react";
import { useImageCreate } from "../../../../store/imageCreateStore"; import { useImageCreate } from "../../../../stores/imageCreateStore";
import { import {
CreationBasicMain, CreationBasicMain,

View File

@ -1,7 +1,7 @@
import React, { useEffect, useState } from "react"; import React, { useEffect, useState } from "react";
import { useImageCreate } from "../../../../../store/imageCreateStore"; import { useImageCreate } from "../../../../../stores/imageCreateStore";
import { useImageQueue } from "../../../../../store/imageQueueStore"; import { useImageQueue } from "../../../../../stores/imageQueueStore";
import { v4 as uuidv4 } from "uuid"; import { v4 as uuidv4 } from "uuid";
import { useRandomSeed } from "../../../../../utils"; import { useRandomSeed } from "../../../../../utils";

View File

@ -8,7 +8,7 @@ import {
ImageFixer, ImageFixer,
XButton, // @ts-ignore XButton, // @ts-ignore
} from "./seedImage.css.ts"; } from "./seedImage.css.ts";
import { useImageCreate } from "../../../../../store/imageCreateStore"; import { useImageCreate } from "../../../../../stores/imageCreateStore";
// TODO : figure out why this needs props to be passed in.. fixes a type error // TODO : figure out why this needs props to be passed in.. fixes a type error
// when the component is used in the parent component // when the component is used in the parent component

View File

@ -0,0 +1,95 @@
import create from "zustand";
import produce from "immer";
import { persist } from 'zustand/middleware'
import { devtools } from "zustand/middleware";
export type ImageCreationUIOptions = {
isOpenAdvancedSettings: boolean;
isOpenAdvImprovementSettings: boolean;
isOpenAdvPropertySettings: boolean;
isOpenAdvWorkflowSettings: boolean;
isOpenAdvGPUSettings: boolean;
isOpenImageModifier: boolean;
imageMofidiersMap: object;
toggleAdvancedSettings: () => void;
toggleAdvImprovementSettings: () => void;
toggleAdvPropertySettings: () => void;
toggleAdvWorkflowSettings: () => void;
toggleAdvGPUSettings: () => void;
toggleImageModifier: () => void;
// addImageModifier: (modifier: string) => void;
};
export const useCreateUI = create<ImageCreationUIOptions>(
//@ts-ignore
persist(
(set, get ) => ({
isOpenAdvancedSettings: false,
isOpenAdvImprovementSettings: false,
isOpenAdvPropertySettings: false,
isOpenAdvWorkflowSettings: false,
isOpenAdvGPUSettings: false,
isOpenImageModifier: false,
imageMofidiersMap: {},
toggleAdvancedSettings: () => {
set(
produce((state) => {
state.isOpenAdvancedSettings = !state.isOpenAdvancedSettings;
})
);
},
toggleAdvImprovementSettings: () => {
set(
produce((state) => {
state.isOpenAdvImprovementSettings = !state.isOpenAdvImprovementSettings;
})
);
},
toggleAdvPropertySettings: () => {
set(
produce((state) => {
state.isOpenAdvPropertySettings = !state.isOpenAdvPropertySettings;
})
);
},
toggleAdvWorkflowSettings: () => {
set(
produce((state) => {
state.isOpenAdvWorkflowSettings = !state.isOpenAdvWorkflowSettings;
})
);
},
toggleAdvGPUSettings: () => {
set(
produce((state) => {
state.isOpenAdvGPUSettings = !state.isOpenAdvGPUSettings;
})
);
},
toggleImageModifier: () => {
set(
produce((state) => {
state.isOpenImageModifier = !state.isOpenImageModifier;
})
);
},
}),
{
name: 'createUI',
// getStorage: () => localStorage,
}
));

View File

@ -3,7 +3,9 @@ import React, { useEffect, useState } from "react";
import { useQuery } from "@tanstack/react-query"; import { useQuery } from "@tanstack/react-query";
import { loadModifications } from "../../../../api"; import { loadModifications } from "../../../../api";
import { useImageCreate } from "../../../../store/imageCreateStore"; import { useImageCreate } from "../../../../stores/imageCreateStore";
import { useCreateUI } from "../creationPanelUIStore";
import ModifierTag from "../../../atoms/modifierTag"; import ModifierTag from "../../../atoms/modifierTag";
@ -12,8 +14,7 @@ type ModifierListProps = {
}; };
function ModifierList({ tags }: ModifierListProps) { function ModifierList({ tags }: ModifierListProps) {
// const setImageOptions = useImageCreate((state) => state.setImageOptions);
// const imageOptions = useImageCreate((state) => state.imageOptions);
return ( return (
<ul className="modifier-list"> <ul className="modifier-list">
{tags.map((tag) => ( {tags.map((tag) => (
@ -50,15 +51,27 @@ function ModifierGrouping({ title, tags }: ModifierGroupingProps) {
} }
export default function ImageModifers() { export default function ImageModifers() {
const { status, data } = useQuery(["modifications"], loadModifications); // const { status, data } = useQuery(["modifications"], loadModifications);
const imageModifierIsOpen = useImageCreate( // const imageModifierIsOpen = useImageCreate(
(state) => state.uiOptions.imageModifierIsOpen // (state) => state.uiOptions.imageModifierIsOpen
// );
// const toggleImageModifiersIsOpen = useImageCreate(
// (state) => state.toggleImageModifiersIsOpen
// );
const allModifiers = useImageCreate((state) => state.allModifiers);
console.log("allModifiers", allModifiers);
const imageModifierIsOpen = useCreateUI(
(state) => state.isOpenImageModifier
); );
const toggleImageModifiersIsOpen = useImageCreate( const toggleImageModifiersIsOpen = useCreateUI(
(state) => state.toggleImageModifiersIsOpen (state) => state.toggleImageModifier
); );
const handleClick = () => { const handleClick = () => {
toggleImageModifiersIsOpen(); toggleImageModifiersIsOpen();
}; };
@ -77,8 +90,9 @@ export default function ImageModifers() {
{/* @ts-ignore */} {/* @ts-ignore */}
{imageModifierIsOpen && {imageModifierIsOpen &&
// @ts-ignore // @ts-ignore
data.map((item, index) => { allModifiers.map((item, index) => {
return ( return (
// @ts-ignore
<ModifierGrouping key={item[0]} title={item[0]} tags={item[1]} /> <ModifierGrouping key={item[0]} title={item[0]} tags={item[1]} />
); );
})} })}

View File

@ -0,0 +1,28 @@
const Mockifiers = [
[
"Drawing Style",
[
"Cel Shading",
"Children's Drawing",
"Crosshatch",
"Detailed and Intricate",
"Doodle",
"Dot Art",
"Line Art",
"Sketch"
]
],
[
"Visual Style",
[
"2D",
"8-bit",
"16-bit",
"Anaglyph",
"Anime",
"CGI",
]
],
];
export default Mockifiers;

View File

@ -1,7 +1,7 @@
import React, { useEffect, useState, useRef } from "react"; import React, { useEffect, useState, useRef } from "react";
import { useImageQueue } from "../../../store/imageQueueStore"; import { useImageQueue } from "../../../stores/imageQueueStore";
import { ImageRequest, useImageCreate } from "../../../store/imageCreateStore"; import { ImageRequest, useImageCreate } from "../../../stores/imageCreateStore";
import { useQuery, useQueryClient } from "@tanstack/react-query"; import { useQuery, useQueryClient } from "@tanstack/react-query";

View File

@ -6,9 +6,9 @@ import { QueryClient, QueryClientProvider } from "@tanstack/react-query";
import { ReactQueryDevtools } from "@tanstack/react-query-devtools"; import { ReactQueryDevtools } from "@tanstack/react-query-devtools";
import { enableMapSet } from "immer"; import { enableMapSet } from "immer";
import Editor from "./components/layouts/Home"; import Editor from "./pages/Home";
import App from "./App"; import App from "./app";
import "./styles.css.ts"; import "./styles.css.ts";

View File

@ -0,0 +1,66 @@
import React, { useEffect, useState } from "react";
import {
AppLayout,
HeaderLayout,
CreateLayout,
DisplayLayout,
FooterLayout, // @ts-ignore
} from "./home.css.ts";
import { useQuery } from "@tanstack/react-query";
import { getSaveDirectory, loadModifications } from "../../api";
import Mockifiers from "../../components/organisms/creationPanel/imageModifiers/modifiers.mock";
import { useImageCreate } from "../../stores/imageCreateStore";
// Todo - import components here
import HeaderDisplay from "../../components/organisms/headerDisplay";
import CreationPanel from "../../components/organisms/creationPanel";
import DisplayPanel from "../../components/organisms/displayPanel";
import FooterDisplay from "../../components/organisms/footerDisplay";
function Editor() {
// Get the original save directory
const setRequestOption = useImageCreate((state) => state.setRequestOptions);
const { status: statusSave, data: dataSave } = useQuery(["SaveDir"], getSaveDirectory);
const { status: statusMods, data: dataMoads } = useQuery(["modifications"], loadModifications);
const setAllModifiers = useImageCreate((state) => state.setAllModifiers);
useEffect(() => {
if (statusSave === "success") {
setRequestOption("save_to_disk_path", dataSave);
}
}, [setRequestOption, statusSave, dataSave]);
useEffect(() => {
if (statusMods === "success") {
setAllModifiers(dataMoads);
}
else if (statusMods === "error") {
// @ts-ignore
setAllModifiers(Mockifiers);
}
}, [setRequestOption, statusMods, dataMoads]);
return (
<div className={AppLayout}>
<header className={HeaderLayout}>
<HeaderDisplay></HeaderDisplay>
</header>
<nav className={CreateLayout}>
<CreationPanel></CreationPanel>
</nav>
<main className={DisplayLayout}>
<DisplayPanel></DisplayPanel>
</main>
<footer className={FooterLayout}>
<FooterDisplay></FooterDisplay>
</footer>
</div>
);
}
export default Editor;

View File

@ -5,8 +5,6 @@ import { devtools } from "zustand/middleware";
import { useRandomSeed } from "../utils"; import { useRandomSeed } from "../utils";
export type ImageCreationUiOptions = { export type ImageCreationUiOptions = {
advancedSettingsIsOpen: boolean;
imageModifierIsOpen: boolean;
isCheckedUseUpscaling: boolean; isCheckedUseUpscaling: boolean;
isCheckUseFaceCorrection: boolean; isCheckUseFaceCorrection: boolean;
isUseRandomSeed: boolean; isUseRandomSeed: boolean;
@ -64,23 +62,29 @@ export type ImageRequest = {
prompt_strength: undefined | number; prompt_strength: undefined | number;
}; };
type ModifiersList = string[];
type ModifiersOptions = string | ModifiersList[];
type ModifiersOptionList = ModifiersOptions[];
interface ImageCreateState { interface ImageCreateState {
parallelCount: number; parallelCount: number;
requestOptions: ImageRequest; requestOptions: ImageRequest;
allModifiers: ModifiersOptionList;
tags: string[]; tags: string[];
setParallelCount: (count: number) => void; setParallelCount: (count: number) => void;
setRequestOptions: (key: keyof ImageRequest, value: any) => void; setRequestOptions: (key: keyof ImageRequest, value: any) => void;
getValueForRequestKey: (key: keyof ImageRequest) => any; getValueForRequestKey: (key: keyof ImageRequest) => any;
setAllModifiers: (modifiers: ModifiersOptionList) => void;
setModifierOptions: (key: string, value: any) => void;
toggleTag: (tag: string) => void; toggleTag: (tag: string) => void;
hasTag: (tag: string) => boolean; hasTag: (tag: string) => boolean;
selectedTags: () => string[]; selectedTags: () => string[];
builtRequest: () => ImageRequest; builtRequest: () => ImageRequest;
uiOptions: ImageCreationUiOptions; uiOptions: ImageCreationUiOptions;
toggleAdvancedSettingsIsOpen: () => void;
toggleImageModifiersIsOpen: () => void;
toggleUseUpscaling: () => void; toggleUseUpscaling: () => void;
isUsingUpscaling: () => boolean; isUsingUpscaling: () => boolean;
toggleUseFaceCorrection: () => void; toggleUseFaceCorrection: () => void;
@ -120,6 +124,8 @@ export const useImageCreate = create<ImageCreateState>(
tags: [] as string[], tags: [] as string[],
allModifiers: [[[]]] as ModifiersOptionList,
setParallelCount: (count: number) => setParallelCount: (count: number) =>
set( set(
produce((state) => { produce((state) => {
@ -139,6 +145,15 @@ export const useImageCreate = create<ImageCreateState>(
return get().requestOptions[key]; return get().requestOptions[key];
}, },
setAllModifiers: (modifiers: ModifiersOptionList) => {
set(
produce((state) => {
state.allModifiers = modifiers;
})
);
},
toggleTag: (tag: string) => { toggleTag: (tag: string) => {
set( set(
produce((state) => { produce((state) => {
@ -196,8 +211,7 @@ export const useImageCreate = create<ImageCreateState>(
uiOptions: { uiOptions: {
// TODO proper persistence of all UI / user settings centrally somewhere? // TODO proper persistence of all UI / user settings centrally somewhere?
// localStorage.getItem('ui:advancedSettingsIsOpen') === 'true', // localStorage.getItem('ui:advancedSettingsIsOpen') === 'true',
advancedSettingsIsOpen: false,
imageModifierIsOpen: false,
isCheckedUseUpscaling: false, isCheckedUseUpscaling: false,
isCheckUseFaceCorrection: true, isCheckUseFaceCorrection: true,
isUseRandomSeed: true, isUseRandomSeed: true,
@ -205,31 +219,6 @@ export const useImageCreate = create<ImageCreateState>(
isSoundEnabled: false, isSoundEnabled: false,
}, },
toggleAdvancedSettingsIsOpen: () => {
set(
produce((state) => {
state.uiOptions.advancedSettingsIsOpen =
!state.uiOptions.advancedSettingsIsOpen;
localStorage.setItem(
"ui:advancedSettingsIsOpen",
state.uiOptions.advancedSettingsIsOpen
);
})
);
},
toggleImageModifiersIsOpen: () => {
set(
produce((state) => {
state.uiOptions.imageModifierIsOpen =
!state.uiOptions.imageModifierIsOpen;
localStorage.setItem(
"ui:imageModifierIsOpen",
state.uiOptions.imageModifierIsOpen
);
})
);
},
toggleUseUpscaling: () => { toggleUseUpscaling: () => {
set( set(

View File

@ -1,8 +1,6 @@
import create from "zustand"; import create from "zustand";
import produce from "immer"; import produce from "immer";
// import { devtools } from 'zustand/middleware'
interface ImageDisplayState { interface ImageDisplayState {
imageOptions: Map<string, any>; imageOptions: Map<string, any>;
currentImage: object | null; currentImage: object | null;

File diff suppressed because it is too large Load Diff