2013-10-13 02:08:11 +02:00
|
|
|
/**
|
|
|
|
* @provides javelin-behavior-policy-control
|
|
|
|
* @requires javelin-behavior
|
|
|
|
* javelin-dom
|
|
|
|
* javelin-util
|
|
|
|
* phabricator-dropdown-menu
|
|
|
|
* phabricator-menu-item
|
|
|
|
* @javelin
|
|
|
|
*/
|
|
|
|
JX.behavior('policy-control', function(config) {
|
|
|
|
var control = JX.$(config.controlID);
|
|
|
|
var input = JX.$(config.inputID);
|
2013-10-13 02:08:35 +02:00
|
|
|
var value = config.value;
|
2013-10-13 02:08:11 +02:00
|
|
|
|
|
|
|
var menu = new JX.PhabricatorDropdownMenu(control)
|
|
|
|
.setWidth(260);
|
|
|
|
|
|
|
|
menu.toggleAlignDropdownRight(false);
|
|
|
|
|
|
|
|
menu.listen('open', function() {
|
|
|
|
menu.clear();
|
|
|
|
|
|
|
|
for (var ii = 0; ii < config.groups.length; ii++) {
|
|
|
|
var group = config.groups[ii];
|
|
|
|
|
|
|
|
var header = new JX.PhabricatorMenuItem(config.labels[group]);
|
|
|
|
header.setDisabled(true);
|
|
|
|
menu.addItem(header);
|
|
|
|
|
|
|
|
for (var jj = 0; jj < config.order[group].length; jj++) {
|
|
|
|
var phid = config.order[group][jj];
|
|
|
|
var option = config.options[phid];
|
|
|
|
|
|
|
|
var render = [JX.$H(config.icons[option.icon]), option.name];
|
|
|
|
|
|
|
|
var item = new JX.PhabricatorMenuItem(
|
|
|
|
render,
|
|
|
|
JX.bind(null, function(phid, render) {
|
|
|
|
JX.DOM.setContent(
|
|
|
|
JX.DOM.find(control, 'span', 'policy-label'),
|
|
|
|
render);
|
|
|
|
input.value = phid;
|
2013-10-13 02:08:35 +02:00
|
|
|
value = phid;
|
2013-10-13 02:08:11 +02:00
|
|
|
}, phid, render));
|
|
|
|
|
2013-10-13 02:08:35 +02:00
|
|
|
if (phid == value) {
|
|
|
|
item.setSelected(true);
|
|
|
|
}
|
|
|
|
|
2013-10-13 02:08:11 +02:00
|
|
|
menu.addItem(item);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
});
|