2015-01-27 15:30:52 +01:00
|
|
|
/**
|
|
|
|
* @provides javelin-behavior-durable-column
|
|
|
|
* @requires javelin-behavior
|
|
|
|
* javelin-dom
|
|
|
|
* javelin-stratcom
|
|
|
|
* javelin-scrollbar
|
Quicksand, an ignoble successor to Quickling
Summary:
Ref T2086. Ref T7014. With the persistent column, there is significant value in retaining chrome state through navigation events, because the user may have a lot of state in the chat window (scroll position, text selection, room juggling, partially entered text, etc). We can do this by capturing navigation events and faking them with Javascript.
(This can also improve performance, albeit slightly, and I believe there are better approaches to tackle performance any problems which exist with the chrome in many cases).
At Facebook, this system was "Photostream" in photos and then "Quickling" in general, and the technical cost of the system was //staggering//. I am loathe to pursue it again. However:
- Browsers are less junky now, and we target a smaller set of browsers. A large part of the technical cost of Quickling was the high complexity of emulating nagivation events in IE, where we needed to navigate a hidden iframe to make history entries. All desktop browsers which we might want to use this system on support the History API (although this prototype does not yet implement it).
- Javelin and Phabricator's architecture are much cleaner than Facebook's was. A large part of the technical cost of Quickling was inconsistency, inlined `onclick` handlers, and general lack of coordination and abstraction. We will have //some// of this, but "correctly written" behaviors are mostly immune to it by design, and many of Javelin's architectural decisions were influenced by desire to avoid issues we encountered building this stuff for Facebook.
- Some of the primitives which Quickling required (like loading resources over Ajax) have existed in a stable state in our codebase for a year or more, and adoption of these primitives was trivial and uneventful (vs a huge production at Facebook).
- My hubris is bolstered by recent success with WebSockets and JX.Scrollbar, both of which I would have assessed as infeasibly complex to develop in this project a few years ago.
To these points, the developer cost to prototype Photostream was several weeks; the developer cost to prototype this was a bit less than an hour. It is plausible to me that implementing and maintaining this system really will be hundreds of times less complex than it was at Facebook.
Test Plan:
My plan for this and D11497 is:
- Get them in master.
- Some secret key / relatively-hidden preference activates the column.
- Quicksand activates //only// when the column is open.
- We can use column + quicksand for a long period of time (i.e., over the course of Conpherence v2 development) and hammer out the long tail of issues.
- When it derps up, you just hide the column and you're good to go.
Reviewers: btrahan, chad
Reviewed By: chad
Subscribers: epriestley
Maniphest Tasks: T2086, T7014
Differential Revision: https://secure.phabricator.com/D11507
2015-01-27 23:52:09 +01:00
|
|
|
* javelin-quicksand
|
2015-01-27 15:30:52 +01:00
|
|
|
* phabricator-keyboard-shortcut
|
|
|
|
*/
|
|
|
|
|
|
|
|
JX.behavior('durable-column', function() {
|
|
|
|
|
Conpherence - make the durable column kind of work and stuff
Summary:
Ref T7014. This hooks up the durable column such that when you open it up it loads your most recent Conpherence. You can then switch amongst the various widgets and stuff and everything works nicely.
Except...
- scroll bar does not work
- also doesn't work at HEAD when I add a ton of text to the UI with no changes? (wrapped $copy in array_fill(0, 1000, $copy))
- "widget selector" does not collapse when you select something else
- this part wasn't really specified so I used the aphlict dropdown stuff. didn't want to keep working on that if this was the wrong UI choice
- can not edit title
- do we still want that to be done by clicking on the title, which pops a dialogue?
- can not add participants or calendar events
- what should this UI be? maybe just a button on the top for "participants" and a button on the bottom for calendar? both on top?
- this is not pixel perfect to the mock or two I've seen around. Aside from generally being bad at that, I definitely didn't get the name + timestamps formatting correctly, because the standard DOM of that has timestamp FIRST which appears second due to a "float right". Seemed like a lot of special-casing for what might not even be that important in the UI so I punted. (And again, there's likely many unknown ways in which this isn't pixel perfect)
There's also code quality issues
- `ConpherenceWidgetConfigConstants` is hopefully temporary or at least gets more sleek as we keep progressing here
- copied some CSS from main Conpherence app
- DOM structure is pretty different
- there's some minor CSS tweaks too given the different width (not to mention the DOM structure being different)
- copied some JS from behavior-pontificate.js to sync threads relative to aphlict updates
- JS in general is like a better version of existing JS; these should collapse I'd hope?
- maybe the aphlict-behavior-dropdown change was badsauce?
...but all that said, this definitely feels really nice and I feel like adding stuff is going to be really easy compared to how normal Conpherence is.
Also includes a bonus bug fix - we now correctly update participation. The user would encounter this issue if they were in a conpherence that got some updates and then they went to a different page; they would have unread status for the messages that were ajax'd in. This patch fixes that by making sure we mark participation up to date with the proper transaction in all cases.
Test Plan: hit "\" to invoke the column and saw nice loading UI and my latest conpherence load. sent messages and verified they received A-OK by looking in DOM console. toggled various widges and verified they rendered correctly. opened up a second browser with a second user on the thread, sent a message, and it was received in a nice asynchronous fashion
Reviewers: chad, epriestley
Reviewed By: epriestley
Subscribers: Korvin, epriestley
Maniphest Tasks: T7014
Differential Revision: https://secure.phabricator.com/D11968
2015-03-05 19:33:39 +01:00
|
|
|
var shouldInit = true;
|
|
|
|
var loadThreadID = null;
|
|
|
|
var loadedThreadID = null;
|
|
|
|
var loadedThreadPHID = null;
|
|
|
|
var latestTransactionID = null;
|
|
|
|
|
2015-01-27 15:30:52 +01:00
|
|
|
var frame = JX.$('phabricator-standard-page');
|
Quicksand, an ignoble successor to Quickling
Summary:
Ref T2086. Ref T7014. With the persistent column, there is significant value in retaining chrome state through navigation events, because the user may have a lot of state in the chat window (scroll position, text selection, room juggling, partially entered text, etc). We can do this by capturing navigation events and faking them with Javascript.
(This can also improve performance, albeit slightly, and I believe there are better approaches to tackle performance any problems which exist with the chrome in many cases).
At Facebook, this system was "Photostream" in photos and then "Quickling" in general, and the technical cost of the system was //staggering//. I am loathe to pursue it again. However:
- Browsers are less junky now, and we target a smaller set of browsers. A large part of the technical cost of Quickling was the high complexity of emulating nagivation events in IE, where we needed to navigate a hidden iframe to make history entries. All desktop browsers which we might want to use this system on support the History API (although this prototype does not yet implement it).
- Javelin and Phabricator's architecture are much cleaner than Facebook's was. A large part of the technical cost of Quickling was inconsistency, inlined `onclick` handlers, and general lack of coordination and abstraction. We will have //some// of this, but "correctly written" behaviors are mostly immune to it by design, and many of Javelin's architectural decisions were influenced by desire to avoid issues we encountered building this stuff for Facebook.
- Some of the primitives which Quickling required (like loading resources over Ajax) have existed in a stable state in our codebase for a year or more, and adoption of these primitives was trivial and uneventful (vs a huge production at Facebook).
- My hubris is bolstered by recent success with WebSockets and JX.Scrollbar, both of which I would have assessed as infeasibly complex to develop in this project a few years ago.
To these points, the developer cost to prototype Photostream was several weeks; the developer cost to prototype this was a bit less than an hour. It is plausible to me that implementing and maintaining this system really will be hundreds of times less complex than it was at Facebook.
Test Plan:
My plan for this and D11497 is:
- Get them in master.
- Some secret key / relatively-hidden preference activates the column.
- Quicksand activates //only// when the column is open.
- We can use column + quicksand for a long period of time (i.e., over the course of Conpherence v2 development) and hammer out the long tail of issues.
- When it derps up, you just hide the column and you're good to go.
Reviewers: btrahan, chad
Reviewed By: chad
Subscribers: epriestley
Maniphest Tasks: T2086, T7014
Differential Revision: https://secure.phabricator.com/D11507
2015-01-27 23:52:09 +01:00
|
|
|
var quick = JX.$('phabricator-standard-page-body');
|
2015-01-27 15:30:52 +01:00
|
|
|
var show = false;
|
|
|
|
|
Conpherence - make the durable column kind of work and stuff
Summary:
Ref T7014. This hooks up the durable column such that when you open it up it loads your most recent Conpherence. You can then switch amongst the various widgets and stuff and everything works nicely.
Except...
- scroll bar does not work
- also doesn't work at HEAD when I add a ton of text to the UI with no changes? (wrapped $copy in array_fill(0, 1000, $copy))
- "widget selector" does not collapse when you select something else
- this part wasn't really specified so I used the aphlict dropdown stuff. didn't want to keep working on that if this was the wrong UI choice
- can not edit title
- do we still want that to be done by clicking on the title, which pops a dialogue?
- can not add participants or calendar events
- what should this UI be? maybe just a button on the top for "participants" and a button on the bottom for calendar? both on top?
- this is not pixel perfect to the mock or two I've seen around. Aside from generally being bad at that, I definitely didn't get the name + timestamps formatting correctly, because the standard DOM of that has timestamp FIRST which appears second due to a "float right". Seemed like a lot of special-casing for what might not even be that important in the UI so I punted. (And again, there's likely many unknown ways in which this isn't pixel perfect)
There's also code quality issues
- `ConpherenceWidgetConfigConstants` is hopefully temporary or at least gets more sleek as we keep progressing here
- copied some CSS from main Conpherence app
- DOM structure is pretty different
- there's some minor CSS tweaks too given the different width (not to mention the DOM structure being different)
- copied some JS from behavior-pontificate.js to sync threads relative to aphlict updates
- JS in general is like a better version of existing JS; these should collapse I'd hope?
- maybe the aphlict-behavior-dropdown change was badsauce?
...but all that said, this definitely feels really nice and I feel like adding stuff is going to be really easy compared to how normal Conpherence is.
Also includes a bonus bug fix - we now correctly update participation. The user would encounter this issue if they were in a conpherence that got some updates and then they went to a different page; they would have unread status for the messages that were ajax'd in. This patch fixes that by making sure we mark participation up to date with the proper transaction in all cases.
Test Plan: hit "\" to invoke the column and saw nice loading UI and my latest conpherence load. sent messages and verified they received A-OK by looking in DOM console. toggled various widges and verified they rendered correctly. opened up a second browser with a second user on the thread, sent a message, and it was received in a nice asynchronous fashion
Reviewers: chad, epriestley
Reviewed By: epriestley
Subscribers: Korvin, epriestley
Maniphest Tasks: T7014
Differential Revision: https://secure.phabricator.com/D11968
2015-03-05 19:33:39 +01:00
|
|
|
|
|
|
|
// TODO - this "upating" stuff is a copy from behavior-pontificate
|
|
|
|
// TODO: This isn't very clean. When you submit a message, you may get a
|
|
|
|
// notification about it back before you get the rendered message back. To
|
|
|
|
// prevent this, we keep track of whether we're currently updating the
|
|
|
|
// thread. If we are, we hold further updates until the response comes
|
|
|
|
// back.
|
|
|
|
|
|
|
|
// After the response returns, we'll do another update if we know about
|
|
|
|
// a transaction newer than the one we got back from the server.
|
|
|
|
var updating = null;
|
|
|
|
// Copy continues with slight modifications for how we store data now
|
|
|
|
JX.Stratcom.listen('aphlict-server-message', null, function(e) {
|
|
|
|
var message = e.getData();
|
|
|
|
|
|
|
|
if (message.type != 'message') {
|
|
|
|
// Not a message event.
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (message.threadPHID != loadedThreadPHID) {
|
|
|
|
// Message event for some thread other than the visible one.
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (message.messageID <= latestTransactionID) {
|
|
|
|
// Message event for something we already know about.
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// If we're currently updating, wait for the update to complete.
|
|
|
|
// If this notification tells us about a message which is newer than the
|
|
|
|
// newest one we know to exist, keep track of it so we can update once
|
|
|
|
// the in-flight update finishes.
|
|
|
|
if (updating && updating.threadPHID == loadedThreadPHID) {
|
|
|
|
if (message.messageID > updating.knownID) {
|
|
|
|
updating.knownID = message.messageID;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
update_thread();
|
|
|
|
});
|
|
|
|
function update_thread() {
|
|
|
|
var params = {
|
|
|
|
action: 'load',
|
|
|
|
latest_transaction_id: latestTransactionID,
|
|
|
|
minimal_display: true
|
|
|
|
};
|
|
|
|
|
|
|
|
var uri = '/conpherence/update/' + loadedThreadID + '/';
|
|
|
|
|
|
|
|
var workflow = new JX.Workflow(uri)
|
|
|
|
.setData(params)
|
|
|
|
.setHandler(function(r) {
|
|
|
|
var messages = _getColumnMessagesNode();
|
|
|
|
JX.DOM.appendContent(messages, JX.$H(r.transactions));
|
|
|
|
messages.scrollTop = messages.scrollHeight;
|
|
|
|
|
|
|
|
latestTransactionID = r.latest_transaction_id;
|
|
|
|
});
|
|
|
|
|
|
|
|
sync_workflow(workflow);
|
|
|
|
}
|
|
|
|
function sync_workflow(workflow) {
|
|
|
|
updating = {
|
|
|
|
threadPHID: loadedThreadPHID,
|
|
|
|
knownID: latestTransactionID
|
|
|
|
};
|
|
|
|
workflow.listen('finally', function() {
|
|
|
|
var need_sync = (updating.knownID > latestTransactionID);
|
|
|
|
updating = null;
|
|
|
|
if (need_sync) {
|
|
|
|
update_thread();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
workflow.start();
|
|
|
|
}
|
|
|
|
// end copy / hack of stuff with big ole TODO on it
|
|
|
|
|
|
|
|
|
2015-03-06 00:32:42 +01:00
|
|
|
function _toggleColumn() {
|
|
|
|
if (window.location.pathname.indexOf('/conpherence/') === 0) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
show = !show;
|
|
|
|
JX.DOM.alterClass(frame, 'with-durable-column', show);
|
|
|
|
var column = JX.$('conpherence-durable-column');
|
|
|
|
if (show) {
|
|
|
|
JX.DOM.show(column);
|
|
|
|
loadThreadContent(loadThreadID);
|
|
|
|
} else {
|
|
|
|
JX.DOM.hide(column);
|
|
|
|
}
|
|
|
|
JX.Stratcom.invoke('resize');
|
|
|
|
JX.Quicksand.setFrame(show ? quick : null);
|
|
|
|
}
|
|
|
|
|
Conpherence - make the durable column kind of work and stuff
Summary:
Ref T7014. This hooks up the durable column such that when you open it up it loads your most recent Conpherence. You can then switch amongst the various widgets and stuff and everything works nicely.
Except...
- scroll bar does not work
- also doesn't work at HEAD when I add a ton of text to the UI with no changes? (wrapped $copy in array_fill(0, 1000, $copy))
- "widget selector" does not collapse when you select something else
- this part wasn't really specified so I used the aphlict dropdown stuff. didn't want to keep working on that if this was the wrong UI choice
- can not edit title
- do we still want that to be done by clicking on the title, which pops a dialogue?
- can not add participants or calendar events
- what should this UI be? maybe just a button on the top for "participants" and a button on the bottom for calendar? both on top?
- this is not pixel perfect to the mock or two I've seen around. Aside from generally being bad at that, I definitely didn't get the name + timestamps formatting correctly, because the standard DOM of that has timestamp FIRST which appears second due to a "float right". Seemed like a lot of special-casing for what might not even be that important in the UI so I punted. (And again, there's likely many unknown ways in which this isn't pixel perfect)
There's also code quality issues
- `ConpherenceWidgetConfigConstants` is hopefully temporary or at least gets more sleek as we keep progressing here
- copied some CSS from main Conpherence app
- DOM structure is pretty different
- there's some minor CSS tweaks too given the different width (not to mention the DOM structure being different)
- copied some JS from behavior-pontificate.js to sync threads relative to aphlict updates
- JS in general is like a better version of existing JS; these should collapse I'd hope?
- maybe the aphlict-behavior-dropdown change was badsauce?
...but all that said, this definitely feels really nice and I feel like adding stuff is going to be really easy compared to how normal Conpherence is.
Also includes a bonus bug fix - we now correctly update participation. The user would encounter this issue if they were in a conpherence that got some updates and then they went to a different page; they would have unread status for the messages that were ajax'd in. This patch fixes that by making sure we mark participation up to date with the proper transaction in all cases.
Test Plan: hit "\" to invoke the column and saw nice loading UI and my latest conpherence load. sent messages and verified they received A-OK by looking in DOM console. toggled various widges and verified they rendered correctly. opened up a second browser with a second user on the thread, sent a message, and it was received in a nice asynchronous fashion
Reviewers: chad, epriestley
Reviewed By: epriestley
Subscribers: Korvin, epriestley
Maniphest Tasks: T7014
Differential Revision: https://secure.phabricator.com/D11968
2015-03-05 19:33:39 +01:00
|
|
|
new JX.KeyboardShortcut('\\', 'Toggle Conpherence Column')
|
2015-03-06 00:32:42 +01:00
|
|
|
.setHandler(_toggleColumn)
|
2015-01-27 15:30:52 +01:00
|
|
|
.register();
|
|
|
|
|
2015-03-01 17:22:05 +01:00
|
|
|
new JX.Scrollbar(JX.$('conpherence-durable-column-content'));
|
2015-01-27 15:30:52 +01:00
|
|
|
|
Quicksand, an ignoble successor to Quickling
Summary:
Ref T2086. Ref T7014. With the persistent column, there is significant value in retaining chrome state through navigation events, because the user may have a lot of state in the chat window (scroll position, text selection, room juggling, partially entered text, etc). We can do this by capturing navigation events and faking them with Javascript.
(This can also improve performance, albeit slightly, and I believe there are better approaches to tackle performance any problems which exist with the chrome in many cases).
At Facebook, this system was "Photostream" in photos and then "Quickling" in general, and the technical cost of the system was //staggering//. I am loathe to pursue it again. However:
- Browsers are less junky now, and we target a smaller set of browsers. A large part of the technical cost of Quickling was the high complexity of emulating nagivation events in IE, where we needed to navigate a hidden iframe to make history entries. All desktop browsers which we might want to use this system on support the History API (although this prototype does not yet implement it).
- Javelin and Phabricator's architecture are much cleaner than Facebook's was. A large part of the technical cost of Quickling was inconsistency, inlined `onclick` handlers, and general lack of coordination and abstraction. We will have //some// of this, but "correctly written" behaviors are mostly immune to it by design, and many of Javelin's architectural decisions were influenced by desire to avoid issues we encountered building this stuff for Facebook.
- Some of the primitives which Quickling required (like loading resources over Ajax) have existed in a stable state in our codebase for a year or more, and adoption of these primitives was trivial and uneventful (vs a huge production at Facebook).
- My hubris is bolstered by recent success with WebSockets and JX.Scrollbar, both of which I would have assessed as infeasibly complex to develop in this project a few years ago.
To these points, the developer cost to prototype Photostream was several weeks; the developer cost to prototype this was a bit less than an hour. It is plausible to me that implementing and maintaining this system really will be hundreds of times less complex than it was at Facebook.
Test Plan:
My plan for this and D11497 is:
- Get them in master.
- Some secret key / relatively-hidden preference activates the column.
- Quicksand activates //only// when the column is open.
- We can use column + quicksand for a long period of time (i.e., over the course of Conpherence v2 development) and hammer out the long tail of issues.
- When it derps up, you just hide the column and you're good to go.
Reviewers: btrahan, chad
Reviewed By: chad
Subscribers: epriestley
Maniphest Tasks: T2086, T7014
Differential Revision: https://secure.phabricator.com/D11507
2015-01-27 23:52:09 +01:00
|
|
|
JX.Quicksand.start();
|
2015-01-27 15:30:52 +01:00
|
|
|
|
Conpherence - make the durable column kind of work and stuff
Summary:
Ref T7014. This hooks up the durable column such that when you open it up it loads your most recent Conpherence. You can then switch amongst the various widgets and stuff and everything works nicely.
Except...
- scroll bar does not work
- also doesn't work at HEAD when I add a ton of text to the UI with no changes? (wrapped $copy in array_fill(0, 1000, $copy))
- "widget selector" does not collapse when you select something else
- this part wasn't really specified so I used the aphlict dropdown stuff. didn't want to keep working on that if this was the wrong UI choice
- can not edit title
- do we still want that to be done by clicking on the title, which pops a dialogue?
- can not add participants or calendar events
- what should this UI be? maybe just a button on the top for "participants" and a button on the bottom for calendar? both on top?
- this is not pixel perfect to the mock or two I've seen around. Aside from generally being bad at that, I definitely didn't get the name + timestamps formatting correctly, because the standard DOM of that has timestamp FIRST which appears second due to a "float right". Seemed like a lot of special-casing for what might not even be that important in the UI so I punted. (And again, there's likely many unknown ways in which this isn't pixel perfect)
There's also code quality issues
- `ConpherenceWidgetConfigConstants` is hopefully temporary or at least gets more sleek as we keep progressing here
- copied some CSS from main Conpherence app
- DOM structure is pretty different
- there's some minor CSS tweaks too given the different width (not to mention the DOM structure being different)
- copied some JS from behavior-pontificate.js to sync threads relative to aphlict updates
- JS in general is like a better version of existing JS; these should collapse I'd hope?
- maybe the aphlict-behavior-dropdown change was badsauce?
...but all that said, this definitely feels really nice and I feel like adding stuff is going to be really easy compared to how normal Conpherence is.
Also includes a bonus bug fix - we now correctly update participation. The user would encounter this issue if they were in a conpherence that got some updates and then they went to a different page; they would have unread status for the messages that were ajax'd in. This patch fixes that by making sure we mark participation up to date with the proper transaction in all cases.
Test Plan: hit "\" to invoke the column and saw nice loading UI and my latest conpherence load. sent messages and verified they received A-OK by looking in DOM console. toggled various widges and verified they rendered correctly. opened up a second browser with a second user on the thread, sent a message, and it was received in a nice asynchronous fashion
Reviewers: chad, epriestley
Reviewed By: epriestley
Subscribers: Korvin, epriestley
Maniphest Tasks: T7014
Differential Revision: https://secure.phabricator.com/D11968
2015-03-05 19:33:39 +01:00
|
|
|
JX.Stratcom.listen(
|
|
|
|
'click',
|
2015-03-06 00:32:42 +01:00
|
|
|
'conpherence-durable-column-header-action',
|
Conpherence - make the durable column kind of work and stuff
Summary:
Ref T7014. This hooks up the durable column such that when you open it up it loads your most recent Conpherence. You can then switch amongst the various widgets and stuff and everything works nicely.
Except...
- scroll bar does not work
- also doesn't work at HEAD when I add a ton of text to the UI with no changes? (wrapped $copy in array_fill(0, 1000, $copy))
- "widget selector" does not collapse when you select something else
- this part wasn't really specified so I used the aphlict dropdown stuff. didn't want to keep working on that if this was the wrong UI choice
- can not edit title
- do we still want that to be done by clicking on the title, which pops a dialogue?
- can not add participants or calendar events
- what should this UI be? maybe just a button on the top for "participants" and a button on the bottom for calendar? both on top?
- this is not pixel perfect to the mock or two I've seen around. Aside from generally being bad at that, I definitely didn't get the name + timestamps formatting correctly, because the standard DOM of that has timestamp FIRST which appears second due to a "float right". Seemed like a lot of special-casing for what might not even be that important in the UI so I punted. (And again, there's likely many unknown ways in which this isn't pixel perfect)
There's also code quality issues
- `ConpherenceWidgetConfigConstants` is hopefully temporary or at least gets more sleek as we keep progressing here
- copied some CSS from main Conpherence app
- DOM structure is pretty different
- there's some minor CSS tweaks too given the different width (not to mention the DOM structure being different)
- copied some JS from behavior-pontificate.js to sync threads relative to aphlict updates
- JS in general is like a better version of existing JS; these should collapse I'd hope?
- maybe the aphlict-behavior-dropdown change was badsauce?
...but all that said, this definitely feels really nice and I feel like adding stuff is going to be really easy compared to how normal Conpherence is.
Also includes a bonus bug fix - we now correctly update participation. The user would encounter this issue if they were in a conpherence that got some updates and then they went to a different page; they would have unread status for the messages that were ajax'd in. This patch fixes that by making sure we mark participation up to date with the proper transaction in all cases.
Test Plan: hit "\" to invoke the column and saw nice loading UI and my latest conpherence load. sent messages and verified they received A-OK by looking in DOM console. toggled various widges and verified they rendered correctly. opened up a second browser with a second user on the thread, sent a message, and it was received in a nice asynchronous fashion
Reviewers: chad, epriestley
Reviewed By: epriestley
Subscribers: Korvin, epriestley
Maniphest Tasks: T7014
Differential Revision: https://secure.phabricator.com/D11968
2015-03-05 19:33:39 +01:00
|
|
|
function (e) {
|
|
|
|
e.kill();
|
2015-03-06 00:32:42 +01:00
|
|
|
var data = e.getNodeData('conpherence-durable-column-header-action');
|
|
|
|
var action = data.action;
|
|
|
|
var link = e.getNode('tag:a');
|
|
|
|
|
|
|
|
switch (action) {
|
|
|
|
case 'add_person':
|
|
|
|
JX.Stratcom.invoke('notification-panel-close');
|
|
|
|
var params = {
|
|
|
|
action: action,
|
|
|
|
latest_transaction_id: latestTransactionID,
|
|
|
|
minimal_display: true
|
|
|
|
};
|
|
|
|
var workflow = new JX.Workflow.newFromLink(link)
|
|
|
|
.setData(params)
|
|
|
|
.setHandler(function(r) {
|
|
|
|
var messages = _getColumnMessagesNode();
|
|
|
|
JX.DOM.appendContent(messages, JX.$H(r.transactions));
|
|
|
|
messages.scrollTop = messages.scrollHeight;
|
|
|
|
|
|
|
|
latestTransactionID = r.latest_transaction_id;
|
|
|
|
// since this is a two step workflow, and the "finally" method
|
|
|
|
// gets called on the first form load, restore "updating" if
|
|
|
|
// necessary
|
|
|
|
if (updating === null) {
|
|
|
|
updating = {
|
|
|
|
threadPHID: loadedThreadPHID,
|
|
|
|
knownID: latestTransactionID
|
|
|
|
};
|
|
|
|
}
|
|
|
|
});
|
|
|
|
sync_workflow(workflow);
|
|
|
|
break;
|
|
|
|
case 'go_conpherence':
|
|
|
|
JX.$U(link.href).go();
|
|
|
|
break;
|
|
|
|
case 'close_window':
|
|
|
|
JX.Stratcom.invoke('notification-panel-close');
|
|
|
|
_toggleColumn();
|
|
|
|
break;
|
Conpherence - make the durable column kind of work and stuff
Summary:
Ref T7014. This hooks up the durable column such that when you open it up it loads your most recent Conpherence. You can then switch amongst the various widgets and stuff and everything works nicely.
Except...
- scroll bar does not work
- also doesn't work at HEAD when I add a ton of text to the UI with no changes? (wrapped $copy in array_fill(0, 1000, $copy))
- "widget selector" does not collapse when you select something else
- this part wasn't really specified so I used the aphlict dropdown stuff. didn't want to keep working on that if this was the wrong UI choice
- can not edit title
- do we still want that to be done by clicking on the title, which pops a dialogue?
- can not add participants or calendar events
- what should this UI be? maybe just a button on the top for "participants" and a button on the bottom for calendar? both on top?
- this is not pixel perfect to the mock or two I've seen around. Aside from generally being bad at that, I definitely didn't get the name + timestamps formatting correctly, because the standard DOM of that has timestamp FIRST which appears second due to a "float right". Seemed like a lot of special-casing for what might not even be that important in the UI so I punted. (And again, there's likely many unknown ways in which this isn't pixel perfect)
There's also code quality issues
- `ConpherenceWidgetConfigConstants` is hopefully temporary or at least gets more sleek as we keep progressing here
- copied some CSS from main Conpherence app
- DOM structure is pretty different
- there's some minor CSS tweaks too given the different width (not to mention the DOM structure being different)
- copied some JS from behavior-pontificate.js to sync threads relative to aphlict updates
- JS in general is like a better version of existing JS; these should collapse I'd hope?
- maybe the aphlict-behavior-dropdown change was badsauce?
...but all that said, this definitely feels really nice and I feel like adding stuff is going to be really easy compared to how normal Conpherence is.
Also includes a bonus bug fix - we now correctly update participation. The user would encounter this issue if they were in a conpherence that got some updates and then they went to a different page; they would have unread status for the messages that were ajax'd in. This patch fixes that by making sure we mark participation up to date with the proper transaction in all cases.
Test Plan: hit "\" to invoke the column and saw nice loading UI and my latest conpherence load. sent messages and verified they received A-OK by looking in DOM console. toggled various widges and verified they rendered correctly. opened up a second browser with a second user on the thread, sent a message, and it was received in a nice asynchronous fashion
Reviewers: chad, epriestley
Reviewed By: epriestley
Subscribers: Korvin, epriestley
Maniphest Tasks: T7014
Differential Revision: https://secure.phabricator.com/D11968
2015-03-05 19:33:39 +01:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
function _getColumnNode() {
|
|
|
|
return JX.$('conpherence-durable-column');
|
|
|
|
}
|
|
|
|
|
|
|
|
function _getColumnBodyNode() {
|
|
|
|
var column = JX.$('conpherence-durable-column');
|
|
|
|
return JX.DOM.find(
|
|
|
|
column,
|
|
|
|
'div',
|
|
|
|
'conpherence-durable-column-body');
|
|
|
|
}
|
|
|
|
|
|
|
|
function _getColumnMessagesNode() {
|
|
|
|
var column = JX.$('conpherence-durable-column');
|
|
|
|
return JX.DOM.find(
|
|
|
|
column,
|
|
|
|
'div',
|
|
|
|
'conpherence-durable-column-transactions');
|
|
|
|
}
|
|
|
|
|
|
|
|
function _getColumnFormNode() {
|
|
|
|
var column = JX.$('conpherence-durable-column');
|
|
|
|
return JX.DOM.find(
|
|
|
|
column,
|
|
|
|
'form',
|
|
|
|
'conpherence-message-form');
|
|
|
|
}
|
|
|
|
|
|
|
|
function _getColumnTextareaNode() {
|
|
|
|
var column = JX.$('conpherence-durable-column');
|
|
|
|
return JX.DOM.find(
|
|
|
|
column,
|
|
|
|
'textarea',
|
|
|
|
'conpherence-durable-column-textarea');
|
|
|
|
}
|
|
|
|
|
|
|
|
function _focusColumnTextareaNode() {
|
|
|
|
var textarea = _getColumnTextareaNode();
|
|
|
|
setTimeout(function() { JX.DOM.focus(textarea); }, 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
function _markLoading(loading) {
|
|
|
|
var column = _getColumnNode();
|
|
|
|
JX.DOM.alterClass(column, 'loading', loading);
|
|
|
|
}
|
|
|
|
|
|
|
|
function loadThreadContent(thread_id) {
|
|
|
|
// loaded this thread already
|
|
|
|
if (loadedThreadID !== null && loadedThreadID == thread_id) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
_markLoading(true);
|
|
|
|
|
|
|
|
var uri = '/conpherence/columnview/';
|
|
|
|
var params = null;
|
|
|
|
// We can pick a thread from the server the first time
|
|
|
|
if (shouldInit) {
|
|
|
|
shouldInit = false;
|
|
|
|
params = { shouldInit : true };
|
|
|
|
} else {
|
|
|
|
params = { id : thread_id };
|
|
|
|
}
|
|
|
|
var handler = function(r) {
|
|
|
|
var column = _getColumnNode();
|
|
|
|
var new_column = JX.$H(r.content);
|
|
|
|
loadedThreadID = r.threadID;
|
|
|
|
loadedThreadPHID = r.threadPHID;
|
|
|
|
loadThreadID = r.threadID;
|
|
|
|
latestTransactionID = r.latestTransactionID;
|
|
|
|
JX.DOM.replace(column, new_column);
|
|
|
|
JX.DOM.show(_getColumnNode());
|
|
|
|
new JX.Scrollbar(JX.$('conpherence-durable-column-content'));
|
|
|
|
_markLoading(false);
|
|
|
|
};
|
|
|
|
|
|
|
|
new JX.Workflow(uri)
|
|
|
|
.setData(params)
|
|
|
|
.setHandler(handler)
|
|
|
|
.start();
|
|
|
|
}
|
|
|
|
|
|
|
|
function _sendMessage(e) {
|
|
|
|
e.kill();
|
|
|
|
_markLoading(true);
|
|
|
|
|
|
|
|
var form = _getColumnFormNode();
|
|
|
|
var params = {
|
|
|
|
latest_transaction_id : latestTransactionID,
|
|
|
|
minimal_display : true
|
|
|
|
};
|
|
|
|
var workflow = JX.Workflow.newFromForm(form, params)
|
|
|
|
.setHandler(function(r) {
|
|
|
|
var messages = _getColumnMessagesNode();
|
|
|
|
JX.DOM.appendContent(messages, JX.$H(r.transactions));
|
|
|
|
messages.scrollTop = messages.scrollHeight;
|
|
|
|
|
|
|
|
var textarea = _getColumnTextareaNode();
|
|
|
|
textarea.value = '';
|
|
|
|
|
|
|
|
latestTransactionID = r.latest_transaction_id;
|
|
|
|
|
|
|
|
_markLoading(false);
|
|
|
|
|
|
|
|
_focusColumnTextareaNode();
|
|
|
|
});
|
|
|
|
sync_workflow(workflow);
|
|
|
|
}
|
|
|
|
|
|
|
|
JX.Stratcom.listen(
|
|
|
|
'click',
|
|
|
|
'conpherence-send-message',
|
|
|
|
_sendMessage);
|
|
|
|
|
|
|
|
JX.Stratcom.listen(
|
|
|
|
['submit', 'didSyntheticSubmit'],
|
|
|
|
'conpherence-message-form',
|
|
|
|
_sendMessage);
|
|
|
|
|
2015-01-27 15:30:52 +01:00
|
|
|
});
|