From 8caa77413ea372e5cbd2980a9922d701af359c04 Mon Sep 17 00:00:00 2001 From: Max Nanis Date: Wed, 28 May 2025 04:41:37 +0100 Subject: initial commit --- src/models/questionSlice.ts | 36 ++++++++++++++++++++++++++++++++++++ 1 file changed, 36 insertions(+) create mode 100644 src/models/questionSlice.ts (limited to 'src/models/questionSlice.ts') diff --git a/src/models/questionSlice.ts b/src/models/questionSlice.ts new file mode 100644 index 0000000..6a4da6f --- /dev/null +++ b/src/models/questionSlice.ts @@ -0,0 +1,36 @@ +import {createSlice, PayloadAction} from '@reduxjs/toolkit' +import type {RootState} from '@/store' +import {UpkQuestion} from "@/api/models/upk-question.ts" + +const initialState: UpkQuestion[] = [] + +// Create the slice and pass in the initial state +const questionSlice = createSlice({ + name: 'questions', + initialState, + reducers: { + setQuestions(state, action: PayloadAction) { + return action.payload; + }, + questionAdded(state, action: PayloadAction) { + state.push(action.payload); + }, + setAnswer(state, action: PayloadAction<{ questionId: string, val: string }>) { + const {questionId, val} = action.payload + console.log(questionId, val) + const existingQuestion = state.find(q => q.questionId === action.payload.questionId) + if (existingQuestion) { + // existingQuestion.addAnswer(action.payload.val) + // existingQuestion.error_msg = "yess" + } + } + } +}) + +// Export the generated reducer function +export const {setAnswer, setQuestions, questionAdded, questionUpdated} = questionSlice.actions; +export default questionSlice.reducer + +export const selectAllQuestions = (state: RootState) => state.questions + +export const selectQuestionById = (state: RootState, questionId: string) => state.questions.find(q => q.id === questionId) \ No newline at end of file -- cgit v1.2.3