forked from ywzhaiqi/userChromeJS
-
Notifications
You must be signed in to change notification settings - Fork 0
/
simpleAppButton.uc.js
174 lines (147 loc) · 7.2 KB
/
simpleAppButton.uc.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
// ==UserScript==
// @name simpleAppButton.uc.js
// @namespace ywzhaiqi@gmail.com
// @description launch application by left click, middle click, right click,可移动的按钮。
// @note 第一次启动需从定制窗口中拖出按钮
// @include main
// @charset UTF-8
// ==/UserScript==
location == "chrome://browser/content/browser.xul" && (function() {
// 依次为鼠标左键、中键、右键点击启动程序的路径。支持相对和绝对路径
var left_click_path = "\\chrome";
var middle_click_path = "C:\\Program Files\\Internet Explorer\\IEXPLORE.EXE";
var right_click_path = "C:\\Windows\\notepad.exe";
// 按钮图标
var image = "";
// 按钮的属性
var buttonAttrs = {
id: "mAppButton-1",
class: "toolbarbutton-1 chromeclass-toolbar-additional",
label: "自定义启动程序按钮",
tooltiptext: "左键点击启动,右键点击启动",
removable: "true",
image: image
};
/* 设置区结束 */
// 来自 User Agent Overrider 扩展
const log = function() { dump(Array.slice(arguments).join(' ') + '\n'); };
const trace = function(error) { log(error); log(error.stack); };
const ToolbarManager = (function() {
/**
* Remember the button position.
* This function Modity from addon-sdk file lib/sdk/widget.js, and
* function BrowserWindow.prototype._insertNodeInToolbar
*/
let layoutWidget = function(document, button, isFirstRun) {
// Add to the customization palette
let toolbox = document.getElementById('navigator-toolbox');
toolbox.palette.appendChild(button);
// Search for widget toolbar by reading toolbar's currentset attribute
let container = null;
let toolbars = document.getElementsByTagName('toolbar');
let id = button.getAttribute('id');
for (let i = 0; i < toolbars.length; i += 1) {
let toolbar = toolbars[i];
if (toolbar.getAttribute('currentset').indexOf(id) !== -1) {
container = toolbar;
}
}
// if widget isn't in any toolbar, default add it next to searchbar
if (!container) {
if (isFirstRun) {
container = document.getElementById('nav-bar');
} else {
return;
}
}
// Now retrieve a reference to the next toolbar item
// by reading currentset attribute on the toolbar
let nextNode = null;
let currentSet = container.getAttribute('currentset');
let ids = (currentSet === '__empty') ? [] : currentSet.split(',');
let idx = ids.indexOf(id);
if (idx !== -1) {
for (let i = idx; i < ids.length; i += 1) {
nextNode = document.getElementById(ids[i]);
if (nextNode) {
break;
}
}
}
// Finally insert our widget in the right toolbar and in the right position
container.insertItem(id, nextNode, null, false);
// Update DOM in order to save position
// in this toolbar. But only do this the first time we add it to the toolbar
if (ids.indexOf(id) === -1) {
container.setAttribute('currentset', container.currentSet);
document.persist(container.id, 'currentset');
}
};
let addWidget = function(window, widget, isFirstRun) {
try {
layoutWidget(window.document, widget, isFirstRun);
} catch(error) {
trace(error);
}
};
let removeWidget = function(window, widgetId) {
try {
let widget = window.document.getElementById(widgetId);
widget.parentNode.removeChild(widget);
} catch (error) {
trace(error);
}
};
let exports = {
addWidget: addWidget,
removeWidget: removeWidget,
};
return exports;
})();
var PROFILE_PATH = Components.classes['@mozilla.org/file/directory_service;1']
.getService(Components.interfaces.nsIProperties).get("ProfD", Components.interfaces.nsILocalFile)
.path;
var appButton = $C('toolbarbutton', buttonAttrs);
appButton.addEventListener("click", function(event) {
if (event.button == 0) {
exec(handlePath(left_click_path));
} else if (event.button == 1) {
exec(handlePath(middle_click_path));
} else if (event.button == 2) {
exec(handlePath(right_click_path));
}
}, false);
ToolbarManager.addWidget(window, appButton, false);
function handlePath(path) {
path = path.replace(/\//g, '\\').toLocaleLowerCase();
if (/^(\\)/.test(path)) {
return PROFILE_PATH + path;
}
return path;
}
function exec(path, args) {
args = args || [];
var args_t = args.slice(0);
for (var i = 0; i < args_t.length; i++) {
args_t[i] = args_t[i].replace(/%u/g, gBrowser.currentURI.spec);
}
var file = Cc['@mozilla.org/file/local;1'].createInstance(Ci.nsILocalFile);
file.initWithPath(path);
if (!file.exists()) {
Cu.reportError('File Not Found: ' + path);
return;
}
if (!file.isExecutable()) {
file.launch();
} else {
var process = Cc['@mozilla.org/process/util;1'].createInstance(Ci.nsIProcess);
process.init(file);
process.run(false, args_t, args_t.length);
}
}
function $C(name, attr) {
var el = document.createElement(name);
if (attr) Object.keys(attr).forEach(function(n) el.setAttribute(n, attr[n]));
return el;
}
})()