summaryrefslogtreecommitdiff
path: root/frontend/src/components/modals/PluginInstallModal.tsx
blob: d9a3b4335e1e5bcd8249892e1ac95fdc4268b1ee (plain)
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
import { ConfirmModal, Navigation, ProgressBarWithInfo, QuickAccessTab } from '@decky/ui';
import { FC, useEffect, useState } from 'react';
import { useTranslation } from 'react-i18next';

import TranslationHelper, { TranslationClass } from '../../utils/TranslationHelper';

interface PluginInstallModalProps {
  artifact: string;
  version: string;
  hash: string;
  installType: number;
  onOK(): void;
  onCancel(): void;
  closeModal?(): void;
}

const PluginInstallModal: FC<PluginInstallModalProps> = ({
  artifact,
  version,
  hash,
  installType,
  onOK,
  onCancel,
  closeModal,
}) => {
  const [loading, setLoading] = useState<boolean>(false);
  const [percentage, setPercentage] = useState<number>(0);
  const [downloadInfo, setDownloadInfo] = useState<string | null>(null);
  const { t } = useTranslation();

  function updateDownloadState(percent: number, trans_text: string | undefined, trans_info: Record<string, string>) {
    setPercentage(percent);
    if (trans_text === undefined) {
      setDownloadInfo(null);
    } else {
      setDownloadInfo(t(trans_text, trans_info));
    }
  }

  useEffect(() => {
    DeckyBackend.addEventListener('loader/plugin_download_info', updateDownloadState);
    return () => {
      DeckyBackend.removeEventListener('loader/plugin_download_info', updateDownloadState);
    };
  }, []);

  return (
    <ConfirmModal
      bOKDisabled={loading}
      closeModal={closeModal}
      onOK={async () => {
        setLoading(true);
        await onOK();
        setTimeout(() => Navigation.OpenQuickAccessMenu(QuickAccessTab.Decky), 250);
        setTimeout(() => DeckyPluginLoader.checkPluginUpdates(), 1000);
      }}
      onCancel={async () => {
        await onCancel();
      }}
      strTitle={
        <div style={{display: "flex", flexDirection: "row", alignItems: "center", width: "100%"}}>
          <TranslationHelper
            transClass={TranslationClass.PLUGIN_INSTALL_MODAL}
            transText="title"
            i18nArgs={{ artifact: artifact }}
            installType={installType}
          />
          {loading && (
            <div style={{marginLeft: "auto"}}>
              <ProgressBarWithInfo
                layout="inline"
                
                bottomSeparator="none"
                nProgress={percentage}
                sOperationText={downloadInfo}
              />
            </div>
          )}
        </div>
      }
      strOKButtonText={
        loading ? (
          <div>
            <TranslationHelper
              transClass={TranslationClass.PLUGIN_INSTALL_MODAL}
              transText="button_processing"
              installType={installType}
            />
          </div>
        ) : (
          <div>
            <TranslationHelper
              transClass={TranslationClass.PLUGIN_INSTALL_MODAL}
              transText="button_idle"
              installType={installType}
            />
          </div>
        )
      }
    >
      <div>
        <TranslationHelper
          transClass={TranslationClass.PLUGIN_INSTALL_MODAL}
          transText="desc"
          i18nArgs={{
            artifact: artifact,
            version: version,
          }}
          installType={installType}
        />
      </div>
      {hash == 'False' && <span style={{ color: 'red' }}>{t('PluginInstallModal.no_hash')}</span>}
    </ConfirmModal>
  );
};

export default PluginInstallModal;