2017-08-27 14:29:37 -05:00
|
|
|
// @flow
|
2017-10-22 12:38:05 -05:00
|
|
|
import { memoize } from 'ramda';
|
2017-11-11 20:15:19 -06:00
|
|
|
import FilterRecord from '../records/FilterRecord';
|
2018-02-04 13:14:37 -06:00
|
|
|
import FoodItemRecord from '../records/FoodItemRecord';
|
2018-03-10 11:54:12 -06:00
|
|
|
import AuthManager from '../AuthManager';
|
2018-04-08 10:54:29 -05:00
|
|
|
import { map, path, nth } from 'ramda';
|
|
|
|
|
import { addImage } from './ImagesApi';
|
|
|
|
|
import { fetchRequest } from './FetchApi';
|
2017-10-29 20:18:33 -05:00
|
|
|
|
2017-10-22 12:38:05 -05:00
|
|
|
export type FoodItemsFilter = {
|
|
|
|
|
radius?: number,
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
export type RawFoodItem = {
|
|
|
|
|
id: string,
|
|
|
|
|
name: string,
|
2018-04-08 10:54:29 -05:00
|
|
|
placeid: string,
|
2017-10-22 12:38:05 -05:00
|
|
|
category: string,
|
|
|
|
|
images: string,
|
|
|
|
|
thumbimage: string,
|
|
|
|
|
latitude: number,
|
|
|
|
|
longitude: number,
|
|
|
|
|
distance: number,
|
2017-11-19 12:22:09 -06:00
|
|
|
lastupdated: number,
|
2017-10-22 12:38:05 -05:00
|
|
|
};
|
2017-08-27 14:29:37 -05:00
|
|
|
|
2017-10-22 12:38:05 -05:00
|
|
|
export type FoodItemsForLocation = {
|
|
|
|
|
orderby: string,
|
|
|
|
|
filter: FoodItemsFilter,
|
2018-04-28 13:12:38 -05:00
|
|
|
fooditems: ?Array<RawFoodItem>,
|
2017-08-27 14:29:37 -05:00
|
|
|
};
|
2017-10-22 12:38:05 -05:00
|
|
|
|
2018-02-04 13:14:37 -06:00
|
|
|
export const getFoodItems = memoize(
|
|
|
|
|
async ({
|
|
|
|
|
loc,
|
|
|
|
|
filter,
|
|
|
|
|
}: {
|
|
|
|
|
loc: Position,
|
|
|
|
|
filter: FilterRecord,
|
|
|
|
|
}): Promise<FoodItemsForLocation> => {
|
2018-04-28 13:12:38 -05:00
|
|
|
const {
|
|
|
|
|
coords: { latitude: lat, longitude: lng },
|
|
|
|
|
} = loc;
|
2018-02-04 13:14:37 -06:00
|
|
|
const { orderby, categories, radius } = filter;
|
2017-11-11 20:15:19 -06:00
|
|
|
|
2018-02-04 13:14:37 -06:00
|
|
|
try {
|
2018-02-11 09:53:53 -06:00
|
|
|
return fetchRequest({
|
|
|
|
|
endpoint: '/fooditems',
|
2018-02-04 13:14:37 -06:00
|
|
|
method: 'POST',
|
2018-02-11 09:53:53 -06:00
|
|
|
body: {
|
2018-02-04 13:14:37 -06:00
|
|
|
lat,
|
|
|
|
|
lng,
|
|
|
|
|
orderby,
|
|
|
|
|
filter: {
|
|
|
|
|
...(categories ? { categories } : {}),
|
|
|
|
|
radius,
|
|
|
|
|
},
|
2018-02-11 09:53:53 -06:00
|
|
|
},
|
|
|
|
|
}).then(json => ({
|
|
|
|
|
...json,
|
|
|
|
|
loading: false,
|
|
|
|
|
error: null,
|
|
|
|
|
}));
|
2018-02-04 13:14:37 -06:00
|
|
|
} catch (error) {
|
2018-04-08 10:54:29 -05:00
|
|
|
console.log(error); // eslint-disable-line no-console
|
2018-02-04 13:14:37 -06:00
|
|
|
return {
|
|
|
|
|
orderby: 'distance',
|
|
|
|
|
filter: {},
|
|
|
|
|
fooditems: [],
|
2017-10-22 12:38:05 -05:00
|
|
|
loading: false,
|
2018-02-04 13:14:37 -06:00
|
|
|
error: error,
|
|
|
|
|
};
|
|
|
|
|
}
|
2017-10-22 12:38:05 -05:00
|
|
|
}
|
2018-02-04 13:14:37 -06:00
|
|
|
);
|
|
|
|
|
|
2018-02-11 09:53:53 -06:00
|
|
|
export const createFoodItem = async (foodItem: FoodItemRecord) => {
|
|
|
|
|
const res = await fetchRequest({
|
|
|
|
|
endpoint: '/addfooditem',
|
|
|
|
|
method: 'POST',
|
|
|
|
|
body: foodItem,
|
2018-02-04 13:14:37 -06:00
|
|
|
});
|
2018-02-25 12:25:24 -06:00
|
|
|
|
2018-03-10 11:54:12 -06:00
|
|
|
if (!AuthManager.user) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const username = AuthManager.user.name;
|
|
|
|
|
|
2018-04-08 10:54:29 -05:00
|
|
|
const addImageUri = (imageUri: string) => addImage({ foodItemId: res.id, imageUri, username });
|
|
|
|
|
|
|
|
|
|
const images = map(path(['url']), await Promise.all(map(addImageUri, foodItem.images.toArray())));
|
2018-02-25 12:25:24 -06:00
|
|
|
|
|
|
|
|
return {
|
|
|
|
|
...res,
|
|
|
|
|
images,
|
2018-04-08 10:54:29 -05:00
|
|
|
thumbimage: nth(0, images),
|
2018-02-25 12:25:24 -06:00
|
|
|
};
|
2018-02-04 13:14:37 -06:00
|
|
|
};
|