2020-07-11 06:09:37 +00:00
|
|
|
import { action, Action } from 'easy-peasy';
|
2020-04-10 20:57:24 +00:00
|
|
|
import { cleanDirectoryPath } from '@/helpers';
|
2019-08-04 21:58:31 +00:00
|
|
|
|
2022-07-24 21:18:32 +00:00
|
|
|
export interface FileUpload {
|
|
|
|
name: string;
|
|
|
|
loaded: number;
|
|
|
|
readonly total: number;
|
|
|
|
}
|
|
|
|
|
2019-08-04 21:58:31 +00:00
|
|
|
export interface ServerFileStore {
|
|
|
|
directory: string;
|
2020-07-11 23:47:13 +00:00
|
|
|
selectedFiles: string[];
|
2022-07-24 21:18:32 +00:00
|
|
|
uploads: FileUpload[];
|
2020-07-11 23:47:13 +00:00
|
|
|
|
2019-08-04 21:58:31 +00:00
|
|
|
setDirectory: Action<ServerFileStore, string>;
|
2020-07-11 23:47:13 +00:00
|
|
|
setSelectedFiles: Action<ServerFileStore, string[]>;
|
2020-07-11 23:57:30 +00:00
|
|
|
appendSelectedFile: Action<ServerFileStore, string>;
|
|
|
|
removeSelectedFile: Action<ServerFileStore, string>;
|
2022-07-24 21:18:32 +00:00
|
|
|
|
2022-07-24 22:50:47 +00:00
|
|
|
clearFileUploads: Action<ServerFileStore>;
|
2022-07-24 21:18:32 +00:00
|
|
|
appendFileUpload: Action<ServerFileStore, FileUpload>;
|
|
|
|
removeFileUpload: Action<ServerFileStore, string>;
|
2019-08-04 21:58:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
const files: ServerFileStore = {
|
2019-08-06 04:52:48 +00:00
|
|
|
directory: '/',
|
2020-07-11 23:47:13 +00:00
|
|
|
selectedFiles: [],
|
2022-07-24 21:18:32 +00:00
|
|
|
uploads: [],
|
2019-08-04 21:58:31 +00:00
|
|
|
|
|
|
|
setDirectory: action((state, payload) => {
|
2020-06-13 16:49:32 +00:00
|
|
|
state.directory = cleanDirectoryPath(payload);
|
2019-08-04 21:58:31 +00:00
|
|
|
}),
|
2020-07-11 23:47:13 +00:00
|
|
|
|
|
|
|
setSelectedFiles: action((state, payload) => {
|
|
|
|
state.selectedFiles = payload;
|
|
|
|
}),
|
2020-07-11 23:57:30 +00:00
|
|
|
|
|
|
|
appendSelectedFile: action((state, payload) => {
|
2022-06-26 19:13:52 +00:00
|
|
|
state.selectedFiles = state.selectedFiles.filter((f) => f !== payload).concat(payload);
|
2020-07-11 23:57:30 +00:00
|
|
|
}),
|
|
|
|
|
|
|
|
removeSelectedFile: action((state, payload) => {
|
2022-06-26 19:13:52 +00:00
|
|
|
state.selectedFiles = state.selectedFiles.filter((f) => f !== payload);
|
2020-07-11 23:57:30 +00:00
|
|
|
}),
|
2022-07-24 21:18:32 +00:00
|
|
|
|
2022-07-24 22:50:47 +00:00
|
|
|
clearFileUploads: action((state) => {
|
|
|
|
state.uploads = [];
|
|
|
|
}),
|
|
|
|
|
2022-07-24 21:18:32 +00:00
|
|
|
appendFileUpload: action((state, payload) => {
|
2022-07-24 22:50:47 +00:00
|
|
|
if (!state.uploads.some(({ name }) => name === payload.name)) {
|
|
|
|
state.uploads = [...state.uploads, payload];
|
|
|
|
} else {
|
|
|
|
state.uploads = state.uploads.map((file) => (file.name === payload.name ? payload : file));
|
|
|
|
}
|
2022-07-24 21:18:32 +00:00
|
|
|
}),
|
|
|
|
|
|
|
|
removeFileUpload: action((state, payload) => {
|
2022-07-24 22:50:47 +00:00
|
|
|
state.uploads = state.uploads.filter(({ name }) => name !== payload);
|
2022-07-24 21:18:32 +00:00
|
|
|
}),
|
2019-08-04 21:58:31 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
export default files;
|