siteinfo regexp demo
by
noromanba
2013-09-30 [2013/09/30 05:48:08]
(Forked from
siteinfo regexp demo by
taizooo)
visualize SITEINFO pattern, link to String_random.js demo page; for Autopagerize Database
@@ -1,40 +1,62 @@
/*
* @title siteinfo regexp demo
- * @description linkify url of "AutoPagerize SITEINFO pattern" on Autopagerize Database
+ * @description visualize SITEINFO pattern, link to String_random.js demo page; for Autopagerize Database
* @include http://wedata.net/items/*
* @include http://wedata.net/databases/*
* @contributor taizooo http://let.hatelabo.jp/taizooo/let/hLHUotLLysV8 (Fork of)
* @orig-license Unknown (as-is)
- * @contributor noromanba
- * @license
+ * @contributor noromanba http://let.hatelabo.jp/noromanba/let/hJmcrJG18dRE
+ * @license TBD
* @require https://gist.github.com/cho45/3238/raw/dollarX.js
*/
-// String_random.js http://lowreal.net/2013/09/03/1
+// String_random.js
// http://lowreal.net/2013/09/13/1
-// Demo of String_random.js http://cho45.stfuawsc.com/String_random.js/demo.html
+// http://cho45.stfuawsc.com/String_random.js/demo.html
// c.f. http://wedata.net/databases/AutoPagerize/items
-(function () {
+(function anonwrap() {
-// TODO
-// - visualize changes; e.g. :after content(url('data: ...'))
-// http://commons.wikimedia.org/wiki/File:Magnifying_glass_icon.svg (PD by Derferman)
-// - softtab and indent beautify
-// - async/wait (optional)
+// c.f.
+// https://userscripts.org/scripts/show/135577
+// https://gist.github.com/noromanba/2897358#file-addicted-to-google-code-prettify-user-js-L111
+var addStyle = (function () {
+ var parent = document.head || document.documentElement || document.body;
+ var style = document.createElement('style');
+ style.type = 'text/css';
+ parent.appendChild(style);
+ return function (css) {
+ style.appendChild(document.createTextNode(css + '\n'));
+ };
+})();
+
+// PD by tombloo
+// c.f. https://github.com/to/tombloo/blob/xpi/chrome/content/library/01_utility.js#L2489
+var commentToText = function (commentFunc) {
+ return commentFunc.toString().replace(/^.*?\r?\n/, '').replace(/\r?\n.*?$/, '');
+};
+
+// PD Icon by El T http://commons.wikimedia.org/wiki/File:Information_icon.svg
+// transcode w/ http://blog.thingslabo.com/archives/000058.html
+var icon = function () {/*
+ .let-regexp-pattern :after {
+ margin-left: 2px;
+ vertical-align: middle;
+ content: url();
+ }
+*/};
+addStyle(commentToText(icon));
var linkify = function (context) {
-
-var x = $X('//tr[th[text()="url"]]/td', context);
-x.forEach(function (x) {
- var b = x.textContent;
- var c = encodeURIComponent(b);
- var d = 'http://cho45.stfuawsc.com/String_random.js/demo.html#' + c;
- x.innerHTML = '<a href="' + d + '">' + b + '</a>'
-});
-
-}; // /linkify
-
+ var containers = $X('//tr[th[text()="url"]]/td', context);
+ containers.forEach(function (container) { // TBD async/wait
+ var pattern = container.textContent;
+ var escaped = encodeURIComponent(pattern);
+ var demoAPI = 'http://cho45.stfuawsc.com/String_random.js/demo.html#' + escaped;
+ container.innerHTML = '<a href="' + demoAPI + '">' + pattern + '</a>';
+ container.classList.add('let-regexp-pattern'); // HTML5, alt. className +=
+ });
+};
linkify(document.body);
[
@@ -47,4 +69,4 @@
}, false);
});
-})(); // /anonwrap
+})(); // /anonwrap
/*
* @title siteinfo regexp demo
* @description visualize SITEINFO pattern, link to String_random.js demo page; for Autopagerize Database
* @include http://wedata.net/items/*
* @include http://wedata.net/databases/*
* @contributor taizooo http://let.hatelabo.jp/taizooo/let/hLHUotLLysV8 (Fork of)
* @orig-license Unknown (as-is)
* @contributor noromanba http://let.hatelabo.jp/noromanba/let/hJmcrJG18dRE
* @license TBD
* @require https://gist.github.com/cho45/3238/raw/dollarX.js
*/
// String_random.js
// http://lowreal.net/2013/09/13/1
// http://cho45.stfuawsc.com/String_random.js/demo.html
// c.f. http://wedata.net/databases/AutoPagerize/items
(function anonwrap() {
// c.f.
// https://userscripts.org/scripts/show/135577
// https://gist.github.com/noromanba/2897358#file-addicted-to-google-code-prettify-user-js-L111
var addStyle = (function () {
var parent = document.head || document.documentElement || document.body;
var style = document.createElement('style');
style.type = 'text/css';
parent.appendChild(style);
return function (css) {
style.appendChild(document.createTextNode(css + '\n'));
};
})();
// PD by tombloo
// c.f. https://github.com/to/tombloo/blob/xpi/chrome/content/library/01_utility.js#L2489
var commentToText = function (commentFunc) {
return commentFunc.toString().replace(/^.*?\r?\n/, '').replace(/\r?\n.*?$/, '');
};
// PD Icon by El T http://commons.wikimedia.org/wiki/File:Information_icon.svg
// transcode w/ http://blog.thingslabo.com/archives/000058.html
var icon = function () {/*
.let-regexp-pattern :after {
margin-left: 2px;
vertical-align: middle;
content: url();
}
*/};
addStyle(commentToText(icon));
var linkify = function (context) {
var containers = $X('//tr[th[text()="url"]]/td', context);
containers.forEach(function (container) { // TBD async/wait
var pattern = container.textContent;
var escaped = encodeURIComponent(pattern);
var demoAPI = 'http://cho45.stfuawsc.com/String_random.js/demo.html#' + escaped;
container.innerHTML = '<a href="' + demoAPI + '">' + pattern + '</a>';
container.classList.add('let-regexp-pattern'); // HTML5, alt. className +=
});
};
linkify(document.body);
[
'AutoPatchWork.DOMNodeInserted',
'AutoPagerize_DOMNodeInserted',
'AutoPagerAfterInsert'
].forEach(function (paging) {
document.body.addEventListener(paging, function (evt) {
linkify(evt.target);
}, false);
});
})(); // /anonwrap
- Permalink
- このページへの個別リンクです。
- RAW
- 書かれたコードへの直接のリンクです。
- Packed
- 文字列が圧縮された書かれたコードへのリンクです。
- Userscript
- Greasemonkey 等で利用する場合の .user.js へのリンクです。
- Loader
- @require やソースコードが長い場合に多段ロードする Loader コミのコードへのリンクです。
- Metadata
- コード中にコメントで @xxx と書かれたメタデータの JSON です。