@open-tender/cloud 0.1.77 → 0.1.78
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
|
@@ -24,11 +24,145 @@ export declare const fetchAnnouncementPage: import("@reduxjs/toolkit").AsyncThun
|
|
|
24
24
|
}>;
|
|
25
25
|
export declare const resetAnnouncements: import("@reduxjs/toolkit").ActionCreatorWithoutPayload<"announcements/resetAnnouncements">;
|
|
26
26
|
export declare const selectAnnouncements: (state: AppState) => AnnouncementsState;
|
|
27
|
-
export declare const selectAnnouncementsPage: (page: AnnouncementPageType) => (state:
|
|
27
|
+
export declare const selectAnnouncementsPage: (page: AnnouncementPageType) => ((state: import("redux").EmptyObject & {
|
|
28
|
+
alerts: import("@open-tender/types").Alerts;
|
|
29
|
+
allergens: import("./allergens").AllergensState;
|
|
30
|
+
announcements: AnnouncementsState;
|
|
31
|
+
checkout: import("./checkout").CheckoutState;
|
|
32
|
+
completedOrders: import("./completedOrders").CompletedOrdersState;
|
|
33
|
+
config: import("./config").ConfigState;
|
|
34
|
+
confirmation: import("./confirmation").ConfirmationState;
|
|
35
|
+
customer: import("redux").CombinedState<{
|
|
36
|
+
account: import("./customer").AccountState;
|
|
37
|
+
communicationPreferences: import("./customer").CustomerCommunicationPrefsState;
|
|
38
|
+
creditCards: import("./customer").CustomerCreditCardsState;
|
|
39
|
+
allergens: import("./customer").CustomerAllergensState;
|
|
40
|
+
addresses: import("./customer").CustomerAddressesState;
|
|
41
|
+
favorites: import("./customer").CustomerFavoritesState;
|
|
42
|
+
fcmToken: import("./customer").CustomerFcmTokenState;
|
|
43
|
+
giftCards: import("./customer").CustomerGiftCardsState;
|
|
44
|
+
groupOrders: import("./customer").CustomerGroupOrdersState;
|
|
45
|
+
houseAccounts: import("./customer").CustomerHouseAccountsState;
|
|
46
|
+
loyalty: import("./customer").CustomerLoyaltyState;
|
|
47
|
+
order: import("./customer").CustomerOrderState;
|
|
48
|
+
orders: import("./customer").CustomerOrdersState;
|
|
49
|
+
pointsShop: import("./customer").PointsShopState;
|
|
50
|
+
qrcode: import("./customer").CustomerQRCodeState;
|
|
51
|
+
rewards: import("./customer").CustomerRewardsState;
|
|
52
|
+
thanx: import("./customer").CustomerThanxState;
|
|
53
|
+
tpls: import("./customer").CustomerTplsState;
|
|
54
|
+
}>;
|
|
55
|
+
deals: import("./deals").DealsState;
|
|
56
|
+
donations: import("./donations").DonationState;
|
|
57
|
+
geolocation: import("./geolocation").GeoLocationState;
|
|
58
|
+
giftCards: import("./giftCards").GiftCardsState;
|
|
59
|
+
groupOrder: import("./groupOrder").GroupOrderState;
|
|
60
|
+
guest: import("./guest").GuestState;
|
|
61
|
+
loader: import("./loader").LoaderState;
|
|
62
|
+
menu: import("./menu").MenuState;
|
|
63
|
+
menuDisplay: import("./menuDisplay").MenuDisplayState;
|
|
64
|
+
menuItems: import("./menuItems").MenuItemsState;
|
|
65
|
+
modal: import("@open-tender/types").Modal;
|
|
66
|
+
misc: import("./misc").MiscState;
|
|
67
|
+
nav: import("./nav").NavState;
|
|
68
|
+
navSite: import("./navSite").NavSiteState;
|
|
69
|
+
notifications: import("@open-tender/types").Notifications;
|
|
70
|
+
oneTimePasscode: import("./oneTimePasscode").OneTimePasscodeState;
|
|
71
|
+
order: import("./order").OrderState;
|
|
72
|
+
orderFulfillment: import("./orderFulfillment").OrderFulfillmentState;
|
|
73
|
+
orderRating: import("./orderRating").OrderRatingState;
|
|
74
|
+
posts: import("./posts").PostsSlice;
|
|
75
|
+
qr: import("./qr").QrState;
|
|
76
|
+
resetPassword: import("./resetPassword").ResetPasswordState;
|
|
77
|
+
revenueCenters: import("./revenueCenters").RevenueCentersState;
|
|
78
|
+
sidebar: import("./sidebar").SidebarState;
|
|
79
|
+
sidebarModal: import("./sidebarModal").SidebarModalState;
|
|
80
|
+
signUp: import("./signUp").SignUpState;
|
|
81
|
+
tags: import("./tags").TagsState;
|
|
82
|
+
validTimes: import("./validTimes").ValidTimesState;
|
|
83
|
+
verifyAccount: import("./verifyAccount").VerifyAccountState;
|
|
84
|
+
}) => {
|
|
28
85
|
settings: import("@open-tender/types").AnnouncementSettings | null;
|
|
29
86
|
entities: Announcements;
|
|
30
87
|
loading: RequestStatus;
|
|
31
88
|
error: RequestError;
|
|
89
|
+
}) & import("reselect").OutputSelectorFields<(args_0: {
|
|
90
|
+
pages: AnnouncementPages;
|
|
91
|
+
loading: RequestStatus;
|
|
92
|
+
error: RequestError;
|
|
93
|
+
}) => {
|
|
94
|
+
settings: import("@open-tender/types").AnnouncementSettings | null;
|
|
95
|
+
entities: Announcements;
|
|
96
|
+
loading: RequestStatus;
|
|
97
|
+
error: RequestError;
|
|
98
|
+
}, {
|
|
99
|
+
clearCache: () => void;
|
|
100
|
+
}> & {
|
|
101
|
+
clearCache: () => void;
|
|
102
|
+
};
|
|
103
|
+
export declare const selectHasAnnouncementsPage: (page: AnnouncementPageType) => ((state: import("redux").EmptyObject & {
|
|
104
|
+
alerts: import("@open-tender/types").Alerts;
|
|
105
|
+
allergens: import("./allergens").AllergensState;
|
|
106
|
+
announcements: AnnouncementsState;
|
|
107
|
+
checkout: import("./checkout").CheckoutState;
|
|
108
|
+
completedOrders: import("./completedOrders").CompletedOrdersState;
|
|
109
|
+
config: import("./config").ConfigState;
|
|
110
|
+
confirmation: import("./confirmation").ConfirmationState;
|
|
111
|
+
customer: import("redux").CombinedState<{
|
|
112
|
+
account: import("./customer").AccountState;
|
|
113
|
+
communicationPreferences: import("./customer").CustomerCommunicationPrefsState;
|
|
114
|
+
creditCards: import("./customer").CustomerCreditCardsState;
|
|
115
|
+
allergens: import("./customer").CustomerAllergensState;
|
|
116
|
+
addresses: import("./customer").CustomerAddressesState;
|
|
117
|
+
favorites: import("./customer").CustomerFavoritesState;
|
|
118
|
+
fcmToken: import("./customer").CustomerFcmTokenState;
|
|
119
|
+
giftCards: import("./customer").CustomerGiftCardsState;
|
|
120
|
+
groupOrders: import("./customer").CustomerGroupOrdersState;
|
|
121
|
+
houseAccounts: import("./customer").CustomerHouseAccountsState;
|
|
122
|
+
loyalty: import("./customer").CustomerLoyaltyState;
|
|
123
|
+
order: import("./customer").CustomerOrderState;
|
|
124
|
+
orders: import("./customer").CustomerOrdersState;
|
|
125
|
+
pointsShop: import("./customer").PointsShopState;
|
|
126
|
+
qrcode: import("./customer").CustomerQRCodeState;
|
|
127
|
+
rewards: import("./customer").CustomerRewardsState;
|
|
128
|
+
thanx: import("./customer").CustomerThanxState;
|
|
129
|
+
tpls: import("./customer").CustomerTplsState;
|
|
130
|
+
}>;
|
|
131
|
+
deals: import("./deals").DealsState;
|
|
132
|
+
donations: import("./donations").DonationState;
|
|
133
|
+
geolocation: import("./geolocation").GeoLocationState;
|
|
134
|
+
giftCards: import("./giftCards").GiftCardsState;
|
|
135
|
+
groupOrder: import("./groupOrder").GroupOrderState;
|
|
136
|
+
guest: import("./guest").GuestState;
|
|
137
|
+
loader: import("./loader").LoaderState;
|
|
138
|
+
menu: import("./menu").MenuState;
|
|
139
|
+
menuDisplay: import("./menuDisplay").MenuDisplayState;
|
|
140
|
+
menuItems: import("./menuItems").MenuItemsState;
|
|
141
|
+
modal: import("@open-tender/types").Modal;
|
|
142
|
+
misc: import("./misc").MiscState;
|
|
143
|
+
nav: import("./nav").NavState;
|
|
144
|
+
navSite: import("./navSite").NavSiteState;
|
|
145
|
+
notifications: import("@open-tender/types").Notifications;
|
|
146
|
+
oneTimePasscode: import("./oneTimePasscode").OneTimePasscodeState;
|
|
147
|
+
order: import("./order").OrderState;
|
|
148
|
+
orderFulfillment: import("./orderFulfillment").OrderFulfillmentState;
|
|
149
|
+
orderRating: import("./orderRating").OrderRatingState;
|
|
150
|
+
posts: import("./posts").PostsSlice;
|
|
151
|
+
qr: import("./qr").QrState;
|
|
152
|
+
resetPassword: import("./resetPassword").ResetPasswordState;
|
|
153
|
+
revenueCenters: import("./revenueCenters").RevenueCentersState;
|
|
154
|
+
sidebar: import("./sidebar").SidebarState;
|
|
155
|
+
sidebarModal: import("./sidebarModal").SidebarModalState;
|
|
156
|
+
signUp: import("./signUp").SignUpState;
|
|
157
|
+
tags: import("./tags").TagsState;
|
|
158
|
+
validTimes: import("./validTimes").ValidTimesState;
|
|
159
|
+
verifyAccount: import("./verifyAccount").VerifyAccountState;
|
|
160
|
+
}) => boolean) & import("reselect").OutputSelectorFields<(args_0: {
|
|
161
|
+
pages: AnnouncementPages;
|
|
162
|
+
loading: RequestStatus;
|
|
163
|
+
}) => boolean, {
|
|
164
|
+
clearCache: () => void;
|
|
165
|
+
}> & {
|
|
166
|
+
clearCache: () => void;
|
|
32
167
|
};
|
|
33
|
-
export declare const selectHasAnnouncementsPage: (page: AnnouncementPageType) => (state: AppState) => boolean;
|
|
34
168
|
export declare const announcementsReducer: import("redux").Reducer<AnnouncementsState, import("redux").AnyAction>;
|
|
@@ -59,19 +59,23 @@ const announcementsSlice = (0, toolkit_1.createSlice)({
|
|
|
59
59
|
exports.resetAnnouncements = announcementsSlice.actions.resetAnnouncements;
|
|
60
60
|
const selectAnnouncements = (state) => state.announcements;
|
|
61
61
|
exports.selectAnnouncements = selectAnnouncements;
|
|
62
|
-
const selectAnnouncementsPage = (page) => (state) => {
|
|
62
|
+
const selectAnnouncementsPage = (page) => (0, toolkit_1.createSelector)((state) => {
|
|
63
63
|
const { pages, loading, error } = state.announcements;
|
|
64
|
+
return { pages, loading, error };
|
|
65
|
+
}, ({ pages, loading, error }) => {
|
|
64
66
|
const data = pages ? pages.find(i => i.page === page) : undefined;
|
|
65
67
|
const { settings = null, entities = [] } = data || {};
|
|
66
68
|
return { settings, entities, loading, error };
|
|
67
|
-
};
|
|
69
|
+
});
|
|
68
70
|
exports.selectAnnouncementsPage = selectAnnouncementsPage;
|
|
69
|
-
const selectHasAnnouncementsPage = (page) => (state) => {
|
|
71
|
+
const selectHasAnnouncementsPage = (page) => (0, toolkit_1.createSelector)((state) => {
|
|
70
72
|
const { pages, loading } = state.announcements;
|
|
73
|
+
return { pages, loading };
|
|
74
|
+
}, ({ pages, loading }) => {
|
|
71
75
|
const data = pages ? pages.find(i => i.page === page) : undefined;
|
|
72
76
|
const { entities = [] } = data || {};
|
|
73
77
|
const hasAnnouncements = entities && entities.length;
|
|
74
78
|
return loading === 'pending' || hasAnnouncements ? true : false;
|
|
75
|
-
};
|
|
79
|
+
});
|
|
76
80
|
exports.selectHasAnnouncementsPage = selectHasAnnouncementsPage;
|
|
77
81
|
exports.announcementsReducer = announcementsSlice.reducer;
|
|
@@ -24,11 +24,145 @@ export declare const fetchAnnouncementPage: import("@reduxjs/toolkit").AsyncThun
|
|
|
24
24
|
}>;
|
|
25
25
|
export declare const resetAnnouncements: import("@reduxjs/toolkit").ActionCreatorWithoutPayload<"announcements/resetAnnouncements">;
|
|
26
26
|
export declare const selectAnnouncements: (state: AppState) => AnnouncementsState;
|
|
27
|
-
export declare const selectAnnouncementsPage: (page: AnnouncementPageType) => (state:
|
|
27
|
+
export declare const selectAnnouncementsPage: (page: AnnouncementPageType) => ((state: import("redux").EmptyObject & {
|
|
28
|
+
alerts: import("@open-tender/types").Alerts;
|
|
29
|
+
allergens: import("./allergens").AllergensState;
|
|
30
|
+
announcements: AnnouncementsState;
|
|
31
|
+
checkout: import("./checkout").CheckoutState;
|
|
32
|
+
completedOrders: import("./completedOrders").CompletedOrdersState;
|
|
33
|
+
config: import("./config").ConfigState;
|
|
34
|
+
confirmation: import("./confirmation").ConfirmationState;
|
|
35
|
+
customer: import("redux").CombinedState<{
|
|
36
|
+
account: import("./customer").AccountState;
|
|
37
|
+
communicationPreferences: import("./customer").CustomerCommunicationPrefsState;
|
|
38
|
+
creditCards: import("./customer").CustomerCreditCardsState;
|
|
39
|
+
allergens: import("./customer").CustomerAllergensState;
|
|
40
|
+
addresses: import("./customer").CustomerAddressesState;
|
|
41
|
+
favorites: import("./customer").CustomerFavoritesState;
|
|
42
|
+
fcmToken: import("./customer").CustomerFcmTokenState;
|
|
43
|
+
giftCards: import("./customer").CustomerGiftCardsState;
|
|
44
|
+
groupOrders: import("./customer").CustomerGroupOrdersState;
|
|
45
|
+
houseAccounts: import("./customer").CustomerHouseAccountsState;
|
|
46
|
+
loyalty: import("./customer").CustomerLoyaltyState;
|
|
47
|
+
order: import("./customer").CustomerOrderState;
|
|
48
|
+
orders: import("./customer").CustomerOrdersState;
|
|
49
|
+
pointsShop: import("./customer").PointsShopState;
|
|
50
|
+
qrcode: import("./customer").CustomerQRCodeState;
|
|
51
|
+
rewards: import("./customer").CustomerRewardsState;
|
|
52
|
+
thanx: import("./customer").CustomerThanxState;
|
|
53
|
+
tpls: import("./customer").CustomerTplsState;
|
|
54
|
+
}>;
|
|
55
|
+
deals: import("./deals").DealsState;
|
|
56
|
+
donations: import("./donations").DonationState;
|
|
57
|
+
geolocation: import("./geolocation").GeoLocationState;
|
|
58
|
+
giftCards: import("./giftCards").GiftCardsState;
|
|
59
|
+
groupOrder: import("./groupOrder").GroupOrderState;
|
|
60
|
+
guest: import("./guest").GuestState;
|
|
61
|
+
loader: import("./loader").LoaderState;
|
|
62
|
+
menu: import("./menu").MenuState;
|
|
63
|
+
menuDisplay: import("./menuDisplay").MenuDisplayState;
|
|
64
|
+
menuItems: import("./menuItems").MenuItemsState;
|
|
65
|
+
modal: import("@open-tender/types").Modal;
|
|
66
|
+
misc: import("./misc").MiscState;
|
|
67
|
+
nav: import("./nav").NavState;
|
|
68
|
+
navSite: import("./navSite").NavSiteState;
|
|
69
|
+
notifications: import("@open-tender/types").Notifications;
|
|
70
|
+
oneTimePasscode: import("./oneTimePasscode").OneTimePasscodeState;
|
|
71
|
+
order: import("./order").OrderState;
|
|
72
|
+
orderFulfillment: import("./orderFulfillment").OrderFulfillmentState;
|
|
73
|
+
orderRating: import("./orderRating").OrderRatingState;
|
|
74
|
+
posts: import("./posts").PostsSlice;
|
|
75
|
+
qr: import("./qr").QrState;
|
|
76
|
+
resetPassword: import("./resetPassword").ResetPasswordState;
|
|
77
|
+
revenueCenters: import("./revenueCenters").RevenueCentersState;
|
|
78
|
+
sidebar: import("./sidebar").SidebarState;
|
|
79
|
+
sidebarModal: import("./sidebarModal").SidebarModalState;
|
|
80
|
+
signUp: import("./signUp").SignUpState;
|
|
81
|
+
tags: import("./tags").TagsState;
|
|
82
|
+
validTimes: import("./validTimes").ValidTimesState;
|
|
83
|
+
verifyAccount: import("./verifyAccount").VerifyAccountState;
|
|
84
|
+
}) => {
|
|
28
85
|
settings: import("@open-tender/types").AnnouncementSettings | null;
|
|
29
86
|
entities: Announcements;
|
|
30
87
|
loading: RequestStatus;
|
|
31
88
|
error: RequestError;
|
|
89
|
+
}) & import("reselect").OutputSelectorFields<(args_0: {
|
|
90
|
+
pages: AnnouncementPages;
|
|
91
|
+
loading: RequestStatus;
|
|
92
|
+
error: RequestError;
|
|
93
|
+
}) => {
|
|
94
|
+
settings: import("@open-tender/types").AnnouncementSettings | null;
|
|
95
|
+
entities: Announcements;
|
|
96
|
+
loading: RequestStatus;
|
|
97
|
+
error: RequestError;
|
|
98
|
+
}, {
|
|
99
|
+
clearCache: () => void;
|
|
100
|
+
}> & {
|
|
101
|
+
clearCache: () => void;
|
|
102
|
+
};
|
|
103
|
+
export declare const selectHasAnnouncementsPage: (page: AnnouncementPageType) => ((state: import("redux").EmptyObject & {
|
|
104
|
+
alerts: import("@open-tender/types").Alerts;
|
|
105
|
+
allergens: import("./allergens").AllergensState;
|
|
106
|
+
announcements: AnnouncementsState;
|
|
107
|
+
checkout: import("./checkout").CheckoutState;
|
|
108
|
+
completedOrders: import("./completedOrders").CompletedOrdersState;
|
|
109
|
+
config: import("./config").ConfigState;
|
|
110
|
+
confirmation: import("./confirmation").ConfirmationState;
|
|
111
|
+
customer: import("redux").CombinedState<{
|
|
112
|
+
account: import("./customer").AccountState;
|
|
113
|
+
communicationPreferences: import("./customer").CustomerCommunicationPrefsState;
|
|
114
|
+
creditCards: import("./customer").CustomerCreditCardsState;
|
|
115
|
+
allergens: import("./customer").CustomerAllergensState;
|
|
116
|
+
addresses: import("./customer").CustomerAddressesState;
|
|
117
|
+
favorites: import("./customer").CustomerFavoritesState;
|
|
118
|
+
fcmToken: import("./customer").CustomerFcmTokenState;
|
|
119
|
+
giftCards: import("./customer").CustomerGiftCardsState;
|
|
120
|
+
groupOrders: import("./customer").CustomerGroupOrdersState;
|
|
121
|
+
houseAccounts: import("./customer").CustomerHouseAccountsState;
|
|
122
|
+
loyalty: import("./customer").CustomerLoyaltyState;
|
|
123
|
+
order: import("./customer").CustomerOrderState;
|
|
124
|
+
orders: import("./customer").CustomerOrdersState;
|
|
125
|
+
pointsShop: import("./customer").PointsShopState;
|
|
126
|
+
qrcode: import("./customer").CustomerQRCodeState;
|
|
127
|
+
rewards: import("./customer").CustomerRewardsState;
|
|
128
|
+
thanx: import("./customer").CustomerThanxState;
|
|
129
|
+
tpls: import("./customer").CustomerTplsState;
|
|
130
|
+
}>;
|
|
131
|
+
deals: import("./deals").DealsState;
|
|
132
|
+
donations: import("./donations").DonationState;
|
|
133
|
+
geolocation: import("./geolocation").GeoLocationState;
|
|
134
|
+
giftCards: import("./giftCards").GiftCardsState;
|
|
135
|
+
groupOrder: import("./groupOrder").GroupOrderState;
|
|
136
|
+
guest: import("./guest").GuestState;
|
|
137
|
+
loader: import("./loader").LoaderState;
|
|
138
|
+
menu: import("./menu").MenuState;
|
|
139
|
+
menuDisplay: import("./menuDisplay").MenuDisplayState;
|
|
140
|
+
menuItems: import("./menuItems").MenuItemsState;
|
|
141
|
+
modal: import("@open-tender/types").Modal;
|
|
142
|
+
misc: import("./misc").MiscState;
|
|
143
|
+
nav: import("./nav").NavState;
|
|
144
|
+
navSite: import("./navSite").NavSiteState;
|
|
145
|
+
notifications: import("@open-tender/types").Notifications;
|
|
146
|
+
oneTimePasscode: import("./oneTimePasscode").OneTimePasscodeState;
|
|
147
|
+
order: import("./order").OrderState;
|
|
148
|
+
orderFulfillment: import("./orderFulfillment").OrderFulfillmentState;
|
|
149
|
+
orderRating: import("./orderRating").OrderRatingState;
|
|
150
|
+
posts: import("./posts").PostsSlice;
|
|
151
|
+
qr: import("./qr").QrState;
|
|
152
|
+
resetPassword: import("./resetPassword").ResetPasswordState;
|
|
153
|
+
revenueCenters: import("./revenueCenters").RevenueCentersState;
|
|
154
|
+
sidebar: import("./sidebar").SidebarState;
|
|
155
|
+
sidebarModal: import("./sidebarModal").SidebarModalState;
|
|
156
|
+
signUp: import("./signUp").SignUpState;
|
|
157
|
+
tags: import("./tags").TagsState;
|
|
158
|
+
validTimes: import("./validTimes").ValidTimesState;
|
|
159
|
+
verifyAccount: import("./verifyAccount").VerifyAccountState;
|
|
160
|
+
}) => boolean) & import("reselect").OutputSelectorFields<(args_0: {
|
|
161
|
+
pages: AnnouncementPages;
|
|
162
|
+
loading: RequestStatus;
|
|
163
|
+
}) => boolean, {
|
|
164
|
+
clearCache: () => void;
|
|
165
|
+
}> & {
|
|
166
|
+
clearCache: () => void;
|
|
32
167
|
};
|
|
33
|
-
export declare const selectHasAnnouncementsPage: (page: AnnouncementPageType) => (state: AppState) => boolean;
|
|
34
168
|
export declare const announcementsReducer: import("redux").Reducer<AnnouncementsState, import("redux").AnyAction>;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { __awaiter } from "tslib";
|
|
2
|
-
import { createAsyncThunk, createSlice } from '@reduxjs/toolkit';
|
|
2
|
+
import { createAsyncThunk, createSelector, createSlice } from '@reduxjs/toolkit';
|
|
3
3
|
import { ReducerType } from './types';
|
|
4
4
|
const initialState = {
|
|
5
5
|
entities: [],
|
|
@@ -55,17 +55,21 @@ const announcementsSlice = createSlice({
|
|
|
55
55
|
});
|
|
56
56
|
export const { resetAnnouncements } = announcementsSlice.actions;
|
|
57
57
|
export const selectAnnouncements = (state) => state.announcements;
|
|
58
|
-
export const selectAnnouncementsPage = (page) => (state) => {
|
|
58
|
+
export const selectAnnouncementsPage = (page) => createSelector((state) => {
|
|
59
59
|
const { pages, loading, error } = state.announcements;
|
|
60
|
+
return { pages, loading, error };
|
|
61
|
+
}, ({ pages, loading, error }) => {
|
|
60
62
|
const data = pages ? pages.find(i => i.page === page) : undefined;
|
|
61
63
|
const { settings = null, entities = [] } = data || {};
|
|
62
64
|
return { settings, entities, loading, error };
|
|
63
|
-
};
|
|
64
|
-
export const selectHasAnnouncementsPage = (page) => (state) => {
|
|
65
|
+
});
|
|
66
|
+
export const selectHasAnnouncementsPage = (page) => createSelector((state) => {
|
|
65
67
|
const { pages, loading } = state.announcements;
|
|
68
|
+
return { pages, loading };
|
|
69
|
+
}, ({ pages, loading }) => {
|
|
66
70
|
const data = pages ? pages.find(i => i.page === page) : undefined;
|
|
67
71
|
const { entities = [] } = data || {};
|
|
68
72
|
const hasAnnouncements = entities && entities.length;
|
|
69
73
|
return loading === 'pending' || hasAnnouncements ? true : false;
|
|
70
|
-
};
|
|
74
|
+
});
|
|
71
75
|
export const announcementsReducer = announcementsSlice.reducer;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@open-tender/cloud",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.78",
|
|
4
4
|
"description": "A library of hooks, reducers, utility functions, and types for use with Open Tender applications that utilize our cloud-based Order API.",
|
|
5
5
|
"main": "./dist/cjs/index.js",
|
|
6
6
|
"module": "./dist/esm/index.js",
|