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;
n>updateURL>https://github.com/vimpr/vimperator-plugins/raw/master/x-hint.js</updateURL> <minVersion>2.3</minVersion> <maxVersion>2.3</maxVersion> <detail><![CDATA[ :xh[int] <Hint-Mode> <XPath>: Show the <Hint-Mode> hints with <XPath> ]]></detail> <detail lang="ja"><![CDATA[ :xh[int] <Hint-Mode> <XPath>: <XPath> <Hint-Mode> ヒントを表示 ]]></detail> </VimperatorPlugin>; // }}} // INFO {{{ let INFO = <> <plugin name="X-Hint" version="1.1.2" href="http://svn.coderepos.org/share/lang/javascript/vimperator-plugins/trunk/x-hint.js" summary="Show the hints with given XPath." lang="en-US" xmlns="http://vimperator.org/namespaces/liberator"> <author email="anekos@snca.net">anekos</author> <license>New BSD License</license> <project name="Vimperator" minVersion="2.3"/> <p>Show the hints with given XPath.</p> <item> <tags>:xhint</tags> <tags>:xh</tags> <spec>:xh<oa>int</oa> <a>HintMode</a> <a>XPath</a></spec> <description> <p> Show the <a>HintMode</a> hints with <a>XPath</a> </p> </description> </item> <item> <tags>:xhintdo</tags> <tags>:xhdo</tags> <spec>:xhintdo <a>XPath</a> <a>javascript</a></spec> <description> <p> Show the hints with <a>XPath</a>. And do <a>javascript</a> code. This command gives the variable "elem" to the context of <a>javascript</a>. </p> </description> </item> </plugin> <plugin name="X-Hint" version="1.1.2" href="http://svn.coderepos.org/share/lang/javascript/vimperator-plugins/trunk/x-hint.js" summary="Show the hints with given XPath." lang="ja" xmlns="http://vimperator.org/namespaces/liberator"> <author email="anekos@snca.net">anekos</author> <license>New BSD License</license> <project name="Vimperator" minVersion="2.3"/> <p>Show the hints with given XPath.</p> <item> <tags>:xhint</tags> <tags>:xh</tags> <spec>:xh<oa>int</oa> <a>HintMode</a> <a>XPath</a></spec> <description> <p> <a>XPath</a> で <a>HintMode</a> ヒントを表示する。 </p> </description> </item> <item> <tags>:xhintdo</tags> <tags>:xhdo</tags> <spec>:xhintdo <a>XPath</a> <a>javascript</a></spec> <description> <p> <a>XPath</a> でヒントを出し、<a>javascript</a> コードを実行します。 <a>javascript</a> の context には 変数 "elem" が与えられます。 </p> </description> </item> </plugin> </>; // }}} (function () { const description = 'Show the hint with given xpath.'; let last = {}; function xpath () (last.xpath || '//a') plugins.libly.$U.around( hints, 'show', function (next, [minor, filter, win]) { if (last.xpath) { // save last.hintMode = this._hintModes[minor]; last.hintTags = last.hintMode.tags; // override last.hintMode.tags = xpath; } return next(); }, true ); plugins.libly.$U.around( hints, 'hide', function (next, [minor, filter, win]) { if (last.hintMode) last.hintMode.tags = last.hintTags; last = {}; return next(); }, true ); function showHintsWith (mode, xpath) { last.xpath = xpath; hints.show(mode); } __context__.show = showHintsWith; commands.addUserCommand( ['xh[int]'], description + '(:xhint <mode> <xpath>)', function (args) { showHintsWith(args[0], args.literalArg); }, { literal: 1 }, true ); let (hintModeText = 'x-hint-do', js = null) { hints.addMode( hintModeText, 'X-Hint DO', function (elem) { let context = {__proto__: modules.userContext, elem: elem}; try { liberator.eval(js, context); } catch (e) { liberator.echoerr(e); } } ); commands.addUserCommand( ['xhintdo', 'xhdo'], 'Run js-code with X-Hint. (:xhdo <xpath> <javascript>)', function (args) { js = args.literalArg; showHintsWith(hintModeText, args[0]); }, { literal: 1, completer: function (context, args) { if (args.completeArg == 1) completion.javascript(context); } }, true ); } })(); // vim:sw=2 ts=2 et si fdm=marker: