aboutsummaryrefslogtreecommitdiff
path: root/src/models
diff options
context:
space:
mode:
Diffstat (limited to 'src/models')
-rw-r--r--src/models/marketplaceAnswerSlice.ts24
-rw-r--r--src/models/upkAnswerSlice.ts23
-rw-r--r--src/models/upkQuestionSlice.ts27
-rw-r--r--src/models/walletSlice.ts2
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({