| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276 |
- /**
- * Watch Plugin
- * @version 1.0
- * @author dron
- * @create 2013-05-07
- */
- Tracker.setupWatchPlugin = function(){
- Tracker.Plugins.addOn( "watch", function(){
- var tmpl, template, window, document, log, time, startBtnId, stopBtnId, clearBtnId,
- stateId, logerId, started, buttonEventBind, stateEvent, start, stop, clear, hooking,
- originalArrivedSnippetGroupFlag, buttonEnable, activeCodeCache, eventBuild,
- original__tracker__, new__tracker__, showState, arrivedSnippetGroupCache,
- buttonStateChange, logHtml;
- tmpl = Tracker.Util.tmpl;
- arrivedSnippetGroupCache = {};
- stateEvent = Tracker.Event.bind( {} );
- time = function( date ){
- var t = [ date.getHours(), date.getMinutes(), date.getSeconds() ].join( ":" );
- t = t.replace( /\b(\d)\b/g, "0$1" );
- return t;
- };
- Tracker.Plugins.addStyle( [
- ".red-dot{ display: inline; margin-left: 2px; background: url() no-repeat center center; }",
- "#code-content .lines .arrive-2{ background-color: #ffba93; color: #000; }",
- "#plugin-watch-page{ }",
- "#plugin-watch-page .header{ height: 126px; background-color: #fafafa; border-bottom: 1px solid #d5d5d5; }",
- "#plugin-watch-page .header .title{ line-height: 42px; padding-left: 30px; }",
- "#plugin-watch-page .header .control{ padding-left: 30px; height: 42px; }",
- "#plugin-watch-page .header .control .btn{ margin-right: 5px; }",
- "#plugin-watch-page .header .state{ padding-left: 30px; line-height: 42px; color: #666; }",
- "#plugin-watch-page .header .state .text{ }",
- "#plugin-watch-page .body{ position: absolute; left: 0; right: 0; top: 127px; bottom: 0; padding: 10px; background-color: #1d1e1a; }",
- "#plugin-watch-page .body .logger{ line-height: 20px; color: #f6f6f6; }",
- "#plugin-watch-page .body .logger .line{ }",
- "#plugin-watch-page .body .logger .line .time{ display: inline-block; width: 80px; }",
- "#plugin-watch-page .body .logger .line .content{ }"
- ].join( "" ) );
- template = {
- page: tmpl( [
- "<div class='header'>",
- "<div class='title'>点击开始监控,即可发现从监控开始到监控结束之间活动的代码</div>", // TODO: unicode
- "<div class='control'>",
- "<button id='<%= startBtnId %>' class='btn'>开始监控</button>",
- "<button id='<%= stopBtnId %>' class='btn disabled'>停止监控</button>",
- "<button id='<%= clearBtnId %>' class='btn disabled'>清除结果</button>",
- "</div>",
- "<div class='state' id='<%= stateId %>'>",
- "<%= stateHtml %>",
- "</div>",
- "</div>",
- "<div class='body scrollable'>",
- "<div class='logger' id='<%= logerId %>'>",
- "</div>",
- "</div>"
- ].join( "" ) ),
- state: tmpl( [
- "<span class='text' style='color: <%= color %>;'><%= text %></span>",
- ].join( "" ) ),
- logLine: tmpl( [
- "<span class='time'><%= time %></span>",
- "<span class='content'><%= content %></span>"
- ].join( "" ) )
- };
- activeCodeCache = function(){
- var cache = {};
- return {
- add: function( id ){
- if( !cache[ id ] )
- cache[ id ] = 1;
- },
- get: function( id ){
- return cache[ id ];
- },
- clear: function(){
- for( var i in cache )
- delete cache[ i ];
- }
- }
- }();
- showState = function( stateText, color ){
- color = color || "#999";
- document.getElementById( stateId ).innerHTML = template.state( {
- text: stateText,
- color: color
- } );
- };
- log = function( c ){
- var t = time( new Date ), logerEl;
- var line = document.createElement( "div" );
- line.className = "line";
- line.innerHTML = template.logLine( { time: t, content: c } );
- logerEl = document.getElementById( logerId );
- logerEl.appendChild( line );
- logHtml = logerEl.innerHTML;
- };
- buttonEventBind = function( buttonId, buttonHandler ){
- Tracker.Event.add( document.getElementById( buttonId ), "click", function(){
- if( !Tracker.Util.hasClass( this, "disabled" ) )
- buttonHandler.call( null );
- } );
- };
- buttonEnable = function( buttonId, enable ){
- var button = document.getElementById( buttonId );
- if( enable )
- Tracker.Util.removeClass( button, "disabled" );
- else
- Tracker.Util.addClass( button, "disabled" );
- };
- new__tracker__ = function( groupId ){
- var code;
- Tracker.StatusPool.arrivedSnippetGroupPut( groupId );
- if( !arrivedSnippetGroupCache[ groupId ] )
- arrivedSnippetGroupCache[ groupId ] = 1;
- if( code = Tracker.StatusPool.snippetGroupToCodeGet( groupId ) ){
- if( activeCodeCache.get( code.id ) )
- return ;
- activeCodeCache.add( code.id );
- // TODO: unicode 编码
- log( "发现新的活动代码在 " + ( code.fullUrl || code.fileName ) +
- " <a href='#' action='show-code' data-code-id='" + code.id +
- "' onclick='return false;'>查看</a>" );
- }else{
- log( "发现新的活动代码在 " + groupId );
- }
- };
- start = function(){
- var pageWindow = Tracker.View.ControlFrame.getWindow( "tracker_page" );
- pageWindow.__tracker__ = new__tracker__;
- Tracker.StatusPool.arrivedSnippetGroupFlagSet( 2 );
- showState( "监控进行中...", "#c00" );
- log( "监控开始" );
- hooking = true;
- stateEvent.fire( "stateChange", "start" );
- };
- stop = function(){
- var pageWindow = Tracker.View.ControlFrame.getWindow( "tracker_page" );
- pageWindow.__tracker__ = original__tracker__;
- Tracker.StatusPool.arrivedSnippetGroupFlagSet( 1 );
- showState( "已停止" );
- log( "监控结束" );
- activeCodeCache.clear();
- hooking = false;
- stateEvent.fire( "stateChange", "stop" );
- };
- clear = function(){
- for( var groupId in arrivedSnippetGroupCache ){
- Tracker.StatusPool.arrivedSnippetGroupDelete( groupId, 2 );
- delete arrivedSnippetGroupCache[ groupId ];
- }
- document.getElementById( logerId ).innerHTML = logHtml = "";
- log( "清除完成" );
- buttonEnable( clearBtnId, false );
- };
- eventBuild = function(){
- var topNav, titleEl;
- Tracker.Event.add( document.getElementById( logerId ), "click", function( e ){
- var target, codeId;
- target = e.target;
- if( target.getAttribute( "action" ) == "show-code" ){
- codeId = target.getAttribute( "data-code-id" );
- Tracker.View.ControlPanel.activeTab( "code-list" );
- Tracker.View.ControlPanel.showCodeDetail( codeId, 2 );
- }
- } );
- topNav = document.getElementById( "top-nav" );
- Tracker.Util.forEach( topNav.childNodes , function( li ){
- if( li.getAttribute( "data-name" ) == "watch" ){
- titleEl = li;
- titleEl.setAttribute( "data-html-backup", li.innerHTML );
- }
- } );
- topNav.tabEvent.on( "active", function( index, name ){
- if( hooking ){
- if( name == "watch" ){
- titleEl.innerHTML = titleEl.getAttribute( "data-html-backup" );
- }else{
- titleEl.innerHTML = titleEl.getAttribute( "data-html-backup" )
- .replace( /<\/a>/i, "<span class='red-dot'> </span></a>" );
- }
- }
- } );
- };
- buttonStateChange = function( state ){
- if( state == "start" ){
- buttonEnable( startBtnId, false );
- buttonEnable( stopBtnId, true );
- buttonEnable( clearBtnId, false );
- }else if( state == "stop" ){
- buttonEnable( startBtnId, true );
- buttonEnable( stopBtnId, false );
- buttonEnable( clearBtnId, true );
- }
- };
- this.onStartUp( function( win, doc ){
- window = win;
- document = doc;
- var pageWindow = Tracker.View.ControlFrame.getWindow( "tracker_page" );
- original__tracker__ = pageWindow.__tracker__;
- this.body.innerHTML = template.page( {
- stateHtml: template.state( { text: "准备就绪", color: null } ),
- startBtnId: startBtnId = Tracker.Util.id(),
- stopBtnId: stopBtnId = Tracker.Util.id(),
- clearBtnId: clearBtnId = Tracker.Util.id(),
- stateId: stateId = Tracker.Util.id(),
- logerId: logerId = Tracker.Util.id()
- } );
- buttonEventBind( startBtnId, start );
- buttonEventBind( stopBtnId, stop );
- buttonEventBind( clearBtnId, clear );
- if( !started ){
- log( "活动监视器初始化完成" );
- log( "准备就绪" );
- stateEvent.on( "stateChange", buttonStateChange );
- }else{
- if( hooking ){
- buttonStateChange( "start" );
- showState( "监控进行中...", "#c00" );
- }else{
- buttonStateChange( "stop" );
- }
- if( logHtml )
- document.getElementById( logerId ).innerHTML = logHtml;
- }
- eventBuild();
- started = true;
- } );
- this.onActive( function(){
- } );
- } );
- };
|