File size: 4,107 Bytes
853f6aa
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
import { IconButton } from "@/app/components/button";
import GithubIcon from "@/app/icons/github.svg";
import SDIcon from "@/app/icons/sd.svg";
import ReturnIcon from "@/app/icons/return.svg";
import HistoryIcon from "@/app/icons/history.svg";
import Locale from "@/app/locales";

import { Path, REPO_URL } from "@/app/constant";

import { useNavigate } from "react-router-dom";
import dynamic from "next/dynamic";
import {
  SideBarContainer,
  SideBarBody,
  SideBarHeader,
  SideBarTail,
  useDragSideBar,
  useHotKey,
} from "@/app/components/sidebar";

import { getParams, getModelParamBasicData } from "./sd-panel";
import { useSdStore } from "@/app/store/sd";
import { showToast } from "@/app/components/ui-lib";
import { useMobileScreen } from "@/app/utils";

const SdPanel = dynamic(
  async () => (await import("@/app/components/sd")).SdPanel,
  {
    loading: () => null,
  },
);

export function SideBar(props: { className?: string }) {
  useHotKey();
  const isMobileScreen = useMobileScreen();
  const { onDragStart, shouldNarrow } = useDragSideBar();
  const navigate = useNavigate();
  const sdStore = useSdStore();
  const currentModel = sdStore.currentModel;
  const params = sdStore.currentParams;
  const setParams = sdStore.setCurrentParams;

  const handleSubmit = () => {
    const columns = getParams?.(currentModel, params);
    const reqParams: any = {};
    for (let i = 0; i < columns.length; i++) {
      const item = columns[i];
      reqParams[item.value] = params[item.value] ?? null;
      if (item.required) {
        if (!reqParams[item.value]) {
          showToast(Locale.SdPanel.ParamIsRequired(item.name));
          return;
        }
      }
    }
    let data: any = {
      model: currentModel.value,
      model_name: currentModel.name,
      status: "wait",
      params: reqParams,
      created_at: new Date().toLocaleString(),
      img_data: "",
    };
    sdStore.sendTask(data, () => {
      setParams(getModelParamBasicData(columns, params, true));
      navigate(Path.SdNew);
    });
  };

  return (
    <SideBarContainer

      onDragStart={onDragStart}

      shouldNarrow={shouldNarrow}

      {...props}

    >

      {isMobileScreen ? (

        <div

          className="window-header"

          data-tauri-drag-region

          style={{

            paddingLeft: 0,

            paddingRight: 0,

          }}

        >

          <div className="window-actions">

            <div className="window-action-button">

              <IconButton

                icon={<ReturnIcon />}

                bordered

                title={Locale.Sd.Actions.ReturnHome}

                onClick={() => navigate(Path.Home)}

              />

            </div>

          </div>

          <SDIcon width={50} height={50} />

          <div className="window-actions">

            <div className="window-action-button">

              <IconButton

                icon={<HistoryIcon />}

                bordered

                title={Locale.Sd.Actions.History}

                onClick={() => navigate(Path.SdNew)}

              />

            </div>

          </div>

        </div>

      ) : (

        <SideBarHeader

          title={

            <IconButton

              icon={<ReturnIcon />}

              bordered

              title={Locale.Sd.Actions.ReturnHome}

              onClick={() => navigate(Path.Home)}

            />

          }

          logo={<SDIcon width={38} height={"100%"} />}

        ></SideBarHeader>

      )}

      <SideBarBody>

        <SdPanel />

      </SideBarBody>

      <SideBarTail

        primaryAction={

          <a href={REPO_URL} target="_blank" rel="noopener noreferrer">

            <IconButton icon={<GithubIcon />} shadow />

          </a>

        }

        secondaryAction={

          <IconButton

            text={Locale.SdPanel.Submit}

            type="primary"

            shadow

            onClick={handleSubmit}

          ></IconButton>

        }

      />

    </SideBarContainer>
  );
}