-
Notifications
You must be signed in to change notification settings - Fork 5
/
app.js
93 lines (81 loc) · 2.72 KB
/
app.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
// @flow
/**
* This file provided by Facebook is for non-commercial testing and evaluation
* purposes only. Facebook reserves all rights not expressly granted.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
* FACEBOOK BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
* ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
*/
import 'todomvc-common';
import * as React from 'react';
import ReactDOM from 'react-dom';
import {graphql} from 'react-relay';
import {QueryRenderer} from 'react-relay-offline';
import {
Network,
type RequestNode,
type Variables,
} from 'relay-runtime';
//import { OfflineStore, Store, Environment, RecordSource} from 'react-relay-offline';
import EnvironmentIDB from 'react-relay-offline/lib/runtime/EnvironmentIDB';
import TodoApp from './components/TodoApp';
import type {appQueryResponse} from 'relay/appQuery.graphql';
async function fetchQuery(
operation: RequestNode,
variables: Variables,
): Promise<{}> {
const response = await fetch('/graphql', {
method: 'POST',
headers: {
'Content-Type': 'application/json',
},
body: JSON.stringify({
query: operation.text,
variables,
}),
});
return response.json();
}
import RelayNetworkLogger from 'relay-runtime/lib/RelayNetworkLogger'
const network = Network.create(RelayNetworkLogger.wrapFetch(fetchQuery, () => ''));
function callbackOffline(type, payload, error) {
//console.log("callbackoffline", type)
//console.log("callbackoffline", payload)
//console.log("callbackoffline", error)
}
const modernEnvironment = EnvironmentIDB.create({ network }, callbackOffline);
const rootElement = document.getElementById('root');
if (rootElement) {
ReactDOM.render(
<QueryRenderer
environment={modernEnvironment}
dataFrom="CACHE_FIRST"
query={graphql`
query appQuery($userId: String) {
user(id: $userId) {
...TodoApp_user
}
}
`}
variables={{
// Mock authenticated ID that matches database
userId: 'me',
}}
render={({error, props, cached, retry}) => {
//console.log('QueryRenderer.render:', { cached, error, retry, state: modernEnvironment.getStoreOffline().getState(),
// });
if (props && props.user) {
return <TodoApp user={props.user} />;
} else if (error) {
return <div>{error.message}</div>;
}
return <div>Loading</div>;
}}
/>,
rootElement,
);
}