| 
									
										
										
										
											2013-03-31 15:19:14 -07:00
										 |  |  | /** | 
					
						
							| 
									
										
										
										
											2013-01-24 17:23:05 -08:00
										 |  |  |  * @provides javelin-behavior-conpherence-menu | 
					
						
							|  |  |  |  * @requires javelin-behavior | 
					
						
							|  |  |  |  *           javelin-dom | 
					
						
							| 
									
										
										
										
											2013-03-08 10:40:06 -08:00
										 |  |  |  *           javelin-request | 
					
						
							| 
									
										
										
										
											2013-01-24 17:23:05 -08:00
										 |  |  |  *           javelin-stratcom | 
					
						
							| 
									
										
										
										
											2013-03-08 10:40:06 -08:00
										 |  |  |  *           javelin-workflow | 
					
						
							| 
									
										
										
										
											2013-04-01 12:43:21 -07:00
										 |  |  |  *           javelin-behavior-device | 
					
						
							| 
									
										
										
										
											2013-03-31 15:19:14 -07:00
										 |  |  |  *           javelin-history | 
					
						
							| 
									
										
										
										
											2013-01-24 17:23:05 -08:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | JX.behavior('conpherence-menu', function(config) { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-01 12:43:21 -07:00
										 |  |  |   var thread = { | 
					
						
							|  |  |  |     selected: null, | 
					
						
							|  |  |  |     node: null, | 
					
						
							|  |  |  |     visible: null | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-01 12:44:00 -07:00
										 |  |  |   function selectthreadid(id) { | 
					
						
							|  |  |  |     var threads = JX.DOM.scry(document.body, 'a', 'conpherence-menu-click'); | 
					
						
							|  |  |  |     for (var ii = 0; ii < threads.length; ii++) { | 
					
						
							|  |  |  |       var data = JX.Stratcom.getData(threads[ii]); | 
					
						
							|  |  |  |       if (data.id == id) { | 
					
						
							|  |  |  |         selectthread(threads[ii]); | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-01 12:43:21 -07:00
										 |  |  |   function selectthread(node) { | 
					
						
							|  |  |  |     if (node === thread.node) { | 
					
						
							|  |  |  |       return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (thread.node) { | 
					
						
							|  |  |  |       JX.DOM.alterClass(thread.node, 'conpherence-selected', false); | 
					
						
							|  |  |  |       JX.DOM.alterClass(thread.node, 'hide-unread-count', false); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     JX.DOM.alterClass(node, 'conpherence-selected', true); | 
					
						
							|  |  |  |     JX.DOM.alterClass(node, 'hide-unread-count', true); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     thread.node = node; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     var data = JX.Stratcom.getData(node); | 
					
						
							| 
									
										
										
										
											2013-04-01 12:44:00 -07:00
										 |  |  |     thread.selected = data.id; | 
					
						
							| 
									
										
										
										
											2013-04-01 12:43:21 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-01 12:44:00 -07:00
										 |  |  |     JX.History.replace(config.base_uri + data.id + '/'); | 
					
						
							| 
									
										
										
										
											2013-04-01 12:43:21 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     redrawthread(); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   function redrawthread() { | 
					
						
							|  |  |  |     if (!thread.node) { | 
					
						
							|  |  |  |       return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (thread.visible == thread.selected) { | 
					
						
							|  |  |  |       return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     var data = JX.Stratcom.getData(thread.node); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     var uri = config.base_uri + 'view/' + data.id + '/'; | 
					
						
							|  |  |  |     var widget_uri = config.base_uri + 'widget/' + data.id + '/'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     new JX.Workflow(uri, {}) | 
					
						
							|  |  |  |       .setHandler(onresponse) | 
					
						
							|  |  |  |       .start(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     new JX.Workflow(widget_uri, {}) | 
					
						
							|  |  |  |       .setHandler(onwidgetresponse) | 
					
						
							|  |  |  |       .start(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     thread.visible = thread.selected; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   function onwidgetresponse(response) { | 
					
						
							| 
									
										
										
										
											2013-02-15 14:01:27 -08:00
										 |  |  |     var widgets = JX.$H(response.widgets); | 
					
						
							|  |  |  |     var widgetsRoot = JX.$(config.widgets_pane); | 
					
						
							|  |  |  |     JX.DOM.setContent(widgetsRoot, widgets); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-01 12:43:21 -07:00
										 |  |  |   function onresponse(response) { | 
					
						
							| 
									
										
										
										
											2013-01-24 17:23:05 -08:00
										 |  |  |     var header = JX.$H(response.header); | 
					
						
							|  |  |  |     var messages = JX.$H(response.messages); | 
					
						
							|  |  |  |     var form = JX.$H(response.form); | 
					
						
							|  |  |  |     var headerRoot = JX.$(config.header); | 
					
						
							|  |  |  |     var messagesRoot = JX.$(config.messages); | 
					
						
							|  |  |  |     var formRoot = JX.$(config.form_pane); | 
					
						
							|  |  |  |     var widgetsRoot = JX.$(config.widgets_pane); | 
					
						
							| 
									
										
										
										
											2013-02-05 11:58:19 -08:00
										 |  |  |     var menuRoot = JX.$(config.menu_pane); | 
					
						
							| 
									
										
										
										
											2013-01-24 17:23:05 -08:00
										 |  |  |     JX.DOM.setContent(headerRoot, header); | 
					
						
							|  |  |  |     JX.DOM.setContent(messagesRoot, messages); | 
					
						
							|  |  |  |     messagesRoot.scrollTop = messagesRoot.scrollHeight; | 
					
						
							|  |  |  |     JX.DOM.setContent(formRoot, form); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   JX.Stratcom.listen( | 
					
						
							|  |  |  |     'click', | 
					
						
							|  |  |  |     'conpherence-menu-click', | 
					
						
							|  |  |  |     function(e) { | 
					
						
							| 
									
										
										
										
											2013-03-31 15:19:14 -07:00
										 |  |  |       if (!e.isNormalClick()) { | 
					
						
							|  |  |  |         return; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-24 17:23:05 -08:00
										 |  |  |       e.kill(); | 
					
						
							| 
									
										
										
										
											2013-04-01 12:43:21 -07:00
										 |  |  |       selectthread(e.getNode('conpherence-menu-click')); | 
					
						
							|  |  |  |     }); | 
					
						
							| 
									
										
										
										
											2013-01-24 17:23:05 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-08 10:40:06 -08:00
										 |  |  |   JX.Stratcom.listen('click', 'conpherence-edit-metadata', function (e) { | 
					
						
							|  |  |  |     e.kill(); | 
					
						
							| 
									
										
										
										
											2013-03-15 23:41:36 -07:00
										 |  |  |     var root = JX.$(config.form_pane); | 
					
						
							| 
									
										
										
										
											2013-03-08 10:40:06 -08:00
										 |  |  |     var form = JX.DOM.find(root, 'form'); | 
					
						
							|  |  |  |     var data = e.getNodeData('conpherence-edit-metadata'); | 
					
						
							|  |  |  |     new JX.Workflow.newFromForm(form, data) | 
					
						
							|  |  |  |       .setHandler(function (r) { | 
					
						
							|  |  |  |         // update the header
 | 
					
						
							|  |  |  |         JX.DOM.setContent( | 
					
						
							|  |  |  |           JX.$(config.header), | 
					
						
							|  |  |  |           JX.$H(r.header) | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // update the menu entry as well
 | 
					
						
							|  |  |  |         JX.DOM.replace( | 
					
						
							|  |  |  |           JX.$(r.conpherence_phid + '-nav-item'), | 
					
						
							|  |  |  |           JX.$H(r.nav_item) | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |       }) | 
					
						
							|  |  |  |       .start(); | 
					
						
							|  |  |  |   }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-15 14:01:27 -08:00
										 |  |  |   JX.Stratcom.listen('click', 'show-older-messages', function(e) { | 
					
						
							|  |  |  |     e.kill(); | 
					
						
							| 
									
										
										
										
											2013-03-29 17:51:22 -07:00
										 |  |  |     var last_offset = e.getNodeData('show-older-messages').offset; | 
					
						
							|  |  |  |     var conf_id = e.getNodeData('show-older-messages').ID; | 
					
						
							|  |  |  |     JX.DOM.remove(e.getNode('show-older-messages')); | 
					
						
							|  |  |  |     var messages_root = JX.$(config.messages); | 
					
						
							|  |  |  |     new JX.Request('/conpherence/view/'+conf_id+'/', function(r) { | 
					
						
							|  |  |  |       var messages = JX.$H(r.messages); | 
					
						
							|  |  |  |       JX.DOM.prependContent(messages_root, | 
					
						
							|  |  |  |       JX.$H(messages)); | 
					
						
							|  |  |  |     }).setData({ offset: last_offset+1 }).send(); | 
					
						
							| 
									
										
										
										
											2013-03-08 10:40:06 -08:00
										 |  |  |   }); | 
					
						
							| 
									
										
										
										
											2013-02-15 14:01:27 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-01 12:43:21 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   // On mobile, we just show a thread list, so we don't want to automatically
 | 
					
						
							|  |  |  |   // select or load any threads. On Desktop, we automatically select the first
 | 
					
						
							|  |  |  |   // thread.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   function ondevicechange() { | 
					
						
							|  |  |  |     if (JX.Device.getDevice() != 'desktop') { | 
					
						
							|  |  |  |       return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // If there's no thread selected yet, select the first thread.
 | 
					
						
							|  |  |  |     if (!thread.selected) { | 
					
						
							|  |  |  |       var threads = JX.DOM.scry(document.body, 'a', 'conpherence-menu-click'); | 
					
						
							|  |  |  |       if (threads.length) { | 
					
						
							|  |  |  |         selectthread(threads[0]); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // We might have a selected but undrawn thread for
 | 
					
						
							|  |  |  |     redrawthread(); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   JX.Stratcom.listen('phabricator-device-change', null, ondevicechange); | 
					
						
							|  |  |  |   ondevicechange(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // If there's a currently visible thread, select it.
 | 
					
						
							| 
									
										
										
										
											2013-04-01 12:44:00 -07:00
										 |  |  |   if (config.selectedID) { | 
					
						
							|  |  |  |     selectthreadid(config.selectedID); | 
					
						
							| 
									
										
										
										
											2013-03-15 23:41:36 -07:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-01-24 17:23:05 -08:00
										 |  |  | }); |