aboutsummaryrefslogtreecommitdiffstats
path: root/web/src/js/components/eventlog.jsx.js
diff options
context:
space:
mode:
authorMaximilian Hils <git@maximilianhils.com>2014-09-22 03:06:19 +0200
committerMaximilian Hils <git@maximilianhils.com>2014-09-22 03:06:19 +0200
commit45f39c23804e12459e810a1f5014d892e4177b48 (patch)
treeda7dfb5884642968a096b6563a02aff63f19a178 /web/src/js/components/eventlog.jsx.js
parent84e2a028c24f00ea86205dbfe5b9315c57d5ae3f (diff)
downloadmitmproxy-45f39c23804e12459e810a1f5014d892e4177b48.tar.gz
mitmproxy-45f39c23804e12459e810a1f5014d892e4177b48.tar.bz2
mitmproxy-45f39c23804e12459e810a1f5014d892e4177b48.zip
beef up event log
Diffstat (limited to 'web/src/js/components/eventlog.jsx.js')
-rw-r--r--web/src/js/components/eventlog.jsx.js102
1 files changed, 90 insertions, 12 deletions
diff --git a/web/src/js/components/eventlog.jsx.js b/web/src/js/components/eventlog.jsx.js
index df212177..08a6dfb4 100644
--- a/web/src/js/components/eventlog.jsx.js
+++ b/web/src/js/components/eventlog.jsx.js
@@ -1,6 +1,31 @@
/** @jsx React.DOM */
-var EventLog = React.createClass({
+var LogMessage = React.createClass({
+ render: function(){
+ var entry = this.props.entry;
+ var indicator;
+ switch(entry.level){
+ case "web":
+ indicator = <i className="fa fa-fw fa-html5"></i>;
+ break;
+ case "debug":
+ indicator = <i className="fa fa-fw fa-bug"></i>;
+ break;
+ default:
+ indicator = <i className="fa fa-fw fa-info"></i>;
+ }
+ return (
+ <div>
+ { indicator } {entry.message}
+ </div>
+ );
+ },
+ shouldComponentUpdate: function(){
+ return false; // log entries are immutable.
+ }
+});
+
+var EventLogContents = React.createClass({
mixins:[AutoScrollMixin],
getInitialState: function () {
return {
@@ -20,22 +45,75 @@ var EventLog = React.createClass({
log: this.log.getAll()
});
},
+ render: function () {
+ var messages = this.state.log.map(function(row) {
+ if(!this.props.filter[row.level]){
+ return null;
+ }
+ return <LogMessage key={row.id} entry={row}/>;
+ }.bind(this));
+ return <pre>{messages}</pre>;
+ }
+});
+
+var ToggleFilter = React.createClass({
+ toggle: function(){
+ return this.props.toggleLevel(this.props.name);
+ },
+ render: function(){
+ var className = "label ";
+ if (this.props.active) {
+ className += "label-primary";
+ } else {
+ className += "label-default";
+ }
+ return (
+ <a
+ href="#"
+ className={className}
+ onClick={this.toggle}>
+ {this.props.name}
+ </a>
+ );
+ }
+});
+
+var EventLog = React.createClass({
+ getInitialState: function(){
+ return {
+ filter: {
+ "debug": false,
+ "info": true,
+ "web": true
+ }
+ };
+ },
close: function () {
SettingsActions.update({
showEventLog: false
});
},
+ toggleLevel: function(level){
+ var filter = this.state.filter;
+ filter[level] = !filter[level];
+ this.setState({filter: filter});
+ return false;
+ },
render: function () {
- var messages = this.state.log.map(function(row) {
- var indicator = null;
- if(row.source === "ui"){
- indicator = <i className="fa fa-html5"></i>;
- }
- return (
- <div key={row.id}>
- { indicator } {row.message}
- </div>);
- });
- return <pre className="eventlog">{messages}</pre>;
+ return (
+ <div className="eventlog">
+ <div>
+ Eventlog
+ <div className="pull-right">
+ <ToggleFilter name="debug" active={this.state.filter.debug} toggleLevel={this.toggleLevel}/>
+ <ToggleFilter name="info" active={this.state.filter.info} toggleLevel={this.toggleLevel}/>
+ <ToggleFilter name="web" active={this.state.filter.web} toggleLevel={this.toggleLevel}/>
+ <i onClick={this.close} className="fa fa-close"></i>
+ </div>
+
+ </div>
+ <EventLogContents filter={this.state.filter}/>
+ </div>
+ );
}
}); \ No newline at end of file