From 897e93b3a6596d25c19fe0a3579d9cd4c9ea66e7 Mon Sep 17 00:00:00 2001 From: Max Nanis Date: Mon, 9 Jun 2025 19:12:44 +0700 Subject: Debugging reducer logic for Upk and Marketplace Answers, along with Upk global definitions --- src/models/marketplaceAnswerSlice.ts | 24 ++++++++++++++++++++++++ src/models/upkAnswerSlice.ts | 23 +++++++++++++++++++++++ src/models/upkQuestionSlice.ts | 27 +++++++++++++++++++++++++++ src/models/walletSlice.ts | 2 +- 4 files changed, 75 insertions(+), 1 deletion(-) create mode 100644 src/models/marketplaceAnswerSlice.ts create mode 100644 src/models/upkAnswerSlice.ts create mode 100644 src/models/upkQuestionSlice.ts (limited to 'src/models') diff --git a/src/models/marketplaceAnswerSlice.ts b/src/models/marketplaceAnswerSlice.ts new file mode 100644 index 0000000..a1db7f0 --- /dev/null +++ b/src/models/marketplaceAnswerSlice.ts @@ -0,0 +1,24 @@ +import {createSlice, PayloadAction} from "@reduxjs/toolkit"; +import {MarketProfileKnowledge} from "@/api"; + +const marketplaceInitialState: MarketProfileKnowledge[] = [] + + +const marketplaceAnswerSlice = createSlice({ + name: 'marketplaceAnswers', + marketplaceInitialState, + 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, +} = marketplaceAnswerSlice.actions; + +export default marketplaceAnswerSlice.reducer; diff --git a/src/models/upkAnswerSlice.ts b/src/models/upkAnswerSlice.ts new file mode 100644 index 0000000..7bd57f1 --- /dev/null +++ b/src/models/upkAnswerSlice.ts @@ -0,0 +1,23 @@ +import {createSlice, PayloadAction} from '@reduxjs/toolkit' +import {UserProfileKnowledge} from "@/api"; + +const upkInitialState: UserProfileKnowledge[] = [] + +const upkAnswerSlice = createSlice({ + name: 'upkAnswers', + upkInitialState, + reducers: { + setUpkAnswers(state, action: PayloadAction) { + const existingIds = new Set(state.map(q => q.property_id)); + const newQuestions = action.payload.filter(q => !existingIds.has(q.property_id)); + state.push(...newQuestions); + } + } +}) + + +export const { + setUpkAnswers, +} = upkAnswerSlice.actions; + +export default upkAnswerSlice.reducer; \ No newline at end of file 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) { + 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 diff --git a/src/models/walletSlice.ts b/src/models/walletSlice.ts index 83eda62..9a2dd0c 100644 --- a/src/models/walletSlice.ts +++ b/src/models/walletSlice.ts @@ -3,7 +3,7 @@ import {createSlice, PayloadAction} from '@reduxjs/toolkit' import {UserWalletBalance} from "@/api"; -const initialState: UserWalletBalance = {}; +const initialState: UserWalletBalance = {} as UserWalletBalance; const walletSlice = createSlice({ -- cgit v1.2.3