diff options
| author | Max Nanis | 2025-06-09 19:12:44 +0700 |
|---|---|---|
| committer | Max Nanis | 2025-06-09 19:12:44 +0700 |
| commit | 897e93b3a6596d25c19fe0a3579d9cd4c9ea66e7 (patch) | |
| tree | e9adf209e4cf9061b3ac383c8d13c2ded0203daf /src/models/upkQuestionSlice.ts | |
| parent | 74890e251dee3e0f195583431cb48b9f3a58ecc9 (diff) | |
| download | panel-ui-897e93b3a6596d25c19fe0a3579d9cd4c9ea66e7.tar.gz panel-ui-897e93b3a6596d25c19fe0a3579d9cd4c9ea66e7.zip | |
Debugging reducer logic for Upk and Marketplace Answers, along with Upk global definitions
Diffstat (limited to 'src/models/upkQuestionSlice.ts')
| -rw-r--r-- | src/models/upkQuestionSlice.ts | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/src/models/upkQuestionSlice.ts b/src/models/upkQuestionSlice.ts new file mode 100644 index 0000000..b99f508 --- /dev/null +++ b/src/models/upkQuestionSlice.ts @@ -0,0 +1,27 @@ +import {createSlice, PayloadAction} from '@reduxjs/toolkit' +import type {RootState} from '@/store' +import {QuestionInfo} from "@/api"; + + +const initialState: QuestionInfo[] = [] + +const upkQuestionSlice = createSlice({ + name: 'upkQuestions', + initialState, + reducers: { + setUpkQuestions(state, action: PayloadAction<QuestionInfo[]>) { + const existingIds = new Set(state.map(q => q.question_id)); + const newQuestions = action.payload.filter(q => !existingIds.has(q.property_id)); + state.push(...newQuestions); + }, + } +}) + +export const { + setUpkQuestions, +} = upkQuestionSlice.actions; +export default upkQuestionSlice.reducer + +// We need to fetch the next available Question that either doesn't have an Answer, or the Answer +// isn't Answer.completed +export const selectUpkQuestions = (state: RootState) => state.questions
\ No newline at end of file |
