-
Notifications
You must be signed in to change notification settings - Fork 0
Store Shape
Fahd Ahsan edited this page Jan 13, 2023
·
2 revisions
Store Shape for proj
store = {
session: {},
spots: {
// Notice there are two slices of state within spots. This is to handle your two different routes for getting a spot.
// Refer to your API Docs to get more information.
allSpots: {
[spotId]: {
spotData,
},
// These optional ordered lists are for you to be able to store an order in which you want your data displayed.
// you can do this on the frontend instead of in your slice is state which is why it is optional.
optionalOrderedList: [],
},
// Notice singleSpot has more data that the allSpots slice. Review your API Docs for more information.
singleSpot: {
spotData,
SpotImages: [imagesData],
Owner: {
ownerData,
},
},
},
// Again the idea here is two have separate slices for the different data responses you receive from your routes.
// For example, you could use each of these slices specifically for the component you are dealing with on the frontend.
reviews: {
// When on a single spot, use the spot slice.
spot: {
[reviewId]: {
reviewData,
User: {
userData,
},
ReviewImages: [imagesData],
},
optionalOrderedList: [],
},
// When on the user's reviews, use the user slice.
user: {
[reviewId]: {
reviewData,
User: {
userData,
},
Spot: {
spotData,
},
ReviewImages: [imagesData],
},
optionalOrderedList: [],
},
},
bookings: {
user: {
[bookingId]: {
bookingData,
Spot: {
spotData,
},
},
optionalOrderedList: [],
},
// Note here that your responses can actually be different here as well.
// HINT: What information should you see if you own this spot? (Refer to API Docs).
spot: {
[bookingId]: {
bookingData,
},
optionalOrderedList: [],
},
},
};