Skip to content

Instantly share code, notes, and snippets.

@xulapp
Created January 23, 2011 05:21
Show Gist options
  • Select an option

  • Save xulapp/791846 to your computer and use it in GitHub Desktop.

Select an option

Save xulapp/791846 to your computer and use it in GitHub Desktop.
unalert is dom based alert dialog
// ==UserScript==
// @name unalert
// @description dom based alert dialog
// @include http://www.nicovideo.jp/*
// @charset utf-8
// @compatibility Firefox
// @namespace http://twitter.com/xulapp
// @author xulapp
// @license MIT License
// @version 2011/01/23 14:20 +09:00
// ==/UserScript==
// @version 2011/01/02 20:30 +09:00
(function unalert() {
const DEFAULT_POSITION = 'right: 0; bottom: 0;';
GM_addStyle(<><![CDATA[
.unalert {
position: fixed;
min-width: 320px;
font-size: 9pt;
text-align: left;
z-index: 2147483647;
}
.unalert-titlebar {
min-height: 21px;
padding: 0 5px;
border-width: 1px 1px 0;
border-style: solid;
border-color: #272727;
-moz-border-radius: 6px 6px 0 0;
background-image: -moz-linear-gradient(#6e6e6e, #272727);
color: #ffffff;
line-height: 21px;
cursor: default;
-moz-user-select: none;
}
.unalert-content {
max-width: 45em;
padding: 8px;
border-width: 0 3px 3px;
border-style: solid;
border-color: #272727;
background-color: #f0f0f0;
}
.unalert-content-box {
min-height: 32px;
padding: 5px 5px 4px 47px;
background: url("") no-repeat 5px 5px;
white-space: pre-wrap;
word-wrap: break-word;
}
.unalert-button-box {
text-align: center;
}
.unalert-button {
min-width: 6em;
margin: 6px 5px 2px;
padding: 0;
font-size: 9pt;
}
]]></>);
var script = document.createElement('script');
script.type = 'text/javascript; version=1.8';
script.textContent = <><![CDATA[
(function() {
function Class(sup, pro) {
if (sup && typeof sup === 'object')
pro = sup, sup = Object;
var con = Object.prototype.hasOwnProperty.call(pro, 'constructor') ? pro.constructor : Function();
pro.constructor = con;
pro.__proto__ = sup && sup.prototype;
con.prototype = pro;
con.superclass = sup;
con.__proto__ = Class.prototype;
return con;
}
Class = Class(Function, {
constructor: Class,
__noSuchMethod__: function __noSuchMethod__(name, args) {
if (name in this.prototype)
return Function.prototype.call.apply(this.prototype[name], args);
throw new TypeError((this.name || 'class') + '.' + name + ' is not a function');
},
$super: function $super(self, args) {
var sup = this.superclass;
var method = $super.caller === this ? sup : sup.prototype[$super.caller.name];
return method.apply(self, args || []);
},
createInstance: function createInstance(args) {
var instance = {__proto__: this.prototype};
var result = this.apply(instance, args || []);
return result instanceof Object ? result : instance;
},
});
var draggable = Class({
constructor: function draggable(element) {
if (!(this instanceof draggable))
return draggable.createInstance(arguments);
this.element = element;
element.addEventListener('mousedown', this, false, false);
},
isDraggableTarget: let (formCtrlExp) function isDraggableTarget(target) {
if (!target) return false;
if (target === this.element) return true;
if (!formCtrlExp)
formCtrlExp = document.createExpression('ancestor-or-self::*[local-name()="select" or local-name()="button" or local-name()="input" or local-name()="textarea" or @*[local-name()="tabindex"]]', null);
return !formCtrlExp.evaluate(target, XPathResult.BOOLEAN_TYPE, null).booleanValue;
},
detatch: function detatch() {
this.element.removeEventListener('mousedown', this, false);
},
handleEvent: function handleEvent(event) {
if (event.type in this)
this[event.type](event);
},
mousedown: function onMouseDown(event) {
if (event.button !== 0) return;
if (!this.isDraggableTarget(event.target)) return;
event.preventDefault();
var focused = this.element.querySelector(':focus');
if (focused)
focused.blur();
this.offsetX = event.pageX - this.element.offsetLeft;
this.offsetY = event.pageY - this.element.offsetTop;
document.addEventListener('mousemove', this, true, false);
document.addEventListener('mouseup', this, true, false);
},
mousemove: function onMouseMove(event) {
event.preventDefault();
this.element.style.left = event.pageX - this.offsetX + 'px';
this.element.style.top = event.pageY - this.offsetY + 'px';
},
mouseup: function onMouseUp(event) {
if (event.button !== 0) return;
event.preventDefault();
document.removeEventListener('mousemove', this, true);
document.removeEventListener('mouseup', this, true);
},
});
alert = function unalert(message) {
var wrapper = document.createElement('div');
wrapper.className = 'unalert';
var tbar = document.createElement('div');
tbar.className = 'unalert-titlebar';
tbar.textContent = 'unalert';
var content = document.createElement('div');
content.className = 'unalert-content';
var cbox = document.createElement('div');
cbox.className = 'unalert-content-box';
cbox.textContent = message;
var bbox = document.createElement('div');
bbox.className = 'unalert-button-box';
var btn = document.createElement('button');
btn.className = 'unalert-button';
btn.textContent = 'OK';
btn.addEventListener('click', function() document.adoptNode(wrapper), false);
draggable(wrapper);
wrapper.appendChild(tbar);
wrapper.appendChild(content);
content.appendChild(cbox);
content.appendChild(bbox);
bbox.appendChild(btn);
document.body.appendChild(wrapper);
wrapper.setAttribute('style', ]]>{uneval(DEFAULT_POSITION)}<![CDATA[);
wrapper.setAttribute('style', 'left: ' + wrapper.offsetLeft + 'px; top: ' + wrapper.offsetTop + 'px;');
};
})();
]]></>;
document.adoptNode(document.querySelector('head').appendChild(script));
})();
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment