diff options
author | Moonchild <mcwerewolf@gmail.com> | 2018-07-01 23:40:32 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-07-01 23:40:32 +0200 |
commit | a659def00b38cded555d4005d2ceb7b55d27040b (patch) | |
tree | 780a2da66a93c7b5d649a71c77a0b507b0ae4e2c /toolkit/jetpack | |
parent | 851d621cf2f9b32ae7ed0998b91de3b4b0099a92 (diff) | |
parent | 51b321c7f4e3ac4fa7ed27931510aea39515f199 (diff) | |
download | UXP-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.js | 23 |
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); } } |