@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
69 lines (68 loc) • 2.63 kB
JavaScript
import { __assign, __awaiter, __generator } from "tslib";
import { createAsyncThunk, createSelector, createSlice } from '@reduxjs/toolkit';
import { ReducerType } from './types';
var initialState = {
entities: [],
loading: 'idle',
error: null
};
export var MenuPagesActionType;
(function (MenuPagesActionType) {
MenuPagesActionType["FetchMenuPages"] = "menuPages/fetchMenuPages";
})(MenuPagesActionType || (MenuPagesActionType = {}));
export var fetchMenuPages = createAsyncThunk(MenuPagesActionType.FetchMenuPages, function (_1, _a) { return __awaiter(void 0, [_1, _a], void 0, function (_, _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('POS_PAGE')];
case 1: return [2 /*return*/, _c.sent()];
case 2:
err_1 = _c.sent();
return [2 /*return*/, rejectWithValue(err_1)];
case 3: return [2 /*return*/];
}
});
}); });
var menuPagesSlice = createSlice({
name: ReducerType.MenuPages,
initialState: initialState,
reducers: {
resetMenuPages: function () { return initialState; }
},
extraReducers: function (builder) {
builder
.addCase(fetchMenuPages.fulfilled, function (state, action) {
state.entities = action.payload || [];
state.loading = 'idle';
state.error = null;
})
.addCase(fetchMenuPages.pending, function (state) {
state.loading = 'pending';
})
.addCase(fetchMenuPages.rejected, function (state, action) {
state.error = action.payload;
state.loading = 'idle';
});
}
});
export var resetMenuPages = menuPagesSlice.actions.resetMenuPages;
export var selectMenuPages = function (state) { return state.menuPages; };
export var selectMenuPagesFiltered = createSelector(function (state) {
var orderType = state.order.orderType;
var pages = state.menuPages.entities;
return { orderType: orderType, pages: pages };
}, function (_a) {
var orderType = _a.orderType, pages = _a.pages;
if (!orderType)
return [];
return pages
.map(function (i) {
return __assign(__assign({}, i), { order_type: i.order_type });
})
.filter(function (i) { return i.order_type === orderType; });
});
export var menuPagesReducer = menuPagesSlice.reducer;