From 618fb497c443662531eb3befe7696a04efe9651d Mon Sep 17 00:00:00 2001 From: Shin'ya Ueoka Date: Sun, 11 Apr 2021 18:00:51 +0900 Subject: Replace completion state with Custom Hooks --- src/console/reducers/completion.ts | 99 -------------------------------------- src/console/reducers/console.ts | 3 -- 2 files changed, 102 deletions(-) delete mode 100644 src/console/reducers/completion.ts (limited to 'src/console/reducers') diff --git a/src/console/reducers/completion.ts b/src/console/reducers/completion.ts deleted file mode 100644 index 2c7ee55..0000000 --- a/src/console/reducers/completion.ts +++ /dev/null @@ -1,99 +0,0 @@ -import Completions from "../Completions"; -import CompletionType from "../../shared/CompletionType"; -import { - COMPLETION_COMPLETION_NEXT, - COMPLETION_COMPLETION_PREV, - COMPLETION_SET_COMPLETIONS, - COMPLETION_START_COMPLETION, - CompletionAction, -} from "../actions/completion"; - -export interface State { - completionTypes: CompletionType[]; - completionSource: string; - completions: Completions; - select: number; -} - -export const defaultState = { - completionTypes: [], - completionSource: "", - completions: [], - select: -1, -}; - -const nextSelection = (state: State): number => { - if (state.completions.length === 0) { - return -1; - } - if (state.select < 0) { - return 0; - } - - const length = state.completions - .map((g) => g.items.length) - .reduce((x, y) => x + y); - if (state.select + 1 < length) { - return state.select + 1; - } - return -1; -}; - -const prevSelection = (state: State): number => { - const length = state.completions - .map((g) => g.items.length) - .reduce((x, y) => x + y); - if (state.select < 0) { - return length - 1; - } - return state.select - 1; -}; - -export const completedText = (state: State): string => { - if (state.select < 0) { - return state.completionSource; - } - const items = state.completions - .map((g) => g.items) - .reduce((g1, g2) => g1.concat(g2)); - return items[state.select].content || ""; -}; - -// eslint-disable-next-line max-lines-per-function -export default function reducer( - state: State = defaultState, - action: CompletionAction -): State { - switch (action.type) { - case COMPLETION_START_COMPLETION: - return { - ...state, - completionTypes: action.completionTypes, - completions: [], - select: -1, - }; - case COMPLETION_SET_COMPLETIONS: - return { - ...state, - completions: action.completions, - completionSource: action.completionSource, - select: -1, - }; - case COMPLETION_COMPLETION_NEXT: { - const select = nextSelection(state); - return { - ...state, - select: select, - }; - } - case COMPLETION_COMPLETION_PREV: { - const select = prevSelection(state); - return { - ...state, - select: select, - }; - } - default: - return state; - } -} diff --git a/src/console/reducers/console.ts b/src/console/reducers/console.ts index 37f1efc..babad69 100644 --- a/src/console/reducers/console.ts +++ b/src/console/reducers/console.ts @@ -1,7 +1,6 @@ import { CONSOLE_HIDE, CONSOLE_HIDE_COMMAND, - CONSOLE_SET_CONSOLE_TEXT, CONSOLE_SHOW_COMMAND, CONSOLE_SHOW_ERROR, CONSOLE_SHOW_FIND, @@ -47,8 +46,6 @@ export default function reducer( mode: state.mode === "command" || state.mode === "find" ? "" : state.mode, }; - case CONSOLE_SET_CONSOLE_TEXT: - return { ...state, consoleText: action.consoleText }; default: return state; } -- cgit v1.2.3