From e5dac8b9d61b175b09d859643a94ea91ee6ef48d Mon Sep 17 00:00:00 2001 From: Max Nanis Date: Tue, 10 Jun 2025 02:51:37 +0700 Subject: Demographics page. userMarketplaceAnswer & userUpkAnswer redux stores. --- src/models/userMarketplaceAnswerSlice.ts | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) create mode 100644 src/models/userMarketplaceAnswerSlice.ts (limited to 'src/models/userMarketplaceAnswerSlice.ts') diff --git a/src/models/userMarketplaceAnswerSlice.ts b/src/models/userMarketplaceAnswerSlice.ts new file mode 100644 index 0000000..7cfe95b --- /dev/null +++ b/src/models/userMarketplaceAnswerSlice.ts @@ -0,0 +1,27 @@ +import {createSlice, PayloadAction} from "@reduxjs/toolkit"; +import {MarketProfileKnowledge} from "@/api"; +import type {RootState} from '@/store' + +const initialState: MarketProfileKnowledge[] = [] + + +const userMarketplaceAnswerSlice = createSlice({ + name: 'userMarketplaceAnswers', + initialState, + reducers: { + setMarketplaceAnswers(state, action: PayloadAction) { + // TODO: Does this need question_id + source uniqueness? + const existingIds = new Set(state.map(q => q.question_id)); + const newQuestions = action.payload.filter(q => !existingIds.has(q.question_id)); + state.push(...newQuestions); + } + } +}) + +export const { + setMarketplaceAnswers, +} = userMarketplaceAnswerSlice.actions; + +export default userMarketplaceAnswerSlice.reducer; + +export const selectUserMarketplaceAnswers = (state: RootState) => state.userMarketplaceAnswers \ No newline at end of file -- cgit v1.2.3