/** * ==VimperatorPlugin== * @name Split Browser for Vimperator * @author teramako * @version 1.1b * @depend "Split Browser" {29c4afe1-db19-4298-8785-fcc94d1d6c1d} * ==/VimperatorPlugin== * * CAUTION: * It's need "SplitBrowser" addon. * Please install from * - https://addons.mozilla.org/en-US/firefox/addon/4287 * or * - https://addons.mozilla.org/ja/firefox/addon/4287 * * Usage: * * ---------------------------- * Commands * ---------------------------- * :sp[lit] [arg1] [arg2] ... [destination] * split horizontal and open [arg1] * opens [arg2] ... to background tab, if [arg2] ... is applied * [destination] is -top, if omitted * * :vs[plit] [arg1] [arg2] ... [destination] * like sp[lit] command * but [destination] is -right, if omitted * * available [destination] * -l or -left * -r or -right * -t or -top * -b or -bottom * * :on[ly] [-g] * Close all subbrowsers * or * Gather all subbrowsers to main browser if `-g' option is applied * * -------------------------- * Mappings * -------------------------- * -> focus next browser * 0 -> focus main browser * $ -> focus the last opened subbrowser * -> virtical split * -> horizontal split * d -> close tab or subbrowser * * s[maps] -> [maps] is some nomral map names * e.g.) * sd -> remove current tab * sgt -> switch focus to the next tab * sgT -> switch focus to the previous tab */ (function(){ const SplitBrowserAppID = '{29c4afe1-db19-4298-8785-fcc94d1d6c1d}'; if (!Application.extensions.get(SplitBrowserAppID).enabled) return; liberator.plugins.splitBrowser = (function(){ function getPositionForOpen(obj){ var p = null; for (var i in obj){ switch (i){ case '-l': p = SplitBrowser.POSITION_LEFT; break; case '-r': p = SplitBrowser.POSITION_RIGHT; break; case '-t': p = SplitBrowser.POSITION_TOP; break; case '-b': p = SplitBrowser.POSITION_BOTTOM; break; } } return p; } function focusSwitch(where, isAbsolute){ //{{{ if (SplitBrowser.browsers.length == 0) return; var bs = SplitBrowser.browsers; if (isAbsolute && bs[key-1]){ bs[key-1].browser.contentWindow.focus(); } else if (where == 0){ getBrowser().contentWindow.focus(); } else if (where == '$'){ bs[bs.length-1].browser.contentWindow.focus(); } else if (/^[-+]?[0-9]+$/.test(where)){ var length = bs.length; var count = parseInt(where,10) % (length + 1); if (SplitBrowser.activeBrowser == getBrowser()){ if (count > 0){ bs[count-1].browser.contentWindow.focus(); } else if (count < 0){ bs[length + count].browser.contentWindow.focus(); } else { return; } } else { var id = SplitBrowser.activeSubBrowser.id; for (var i=0; i 0){ bs[count-1].browser.contentWindow.focus(); } else if (count < 0){ bs[length + count].browser.contentWindow.focus(); } else { getBrowser().contentWindow.focus(); } return true; } } } } } //}}} var commandExtra = { completer: function(filter) completion.url(filter), options: [ [['-l','-left'], commands.OPTION_NOARG], [['-r','-right'], commands.OPTION_NOARG], [['-t','-top'], commands.OPTION_NOARG], [['-b','-bottom'], commands.OPTION_NOARG] ], argCount: "*" }; /* ---------------------------------------------- * Commands * --------------------------------------------*/ commands.addUserCommand(['sp[lit]'], 'split browser', //{{{ function(args){ liberator.plugins.splitBrowser.openSubBrowser(args, SplitBrowser.POSITION_TOP); }, commandExtra ); //}}} commands.addUserCommand(['vs[plit]'], 'split browser', //{{{ function(args){ liberator.plugins.splitBrowser.openSubBrowser(args, SplitBrowser.POSITION_RIGHT); }, commandExtra ); //}}} commands.addUserCommand(['on[ly]'], 'Close or gather all subbrowsers', //{{{ function(args){ if (SplitBrowser.browsers.length == 0) { liberator.echoerr('SubBrowser is none'); return; } if (args == '-g') { SplitBrowser.gatherSubBrowsers(); } else { SplitBrowser.removeAllSubBrowsers(); } } ); //}}} /* ---------------------------------------------- * Mappings * --------------------------------------------*/ mappings.addUserMap([modes.NORMAL],['s'], 'SplitBrowser motion Map', //{{{ function(key, count){ gBrowser = SplitBrowser.activeBrowser; try { var map = mappings.get(modes.NORMAL, key) map.execute(null, count); } catch(e) { liberator.log(e); } finally { gBrowser = document.getElementById('content'); } },{ motion: true, count: true, rhs: 'Motion map for SplitBrowser' } ); //}}} mappings.addUserMap([modes.NORMAL], [''], 'select subbrowser', //{{{ function(count, key){ if (/[1-9]/.test(key)){ focusSwitch(parseInt(key), true); return; } switch (key){ case '0': case '$': focusSwitch(key); break; case 'h': //FIXME: How to get subbrowser of relative position ? case 'j': case '': case 'w': focusSwitch(count > 0 ? count : 1); break; case 'k': case 'l': case 'W': forcusSwitch('-' + (count > 0 ? count : 1)); break; case 'd': liberator.plugins.splitBrowser.closeSubBrowser(); break; case 'v': case '': liberator.plugins.splitBrowser.openSubBrowser([buffer.URL],SplitBrowser.POSITION_RIGHT); break; case 's': case '': liberator.plugins.splitBrowser.openSubBrowser([buffer.URL],SplitBrowser.POSITION_TOP); break; } },{ //flags: Mappings.flags.COUNT + Mappings.flags.ARGUMENT, count: true, arg: true, rhs: 'select subbrowser' } ); //}}} /** * Overwrite for SplitBrowser */ config.__defineGetter__('browser', function () SplitBrowser.activeBrowser); config.__defineGetter__('tabbrowser', function () SplitBrowser.activeBrowser); var manager = { splitBrowserId: SplitBrowserAppID, /** * create new subBrowser and load url * @param {Object} args command aruguments * @param {Number} defPosition default split direction */ openSubBrowser: function(args, defPosition){ var url; var urls = []; var position = defPosition || SplitBrowser.POSITION_TOP; position = getPositionForOpen(args) || position; if (args.length > 0){ urls = util.stringToURLArray(args.join(', ')); if (urls.length == 0) { url = buffer.URL; } else { url = urls[0]; urls.shift(); } } else { url = buffer.URL; } var subBrowser = SplitBrowser.addSubBrowser(url, null, position); subBrowser.addEventListener('load',function(){ subBrowser.removeEventListener('load',arguments.callee,true); subBrowser.browser.contentWindow.focus(); },true); urls.forEach(function(url){ subBrowser.browser.addTab(url, null, null, null); }); return subBrowser; }, closeSubBrowser: function(){ var b = SplitBrowser.activeBrowser; if (b.mTabs.length > 1){ b.removeTab(b.mCurrentTab); } else { if (b === getBrowser()){ liberator.open('about:blank', liberator.NEW_BACKGROUND_TAB); getBrowser().removeTab(gBrowser.mCurrentTab); } else { SplitBrowser.activeBrowserCloseWindow(); } } } }; return manager; })(); })(); // vim:fdm=marker sw=4 ts=4 et: 152' href='#n152'>152 153 154 155 156 157 158 159 160
/* {{{
Copyright (c) 2008, anekos.
All rights reserved.

Redistribution and use in source and binary forms, with or without modification,
are permitted provided that the following conditions are met:

    1. Redistributions of source code must retain the above copyright notice,
       this list of conditions and the following disclaimer.
    2. Redistributions in binary form must reproduce the above copyright notice,
       this list of conditions and the following disclaimer in the documentation
       and/or other materials provided with the distribution.
    3. The names of the authors may not be used to endorse or promote products
       derived from this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
THE POSSIBILITY OF SUCH DAMAGE.


###################################################################################
# http://sourceforge.jp/projects/opensource/wiki/licenses%2Fnew_BSD_license       #
# に参考になる日本語訳がありますが、有効なのは上記英文となります。                #
###################################################################################

}}} */

// PLUGIN_INFO {{{
let PLUGIN_INFO =
<VimperatorPlugin>
  <name>translaten</name>
  <name lang="ja">自動一括翻訳</name>
  <description>Automatically translate by clipboard changes</description>
  <description lang="ja">クリップボードの変更を監視して一括翻訳サービスに流し込む</description>
  <version>1.0</version>
  <author mail="anekos@snca.net" homepage="http://d.hatena.ne.jp/nokturnalmortum/">anekos</author>
  <license>new BSD License (Please read the source code comments of this plugin)</license>
  <license lang="ja">修正BSDライセンス (ソースコードのコメントを参照してください)</license>
  <minVersion>2.0pre</minVersion>
  <maxVersion>2.0pre</maxVersion>
  <detail><![CDATA[
    == Activation ==
      >||
        set translaten
      ||<
  ]]></detail>
  <detail lang="ja"><![CDATA[
    == Usage ==
      特に操作は必要ありません
      >||
        set translaten
      ||<
      有効化した後にクリップボードに変化があればその内容を 'http://7go.biz/translation/' に流し込んで翻訳します
    == Link ==
      http://vimperator.g.hatena.ne.jp/nokturnalmortum/20090104/1231070505
  ]]></detail>
</VimperatorPlugin>;
// }}}

(function () {

  const URL = 'http://7go.biz/translation/';

  function TranslaTen () {
    this.handle;
    this.running = false;
  }

  function inTheSite ()
    (~buffer.URL.indexOf(URL))

  TranslaTen.prototype = {
    get clipboard () util.readFromClipboard(),

    open: function () {
      if (inTheSite())
        return;
      if (buffer.URL == 'about:blank')
        return liberator.open(URL, liberator.CURRENT_TAB);
      for (let [number, browser] in Iterator(tabs.browsers)) {
        if (~browser.contentDocument.location.href.indexOf(URL))
          return liberator.modules.tabs.select(number, false);
      }
      liberator.open(URL, liberator.NEW_TAB);
    },

    stop: function () {
      if (this.handle) {
        clearInterval(this.handle);
        this.handle = null;
      }
      this.running = false;
    },

    run: function () {
      let self = this;
      if (this.running)
        return;
      this.running = true;
      this.prev = this.clipboard;
      this.open();
      this.handle = setInterval(
        function () {
          let now = self.clipboard;
          if (now == self.prev)
            return;
          self.prev = now;
          self.open();
          let f = function () { self.elements.textarea.value = now; self.elements.submit.click(); };
          if (inTheSite()) {
            f();
          } else {
            let handle = setInterval(
              function () {
                if (inTheSite() && buffer.loaded) {
                  clearInterval(handle);
                  f();
                }
              },
              200
            );
          }
        },
        100
      );
    },

    elements: {
      get submit () content.document.getElementsByTagName('INPUT')[0],
      get textarea () content.document.getElementsByTagName('TEXTAREA')[0]
    }
  };

  let translaten = new TranslaTen();

  options.add(
    ['translaten'],
    'Automatically translate by clipboard changes',
    'boolean',
    false,
    {
      setter: function (value) {
        if (value)
          translaten.run();
        else
          translaten.stop();
      }
    }
  );

})();

// vim:sw=2 ts=2 et si fdm=marker: