mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-14 01:48:35 +01:00
Get nm_action dialogs working
This commit is contained in:
parent
8a033b6b9a
commit
322fa3c8f4
@ -189,11 +189,23 @@ export class Et2Dialog extends Et2Widget(ScopedElementsMixin(SlotMixin(LionDialo
|
|||||||
// There's an issue with Et2DialogContent.style being undefined, so this has to stay false until it gets
|
// There's an issue with Et2DialogContent.style being undefined, so this has to stay false until it gets
|
||||||
// figured out
|
// figured out
|
||||||
modal: Boolean,
|
modal: Boolean,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Title for the dialog, goes in the header
|
||||||
|
*/
|
||||||
title: String,
|
title: String,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Pre-defined group of buttons, one of the BUTTONS_*
|
||||||
|
*/
|
||||||
buttons: Number,
|
buttons: Number,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Instead of a message, show this template file instead
|
||||||
|
*/
|
||||||
template: String,
|
template: String,
|
||||||
|
|
||||||
|
// Force size on the dialog. Normally it sizes to content.
|
||||||
width: Number,
|
width: Number,
|
||||||
height: Number,
|
height: Number,
|
||||||
|
|
||||||
@ -203,6 +215,10 @@ export class Et2Dialog extends Et2Widget(ScopedElementsMixin(SlotMixin(LionDialo
|
|||||||
icon: String,
|
icon: String,
|
||||||
value: Object,
|
value: Object,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Automatically destroy the dialog when it closes. Set to false to keep the dialog around.
|
||||||
|
*/
|
||||||
|
destroy_on_close: Boolean,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -284,6 +300,8 @@ export class Et2Dialog extends Et2Widget(ScopedElementsMixin(SlotMixin(LionDialo
|
|||||||
}
|
}
|
||||||
// Needs to not be modal until the style thing is figured out
|
// Needs to not be modal until the style thing is figured out
|
||||||
this.modal = false;
|
this.modal = false;
|
||||||
|
this.dialog_type = Et2Dialog.PLAIN_MESSAGE;
|
||||||
|
this.destroy_on_close = true;
|
||||||
this.__value = {};
|
this.__value = {};
|
||||||
|
|
||||||
this._onOpen = this._onOpen.bind(this);
|
this._onOpen = this._onOpen.bind(this);
|
||||||
@ -358,13 +376,15 @@ export class Et2Dialog extends Et2Widget(ScopedElementsMixin(SlotMixin(LionDialo
|
|||||||
|
|
||||||
this.dispatchEvent(new Event('close'));
|
this.dispatchEvent(new Event('close'));
|
||||||
|
|
||||||
// No real need to do this automatically, dialog could be reused without this
|
if(this.destroy_on_close)
|
||||||
if(this._template_widget)
|
|
||||||
{
|
{
|
||||||
this._template_widget.clear();
|
if(this._template_widget)
|
||||||
|
{
|
||||||
|
this._template_widget.clear();
|
||||||
|
}
|
||||||
|
this._overlayCtrl.teardown();
|
||||||
|
this.remove();
|
||||||
}
|
}
|
||||||
this._overlayCtrl.teardown();
|
|
||||||
this.remove();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
_onClick(ev : MouseEvent)
|
_onClick(ev : MouseEvent)
|
||||||
@ -511,6 +531,17 @@ export class Et2Dialog extends Et2Widget(ScopedElementsMixin(SlotMixin(LionDialo
|
|||||||
return this._overlayTemplate();
|
return this._overlayTemplate();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Don't allow any children here, pass them on to the content node
|
||||||
|
*
|
||||||
|
* @param {HTMLElement} node
|
||||||
|
* @returns {any}
|
||||||
|
*/
|
||||||
|
appendChild(node : HTMLElement)
|
||||||
|
{
|
||||||
|
return this._overlayContentNode.appendChild(node);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Defining this overlay as a templates from OverlayMixin
|
* Defining this overlay as a templates from OverlayMixin
|
||||||
* this is our source to give as .contentNode to OverlayController.
|
* this is our source to give as .contentNode to OverlayController.
|
||||||
|
@ -75,6 +75,12 @@ export class Et2DialogOverlay extends SlotMixin(LitElement)
|
|||||||
margin-top: 0.5em;
|
margin-top: 0.5em;
|
||||||
padding: 5px;
|
padding: 5px;
|
||||||
}
|
}
|
||||||
|
/* Override style for legacy nextmatch action dialogs */
|
||||||
|
::slotted([slot="content"]) {
|
||||||
|
display: block !important;
|
||||||
|
position: relative !important;
|
||||||
|
inset: initial !important;
|
||||||
|
}
|
||||||
::slotted([slot="buttons"]) {
|
::slotted([slot="buttons"]) {
|
||||||
flex: 1 0 auto;
|
flex: 1 0 auto;
|
||||||
}
|
}
|
||||||
@ -219,6 +225,11 @@ export class Et2DialogOverlay extends SlotMixin(LitElement)
|
|||||||
|
|
||||||
_buttonsTemplate()
|
_buttonsTemplate()
|
||||||
{
|
{
|
||||||
|
if(!this.buttons)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// Set button._parent here, otherwise button will have trouble finding our egw()
|
// Set button._parent here, otherwise button will have trouble finding our egw()
|
||||||
return html`${repeat(this.buttons, (button : DialogButton) => button.id, (button, index) =>
|
return html`${repeat(this.buttons, (button : DialogButton) => button.id, (button, index) =>
|
||||||
{
|
{
|
||||||
|
@ -428,94 +428,69 @@ export function nm_open_popup(_action, _selected)
|
|||||||
//Check if there is nextmatch on _action otherwise gets the uniqueid from _ids
|
//Check if there is nextmatch on _action otherwise gets the uniqueid from _ids
|
||||||
var uid;
|
var uid;
|
||||||
if (typeof _action.data.nextmatch !== 'undefined')
|
if (typeof _action.data.nextmatch !== 'undefined')
|
||||||
|
{
|
||||||
uid = _action.data.nextmatch.getInstanceManager().uniqueId;
|
uid = _action.data.nextmatch.getInstanceManager().uniqueId;
|
||||||
else if(typeof _selected[0] !== 'undefined')
|
}
|
||||||
|
else if (typeof _selected[0] !== 'undefined')
|
||||||
|
{
|
||||||
uid = _selected[0].manager.data.nextmatch.getInstanceManager().uniqueId;
|
uid = _selected[0].manager.data.nextmatch.getInstanceManager().uniqueId;
|
||||||
|
}
|
||||||
|
let action = _action;
|
||||||
|
let selected = _selected;
|
||||||
|
|
||||||
// Find the popup div
|
// Find the popup div
|
||||||
var popup = jQuery("#"+(uid||"") + "_"+_action.id+"_popup").first() || jQuery("[id*='" + _action.id + "_popup']").first();
|
var popup = document.body.querySelector("et2-dialog[id*='" + _action.id + "_popup']") || document.body.querySelector("#" + (uid || "") + "_" + _action.id + "_popup") || document.body.querySelector("[id*='" + _action.id + "_popup']");
|
||||||
if (popup) {
|
if (popup && popup instanceof Et2Dialog)
|
||||||
|
{
|
||||||
|
popup.open();
|
||||||
|
}
|
||||||
|
else if (popup)
|
||||||
|
{
|
||||||
nm_popup_action = _action;
|
nm_popup_action = _action;
|
||||||
if(_selected.length && typeof _selected[0] == 'object')
|
if (_selected.length && typeof _selected[0] == 'object')
|
||||||
{
|
{
|
||||||
_action.data.nextmatch = _selected[0]._context._widget;
|
_action.data.nextmatch = _selected[0]._context._widget;
|
||||||
nm_popup_ids = _selected;
|
nm_popup_ids = _selected;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
egw().debug("warn", 'Not proper format for IDs, should be array of egwActionObject',_selected);
|
egw().debug("warn", 'Not proper format for IDs, should be array of egwActionObject', _selected);
|
||||||
nm_popup_ids = _selected;
|
nm_popup_ids = _selected;
|
||||||
}
|
}
|
||||||
|
|
||||||
var dialog = jQuery('.action_popup-content',popup);
|
let dialog = new Et2Dialog();
|
||||||
if(dialog.length == 0)
|
dialog.destroy_on_close = false;
|
||||||
|
dialog.id = popup.id;
|
||||||
|
popup.setAttribute("id", "_" + popup.id);
|
||||||
|
dialog.getUpdateComplete().then(() =>
|
||||||
{
|
{
|
||||||
// Couldn't get the dialog, use the div less the first (header) & last (buttons) nodes
|
let title = popup.querySelector(".promptheader")
|
||||||
dialog = jQuery(document.createElement('div'))
|
if (title)
|
||||||
.addClass('action_popup-content');
|
|
||||||
if(popup.children().length == 1)
|
|
||||||
{
|
{
|
||||||
dialog.append(popup.children().children().slice(1,popup.children().children().length-1));
|
title.slot = "heading"
|
||||||
|
dialog.appendChild(title);
|
||||||
}
|
}
|
||||||
else
|
popup.slot = "content";
|
||||||
{
|
|
||||||
dialog.append(popup.children().slice(1,popup.children().length-1));
|
|
||||||
}
|
|
||||||
dialog.appendTo(popup);
|
|
||||||
}
|
|
||||||
if(dialog.length == 1)
|
|
||||||
{
|
|
||||||
// Set up the buttons
|
|
||||||
var dialog_parent = dialog.parent();
|
|
||||||
var d_buttons = [];
|
|
||||||
var action = _action;
|
|
||||||
let selected = _selected;
|
|
||||||
popup.show();
|
|
||||||
var close_function = function()
|
|
||||||
{
|
|
||||||
dialog_parent.append(dialog);
|
|
||||||
};
|
|
||||||
jQuery('button:visible',popup).each(function(index) {
|
|
||||||
var but = jQuery(this);
|
|
||||||
if(but.attr("id"))
|
|
||||||
{
|
|
||||||
// Find the associated widget
|
|
||||||
var widget_id = but.attr("id").replace(_action.data.nextmatch.getInstanceManager().uniqueId+'_', '');
|
|
||||||
var button = nm_popup_action.data.nextmatch.getRoot().getWidgetById(widget_id);
|
|
||||||
}
|
|
||||||
var button_data = {
|
|
||||||
text: but.text(),
|
|
||||||
id: widget_id,
|
|
||||||
click: button && button.onclick ? function(e) {
|
|
||||||
jQuery(this).dialog("close");
|
|
||||||
nm_popup_action = action;
|
|
||||||
nm_popup_ids = selected;
|
|
||||||
button.onclick.apply(button, e.currentTarget);
|
|
||||||
close_function();
|
|
||||||
} : function(e) {
|
|
||||||
jQuery(this).dialog("close");
|
|
||||||
nm_popup_action = null;
|
|
||||||
close_function();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
if(button && button.options && button.options.image)
|
|
||||||
{
|
|
||||||
button_data.image = button.options.image;
|
|
||||||
}
|
|
||||||
d_buttons.push(button_data);
|
|
||||||
});
|
|
||||||
|
|
||||||
popup.hide();
|
// Move buttons
|
||||||
var _dialog = et2_dialog.show_dialog(
|
popup.querySelectorAll('et2-button').forEach((button) =>
|
||||||
close_function,
|
{
|
||||||
'',
|
button.slot = "buttons";
|
||||||
jQuery('.promptheader',popup).text(),
|
let button_click = button.onclick;
|
||||||
{},
|
button.onclick = (e) =>
|
||||||
d_buttons
|
{
|
||||||
);
|
window.nm_popup_action = button_click ? _action : null;
|
||||||
_dialog.set_dialog_type('');
|
window.nm_popup_ids = selected;
|
||||||
_dialog.div.append(dialog)
|
dialog.close();
|
||||||
.css('overflow', 'initial');
|
|
||||||
}
|
return button_click?.apply(button, e.currentTarget);
|
||||||
|
};
|
||||||
|
dialog.appendChild(button);
|
||||||
|
})
|
||||||
|
dialog.appendChild(popup);
|
||||||
|
});
|
||||||
|
|
||||||
|
document.body.appendChild(dialog);
|
||||||
|
|
||||||
// Reset global variables
|
// Reset global variables
|
||||||
nm_popup_action = null;
|
nm_popup_action = null;
|
||||||
@ -534,9 +509,7 @@ window.nm_submit_popup = function(button)
|
|||||||
{
|
{
|
||||||
if (nm_popup_action.data.nextmatch)
|
if (nm_popup_action.data.nextmatch)
|
||||||
{
|
{
|
||||||
// Find the associated widget
|
button.clicked = true;
|
||||||
var widget_id = jQuery(button).attr("id").replace(nm_popup_action.data.nextmatch.getInstanceManager().uniqueId+'_', '');
|
|
||||||
nm_popup_action.data.nextmatch.getRoot().getWidgetById(widget_id).clicked = true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Mangle senders to get IDs where nm_action() wants them
|
// Mangle senders to get IDs where nm_action() wants them
|
||||||
@ -569,12 +542,13 @@ window.nm_submit_popup = function(button)
|
|||||||
*/
|
*/
|
||||||
window.nm_hide_popup = function(element, div_id)
|
window.nm_hide_popup = function(element, div_id)
|
||||||
{
|
{
|
||||||
var prefix = element.id.substring(0,element.id.indexOf('['));
|
var prefix = element.id.substring(0, element.id.indexOf('['));
|
||||||
var popup = div_id ? document.getElementById(div_id) : jQuery("#"+prefix+"_popup").get(0) || jQuery("[id*='" + prefix + "_popup']").get(0);
|
var popup = div_id ? document.getElementById(div_id) : document.querySelector("#" + prefix + "_popup") || document.querySelector("[id*='" + prefix + "_popup']");
|
||||||
|
|
||||||
// Hide popup
|
// Hide popup
|
||||||
if(popup) {
|
if (popup)
|
||||||
popup.style.display = 'none';
|
{
|
||||||
|
popup.close();
|
||||||
}
|
}
|
||||||
nm_popup_action = null;
|
nm_popup_action = null;
|
||||||
nm_popup_ids = null;
|
nm_popup_ids = null;
|
||||||
|
@ -343,7 +343,7 @@ class InfologApp extends EgwApp
|
|||||||
confirm_delete(_action, _senders)
|
confirm_delete(_action, _senders)
|
||||||
{
|
{
|
||||||
let children = false;
|
let children = false;
|
||||||
let child_button = jQuery('#delete_sub').get(0) || jQuery('[id*="delete_sub"]').get(0);
|
let child_button = document.body.querySelector('#delete_sub') || document.body.querySelector('[id*="delete_sub"]');
|
||||||
this._action_all = _action.parent.data.nextmatch?.getSelection().all;
|
this._action_all = _action.parent.data.nextmatch?.getSelection().all;
|
||||||
this._action_ids = [];
|
this._action_ids = [];
|
||||||
if(child_button)
|
if(child_button)
|
||||||
@ -352,13 +352,13 @@ class InfologApp extends EgwApp
|
|||||||
{
|
{
|
||||||
this._action_ids.push(_senders[i].id.split("::").pop());
|
this._action_ids.push(_senders[i].id.split("::").pop());
|
||||||
|
|
||||||
if (jQuery(_senders[i].iface.getDOMNode()).hasClass('infolog_rowHasSubs'))
|
if(_senders[i].iface.getDOMNode().classList.contains("infolog_rowHasSubs"))
|
||||||
{
|
{
|
||||||
children = true;
|
children = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
child_button.style.display = children ? 'block' : 'none';
|
child_button.disabled = !children;
|
||||||
}
|
}
|
||||||
nm_open_popup(_action, _senders);
|
nm_open_popup(_action, _senders);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user