diff --git a/assets/mainWindow/css/loading.css b/assets/mainWindow/css/loading.css index 8782de6..47ad63a 100644 --- a/assets/mainWindow/css/loading.css +++ b/assets/mainWindow/css/loading.css @@ -2,6 +2,8 @@ body { overflow: hidden !important; border: solid 1px #ccc; height: 300px; + user-select: none; + cursor: default; } .text-center { @@ -31,6 +33,15 @@ body.agamaMode { background-color: rgba(33, 33, 33, 0.85); padding-top: 40px; color: #fff; + height: 335px; +} + +body.agama-default-window-height { + height: 300px !important; +} + +body.agama-app-settings-window { + height: 770px; } .agama-logo { @@ -38,11 +49,21 @@ body.agamaMode { } #agamaModeStatus { - padding-bottom: 25px; + padding-bottom: 35px; font-weight: bold; font-size: 16px; } +.btn-info { + color: #fff; + background-color: #25b4c5 !important; + border-color: #25b4c5 !important; +} +.btn-info:hover { + background-color: #6cd2de !important; + border-color: #6cd2de !important; +} + .btn-primary.focus, .btn-primary:focus, .btn-primary:hover, @@ -67,8 +88,8 @@ body.agamaMode { font-size: 14px; line-height: 1.57142857; border-radius: 3px; - -webkit-box-shadow: 0 1px 4px 0 rgba(0,0,0,.1); - box-shadow: 0 1px 4px 0 rgba(0,0,0,.1); + -webkit-box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.1); + box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.1); -webkit-transition: border .2s linear,color .2s linear,width .2s linear,background-color .2s linear; -o-transition: border .2s linear,color .2s linear,width .2s linear,background-color .2s linear; transition: border .2s linear,color .2s linear,width .2s linear,background-color .2s linear; @@ -114,4 +135,251 @@ body.agamaMode { .app-closing { position: relative; top: 50px; +} + +.height--auto { + height: auto; +} + +.settings-title { + font-weight: bold; + margin-bottom: 30px; +} + +.margin-right-5 { + margin-right: 5px; +} +.margin-right-10 { + margin-right: 10px; +} +.margin-right-20 { + margin-right: 20px; +} +.margin-top-15 { + margin-top: 15px; +} +.margin-top-20 { + margin-top: 20px; +} + +.btn-close { + border-bottom-left-radius: 50%; + background: #fff; + color: rgba(33, 33, 33, 0.85); + padding: 8px 10px; + font-weight: bold; + font-size: 20px; + position: absolute; + top: 0; + right: 0; + cursor: pointer; +} + +.btn-close img { + height: 12px; + position: relative; + top: -1px; + right: -1px; +} + +.btn-mode img { + height: 20px; + position: relative; + top: -1px; + left: -4px; + padding-right: 5px; +} + +/* settings */ +.settings-help { + position: relative; + top: -2px; + left: 10px; + color: #fff; + border-radius: 50%; + background: #5683ad; + display: inline-block; + padding: 4px 4px; + line-height: 30px; + cursor: default; +} + +.settings-help img { + height: 13px; +} + +.settings-buttons-block { + margin-top: 50px; +} + +.settings-table { + margin: 0 auto; + width: 650px; + text-align: left; +} + +.settings-table input[type="number"] { + width: 100px; + padding: 0 4px; +} + +.settings-table input[type="text"] { + width: 100%; + padding: 0 4px; +} + +.settings-table td { + padding-bottom: 35px; +} + +.settings-table tr:last-child td { + padding: 0; +} + +.settings-table .left { + width: 50%; +} + +.settings-table .right { + width: 50%; + text-align: left; +} + +.agama-app-settings-window #agamaModeStatus { + padding-bottom: 50px; +} + +/* toggle */ +.slider { + border-radius: 20px; + position: absolute; + cursor: pointer; + top: 0; + left: 0; + right: 0; + bottom: 0; + background-color: #fff; + transition: .4s; +} +.switch input { + display: none; +} +input[type=checkbox], +input[type=radio] { + margin: 4px 0 0; + margin-top: 1px\9; + line-height: normal; +} +input[type=checkbox], +input[type=radio] { + -webkit-box-sizing: border-box; + -moz-box-sizing: border-box; + box-sizing: border-box; + padding: 0; +} +.switch { + position: relative; + display: inline-block; + width: 40px; + height: 24px; +} +label { + font-weight: 300; +} +label { + display: inline-block; + max-width: 100%; + margin-bottom: 5px; + font-weight: 700; +} +input:checked + .slider { + background: #36ab7a; +} +input:checked + .slider:before { + background: #fff; +} +input:checked + .slider:before { + -ms-transform: translateX(16px); + transform: translateX(16px); +} +.slider:before { + content: ''; + display: inline-block; + border-radius: 50%; + position: absolute; + height: 20px; + width: 20px; + left: 2px; + bottom: 2px; + background-color: #ccc; + transition: .4s; +} +input[type="text"], +input[type="number"] { + color: rgb(33, 33, 33); +} + +/* toastr */ +#toast-container { + position: fixed; + z-index: 999999; +} +.toast-bottom-right { + right: 12px; + bottom: 12px; +} +#toast-container > .toast-success { + background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADsSURBVEhLY2AYBfQMgf///3P8+/evAIgvA/FsIF+BavYDDWMBGroaSMMBiE8VC7AZDrIFaMFnii3AZTjUgsUUWUDA8OdAH6iQbQEhw4HyGsPEcKBXBIC4ARhex4G4BsjmweU1soIFaGg/WtoFZRIZdEvIMhxkCCjXIVsATV6gFGACs4Rsw0EGgIIH3QJYJgHSARQZDrWAB+jawzgs+Q2UO49D7jnRSRGoEFRILcdmEMWGI0cm0JJ2QpYA1RDvcmzJEWhABhD/pqrL0S0CWuABKgnRki9lLseS7g2AlqwHWQSKH4oKLrILpRGhEQCw2LiRUIa4lwAAAABJRU5ErkJggg==) !important; +} +#toast-container > .toast-error { + background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAHOSURBVEhLrZa/SgNBEMZzh0WKCClSCKaIYOED+AAKeQQLG8HWztLCImBrYadgIdY+gIKNYkBFSwu7CAoqCgkkoGBI/E28PdbLZmeDLgzZzcx83/zZ2SSXC1j9fr+I1Hq93g2yxH4iwM1vkoBWAdxCmpzTxfkN2RcyZNaHFIkSo10+8kgxkXIURV5HGxTmFuc75B2RfQkpxHG8aAgaAFa0tAHqYFfQ7Iwe2yhODk8+J4C7yAoRTWI3w/4klGRgR4lO7Rpn9+gvMyWp+uxFh8+H+ARlgN1nJuJuQAYvNkEnwGFck18Er4q3egEc/oO+mhLdKgRyhdNFiacC0rlOCbhNVz4H9FnAYgDBvU3QIioZlJFLJtsoHYRDfiZoUyIxqCtRpVlANq0EU4dApjrtgezPFad5S19Wgjkc0hNVnuF4HjVA6C7QrSIbylB+oZe3aHgBsqlNqKYH48jXyJKMuAbiyVJ8KzaB3eRc0pg9VwQ4niFryI68qiOi3AbjwdsfnAtk0bCjTLJKr6mrD9g8iq/S/B81hguOMlQTnVyG40wAcjnmgsCNESDrjme7wfftP4P7SP4N3CJZdvzoNyGq2c/HWOXJGsvVg+RA/k2MC/wN6I2YA2Pt8GkAAAAASUVORK5CYII=) !important; +} +#toast-container > div { + margin: 0 0 6px; + padding: 15px 15px 15px 50px; + width: 300px; + -moz-border-radius: 3px 3px 3px 3px; + -webkit-border-radius: 3px 3px 3px 3px; + border-radius: 3px 3px 3px 3px; + background-position: 15px center; + background-repeat: no-repeat; + color: #fff; +} +.toast-success { + background-color: #51a351; +} +.toast-error { + background-color: #bd362f; +} +.toast-title { + font-weight: bold; + text-align: left; + margin-left: 10px; +} +button.toast-close-button { + padding: 0; + cursor: pointer; + background: transparent; + border: 0; + -webkit-appearance: none; +} +.toast-close-button { + position: relative; + right: -0.3em; + top: -0.3em; + float: right; + font-size: 20px; + font-weight: bold; + color: #fff; + -webkit-text-shadow: 0 1px 0 #fff; + text-shadow: 0 1px 0 #fff; + opacity: .8; + -ms-filter: alpha(opacity=80); + filter: alpha(opacity=80); +} +.toast-message { + text-align: left; + margin-left: 10px; + -ms-word-wrap: break-word; + word-wrap: break-word; } \ No newline at end of file diff --git a/assets/mainWindow/img/fa-close.png b/assets/mainWindow/img/fa-close.png new file mode 100644 index 0000000..541cde8 Binary files /dev/null and b/assets/mainWindow/img/fa-close.png differ diff --git a/assets/mainWindow/img/fa-cogs.png b/assets/mainWindow/img/fa-cogs.png new file mode 100644 index 0000000..3faf854 Binary files /dev/null and b/assets/mainWindow/img/fa-cogs.png differ diff --git a/assets/mainWindow/img/fa-cube.png b/assets/mainWindow/img/fa-cube.png new file mode 100644 index 0000000..6d89cfa Binary files /dev/null and b/assets/mainWindow/img/fa-cube.png differ diff --git a/assets/mainWindow/img/fa-cubes.png b/assets/mainWindow/img/fa-cubes.png new file mode 100644 index 0000000..df37e21 Binary files /dev/null and b/assets/mainWindow/img/fa-cubes.png differ diff --git a/assets/mainWindow/img/fa-question.png b/assets/mainWindow/img/fa-question.png new file mode 100644 index 0000000..429d671 Binary files /dev/null and b/assets/mainWindow/img/fa-question.png differ diff --git a/assets/mainWindow/js/loading.js b/assets/mainWindow/js/loading.js index 0620761..82ff800 100644 --- a/assets/mainWindow/js/loading.js +++ b/assets/mainWindow/js/loading.js @@ -1,59 +1,225 @@ - function closeMainWindow() { - const remote = require('electron').remote; - const window = remote.getCurrentWindow(); +let _configCopy; - window.createWindow('open'); - window.hide(); - } +function initSettingsForm() { + const remote = require('electron').remote; + let appConf = remote.getCurrentWindow().appConfig; + let appConfSchema = remote.getCurrentWindow().appConfigSchema; + _configCopy = Object.assign({}, appConf); - function quitApp() { - const remote = require('electron').remote; - const window = remote.getCurrentWindow(); + let _htmlOut = '<table class="settings-table">'; + for (let key in appConf) { + if (appConfSchema[key] && + appConfSchema[key].initDisplay) { + _htmlOut = ` + ${_htmlOut} + <tr> + <td class="left"> + ${appConfSchema[key].displayName}`; + + if (appConfSchema[key].info) { + _htmlOut = ` + ${_htmlOut} + <div + class="settings-help" + title="${appConfSchema[key].info}"> + <img src="EasyDEX-GUI/assets/mainWindow/img/fa-question.png" /> + </div>`; + } - window.forseCloseApp(); + if (appConfSchema[key].type === 'number') { + _htmlOut = ` + ${_htmlOut} + </td> + <td class="right"> + <input + type="number" + id="${key}" + pattern="[0-9]*" + onKeyup="handleInput('${key}')" + value="${_configCopy[key]}" /> + </td> + </tr>`; + } else if (appConfSchema[key].type === 'string' || appConfSchema[key].type === 'folder') { + _htmlOut = ` + ${_htmlOut} + </td> + <td class="right"> + <input + type="text" + id="${key}" + onKeyup="handleInput('${key}')" + value="${_configCopy[key]}" /> + </td> + </tr>`; + } else if (appConfSchema[key].type === 'boolean') { + _htmlOut = `${_htmlOut} + </td> + <td class="right"> + <label + class="switch" + id="${key}" + onClick="settingsToggle(\'${key}\')"> + ${(appConf[key] ? '<input type="checkbox" class="cb" checked />' : '<input type="checkbox" class="cb" />')} + <div class="slider"></div> + </label> + </td> + </tr>`; + } + } } - function normalStart() { + _htmlOut = ` + ${_htmlOut} + </table>`; + + $('#agamaConfigBlock').html(_htmlOut); +} + +function hideToastImmediate() { + $('#toast-container').addClass('hide'); +} + +function hideToast() { + setTimeout(function() { + $('#toast-container').addClass('hide'); + }, 5000); +} + +function showToast(type, message) { + $('#toast-container .toast').removeClass('toast-success').removeClass('toast-error'); + $('#toast-container .toast').addClass(`toast-${type}`); + $('#toast-container .toast-message').html(message); + $('#toast-container').removeClass('hide'); + hideToast(); +} + +function setDefaultAppSettings() { + const remote = require('electron').remote; + + remote.getCurrentWindow().setDefaultAppSettings(); + remote.getCurrentWindow().appConfig = remote.getCurrentWindow().defaultAppSettings; + initSettingsForm(); + showToast('success', 'App settings are reset to default'); +} + +function handleSaveSettings() { + if (_configCopy.dataDir && + _configCopy.dataDir.length) { const remote = require('electron').remote; - let appConf = remote.getCurrentWindow().appConfig; - appConf.iguanaLessMode = false; - - // run iguana-less mode with no daemons startup - if (appConf && appConf.iguanaLessMode) { - // do something - } else { // run normal mode with 2 iguana instances started prior loading GUI - if (appConf && !appConf.manualIguanaStart) { - StartIguana(); + + remote.getCurrentWindow().testLocation(_configCopy.dataDir) + .then(function(res) { + $('#debugOut').html(res + ' | ' + _configCopy.dataDir); + if (res === -1) { + showToast('error', 'Komodo datadir path is invalid'); + } else if (res === false) { + showToast('error', 'Komodo datadir path is not a directory'); + } else { + // save settings + remote.getCurrentWindow().updateAppSettings(_configCopy); + remote.getCurrentWindow().appConfig = _configCopy; + showToast('success', 'Settings saved'); } + }); + } else { + // save settings + const remote = require('electron').remote; - var portcheck; + remote.getCurrentWindow().updateAppSettings(_configCopy); + remote.getCurrentWindow().appConfig = _configCopy; + showToast('success', 'Settings saved'); + } +} - function startcheck() { - portcheck = setInterval(function() { - Iguana_activehandle(appConf).then(function(result){ - console.log(result); +function handleInput(key) { + const _value = $(`#${key}`).val(); + _configCopy[key] = _value; +} - if (result !== 'error') { - stopcheck(); +function settingsToggle(key) { + const _value = $(`#${key} .cb`).prop('checked'); + _configCopy[key] = _value; +} - if (appConf && appConf.useBasiliskInstance) { - StartIguana_Cache(); - } +function closeSettingsWindow() { + const remote = require('electron').remote; + const window = remote.getCurrentWindow(); - $('#loading_status_text').text('Connecting to Basilisk Network...'); - EDEX_DEXgetinfoAll(appConf.skipBasiliskNetworkCheck, appConf.minNotaries, appConf); + window.destroyAppSettingsWindow(); +} + +function reloadSettingsWindow() { + const remote = require('electron').remote; + const window = remote.getCurrentWindow(); + + window.reloadSettingsWindow(); +} + +function openSettingsWindow() { + const remote = require('electron').remote; + const window = remote.getCurrentWindow(); + + window.createAppSettingsWindow(); +} + +function closeMainWindow() { + const remote = require('electron').remote; + const window = remote.getCurrentWindow(); + + window.createWindow('open'); + window.hide(); +} + +function quitApp() { + const remote = require('electron').remote; + const window = remote.getCurrentWindow(); + + window.forseCloseApp(); +} + +function normalStart() { + const remote = require('electron').remote; + let appConf = remote.getCurrentWindow().appConfig; + appConf.iguanaLessMode = false; + + // run iguana-less mode with no daemons startup + if (appConf && + appConf.iguanaLessMode) { + // do something + } else { // run normal mode with 2 iguana instances started prior loading GUI + if (appConf && + !appConf.manualIguanaStart) { + StartIguana(); + } + + var portcheck; + + function startcheck() { + portcheck = setInterval(function() { + Iguana_activehandle(appConf).then(function(result){ + console.log(result); + + if (result !== 'error') { + stopcheck(); + + if (appConf && appConf.useBasiliskInstance) { + StartIguana_Cache(); } - }) - }, 2000); - } - function stopcheck() { - clearInterval(portcheck); - } + $('#loading_status_text').text('Connecting to Basilisk Network...'); + EDEX_DEXgetinfoAll(appConf.skipBasiliskNetworkCheck, appConf.minNotaries, appConf); + } + }) + }, 2000); + } - startcheck(); + function stopcheck() { + clearInterval(portcheck); } + + startcheck(); } +} function IguanaAJAX(url, ajax_data, timeout) { return $.ajax({ diff --git a/react/src/components/addcoin/addcoinOptionsACFiat.js b/react/src/components/addcoin/addcoinOptionsACFiat.js index c5b8ace..6268c70 100644 --- a/react/src/components/addcoin/addcoinOptionsACFiat.js +++ b/react/src/components/addcoin/addcoinOptionsACFiat.js @@ -2,41 +2,52 @@ import React from 'react'; import { translate } from '../../translate/translate'; class AddCoinOptionsACFiat extends React.Component { + const _fiat = [ + 'aud', + 'brl', + 'gbp', + 'bgn', + 'cad', + 'hrk', + 'czk', + 'cny', + 'dkk', + 'eur', + 'hkd', + 'huf', + 'inr', + 'idr', + 'ils', + 'jpy', + 'krw', + 'myr', + 'mxn', + 'nzd', + 'nok', + 'php', + 'pln', + 'ron', + 'rub', + 'sgd', + 'zar', + 'sek', + 'chf', + 'thb', + 'try', + 'usd' + ]; + let _items = []; + + for (let i = 0; i < _fiat.length; i++) { + _items.push( + <option value={ `${_fiat[i].toUpperCase()}|basilisk|native` }>{ translate(`FIAT_CURRENCIES.${_fiat[i].toUpperCase()}`) }</option> + ); + } + render() { return ( <optgroup label={ translate('ADD_COIN.FIAT_CURRENCIES') }> - <option value="AUD|basilisk|native">Australian Dollar (AUD)</option> - <option value="BRL|basilisk|native">Brazilian Real (BRL)</option> - <option value="GBP|basilisk|native">British Pound (GBP)</option> - <option value="BGN|basilisk|native">Bulgarian Lev (BGN)</option> - <option value="CAD|basilisk|native">Canadian Dollar (CAD)</option> - <option value="HRK|basilisk|native">Croatian Kuna (HRK)</option> - <option value="CZK|basilisk|native">Czech Koruna (CZK)</option> - <option value="CNY|basilisk|native">Chinese Yuan (CNY)</option> - <option value="DKK|basilisk|native">Danish Krone (DKK)</option> - <option value="EUR|basilisk|native">Euro (EUR)</option> - <option value="HKD|basilisk|native">Hong Kong Dollar (HKD)</option> - <option value="HUF|basilisk|native">Hungarian Forint (HUF)</option> - <option value="INR|basilisk|native">Indian Rupee (INR)</option> - <option value="IDR|basilisk|native">Indonesian Rupiah (IDR)</option> - <option value="ILS|basilisk|native">Israeli Shekel (ILS)</option> - <option value="JPY|basilisk|native">Japanese Yen (JPY)</option> - <option value="KRW|basilisk|native">Korean Won (KRW)</option> - <option value="MYR|basilisk|native">Malaysian Ringgit (MYR)</option> - <option value="MXN|basilisk|native">Mexican peso (MXN)</option> - <option value="NZD|basilisk|native">New Zealand Dollar (NZD)</option> - <option value="NOK|basilisk|native">Norwegian Krone (NOK)</option> - <option value="PHP|basilisk|native">Philippine Peso (PHP)</option> - <option value="PLN|basilisk|native">Polish Zloty (PLN)</option> - <option value="RON|basilisk|native">Romanian Leu (RON)</option> - <option value="RUB|basilisk|native">Russian Ruble (RUB)</option> - <option value="SGD|basilisk|native">Singapore Dollar (SGD)</option> - <option value="ZAR|basilisk|native">South African Rand (ZAR)</option> - <option value="SEK|basilisk|native">Swedish Krona (SEK)</option> - <option value="CHF|basilisk|native">Swiss Franc (CHF)</option> - <option value="THB|basilisk|native">Thai Baht (THB)</option> - <option value="TRY|basilisk|native">Turkish Lira (TRY)</option> - <option value="USD|basilisk|native">US Dollar (USD)</option> + { _items } </optgroup> ); } diff --git a/react/src/components/addcoin/addcoinOptionsCrypto.js b/react/src/components/addcoin/addcoinOptionsCrypto.js index c192407..c72aa68 100644 --- a/react/src/components/addcoin/addcoinOptionsCrypto.js +++ b/react/src/components/addcoin/addcoinOptionsCrypto.js @@ -12,50 +12,61 @@ class AddCoinOptionsCrypto extends React.Component { } render() { - const isWindows = this.props.appSettings && this.props.appSettings.appInfo && this.props.appSettings.appInfo.sysInfo && this.props.appSettings.appInfo.sysInfo.platform === 'win32'; + // const isWindows = this.props.appSettings && this.props.appSettings.appInfo && this.props.appSettings.appInfo.sysInfo && this.props.appSettings.appInfo.sysInfo.platform === 'win32'; + let appConfig; + + try { + appConfig = window.require('electron').remote.getCurrentWindow().appConfig; + } catch (e) {} - //<option value="ANC|full">AnonCoin (ANC)</option> - //<option value="MZC|full">MazaCoin (MZC)</option> - //<option value="SYS|full">SysCoin (SYS)</option> return ( <optgroup label={ translate('ADD_COIN.CRYPTO_CURRENCIES') }> + <option + value="ANC|full" + className={ this.state.nativeOnly || !appConfig.experimentalFeatures ? 'hide' : '' }>AnonCoin (ANC)</option> <option value="BTCD|full" - className={ this.state.nativeOnly || isWindows ? 'hide' : '' }>BitcoinDark (BTCD)</option> + className={ this.state.nativeOnly || !appConfig.experimentalFeatures ? 'hide' : '' }>BitcoinDark (BTCD)</option> <option value="BTC|full" - className={ this.state.nativeOnly || isWindows ? 'hide' : '' }>Bitcoin (BTC)</option> + className={ this.state.nativeOnly || !appConfig.experimentalFeatures ? 'hide' : '' }>Bitcoin (BTC)</option> <option value="BTM|full" - className={ this.state.nativeOnly || isWindows ? 'hide' : '' }>Bitmark (BTM)</option> + className={ this.state.nativeOnly || !appConfig.experimentalFeatures ? 'hide' : '' }>Bitmark (BTM)</option> <option value="CARB|full" - className={ this.state.nativeOnly || isWindows ? 'hide' : '' }>Carboncoin (CARB)</option> + className={ this.state.nativeOnly || !appConfig.experimentalFeatures ? 'hide' : '' }>Carboncoin (CARB)</option> <option value="DGB|full" - className={ this.state.nativeOnly || isWindows ? 'hide' : '' }>Digibyte (DGB)</option> + className={ this.state.nativeOnly || !appConfig.experimentalFeatures ? 'hide' : '' }>Digibyte (DGB)</option> <option value="DOGE|full" - className={ this.state.nativeOnly || isWindows ? 'hide' : '' }>Dogecoin (DOGE)</option> + className={ this.state.nativeOnly || !appConfig.experimentalFeatures ? 'hide' : '' }>Dogecoin (DOGE)</option> <option value="FRK|full" - className={ this.state.nativeOnly || isWindows ? 'hide' : '' }>Franko (FRK)</option> + className={ this.state.nativeOnly || !appConfig.experimentalFeatures ? 'hide' : '' }>Franko (FRK)</option> <option value="GAME|full" - className={ this.state.nativeOnly || isWindows ? 'hide' : '' }>Gamecredits (GAME)</option> + className={ this.state.nativeOnly || !appConfig.experimentalFeatures ? 'hide' : '' }>Gamecredits (GAME)</option> <option value="KMD|basilisk|native">Komodo (KMD)</option> + <option + value="MZC|full" + className={ this.state.nativeOnly || !appConfig.experimentalFeatures ? 'hide' : '' }>MazaCoin (MZC)</option> <option value="LTC|full" - className={ this.state.nativeOnly || isWindows ? 'hide' : '' }>Litecoin (LTC)</option> + className={ this.state.nativeOnly || !appConfig.experimentalFeatures ? 'hide' : '' }>Litecoin (LTC)</option> + <option + value="SYS|full" + className={ this.state.nativeOnly || !appConfig.experimentalFeatures ? 'hide' : '' }>SysCoin (SYS)</option> <option value="UNO|full" - className={ this.state.nativeOnly || isWindows ? 'hide' : '' }>Unobtanium (UNO)</option> + className={ this.state.nativeOnly || !appConfig.experimentalFeatures ? 'hide' : '' }>Unobtanium (UNO)</option> <option value="ZEC|full" - className={ this.state.nativeOnly || isWindows ? 'hide' : '' }>Zcash (ZEC)</option> + className={ this.state.nativeOnly || !appConfig.experimentalFeatures ? 'hide' : '' }>Zcash (ZEC)</option> <option value="ZET|full" - className={ this.state.nativeOnly || isWindows ? 'hide' : '' }>Zetacoin (ZET)</option> + className={ this.state.nativeOnly || !appConfig.experimentalFeatures ? 'hide' : '' }>Zetacoin (ZET)</option> </optgroup> ); } @@ -65,7 +76,6 @@ const mapStateToProps = (state) => { return { appSettings: state.appSettings, }; - }; export default connect(mapStateToProps)(AddCoinOptionsCrypto); diff --git a/react/src/components/addcoin/coin-selectors.render.js b/react/src/components/addcoin/coin-selectors.render.js index 7f164f8..60bc6f9 100644 --- a/react/src/components/addcoin/coin-selectors.render.js +++ b/react/src/components/addcoin/coin-selectors.render.js @@ -6,6 +6,13 @@ import AddCoinOptionsACFiat from '../addcoin/addcoinOptionsACFiat'; const CoinSelectorsRender = function(item, coin, i) { const isWindows = this.props.Settings && this.props.Settings.appInfo && this.props.Settings.appInfo.sysInfo && this.props.Settings.appInfo.sysInfo.platform === 'win32'; + let appConfig; + + try { + appConfig = window.require('electron').remote.getCurrentWindow().appConfig; + } catch (e) {} + + const hideFullModeBtn = item && item.selectedCoin && item.selectedCoin.indexOf('|full') === -1 || !appConfig.experimentalFeatures ? true : false; return ( <div @@ -54,7 +61,7 @@ const CoinSelectorsRender = function(item, coin, i) { </button> </div> <div className="col-sm-11 text-center add-coin-modes"> - <div className={ this.state.nativeOnly || isWindows ? 'hide' : 'form-group col-lg-4 col-md-4 col-sm-6 col-xs-6 style-addcoin-lbl-mdl-login' }> + <div className={ this.state.nativeOnly || hideFullModeBtn ? 'hide' : 'form-group col-lg-4 col-md-4 col-sm-6 col-xs-6 style-addcoin-lbl-mdl-login' }> <input type="radio" className="to-labelauty labelauty" diff --git a/react/src/components/dashboard/settings/settings.js b/react/src/components/dashboard/settings/settings.js index 101565e..8aab3ca 100644 --- a/react/src/components/dashboard/settings/settings.js +++ b/react/src/components/dashboard/settings/settings.js @@ -534,7 +534,6 @@ class Settings extends React.Component { <input type="number" pattern="[0-9]*" - type="text" name={ `${key}__${_key}` } value={ _appConfig[key][_key] } onChange={ (event) => this.updateInputSettings(event, key, _key) } /> @@ -856,7 +855,7 @@ const mapStateToProps = (state) => { ActiveCoin: { coin: state.ActiveCoin.coin, }, - Settings: state.Settings, + Settings: state.Settings, }; }; diff --git a/react/src/components/dashboard/walletsNativeSend/walletsNativeSend.js b/react/src/components/dashboard/walletsNativeSend/walletsNativeSend.js index e5daafb..9a9225f 100644 --- a/react/src/components/dashboard/walletsNativeSend/walletsNativeSend.js +++ b/react/src/components/dashboard/walletsNativeSend/walletsNativeSend.js @@ -47,6 +47,9 @@ class WalletsNativeSend extends React.Component { this.toggleSubstractFee = this.toggleSubstractFee.bind(this); } + // TODO: 1) t -> z amount validation + // 2) z -> z amount validation + WalletsNativeSendFormRender() { return _WalletsNativeSendFormRender.call(this); } @@ -366,8 +369,9 @@ class WalletsNativeSend extends React.Component { checkTotalBalance() { let _balance = 0; + if (this.props.ActiveCoin.balance && - this.props.ActiveCoin.balance.total) { + this.props.ActiveCoin.balance.total) { _balance = this.props.ActiveCoin.balance.total; }