summaryrefslogtreecommitdiffstats
path: root/toolkit/jetpack
diff options
context:
space:
mode:
authorMoonchild <mcwerewolf@gmail.com>2018-07-01 23:40:32 +0200
committerGitHub <noreply@github.com>2018-07-01 23:40:32 +0200
commita659def00b38cded555d4005d2ceb7b55d27040b (patch)
tree780a2da66a93c7b5d649a71c77a0b507b0ae4e2c /toolkit/jetpack
parent851d621cf2f9b32ae7ed0998b91de3b4b0099a92 (diff)
parent51b321c7f4e3ac4fa7ed27931510aea39515f199 (diff)
downloadUXP-a659def00b38cded555d4005d2ceb7b55d27040b.tar
UXP-a659def00b38cded555d4005d2ceb7b55d27040b.tar.gz
UXP-a659def00b38cded555d4005d2ceb7b55d27040b.tar.lz
UXP-a659def00b38cded555d4005d2ceb7b55d27040b.tar.xz
UXP-a659def00b38cded555d4005d2ceb7b55d27040b.zip
Merge pull request #579 from JustOff/PR_pmkit_dyn_buttons
[PMkit] Keep the buttons position when they are placed right before space, flexible space or separator
Diffstat (limited to 'toolkit/jetpack')
-rw-r--r--toolkit/jetpack/sdk/ui/buttons.js23
1 files changed, 21 insertions, 2 deletions
diff --git a/toolkit/jetpack/sdk/ui/buttons.js b/toolkit/jetpack/sdk/ui/buttons.js
index 6aaed3865..450584ea7 100644
--- a/toolkit/jetpack/sdk/ui/buttons.js
+++ b/toolkit/jetpack/sdk/ui/buttons.js
@@ -50,6 +50,14 @@ function insertButton(aWindow, id, onBuild) {
let toolbar = toolbarId != "" && doc.getElementById(toolbarId);
if (toolbar) {
+ // Handle special items with dynamic ids
+ let match = /^(separator|spacer|spring)\[(\d+)\]$/.exec(nextItemId);
+ if (match !== null) {
+ let dynItems = toolbar.querySelectorAll("toolbar" + match[1]);
+ if (match[2] < dynItems.length) {
+ nextItemId = dynItems[match[2]].id;
+ }
+ }
let nextItem = nextItemId != "" && doc.getElementById(nextItemId);
// If nextItem not in toolbar then retrieve it by reading currentset attribute
if (!(nextItem && nextItem.parentNode && nextItem.parentNode.id == toolbarId)) {
@@ -82,15 +90,26 @@ function afterCustomize(e) {
for (let [id] of buttonsList) {
let toolbox = e.target;
let b = toolbox.parentNode.querySelector("#" + id);
- let toolbarId = null, nextItemId = null;
+ let toolbarId = null, nextItem = null, nextItemId = null;
if (b) {
let parent = b.parentNode;
- let nextItem = b.nextSibling;
+ nextItem = b.nextSibling;
if (parent && parent.localName == "toolbar") {
toolbarId = parent.id;
nextItemId = nextItem && nextItem.id;
}
}
+ // Handle special items with dynamic ids
+ let match = /^(separator|spacer|spring)\d+$/.exec(nextItemId);
+ if (match !== null) {
+ let dynItems = nextItem.parentNode.querySelectorAll("toolbar" + match[1]);
+ for (let i = 0; i < dynItems.length; i++) {
+ if (dynItems[i].id == nextItemId) {
+ nextItemId = match[1] + "[" + i + "]";
+ break;
+ }
+ }
+ }
saveLocation(id, toolbarId, nextItemId);
}
}