Skip to content

Commit

Permalink
Merge pull request #4 from TI-ZA/visuals
Browse files Browse the repository at this point in the history
Visuals
  • Loading branch information
coranos authored Apr 30, 2020
2 parents f84e590 + 98c3e8a commit b3f2deb
Show file tree
Hide file tree
Showing 14 changed files with 202 additions and 772 deletions.
9 changes: 7 additions & 2 deletions index.js
Original file line number Diff line number Diff line change
Expand Up @@ -113,14 +113,19 @@ app.on( 'ready', () => {
width: 780,
height: 520,
frame: false,
titleBarStyle: 'hidden',
// titleBarStyle: 'hidden',
transparent: true,
trafficLightPosition: {x: 15, y: 15},
// trafficLightPosition: {x: 15, y: 15},
maximizable: false,
maxHeight: 520,
// resizable: false,
icon: path.join( __dirname, 'assets/icons/png/64x64.png' ),
webPreferences: {
nodeIntegration: true
}
} );

require('./libraries/electron-traffic-light.js')(mainWindow);

// disable navigation window.
mainWindow.setMenu( null );
Expand Down
173 changes: 173 additions & 0 deletions libraries/electron-traffic-light.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,173 @@

/**
* win: Browser Window to inject traffic-light
* options:
* Object: style: traffic-light style //TODO
* Function: shouldAddTrafficLight (url) => trueOrFlase. determine inject traffic or not
* Function: shouldAddDragBar (url) => trueOrFlase. determine inject drag bar or not
* return EventEmitter
*
* Events:
* 'minimize'
* 'maximize'
* 'close'
* 'fullscreen'
**/
const {BrowserWindow, ipcMain} = require('electron')
const fs = require('fs')
const path = require('path')
const EventEmitter = require('events');

function cssJS() {
return `
var style = document.createElement('style');
style.type = 'text/css';
style.innerHTML = \`
#drag-bar {
-webkit-app-region:no-drag; position: fixed;
height: 50px;
width: 80px;
top: 0;
left: 0;
user-select: none;
z-index: 1;
}
#traffic-light {
display: flex;
justify-content: space-between;
width: 52px;
position: fixed;
z-index: 2;
left: 12px;
top: 19px;
}
[data-type=close] {
background-image: url('')
}
#traffic-light:hover [data-type=close] {
background-image: url('')
}
[data-type=min] {
background-image: url('')
}
#traffic-light:hover [data-type=min] {
background-image: url('')
}
[data-type=fullscreen] {
background-image: url('')
}
#traffic-light:hover [data-type=fullscreen] {
background-image: url('')
}
#traffic-light [data-type] {
width: 12px;
height: 12px;
display: flex;
align-items: center;
justify-content: center;
background-size: 12px;
}
\`
document.getElementsByTagName('head')[0].appendChild(style);
`
}
function dragBarJS(id) {
return `
let div = document.createElement('div')
div.setAttribute('id', 'drag-bar')
div.ondblclick = (e) => {
if(e.target && e.target.nodeName.toUpperCase == 'SPAN') {
}
window.require('electron').ipcRenderer.send('electron-traffic-light:${id}.toggleMax');
};
document.body.append(div)
`
}
function trafficLightJS(id) {
return `
const trafficLight = document.createElement('div');
trafficLight.setAttribute('id', 'traffic-light')
trafficLight.innerHTML = \`
<div data-type="close"></div>
<div data-type="min"></div>
<div data-type="fullscreen"></div>
\`
document.body.append(trafficLight)
trafficLight.onclick = (e) => {
if(e.target && e.target.dataset && ~['close', 'min'].indexOf(e.target.dataset.type)) {
window.require('electron').ipcRenderer.send('electron-traffic-light:${id}.' + e.target.dataset.type);
}
}
`
}

// TODO:
// * README
// * test
// * fullscreen then change icon
// * options + fullscreen = max
// * blur => icon change to grey
// * options:
// trafficlight:
// minmizable, maximizable, closable
// line-height, with

module.exports = function inject(win, options={}) {
if(!win || !(win instanceof BrowserWindow)) return;
const trafficLightEmitter = new EventEmitter();
const { webContents } = win
let bounds = options.bounds || win.getBounds()

webContents.on('dom-ready', e => {
let currentUrl = webContents.getURL()
webContents.executeJavaScript(cssJS())
if(!options.shouldAddTrafficLight || options.shouldAddTrafficLight(currentUrl)) {
webContents.executeJavaScript(trafficLightJS(win.id))
}

if(!options.shouldAddDragBar || options.shouldAddDragBar(currentUrl)) {
webContents.executeJavaScript(dragBarJS(win.id))
}
})

// ipcHandle
ipcMain.on(`electron-traffic-light:${win.id}.toggleMax`, () => {
if(win.isFullScreen()) {
win.setFullScreen(false);
win.setBounds(bounds, true);
} else if(win.isMaximized()) {
// mainWindow.maximize();
win.setBounds(bounds, true);
} else {
win.maximize()
}
})

ipcMain.on(`electron-traffic-light:${win.id}.fullscreen`, () => {
win.setFullScreen(!win.isFullScreen());
if(win.isFullScreen()) {
trafficLightEmitter.emit('fullscreen')
win.setFullScreen(false);
} else {
trafficLightEmitter.emit('reset-fullscreen')
win.setFullScreen(true);
}
})

ipcMain.on(`electron-traffic-light:${win.id}.min`, () => {
win.minimize()
trafficLightEmitter.emit('set-minimize')
})

ipcMain.on(`electron-traffic-light:${win.id}.close`, () => {
if (win.isFullScreen()) {
win.setFullScreen(false);
win.setBounds(bounds, true);
} else {
win.close();
}
trafficLightEmitter.emit('set-close')
})

return trafficLightEmitter
}
2 changes: 1 addition & 1 deletion scripts/App.js
Original file line number Diff line number Diff line change
Expand Up @@ -753,7 +753,7 @@ const requestListOfCandidateVotes = () => {
if (address !== undefined) {
candidateVoteListStatus = 'Loading Votes, Please Wait';

const txUrl = `${getRestService()}/api/v1/dpos/address/${address}?pageSize=5000&pageNum=1`;
const txUrl = `${getRestService()}/api/v1/dpos/address/${address}?pageSize=1&pageNum=1`;
// mainConsole.log('requestListOfCandidateVotes', txUrl);

renderApp();
Expand Down
15 changes: 15 additions & 0 deletions style.css
Original file line number Diff line number Diff line change
Expand Up @@ -5,8 +5,18 @@ body {
width: 780;
background-color: rgba (0, 0, 0);
background-image: url(artwork/BG7.svg);
-webkit-app-region: drag;
}

button,
a,
p,
img,
textarea,
input,
select {
-webkit-app-region: no-drag;
}
@font-face {
font-family: "BioSans-Regular";
src: url("artwork/biosans-regular.otf");
Expand Down Expand Up @@ -132,6 +142,10 @@ html {
background-image: linear-gradient(-180deg, #33373D 0%, rgba(51, 55, 61, 0.00) 130%);
}

.dark-hover {
-webkit-app-region: no-drag;
}

.dark-hover:hover {
background: rgba(151, 153, 166, 0.16);
}
Expand Down Expand Up @@ -293,6 +307,7 @@ html {
background-image: linear-gradient(-180deg, #33373D 0%, rgba(51, 55, 61, 0.00) 130%);
border-radius: 0 0 16.71px 16.71px;
grid-area: top-center;
-webkit-app-region: no-drag;
}

.send-bg {
Expand Down
43 changes: 1 addition & 42 deletions views/generate-mnemonic.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,6 @@ module.exports = (props) => {
<div className="flex1"></div>
</div>
<p className="address-text font_size24 margin_none display_inline_block gradient-font">Create New Wallet (Mnemonics)</p>
{/* <textarea className="qraddress-div color_white textarea-placeholder padding_5px" type="text" rows="4" cols="50" id="mnemonic" placeholder="Enter 12 word mnemonic/seed phrase"></textarea> */}
<div className="qraddress-div">
<p className="address-ex display_inline_block font_size14 padding_5px">{App.getGeneratedMnemonic()}</p>
</div>
Expand All @@ -36,44 +35,4 @@ module.exports = (props) => {

</div>
</div>);
}








// <table id="generateMnemonic" className="w750h520px color_white no_padding no_border">
// <tbody>
// <tr>
// <td>
// <div className="">New Mnemonic</div>
// <br/>
// <br/>
// {App.getGeneratedMnemonic()}
// <br/>
// <br/>
// <hr/>
// <strong>
// Reminder: Save this Mnemonicy.
// <br/>
// If you lose this Mnemonic, there will be no way to recover your coins.
// <br/>
// Keep a backup of it in a safe place.
// <br/>
// To use this key, copy it (you can use the convenient copy button), and use to log in to the wallet.
// <br/>
// </strong>
// <br/>
// <div className="h25px bordered display_inline_block bgcolor_black_hover" onClick={(e) => regenerate()}>Regenerate</div>
// <div className="h25px bordered display_inline_block bgcolor_black_hover" onClick={(e) => App.copyMnemonicToClipboard()}>Copy</div>
// <div className="h25px bordered display_inline_block bgcolor_black_hover" onClick={(e) => GuiToggles.showLanding()}>Done</div>
// <br/>
// </td>
// </tr>
// </tbody>
// </table>
// );
// }
}
Loading

0 comments on commit b3f2deb

Please sign in to comment.