@open-tender/store
Version:
A library of hooks, reducers, utility functions, and types for use with Open Tender applications that utilize our in-store POS API
121 lines (120 loc) • 5.12 kB
JavaScript
import { __awaiter, __generator } from "tslib";
import { createAsyncThunk, createSlice } from '@reduxjs/toolkit';
import { ReducerType } from './types';
var initialState = {
data: null,
loading: 'idle',
error: null
};
export var SettingsActionType;
(function (SettingsActionType) {
SettingsActionType["FetchSetting"] = "settings/fetchSetting";
SettingsActionType["UpdateSetting"] = "settings/updateSetting";
SettingsActionType["UpdateSettings"] = "settings/updateSettings";
})(SettingsActionType || (SettingsActionType = {}));
export var fetchSetting = createAsyncThunk(SettingsActionType.FetchSetting, function (posSettingType_1, _a) { return __awaiter(void 0, [posSettingType_1, _a], void 0, function (posSettingType, _b) {
var api, err_1;
var getState = _b.getState, rejectWithValue = _b.rejectWithValue;
return __generator(this, function (_c) {
switch (_c.label) {
case 0:
_c.trys.push([0, 2, , 3]);
api = getState().config.api;
return [4 /*yield*/, api.getSettings(posSettingType)];
case 1: return [2 /*return*/, _c.sent()];
case 2:
err_1 = _c.sent();
return [2 /*return*/, rejectWithValue(err_1)];
case 3: return [2 /*return*/];
}
});
}); });
export var updateSetting = createAsyncThunk(SettingsActionType.UpdateSetting, function (posSettingType_1, _a) { return __awaiter(void 0, [posSettingType_1, _a], void 0, function (posSettingType, _b) {
var api, err_2;
var getState = _b.getState, rejectWithValue = _b.rejectWithValue;
return __generator(this, function (_c) {
switch (_c.label) {
case 0:
_c.trys.push([0, 2, , 3]);
api = getState().config.api;
return [4 /*yield*/, api.postSettings(posSettingType)];
case 1: return [2 /*return*/, _c.sent()];
case 2:
err_2 = _c.sent();
return [2 /*return*/, rejectWithValue(err_2)];
case 3: return [2 /*return*/];
}
});
}); });
export var updateSettings = createAsyncThunk(SettingsActionType.UpdateSettings, function (posSettingTypes_1, _a) { return __awaiter(void 0, [posSettingTypes_1, _a], void 0, function (posSettingTypes, _b) {
var api_1, requests, err_3;
var getState = _b.getState, rejectWithValue = _b.rejectWithValue;
return __generator(this, function (_c) {
switch (_c.label) {
case 0:
_c.trys.push([0, 2, , 3]);
api_1 = getState().config.api;
requests = posSettingTypes.map(function (posSettingType) { return __awaiter(void 0, void 0, void 0, function () {
return __generator(this, function (_a) {
switch (_a.label) {
case 0: return [4 /*yield*/, api_1.postSettings(posSettingType)];
case 1: return [2 /*return*/, _a.sent()];
}
});
}); });
return [4 /*yield*/, Promise.all(requests)];
case 1: return [2 /*return*/, _c.sent()];
case 2:
err_3 = _c.sent();
return [2 /*return*/, rejectWithValue(err_3)];
case 3: return [2 /*return*/];
}
});
}); });
var settingsSlice = createSlice({
name: ReducerType.Settings,
initialState: initialState,
reducers: {
resetSettings: function () { return initialState; }
},
extraReducers: function (builder) {
builder
.addCase(fetchSetting.pending, function (state) {
state.loading = 'pending';
})
.addCase(fetchSetting.fulfilled, function (state, action) {
state.data = action.payload;
state.loading = 'idle';
state.error = null;
})
.addCase(fetchSetting.rejected, function (state, action) {
state.error = action.payload;
state.loading = 'idle';
})
.addCase(updateSetting.pending, function (state) {
state.loading = 'pending';
})
.addCase(updateSetting.fulfilled, function (state) {
state.loading = 'idle';
state.error = null;
})
.addCase(updateSetting.rejected, function (state, action) {
state.error = action.payload;
state.loading = 'idle';
})
.addCase(updateSettings.pending, function (state) {
state.loading = 'pending';
})
.addCase(updateSettings.fulfilled, function (state) {
state.loading = 'idle';
state.error = null;
})
.addCase(updateSettings.rejected, function (state, action) {
state.error = action.payload;
state.loading = 'idle';
});
}
});
export var resetSettings = settingsSlice.actions.resetSettings;
export var selectSettings = function (state) { return state.settings; };
export var settingsReducer = settingsSlice.reducer;