@plutonhq/core-frontend 0.1.30 → 0.1.31
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist-lib/@types/devices.d.ts +4 -4
- package/dist-lib/@types/devices.d.ts.map +1 -1
- package/dist-lib/@types/plans.d.ts +1 -0
- package/dist-lib/@types/plans.d.ts.map +1 -1
- package/dist-lib/components/App/Footer/Footer.d.ts +2 -1
- package/dist-lib/components/App/Footer/Footer.d.ts.map +1 -1
- package/dist-lib/components/App/Footer/Footer.js +10 -8
- package/dist-lib/components/App/Footer/Footer.js.map +1 -1
- package/dist-lib/components/Device/EditDevice/EditDevice.d.ts.map +1 -1
- package/dist-lib/components/Device/EditDevice/EditDevice.js +70 -61
- package/dist-lib/components/Device/EditDevice/EditDevice.js.map +1 -1
- package/dist-lib/components/Plan/BackupProgress/BackupProgress.d.ts.map +1 -1
- package/dist-lib/components/Plan/BackupProgress/BackupProgress.js +66 -68
- package/dist-lib/components/Plan/BackupProgress/BackupProgress.js.map +1 -1
- package/dist-lib/components/Plan/BackupProgress/BackupProgress.module.scss.js +40 -38
- package/dist-lib/components/Plan/BackupProgress/BackupProgress.module.scss.js.map +1 -1
- package/dist-lib/components/Plan/PlanSettings/PlanScriptsSettings.d.ts.map +1 -1
- package/dist-lib/components/Plan/PlanSettings/PlanScriptsSettings.js +89 -101
- package/dist-lib/components/Plan/PlanSettings/PlanScriptsSettings.js.map +1 -1
- package/dist-lib/components/Plan/PlanSettings/PlanSourceSettings.d.ts.map +1 -1
- package/dist-lib/components/Plan/PlanSettings/PlanSourceSettings.js +31 -25
- package/dist-lib/components/Plan/PlanSettings/PlanSourceSettings.js.map +1 -1
- package/dist-lib/components/common/form/StoragePicker/StoragePicker.d.ts.map +1 -1
- package/dist-lib/components/common/form/StoragePicker/StoragePicker.js +52 -46
- package/dist-lib/components/common/form/StoragePicker/StoragePicker.js.map +1 -1
- package/dist-lib/routes/PlanSingle/PlanSingle.d.ts.map +1 -1
- package/dist-lib/routes/PlanSingle/PlanSingle.js +76 -72
- package/dist-lib/routes/PlanSingle/PlanSingle.js.map +1 -1
- package/dist-lib/routes/PlanSingle/PlanSingle.module.scss.js +14 -12
- package/dist-lib/routes/PlanSingle/PlanSingle.module.scss.js.map +1 -1
- package/dist-lib/styles/core-frontend.css +1 -1
- package/dist-lib/utils/progressHelpers.d.ts.map +1 -1
- package/dist-lib/utils/progressHelpers.js +1 -0
- package/dist-lib/utils/progressHelpers.js.map +1 -1
- package/package.json +1 -1
- package/src/@types/devices.ts +4 -4
- package/src/@types/plans.ts +1 -0
- package/src/components/App/Footer/Footer.tsx +3 -2
- package/src/components/Device/EditDevice/EditDevice.tsx +11 -4
- package/src/components/Plan/BackupProgress/BackupProgress.module.scss +3 -0
- package/src/components/Plan/BackupProgress/BackupProgress.tsx +5 -3
- package/src/components/Plan/PlanSettings/PlanScriptsSettings.tsx +29 -31
- package/src/components/Plan/PlanSettings/PlanSourceSettings.tsx +11 -3
- package/src/components/common/form/StoragePicker/StoragePicker.tsx +10 -2
- package/src/routes/PlanSingle/PlanSingle.module.scss +10 -0
- package/src/routes/PlanSingle/PlanSingle.tsx +6 -1
- package/src/utils/progressHelpers.ts +1 -0
|
@@ -1,60 +1,58 @@
|
|
|
1
1
|
import { jsxs as r, jsx as t, Fragment as C } from "react/jsx-runtime";
|
|
2
|
-
import { useState as
|
|
3
|
-
import { useQueryClient as
|
|
4
|
-
import { toast as
|
|
2
|
+
import { useState as x } from "react";
|
|
3
|
+
import { useQueryClient as W } from "@tanstack/react-query";
|
|
4
|
+
import { toast as O } from "react-toastify";
|
|
5
5
|
import d from "../../common/Icon/Icon.js";
|
|
6
|
-
import { useCancelBackup as
|
|
6
|
+
import { useCancelBackup as X, useGetBackupProgress as Z } from "../../../services/backups.js";
|
|
7
7
|
import e from "./BackupProgress.module.scss.js";
|
|
8
|
-
import { timeAgo as
|
|
9
|
-
import { extractResticData as
|
|
10
|
-
import
|
|
11
|
-
import { useCancelRestore as
|
|
12
|
-
import
|
|
13
|
-
const
|
|
14
|
-
const [
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
total_files_processed: I = (s == null ? void 0 : s.total_files) || 0,
|
|
18
|
-
files_done: K = 0,
|
|
8
|
+
import { timeAgo as D, formatDateTime as ee, formatBytes as j, formatSeconds as se } from "../../../utils/helpers.js";
|
|
9
|
+
import { extractResticData as re, generateBackupProgressMessage as te, generateRestoreProgressMessage as ne, generateMirrorProgressMessage as ie } from "../../../utils/progressHelpers.js";
|
|
10
|
+
import oe from "../../common/ActionModal/ActionModal.js";
|
|
11
|
+
import { useCancelRestore as ae, useGetRestoreProgress as le } from "../../../services/restores.js";
|
|
12
|
+
import ce from "../BackupEvents/BackupEvents.js";
|
|
13
|
+
const _e = ({ item: l, sourceId: b, sourceType: v, planId: c, type: i = "backup" }) => {
|
|
14
|
+
const [I, M] = x(!1), [K, S] = x(!1), B = W(), $ = ae(), w = X(), { id: g, started: y } = l, { data: o } = i === "backup" ? Z({ id: g, sourceId: b, sourceType: v, planId: c }) : le({ id: g, sourceId: b, sourceType: v, planId: c }), s = re(o), L = i === "backup" ? te(o) : ne(o), Q = o == null ? void 0 : o.events.find((a) => a.action === "BACKUP_OPERATION_START" && a.resticData), U = i === "backup" && !Q, {
|
|
15
|
+
total_files_processed: G = (s == null ? void 0 : s.total_files) || 0,
|
|
16
|
+
files_done: Y = 0,
|
|
19
17
|
total_bytes_processed: N = (s == null ? void 0 : s.total_bytes_processed) || (s == null ? void 0 : s.total_bytes) || 0,
|
|
20
18
|
bytes_done: F = 0,
|
|
21
|
-
bytes_restored:
|
|
22
|
-
files_restored:
|
|
23
|
-
seconds_remaining:
|
|
19
|
+
bytes_restored: A = 0,
|
|
20
|
+
files_restored: T = 0,
|
|
21
|
+
seconds_remaining: H = 0,
|
|
24
22
|
percent_done: _ = 0
|
|
25
23
|
} = s || {};
|
|
26
|
-
let h =
|
|
27
|
-
|
|
28
|
-
const
|
|
29
|
-
console.log("cancel :",
|
|
24
|
+
let h = Y, f = F, P = N, z = G, m = N ? Math.round(F / N * 100) : 0;
|
|
25
|
+
i === "restore" && (m = Math.round(_ * 100), s != null && s.total_bytes && (P = s.total_bytes), A ? f = A : s != null && s.total_bytes && (f = Math.round(_ * s.total_bytes)), T ? h = T : s != null && s.total_files && (h = Math.round(_ * s.total_files))), (s == null ? void 0 : s.message_type) === "summary" && (m = 100, h = z, f = P);
|
|
26
|
+
const J = () => {
|
|
27
|
+
console.log("cancel :", i, l), i === "backup" ? O.promise(
|
|
30
28
|
w.mutateAsync(
|
|
31
29
|
{ planId: c, backupId: l.id },
|
|
32
30
|
{
|
|
33
|
-
onSuccess: () =>
|
|
31
|
+
onSuccess: () => B.invalidateQueries({ queryKey: ["plan", c] })
|
|
34
32
|
}
|
|
35
33
|
),
|
|
36
34
|
{
|
|
37
35
|
pending: "Sending Cancel Request...",
|
|
38
36
|
success: "Backup process Cancelled!",
|
|
39
37
|
error: {
|
|
40
|
-
render({ data:
|
|
41
|
-
return `Failed to cancel backup process. ${(
|
|
38
|
+
render({ data: a }) {
|
|
39
|
+
return `Failed to cancel backup process. ${(a == null ? void 0 : a.message) || "Unknown Error."}`;
|
|
42
40
|
}
|
|
43
41
|
}
|
|
44
42
|
}
|
|
45
|
-
) :
|
|
46
|
-
|
|
43
|
+
) : O.promise(
|
|
44
|
+
$.mutateAsync(
|
|
47
45
|
{ planId: c, restoreId: l.id },
|
|
48
46
|
{
|
|
49
|
-
onSuccess: () =>
|
|
47
|
+
onSuccess: () => B.invalidateQueries({ queryKey: ["plan", c] })
|
|
50
48
|
}
|
|
51
49
|
),
|
|
52
50
|
{
|
|
53
51
|
pending: "Sending Cancel Request...",
|
|
54
52
|
success: "Restore process Cancelled!",
|
|
55
53
|
error: {
|
|
56
|
-
render({ data:
|
|
57
|
-
return `Failed to cancel restore process. ${(
|
|
54
|
+
render({ data: a }) {
|
|
55
|
+
return `Failed to cancel restore process. ${(a == null ? void 0 : a.message) || "Unknown Error."}`;
|
|
58
56
|
}
|
|
59
57
|
}
|
|
60
58
|
}
|
|
@@ -65,13 +63,13 @@ const ye = ({ item: l, sourceId: k, sourceType: v, planId: c, type: o = "backup"
|
|
|
65
63
|
/* @__PURE__ */ t("div", { className: e.backupIcon, children: /* @__PURE__ */ t(d, { type: "loading", size: 24 }) }),
|
|
66
64
|
/* @__PURE__ */ r("div", { className: e.backupLeft, children: [
|
|
67
65
|
/* @__PURE__ */ r("div", { className: e.backupId, children: [
|
|
68
|
-
|
|
66
|
+
i === "restore" ? "Restoring " : "",
|
|
69
67
|
"backup-",
|
|
70
68
|
g,
|
|
71
|
-
/* @__PURE__ */ r("span", { className: e.backupTime, title:
|
|
69
|
+
/* @__PURE__ */ r("span", { className: e.backupTime, title: ee(y), children: [
|
|
72
70
|
/* @__PURE__ */ t(d, { type: "clock", size: 12 }),
|
|
73
71
|
" Started ",
|
|
74
|
-
y ?
|
|
72
|
+
y ? D(new Date(y)) : "a few seconds ago"
|
|
75
73
|
] }),
|
|
76
74
|
l.errorMsg && /* @__PURE__ */ r("span", { className: e.backupError, children: [
|
|
77
75
|
/* @__PURE__ */ t(d, { type: "error-circle-filled", size: 13 }),
|
|
@@ -85,8 +83,8 @@ const ye = ({ item: l, sourceId: k, sourceType: v, planId: c, type: o = "backup"
|
|
|
85
83
|
] })
|
|
86
84
|
] }),
|
|
87
85
|
/* @__PURE__ */ r("div", { className: e.backupStart, children: [
|
|
88
|
-
/* @__PURE__ */ t("div", { children: /* @__PURE__ */ t("span", { className: e.progressMessage, onClick: () => S(!0), children:
|
|
89
|
-
/* @__PURE__ */ r("button", { onClick: () =>
|
|
86
|
+
/* @__PURE__ */ t("div", { children: /* @__PURE__ */ t("span", { className: e.progressMessage, onClick: () => S(!0), children: L }) }),
|
|
87
|
+
/* @__PURE__ */ r("button", { onClick: () => M(!0), title: `Cancel ${i}`, children: [
|
|
90
88
|
/* @__PURE__ */ t(d, { type: "close", size: 12 }),
|
|
91
89
|
" Cancel"
|
|
92
90
|
] })
|
|
@@ -98,69 +96,69 @@ const ye = ({ item: l, sourceId: k, sourceType: v, planId: c, type: o = "backup"
|
|
|
98
96
|
/* @__PURE__ */ r("span", { children: [
|
|
99
97
|
h,
|
|
100
98
|
" / ",
|
|
101
|
-
|
|
99
|
+
z,
|
|
102
100
|
" Files"
|
|
103
101
|
] }),
|
|
104
102
|
/* @__PURE__ */ t("i", {}),
|
|
105
103
|
/* @__PURE__ */ r("span", { children: [
|
|
106
|
-
|
|
104
|
+
j(f),
|
|
107
105
|
" / ",
|
|
108
|
-
|
|
106
|
+
j(P)
|
|
109
107
|
] })
|
|
110
108
|
] }),
|
|
111
|
-
/* @__PURE__ */ t("div", { className: e.ProgressStatsRight, children:
|
|
109
|
+
/* @__PURE__ */ t("div", { className: e.ProgressStatsRight, children: i !== "restore" && /* @__PURE__ */ r(C, { children: [
|
|
112
110
|
"Remaining: ",
|
|
113
|
-
|
|
111
|
+
se(H)
|
|
114
112
|
] }) })
|
|
115
113
|
] }),
|
|
116
114
|
/* @__PURE__ */ t("div", { className: e.progressBar, children: /* @__PURE__ */ t(
|
|
117
115
|
"div",
|
|
118
116
|
{
|
|
119
|
-
className: `${e.progressBarFill} ${
|
|
120
|
-
style: { width:
|
|
117
|
+
className: `${e.progressBarFill} ${m > 3 ? e.progressBarFilled : ""} ${U ? e.progressBarDryRun : ""}`,
|
|
118
|
+
style: { width: m + "%" },
|
|
121
119
|
children: /* @__PURE__ */ r("span", { children: [
|
|
122
|
-
|
|
120
|
+
m,
|
|
123
121
|
"%"
|
|
124
122
|
] })
|
|
125
123
|
}
|
|
126
124
|
) })
|
|
127
125
|
] }),
|
|
128
|
-
|
|
129
|
-
|
|
126
|
+
I && /* @__PURE__ */ t(
|
|
127
|
+
oe,
|
|
130
128
|
{
|
|
131
|
-
title: `Cancel ${
|
|
132
|
-
message: /* @__PURE__ */ t(C, { children: `Are you sure you want to cancel the ${
|
|
133
|
-
closeModal: () =>
|
|
129
|
+
title: `Cancel ${i}`,
|
|
130
|
+
message: /* @__PURE__ */ t(C, { children: `Are you sure you want to cancel the ${i} process?` }),
|
|
131
|
+
closeModal: () => M(!1),
|
|
134
132
|
width: "400px",
|
|
135
133
|
primaryAction: {
|
|
136
|
-
title: `Yes, Cancel ${
|
|
134
|
+
title: `Yes, Cancel ${i}`,
|
|
137
135
|
type: "danger",
|
|
138
|
-
isPending:
|
|
139
|
-
action: () =>
|
|
136
|
+
isPending: i === "restore" ? $.isPending : w.isPending,
|
|
137
|
+
action: () => J()
|
|
140
138
|
}
|
|
141
139
|
}
|
|
142
140
|
),
|
|
143
|
-
|
|
144
|
-
|
|
141
|
+
K && /* @__PURE__ */ t(
|
|
142
|
+
ce,
|
|
145
143
|
{
|
|
146
144
|
id: g,
|
|
147
|
-
type:
|
|
145
|
+
type: i,
|
|
148
146
|
planId: c,
|
|
149
|
-
sourceId:
|
|
147
|
+
sourceId: b,
|
|
150
148
|
sourceType: v,
|
|
151
|
-
progressData:
|
|
149
|
+
progressData: o,
|
|
152
150
|
inProgress: !0,
|
|
153
151
|
close: () => S(!1)
|
|
154
152
|
}
|
|
155
153
|
)
|
|
156
154
|
] }, l.id),
|
|
157
|
-
(
|
|
155
|
+
(o == null ? void 0 : o.mirrors) && Object.keys(o.mirrors).length > 0 && /* @__PURE__ */ r("div", { className: e.mirrorsSection, children: [
|
|
158
156
|
/* @__PURE__ */ t("div", { className: e.mirrorsTitle, children: "Replicating" }),
|
|
159
|
-
/* @__PURE__ */ t("div", { className: e.mirrorsList, children: Object.entries(
|
|
160
|
-
var
|
|
161
|
-
const
|
|
162
|
-
let
|
|
163
|
-
return n.status === "running" && (
|
|
157
|
+
/* @__PURE__ */ t("div", { className: e.mirrorsList, children: Object.entries(o.mirrors).map(([a, n]) => {
|
|
158
|
+
var E, q;
|
|
159
|
+
const k = (q = (E = n.events) == null ? void 0 : E.slice().reverse().find((V) => V.resticData)) == null ? void 0 : q.resticData, p = k != null && k.percent_done ? Math.round(k.percent_done * 100) : 0, R = ie(n);
|
|
160
|
+
let u = e.mirrorPending;
|
|
161
|
+
return n.status === "running" && (u = p > 0 ? e.mirrorRunning : e.mirrorRunningIndeterminate), n.status === "completed" && (u = e.mirrorCompleted), n.status === "failed" && (u = e.mirrorFailed), n.status === "retrying" && (u = e.mirrorRunningIndeterminate), /* @__PURE__ */ r("div", { className: e.mirrorItem, children: [
|
|
164
162
|
/* @__PURE__ */ r("div", { className: e.mirrorStorageIcon, children: [
|
|
165
163
|
(n.status === "running" || n.status === "pending" || n.status === "retrying") && /* @__PURE__ */ t(d, { type: "loading", size: 12 }),
|
|
166
164
|
/* @__PURE__ */ t("img", { src: `/providers/${n.storageType}.png` })
|
|
@@ -168,9 +166,9 @@ const ye = ({ item: l, sourceId: k, sourceType: v, planId: c, type: o = "backup"
|
|
|
168
166
|
/* @__PURE__ */ r("div", { className: e.mirrorProgress, children: [
|
|
169
167
|
/* @__PURE__ */ r("div", { className: e.mirrorInfo, children: [
|
|
170
168
|
/* @__PURE__ */ t("span", { className: e.mirrorName, children: n.storageName }),
|
|
171
|
-
/* @__PURE__ */ r("span", { className: `${e.mirrorStatus} ${
|
|
169
|
+
/* @__PURE__ */ r("span", { className: `${e.mirrorStatus} ${u}`, children: [
|
|
172
170
|
n.status === "pending" && "Pending",
|
|
173
|
-
n.status === "running" && (p > 0 ? `${p}% — ${
|
|
171
|
+
n.status === "running" && (p > 0 ? `${p}% — ${R}` : R),
|
|
174
172
|
n.status === "completed" && /* @__PURE__ */ r(C, { children: [
|
|
175
173
|
/* @__PURE__ */ t(d, { type: "check", size: 10 }),
|
|
176
174
|
" Completed"
|
|
@@ -179,25 +177,25 @@ const ye = ({ item: l, sourceId: k, sourceType: v, planId: c, type: o = "backup"
|
|
|
179
177
|
/* @__PURE__ */ t(d, { type: "error", size: 12 }),
|
|
180
178
|
" Failed"
|
|
181
179
|
] }),
|
|
182
|
-
n.status === "retrying" &&
|
|
180
|
+
n.status === "retrying" && R
|
|
183
181
|
] })
|
|
184
182
|
] }),
|
|
185
183
|
/* @__PURE__ */ t("div", { className: e.mirrorBar, children: /* @__PURE__ */ t(
|
|
186
184
|
"div",
|
|
187
185
|
{
|
|
188
|
-
className: `${e.mirrorBarFill} ${
|
|
186
|
+
className: `${e.mirrorBarFill} ${u}`,
|
|
189
187
|
style: {
|
|
190
188
|
width: n.status === "completed" || n.status === "failed" ? "100%" : p > 0 ? `${p}%` : void 0
|
|
191
189
|
}
|
|
192
190
|
}
|
|
193
191
|
) })
|
|
194
192
|
] })
|
|
195
|
-
] },
|
|
193
|
+
] }, a);
|
|
196
194
|
}) })
|
|
197
195
|
] })
|
|
198
196
|
] }, l.id);
|
|
199
197
|
};
|
|
200
198
|
export {
|
|
201
|
-
|
|
199
|
+
_e as default
|
|
202
200
|
};
|
|
203
201
|
//# sourceMappingURL=BackupProgress.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BackupProgress.js","sources":["../../../../src/components/Plan/BackupProgress/BackupProgress.tsx"],"sourcesContent":["import { useState } from 'react';\r\nimport { useQueryClient } from '@tanstack/react-query';\r\nimport { toast } from 'react-toastify';\r\nimport Icon from '../../common/Icon/Icon';\r\nimport { useCancelBackup, useGetBackupProgress } from '../../../services/backups';\r\nimport classes from './BackupProgress.module.scss';\r\nimport { formatBytes, formatDateTime, formatSeconds, timeAgo } from '../../../utils/helpers';\r\nimport {\r\n generateBackupProgressMessage,\r\n extractResticData,\r\n generateRestoreProgressMessage,\r\n generateMirrorProgressMessage,\r\n} from '../../../utils/progressHelpers';\r\nimport { Backup } from '../../../@types/backups';\r\nimport { RestoreSlim } from '../../../@types/restores';\r\nimport ActionModal from '../../common/ActionModal/ActionModal';\r\nimport { useCancelRestore, useGetRestoreProgress } from '../../../services/restores';\r\nimport BackupEvents from '../BackupEvents/BackupEvents';\r\nimport { ReplicationProgressData } from '../../../@types/backups';\r\n\r\ninterface BackupProgressProps {\r\n item: Backup | RestoreSlim;\r\n sourceId: string;\r\n sourceType: string;\r\n planId: string;\r\n type: 'backup' | 'restore';\r\n}\r\n\r\nconst BackupProgress = ({ item, sourceId, sourceType, planId, type = 'backup' }: BackupProgressProps) => {\r\n const [showCancelModal, setShowCancelModal] = useState(false);\r\n const [showProgressDetails, setShowProgressDetails] = useState(false);\r\n const queryClient = useQueryClient();\r\n const cancelRestoreMutation = useCancelRestore();\r\n const cancelBackupMutation = useCancelBackup();\r\n\r\n const { id, started } = item;\r\n const { data: progressData } =\r\n type === 'backup' ? useGetBackupProgress({ id, sourceId, sourceType, planId }) : useGetRestoreProgress({ id, sourceId, sourceType, planId });\r\n\r\n console.log('#### data :', progressData);\r\n\r\n const resticData = extractResticData(progressData);\r\n const progressMessage = type === 'backup' ? generateBackupProgressMessage(progressData) : generateRestoreProgressMessage(progressData);\r\n\r\n // Extract progress values from restic data or use defaults\r\n const {\r\n total_files_processed: total_files = resticData?.total_files || 0,\r\n files_done = 0,\r\n total_bytes_processed: total_bytes = resticData?.total_bytes_processed || resticData?.total_bytes || 0,\r\n bytes_done = 0,\r\n bytes_restored = 0,\r\n files_restored = 0,\r\n seconds_remaining = 0,\r\n percent_done = 0,\r\n } = resticData || {};\r\n\r\n let filesProcessed = files_done;\r\n let bytesProcessed = bytes_done;\r\n let totalBytes = total_bytes;\r\n let totalFiles = total_files;\r\n let progressPercent = total_bytes ? Math.round((bytes_done / total_bytes) * 100) : 0;\r\n\r\n if (type === 'restore') {\r\n progressPercent = Math.round(percent_done * 100);\r\n if (resticData?.total_bytes) {\r\n totalBytes = resticData.total_bytes;\r\n }\r\n if (bytes_restored) {\r\n bytesProcessed = bytes_restored;\r\n } else {\r\n if (resticData?.total_bytes) {\r\n bytesProcessed = Math.round(percent_done * resticData.total_bytes);\r\n }\r\n }\r\n if (files_restored) {\r\n filesProcessed = files_restored;\r\n } else {\r\n if (resticData?.total_files) {\r\n filesProcessed = Math.round(percent_done * resticData.total_files);\r\n }\r\n }\r\n }\r\n\r\n // For completed backups, show 100% if we have summary data\r\n if (resticData?.message_type === 'summary') {\r\n progressPercent = 100;\r\n filesProcessed = totalFiles;\r\n bytesProcessed = totalBytes;\r\n }\r\n\r\n const cancel = () => {\r\n console.log('cancel :', type, item);\r\n if (type === 'backup') {\r\n toast.promise(\r\n cancelBackupMutation.mutateAsync(\r\n { planId, backupId: item.id },\r\n {\r\n onSuccess: () => queryClient.invalidateQueries({ queryKey: ['plan', planId] }),\r\n },\r\n ),\r\n {\r\n pending: 'Sending Cancel Request...',\r\n success: 'Backup process Cancelled!',\r\n error: {\r\n render({ data }: any) {\r\n // When the promise reject, data will contains the error\r\n return `Failed to cancel backup process. ${data?.message || 'Unknown Error.'}`;\r\n },\r\n },\r\n },\r\n );\r\n } else {\r\n toast.promise(\r\n cancelRestoreMutation.mutateAsync(\r\n { planId, restoreId: item.id },\r\n {\r\n onSuccess: () => queryClient.invalidateQueries({ queryKey: ['plan', planId] }),\r\n },\r\n ),\r\n {\r\n pending: 'Sending Cancel Request...',\r\n success: 'Restore process Cancelled!',\r\n error: {\r\n render({ data }: any) {\r\n // When the promise reject, data will contains the error\r\n return `Failed to cancel restore process. ${data?.message || 'Unknown Error.'}`;\r\n },\r\n },\r\n },\r\n );\r\n }\r\n };\r\n\r\n return (\r\n <div key={item.id} className={classes.backup}>\r\n <div key={item.id} className={classes.backupProgress}>\r\n <div className={classes.backupIcon}>\r\n <Icon type=\"loading\" size={24} />\r\n </div>\r\n <div className={classes.backupLeft}>\r\n <div className={classes.backupId}>\r\n {type === 'restore' ? 'Restoring ' : ''}backup-{id}\r\n <span className={classes.backupTime} title={formatDateTime(started)}>\r\n <Icon type=\"clock\" size={12} /> Started {started ? timeAgo(new Date(started)) : 'a few seconds ago'}\r\n </span>\r\n {item.errorMsg && (\r\n <span className={classes.backupError}>\r\n <Icon type=\"error-circle-filled\" size={13} />{' '}\r\n <i data-tooltip-id=\"htmlToolTip\" data-tooltip-place=\"top\" data-tooltip-html={item.errorMsg}>\r\n <u>Error</u> Occurred.\r\n </i>{' '}\r\n Retrying...\r\n </span>\r\n )}\r\n </div>\r\n <div className={classes.backupStart}>\r\n <div>\r\n <span className={classes.progressMessage} onClick={() => setShowProgressDetails(true)}>\r\n {progressMessage}\r\n </span>\r\n {/* <Icon type=\"clock\" size={12} /> Started {started ? timeAgo(new Date(started)) : 'a few seconds ago'} */}\r\n </div>\r\n <button onClick={() => setShowCancelModal(true)} title={`Cancel ${type}`}>\r\n <Icon type=\"close\" size={12} /> Cancel\r\n </button>\r\n </div>\r\n </div>\r\n <div className={classes.backupRight}>\r\n <div className={classes.ProgressStats}>\r\n <div className={classes.ProgressStatsLeft}>\r\n <span>\r\n {filesProcessed} / {totalFiles} Files\r\n </span>\r\n <i></i>\r\n <span>\r\n {formatBytes(bytesProcessed)} / {formatBytes(totalBytes)}\r\n </span>\r\n </div>\r\n <div className={classes.ProgressStatsRight}>{type !== 'restore' && <>Remaining: {formatSeconds(seconds_remaining)}</>}</div>\r\n </div>\r\n <div className={classes.progressBar}>\r\n <div\r\n className={`${classes.progressBarFill} ${progressPercent > 3 ? classes.progressBarFilled : ''}`}\r\n style={{ width: progressPercent + '%' }}\r\n >\r\n <span>{progressPercent}%</span>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n {showCancelModal && (\r\n <ActionModal\r\n title={`Cancel ${type}`}\r\n message={<>{`Are you sure you want to cancel the ${type} process?`}</>}\r\n closeModal={() => setShowCancelModal(false)}\r\n width=\"400px\"\r\n primaryAction={{\r\n title: `Yes, Cancel ${type}`,\r\n type: 'danger',\r\n isPending: type === 'restore' ? cancelRestoreMutation.isPending : cancelBackupMutation.isPending,\r\n action: () => cancel(),\r\n }}\r\n />\r\n )}\r\n {showProgressDetails && (\r\n <BackupEvents\r\n id={id}\r\n type={type}\r\n planId={planId}\r\n sourceId={sourceId}\r\n sourceType={sourceType}\r\n progressData={progressData}\r\n inProgress={true}\r\n close={() => setShowProgressDetails(false)}\r\n />\r\n )}\r\n </div>\r\n {/* Mirrors Progress */}\r\n {progressData?.mirrors && Object.keys(progressData.mirrors).length > 0 && (\r\n <div className={classes.mirrorsSection}>\r\n <div className={classes.mirrorsTitle}>Replicating</div>\r\n <div className={classes.mirrorsList}>\r\n {Object.entries(progressData.mirrors as Record<string, ReplicationProgressData>).map(([storageId, mirror]) => {\r\n const mirrorResticData = mirror.events\r\n ?.slice()\r\n .reverse()\r\n .find((e: any) => e.resticData)?.resticData;\r\n const mirrorPercent = mirrorResticData?.percent_done ? Math.round(mirrorResticData.percent_done * 100) : 0;\r\n const mirrorMessage = generateMirrorProgressMessage(mirror);\r\n\r\n let mirrorStatusClass = classes.mirrorPending;\r\n if (mirror.status === 'running')\r\n mirrorStatusClass = mirrorPercent > 0 ? classes.mirrorRunning : classes.mirrorRunningIndeterminate;\r\n if (mirror.status === 'completed') mirrorStatusClass = classes.mirrorCompleted;\r\n if (mirror.status === 'failed') mirrorStatusClass = classes.mirrorFailed;\r\n if (mirror.status === 'retrying') mirrorStatusClass = classes.mirrorRunningIndeterminate;\r\n\r\n return (\r\n <div key={storageId} className={classes.mirrorItem}>\r\n <div className={classes.mirrorStorageIcon}>\r\n {(mirror.status === 'running' || mirror.status === 'pending' || mirror.status === 'retrying') && (\r\n <Icon type=\"loading\" size={12} />\r\n )}\r\n <img src={`/providers/${mirror.storageType}.png`} />\r\n </div>\r\n <div className={classes.mirrorProgress}>\r\n <div className={classes.mirrorInfo}>\r\n <span className={classes.mirrorName}>{mirror.storageName}</span>\r\n <span className={`${classes.mirrorStatus} ${mirrorStatusClass}`}>\r\n {mirror.status === 'pending' && 'Pending'}\r\n {mirror.status === 'running' && (mirrorPercent > 0 ? `${mirrorPercent}% — ${mirrorMessage}` : mirrorMessage)}\r\n {mirror.status === 'completed' && (\r\n <>\r\n <Icon type=\"check\" size={10} /> Completed\r\n </>\r\n )}\r\n {mirror.status === 'failed' && (\r\n <span data-tooltip-id=\"htmlToolTip\" data-tooltip-html={mirror.error || 'Replication failed'}>\r\n <Icon type=\"error\" size={12} /> Failed\r\n </span>\r\n )}\r\n {mirror.status === 'retrying' && mirrorMessage}\r\n </span>\r\n </div>\r\n <div className={classes.mirrorBar}>\r\n <div\r\n className={`${classes.mirrorBarFill} ${mirrorStatusClass}`}\r\n style={{\r\n width:\r\n mirror.status === 'completed'\r\n ? '100%'\r\n : mirror.status === 'failed'\r\n ? '100%'\r\n : mirrorPercent > 0\r\n ? `${mirrorPercent}%`\r\n : undefined,\r\n }}\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n })}\r\n </div>\r\n </div>\r\n )}\r\n </div>\r\n );\r\n};\r\nexport default BackupProgress;\r\n"],"names":["BackupProgress","item","sourceId","sourceType","planId","type","showCancelModal","setShowCancelModal","useState","showProgressDetails","setShowProgressDetails","queryClient","useQueryClient","cancelRestoreMutation","useCancelRestore","cancelBackupMutation","useCancelBackup","id","started","progressData","useGetBackupProgress","useGetRestoreProgress","resticData","extractResticData","progressMessage","generateBackupProgressMessage","generateRestoreProgressMessage","total_files","files_done","total_bytes","bytes_done","bytes_restored","files_restored","seconds_remaining","percent_done","filesProcessed","bytesProcessed","totalBytes","totalFiles","progressPercent","cancel","toast","data","jsxs","classes","jsx","Icon","formatDateTime","timeAgo","formatBytes","Fragment","formatSeconds","ActionModal","BackupEvents","storageId","mirror","mirrorResticData","_b","_a","e","mirrorPercent","mirrorMessage","generateMirrorProgressMessage","mirrorStatusClass"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"BackupProgress.js","sources":["../../../../src/components/Plan/BackupProgress/BackupProgress.tsx"],"sourcesContent":["import { useState } from 'react';\r\nimport { useQueryClient } from '@tanstack/react-query';\r\nimport { toast } from 'react-toastify';\r\nimport Icon from '../../common/Icon/Icon';\r\nimport { useCancelBackup, useGetBackupProgress } from '../../../services/backups';\r\nimport classes from './BackupProgress.module.scss';\r\nimport { formatBytes, formatDateTime, formatSeconds, timeAgo } from '../../../utils/helpers';\r\nimport {\r\n generateBackupProgressMessage,\r\n extractResticData,\r\n generateRestoreProgressMessage,\r\n generateMirrorProgressMessage,\r\n} from '../../../utils/progressHelpers';\r\nimport { Backup } from '../../../@types/backups';\r\nimport { RestoreSlim } from '../../../@types/restores';\r\nimport ActionModal from '../../common/ActionModal/ActionModal';\r\nimport { useCancelRestore, useGetRestoreProgress } from '../../../services/restores';\r\nimport BackupEvents from '../BackupEvents/BackupEvents';\r\nimport { ReplicationProgressData } from '../../../@types/backups';\r\n\r\ninterface BackupProgressProps {\r\n item: Backup | RestoreSlim;\r\n sourceId: string;\r\n sourceType: string;\r\n planId: string;\r\n type: 'backup' | 'restore';\r\n}\r\n\r\nconst BackupProgress = ({ item, sourceId, sourceType, planId, type = 'backup' }: BackupProgressProps) => {\r\n const [showCancelModal, setShowCancelModal] = useState(false);\r\n const [showProgressDetails, setShowProgressDetails] = useState(false);\r\n const queryClient = useQueryClient();\r\n const cancelRestoreMutation = useCancelRestore();\r\n const cancelBackupMutation = useCancelBackup();\r\n\r\n const { id, started } = item;\r\n const { data: progressData } =\r\n type === 'backup' ? useGetBackupProgress({ id, sourceId, sourceType, planId }) : useGetRestoreProgress({ id, sourceId, sourceType, planId });\r\n\r\n const resticData = extractResticData(progressData);\r\n const progressMessage = type === 'backup' ? generateBackupProgressMessage(progressData) : generateRestoreProgressMessage(progressData);\r\n\r\n // Check if DryRun progress tracking phase\r\n const actualBackupStarted = progressData?.events.find((e: any) => e.action === 'BACKUP_OPERATION_START' && e.resticData);\r\n const isDryRun = type === 'backup' && !actualBackupStarted;\r\n\r\n // Extract progress values from restic data or use defaults\r\n const {\r\n total_files_processed: total_files = resticData?.total_files || 0,\r\n files_done = 0,\r\n total_bytes_processed: total_bytes = resticData?.total_bytes_processed || resticData?.total_bytes || 0,\r\n bytes_done = 0,\r\n bytes_restored = 0,\r\n files_restored = 0,\r\n seconds_remaining = 0,\r\n percent_done = 0,\r\n } = resticData || {};\r\n\r\n let filesProcessed = files_done;\r\n let bytesProcessed = bytes_done;\r\n let totalBytes = total_bytes;\r\n let totalFiles = total_files;\r\n let progressPercent = total_bytes ? Math.round((bytes_done / total_bytes) * 100) : 0;\r\n\r\n if (type === 'restore') {\r\n progressPercent = Math.round(percent_done * 100);\r\n if (resticData?.total_bytes) {\r\n totalBytes = resticData.total_bytes;\r\n }\r\n if (bytes_restored) {\r\n bytesProcessed = bytes_restored;\r\n } else {\r\n if (resticData?.total_bytes) {\r\n bytesProcessed = Math.round(percent_done * resticData.total_bytes);\r\n }\r\n }\r\n if (files_restored) {\r\n filesProcessed = files_restored;\r\n } else {\r\n if (resticData?.total_files) {\r\n filesProcessed = Math.round(percent_done * resticData.total_files);\r\n }\r\n }\r\n }\r\n\r\n // For completed backups, show 100% if we have summary data\r\n if (resticData?.message_type === 'summary') {\r\n progressPercent = 100;\r\n filesProcessed = totalFiles;\r\n bytesProcessed = totalBytes;\r\n }\r\n\r\n const cancel = () => {\r\n console.log('cancel :', type, item);\r\n if (type === 'backup') {\r\n toast.promise(\r\n cancelBackupMutation.mutateAsync(\r\n { planId, backupId: item.id },\r\n {\r\n onSuccess: () => queryClient.invalidateQueries({ queryKey: ['plan', planId] }),\r\n },\r\n ),\r\n {\r\n pending: 'Sending Cancel Request...',\r\n success: 'Backup process Cancelled!',\r\n error: {\r\n render({ data }: any) {\r\n // When the promise reject, data will contains the error\r\n return `Failed to cancel backup process. ${data?.message || 'Unknown Error.'}`;\r\n },\r\n },\r\n },\r\n );\r\n } else {\r\n toast.promise(\r\n cancelRestoreMutation.mutateAsync(\r\n { planId, restoreId: item.id },\r\n {\r\n onSuccess: () => queryClient.invalidateQueries({ queryKey: ['plan', planId] }),\r\n },\r\n ),\r\n {\r\n pending: 'Sending Cancel Request...',\r\n success: 'Restore process Cancelled!',\r\n error: {\r\n render({ data }: any) {\r\n // When the promise reject, data will contains the error\r\n return `Failed to cancel restore process. ${data?.message || 'Unknown Error.'}`;\r\n },\r\n },\r\n },\r\n );\r\n }\r\n };\r\n\r\n return (\r\n <div key={item.id} className={classes.backup}>\r\n <div key={item.id} className={classes.backupProgress}>\r\n <div className={classes.backupIcon}>\r\n <Icon type=\"loading\" size={24} />\r\n </div>\r\n <div className={classes.backupLeft}>\r\n <div className={classes.backupId}>\r\n {type === 'restore' ? 'Restoring ' : ''}backup-{id}\r\n <span className={classes.backupTime} title={formatDateTime(started)}>\r\n <Icon type=\"clock\" size={12} /> Started {started ? timeAgo(new Date(started)) : 'a few seconds ago'}\r\n </span>\r\n {item.errorMsg && (\r\n <span className={classes.backupError}>\r\n <Icon type=\"error-circle-filled\" size={13} />{' '}\r\n <i data-tooltip-id=\"htmlToolTip\" data-tooltip-place=\"top\" data-tooltip-html={item.errorMsg}>\r\n <u>Error</u> Occurred.\r\n </i>{' '}\r\n Retrying...\r\n </span>\r\n )}\r\n </div>\r\n <div className={classes.backupStart}>\r\n <div>\r\n <span className={classes.progressMessage} onClick={() => setShowProgressDetails(true)}>\r\n {progressMessage}\r\n </span>\r\n {/* <Icon type=\"clock\" size={12} /> Started {started ? timeAgo(new Date(started)) : 'a few seconds ago'} */}\r\n </div>\r\n <button onClick={() => setShowCancelModal(true)} title={`Cancel ${type}`}>\r\n <Icon type=\"close\" size={12} /> Cancel\r\n </button>\r\n </div>\r\n </div>\r\n <div className={classes.backupRight}>\r\n <div className={classes.ProgressStats}>\r\n <div className={classes.ProgressStatsLeft}>\r\n <span>\r\n {filesProcessed} / {totalFiles} Files\r\n </span>\r\n <i></i>\r\n <span>\r\n {formatBytes(bytesProcessed)} / {formatBytes(totalBytes)}\r\n </span>\r\n </div>\r\n <div className={classes.ProgressStatsRight}>{type !== 'restore' && <>Remaining: {formatSeconds(seconds_remaining)}</>}</div>\r\n </div>\r\n <div className={classes.progressBar}>\r\n <div\r\n className={`${classes.progressBarFill} ${progressPercent > 3 ? classes.progressBarFilled : ''} ${isDryRun ? classes.progressBarDryRun : ''}`}\r\n style={{ width: progressPercent + '%' }}\r\n >\r\n <span>{progressPercent}%</span>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n {showCancelModal && (\r\n <ActionModal\r\n title={`Cancel ${type}`}\r\n message={<>{`Are you sure you want to cancel the ${type} process?`}</>}\r\n closeModal={() => setShowCancelModal(false)}\r\n width=\"400px\"\r\n primaryAction={{\r\n title: `Yes, Cancel ${type}`,\r\n type: 'danger',\r\n isPending: type === 'restore' ? cancelRestoreMutation.isPending : cancelBackupMutation.isPending,\r\n action: () => cancel(),\r\n }}\r\n />\r\n )}\r\n {showProgressDetails && (\r\n <BackupEvents\r\n id={id}\r\n type={type}\r\n planId={planId}\r\n sourceId={sourceId}\r\n sourceType={sourceType}\r\n progressData={progressData}\r\n inProgress={true}\r\n close={() => setShowProgressDetails(false)}\r\n />\r\n )}\r\n </div>\r\n {/* Mirrors Progress */}\r\n {progressData?.mirrors && Object.keys(progressData.mirrors).length > 0 && (\r\n <div className={classes.mirrorsSection}>\r\n <div className={classes.mirrorsTitle}>Replicating</div>\r\n <div className={classes.mirrorsList}>\r\n {Object.entries(progressData.mirrors as Record<string, ReplicationProgressData>).map(([storageId, mirror]) => {\r\n const mirrorResticData = mirror.events\r\n ?.slice()\r\n .reverse()\r\n .find((e: any) => e.resticData)?.resticData;\r\n const mirrorPercent = mirrorResticData?.percent_done ? Math.round(mirrorResticData.percent_done * 100) : 0;\r\n const mirrorMessage = generateMirrorProgressMessage(mirror);\r\n\r\n let mirrorStatusClass = classes.mirrorPending;\r\n if (mirror.status === 'running')\r\n mirrorStatusClass = mirrorPercent > 0 ? classes.mirrorRunning : classes.mirrorRunningIndeterminate;\r\n if (mirror.status === 'completed') mirrorStatusClass = classes.mirrorCompleted;\r\n if (mirror.status === 'failed') mirrorStatusClass = classes.mirrorFailed;\r\n if (mirror.status === 'retrying') mirrorStatusClass = classes.mirrorRunningIndeterminate;\r\n\r\n return (\r\n <div key={storageId} className={classes.mirrorItem}>\r\n <div className={classes.mirrorStorageIcon}>\r\n {(mirror.status === 'running' || mirror.status === 'pending' || mirror.status === 'retrying') && (\r\n <Icon type=\"loading\" size={12} />\r\n )}\r\n <img src={`/providers/${mirror.storageType}.png`} />\r\n </div>\r\n <div className={classes.mirrorProgress}>\r\n <div className={classes.mirrorInfo}>\r\n <span className={classes.mirrorName}>{mirror.storageName}</span>\r\n <span className={`${classes.mirrorStatus} ${mirrorStatusClass}`}>\r\n {mirror.status === 'pending' && 'Pending'}\r\n {mirror.status === 'running' && (mirrorPercent > 0 ? `${mirrorPercent}% — ${mirrorMessage}` : mirrorMessage)}\r\n {mirror.status === 'completed' && (\r\n <>\r\n <Icon type=\"check\" size={10} /> Completed\r\n </>\r\n )}\r\n {mirror.status === 'failed' && (\r\n <span data-tooltip-id=\"htmlToolTip\" data-tooltip-html={mirror.error || 'Replication failed'}>\r\n <Icon type=\"error\" size={12} /> Failed\r\n </span>\r\n )}\r\n {mirror.status === 'retrying' && mirrorMessage}\r\n </span>\r\n </div>\r\n <div className={classes.mirrorBar}>\r\n <div\r\n className={`${classes.mirrorBarFill} ${mirrorStatusClass}`}\r\n style={{\r\n width:\r\n mirror.status === 'completed'\r\n ? '100%'\r\n : mirror.status === 'failed'\r\n ? '100%'\r\n : mirrorPercent > 0\r\n ? `${mirrorPercent}%`\r\n : undefined,\r\n }}\r\n />\r\n </div>\r\n </div>\r\n </div>\r\n );\r\n })}\r\n </div>\r\n </div>\r\n )}\r\n </div>\r\n );\r\n};\r\nexport default BackupProgress;\r\n"],"names":["BackupProgress","item","sourceId","sourceType","planId","type","showCancelModal","setShowCancelModal","useState","showProgressDetails","setShowProgressDetails","queryClient","useQueryClient","cancelRestoreMutation","useCancelRestore","cancelBackupMutation","useCancelBackup","id","started","progressData","useGetBackupProgress","useGetRestoreProgress","resticData","extractResticData","progressMessage","generateBackupProgressMessage","generateRestoreProgressMessage","actualBackupStarted","e","isDryRun","total_files","files_done","total_bytes","bytes_done","bytes_restored","files_restored","seconds_remaining","percent_done","filesProcessed","bytesProcessed","totalBytes","totalFiles","progressPercent","cancel","toast","data","jsxs","classes","jsx","Icon","formatDateTime","timeAgo","formatBytes","Fragment","formatSeconds","ActionModal","BackupEvents","storageId","mirror","mirrorResticData","_b","_a","mirrorPercent","mirrorMessage","generateMirrorProgressMessage","mirrorStatusClass"],"mappings":"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"}
|
|
@@ -1,66 +1,68 @@
|
|
|
1
|
-
const r = "
|
|
1
|
+
const r = "_backup_xS6ZS", o = "_backupProgress_NIF8H", s = "_backupIcon_1VCof", t = "_backupLeft_T8u86", i = "_backupId_G1qV9", e = "_backupTime_axKgJ", a = "_backupError_Xyoex", n = "_backupStart_ND7RT", c = "_progressMessage_drmBQ", m = "_backupRight_iTzHX", _ = "_ProgressStats_WS4AM", p = "_ProgressStatsLeft_aAdVE", g = "_progressBar_9H5Cx", u = "_progressBarFill_okbGN", l = "_progressBarFilled_XYmUx", b = "_progressBarDryRun_XpA0M", k = "_mirrorsSection_shaGt", d = "_mirrorsTitle_LZXPU", I = "_mirrorsList_tnwP8", S = "_mirrorItem_RxqoD", B = "_mirrorProgress_xcaAG", P = "_mirrorStorageIcon_6asKY", F = "_mirrorInfo_F3BKE", R = "_mirrorName_3j8ZY", f = "_mirrorStatus_U7ORY", L = "_mirrorCompleted_dw4av", T = "_mirrorFailed_CdoUN", N = "_mirrorBar_oQFsQ", x = "_mirrorBarFill_ItiQz", C = "_mirrorRunning_G7IVN", D = "_mirrorPending_5T3nu", E = "_mirrorRunningIndeterminate_ONi6D", G = {
|
|
2
2
|
backup: r,
|
|
3
3
|
backupProgress: o,
|
|
4
4
|
backupIcon: s,
|
|
5
5
|
backupLeft: t,
|
|
6
6
|
backupId: i,
|
|
7
7
|
backupTime: e,
|
|
8
|
-
backupError:
|
|
9
|
-
backupStart:
|
|
8
|
+
backupError: a,
|
|
9
|
+
backupStart: n,
|
|
10
10
|
progressMessage: c,
|
|
11
11
|
backupRight: m,
|
|
12
12
|
ProgressStats: _,
|
|
13
|
-
ProgressStatsLeft:
|
|
14
|
-
progressBar:
|
|
13
|
+
ProgressStatsLeft: p,
|
|
14
|
+
progressBar: g,
|
|
15
15
|
progressBarFill: u,
|
|
16
16
|
progressBarFilled: l,
|
|
17
|
+
progressBarDryRun: b,
|
|
17
18
|
mirrorsSection: k,
|
|
18
|
-
mirrorsTitle:
|
|
19
|
-
mirrorsList:
|
|
20
|
-
mirrorItem:
|
|
21
|
-
mirrorProgress:
|
|
22
|
-
mirrorStorageIcon:
|
|
23
|
-
mirrorInfo:
|
|
24
|
-
mirrorName:
|
|
19
|
+
mirrorsTitle: d,
|
|
20
|
+
mirrorsList: I,
|
|
21
|
+
mirrorItem: S,
|
|
22
|
+
mirrorProgress: B,
|
|
23
|
+
mirrorStorageIcon: P,
|
|
24
|
+
mirrorInfo: F,
|
|
25
|
+
mirrorName: R,
|
|
25
26
|
mirrorStatus: f,
|
|
26
|
-
mirrorCompleted:
|
|
27
|
-
mirrorFailed:
|
|
28
|
-
mirrorBar:
|
|
29
|
-
mirrorBarFill:
|
|
30
|
-
mirrorRunning:
|
|
31
|
-
mirrorPending:
|
|
32
|
-
mirrorRunningIndeterminate:
|
|
27
|
+
mirrorCompleted: L,
|
|
28
|
+
mirrorFailed: T,
|
|
29
|
+
mirrorBar: N,
|
|
30
|
+
mirrorBarFill: x,
|
|
31
|
+
mirrorRunning: C,
|
|
32
|
+
mirrorPending: D,
|
|
33
|
+
mirrorRunningIndeterminate: E
|
|
33
34
|
};
|
|
34
35
|
export {
|
|
35
36
|
_ as ProgressStats,
|
|
36
|
-
|
|
37
|
+
p as ProgressStatsLeft,
|
|
37
38
|
r as backup,
|
|
38
|
-
|
|
39
|
+
a as backupError,
|
|
39
40
|
s as backupIcon,
|
|
40
41
|
i as backupId,
|
|
41
42
|
t as backupLeft,
|
|
42
43
|
o as backupProgress,
|
|
43
44
|
m as backupRight,
|
|
44
|
-
|
|
45
|
+
n as backupStart,
|
|
45
46
|
e as backupTime,
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
47
|
+
G as default,
|
|
48
|
+
N as mirrorBar,
|
|
49
|
+
x as mirrorBarFill,
|
|
50
|
+
L as mirrorCompleted,
|
|
51
|
+
T as mirrorFailed,
|
|
52
|
+
F as mirrorInfo,
|
|
53
|
+
S as mirrorItem,
|
|
54
|
+
R as mirrorName,
|
|
55
|
+
D as mirrorPending,
|
|
56
|
+
B as mirrorProgress,
|
|
57
|
+
C as mirrorRunning,
|
|
58
|
+
E as mirrorRunningIndeterminate,
|
|
58
59
|
f as mirrorStatus,
|
|
59
|
-
|
|
60
|
-
|
|
60
|
+
P as mirrorStorageIcon,
|
|
61
|
+
I as mirrorsList,
|
|
61
62
|
k as mirrorsSection,
|
|
62
|
-
|
|
63
|
-
|
|
63
|
+
d as mirrorsTitle,
|
|
64
|
+
g as progressBar,
|
|
65
|
+
b as progressBarDryRun,
|
|
64
66
|
u as progressBarFill,
|
|
65
67
|
l as progressBarFilled,
|
|
66
68
|
c as progressMessage
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"BackupProgress.module.scss.js","sources":[],"sourcesContent":[],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"BackupProgress.module.scss.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PlanScriptsSettings.d.ts","sourceRoot":"","sources":["../../../../src/components/Plan/PlanSettings/PlanScriptsSettings.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,
|
|
1
|
+
{"version":3,"file":"PlanScriptsSettings.d.ts","sourceRoot":"","sources":["../../../../src/components/Plan/PlanSettings/PlanScriptsSettings.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAc,MAAM,uBAAuB,CAAC;AAMpE,UAAU,wBAAwB;IAC/B,QAAQ,EAAE,eAAe,CAAC,UAAU,CAAC,CAAC,SAAS,CAAC,CAAC;IACjD,QAAQ,EAAE,CAAC,QAAQ,EAAE,eAAe,CAAC,UAAU,CAAC,CAAC,SAAS,CAAC,KAAK,IAAI,CAAC;IACrE,QAAQ,CAAC,EAAE,MAAM,CAAC;CACpB;AA2BD,QAAA,MAAM,mBAAmB,GAAI,mCAU1B,wBAAwB,4CA0N1B,CAAC;AAEF,eAAe,mBAAmB,CAAC"}
|