Ui 2 shell (#5510)
* Split application into ~/shell * reset.css back to index
This commit is contained in:
parent
cdab1ebc04
commit
2f0ce06cc1
@ -90,6 +90,18 @@
|
|||||||
"visible": true,
|
"visible": true,
|
||||||
"secure": true
|
"secure": true
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"id": "playground",
|
||||||
|
"url": "playground",
|
||||||
|
"src": "Playground",
|
||||||
|
"name": "Playground",
|
||||||
|
"description": "Playground for Parity UI components",
|
||||||
|
"author": "Parity Team <admin@ethcore.io>",
|
||||||
|
"version": "2.0.0",
|
||||||
|
"visible": true,
|
||||||
|
"secure": true,
|
||||||
|
"noselect": true
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"id": "requests",
|
"id": "requests",
|
||||||
"url": "requests",
|
"url": "requests",
|
||||||
@ -145,5 +157,17 @@
|
|||||||
"visible": true,
|
"visible": true,
|
||||||
"secure": true,
|
"secure": true,
|
||||||
"noselect": true
|
"noselect": true
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"id": "web",
|
||||||
|
"url": "web",
|
||||||
|
"src": "Web",
|
||||||
|
"name": "Web",
|
||||||
|
"description": "Embed dapps loaded from the web into the Parity shell",
|
||||||
|
"author": "Parity Team <admin@ethcore.io>",
|
||||||
|
"version": "2.0.0",
|
||||||
|
"visible": true,
|
||||||
|
"secure": true,
|
||||||
|
"noselect": true
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
@ -19,7 +19,7 @@ import BigNumber from 'bignumber.js';
|
|||||||
import { outTransaction } from '@parity/api/format/output';
|
import { outTransaction } from '@parity/api/format/output';
|
||||||
|
|
||||||
import { trackRequest as trackRequestUtil, parseTransactionReceipt } from '~/util/tx';
|
import { trackRequest as trackRequestUtil, parseTransactionReceipt } from '~/util/tx';
|
||||||
import SavedRequests from '~/views/Application/Requests/savedRequests';
|
import SavedRequests from '~/shell/Application/Requests/savedRequests';
|
||||||
|
|
||||||
const savedRequests = new SavedRequests();
|
const savedRequests = new SavedRequests();
|
||||||
|
|
||||||
|
@ -1,78 +0,0 @@
|
|||||||
// Copyright 2015-2017 Parity Technologies (UK) Ltd.
|
|
||||||
// This file is part of Parity.
|
|
||||||
|
|
||||||
// Parity is free software: you can redistribute it and/or modify
|
|
||||||
// it under the terms of the GNU General Public License as published by
|
|
||||||
// the Free Software Foundation, either version 3 of the License, or
|
|
||||||
// (at your option) any later version.
|
|
||||||
|
|
||||||
// Parity is distributed in the hope that it will be useful,
|
|
||||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
// GNU General Public License for more details.
|
|
||||||
|
|
||||||
// You should have received a copy of the GNU General Public License
|
|
||||||
// along with Parity. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
import HistoryStore from '~/mobx/historyStore';
|
|
||||||
import { Application, Dapp, Dapps, Web } from '~/views';
|
|
||||||
import builtinDapps from '~/config/dappsBuiltin.json';
|
|
||||||
import viewsDapps from '~/config/dappsViews.json';
|
|
||||||
|
|
||||||
const dapps = [].concat(viewsDapps, builtinDapps);
|
|
||||||
|
|
||||||
// const accountsHistory = HistoryStore.get('accounts');
|
|
||||||
const dappsHistory = HistoryStore.get('dapps');
|
|
||||||
|
|
||||||
function redirectTo (path) {
|
|
||||||
return (nextState, replace) => {
|
|
||||||
replace(path);
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
const routes = [
|
|
||||||
{ path: '/', onEnter: redirectTo('/apps') },
|
|
||||||
{ path: '/auth', onEnter: redirectTo('/apps') }
|
|
||||||
];
|
|
||||||
|
|
||||||
const childRoutes = [
|
|
||||||
{
|
|
||||||
path: 'app/:id',
|
|
||||||
component: Dapp,
|
|
||||||
onEnter: ({ params }) => {
|
|
||||||
if (!dapps[params.id] || !dapps[params.id].skipHistory) {
|
|
||||||
dappsHistory.add(params.id);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{
|
|
||||||
path: 'app/:id/:details',
|
|
||||||
component: Dapp,
|
|
||||||
onEnter: ({ params }) => {
|
|
||||||
if (!dapps[params.id] || !dapps[params.id].skipHistory) {
|
|
||||||
dappsHistory.add(params.id);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{ path: 'apps', component: Dapps },
|
|
||||||
{ path: 'web', component: Web },
|
|
||||||
{ path: 'web/:url', component: Web }
|
|
||||||
];
|
|
||||||
|
|
||||||
// TODO: use ES6 imports when supported
|
|
||||||
if (process.env.NODE_ENV !== 'production') {
|
|
||||||
const Playground = require('./views/Playground').default;
|
|
||||||
|
|
||||||
childRoutes.push({
|
|
||||||
path: 'playground',
|
|
||||||
component: Playground
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
routes.push({
|
|
||||||
path: '/',
|
|
||||||
component: Application,
|
|
||||||
childRoutes
|
|
||||||
});
|
|
||||||
|
|
||||||
export default routes;
|
|
@ -26,8 +26,9 @@ import store from 'store';
|
|||||||
import imagesEthcoreBlock from '~/../assets/images/parity-logo-white-no-text.svg';
|
import imagesEthcoreBlock from '~/../assets/images/parity-logo-white-no-text.svg';
|
||||||
import { AccountCard, Badge, Button, ContainerTitle, IdentityIcon, SelectionList } from '~/ui';
|
import { AccountCard, Badge, Button, ContainerTitle, IdentityIcon, SelectionList } from '~/ui';
|
||||||
import { CancelIcon, FingerprintIcon } from '~/ui/Icons';
|
import { CancelIcon, FingerprintIcon } from '~/ui/Icons';
|
||||||
import DappsStore from '~/views/Dapps/dappsStore';
|
|
||||||
import Signer from '~/views/Signer/Embedded';
|
import DappsStore from '~/shell/Dapps/dappsStore';
|
||||||
|
import Signer from '~/shell/Signer/Embedded';
|
||||||
|
|
||||||
import AccountStore from './accountStore';
|
import AccountStore from './accountStore';
|
||||||
import styles from './parityBar.css';
|
import styles from './parityBar.css';
|
@ -22,7 +22,6 @@ es6Promise.polyfill();
|
|||||||
|
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import ReactDOM from 'react-dom';
|
import ReactDOM from 'react-dom';
|
||||||
import { AppContainer } from 'react-hot-loader';
|
|
||||||
|
|
||||||
import injectTapEventPlugin from 'react-tap-event-plugin';
|
import injectTapEventPlugin from 'react-tap-event-plugin';
|
||||||
|
|
||||||
@ -34,16 +33,15 @@ import ContextProvider from '~/ui/ContextProvider';
|
|||||||
import muiTheme from '~/ui/Theme';
|
import muiTheme from '~/ui/Theme';
|
||||||
|
|
||||||
import { patchApi } from '~/util/tx';
|
import { patchApi } from '~/util/tx';
|
||||||
import { setApi } from '~/redux/providers/apiActions';
|
|
||||||
|
|
||||||
import '~/environment';
|
import '~/environment';
|
||||||
|
|
||||||
import '../assets/fonts/Roboto/font.css';
|
import '~/../assets/fonts/Roboto/font.css';
|
||||||
import '../assets/fonts/RobotoMono/font.css';
|
import '~/../assets/fonts/RobotoMono/font.css';
|
||||||
|
|
||||||
injectTapEventPlugin();
|
injectTapEventPlugin();
|
||||||
|
|
||||||
import ParityBar from '~/views/ParityBar';
|
import ParityBar from '~/shell/ParityBar';
|
||||||
|
|
||||||
// Test transport (std transport should be provided as global object)
|
// Test transport (std transport should be provided as global object)
|
||||||
class FakeTransport {
|
class FakeTransport {
|
||||||
@ -96,25 +94,15 @@ ContractInstances.get(api);
|
|||||||
|
|
||||||
const store = initStore(api, null, true);
|
const store = initStore(api, null, true);
|
||||||
|
|
||||||
store.dispatch({ type: 'initAll', api });
|
|
||||||
store.dispatch(setApi(api));
|
|
||||||
|
|
||||||
window.secureApi = api;
|
window.secureApi = api;
|
||||||
|
|
||||||
const app = (
|
|
||||||
<ParityBar dapp externalLink={ 'http://127.0.0.1:8180' } />
|
|
||||||
);
|
|
||||||
const container = document.querySelector('#container');
|
|
||||||
|
|
||||||
ReactDOM.render(
|
ReactDOM.render(
|
||||||
<AppContainer>
|
|
||||||
<ContextProvider
|
<ContextProvider
|
||||||
api={ api }
|
api={ api }
|
||||||
muiTheme={ muiTheme }
|
muiTheme={ muiTheme }
|
||||||
store={ store }
|
store={ store }
|
||||||
>
|
>
|
||||||
{ app }
|
<ParityBar dapp externalLink={ 'http://127.0.0.1:8180' } />
|
||||||
</ContextProvider>
|
</ContextProvider>,
|
||||||
</AppContainer>,
|
document.querySelector('#container')
|
||||||
container
|
|
||||||
);
|
);
|
@ -22,26 +22,29 @@ es6Promise.polyfill();
|
|||||||
|
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import ReactDOM from 'react-dom';
|
import ReactDOM from 'react-dom';
|
||||||
import { AppContainer } from 'react-hot-loader';
|
|
||||||
|
|
||||||
import injectTapEventPlugin from 'react-tap-event-plugin';
|
import injectTapEventPlugin from 'react-tap-event-plugin';
|
||||||
import { hashHistory } from 'react-router';
|
import { IndexRoute, Redirect, Route, Router, hashHistory } from 'react-router';
|
||||||
import qs from 'querystring';
|
import qs from 'querystring';
|
||||||
|
|
||||||
import SecureApi from './secureApi';
|
import SecureApi from '~/secureApi';
|
||||||
import ContractInstances from '~/contracts';
|
import ContractInstances from '~/contracts';
|
||||||
|
|
||||||
import { initStore } from './redux';
|
import { initStore } from '~/redux';
|
||||||
import ContextProvider from '~/ui/ContextProvider';
|
import ContextProvider from '~/ui/ContextProvider';
|
||||||
import muiTheme from '~/ui/Theme';
|
import muiTheme from '~/ui/Theme';
|
||||||
import MainApplication from './main';
|
|
||||||
|
|
||||||
import { patchApi } from '~/util/tx';
|
import { patchApi } from '~/util/tx';
|
||||||
|
|
||||||
import './environment';
|
import Application from './Application';
|
||||||
|
import Dapp from './Dapp';
|
||||||
|
import Dapps from './Dapps';
|
||||||
|
|
||||||
import '../assets/fonts/Roboto/font.css';
|
import styles from '~/reset.css';
|
||||||
import '../assets/fonts/RobotoMono/font.css';
|
|
||||||
|
import '~/environment';
|
||||||
|
|
||||||
|
import '~/../assets/fonts/Roboto/font.css';
|
||||||
|
import '~/../assets/fonts/RobotoMono/font.css';
|
||||||
|
|
||||||
injectTapEventPlugin();
|
injectTapEventPlugin();
|
||||||
|
|
||||||
@ -71,26 +74,30 @@ const store = initStore(api, hashHistory);
|
|||||||
|
|
||||||
window.secureApi = api;
|
window.secureApi = api;
|
||||||
|
|
||||||
ReactDOM.render(
|
import HistoryStore from '~/mobx/historyStore';
|
||||||
<AppContainer>
|
import builtinDapps from '~/config/dappsBuiltin.json';
|
||||||
<ContextProvider api={ api } muiTheme={ muiTheme } store={ store }>
|
import viewsDapps from '~/config/dappsViews.json';
|
||||||
<MainApplication routerHistory={ hashHistory } />
|
|
||||||
</ContextProvider>
|
|
||||||
</AppContainer>,
|
|
||||||
document.querySelector('#container')
|
|
||||||
);
|
|
||||||
|
|
||||||
if (module.hot) {
|
const dapps = [].concat(viewsDapps, builtinDapps);
|
||||||
module.hot.accept('./main.js', () => {
|
|
||||||
require('./main.js');
|
|
||||||
|
|
||||||
ReactDOM.render(
|
const dappsHistory = HistoryStore.get('dapps');
|
||||||
<AppContainer>
|
|
||||||
<ContextProvider api={ api } muiTheme={ muiTheme } store={ store }>
|
function onEnterDapp ({ params }) {
|
||||||
<MainApplication routerHistory={ hashHistory } />
|
if (!dapps[params.id] || !dapps[params.id].skipHistory) {
|
||||||
</ContextProvider>
|
dappsHistory.add(params.id);
|
||||||
</AppContainer>,
|
|
||||||
document.querySelector('#container')
|
|
||||||
);
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
ReactDOM.render(
|
||||||
|
<ContextProvider api={ api } muiTheme={ muiTheme } store={ store }>
|
||||||
|
<Router className={ styles.reset } history={ hashHistory }>
|
||||||
|
<Route path='/' component={ Application }>
|
||||||
|
<Redirect from='/auth' to='/' />
|
||||||
|
<Route path='/:id' component={ Dapp } onEnter={ onEnterDapp } />
|
||||||
|
<Route path='/:id/:details' component={ Dapp } onEnter={ onEnterDapp } />
|
||||||
|
<IndexRoute component={ Dapps } />
|
||||||
|
</Route>
|
||||||
|
</Router>
|
||||||
|
</ContextProvider>,
|
||||||
|
document.querySelector('#container')
|
||||||
|
);
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user