Browse Source

Merge pull request #85 from torkelrogstad/lint

Lint
renovate/lint-staged-8.x
JimmyMow 7 years ago
committed by GitHub
parent
commit
3795936861
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
  1. 2
      .eslintrc
  2. 2
      app/components/ChannelForm/StepOne.js
  3. 2
      app/components/LndSyncing/LndSyncing.js
  4. 12
      app/containers/Root.js
  5. 22
      app/index.js
  6. 2
      app/lnd/config/index.js
  7. 42
      app/lnd/utils/index.js
  8. 2
      app/reducers/channels.js
  9. 34
      app/store/configureStore.dev.js
  10. 4
      app/store/configureStore.js
  11. 2
      internals/mocks/fileMock.js
  12. 16
      internals/scripts/CheckBuiltsExist.js
  13. 8
      internals/scripts/CheckNodeEnv.js
  14. 3
      test/components/Nav.spec.js
  15. 6
      test/example.js
  16. 11
      test/reducers/__snapshots__/peers.spec.js.snap
  17. 12
      test/runTests.js
  18. 6
      webpack.config.base.js
  19. 4
      webpack.config.eslint.js
  20. 16
      webpack.config.main.prod.js
  21. 18
      webpack.config.renderer.dev.dll.js
  22. 20
      webpack.config.renderer.prod.js

2
.eslintrc

@ -11,7 +11,7 @@
},
"rules": {
"comma-dangle": ["error", "never"],
"semi": 0,
"semi": ["error", "never"],
"indent": 2,
"jsx-quotes": ["error", "prefer-single"],
"react/jsx-filename-extension": [1, { "extensions": [".js", ".jsx"] }],

2
app/components/ChannelForm/StepOne.js

@ -5,7 +5,7 @@ import styles from './StepOne.scss'
class StepOne extends Component {
constructor(props) {
super(props);
super(props)
this.state = {
peers: props.peers,
searchQuery: ''

2
app/components/LndSyncing/LndSyncing.js

@ -4,7 +4,7 @@ import styles from './LndSyncing.scss'
class LndSyncing extends Component {
constructor(props) {
super(props);
super(props)
this.state = {
facts: [
{

12
app/containers/Root.js

@ -3,9 +3,10 @@ import React from 'react'
import { Provider, connect } from 'react-redux'
import { ConnectedRouter } from 'react-router-redux'
import PropTypes from 'prop-types'
import { fetchBlockHeight, lndSelectors } from 'reducers/lnd'
import LoadingBolt from 'components/LoadingBolt'
import LndSyncing from 'components/LndSyncing'
import LoadingBolt from '../components/LoadingBolt'
import LndSyncing from '../components/LndSyncing'
import { fetchBlockHeight, lndSelectors } from '../reducers/lnd'
import Routes from '../routes'
const mapDispatchToProps = {
@ -18,11 +19,6 @@ const mapStateToProps = state => ({
syncPercentage: lndSelectors.syncPercentage(state)
})
type RootType = {
store: {},
history: {}
};
const Root = ({
store,
history,

22
app/index.js

@ -1,27 +1,27 @@
import React from 'react';
import { render } from 'react-dom';
import { AppContainer } from 'react-hot-loader';
import Root from './containers/Root';
import { configureStore, history } from './store/configureStore';
import './app.global.scss';
import React from 'react'
import { render } from 'react-dom'
import { AppContainer } from 'react-hot-loader'
import Root from './containers/Root'
import { configureStore, history } from './store/configureStore'
import './app.global.scss'
const store = configureStore();
const store = configureStore()
render(
<AppContainer>
<Root store={store} history={history} />
</AppContainer>,
document.getElementById('root')
);
)
if (module.hot) {
module.hot.accept('./containers/Root', () => {
const NextRoot = require('./containers/Root'); // eslint-disable-line global-require
const NextRoot = require('./containers/Root') // eslint-disable-line global-require
render(
<AppContainer>
<NextRoot store={store} history={history} />
</AppContainer>,
document.getElementById('root')
);
});
)
})
}

2
app/lnd/config/index.js

@ -8,7 +8,7 @@ import { join } from 'path'
let loc
switch (platform()) {
case 'darwin':
loc = 'Library/Application\ Support/Lnd/tls.cert'
loc = 'Library/Application Support/Lnd/tls.cert'
break
case 'linux':
loc = '.lnd/tls.cert'

42
app/lnd/utils/index.js

@ -0,0 +1,42 @@
import zbase32 from 'zbase32'
function convertBigEndianBufferToLong(longBuffer) {
let longValue = 0
const byteArray = Buffer.from(longBuffer).swap64()
for (let i = byteArray.length - 1; i >= 0; i -= 1) {
longValue = (longValue * 256) + byteArray[i]
}
return longValue
}
export function decodeInvoice(payreq) {
const payreqBase32 = zbase32.decode(payreq)
const bufferHexRotated = Buffer.from(payreqBase32).toString('hex')
const bufferHex = bufferHexRotated.substr(bufferHexRotated.length - 1, bufferHexRotated.length)
+ bufferHexRotated.substr(0, bufferHexRotated.length - 1)
const buffer = Buffer.from(bufferHex, 'hex')
const pubkeyBuffer = buffer.slice(0, 33)
const pubkey = pubkeyBuffer.toString('hex')
const paymentHashBuffer = buffer.slice(33, 65)
const paymentHashHex = paymentHashBuffer.toString('hex')
const valueBuffer = buffer.slice(65, 73)
const amount = convertBigEndianBufferToLong(valueBuffer)
return {
payreq,
pubkey,
amount,
r_hash: paymentHashHex
}
}
export default {
decodeInvoice
}

2
app/reducers/channels.js

@ -200,7 +200,7 @@ export const channelGraphData = (event, data) => (dispatch, getState) => {
dispatch(fetchDescribeNetwork())
// loop through the channel updates
for (let i = 0; i < channel_updates.length; i++) {
for (let i = 0; i < channel_updates.length; i += 1) {
const channel_update = channel_updates[i]
const { advertising_node, connecting_node } = channel_update

34
app/store/configureStore.dev.js

@ -6,31 +6,31 @@ import { createLogger } from 'redux-logger'
import rootReducer from '../reducers'
import ipc from '../reducers/ipc'
const history = createHashHistory();
const history = createHashHistory()
const configureStore = (initialState?: counterStateType) => {
// Redux Configuration
const middleware = [];
const enhancers = [];
const middleware = []
const enhancers = []
// Thunk Middleware
middleware.push(thunk);
middleware.push(thunk)
// Logging Middleware
const logger = createLogger({
level: 'info',
collapsed: true
});
middleware.push(logger);
})
middleware.push(logger)
// Router Middleware
const router = routerMiddleware(history);
middleware.push(router);
const router = routerMiddleware(history)
middleware.push(router)
// Redux DevTools Configuration
const actionCreators = {
...routerActions
};
}
// If Redux DevTools Extension is installed use it, otherwise use Redux compose
/* eslint-disable no-underscore-dangle */
const composeEnhancers = window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__
@ -38,23 +38,23 @@ const configureStore = (initialState?: counterStateType) => {
// Options: http://zalmoxisus.github.io/redux-devtools-extension/API/Arguments.html
actionCreators
})
: compose;
: compose
/* eslint-enable no-underscore-dangle */
// Apply Middleware & Compose Enhancers
enhancers.push(applyMiddleware(...middleware, ipc));
const enhancer = composeEnhancers(...enhancers);
enhancers.push(applyMiddleware(...middleware, ipc))
const enhancer = composeEnhancers(...enhancers)
// Create Store
const store = createStore(rootReducer, initialState, enhancer);
const store = createStore(rootReducer, initialState, enhancer)
if (module.hot) {
module.hot.accept('../reducers', () =>
store.replaceReducer(require('../reducers')) // eslint-disable-line global-require
);
)
}
return store;
};
return store
}
export default { configureStore, history };
export default { configureStore, history }

4
app/store/configureStore.js

@ -1,6 +1,6 @@
// @flow
if (process.env.NODE_ENV === 'production') {
module.exports = require('./configureStore.prod'); // eslint-disable-line global-require
module.exports = require('./configureStore.prod') // eslint-disable-line global-require
} else {
module.exports = require('./configureStore.dev'); // eslint-disable-line global-require
module.exports = require('./configureStore.dev') // eslint-disable-line global-require
}

2
internals/mocks/fileMock.js

@ -1 +1 @@
export default 'test-file-stub';
export default 'test-file-stub'

16
internals/scripts/CheckBuiltsExist.js

@ -1,24 +1,24 @@
// @flow
// Check if the renderer and main bundles are built
import path from 'path';
import chalk from 'chalk';
import fs from 'fs';
import path from 'path'
import chalk from 'chalk'
import fs from 'fs'
function CheckBuildsExist() {
const mainPath = path.join(__dirname, '..', '..', 'app', 'main.prod.js');
const rendererPath = path.join(__dirname, '..', '..', 'app', 'dist', 'renderer.prod.js');
const mainPath = path.join(__dirname, '..', '..', 'app', 'main.prod.js')
const rendererPath = path.join(__dirname, '..', '..', 'app', 'dist', 'renderer.prod.js')
if (!fs.existsSync(mainPath)) {
throw new Error(chalk.whiteBright.bgRed.bold(
'The main process is not built yet. Build it by running "npm run build-main"'
));
))
}
if (!fs.existsSync(rendererPath)) {
throw new Error(chalk.whiteBright.bgRed.bold(
'The renderer process is not built yet. Build it by running "npm run build-renderer"'
));
))
}
}
CheckBuildsExist();
CheckBuildsExist()

8
internals/scripts/CheckNodeEnv.js

@ -1,17 +1,17 @@
// @flow
import chalk from 'chalk';
import chalk from 'chalk'
export default function CheckNodeEnv(expectedEnv: string) {
if (!expectedEnv) {
throw new Error('"expectedEnv" not set');
throw new Error('"expectedEnv" not set')
}
if (process.env.NODE_ENV !== expectedEnv) {
/* eslint-disable */
console.log(chalk.whiteBright.bgRed.bold(
`"process.env.NODE_ENV" must be "${expectedEnv}" to use this webpack config`
));
))
/* eslint-enable */
process.exit(2);
process.exit(2)
}
}

3
test/components/Nav.spec.js

@ -21,9 +21,8 @@ describe('default elements', () => {
it('should render nav links', () => {
expect(el.find(NavLink).at(0).props().to).toBe('/')
expect(el.find(NavLink).at(1).props().to).toBe('/wallet')
expect(el.find(NavLink).at(1).props().to).toBe('/peers')
expect(el.find(NavLink).at(2).props().to).toBe('/channels')
expect(el.find(NavLink).at(3).props().to).toBe('/settings')
})
it('should render buttons', () => {
expect(el.find('.button').at(0).text()).toContain('Pay')

6
test/example.js

@ -1,5 +1,5 @@
describe('description', () => {
it('should have description', () => {
expect(1 + 2).toBe(3);
});
});
expect(1 + 2).toBe(3)
})
})

11
test/reducers/__snapshots__/peers.spec.js.snap

@ -12,6 +12,7 @@ Object {
},
"peers": Array [],
"peersLoading": false,
"searchQuery": "",
}
`;
@ -27,6 +28,7 @@ Object {
},
"peers": Array [],
"peersLoading": false,
"searchQuery": "",
}
`;
@ -44,6 +46,7 @@ Object {
"foo",
],
"peersLoading": false,
"searchQuery": "",
}
`;
@ -59,6 +62,7 @@ Object {
},
"peers": Array [],
"peersLoading": false,
"searchQuery": "",
}
`;
@ -74,6 +78,7 @@ Object {
},
"peers": Array [],
"peersLoading": false,
"searchQuery": "",
}
`;
@ -89,6 +94,7 @@ Object {
},
"peers": Array [],
"peersLoading": false,
"searchQuery": "",
}
`;
@ -104,6 +110,7 @@ Object {
},
"peers": Array [],
"peersLoading": true,
"searchQuery": "",
}
`;
@ -119,6 +126,7 @@ Object {
},
"peers": "foo",
"peersLoading": false,
"searchQuery": "",
}
`;
@ -134,6 +142,7 @@ Object {
},
"peers": Array [],
"peersLoading": false,
"searchQuery": "",
}
`;
@ -152,6 +161,7 @@ Object {
},
"peers": Array [],
"peersLoading": false,
"searchQuery": "",
}
`;
@ -167,5 +177,6 @@ Object {
},
"peers": Array [],
"peersLoading": false,
"searchQuery": "",
}
`;

12
test/runTests.js

@ -1,11 +1,11 @@
const spawn = require('cross-spawn');
const path = require('path');
const spawn = require('cross-spawn')
const path = require('path')
const s = `\\${path.sep}`;
const s = `\\${path.sep}`
const pattern = process.argv[2] === 'e2e'
? `test${s}e2e${s}.+\\.spec\\.js`
: `test${s}(?!e2e${s})[^${s}]+${s}.+\\.spec\\.js$`;
: `test${s}(?!e2e${s})[^${s}]+${s}.+\\.spec\\.js$`
const result = spawn.sync(path.normalize('./node_modules/.bin/jest'), [pattern], { stdio: 'inherit' });
const result = spawn.sync(path.normalize('./node_modules/.bin/jest'), [pattern], { stdio: 'inherit' })
process.exit(result.status);
process.exit(result.status)

6
webpack.config.base.js

@ -2,9 +2,9 @@
* Base webpack config used across other specific configs
*/
import path from 'path';
import webpack from 'webpack';
import { dependencies as externals } from './app/package.json';
import path from 'path'
import webpack from 'webpack'
import { dependencies as externals } from './app/package.json'
export default {
externals: Object.keys(externals || {}),

4
webpack.config.eslint.js

@ -1,3 +1,3 @@
require('babel-register');
require('babel-register')
module.exports = require('./webpack.config.renderer.dev');
module.exports = require('./webpack.config.renderer.dev')

16
webpack.config.main.prod.js

@ -2,14 +2,14 @@
* Webpack config for production electron main process
*/
import webpack from 'webpack';
import merge from 'webpack-merge';
import BabiliPlugin from 'babili-webpack-plugin';
import { BundleAnalyzerPlugin } from 'webpack-bundle-analyzer';
import baseConfig from './webpack.config.base';
import CheckNodeEnv from './internals/scripts/CheckNodeEnv';
import webpack from 'webpack'
import merge from 'webpack-merge'
import BabiliPlugin from 'babili-webpack-plugin'
import { BundleAnalyzerPlugin } from 'webpack-bundle-analyzer'
import baseConfig from './webpack.config.base'
import CheckNodeEnv from './internals/scripts/CheckNodeEnv'
CheckNodeEnv('production');
CheckNodeEnv('production')
export default merge.smart(baseConfig, {
devtool: 'source-map',
@ -59,4 +59,4 @@ export default merge.smart(baseConfig, {
__dirname: false,
__filename: false
}
});
})

18
webpack.config.renderer.dev.dll.js

@ -2,16 +2,16 @@
* Builds the DLL for development electron renderer process
*/
import webpack from 'webpack';
import path from 'path';
import merge from 'webpack-merge';
import baseConfig from './webpack.config.base';
import { dependencies } from './package.json';
import CheckNodeEnv from './internals/scripts/CheckNodeEnv';
import webpack from 'webpack'
import path from 'path'
import merge from 'webpack-merge'
import baseConfig from './webpack.config.base'
import { dependencies } from './package.json'
import CheckNodeEnv from './internals/scripts/CheckNodeEnv'
CheckNodeEnv('development');
CheckNodeEnv('development')
const dist = path.resolve(process.cwd(), 'dll');
const dist = path.resolve(process.cwd(), 'dll')
export default merge.smart(baseConfig, {
context: process.cwd(),
@ -205,4 +205,4 @@ export default merge.smart(baseConfig, {
}
})
]
});
})

20
webpack.config.renderer.prod.js

@ -2,16 +2,16 @@
* Build config for electron renderer process
*/
import path from 'path';
import webpack from 'webpack';
import ExtractTextPlugin from 'extract-text-webpack-plugin';
import { BundleAnalyzerPlugin } from 'webpack-bundle-analyzer';
import merge from 'webpack-merge';
import BabiliPlugin from 'babili-webpack-plugin';
import baseConfig from './webpack.config.base';
import CheckNodeEnv from './internals/scripts/CheckNodeEnv';
import path from 'path'
import webpack from 'webpack'
import ExtractTextPlugin from 'extract-text-webpack-plugin'
import { BundleAnalyzerPlugin } from 'webpack-bundle-analyzer'
import merge from 'webpack-merge'
import BabiliPlugin from 'babili-webpack-plugin'
import baseConfig from './webpack.config.base'
import CheckNodeEnv from './internals/scripts/CheckNodeEnv'
CheckNodeEnv('production');
CheckNodeEnv('production')
export default merge.smart(baseConfig, {
devtool: 'source-map',
@ -165,4 +165,4 @@ export default merge.smart(baseConfig, {
openAnalyzer: process.env.OPEN_ANALYZER === 'true'
})
]
});
})

Loading…
Cancel
Save