Skip to content
This repository has been archived by the owner on Nov 6, 2020. It is now read-only.

Commit

Permalink
Add position to Dapp Manifest
Browse files Browse the repository at this point in the history
  • Loading branch information
ngotchac committed Jan 18, 2017
1 parent 74550a5 commit d12c9f8
Show file tree
Hide file tree
Showing 4 changed files with 61 additions and 36 deletions.
4 changes: 2 additions & 2 deletions js/src/views/Application/application.js
Original file line number Diff line number Diff line change
Expand Up @@ -54,7 +54,7 @@ class Application extends Component {
upgradeStore = new UpgradeStore(this.context.api);

render () {
const [root, hash = ''] = (window.location.hash || '').replace('#/', '').split('/');
const [root] = (window.location.hash || '').replace('#/', '').split('/');
const isMinimized = root === 'app' || root === 'web';

if (inFrame) {
Expand All @@ -67,7 +67,7 @@ class Application extends Component {
<div>
{ isMinimized ? this.renderMinimized() : this.renderApp() }
<Connection />
<ParityBar dapp={ isMinimized } hash={ hash || root } />
<ParityBar dapp={ isMinimized } />
</div>
);
}
Expand Down
1 change: 1 addition & 0 deletions js/src/views/Dapps/builtin.json
Original file line number Diff line number Diff line change
Expand Up @@ -81,6 +81,7 @@
"description": "A Javascript development console complete with web3 and parity objects.",
"version": "0.3",
"author": "Gav Wood <[email protected]>",
"position": "top-right",
"visible": true
}
]
29 changes: 20 additions & 9 deletions js/src/views/Dapps/dappsStore.js
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@
// You should have received a copy of the GNU General Public License
// along with Parity. If not, see <http://www.gnu.org/licenses/>.

import EventEmitter from 'eventemitter3';
import { action, computed, observable, transaction } from 'mobx';
import store from 'store';

Expand All @@ -30,7 +31,7 @@ const BUILTIN_APPS_KEY = 'BUILTIN_APPS_KEY';

let instance = null;

export default class DappsStore {
export default class DappsStore extends EventEmitter {
@observable apps = [];
@observable displayApps = {};
@observable modalOpen = false;
Expand All @@ -44,13 +45,27 @@ export default class DappsStore {
_registryAppsIds = null;

constructor (api) {
super();

this._api = api;

this.readDisplayApps();
this.loadExternalOverlay();
this.subscribeToChanges();
}

static get (api) {
if (!instance) {
instance = new DappsStore(api);
}

if (api && !instance._api) {
instance._api = api;
}

return instance;
}

/**
* Try to find the app from the local (local or builtin)
* apps, else fetch from the node
Expand All @@ -68,6 +83,10 @@ export default class DappsStore {
}

return this.fetchRegistryApp(dappReg, id, true);
})
.then((app) => {
this.emit('loaded', app);
return app;
});
}

Expand All @@ -90,14 +109,6 @@ export default class DappsStore {
.then(this.writeDisplayApps);
}

static get (api) {
if (!instance) {
instance = new DappsStore(api);
}

return instance;
}

subscribeToChanges () {
const { dappReg } = Contracts.get();

Expand Down
63 changes: 38 additions & 25 deletions js/src/views/ParityBar/parityBar.js
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ import store from 'store';
import { CancelIcon, FingerprintIcon } from '~/ui/Icons';
import { Badge, Button, ContainerTitle, ParityBackground } from '~/ui';
import { Embedded as Signer } from '../Signer';
import DappsStore from '~/views/Dapps/dappsStore';

import imagesEthcoreBlock from '../../../assets/images/parity-logo-white-no-text.svg';
import styles from './parityBar.css';
Expand All @@ -32,14 +33,13 @@ const LS_STORE_KEY = '_parity::parityBar';
const DEFAULT_POSITION = { right: '1em', bottom: 0 };

class ParityBar extends Component {
app = null;
measures = null;
moving = false;

static propTypes = {
dapp: PropTypes.bool,
hash: PropTypes.string,
pending: PropTypes.array,
root: PropTypes.string
pending: PropTypes.array
};

state = {
Expand All @@ -48,12 +48,6 @@ class ParityBar extends Component {
position: DEFAULT_POSITION
};

getAppId (props = this.props) {
const { hash = '-1' } = props;

return hash;
}

constructor (props) {
super(props);

Expand All @@ -62,22 +56,19 @@ class ParityBar extends Component {
40,
{ leading: true, trailing: true }
);
}

componentWillMount () {
// Load the saved position of the Parity Bar
this.loadPosition();
// Hook to the dapp loaded event to position the
// Parity Bar accordingly
DappsStore.get().on('loaded', (app) => {
this.app = app;
this.loadPosition();
});
}

componentWillReceiveProps (nextProps) {
const count = this.props.pending.length;
const newCount = nextProps.pending.length;

// Reload the Bar position when changing dapps
if (nextProps.dapp && nextProps.hash !== this.props.hash) {
this.loadPosition(nextProps);
}

if (count === newCount) {
return;
}
Expand Down Expand Up @@ -435,21 +426,43 @@ class ParityBar extends Component {
}

loadPosition (props = this.props) {
const { config } = this;
const appId = this.getAppId(props);
const { app, config } = this;

if (!app) {
return this.setState({ position: DEFAULT_POSITION });
}

const position = config[appId] || { ...DEFAULT_POSITION };
if (config[app.id]) {
return this.setState({ position: config[app.id] });
}

const position = this.stringToPosition(app.position);
this.setState({ position });
}

savePosition (position) {
const { config } = this;
const appId = this.getAppId();

config[appId] = position;
const { app, config } = this;
config[app.id] = position;

store.set(LS_STORE_KEY, JSON.stringify(config));
}

stringToPosition (value) {
switch (value) {
case 'top-left':
return { top: 0, left: '1em' };

case 'top-right':
return { top: 0, right: '1em' };

case 'bottom-left':
return { bottom: 0, left: '1em' };

case 'bottom-right':
default:
return DEFAULT_POSITION;
}
}
}

function mapStateToProps (state) {
Expand Down

0 comments on commit d12c9f8

Please sign in to comment.