Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[WIP] Hot reloading and redesign #43

Closed
wants to merge 61 commits into from
Closed
Changes from 1 commit
Commits
Show all changes
61 commits
Select commit Hold shift + click to select a range
ff62659
Update dependencies
dignifiedquire Sep 19, 2015
093764c
Add travis
dignifiedquire Sep 19, 2015
7eef78d
New build system with hot reloading and babel
dignifiedquire Sep 19, 2015
8da10e4
Start refactoring of views
dignifiedquire Sep 20, 2015
daae181
Fix hot reloading
dignifiedquire Sep 20, 2015
9b314f5
Pretty new start screen
dignifiedquire Sep 20, 2015
fa677b3
Make start button do work
dignifiedquire Sep 21, 2015
a454d13
Start work on profile screen
dignifiedquire Sep 21, 2015
8708ec3
Add simple-stat component
dignifiedquire Sep 21, 2015
8322a2d
Add loader component
dignifiedquire Sep 21, 2015
6a0341d
Tweak window settings
dignifiedquire Sep 21, 2015
a517486
Setup fade transitions
dignifiedquire Sep 22, 2015
2c551e7
Update and clean dependencies
dignifiedquire Sep 22, 2015
0249bbf
Add action buttons with icons to the profile screen
dignifiedquire Sep 22, 2015
4e6c20e
ES201xify controls and use safe-ipc
dignifiedquire Sep 22, 2015
c317a40
Add location display
dignifiedquire Sep 22, 2015
df3028f
Refactor main process code
dignifiedquire Sep 22, 2015
b1d3b37
Remove unused dependency open
dignifiedquire Sep 22, 2015
9c1cc52
misc
dignifiedquire Sep 22, 2015
38a461f
Cleanup dependencies
dignifiedquire Sep 26, 2015
6fa46eb
Updated react-transform config
dignifiedquire Sep 26, 2015
dc9a095
Extract window urls into config
dignifiedquire Sep 26, 2015
08c8de0
More es201x
dignifiedquire Sep 26, 2015
0e162c1
Ignore npm log
dignifiedquire Sep 26, 2015
9d13988
Start work on new welcome screen
dignifiedquire Sep 26, 2015
2ec3391
Improve welcome dialog with a select dir dialog
dignifiedquire Sep 26, 2015
13ef8fd
More work on welcome
dignifiedquire Oct 2, 2015
dd99729
Auto start daemon
dignifiedquire Oct 2, 2015
36af49d
Update dependencies
dignifiedquire Oct 2, 2015
e6799e1
[setup] Add key selection dropdown
dignifiedquire Oct 2, 2015
f0d8c75
Fixes
dignifiedquire Oct 2, 2015
48a4895
[setup] Show and hide options
dignifiedquire Oct 2, 2015
99c181d
Drop silent-chromium as electron now is silent by default
dignifiedquire Oct 6, 2015
c4a35c3
Fix file uploading
dignifiedquire Oct 6, 2015
1ebbd69
Add system notifications for file uploading
dignifiedquire Oct 6, 2015
d95fa77
Add file uploading to main window
dignifiedquire Oct 6, 2015
72cae21
Always be on top
dignifiedquire Oct 6, 2015
3fcca21
Do not show settings for now
dignifiedquire Oct 6, 2015
4a4a8b9
Fix and improve profile buttons
dignifiedquire Oct 6, 2015
04668bc
Cleanup and proper logging
dignifiedquire Oct 6, 2015
4886473
Remove jsxstyle
dignifiedquire Oct 6, 2015
d253ddf
Fix header
dignifiedquire Oct 6, 2015
0abdcd3
Remove unused files
dignifiedquire Oct 6, 2015
54365a9
Remove unused view
dignifiedquire Oct 6, 2015
33f2977
Fixes for start:production
dignifiedquire Oct 6, 2015
949c5ee
Properly handle application quit.
dignifiedquire Oct 7, 2015
9befeda
Fix shutdown when the daemon is stopped
dignifiedquire Oct 7, 2015
14e0918
docs: Start improving the readme documentation
dignifiedquire Oct 7, 2015
09593b2
docs: Drop unused badges
dignifiedquire Oct 7, 2015
f34f203
fix: Rename Quit to Stop
dignifiedquire Oct 7, 2015
f8571b3
refactor: Start work on the welcome screen
dignifiedquire Oct 7, 2015
7711a10
feat: Setup screen is nearly ready
dignifiedquire Oct 7, 2015
beab2d6
feat: Add key size option to advanced setup
dignifiedquire Oct 7, 2015
75101f7
Upgrade to [email protected]
dignifiedquire Oct 11, 2015
3945797
Integrate ipfs logo into the header
dignifiedquire Oct 11, 2015
63aa734
Cleanup settings
dignifiedquire Oct 11, 2015
6b0ca37
Cleanup and reorganise components.
dignifiedquire Oct 11, 2015
1ff9bd8
Update travis config
dignifiedquire Oct 11, 2015
ecb013f
Make packaging work
dignifiedquire Oct 11, 2015
3483763
Try to fix travis
dignifiedquire Oct 12, 2015
e4d5320
packaging: Add app-version number
dignifiedquire Oct 12, 2015
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Refactor main process code
  • Loading branch information
dignifiedquire committed Sep 22, 2015
commit df3028f1808d1c77fc39711778edc672ed5c4d2e
88 changes: 57 additions & 31 deletions app/config.js
Original file line number Diff line number Diff line change
@@ -1,34 +1,60 @@
var path = require('path')
var os = require('os')
var fs = require('fs')
var app = require('app')

var IPFS_PATH_FILE = app.getDataPath() + '/ipfs-electron-app-node-path'

exports = module.exports = {
'menu-bar': {
width: 300,
height: 400
},
window: {
icon: path.resolve(__dirname, '../node_modules/ipfs-logo/ipfs-logo-256-ice.png'),
'auto-hide-menu-bar': true,
width: 800,
height: 600
},
'tray-icon': (os.platform() !== 'darwin'
? path.resolve(__dirname, '../node_modules/ipfs-logo/ipfs-logo-256-ice.png')
: path.resolve(__dirname, '../node_modules/ipfs-logo/platform-icons/osx-menu-bar.png')),
import path from 'path'
import os from 'os'
import fs from 'fs'

const app = require('app')

const isProduction = process.env.NODE_ENV === 'production'
const IPFS_PATH_FILE = app.getDataPath() + '/ipfs-electron-app-node-path'

const trayIcon = () => {
if (os.platform() !== 'darwin') {
return path.resolve(__dirname, '../node_modules/ipfs-logo/ipfs-logo-256-ice.png')
}

return path.resolve(__dirname, '../node_modules/ipfs-logo/platform-icons/osx-menu-bar.png')
}

const menuBar = {
dir: __dirname,
width: 300,
height: 400,
index: isProduction
? `file://${__dirname}/menubar.html`
: 'http://localhost:3000/menubar.html',
icon: trayIcon(),
'always-on-top': !isProduction,
preloadWindow: true,
resizable: false,
'web-preferences': {
'web-security': false
}
}

const window = {
icon: path.resolve(__dirname, '../node_modules/ipfs-logo/ipfs-logo-256-ice.png'),
'auto-hide-menu-bar': true,
width: 800,
height: 600
}

const ipfsPath = () => {
let pathIPFS
try {
pathIPFS = fs.readFileSync(IPFS_PATH_FILE, 'utf-8')
} catch (e) {
pathIPFS = process.env.IPFS_PATH ||
(process.env.HOME || process.env.USERPROFILE) + '/.ipfs'
}

return pathIPFS
}

export default {
menuBar,
window,
'tray-icon': trayIcon(),
'webui-path': '/webui',
'ipfs-path': (function () {
var pathIPFS
try {
pathIPFS = fs.readFileSync(IPFS_PATH_FILE, 'utf-8')
} catch (e) {
pathIPFS = process.env.IPFS_PATH ||
(process.env.HOME || process.env.USERPROFILE) + '/.ipfs'
}
return pathIPFS
})(),
'ipfs-path': ipfsPath(),
'ipfs-path-file': IPFS_PATH_FILE
}
6 changes: 3 additions & 3 deletions app/controls/open-browser.js
Original file line number Diff line number Diff line change
@@ -1,12 +1,12 @@
import ipc from 'electron-safe-ipc/host'
import {apiAddrToUrl} from './utils'
import init from './../init'
import {getIPFS} from './../init'

const shell = require('shell')

function openBrowser (cb) {
if (init.getIPFS()) {
init.getIPFS().config.get('Addresses.API', (err, res) => {
if (getIPFS()) {
getIPFS().config.get('Addresses.API', (err, res) => {
if (err) { // TODO error should be emited to a error panel
return console.error(err)
}
6 changes: 3 additions & 3 deletions app/controls/open-console.js
Original file line number Diff line number Diff line change
@@ -1,13 +1,13 @@
import ipc from 'electron-safe-ipc/host'
import {apiAddrToUrl} from './utils'
import init from './../init'
import {getIPFS} from './../init'
import config from './../config'

const BrowserWindow = require('browser-window')

function openConsole () {
if (init.getIPFS()) {
init.getIPFS().config.get('Addresses.API', (err, res) => {
if (getIPFS()) {
getIPFS().config.get('Addresses.API', (err, res) => {
if (err) { // TODO() error should be emited to a error panel
return console.error(err)
}
34 changes: 34 additions & 0 deletions app/helpers.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
import geoip from 'ipfs-geoip'

function isLocal (address) {
var split = address.split('.')
if (split[0] === '10') return true
if (split[0] === '127') return true
if (split[0] === '192' && split[1] === '168') return true
if (split[0] === '172' && +split[1] >= 16 && +split[1] <= 31) return true
return false
}

export function getLocation (ipfs, multiaddrs, cb) {
if (multiaddrs.length === 0) return cb(null, null)
var address = multiaddrs[0].split('/')[2]
if (isLocal(address)) return getLocation(ipfs, multiaddrs.slice(1), cb)

geoip.lookup(ipfs, address, function (err, res) {
if (err) {
throw err
}

if (!res.country_name && multiaddrs.length > 1) {
return getLocation(ipfs, multiaddrs.slice(1), cb)
}

var location = 'Earth'
if (res.country_name) location = res.country_name + ', ' + location
if (res.region_code) location = res.region_code + ', ' + location
if (res.city) location = res.city + ', ' + location

res.formatted = location
cb(null, res)
})
}
Loading