aboutsummaryrefslogtreecommitdiffstats
path: root/mouseinspect.js
blob: b28d1f08b794865f8186c246affe37a99da8d14c (plain)
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
/*
 * ==VimperatorPlugin==
 * @name            mouseinspect.js
 * @description     display informations of the specified element and highlight it by mouse.
 * @description-ja  マウスで指定した要素の情報をコマンドラインに表示&ハイライトする。
 * @author          janus_wel <janus_wel@fb3.so-net.ne.jp>
 * @version         0.21
 * @minversion      2.0pre 2008/10/16
 * ==/VimperatorPlugin==
 *
 * LICENSE
 *   New BSD License
 *
 * CONSTRAINT
 *  need highlight.js
 *
 * USAGE
 *  :mouseinspect
 *  :mins
 *      -> start inspect by mouse
 *
 *  :nomouseinspect
 *  :nomins
 *      -> stop inspect and clear highlight
 *
 * SETTING
 *  blink_element_color:    color. default is red.
 *  blink_element_opacity:  opacity value. default is 0.5 .
 *
 * EXAMPLE
 *  let blink_element_color='green'
 *  let blink_element_opacity='0.7'
 * */

// use setTimeout to synchronize ( wait to process highlight.js )
// "liberator.modules.plugins.highlighterFactory" is build by highlight.js .
// it is the factory that build highlight object.
setTimeout( function () {

if (!plugins.highlighterFactory) {
    liberator.log('mouseinspect.js needs highlight.js', 0);
    return;
}

// default settings
const defaultColor   = 'red';
const defaultOpacity = 0.5;

// main
let elementInfo = function (event) {
    let element = event.target;

    if (element.className === 'vimp_plugin_highlightelement') {
        elementInfo.highlighter.unhighlightAll();
        return;
    }

    let attributes = [a.name + '="' + a.value + '"' for (a in util.Array.iterator(element.attributes))].join(' ');
    let str = '<' + element.localName.toLowerCase() + (attributes ? ' ' + attributes : '') + '>';
    liberator.echo(str, commandline.FORCE_SINGLELINE);

    elementInfo.highlighter.highlight(element);
};

let setupHighlighter = function () {
    elementInfo.highlighter = plugins.highlighterFactory({
        color:    liberator.globalVariables.mouse_inspect_color   || defaultColor,
        opacity:  liberator.globalVariables.mouse_inspect_opacity || defaultOpacity,
        interval: 0,
    });
}

setupHighlighter();

// register commands
commands.addUserCommand(
    ['mouseinspect', 'mins'],
    'mouse',
    function () {
        setupHighlighter();
        window.addEventListener('mousemove', elementInfo, false);
    },
    {}
);
commands.addUserCommand(
    ['nomouseinspect', 'nomins'],
    'mouse',
    function () {
        window.removeEventListener('mousemove', elementInfo, false);
        elementInfo.highlighter.unhighlightAll();
    },
    {}
);

}, 0); // setTimeout

// vim: set sw=4 ts=4 et;
ar! "fooooobar!" メモに書く ]]></detail> </VimperatorPlugin>; // }}} // References: // http://developer.mozilla.org/index.php?title=Ja/Code_snippets/File_I%2F%2FO (function () { let localfilepath = liberator.globalVariables.memo_filepath || io.expandPath('~/.vimpmemo'); let charset = 'UTF-8'; //ネタ的 let lz = function(s,n)(s+'').replace(new RegExp('^.{0,'+(n-1)+'}$'),function(s)lz('0'+s,n)); function dateTime () { with (new Date()) return lz(getFullYear(), 4) + '/' + lz(getMonth() + 1, 2) + '/' + lz(getDate(), 2) + ' ' + lz(getHours(), 2) + ':' + lz(getMinutes(), 2); } function filepath () { let result = Cc["@mozilla.org/file/local;1"].createInstance(Ci.nsILocalFile); result.initWithPath(localfilepath); return result; } function puts (line) { line = dateTime() + "\t" + line + "\n"; let out = Cc["@mozilla.org/network/file-output-stream;1"].createInstance(Ci.nsIFileOutputStream); let conv = Cc['@mozilla.org/intl/converter-output-stream;1']. createInstance(Ci.nsIConverterOutputStream); out.init(filepath(), 0x02 | 0x10 | 0x08, 0664, 0); conv.init(out, charset, line.length, Components.interfaces.nsIConverterInputStream.DEFAULT_REPLACEMENT_CHARACTER); conv.writeString(line); conv.close(); out.close(); } function gets () { let file = Cc['@mozilla.org/network/file-input-stream;1'].createInstance(Ci.nsIFileInputStream); file.init(filepath(), 1, 0, false); let conv = Cc['@mozilla.org/intl/converter-input-stream;1'].createInstance(Ci.nsIConverterInputStream); conv.init(file, charset, file.available(), conv.DEFAULT_REPLACEMENT_CHARACTER); let result = {}; conv.readString(file.available(), result); conv.close(); file.close(); return result.value; } commands.addUserCommand( ['memo'], 'Write memo', function (arg) { if (arg.bang) return util.copyToClipboard(arg.literalArg); if (arg.literalArg) { puts(arg.literalArg); } else { let out = <></>; gets().split(/\n/).reverse().forEach(function (l) { out += <li>{l}</li> }); liberator.echo(out); } }, { bang: true, literal: 0, completer: function (context, args) { if (!args.bang) return; context.compare = void 0; context.createRow = function(item, highlightGroup) { let desc = item[1] || this.process[1].call(this, item, item.description); if (item.description && item.description.length) { return <div highlight={highlightGroup || "CompItem"} style="white-space: nowrap"> <li highlight="CompDesc"> {item.description} </li> </div>; } return <div highlight={highlightGroup || "CompItem"} style="white-space: nowrap"> <li highlight="CompDesc">{item[0]}&#160;</li> </div>; }; context.filters = [function (item) this.match(item.description)]; context.completions = [ [it.replace(/^[^\t]+\t/, ''), it] for ([, it] in Iterator(gets().split(/\n/).reverse())) if (it.length) ]; } }, true ); })();