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-04-08 13:41:34 -07:00
|
|
|
* javelin-util
|
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-04-26 10:30:41 -07:00
|
|
|
* javelin-vector
|
2015-04-13 11:49:30 -07:00
|
|
|
* javelin-scrollbar
|
2015-04-02 13:41:48 -07:00
|
|
|
* phabricator-title
|
2014-02-17 15:57:13 -08:00
|
|
|
* phabricator-shaped-request
|
2015-03-10 12:20:29 -07:00
|
|
|
* conpherence-thread-manager
|
2013-01-24 17:23:05 -08:00
|
|
|
*/
|
|
|
|
|
|
|
|
JX.behavior('conpherence-menu', function(config) {
|
2013-05-29 12:46:06 -07:00
|
|
|
/**
|
|
|
|
* State for displayed thread.
|
|
|
|
*/
|
|
|
|
var _thread = {
|
2013-04-01 12:43:21 -07:00
|
|
|
selected: null,
|
2013-05-29 12:46:06 -07:00
|
|
|
visible: null,
|
|
|
|
node: null
|
2013-04-01 12:43:21 -07:00
|
|
|
};
|
|
|
|
|
2015-04-13 11:49:30 -07:00
|
|
|
var scrollbar = null;
|
|
|
|
|
2015-03-10 12:20:29 -07:00
|
|
|
// TODO - move more logic into the ThreadManager
|
|
|
|
var threadManager = new JX.ConpherenceThreadManager();
|
2015-05-12 14:44:25 -07:00
|
|
|
threadManager.setMessagesRootCallback(function() {
|
|
|
|
return scrollbar.getContentNode();
|
|
|
|
});
|
2015-03-10 13:53:30 -07:00
|
|
|
threadManager.setWillLoadThreadCallback(function() {
|
2016-10-13 19:48:41 -07:00
|
|
|
markThreadsLoading(true);
|
2015-03-10 13:53:30 -07:00
|
|
|
});
|
|
|
|
threadManager.setDidLoadThreadCallback(function(r) {
|
|
|
|
var header = JX.$H(r.header);
|
2016-10-13 11:09:54 -07:00
|
|
|
var search = JX.$H(r.search);
|
2015-05-13 11:06:54 -07:00
|
|
|
var messages = JX.$H(r.transactions);
|
2015-03-10 13:53:30 -07:00
|
|
|
var form = JX.$H(r.form);
|
|
|
|
var root = JX.DOM.find(document, 'div', 'conpherence-layout');
|
|
|
|
var header_root = JX.DOM.find(root, 'div', 'conpherence-header-pane');
|
2016-10-13 11:09:54 -07:00
|
|
|
var search_root = JX.DOM.find(root, 'div', 'conpherence-search-main');
|
2015-03-10 13:53:30 -07:00
|
|
|
var form_root = JX.DOM.find(root, 'div', 'conpherence-form');
|
|
|
|
JX.DOM.setContent(header_root, header);
|
2016-10-13 11:09:54 -07:00
|
|
|
JX.DOM.setContent(search_root, search);
|
2015-04-14 13:04:22 -07:00
|
|
|
JX.DOM.setContent(scrollbar.getContentNode(), messages);
|
2015-03-10 13:53:30 -07:00
|
|
|
JX.DOM.setContent(form_root, form);
|
|
|
|
|
2016-10-13 19:48:41 -07:00
|
|
|
markThreadsLoading(false);
|
2015-03-10 13:53:30 -07:00
|
|
|
|
|
|
|
didRedrawThread(true);
|
|
|
|
});
|
2015-04-14 13:04:22 -07:00
|
|
|
|
2015-03-10 13:53:30 -07:00
|
|
|
threadManager.setDidUpdateThreadCallback(function(r) {
|
2015-04-13 15:24:48 -07:00
|
|
|
_scrollMessageWindow();
|
2015-03-10 12:20:29 -07:00
|
|
|
});
|
2015-04-14 13:04:22 -07:00
|
|
|
|
2015-03-10 12:20:29 -07:00
|
|
|
threadManager.setWillSendMessageCallback(function () {
|
|
|
|
var root = JX.DOM.find(document, 'div', 'conpherence-layout');
|
|
|
|
var form_root = JX.DOM.find(root, 'div', 'conpherence-form');
|
|
|
|
markThreadLoading(true);
|
|
|
|
JX.DOM.alterClass(form_root, 'loading', true);
|
|
|
|
});
|
2015-04-14 13:04:22 -07:00
|
|
|
|
2015-04-09 15:07:12 -07:00
|
|
|
threadManager.setDidSendMessageCallback(function (r, non_update) {
|
2015-03-10 12:20:29 -07:00
|
|
|
var root = JX.DOM.find(document, 'div', 'conpherence-layout');
|
|
|
|
var form_root = JX.DOM.find(root, 'div', 'conpherence-form');
|
2015-04-09 15:07:12 -07:00
|
|
|
var textarea = JX.DOM.find(form_root, 'textarea');
|
|
|
|
if (!non_update) {
|
2015-05-13 11:06:54 -07:00
|
|
|
_scrollMessageWindow();
|
2015-04-09 15:07:12 -07:00
|
|
|
textarea.value = '';
|
2015-03-10 12:20:29 -07:00
|
|
|
}
|
|
|
|
markThreadLoading(false);
|
|
|
|
|
|
|
|
setTimeout(function() { JX.DOM.focus(textarea); }, 100);
|
|
|
|
});
|
|
|
|
threadManager.start();
|
|
|
|
|
2013-05-29 12:46:06 -07:00
|
|
|
/**
|
|
|
|
* Current role of this behavior. The two possible roles are to show a 'list'
|
|
|
|
* of threads or a specific 'thread'. On devices, this behavior stays in the
|
|
|
|
* 'list' role indefinitely, treating clicks normally and the next page
|
|
|
|
* loads the behavior with role = 'thread'. On desktop, this behavior
|
|
|
|
* auto-loads a thread as part of the 'list' role. As the thread loads the
|
|
|
|
* role is changed to 'thread'.
|
|
|
|
*/
|
|
|
|
var _currentRole = null;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* When _oldDevice is null the code is executing for the first time.
|
|
|
|
*/
|
|
|
|
var _oldDevice = null;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Initializes this behavior based on all the configuraton jonx and the
|
|
|
|
* result of JX.Device.getDevice();
|
|
|
|
*/
|
|
|
|
function init() {
|
|
|
|
_currentRole = config.role;
|
|
|
|
|
|
|
|
if (_currentRole == 'thread') {
|
|
|
|
markThreadsLoading(true);
|
|
|
|
} else {
|
|
|
|
markThreadLoading(true);
|
2013-04-01 12:44:00 -07:00
|
|
|
}
|
2013-05-29 12:46:06 -07:00
|
|
|
markWidgetLoading(true);
|
|
|
|
onDeviceChange();
|
2015-04-13 11:49:30 -07:00
|
|
|
var root = JX.DOM.find(document, 'div', 'conpherence-layout');
|
|
|
|
var messages_root = JX.DOM.find(root, 'div', 'conpherence-message-pane');
|
|
|
|
var messages = JX.DOM.find(messages_root, 'div', 'conpherence-messages');
|
|
|
|
scrollbar = new JX.Scrollbar(messages);
|
2015-04-30 16:54:57 -07:00
|
|
|
scrollbar.setAsScrollFrame();
|
2013-04-01 12:44:00 -07:00
|
|
|
}
|
2013-05-29 12:46:06 -07:00
|
|
|
init();
|
2013-04-01 12:44:00 -07:00
|
|
|
|
2013-05-29 12:46:06 -07:00
|
|
|
/**
|
|
|
|
* Selecting threads
|
|
|
|
*/
|
|
|
|
function selectThreadByID(id, update_page_data) {
|
|
|
|
var thread = JX.$(id);
|
|
|
|
selectThread(thread, update_page_data);
|
|
|
|
}
|
2013-04-01 12:43:21 -07:00
|
|
|
|
2013-05-29 12:46:06 -07:00
|
|
|
function selectThread(node, update_page_data) {
|
|
|
|
if (_thread.node) {
|
|
|
|
JX.DOM.alterClass(_thread.node, 'conpherence-selected', false);
|
2013-04-01 12:43:21 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
JX.DOM.alterClass(node, 'conpherence-selected', true);
|
|
|
|
JX.DOM.alterClass(node, 'hide-unread-count', true);
|
|
|
|
|
2013-05-29 12:46:06 -07:00
|
|
|
_thread.node = node;
|
2013-04-01 12:43:21 -07:00
|
|
|
|
|
|
|
var data = JX.Stratcom.getData(node);
|
2013-05-29 12:46:06 -07:00
|
|
|
_thread.selected = data.threadID;
|
2013-04-01 12:43:21 -07:00
|
|
|
|
2013-05-29 12:46:06 -07:00
|
|
|
if (update_page_data) {
|
|
|
|
updatePageData(data);
|
2013-04-15 16:27:41 -07:00
|
|
|
}
|
2013-04-10 11:37:04 -07:00
|
|
|
|
2013-05-29 12:46:06 -07:00
|
|
|
redrawThread();
|
2013-04-01 12:43:21 -07:00
|
|
|
}
|
|
|
|
|
2013-05-29 12:46:06 -07:00
|
|
|
function updatePageData(data) {
|
2015-04-13 12:45:55 -07:00
|
|
|
var uri = '/Z' + _thread.selected;
|
|
|
|
JX.History.replace(uri);
|
2013-04-15 16:27:41 -07:00
|
|
|
if (data.title) {
|
2015-04-02 13:41:48 -07:00
|
|
|
JX.Title.setTitle(data.title);
|
2013-05-29 12:46:06 -07:00
|
|
|
} else if (_thread.node) {
|
|
|
|
var threadData = JX.Stratcom.getData(_thread.node);
|
2015-04-02 13:41:48 -07:00
|
|
|
JX.Title.setTitle(threadData.title);
|
2013-04-15 16:27:41 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
JX.Stratcom.listen(
|
|
|
|
'conpherence-update-page-data',
|
|
|
|
null,
|
|
|
|
function (e) {
|
2013-05-29 12:46:06 -07:00
|
|
|
updatePageData(e.getData());
|
2013-04-15 16:27:41 -07:00
|
|
|
}
|
|
|
|
);
|
|
|
|
|
2013-05-29 12:46:06 -07:00
|
|
|
function redrawThread() {
|
|
|
|
if (!_thread.node) {
|
2013-04-01 12:43:21 -07:00
|
|
|
return;
|
|
|
|
}
|
2013-04-01 12:52:56 -07:00
|
|
|
|
2013-05-29 12:46:06 -07:00
|
|
|
if (_thread.visible == _thread.selected) {
|
2013-04-01 12:43:21 -07:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2013-05-29 12:46:06 -07:00
|
|
|
var data = JX.Stratcom.getData(_thread.node);
|
2013-04-01 12:43:21 -07:00
|
|
|
|
2013-05-29 12:46:06 -07:00
|
|
|
if (_thread.visible !== null || !config.hasThread) {
|
2015-03-10 13:53:30 -07:00
|
|
|
threadManager.setLoadThreadURI('/conpherence/' + data.threadID + '/');
|
|
|
|
threadManager.loadThreadByID(data.threadID);
|
2013-05-29 12:46:06 -07:00
|
|
|
} else if (config.hasThread) {
|
2015-03-10 13:53:30 -07:00
|
|
|
// we loaded the thread via the server so let the thread manager know
|
|
|
|
threadManager.setLoadedThreadID(config.selectedThreadID);
|
|
|
|
threadManager.setLoadedThreadPHID(config.selectedThreadPHID);
|
|
|
|
threadManager.setLatestTransactionID(config.latestTransactionID);
|
2015-03-25 11:48:22 -07:00
|
|
|
threadManager.setCanEditLoadedThread(config.canEditSelectedThread);
|
2015-05-14 11:14:07 -07:00
|
|
|
threadManager.cacheCurrentTransactions();
|
2013-05-29 12:46:06 -07:00
|
|
|
_scrollMessageWindow();
|
2015-02-25 15:14:27 -08:00
|
|
|
_focusTextarea();
|
2013-04-08 11:13:35 -07:00
|
|
|
} else {
|
2013-05-29 12:46:06 -07:00
|
|
|
didRedrawThread();
|
2013-04-01 12:52:56 -07:00
|
|
|
}
|
2013-04-01 12:43:21 -07:00
|
|
|
|
2013-05-29 12:46:06 -07:00
|
|
|
if (_thread.visible !== null || !config.hasWidgets) {
|
2013-05-29 14:35:34 -07:00
|
|
|
reloadWidget(data);
|
2013-04-01 12:52:56 -07:00
|
|
|
}
|
2013-04-01 12:43:21 -07:00
|
|
|
|
2013-05-29 12:46:06 -07:00
|
|
|
_thread.visible = _thread.selected;
|
2013-04-01 12:43:21 -07:00
|
|
|
}
|
|
|
|
|
2013-05-29 12:46:06 -07:00
|
|
|
function markThreadsLoading(loading) {
|
2016-10-13 11:09:54 -07:00
|
|
|
var root = JX.$('conpherence-main-layout');
|
|
|
|
JX.DOM.alterClass(root, 'loading', loading);
|
2016-10-13 19:48:41 -07:00
|
|
|
}
|
2013-05-29 12:46:06 -07:00
|
|
|
|
2016-10-13 19:48:41 -07:00
|
|
|
function markThreadLoading(loading) {
|
2013-05-29 12:46:06 -07:00
|
|
|
try {
|
|
|
|
var textarea = JX.DOM.find(form, 'textarea');
|
|
|
|
textarea.disabled = loading;
|
|
|
|
var button = JX.DOM.find(form, 'button');
|
|
|
|
button.disabled = loading;
|
|
|
|
} catch (ex) {
|
|
|
|
// haven't loaded it yet!
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function markWidgetLoading(loading) {
|
|
|
|
var root = JX.DOM.find(document, 'div', 'conpherence-layout');
|
2016-09-15 13:21:21 -07:00
|
|
|
var widgets_root = JX.DOM.find(root, 'div', 'conpherence-participant-pane');
|
2013-05-29 12:46:06 -07:00
|
|
|
|
|
|
|
JX.DOM.alterClass(widgets_root, 'loading', loading);
|
|
|
|
}
|
|
|
|
|
2013-05-29 14:35:34 -07:00
|
|
|
function reloadWidget(data) {
|
|
|
|
markWidgetLoading(true);
|
|
|
|
if (!data.widget) {
|
|
|
|
data.widget = getDefaultWidget();
|
|
|
|
}
|
2016-09-14 18:34:11 -07:00
|
|
|
var widget_uri = config.baseURI + 'participant/' + data.threadID + '/';
|
2013-05-29 14:35:34 -07:00
|
|
|
new JX.Workflow(widget_uri, {})
|
|
|
|
.setHandler(JX.bind(null, onWidgetResponse, data.threadID, data.widget))
|
|
|
|
.start();
|
|
|
|
}
|
|
|
|
JX.Stratcom.listen(
|
|
|
|
'conpherence-reload-widget',
|
|
|
|
null,
|
|
|
|
function (e) {
|
|
|
|
var data = e.getData();
|
|
|
|
if (data.threadID != _thread.selected) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
reloadWidget(data);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
function onWidgetResponse(thread_id, widget, response) {
|
2013-05-29 12:46:06 -07:00
|
|
|
// we got impatient and this is no longer the right answer :/
|
|
|
|
if (_thread.selected != thread_id) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
var root = JX.DOM.find(document, 'div', 'conpherence-layout');
|
|
|
|
var widgets_root = JX.DOM.find(root, 'div', 'conpherence-widgets-holder');
|
|
|
|
JX.DOM.setContent(widgets_root, JX.$H(response.widgets));
|
2013-05-24 10:50:18 -07:00
|
|
|
}
|
|
|
|
|
2013-05-29 12:46:06 -07:00
|
|
|
function getDefaultWidget() {
|
2016-10-18 21:49:02 -07:00
|
|
|
return 'widgets-people';
|
2013-02-15 14:01:27 -08:00
|
|
|
}
|
|
|
|
|
2013-05-29 12:46:06 -07:00
|
|
|
/**
|
|
|
|
* This function is a wee bit tricky. Internally, we want to scroll the
|
|
|
|
* message window and let other stuff - notably widgets - redraw / build if
|
|
|
|
* necessary. Externally, we want a hook to scroll the message window
|
|
|
|
* - notably when the widget selector is used to invoke the message pane.
|
|
|
|
* The following three functions get 'er done.
|
|
|
|
*/
|
2015-02-25 15:14:27 -08:00
|
|
|
function didRedrawThread(build_device_widget_selector) {
|
|
|
|
_scrollMessageWindow();
|
|
|
|
_focusTextarea();
|
|
|
|
JX.Stratcom.invoke(
|
|
|
|
'conpherence-did-redraw-thread',
|
|
|
|
null,
|
|
|
|
{
|
|
|
|
widget : getDefaultWidget(),
|
|
|
|
threadID : _thread.selected,
|
|
|
|
buildDeviceWidgetSelector : build_device_widget_selector
|
|
|
|
});
|
2013-05-29 12:46:06 -07:00
|
|
|
}
|
2015-04-30 16:54:57 -07:00
|
|
|
|
2015-04-13 15:24:48 -07:00
|
|
|
var _firstScroll = true;
|
2013-05-29 12:46:06 -07:00
|
|
|
function _scrollMessageWindow() {
|
2015-04-13 15:24:48 -07:00
|
|
|
if (_firstScroll) {
|
|
|
|
_firstScroll = false;
|
2015-04-30 16:54:57 -07:00
|
|
|
|
|
|
|
// We want to let the standard #anchor tech take over after we make sure
|
|
|
|
// we don't have to present the user with a "load older message?" dialog
|
2015-04-13 15:24:48 -07:00
|
|
|
if (window.location.hash) {
|
2015-04-30 16:54:57 -07:00
|
|
|
var hash = window.location.hash.replace(/^#/, '');
|
|
|
|
try {
|
|
|
|
JX.$('anchor-' + hash);
|
|
|
|
} catch (ex) {
|
|
|
|
var uri = '/conpherence/' +
|
|
|
|
_thread.selected + '/' + hash + '/';
|
|
|
|
threadManager.setLoadThreadURI(uri);
|
|
|
|
threadManager.loadThreadByID(_thread.selected, true);
|
|
|
|
_firstScroll = true;
|
|
|
|
return;
|
|
|
|
}
|
2015-04-13 15:24:48 -07:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
2015-04-14 13:04:22 -07:00
|
|
|
scrollbar.scrollTo(scrollbar.getViewportNode().scrollHeight);
|
2013-05-29 12:46:06 -07:00
|
|
|
}
|
2015-02-25 15:14:27 -08:00
|
|
|
function _focusTextarea() {
|
|
|
|
var root = JX.DOM.find(document, 'div', 'conpherence-layout');
|
|
|
|
var form_root = JX.DOM.find(root, 'div', 'conpherence-form');
|
2015-03-24 18:38:16 -07:00
|
|
|
try {
|
|
|
|
var textarea = JX.DOM.find(form_root, 'textarea');
|
|
|
|
// We may have a draft so do this JS trick so we end up focused at the
|
|
|
|
// end of the draft.
|
|
|
|
var textarea_value = textarea.value;
|
|
|
|
textarea.value = '';
|
|
|
|
JX.DOM.focus(textarea);
|
|
|
|
textarea.value = textarea_value;
|
|
|
|
} catch (ex) {
|
|
|
|
// no textarea? no problem
|
|
|
|
}
|
2015-02-25 15:14:27 -08:00
|
|
|
}
|
2013-04-15 16:27:41 -07:00
|
|
|
JX.Stratcom.listen(
|
|
|
|
'conpherence-redraw-thread',
|
2013-04-22 16:18:18 -07:00
|
|
|
null,
|
2014-06-24 03:27:47 +10:00
|
|
|
function () {
|
2013-05-29 12:46:06 -07:00
|
|
|
_scrollMessageWindow();
|
2013-04-15 16:27:41 -07:00
|
|
|
}
|
|
|
|
);
|
|
|
|
|
2013-01-24 17:23:05 -08:00
|
|
|
JX.Stratcom.listen(
|
|
|
|
'click',
|
|
|
|
'conpherence-menu-click',
|
|
|
|
function(e) {
|
2013-03-31 15:19:14 -07:00
|
|
|
if (!e.isNormalClick()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2013-04-01 12:50:51 -07:00
|
|
|
// On devices, just follow the link normally.
|
|
|
|
if (JX.Device.getDevice() != 'desktop') {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2013-01-24 17:23:05 -08:00
|
|
|
e.kill();
|
2013-05-29 12:46:06 -07:00
|
|
|
selectThread(e.getNode('conpherence-menu-click'), true);
|
2013-04-01 12:43:21 -07:00
|
|
|
});
|
2013-01-24 17:23:05 -08:00
|
|
|
|
2013-05-29 12:46:06 -07:00
|
|
|
/**
|
|
|
|
* On devices, 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, changing the _currentRole from list to thread.
|
|
|
|
*/
|
|
|
|
function onDeviceChange() {
|
2013-04-02 06:44:31 -07:00
|
|
|
var new_device = JX.Device.getDevice();
|
2013-05-29 12:46:06 -07:00
|
|
|
if (new_device === _oldDevice) {
|
2013-04-02 06:44:31 -07:00
|
|
|
return;
|
|
|
|
}
|
2013-05-24 10:50:18 -07:00
|
|
|
|
2013-05-29 12:46:06 -07:00
|
|
|
if (_oldDevice === null) {
|
|
|
|
_oldDevice = new_device;
|
|
|
|
if (_currentRole == 'list') {
|
2013-05-24 10:50:18 -07:00
|
|
|
if (new_device != 'desktop') {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
} else {
|
2013-05-29 12:46:06 -07:00
|
|
|
loadThreads();
|
2013-05-24 10:50:18 -07:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
2013-04-15 16:27:41 -07:00
|
|
|
var update_toggled_widget =
|
2013-05-29 12:46:06 -07:00
|
|
|
new_device == 'desktop' || _oldDevice == 'desktop';
|
|
|
|
_oldDevice = new_device;
|
2013-04-02 06:44:31 -07:00
|
|
|
|
2013-05-29 12:46:06 -07:00
|
|
|
if (_thread.visible !== null && update_toggled_widget) {
|
|
|
|
JX.Stratcom.invoke(
|
|
|
|
'conpherence-did-redraw-thread',
|
|
|
|
null,
|
|
|
|
{
|
|
|
|
widget : getDefaultWidget(),
|
|
|
|
threadID : _thread.selected
|
|
|
|
});
|
2013-04-01 12:43:21 -07:00
|
|
|
}
|
|
|
|
|
2013-05-29 12:46:06 -07:00
|
|
|
if (_currentRole == 'list' && new_device == 'desktop') {
|
|
|
|
// this selects a thread and loads it
|
|
|
|
didLoadThreads();
|
|
|
|
_currentRole = 'thread';
|
2013-05-24 10:50:18 -07:00
|
|
|
var root = JX.DOM.find(document, 'div', 'conpherence-layout');
|
|
|
|
JX.DOM.alterClass(root, 'conpherence-role-list', false);
|
|
|
|
JX.DOM.alterClass(root, 'conpherence-role-thread', true);
|
2013-04-01 12:43:21 -07:00
|
|
|
}
|
|
|
|
}
|
2013-05-29 12:46:06 -07:00
|
|
|
JX.Stratcom.listen('phabricator-device-change', null, onDeviceChange);
|
2013-04-01 12:43:21 -07:00
|
|
|
|
2013-05-29 12:46:06 -07:00
|
|
|
function loadThreads() {
|
|
|
|
markThreadsLoading(true);
|
|
|
|
var uri = config.baseURI + 'thread/' + config.selectedThreadID + '/';
|
2013-04-01 12:52:56 -07:00
|
|
|
new JX.Workflow(uri)
|
2013-05-29 12:46:06 -07:00
|
|
|
.setHandler(onLoadThreadsResponse)
|
2013-04-01 12:52:56 -07:00
|
|
|
.start();
|
|
|
|
}
|
|
|
|
|
2013-05-29 12:46:06 -07:00
|
|
|
function onLoadThreadsResponse(r) {
|
2013-04-01 12:52:56 -07:00
|
|
|
var layout = JX.$(config.layoutID);
|
|
|
|
var menu = JX.DOM.find(layout, 'div', 'conpherence-menu-pane');
|
|
|
|
JX.DOM.setContent(menu, JX.$H(r));
|
|
|
|
|
2013-05-29 12:46:06 -07:00
|
|
|
config.selectedID && selectThreadByID(config.selectedID);
|
|
|
|
|
|
|
|
markThreadsLoading(false);
|
2013-04-01 12:52:56 -07:00
|
|
|
}
|
|
|
|
|
2013-05-29 12:46:06 -07:00
|
|
|
function didLoadThreads() {
|
2013-04-01 12:52:56 -07:00
|
|
|
// If there's no thread selected yet, select the current thread or the
|
|
|
|
// first thread.
|
2013-05-29 12:46:06 -07:00
|
|
|
if (!_thread.selected) {
|
2013-04-01 12:52:56 -07:00
|
|
|
if (config.selectedID) {
|
2013-05-29 12:46:06 -07:00
|
|
|
selectThreadByID(config.selectedID, true);
|
2013-04-01 12:52:56 -07:00
|
|
|
} else {
|
2013-04-15 16:27:41 -07:00
|
|
|
var layout = JX.$(config.layoutID);
|
|
|
|
var threads = JX.DOM.scry(layout, 'a', 'conpherence-menu-click');
|
2013-04-01 12:52:56 -07:00
|
|
|
if (threads.length) {
|
2013-05-29 12:46:06 -07:00
|
|
|
selectThread(threads[0]);
|
2013-04-15 16:27:41 -07:00
|
|
|
} else {
|
|
|
|
var nothreads = JX.DOM.find(layout, 'div', 'conpherence-no-threads');
|
|
|
|
nothreads.style.display = 'block';
|
2013-05-30 12:42:55 -07:00
|
|
|
markThreadLoading(false);
|
|
|
|
markWidgetLoading(false);
|
2013-04-01 12:52:56 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2013-03-15 23:41:36 -07:00
|
|
|
}
|
|
|
|
|
2013-04-26 10:30:41 -07:00
|
|
|
JX.Stratcom.listen(
|
|
|
|
['click'],
|
2015-03-31 12:45:32 -07:00
|
|
|
'conpherence-menu-see-more',
|
|
|
|
function (e) {
|
|
|
|
e.kill();
|
|
|
|
var sigil = e.getNodeData('conpherence-menu-see-more').moreSigil;
|
|
|
|
var root = JX.$('conpherence-menu-pane');
|
|
|
|
var more = JX.DOM.scry(root, 'li', sigil);
|
|
|
|
for (var i = 0; i < more.length; i++) {
|
|
|
|
JX.DOM.alterClass(more[i], 'hidden', false);
|
|
|
|
}
|
|
|
|
JX.DOM.hide(e.getNode('conpherence-menu-see-more'));
|
|
|
|
});
|
2013-04-26 10:30:41 -07:00
|
|
|
|
2014-02-17 15:57:13 -08:00
|
|
|
JX.Stratcom.listen(
|
|
|
|
['keydown'],
|
|
|
|
'conpherence-pontificate',
|
2015-03-11 15:54:07 -07:00
|
|
|
function (e) {
|
|
|
|
threadManager.handleDraftKeydown(e);
|
|
|
|
});
|
2014-02-17 15:57:13 -08:00
|
|
|
|
2013-01-24 17:23:05 -08:00
|
|
|
});
|