Merge pull request #1014 from embark-framework/bug_fix/search-error

Fix search bar
This commit is contained in:
Eric Mastro 2018-10-31 10:18:50 +01:00 committed by GitHub
commit 941e8175cb
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 31 additions and 18 deletions

View File

@ -17,7 +17,6 @@ import {
import {explorerSearch} from "../actions";
import {LIGHT_THEME, DARK_THEME} from '../constants';
import FontAwesome from 'react-fontawesome';
import { } from 'reactstrap';
import "./Layout.css";
@ -92,6 +91,8 @@ class Layout extends React.Component {
if (nextProps.searchResult.error) {
this.setState({searchError: true});
return true;
} else {
this.setState({searchError: false});
}
if (nextProps.searchResult.className) {
@ -245,13 +246,12 @@ class Layout extends React.Component {
<AppSidebarMinimizer />
</AppSidebar>
}
<main className="main">
<Alert color="danger" isOpen={this.state.searchError} toggle={() => this.dismissSearchError()}>
{searchResult.error}
</Alert>
<Container fluid className="h-100 pt-4">
<Alert color="danger" isOpen={(this.state.searchError && Boolean(searchResult.error))}
className="search-error no-gutters" toggle={() => this.dismissSearchError()}>
{searchResult.error}
</Alert>
{children}
</Container>
</main>

View File

@ -4,7 +4,6 @@ import {Form, Input, Button} from 'reactstrap';
import FontAwesome from 'react-fontawesome';
import classNames from 'classnames';
import './SearchBar.css';
class SearchBar extends React.Component {
constructor(props) {

View File

@ -1,5 +1,6 @@
export const EMBARK_PROCESS_NAME = 'embark';
export const LOG_LIMIT = 50;
export const LOG_LIMIT = 200;
export const ELEMENTS_LIMIT = 200;
export const DARK_THEME = 'dark';
export const LIGHT_THEME = 'light';
export const DEPLOYMENT_PIPELINES = {

View File

@ -3,11 +3,10 @@ import {REQUEST, SUCCESS, FAILURE, CONTRACT_COMPILE, FILES, LOGOUT, AUTHENTICATE
FETCH_CREDENTIALS, UPDATE_BASE_ETHER, CHANGE_THEME, FETCH_THEME, EXPLORER_SEARCH, DEBUGGER_INFO,
SIGN_MESSAGE, VERIFY_MESSAGE, TOGGLE_BREAKPOINT,
UPDATE_DEPLOYMENT_PIPELINE, WEB3_CONNECT, WEB3_DEPLOY, WEB3_ESTIMAGE_GAS, FETCH_EDITOR_TABS} from "../actions";
import {EMBARK_PROCESS_NAME, DARK_THEME, DEPLOYMENT_PIPELINES, DEFAULT_HOST} from '../constants';
import {EMBARK_PROCESS_NAME, DARK_THEME, DEPLOYMENT_PIPELINES, DEFAULT_HOST, ELEMENTS_LIMIT} from '../constants';
const BN_FACTOR = 10000;
const VOID_ADDRESS = '0x0000000000000000000000000000000000000000';
const MAX_ELEMENTS = 200;
const entitiesDefaultState = {
accounts: [],
@ -92,7 +91,7 @@ const filtrer = {
},
processLogs: function(processLog, index, self) {
if (processLog.id !== undefined) {
return index === self.findIndex((p) => p.id === processLog.id) && index <= MAX_ELEMENTS;
return index === self.findIndex((p) => p.id === processLog.id) && index <= ELEMENTS_LIMIT;
}
return true;
},
@ -108,14 +107,14 @@ const filtrer = {
return index === self.findIndex((t) => t.address === account.address);
},
blocks: function(block, index, self) {
if (index > MAX_ELEMENTS) {
if (index > ELEMENTS_LIMIT) {
return false;
}
return index === self.findIndex((t) => t.number === block.number);
},
transactions: function(tx, index, self) {
if (index > MAX_ELEMENTS) {
if (index > ELEMENTS_LIMIT) {
return false;
}
return index === self.findIndex((t) => (

View File

@ -1,10 +1,10 @@
import {put, select} from "redux-saga/effects";
import {getAccounts, getBlocks, getTransactions, getContracts} from "../reducers/selectors";
import {fetchAccounts, fetchBlocks, fetchTransactions, fetchContracts} from "./index";
import {ELEMENTS_LIMIT} from '../constants';
export function *searchExplorer(entity, payload) {
let result;
const SEARCH_LIMIT = 100;
// Accounts
yield fetchAccounts({});
@ -29,7 +29,7 @@ export function *searchExplorer(entity, payload) {
}
// Blocks
yield fetchBlocks({limit: SEARCH_LIMIT});
yield fetchBlocks({limit: ELEMENTS_LIMIT});
const blocks = yield select(getBlocks);
const intSearchValue = parseInt(payload.searchValue, 10);
result = blocks.find(block => {
@ -41,7 +41,7 @@ export function *searchExplorer(entity, payload) {
}
// Transactions
yield fetchTransactions({blockLimit: SEARCH_LIMIT});
yield fetchTransactions({blockLimit: ELEMENTS_LIMIT});
const transactions = yield select(getTransactions);
result = transactions.find(transaction => {
return transaction.hash === payload.searchValue;
@ -51,5 +51,5 @@ export function *searchExplorer(entity, payload) {
return yield put(entity.success(result));
}
return yield put(entity.success({error: 'No result found in transactions, accounts, contracts, or blocks'}));
return yield put(entity.success({error: `No result found in transactions, accounts, contracts, or blocks. Please note: We limit the search to the last ${ELEMENTS_LIMIT} elements for performance`}));
}

View File

@ -1,3 +1,6 @@
@import "bootstrap/variables";
@import "variables";
#root .search-bar input {
border-top-right-radius: 0;
border-bottom-right-radius: 0;
@ -27,4 +30,13 @@
.search-bar .search-loading {
margin-top: 16px;
}
}
#root .search-error {
position: sticky;
margin: -#{$grid-gutter-width} -#{$grid-gutter-width} #{$grid-gutter-width} -#{$grid-gutter-width};
top: $navbar-height;
z-index: 3242;
border-radius: 0;
border: 0;
}

View File

@ -60,3 +60,5 @@
// Custom Properties support for Internet Explorer
@import "ie-custom-properties";
}
@import "SearchBar";