2022-09-16 17:18:15 +00:00
|
|
|
import { createSlice } from '@reduxjs/toolkit';
|
|
|
|
import type { PayloadAction } from '@reduxjs/toolkit';
|
|
|
|
import { ExpandedIndex } from '@chakra-ui/react';
|
2022-09-26 01:50:47 +00:00
|
|
|
import * as InvokeAI from '../../app/invokeai';
|
2022-09-16 17:18:15 +00:00
|
|
|
|
2022-09-18 07:33:09 +00:00
|
|
|
export type LogLevel = 'info' | 'warning' | 'error';
|
|
|
|
|
2022-09-16 17:18:15 +00:00
|
|
|
export interface LogEntry {
|
|
|
|
timestamp: string;
|
2022-09-18 07:33:09 +00:00
|
|
|
level: LogLevel;
|
2022-09-16 17:18:15 +00:00
|
|
|
message: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
export interface Log {
|
|
|
|
[index: number]: LogEntry;
|
|
|
|
}
|
|
|
|
|
2022-09-26 01:50:47 +00:00
|
|
|
export interface SystemState
|
|
|
|
extends InvokeAI.SystemStatus,
|
|
|
|
InvokeAI.SystemConfig {
|
2022-09-18 07:33:09 +00:00
|
|
|
shouldDisplayInProgress: boolean;
|
2022-11-01 10:17:43 +00:00
|
|
|
shouldDisplayInProgressLatents: boolean;
|
2022-09-16 17:18:15 +00:00
|
|
|
log: Array<LogEntry>;
|
|
|
|
shouldShowLogViewer: boolean;
|
|
|
|
isGFPGANAvailable: boolean;
|
|
|
|
isESRGANAvailable: boolean;
|
|
|
|
isConnected: boolean;
|
|
|
|
socketId: string;
|
|
|
|
shouldConfirmOnDelete: boolean;
|
|
|
|
openAccordions: ExpandedIndex;
|
2022-09-18 07:33:09 +00:00
|
|
|
currentStep: number;
|
|
|
|
totalSteps: number;
|
|
|
|
currentIteration: number;
|
|
|
|
totalIterations: number;
|
|
|
|
currentStatus: string;
|
|
|
|
currentStatusHasSteps: boolean;
|
2022-09-23 13:09:48 +00:00
|
|
|
shouldDisplayGuides: boolean;
|
2022-10-03 16:15:26 +00:00
|
|
|
wasErrorSeen: boolean;
|
2022-10-28 07:50:47 +00:00
|
|
|
isCancelable: boolean;
|
2022-09-16 17:18:15 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
const initialSystemState = {
|
|
|
|
isConnected: false,
|
|
|
|
isProcessing: false,
|
|
|
|
log: [],
|
|
|
|
shouldShowLogViewer: false,
|
|
|
|
shouldDisplayInProgress: false,
|
2022-11-01 10:17:43 +00:00
|
|
|
shouldDisplayInProgressLatents: false,
|
2022-09-23 13:09:48 +00:00
|
|
|
shouldDisplayGuides: true,
|
2022-09-16 17:18:15 +00:00
|
|
|
isGFPGANAvailable: true,
|
|
|
|
isESRGANAvailable: true,
|
|
|
|
socketId: '',
|
|
|
|
shouldConfirmOnDelete: true,
|
|
|
|
openAccordions: [0],
|
2022-09-18 07:33:09 +00:00
|
|
|
currentStep: 0,
|
|
|
|
totalSteps: 0,
|
|
|
|
currentIteration: 0,
|
|
|
|
totalIterations: 0,
|
2022-09-26 01:50:47 +00:00
|
|
|
currentStatus: 'Disconnected',
|
2022-09-18 07:33:09 +00:00
|
|
|
currentStatusHasSteps: false,
|
2022-09-20 13:17:31 +00:00
|
|
|
model: '',
|
|
|
|
model_id: '',
|
|
|
|
model_hash: '',
|
|
|
|
app_id: '',
|
|
|
|
app_version: '',
|
2022-10-28 07:50:47 +00:00
|
|
|
model_list: {},
|
2022-10-03 16:15:26 +00:00
|
|
|
hasError: false,
|
|
|
|
wasErrorSeen: true,
|
2022-10-28 07:50:47 +00:00
|
|
|
isCancelable: true,
|
2022-09-16 17:18:15 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
const initialState: SystemState = initialSystemState;
|
|
|
|
|
|
|
|
export const systemSlice = createSlice({
|
|
|
|
name: 'system',
|
|
|
|
initialState,
|
|
|
|
reducers: {
|
|
|
|
setShouldDisplayInProgress: (state, action: PayloadAction<boolean>) => {
|
|
|
|
state.shouldDisplayInProgress = action.payload;
|
|
|
|
},
|
2022-11-01 10:17:43 +00:00
|
|
|
setShouldDisplayInProgressLatents: (state, action: PayloadAction<boolean>) => {
|
|
|
|
state.shouldDisplayInProgressLatents = action.payload;
|
|
|
|
},
|
2022-09-16 17:18:15 +00:00
|
|
|
setIsProcessing: (state, action: PayloadAction<boolean>) => {
|
|
|
|
state.isProcessing = action.payload;
|
|
|
|
},
|
2022-09-18 07:33:09 +00:00
|
|
|
setCurrentStatus: (state, action: PayloadAction<string>) => {
|
|
|
|
state.currentStatus = action.payload;
|
|
|
|
},
|
2022-09-20 13:17:31 +00:00
|
|
|
setSystemStatus: (state, action: PayloadAction<InvokeAI.SystemStatus>) => {
|
2022-10-03 16:15:26 +00:00
|
|
|
return { ...state, ...action.payload };
|
|
|
|
},
|
|
|
|
errorOccurred: (state) => {
|
|
|
|
state.hasError = true;
|
|
|
|
state.isProcessing = false;
|
2022-10-28 17:44:03 +00:00
|
|
|
state.isCancelable = true;
|
2022-10-03 16:15:26 +00:00
|
|
|
state.currentStep = 0;
|
|
|
|
state.totalSteps = 0;
|
|
|
|
state.currentIteration = 0;
|
|
|
|
state.totalIterations = 0;
|
|
|
|
state.currentStatusHasSteps = false;
|
2022-10-27 04:24:00 +00:00
|
|
|
state.currentStatus = 'Error';
|
2022-10-03 16:15:26 +00:00
|
|
|
state.wasErrorSeen = false;
|
|
|
|
},
|
|
|
|
errorSeen: (state) => {
|
|
|
|
state.hasError = false;
|
|
|
|
state.wasErrorSeen = true;
|
|
|
|
state.currentStatus = state.isConnected ? 'Connected' : 'Disconnected';
|
2022-09-16 17:18:15 +00:00
|
|
|
},
|
2022-09-18 07:33:09 +00:00
|
|
|
addLogEntry: (
|
|
|
|
state,
|
|
|
|
action: PayloadAction<{
|
|
|
|
timestamp: string;
|
|
|
|
message: string;
|
|
|
|
level?: LogLevel;
|
|
|
|
}>
|
|
|
|
) => {
|
|
|
|
const { timestamp, message, level } = action.payload;
|
|
|
|
const logLevel = level || 'info';
|
|
|
|
|
2022-09-16 17:18:15 +00:00
|
|
|
const entry: LogEntry = {
|
2022-09-18 07:33:09 +00:00
|
|
|
timestamp,
|
|
|
|
message,
|
|
|
|
level: logLevel,
|
2022-09-16 17:18:15 +00:00
|
|
|
};
|
2022-09-18 07:33:09 +00:00
|
|
|
|
2022-09-16 17:18:15 +00:00
|
|
|
state.log.push(entry);
|
|
|
|
},
|
|
|
|
setShouldShowLogViewer: (state, action: PayloadAction<boolean>) => {
|
|
|
|
state.shouldShowLogViewer = action.payload;
|
|
|
|
},
|
|
|
|
setIsConnected: (state, action: PayloadAction<boolean>) => {
|
|
|
|
state.isConnected = action.payload;
|
2022-09-26 01:50:47 +00:00
|
|
|
state.isProcessing = false;
|
2022-10-28 17:44:03 +00:00
|
|
|
state.isCancelable = true;
|
2022-09-26 01:50:47 +00:00
|
|
|
state.currentStep = 0;
|
|
|
|
state.totalSteps = 0;
|
|
|
|
state.currentIteration = 0;
|
|
|
|
state.totalIterations = 0;
|
|
|
|
state.currentStatusHasSteps = false;
|
2022-10-03 16:15:26 +00:00
|
|
|
state.hasError = false;
|
2022-09-16 17:18:15 +00:00
|
|
|
},
|
|
|
|
setSocketId: (state, action: PayloadAction<string>) => {
|
|
|
|
state.socketId = action.payload;
|
|
|
|
},
|
|
|
|
setShouldConfirmOnDelete: (state, action: PayloadAction<boolean>) => {
|
|
|
|
state.shouldConfirmOnDelete = action.payload;
|
|
|
|
},
|
|
|
|
setOpenAccordions: (state, action: PayloadAction<ExpandedIndex>) => {
|
|
|
|
state.openAccordions = action.payload;
|
|
|
|
},
|
2022-09-20 13:17:31 +00:00
|
|
|
setSystemConfig: (state, action: PayloadAction<InvokeAI.SystemConfig>) => {
|
2022-10-28 05:47:15 +00:00
|
|
|
return {
|
|
|
|
...state,
|
|
|
|
...action.payload,
|
|
|
|
};
|
2022-09-20 13:17:31 +00:00
|
|
|
},
|
2022-09-23 13:09:48 +00:00
|
|
|
setShouldDisplayGuides: (state, action: PayloadAction<boolean>) => {
|
|
|
|
state.shouldDisplayGuides = action.payload;
|
|
|
|
},
|
2022-10-03 16:15:26 +00:00
|
|
|
processingCanceled: (state) => {
|
|
|
|
state.isProcessing = false;
|
2022-10-28 17:44:03 +00:00
|
|
|
state.isCancelable = true;
|
2022-10-03 16:15:26 +00:00
|
|
|
state.currentStep = 0;
|
|
|
|
state.totalSteps = 0;
|
|
|
|
state.currentIteration = 0;
|
|
|
|
state.totalIterations = 0;
|
|
|
|
state.currentStatusHasSteps = false;
|
|
|
|
state.currentStatus = 'Processing canceled';
|
|
|
|
},
|
2022-10-28 07:50:47 +00:00
|
|
|
setModelList: (
|
|
|
|
state,
|
|
|
|
action: PayloadAction<InvokeAI.ModelList | Record<string, never>>
|
|
|
|
) => {
|
|
|
|
state.model_list = action.payload;
|
|
|
|
},
|
|
|
|
setIsCancelable: (state, action: PayloadAction<boolean>) => {
|
|
|
|
state.isCancelable = action.payload;
|
|
|
|
},
|
2022-10-31 07:57:41 +00:00
|
|
|
modelChangeRequested: (state) => {
|
|
|
|
state.currentStatus = 'Loading Model';
|
|
|
|
state.isCancelable = false;
|
|
|
|
state.isProcessing = true;
|
|
|
|
state.currentStatusHasSteps = false;
|
|
|
|
},
|
2022-09-16 17:18:15 +00:00
|
|
|
},
|
|
|
|
});
|
|
|
|
|
|
|
|
export const {
|
|
|
|
setShouldDisplayInProgress,
|
2022-11-01 10:17:43 +00:00
|
|
|
setShouldDisplayInProgressLatents,
|
2022-09-16 17:18:15 +00:00
|
|
|
setIsProcessing,
|
|
|
|
addLogEntry,
|
|
|
|
setShouldShowLogViewer,
|
|
|
|
setIsConnected,
|
|
|
|
setSocketId,
|
|
|
|
setShouldConfirmOnDelete,
|
|
|
|
setOpenAccordions,
|
2022-09-18 07:33:09 +00:00
|
|
|
setSystemStatus,
|
|
|
|
setCurrentStatus,
|
2022-09-20 13:17:31 +00:00
|
|
|
setSystemConfig,
|
2022-09-23 13:09:48 +00:00
|
|
|
setShouldDisplayGuides,
|
2022-10-03 16:15:26 +00:00
|
|
|
processingCanceled,
|
|
|
|
errorOccurred,
|
|
|
|
errorSeen,
|
2022-10-28 07:50:47 +00:00
|
|
|
setModelList,
|
|
|
|
setIsCancelable,
|
2022-10-31 07:57:41 +00:00
|
|
|
modelChangeRequested,
|
2022-09-16 17:18:15 +00:00
|
|
|
} = systemSlice.actions;
|
|
|
|
|
|
|
|
export default systemSlice.reducer;
|