2017-02-07 10:18:38 -08:00
|
|
|
'use strict';
|
2017-02-07 09:03:00 -08:00
|
|
|
|
|
|
|
// This file just a dummy example of a HTTP API to talk to the backend.
|
|
|
|
// The state of the "database" that would normally live on the server
|
|
|
|
// is simply held here in memory.
|
|
|
|
|
|
|
|
const backendStateForLoggedInPerson = {
|
|
|
|
chats: [
|
|
|
|
{
|
|
|
|
name: 'Claire',
|
|
|
|
messages: [
|
|
|
|
{
|
|
|
|
name: 'Claire',
|
|
|
|
text: 'I ❤️ React Native!',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 'John',
|
|
|
|
messages: [
|
|
|
|
{
|
|
|
|
name: 'John',
|
|
|
|
text: 'I ❤️ React Native!',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
}
|
|
|
|
],
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Randomly simulate network failures.
|
|
|
|
* It is useful to enable this during development to make sure our app works
|
|
|
|
* in real-world conditions.
|
|
|
|
*/
|
|
|
|
function isNetworkFailure() {
|
|
|
|
const chanceOfFailure = 0; // 0..1
|
|
|
|
return Math.random() < chanceOfFailure;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Helper for the other functions in this file.
|
|
|
|
* Simulates a short delay and then returns a provided value or failure.
|
|
|
|
* This is just a dummy example. Normally we'd make a HTTP request,
|
|
|
|
* see http://facebook.github.io/react-native/docs/network.html
|
|
|
|
*/
|
|
|
|
function _makeSimulatedNetworkRequest(getValue) {
|
|
|
|
const durationMs = 400;
|
|
|
|
return new Promise(function (resolve, reject) {
|
|
|
|
setTimeout(function () {
|
|
|
|
if (isNetworkFailure()) {
|
|
|
|
reject(new Error('Network failure'));
|
|
|
|
} else {
|
|
|
|
getValue(resolve, reject);
|
|
|
|
}
|
|
|
|
}, durationMs);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fetch a list of all chats for the logged in person.
|
|
|
|
*/
|
|
|
|
async function fetchChatList() {
|
|
|
|
return _makeSimulatedNetworkRequest((resolve, reject) => {
|
2017-02-07 10:18:38 -08:00
|
|
|
resolve(backendStateForLoggedInPerson.chats.map(chat => chat.name));
|
2017-02-07 09:03:00 -08:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fetch a single chat.
|
|
|
|
*/
|
|
|
|
async function fetchChat(name) {
|
|
|
|
return _makeSimulatedNetworkRequest((resolve, reject) => {
|
|
|
|
resolve(
|
|
|
|
backendStateForLoggedInPerson.chats.find(
|
|
|
|
chat => chat.name === name
|
|
|
|
)
|
2017-02-07 10:18:38 -08:00
|
|
|
);
|
2017-02-07 09:03:00 -08:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Send given message to given person.
|
|
|
|
*/
|
|
|
|
async function sendMessage({name, message}) {
|
|
|
|
return _makeSimulatedNetworkRequest((resolve, reject) => {
|
2017-02-07 10:18:38 -08:00
|
|
|
const chatForName = backendStateForLoggedInPerson.chats.find(
|
2017-02-07 09:03:00 -08:00
|
|
|
chat => chat.name === name
|
|
|
|
);
|
2017-02-07 10:18:38 -08:00
|
|
|
if (chatForName) {
|
|
|
|
chatForName.messages.push({
|
2017-02-07 09:03:00 -08:00
|
|
|
name: 'Me',
|
|
|
|
text: message,
|
|
|
|
});
|
|
|
|
resolve();
|
|
|
|
} else {
|
|
|
|
reject(new Error('Uknown person: ' + name));
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
const Backend = {
|
|
|
|
fetchChatList,
|
|
|
|
fetchChat,
|
|
|
|
sendMessage,
|
|
|
|
};
|
|
|
|
|
|
|
|
export default Backend;
|
|
|
|
|
|
|
|
// In case you are looking into using Redux for state management,
|
|
|
|
// this is how network requests are done in the f8 app which uses Redux:
|
|
|
|
// - To load some data, a Component fires a Redux action, such as loadSession()
|
|
|
|
// - That action makes the HTTP requests and then dispatches a redux action
|
|
|
|
// {type: 'LOADED_SESSIONS', results}
|
|
|
|
// - Then all reducers get called and one of them updates a part of the application
|
|
|
|
// state by storing the results
|
|
|
|
// - Redux re-renders the connected Components
|
|
|
|
// See https://github.com/fbsamples/f8app/search?utf8=%E2%9C%93&q=loaded_sessions
|