luci-base: form.js: rework stacked modal CBI map logic
authorJo-Philipp Wich <jo@mein.io>
Thu, 5 May 2022 21:07:13 +0000 (23:07 +0200)
committerJo-Philipp Wich <jo@mein.io>
Fri, 6 May 2022 11:42:54 +0000 (13:42 +0200)
Only stack a new modal CBI map on top of the currently displayed modal one
if the related map or section differs. This prevents misbehavior when
switching the protocol of interfaces.

Signed-off-by: Jo-Philipp Wich <jo@mein.io>
modules/luci-base/htdocs/luci-static/resources/form.js

index c17f8ff0ca967ad45cf985fd65e27de50d63c180..62fcc903e80e67c1489d655159cb8b233f760c0d 100644 (file)
@@ -3149,6 +3149,7 @@ var CBITableSection = CBITypedSection.extend(/** @lends LuCI.form.TableSection.p
                    s = m.section(CBINamedSection, section_id, this.sectiontype);
 
                m.parent = parent;
+               m.section = section_id;
                m.readonly = parent.readonly;
 
                s.tabs = this.tabs;
@@ -3188,20 +3189,24 @@ var CBITableSection = CBITypedSection.extend(/** @lends LuCI.form.TableSection.p
                }
 
                return Promise.resolve(this.addModalOptions(s, section_id, ev)).then(L.bind(m.render, m)).then(L.bind(function(nodes) {
-                       var modalMap = this.getActiveModalMap();
+                       var mapNode = this.getActiveModalMap(),
+                           activeMap = mapNode ? dom.findClassInstance(mapNode) : null;
 
-                       if (modalMap) {
-                               modalMap.parentNode
+                       if (activeMap && (activeMap.parent !== parent || activeMap.section !== section_id)) {
+                               mapNode.parentNode
                                        .querySelector('h4')
                                        .appendChild(E('span', title ? ' ยป ' + title : ''));
 
-                               modalMap.parentNode
+                               mapNode.parentNode
                                        .querySelector('div.right > button')
                                        .firstChild.data = _('Back');
 
-                               modalMap.classList.add('hidden');
-                               modalMap.parentNode.insertBefore(nodes, modalMap.nextElementSibling);
-                               nodes.classList.add('flash');
+                               mapNode.classList.add('hidden');
+                               mapNode.parentNode.insertBefore(nodes, mapNode.nextElementSibling);
+
+                               return activeMap.save(null, true).then(function() {
+                                       nodes.classList.add('flash');
+                               }, function() {});
                        }
                        else {
                                ui.showModal(title, [