mirror of
https://github.com/embarklabs/embark.git
synced 2025-01-16 16:55:00 +00:00
Fixed issue with compounding duplicated logs
On every load of the component, the API request would fetch the entire log history, and effective append it to the list of process logs, so that if a component was loaded multiple times (ie click to different tab, then back to home), the log would be duplicated. This was solved by timestamping and labelling each fetch response, then getting the latest response in the selector, and filtering by process name in the component.
This commit is contained in:
parent
7de72cb474
commit
0fa1e11ac7
@ -100,7 +100,19 @@ export const commands = {
|
|||||||
export const PROCESS_LOGS = createRequestTypes('PROCESS_LOGS');
|
export const PROCESS_LOGS = createRequestTypes('PROCESS_LOGS');
|
||||||
export const processLogs = {
|
export const processLogs = {
|
||||||
request: (processName) => action(PROCESS_LOGS[REQUEST], {processName}),
|
request: (processName) => action(PROCESS_LOGS[REQUEST], {processName}),
|
||||||
success: (processLogs) => action(PROCESS_LOGS[SUCCESS], {processLogs}),
|
success: (processLogs, payload) => {
|
||||||
|
return action(PROCESS_LOGS[SUCCESS],
|
||||||
|
{
|
||||||
|
processLogs: [
|
||||||
|
{
|
||||||
|
process: payload.processName,
|
||||||
|
timestamp: new Date().getTime(),
|
||||||
|
logs: processLogs
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
);
|
||||||
|
},
|
||||||
failure: (error) => action(PROCESS_LOGS[FAILURE], {error})
|
failure: (error) => action(PROCESS_LOGS[FAILURE], {error})
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -31,6 +31,16 @@ class Console extends Component {
|
|||||||
this.setState({value: event.target.value});
|
this.setState({value: event.target.value});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
getProcessLogs(processName){
|
||||||
|
const log = this.props.processLogs
|
||||||
|
.reverse()
|
||||||
|
.filter((item) => item.process === processName);
|
||||||
|
|
||||||
|
if(!log.length) return [];
|
||||||
|
//should be only one item in the array
|
||||||
|
return log[0].logs;
|
||||||
|
}
|
||||||
|
|
||||||
renderCommandsResult(){
|
renderCommandsResult(){
|
||||||
const {commands} = this.props;
|
const {commands} = this.props;
|
||||||
return (
|
return (
|
||||||
@ -42,7 +52,7 @@ class Console extends Component {
|
|||||||
}
|
}
|
||||||
|
|
||||||
renderTabs() {
|
renderTabs() {
|
||||||
const {processLogs, processes} = this.props;
|
const {processes} = this.props;
|
||||||
return processes
|
return processes
|
||||||
.sort((a, b) => { // ensure the "Embark" tab is displayed first
|
.sort((a, b) => { // ensure the "Embark" tab is displayed first
|
||||||
if (a.name === this.DEFAULT_PROCESS) return -1;
|
if (a.name === this.DEFAULT_PROCESS) return -1;
|
||||||
@ -53,10 +63,7 @@ class Console extends Component {
|
|||||||
<Tab title={process.name} key={process.name} onClick={(e, x) => this.clickTab(e, x)}>
|
<Tab title={process.name} key={process.name} onClick={(e, x) => this.clickTab(e, x)}>
|
||||||
<Logs>
|
<Logs>
|
||||||
{
|
{
|
||||||
processLogs
|
this.getProcessLogs(process.name)
|
||||||
.reverse()
|
|
||||||
.filter((item) => item.name === process.name)
|
|
||||||
.sort((a, b) => a.timestamp - b.timestamp)
|
|
||||||
.map((item, i) => <p key={i} className={item.logLevel}
|
.map((item, i) => <p key={i} className={item.logLevel}
|
||||||
dangerouslySetInnerHTML={{__html: convert.toHtml(item.msg)}}></p>)
|
dangerouslySetInnerHTML={{__html: convert.toHtml(item.msg)}}></p>)
|
||||||
}
|
}
|
||||||
|
@ -53,7 +53,15 @@ export function getProcesses(state) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export function getProcessLogs(state) {
|
export function getProcessLogs(state) {
|
||||||
return state.entities.processLogs;
|
if(!state.entities.processLogs.length) return [];
|
||||||
|
const processLogsObj = state.entities.processLogs.reduce((processLogs, processLog) => {
|
||||||
|
const existingProcessLog = processLogs[processLog.process];
|
||||||
|
if(!existingProcessLog || processLog.timestamp > existingProcessLog.timestamp){
|
||||||
|
processLogs[processLog.process] = processLog;
|
||||||
|
}
|
||||||
|
return processLogs;
|
||||||
|
}, {});
|
||||||
|
return Object.values(processLogsObj);
|
||||||
}
|
}
|
||||||
|
|
||||||
export function getContractLogsByContract(state, contractName) {
|
export function getContractLogsByContract(state, contractName) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user