diff options
Diffstat (limited to 'swat')
-rw-r--r-- | swat/desktop/index.esp | 66 | ||||
-rw-r--r-- | swat/scripting/client/desktop.js | 37 |
2 files changed, 57 insertions, 46 deletions
diff --git a/swat/desktop/index.esp b/swat/desktop/index.esp index ee4290f234..0714a2d038 100644 --- a/swat/desktop/index.esp +++ b/swat/desktop/index.esp @@ -51,30 +51,6 @@ function blankW() blank.setVisible(true); } -function showContextMenu(e) -{ - var aboutCmd = new QxCommand(); - aboutCmd.addEventListener("execute", function() { - showMessage("SWAT, the Samba Web Administration Tool.<br/>This tool is currently under development."); - }); - - var newWin = new QxCommand(); - newWin.addEventListener("execute", blankW); - - cmenu = new QxMenu; - - var sub1 = new QxMenuButton("About SWAT", null, aboutCmd); - var sep = new QxMenuSeparator(); - var sub2 = new QxMenuButton("New Window", null, newWin); - - cmenu.add(sub1, sep, sub2); - - cmenu.setLeft(e.getClientX()); - cmenu.setTop(e.getClientY()); - w.add(cmenu); - cmenu.setVisible(true); -} - // Always open with stats var win = new QxWindow(); document.js.add('/scripting/client/status.js'); @@ -116,6 +92,48 @@ function showReg() regWin.setVisible('true'); } +function clientContextMenu(e) +{ + var aboutCmd = new QxCommand(); + aboutCmd.addEventListener("execute", function() { + showMessage("SWAT, the Samba Web Administration Tool.<br/>This tool is currently under development."); + }); + + var newWin = new QxCommand(); + newWin.addEventListener("execute", blankW); + + var cmenu = new QxMenu; + + var sub1 = new QxMenuButton("About SWAT", null, aboutCmd); + var sep = new QxMenuSeparator(); + var sub2 = new QxMenuButton("New Window", null, newWin); + + cmenu.add(sub1, sep, sub2); + + cmenu.setLeft(e.getClientX()); + cmenu.setTop(e.getClientY()); + w.add(cmenu); + cmenu.setVisible(true); +} + +function windowContextMenu(t, e) +{ + var WinWin = new QxCommand(); + WinWin.addEventListener("execute", function() { + var blank = new QxWindow(); + t.add(blank); + blank.setVisible(true); + }); + + var inset = new QxMenu; + var sub1 = new QxMenuButton("Open window in a window", null, WinWin); + + inset.add(sub1); + t.add(inset) + + inset.setVisible(true); +} + function startMenu() { var sMenu = new QxMenu; diff --git a/swat/scripting/client/desktop.js b/swat/scripting/client/desktop.js index 6383e58bda..bddd38b60c 100644 --- a/swat/scripting/client/desktop.js +++ b/swat/scripting/client/desktop.js @@ -89,26 +89,6 @@ function openIn(e) blank.setVisible(true); } -function winMenu(e) -{ - var self = this; - var WinWin = new QxCommand(); - WinWin.addEventListener("execute", function() { - var blank = new QxWindow(); - self.add(blank); - blank.setVisible(true); - }); - - var inset = new QxMenu; - var sub1 = new QxMenuButton("Open window in a window", null, WinWin); - - inset.add(sub1); - self.add(inset) - - cmenu.setVisible(false); - inset.setVisible(true); -} - function Window(h, src, s) { this.self = new QxWindow(h); @@ -121,7 +101,7 @@ function Window(h, src, s) this.self.setTop(getPosX(this.self)); this.self.setLeft(getPosY(this.self)); - this.self.addEventListener("contextmenu", winMenu); + this.self.addEventListener("contextmenu", contextMenu); return this.self; } @@ -148,10 +128,23 @@ Window.small = SmallWindow; Window.standard = StandardWindow; Window.large = LargeWindow; +function contextMenu(e) +{ + var t = e.getTarget() + var tObj = t.getHtmlAttribute("class") + + if (tObj == 'QxWidget') { + clientContextMenu(e); + } else if (tObj == 'QxWindowPane') { + windowContextMenu(t, e); + } +} + + window.application.main = function() { var doc = this.getClientWindow().getClientDocument(); - doc.addEventListener("contextmenu", showContextMenu); + doc.addEventListener("contextmenu", contextMenu); doc.add(w); var bar = new QxMenuBar; |