Instantly share code, notes, and snippets.
Created
January 26, 2012 08:19
-
Star
0
(0)
You must be signed in to star a gist -
Fork
0
(0)
You must be signed in to fork a gist
-
Save Griever/1681672 to your computer and use it in GitHub Desktop.
冗長な右クリックメニューを纏めるテスト
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// ==UserScript== | |
// @name iContextMenu.uc.js | |
// @description 冗長な右クリックメニューを纏める | |
// @namespace http://d.hatena.ne.jp/Griever/ | |
// @author Griever | |
// @license MIT License | |
// @compatibility Firefox 10 | |
// @charset UTF-8 | |
// @include main | |
// @version 下書き3 | |
// @screenshot http://f.hatena.ne.jp/Griever/20120408171623 | |
// @note | |
// ==/UserScript== | |
(function(css){ | |
const PAGE_ITEM = [ | |
{ command: 'context-bookmarkpage', icon: 'starbutton' } | |
,{ | |
label: 'ページの URL をコピー' | |
,oncommand: 'Cc["@mozilla.org/widget/clipboardhelper;1"].getService(Ci.nsIClipboardHelper).copyString(content.location.href);' | |
,icon: 'copy' | |
} | |
,{ command: 'context-savepage' } | |
,{ command: 'context-sendpage', hidden: 'true' } | |
,{ command: 'context-sep-viewsource' } | |
,{ command: 'context-viewsource' } | |
,{ command: 'context-viewinfo' } | |
,{ command: 'context-viewbgimage' } | |
,{ command: 'context-sep-viewbgimage' } | |
,{ command: 'context-back' } | |
,{ command: 'context-forward' } | |
,{ command: 'context-reload' } | |
,{ command: 'context-stop' } | |
,{ command: 'context-sep-stop' } | |
,{ | |
label: 'ホームページを開く', | |
oncommand: 'BrowserGoHome(event);', | |
icon: 'home' | |
} | |
]; | |
const LINK_ITEM = [ | |
{ command: 'context-copylink' } | |
,{ | |
label: 'リンクを現在のタブに開く' | |
,icon: 'blank' | |
,oncommand: 'document.getElementById("context-openlinkincurrent").doCommand(); closeMenus(event.target);' | |
,onclick: 'checkForMiddleClick(document.getElementById("context-openlinkintab"), event);' | |
} | |
,{ command: 'context-openlinkintab' } | |
,{ command: 'context-openlink' } | |
,{ command: 'context-sep-open' } | |
,{ command: 'context-bookmarklink' } | |
,{ command: 'context-savelink' } | |
,{ command: 'context-sendlink', hidden: 'true' } | |
,{ command: 'context-sep-copylink', hidden: 'true' } | |
]; | |
const IMAGE_ITEM = [ | |
{ command: 'context-viewimage' } | |
,{ command: 'context-copyimage-contents' } | |
,{ command: 'context-copyimage' } | |
,{ command: 'context-sep-copyimage' } | |
,{ command: 'context-saveimage' } | |
,{ command: 'context-viewimageinfo' } | |
,{ command: 'context-sendimage', hidden: 'true' } | |
,{ command: 'context-setDesktopBackground' } | |
]; | |
if (window.giContextMenu) { | |
window.giContextMenu.destroy(); | |
delete window.giContextMenu; | |
} | |
window.giContextMenu = { | |
init: function() { | |
var contextmenu = document.getElementById("contentAreaContextMenu"); | |
this.add(PAGE_ITEM).setAttribute("condition", "normal"); | |
this.add(LINK_ITEM).setAttribute("condition", "link"); | |
this.add(IMAGE_ITEM).setAttribute("condition", "image"); | |
var ids = [].concat( | |
['#contentAreaContextMenu #'+command for each({command} in PAGE_ITEM) if (command)] | |
,['#contentAreaContextMenu[iContextMenu~="link"] #' + command for each({command} in LINK_ITEM) if (command)] | |
,['#contentAreaContextMenu[iContextMenu~="image"] #' + command for each({command} in IMAGE_ITEM) if (command)] | |
); | |
if (ids.length) | |
css += "\n" + ids.join(", ") + "{ display: none !important; }"; | |
this.xulstyle = addStyle(css); | |
contextmenu.addEventListener("popupshowing", this, false); | |
window.addEventListener("unload", this, false); | |
}, | |
uninit: function() { | |
var contextmenu = document.getElementById("contentAreaContextMenu"); | |
contextmenu.removeEventListener("popupshowing", this, false); | |
window.removeEventListener("unload", this, false); | |
}, | |
destroy: function() { | |
this.uninit(); | |
if (this.xulstyle) this.xulstyle.parentNode.removeChild(this.xulstyle); | |
$$('menu.icontextmenu').forEach(function(e) e.parentNode.removeChild(e) ); | |
$$('.icontextmenu').forEach(function(e) e.parentNode.removeChild(e) ); | |
}, | |
handleEvent: function(event) { | |
switch(event.type){ | |
case "popupshowing": | |
if (event.target != event.currentTarget) return; | |
var state = []; | |
if (gContextMenu.onTextInput) | |
state.push("input"); | |
if (gContextMenu.isTextSelected) | |
state.push("select"); | |
if (gContextMenu.onLink) | |
state.push(gContextMenu.onMailtoLink ? "mailto" : "link"); | |
if (gContextMenu.onImage) | |
state.push("image"); | |
if (gContextMenu.onVideo || gContextMenu.onAudio) | |
state.push("media"); | |
event.currentTarget.setAttribute("iContextMenu", state.join(" ")); | |
break; | |
case "unload": | |
this.uninit(); | |
break; | |
} | |
}, | |
add: function(itemArray) { | |
var menu = document.createElement("menu"); | |
var popup = menu.appendChild(document.createElement("menupopup")); | |
var mcls = menu.classList; | |
mcls.add("icontextmenu"); | |
mcls.add("menu-iconic"); | |
var ins = $("context-openlinkincurrent"); | |
ins.parentNode.insertBefore(menu, ins); | |
itemArray.forEach(function(obj) { | |
if (typeof obj === 'undefined') return; | |
popup.appendChild(this.newMenuitem(obj)); | |
}, this); | |
let fc = menu.getElementsByTagName("menuitem")[0]; | |
if (fc) { | |
let cm = fc.getAttribute("command"); | |
if (cm) cm = document.getElementById(cm); | |
if (cm) { | |
["label","accesskey"].forEach(function(n){ | |
if (cm.hasAttribute(n)) menu.setAttribute(n, cm.getAttribute(n)); | |
}, this); | |
} | |
["image","icon"].forEach(function(n){ | |
if (fc.hasAttribute(n)) menu.setAttribute(n, fc.getAttribute(n)); | |
}, this); | |
menu.setAttribute("onclick", <![CDATA[ | |
if (event.target != event.currentTarget) return; | |
var fc = event.currentTarget.getElementsByTagName("menuitem")[0]; | |
if (!fc) return; | |
if (event.button === 1) { | |
checkForMiddleClick(fc, event); | |
} else { | |
fc.doCommand(); | |
closeMenus(event.currentTarget); | |
} | |
]]>.toString()); | |
} | |
return menu; | |
}, | |
newMenuitem: function(obj) { | |
var menuitem; | |
var org = obj.command ? document.getElementById(obj.command) : null; | |
// label == separator か必要なプロパティが足りない場合は区切りとみなす | |
if (!obj || obj.label === "separator" || (!obj.oncommand && !obj.command)) { | |
menuitem = document.createElement("menuseparator"); | |
} else if (obj.oncommand || obj.command) { | |
if (org && org.localName === "menuseparator") { | |
menuitem = document.createElement("menuseparator"); | |
} else { | |
menuitem = document.createElement("menuitem"); | |
if (!obj.label) | |
obj.label = obj.command || obj.oncommand; | |
} | |
} else { | |
menuitem = document.createElement("menuitem"); | |
} | |
if (obj.command) | |
menuitem.setAttribute("command", obj.command); | |
if (obj) { | |
for (let [key, val] in Iterator(obj)) { | |
if (key === "command") continue; | |
if (typeof val == "function") | |
obj[key] = val = val.toSource() + ".call(this, event);"; | |
menuitem.setAttribute(key, val); | |
} | |
} | |
var cls = menuitem.classList; | |
cls.add("icontextmenu"); | |
if (org) { | |
// hidden等を同期させる荒業 | |
org.cloneitem = menuitem; | |
["hidden", "collapsed", "disabled"].forEach(function(n){ | |
if (obj[n]) return; | |
org.__defineSetter__(n, function(val){ | |
if (this.cloneitem) | |
this.cloneitem.setAttribute(n, !!val); | |
this.setAttribute(n, !!val); | |
return val; | |
}); | |
org.__defineGetter__(n, function(){ | |
return this.getAttribute(n) == "true"; | |
}); | |
}); | |
} | |
// separator はここで終了 | |
if (menuitem.localName == "menuseparator") | |
return menuitem; | |
cls.add("menuitem-iconic"); | |
if (!obj.onclick) | |
menuitem.setAttribute("onclick", "checkForMiddleClick(this, event)"); | |
return menuitem; | |
}, | |
}; | |
window.giContextMenu.init(); | |
function $(id) { return document.getElementById(id); } | |
function $$(exp, doc) { return Array.prototype.slice.call((doc || document).querySelectorAll(exp)); } | |
// http://gist.github.com/321205 | |
function $A(args) { return Array.prototype.slice.call(args); } | |
function U(text) 1 < 'あ'.length ? decodeURIComponent(escape(text)) : text; | |
function $E(xml, doc) { | |
doc = doc || document; | |
xml = <root xmlns={doc.documentElement.namespaceURI}/>.appendChild(xml); | |
var settings = XML.settings(); | |
XML.prettyPrinting = false; | |
var root = new DOMParser().parseFromString(xml.toXMLString(), 'application/xml').documentElement; | |
XML.setSettings(settings); | |
doc.adoptNode(root); | |
var range = doc.createRange(); | |
range.selectNodeContents(root); | |
var frag = range.extractContents(); | |
range.detach(); | |
return frag.childNodes.length < 2 ? frag.firstChild : frag; | |
} | |
function addStyle(css) { | |
var pi = document.createProcessingInstruction( | |
'xml-stylesheet', | |
'type="text/css" href="data:text/css;utf-8,' + encodeURIComponent(css) + '"' | |
); | |
return document.insertBefore(pi, document.documentElement); | |
} | |
})(<![CDATA[ | |
@namespace url("http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul"); | |
#contentAreaContextMenu:not([iContextMenu~="select"]) .icontextmenu[condition~="select"], | |
#contentAreaContextMenu:not([iContextMenu~="link"]) .icontextmenu[condition~="link"], | |
#contentAreaContextMenu:not([iContextMenu~="mailto"]) .icontextmenu[condition~="mailto"], | |
#contentAreaContextMenu:not([iContextMenu~="image"]) .icontextmenu[condition~="image"], | |
#contentAreaContextMenu:not([iContextMenu~="media"]) .icontextmenu[condition~="media"], | |
#contentAreaContextMenu:not([iContextMenu~="input"]) .icontextmenu[condition~="input"], | |
#contentAreaContextMenu[iContextMenu~="select"] .icontextmenu[condition~="noselect"], | |
#contentAreaContextMenu[iContextMenu~="link"] .icontextmenu[condition~="nolink"], | |
#contentAreaContextMenu[iContextMenu~="mailto"] .icontextmenu[condition~="nomailto"], | |
#contentAreaContextMenu[iContextMenu~="image"] .icontextmenu[condition~="noimage"], | |
#contentAreaContextMenu[iContextMenu~="media"] .icontextmenu[condition~="nomedia"], | |
#contentAreaContextMenu[iContextMenu~="input"] .icontextmenu[condition~="noinput"], | |
#contentAreaContextMenu:not([iContextMenu=""]) .icontextmenu[condition~="normal"] | |
{ display: none !important; } | |
.icontextmenu:-moz-any([icon="star"], [command^="context-bookmark"]) { | |
list-style-image: url("chrome://browser/skin/places/editBookmark.png"); | |
-moz-image-region: rect(0px, 16px, 16px, 0px); | |
} | |
.icontextmenu:-moz-any([icon="save"], [command^="context-save"]) { | |
list-style-image: url(""); | |
} | |
.icontextmenu:-moz-any([icon="copy"], [command^="context-copy"]) { | |
list-style-image: url(""); | |
} | |
.icontextmenu:-moz-any([icon="send"], [command^="context-send"]) { | |
list-style-image: url(""); | |
} | |
.icontextmenu:-moz-any([command="context-viewsource"], [command="context-viewpartialsource-selection"]) { | |
list-style-image: url(""); | |
} | |
.icontextmenu:-moz-any([icon="info"], [command="context-viewinfo"], [command="context-viewimageinfo"]) { | |
list-style-image: url(""); | |
} | |
.icontextmenu:-moz-any([icon="blank"], [command="context-openlinkincurrent"]) { | |
list-style-image: url(""); | |
} | |
.icontextmenu:-moz-any([icon="app"], [command="context-openlink"]) { | |
list-style-image: url(""); | |
} | |
.icontextmenu:-moz-any([icon="jpg"], [command="context-viewimage"]) { | |
list-style-image: url("moz-icon://.jpg?size=16"); | |
} | |
.icontextmenu:-moz-any([icon="images"], [command="context-copyimage-contents"]) { | |
list-style-image: url(""); | |
} | |
.icontextmenu:-moz-any([icon="back"], [command="context-back"]) { | |
list-style-image: url("chrome://browser/skin/Toolbar.png"); -moz-image-region: rect(0, 18px, 18px, 0); | |
} | |
.icontextmenu:-moz-any([icon="forward"], [command="context-forward"]) { | |
list-style-image: url("chrome://browser/skin/Toolbar.png"); -moz-image-region: rect(0, 36px, 18px, 18px); | |
} | |
.icontextmenu:-moz-any([icon="stop"], [command="context-stop"]) { | |
list-style-image: url("chrome://browser/skin/Toolbar.png"); -moz-image-region: rect(0, 54px, 18px, 36px); | |
} | |
.icontextmenu:-moz-any([icon="reload"], [command="context-reload"]) { | |
list-style-image: url("chrome://browser/skin/Toolbar.png"); -moz-image-region: rect(0, 72px, 18px, 54px); | |
} | |
.icontextmenu:-moz-any([icon="home"], [command="Browser:Home"]) { | |
list-style-image: url("chrome://browser/skin/Toolbar.png"); -moz-image-region: rect(0, 90px, 18px, 72px); | |
} | |
.icontextmenu:-moz-any([icon="download"]) { | |
list-style-image: url("chrome://browser/skin/Toolbar.png"); -moz-image-region: rect(0, 108px, 18px, 90px); | |
} | |
.icontextmenu:-moz-any([icon="history"]) { | |
list-style-image: url("chrome://browser/skin/Toolbar.png"); -moz-image-region: rect(0, 126px, 18px, 108px); | |
} | |
.icontextmenu:-moz-any([icon="bookmark"]) { | |
list-style-image: url("chrome://browser/skin/Toolbar.png"); -moz-image-region: rect(0, 144px, 18px, 126px); | |
} | |
.icontextmenu:-moz-any([icon="print"]) { | |
list-style-image: url("chrome://browser/skin/Toolbar.png"); -moz-image-region: rect(0, 162px, 18px, 144px); | |
} | |
.icontextmenu:-moz-any([icon="newtab"], [command="context-openlinkintab"]) { | |
list-style-image: url("chrome://browser/skin/Toolbar.png"); -moz-image-region: rect(0, 180px, 18px, 162px); | |
} | |
.icontextmenu:-moz-any([icon="newwindow"]) { | |
list-style-image: url("chrome://browser/skin/Toolbar.png"); -moz-image-region: rect(0, 198px, 18px, 180px); | |
} | |
.icontextmenu:-moz-any([icon="copy2"]) { | |
list-style-image: url("chrome://browser/skin/Toolbar.png"); -moz-image-region: rect(0, 234px, 18px, 216px); | |
} | |
.icontextmenu:-moz-any([icon="paste"]) { | |
list-style-image: url("chrome://browser/skin/Toolbar.png"); -moz-image-region: rect(0, 252px, 18px, 234px); | |
} | |
.icontextmenu:-moz-any([icon="fullscreen"]) { | |
list-style-image: url("chrome://browser/skin/Toolbar.png"); -moz-image-region: rect(0, 270px, 18px, 252px); | |
} | |
.icontextmenu:-moz-any([icon="zoomout"], [icon="plus"]) { | |
list-style-image: url("chrome://browser/skin/Toolbar.png"); -moz-image-region: rect(0, 288px, 18px, 270px); | |
} | |
.icontextmenu:-moz-any([icon="zoomin"], [icon="minus"]) { | |
list-style-image: url("chrome://browser/skin/Toolbar.png"); -moz-image-region: rect(0, 306px, 18px, 288px); | |
} | |
.icontextmenu:-moz-any([icon="sync"]) { | |
list-style-image: url("chrome://browser/skin/Toolbar.png"); -moz-image-region: rect(0, 324px, 18px, 306px); | |
} | |
.icontextmenu:-moz-any([icon="feed"]) { | |
list-style-image: url("chrome://browser/skin/Toolbar.png"); -moz-image-region: rect(0, 342px, 18px, 324px); | |
} | |
.icontextmenu:-moz-any([icon="feedorange"]) { | |
list-style-image: url("chrome://browser/skin/feeds/feedIcon16.png"); | |
} | |
.icontextmenu:-moz-any([icon="search"], [command="context-searchselect"]) { | |
list-style-image: url("chrome://global/skin/icons/Search-glass.png"); | |
-moz-image-region: rect(0px, 16px, 16px, 0px); | |
} | |
.icontextmenu:-moz-any([icon="starbutton"]) { | |
list-style-image: none; | |
} | |
.icontextmenu:-moz-any([icon="starbutton"]) > hbox > .menu-iconic-icon { | |
background: transparent no-repeat center center -moz-element(#star-button); | |
} | |
]]>.toString()); |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment