persist deploy values in memory
This commit is contained in:
		@@ -57,7 +57,9 @@ export const SetHookDialog: React.FC<{ accountAddress: string }> = React.memo(
 | 
			
		||||
  ({ accountAddress }) => {
 | 
			
		||||
    const snap = useSnapshot(state);
 | 
			
		||||
    const account = snap.accounts.find((acc) => acc.address === accountAddress);
 | 
			
		||||
 | 
			
		||||
    const activeFile = snap.files[snap.active]?.compiledContent
 | 
			
		||||
      ? snap.files[snap.active]
 | 
			
		||||
      : snap.files.filter((file) => file.compiledContent)[0];
 | 
			
		||||
    const [isSetHookDialogOpen, setIsSetHookDialogOpen] = useState(false);
 | 
			
		||||
    const {
 | 
			
		||||
      register,
 | 
			
		||||
@@ -68,11 +70,12 @@ export const SetHookDialog: React.FC<{ accountAddress: string }> = React.memo(
 | 
			
		||||
      getValues,
 | 
			
		||||
      formState: { errors },
 | 
			
		||||
    } = useForm<SetHookData>({
 | 
			
		||||
      defaultValues: {
 | 
			
		||||
        HookNamespace:
 | 
			
		||||
          snap.files?.[snap.activeWat]?.name?.split(".")?.[0] || "",
 | 
			
		||||
        Invoke: transactionOptions.filter((to) => to.label === "ttPAYMENT"),
 | 
			
		||||
      },
 | 
			
		||||
      defaultValues: snap.deployValues?.[activeFile?.name]
 | 
			
		||||
        ? snap.deployValues[activeFile?.name]
 | 
			
		||||
        : {
 | 
			
		||||
            HookNamespace: "kus",
 | 
			
		||||
            Invoke: transactionOptions.filter((to) => to.label === "ttPAYMENT"),
 | 
			
		||||
          },
 | 
			
		||||
    });
 | 
			
		||||
    const { fields, append, remove } = useFieldArray({
 | 
			
		||||
      control,
 | 
			
		||||
@@ -83,12 +86,18 @@ export const SetHookDialog: React.FC<{ accountAddress: string }> = React.memo(
 | 
			
		||||
    const watchedFee = watch("Fee");
 | 
			
		||||
    // Update value if activeWat changes
 | 
			
		||||
    useEffect(() => {
 | 
			
		||||
      setValue(
 | 
			
		||||
        "HookNamespace",
 | 
			
		||||
        snap.files?.[snap.activeWat]?.name?.split(".")?.[0] || ""
 | 
			
		||||
      );
 | 
			
		||||
      const defaultValue = snap.deployValues?.[activeFile?.name]
 | 
			
		||||
        ? snap.deployValues?.[activeFile?.name].HookNamespace
 | 
			
		||||
        : snap.files?.[snap.activeWat]?.name?.split(".")?.[0] || "";
 | 
			
		||||
      setValue("HookNamespace", defaultValue);
 | 
			
		||||
      setFormInitialized(true);
 | 
			
		||||
    }, [snap.activeWat, snap.files, setValue]);
 | 
			
		||||
    }, [
 | 
			
		||||
      snap.activeWat,
 | 
			
		||||
      snap.files,
 | 
			
		||||
      setValue,
 | 
			
		||||
      activeFile?.name,
 | 
			
		||||
      snap.deployValues,
 | 
			
		||||
    ]);
 | 
			
		||||
    useEffect(() => {
 | 
			
		||||
      if (
 | 
			
		||||
        watchedFee &&
 | 
			
		||||
@@ -108,7 +117,9 @@ export const SetHookDialog: React.FC<{ accountAddress: string }> = React.memo(
 | 
			
		||||
    const [hashedNamespace, setHashedNamespace] = useState("");
 | 
			
		||||
    const namespace = watch(
 | 
			
		||||
      "HookNamespace",
 | 
			
		||||
      snap.files?.[snap.active]?.name?.split(".")?.[0] || ""
 | 
			
		||||
      snap.deployValues?.[activeFile?.name]
 | 
			
		||||
        ? snap.deployValues?.[activeFile?.name].HookNamespace
 | 
			
		||||
        : snap.files?.[snap.activeWat]?.name?.split(".")?.[0] || ""
 | 
			
		||||
    );
 | 
			
		||||
    const calculateHashedValue = useCallback(async () => {
 | 
			
		||||
      const hashedVal = await sha256(namespace);
 | 
			
		||||
@@ -191,9 +202,6 @@ export const SetHookDialog: React.FC<{ accountAddress: string }> = React.memo(
 | 
			
		||||
                  <Controller
 | 
			
		||||
                    name="Invoke"
 | 
			
		||||
                    control={control}
 | 
			
		||||
                    defaultValue={transactionOptions.filter(
 | 
			
		||||
                      (to) => to.label === "ttPAYMENT"
 | 
			
		||||
                    )}
 | 
			
		||||
                    render={({ field }) => (
 | 
			
		||||
                      <Select
 | 
			
		||||
                        {...field}
 | 
			
		||||
@@ -210,9 +218,6 @@ export const SetHookDialog: React.FC<{ accountAddress: string }> = React.memo(
 | 
			
		||||
                  <Input
 | 
			
		||||
                    {...register("HookNamespace", { required: true })}
 | 
			
		||||
                    autoComplete={"off"}
 | 
			
		||||
                    defaultValue={
 | 
			
		||||
                      snap.files?.[snap.activeWat]?.name?.split(".")?.[0] || ""
 | 
			
		||||
                    }
 | 
			
		||||
                  />
 | 
			
		||||
                  {errors.HookNamespace?.type === "required" && (
 | 
			
		||||
                    <Box css={{ display: "inline", color: "$red11" }}>
 | 
			
		||||
 
 | 
			
		||||
@@ -126,6 +126,10 @@ export const deployHook = async (
 | 
			
		||||
  data: SetHookData
 | 
			
		||||
) => {
 | 
			
		||||
  if (typeof window !== "undefined") {
 | 
			
		||||
    const activeFile = state.files[state.active]?.compiledContent
 | 
			
		||||
      ? state.files[state.active]
 | 
			
		||||
      : state.files.filter((file) => file.compiledContent)[0];
 | 
			
		||||
    state.deployValues[activeFile.name] = data;
 | 
			
		||||
    const tx = await prepareDeployHookTx(account, data);
 | 
			
		||||
    if (!tx) {
 | 
			
		||||
      return;
 | 
			
		||||
 
 | 
			
		||||
@@ -52,6 +52,8 @@ export interface ILog {
 | 
			
		||||
  defaultCollapsed?: boolean
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export type DeployValue = Record<IFile['name'], any>;
 | 
			
		||||
 | 
			
		||||
export interface IState {
 | 
			
		||||
  files: IFile[];
 | 
			
		||||
  gistId?: string | null;
 | 
			
		||||
@@ -82,7 +84,8 @@ export interface IState {
 | 
			
		||||
  compileOptions: {
 | 
			
		||||
    optimizationLevel: '-O0' | '-O1' | '-O2' | '-O3' | '-O4' | '-Os';
 | 
			
		||||
    strip: boolean
 | 
			
		||||
  }
 | 
			
		||||
  },
 | 
			
		||||
  deployValues: DeployValue
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// let localStorageState: null | string = null;
 | 
			
		||||
@@ -116,7 +119,8 @@ let initialState: IState = {
 | 
			
		||||
  compileOptions: {
 | 
			
		||||
    optimizationLevel: '-O2',
 | 
			
		||||
    strip: true
 | 
			
		||||
  }
 | 
			
		||||
  },
 | 
			
		||||
  deployValues: {}
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
let localStorageAccounts: string | null = null;
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user