| 
									
										
										
										
											2011-01-25 11:57:47 -08:00
										 |  |  | /** | 
					
						
							|  |  |  |  * @provides javelin-behavior-differential-populate | 
					
						
							| 
									
										
										
											
												Bring Javelin into Phabricator via git submodule, not copy-and-paste
Summary:
Javelin is currently embedded in Phabricator via copy-and-paste of prebuilt
packages. This is not so great.
Pull it in as a submodule instead and make all the Phabriator resources declare
proper dependency trees. Add Javelin linting.
Test Plan:
I tried to run through pretty much all the JS functionality on the site. This is
still a high-risk change, but I did a pretty thorough test
Differential: inline comments, revealing diffs, list tokenizers, comment
preview, editing/deleting comments, add review action.
Maniphest: list tokenizer, comment actions
Herald: rule editing, tokenizers, add/remove rows
Reviewed By: tomo
Reviewers: aran, tomo, mroch, jungejason, tuomaspelkonen
CC: aran, tomo, epriestley
Differential Revision: 223
											
										 
											2011-05-03 15:11:55 -07:00
										 |  |  |  * @requires javelin-behavior | 
					
						
							| 
									
										
										
										
											2011-07-16 07:09:19 -07:00
										 |  |  |  *           javelin-workflow | 
					
						
							| 
									
										
										
											
												Bring Javelin into Phabricator via git submodule, not copy-and-paste
Summary:
Javelin is currently embedded in Phabricator via copy-and-paste of prebuilt
packages. This is not so great.
Pull it in as a submodule instead and make all the Phabriator resources declare
proper dependency trees. Add Javelin linting.
Test Plan:
I tried to run through pretty much all the JS functionality on the site. This is
still a high-risk change, but I did a pretty thorough test
Differential: inline comments, revealing diffs, list tokenizers, comment
preview, editing/deleting comments, add review action.
Maniphest: list tokenizer, comment actions
Herald: rule editing, tokenizers, add/remove rows
Reviewed By: tomo
Reviewers: aran, tomo, mroch, jungejason, tuomaspelkonen
CC: aran, tomo, epriestley
Differential Revision: 223
											
										 
											2011-05-03 15:11:55 -07:00
										 |  |  |  *           javelin-util | 
					
						
							|  |  |  |  *           javelin-dom | 
					
						
							| 
									
										
										
										
											2012-03-12 20:04:12 -07:00
										 |  |  |  *           javelin-stratcom | 
					
						
							|  |  |  |  *           phabricator-tooltip | 
					
						
							| 
									
										
										
										
											2011-01-25 11:57:47 -08:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | JX.behavior('differential-populate', function(config) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   function onresponse(target, response) { | 
					
						
							| 
									
										
										
										
											2012-03-12 17:06:55 -07:00
										 |  |  |     JX.DOM.replace(JX.$(target), JX.$H(response.changeset)); | 
					
						
							|  |  |  |     if (response.coverage) { | 
					
						
							|  |  |  |       for (var k in response.coverage) { | 
					
						
							|  |  |  |         try { | 
					
						
							|  |  |  |           JX.DOM.replace(JX.$(k), JX.$H(response.coverage[k])); | 
					
						
							|  |  |  |         } catch (ignored) { | 
					
						
							|  |  |  |           // Not terribly important.
 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2011-01-25 11:57:47 -08:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   for (var k in config.registry) { | 
					
						
							| 
									
										
										
										
											2011-07-16 07:09:19 -07:00
										 |  |  |     var data = { | 
					
						
							|  |  |  |       ref : config.registry[k], | 
					
						
							|  |  |  |       whitespace: config.whitespace | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     new JX.Workflow(config.uri, data) | 
					
						
							|  |  |  |       .setHandler(JX.bind(null, onresponse, k)) | 
					
						
							|  |  |  |       .start(); | 
					
						
							| 
									
										
										
										
											2011-01-25 11:57:47 -08:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-12 20:04:12 -07:00
										 |  |  |   var highlighted = null; | 
					
						
							|  |  |  |   var highlight_class = null; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   JX.Stratcom.listen( | 
					
						
							|  |  |  |     ['mouseover', 'mouseout'], | 
					
						
							|  |  |  |     ['differential-changeset', 'tag:td'], | 
					
						
							|  |  |  |     function(e) { | 
					
						
							|  |  |  |       var t = e.getTarget(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       // NOTE: Using className is not best practice, but the diff UI is perf
 | 
					
						
							|  |  |  |       // sensitive.
 | 
					
						
							|  |  |  |       if (!t.className.match(/cov/)) { | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (e.getType() == 'mouseout') { | 
					
						
							|  |  |  |         JX.Tooltip.hide(); | 
					
						
							|  |  |  |         if (highlighted) { | 
					
						
							|  |  |  |           JX.DOM.alterClass(highlighted, highlight_class, false); | 
					
						
							|  |  |  |           highlighted = null; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  |         highlight_class = null; | 
					
						
							|  |  |  |         var msg; | 
					
						
							|  |  |  |         if (t.className.match(/cov-C/)) { | 
					
						
							|  |  |  |           msg = 'Covered'; | 
					
						
							|  |  |  |           highlight_class = 'source-cov-C'; | 
					
						
							|  |  |  |         } else if (t.className.match(/cov-U/)) { | 
					
						
							|  |  |  |           msg = 'Not Covered'; | 
					
						
							|  |  |  |           highlight_class = 'source-cov-U'; | 
					
						
							|  |  |  |         } else if (t.className.match(/cov-N/)) { | 
					
						
							|  |  |  |           msg = 'Not Executable'; | 
					
						
							|  |  |  |           highlight_class = 'source-cov-N'; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (msg) { | 
					
						
							|  |  |  |           JX.Tooltip.show(t, 120, 'E', msg); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (highlight_class) { | 
					
						
							|  |  |  |           highlighted = t.previousSibling; | 
					
						
							|  |  |  |           JX.DOM.alterClass(highlighted, highlight_class, true); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-01-25 11:57:47 -08:00
										 |  |  | }); |