diff --git a/app/app.global.scss b/app/app.global.scss index 0398282e..e24fe2be 100644 --- a/app/app.global.scss +++ b/app/app.global.scss @@ -25,7 +25,7 @@ body { } // disable the pinball scrollers for windows -* { +*, input[type=text], input[type=number] { &::-webkit-inner-spin-button, &::-webkit-outer-spin-button { -webkit-appearance: none; } diff --git a/app/app.icns b/app/app.icns deleted file mode 100644 index 4aa9cb2c..00000000 Binary files a/app/app.icns and /dev/null differ diff --git a/app/components/Contacts/ContactsForm.js b/app/components/Contacts/ContactsForm.js index 51a8d597..f821dbc8 100644 --- a/app/components/Contacts/ContactsForm.js +++ b/app/components/Contacts/ContactsForm.js @@ -102,7 +102,7 @@ class ContactsForm extends React.Component { updateManualFormSearchQuery('') return } - // clear any existing errors + // clear any existing errors updateManualFormErrors({ manualInput: null }) const [pubkey, host] = contactsform.manualSearchQuery && contactsform.manualSearchQuery.split('@') @@ -112,6 +112,16 @@ class ContactsForm extends React.Component { updateManualFormSearchQuery('') } + const searchUpdated = (search) => { + updateContactFormSearchQuery(search) + + console.log('search: ', search) + if (search.includes('@') && search.split('@')[0].length === 66) { + console.log('yo') + updateManualFormSearchQuery(search) + } + } + return (
updateContactFormSearchQuery(event.target.value)} + onChange={event => searchUpdated(event.target.value)} />
diff --git a/app/components/Contacts/ContactsForm.scss b/app/components/Contacts/ContactsForm.scss index 3c6b7a45..19123176 100644 --- a/app/components/Contacts/ContactsForm.scss +++ b/app/components/Contacts/ContactsForm.scss @@ -49,7 +49,7 @@ .networkResults { overflow-y: scroll; - height: 300px; + height: 250px; margin-top: 30px; padding: 20px 0; @@ -156,7 +156,7 @@ .manualFormSpinner { position: absolute; right: 0; - top: 50%; + top: 40%; padding: 0 10px; } } diff --git a/app/components/Nav/Nav.js b/app/components/Nav/Nav.js index 467b2caa..6b275af4 100644 --- a/app/components/Nav/Nav.js +++ b/app/components/Nav/Nav.js @@ -3,10 +3,10 @@ import PropTypes from 'prop-types' import { NavLink } from 'react-router-dom' import Isvg from 'react-inlinesvg' -import walletIcon from 'icons/wallet.svg' -import peersIcon from 'icons/peers.svg' -import networkIcon from 'icons/globe.svg' -import helpIcon from 'icons/help.svg' +import walletIcon from 'icons/wallet_2.svg' +import peersIcon from 'icons/channels.svg' +import networkIcon from 'icons/network.svg' +import helpIcon from 'icons/help_2.svg' import styles from './Nav.scss' diff --git a/app/components/Nav/Nav.scss b/app/components/Nav/Nav.scss index 028d4c63..88fa5ef5 100644 --- a/app/components/Nav/Nav.scss +++ b/app/components/Nav/Nav.scss @@ -3,7 +3,7 @@ .nav { display: inline-block; vertical-align: top; - width: 20%; + width: 15%; font-size: 24px; background: $secondary; height: 100vh; @@ -133,12 +133,11 @@ opacity: 0.5; cursor: pointer; text-decoration: none; - border-left: 20px solid transparent; transition: all 0.25s; li { margin: 12.5px 0; - min-width: 200px; + min-width: 150px; } &.active { @@ -151,15 +150,15 @@ } svg { - width: 32px; - height: 32px; + width: 28px; + height: 28px; vertical-align: middle; } span { margin-left: 15px; line-height: 22px; - font-size: 20px; + font-size: 18px; font-weight: 500; letter-spacing: .2px; } @@ -172,15 +171,17 @@ position: absolute; bottom: 10px; right: 12.5%; + + .button { + margin-bottom: 20px; + font-weight: bold; + cursor: pointer; + text-transform: uppercase; + letter-spacing: .2px; + font-size: 0.75em; + } } -.button { - margin-bottom: 20px; - font-weight: bold; - cursor: pointer; - text-transform: uppercase; - letter-spacing: .2px; -} .content { width: 80%; diff --git a/app/icons/contacts.svg b/app/icons/contacts.svg new file mode 100644 index 00000000..e14de286 --- /dev/null +++ b/app/icons/contacts.svg @@ -0,0 +1,15 @@ + + + + Group 7 + Created with Sketch. + + + + + + + + + + \ No newline at end of file diff --git a/app/icons/help_2.svg b/app/icons/help_2.svg new file mode 100644 index 00000000..795edd1a --- /dev/null +++ b/app/icons/help_2.svg @@ -0,0 +1,18 @@ + + + + life-buoy + Created with Sketch. + + + + + + + + + + + + + \ No newline at end of file diff --git a/app/icons/network.svg b/app/icons/network.svg new file mode 100644 index 00000000..fdb679cb --- /dev/null +++ b/app/icons/network.svg @@ -0,0 +1,14 @@ + + + + Group 2 + Created with Sketch. + + + + + + + + + \ No newline at end of file diff --git a/app/icons/wallet_2.svg b/app/icons/wallet_2.svg new file mode 100644 index 00000000..40b89fc1 --- /dev/null +++ b/app/icons/wallet_2.svg @@ -0,0 +1,15 @@ + + + + Group 5 + Created with Sketch. + + + + + + + + + + \ No newline at end of file diff --git a/app/icons/zap.icns b/app/icons/zap.icns deleted file mode 100644 index 4aa9cb2c..00000000 Binary files a/app/icons/zap.icns and /dev/null differ diff --git a/app/menu.js b/app/menu.js index 0b31d242..b71fac01 100644 --- a/app/menu.js +++ b/app/menu.js @@ -47,11 +47,9 @@ export default class MenuBuilder { const subMenuAbout = { label: 'Electron', submenu: [ - { label: 'About ElectronReact', selector: 'orderFrontStandardAboutPanel:' }, + { label: 'About Zap', selector: 'orderFrontStandardAboutPanel:' }, { type: 'separator' }, - { label: 'Services', submenu: [] }, - { type: 'separator' }, - { label: 'Hide ElectronReact', accelerator: 'Command+H', selector: 'hide:' }, + { label: 'Hide Zap', accelerator: 'Command+H', selector: 'hide:' }, { label: 'Hide Others', accelerator: 'Command+Shift+H', selector: 'hideOtherApplications:' }, { label: 'Show All', selector: 'unhideAllApplications:' }, { type: 'separator' }, @@ -104,10 +102,10 @@ export default class MenuBuilder { const subMenuHelp = { label: 'Help', submenu: [ - { label: 'Learn More', click() { shell.openExternal('http://electron.atom.io') } }, - { label: 'Documentation', click() { shell.openExternal('https://github.com/atom/electron/tree/master/docs#readme') } }, - { label: 'Community Discussions', click() { shell.openExternal('https://discuss.atom.io/c/electron') } }, - { label: 'Search Issues', click() { shell.openExternal('https://github.com/atom/electron/issues') } } + { label: 'Learn More', click() { shell.openExternal('https://zap.jackmallers.com/') } }, + { label: 'Documentation', click() { shell.openExternal('https://github.com/LN-Zap/zap-desktop') } }, + { label: 'Community Discussions', click() { shell.openExternal('zaphq.slack.com') } }, + { label: 'Search Issues', click() { shell.openExternal('https://github.com/LN-Zap/zap-desktop/issues') } } ] } @@ -169,22 +167,22 @@ export default class MenuBuilder { submenu: [{ label: 'Learn More', click() { - shell.openExternal('http://electron.atom.io') + shell.openExternal('https://zap.jackmallers.com/') } }, { label: 'Documentation', click() { - shell.openExternal('https://github.com/atom/electron/tree/master/docs#readme') + shell.openExternal('https://github.com/LN-Zap/zap-desktop') } }, { label: 'Community Discussions', click() { - shell.openExternal('https://discuss.atom.io/c/electron') + shell.openExternal('zaphq.slack.com') } }, { label: 'Search Issues', click() { - shell.openExternal('https://github.com/atom/electron/issues') + shell.openExternal('https://github.com/LN-Zap/zap-desktop/issues') } }] }] diff --git a/app/reducers/activity.js b/app/reducers/activity.js index d7c1d06b..f8db7870 100644 --- a/app/reducers/activity.js +++ b/app/reducers/activity.js @@ -16,7 +16,8 @@ const initialState = { modal: { modalType: null, modalProps: {} - } + }, + searchText: '' } // ------------------------------------ @@ -29,6 +30,8 @@ export const CHANGE_FILTER = 'CHANGE_FILTER' export const TOGGLE_PULLDOWN = 'TOGGLE_PULLDOWN' +export const UPDATE_SEARCH_TEXT = 'UPDATE_SEARCH_TEXT' + // ------------------------------------ // Actions // ------------------------------------ @@ -59,6 +62,13 @@ export function toggleFilterPulldown() { } } +export function updateSearchText(searchText) { + return { + type: UPDATE_SEARCH_TEXT, + searchText + } +} + // ------------------------------------ // Action Handlers // ------------------------------------ @@ -66,7 +76,9 @@ const ACTION_HANDLERS = { [SHOW_ACTIVITY_MODAL]: (state, { modalType, modalProps }) => ({ ...state, modal: { modalType, modalProps } }), [HIDE_ACTIVITY_MODAL]: state => ({ ...state, modal: { modalType: null, modalProps: {} } }), [CHANGE_FILTER]: (state, { filter }) => ({ ...state, filter, filterPulldown: false }), - [TOGGLE_PULLDOWN]: state => ({ ...state, filterPulldown: !state.filterPulldown }) + [TOGGLE_PULLDOWN]: state => ({ ...state, filterPulldown: !state.filterPulldown }), + + [UPDATE_SEARCH_TEXT]: (state, { searchText }) => ({ ...state, searchText }) } // ------------------------------------ @@ -75,20 +87,34 @@ const ACTION_HANDLERS = { const activitySelectors = {} const filtersSelector = state => state.activity.filters const filterSelector = state => state.activity.filter +const searchSelector = state => state.activity.searchText const paymentsSelector = state => state.payment.payments const invoicesSelector = state => state.invoice.invoices const transactionsSelector = state => state.transaction.transactions const allActivity = createSelector( + searchSelector, paymentsSelector, invoicesSelector, transactionsSelector, - (payments, invoices, transactions) => [...payments, ...invoices, ...transactions].sort((a, b) => { - const aTimestamp = Object.prototype.hasOwnProperty.call(a, 'time_stamp') ? a.time_stamp : a.creation_date - const bTimestamp = Object.prototype.hasOwnProperty.call(b, 'time_stamp') ? b.time_stamp : b.creation_date - - return bTimestamp - aTimestamp - }) + (searchText, payments, invoices, transactions) => { + const searchedArr = [...payments, ...invoices, ...transactions].filter((tx) => { + if ((tx.tx_hash && tx.tx_hash.includes(searchText)) || + (tx.payment_hash && tx.payment_hash.includes(searchText)) || + (tx.r_hash && tx.r_hash.includes(searchText))) { + return true + } + + return false + }) + + return searchedArr.sort((a, b) => { + const aTimestamp = Object.prototype.hasOwnProperty.call(a, 'time_stamp') ? a.time_stamp : a.creation_date + const bTimestamp = Object.prototype.hasOwnProperty.call(b, 'time_stamp') ? b.time_stamp : b.creation_date + + return bTimestamp - aTimestamp + }) + } ) const lnActivity = createSelector( @@ -131,7 +157,6 @@ activitySelectors.nonActiveFilters = createSelector( (filters, filter) => filters.filter(f => f.key !== filter.key) ) - export { activitySelectors } diff --git a/app/routes/activity/components/Activity.js b/app/routes/activity/components/Activity.js index 2af22af4..60c83d5d 100644 --- a/app/routes/activity/components/Activity.js +++ b/app/routes/activity/components/Activity.js @@ -47,14 +47,14 @@ class Activity extends Component { render() { const { ticker, - searchInvoices, - invoice: { invoicesSearchText, invoiceLoading }, + updateSearchText, + invoice: { invoiceLoading }, address: { address }, balance, info, payment: { paymentLoading }, currentTicker, - activity: { modal, filter, filterPulldown }, + activity: { modal, filter, filterPulldown, searchText }, hideActivityModal, changeFilter, toggleFilterPulldown, @@ -84,10 +84,10 @@ class Activity extends Component { searchInvoices(event.target.value)} + value={searchText} + onChange={event => updateSearchText(event.target.value)} className={`${styles.text} ${styles.input}`} - placeholder='Search by amount, hash, memo, etc' + placeholder='Search by hash...' type='text' id='invoiceSearch' /> @@ -132,7 +132,7 @@ Activity.propTypes = { fetchBalance: PropTypes.func.isRequired, ticker: PropTypes.object.isRequired, - searchInvoices: PropTypes.func.isRequired, + updateSearchText: PropTypes.func.isRequired, invoice: PropTypes.object.isRequired, payment: PropTypes.object.isRequired, currentTicker: PropTypes.object.isRequired, diff --git a/app/routes/activity/containers/ActivityContainer.js b/app/routes/activity/containers/ActivityContainer.js index 3f0df128..1caa3a50 100644 --- a/app/routes/activity/containers/ActivityContainer.js +++ b/app/routes/activity/containers/ActivityContainer.js @@ -3,7 +3,6 @@ import { tickerSelectors } from 'reducers/ticker' import { fetchBalance } from 'reducers/balance' import { fetchInvoices, - searchInvoices, setInvoice, invoiceSelectors } from 'reducers/invoice' @@ -18,7 +17,8 @@ import { hideActivityModal, changeFilter, toggleFilterPulldown, - activitySelectors + activitySelectors, + updateSearchText } from 'reducers/activity' import { newAddress } from 'reducers/address' @@ -30,13 +30,13 @@ const mapDispatchToProps = { fetchPayments, fetchInvoices, fetchTransactions, - searchInvoices, showActivityModal, hideActivityModal, changeFilter, toggleFilterPulldown, newAddress, - fetchBalance + fetchBalance, + updateSearchText } const mapStateToProps = state => ({ diff --git a/app/routes/app/components/App.scss b/app/routes/app/components/App.scss index 3b0fb72a..52648e17 100644 --- a/app/routes/app/components/App.scss +++ b/app/routes/app/components/App.scss @@ -1,6 +1,6 @@ .content { position: relative; - width: 80%; + width: 85%; height: 100vh; display: inline-block; vertical-align: top; diff --git a/package.json b/package.json index b1f54ff4..8c9e92dd 100644 --- a/package.json +++ b/package.json @@ -82,8 +82,8 @@ }, "extraResources": [ { - "from": "./resources/bin/darwin/lnd", - "to": "./bin/lnd" + "from": "./resources/bin/win32/lnd.exe", + "to": "./bin/lnd.exe" } ] },