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 | |
| 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')
| -rw-r--r-- | src/models/marketplaceAnswerSlice.ts | 24 | ||||
| -rw-r--r-- | src/models/upkAnswerSlice.ts | 23 | ||||
| -rw-r--r-- | src/models/upkQuestionSlice.ts | 27 | ||||
| -rw-r--r-- | src/models/walletSlice.ts | 2 |
4 files changed, 75 insertions, 1 deletions
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<MarketProfileKnowledge[]>) { + // 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<UserProfileKnowledge[]>) { + 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<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 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({ |
