diff options
| author | Robby Russell <robby@planetargon.com> | 2015-09-04 22:30:44 -0700 | 
|---|---|---|
| committer | Robby Russell <robby@planetargon.com> | 2015-09-04 22:30:44 -0700 | 
| commit | 9c08641d7c2aae0c82fa5ad91f94c67b70115ba5 (patch) | |
| tree | 6afc8098784447aad57cf63b188d6039bdb5138f /plugins/frontend-search | |
| parent | 0532860c618aabc02d5dab34391b967e8e4c6272 (diff) | |
| parent | c481c62bc996cfe22417621dfd96c4267eb1e740 (diff) | |
| download | zsh-9c08641d7c2aae0c82fa5ad91f94c67b70115ba5.tar.gz zsh-9c08641d7c2aae0c82fa5ad91f94c67b70115ba5.tar.bz2 zsh-9c08641d7c2aae0c82fa5ad91f94c67b70115ba5.zip | |
Merge pull request #4299 from mcornella/refactor-frontend-search-plugin
Refactor frontend-search plugin
Diffstat (limited to 'plugins/frontend-search')
| -rw-r--r-- | plugins/frontend-search/README.md | 114 | ||||
| -rw-r--r-- | plugins/frontend-search/frontend-search.plugin.zsh | 220 | 
2 files changed, 126 insertions, 208 deletions
| diff --git a/plugins/frontend-search/README.md b/plugins/frontend-search/README.md index b8e96ea4a..d0bc5589f 100644 --- a/plugins/frontend-search/README.md +++ b/plugins/frontend-search/README.md @@ -1,76 +1,60 @@ -## Rationale ## +## Introduction ## -> Searches for your Frontend contents more easier +> Searches for your frontend web development made easier -## Instalation ## +## Installation ## +Open your `~/.zshrc` file and enable the `frontend-search` plugin: -Open your `.zshrc` file and load `frontend-search` plugin +```zsh + +plugins=( ... frontend-search) -```bash -... -plugins=( <your-plugins-list>... frontend-search) -...  ``` -## Commands ## - -All command searches are accept only in format - -* `frontend <search-content> <search-term>` - -The search content are - -* `jquery <api.jquery.com>` -* `mdn <developer.mozilla.org>` -* `compass <compass-style.org>` -* `html5please <html5please.com>` -* `caniuse <caniuse.com>` -* `aurajs <aurajs.com>` -* `dartlang <api.dartlang.org/apidocs/channels/stable/dartdoc-viewer>` -* `lodash <search>` -* `qunit <api.qunitjs.com>` -* `fontello <fontello.com>` -* `bootsnipp <bootsnipp.com>` -* `cssflow <cssflow.com>` -* `codepen <codepen.io>` -* `unheap <www.unheap.com>` -* `bem <google.com/search?as_q=<search-term>&as_sitesearch=bem.info>` -* `smacss <google.com/search?as_q=<search-term>&as_sitesearch=smacss.com>` -* `angularjs <google.com/search?as_q=<search-term>&as_sitesearch=angularjs.org>` -* `reactjs <google.com/search?as_q=<search-term>&as_sitesearch=facebook.github.io/react>` -* `emberjs <emberjs.com>` -* `stackoverflow <stackoverflow.com>` -* `npmjs <npmjs.com>` - - -## Aliases ## - -There are a few aliases presented as well: - -* `jquery` A shorthand for `frontend jquery` -* `mdn` A shorthand for `frontend mdn` -* `compass` A shorthand for `frontend compass` -* `html5please` A shorthand for `frontend html5please` -* `caniuse` A shorthand for `frontend caniuse` -* `aurajs` A shorthand for `frontend aurajs` -* `dartlang` A shorthand for `frontend dartlang` -* `lodash` A shorthand for `frontend lodash` -* `qunit` A shorthand for `frontend qunit` -* `fontello` A shorthand for `frontend fontello` -* `bootsnipp` A shorthand for `frontend bootsnipp` -* `cssflow` A shorthand for `frontend cssflow` -* `codepen` A shorthand for `frontend codepen` -* `unheap` A shorthand for `frontend unheap` -* `bem` A shorthand for `frontend bem` -* `smacss` A shorthand for `frontend smacss` -* `angularjs` A shorthand for `frontend angularjs` -* `reactjs` A shorthand for `frontend reactjs` -* `emberjs` A shorthand for `frontend emberjs` -* `stackoverflow` A shorthand for `frontend stackoverflow` -* `npmjs` A shorthand for `frontend npmjs` +## Usage ## + +You can use the frontend-search plugin in these two forms: + +* `frontend <context> <term> [more terms if you want]` +* `<context> <term> [more terms if you want]` + +For example, these two are equivalent: + +```zsh +$ frontend angularjs dependency injection +$ angularjs dependency injection +``` + +Available search contexts are: + +| context       | URL                                                                      | +|---------------|--------------------------------------------------------------------------| +| angularjs     | `https://google.com/search?as_sitesearch=angularjs.org&as_q=`            | +| aurajs        | `http://aurajs.com/api/#stq=`                                            | +| bem           | `https://google.com/search?as_sitesearch=bem.info&as_q=`                 | +| bootsnipp     | `http://bootsnipp.com/search?q=`                                         | +| caniuse       | `http://caniuse.com/#search=`                                            | +| codepen       | `http://codepen.io/search?q=`                                            | +| compass       | `http://compass-style.org/search?q=`                                     | +| cssflow       | `http://www.cssflow.com/search?q=`                                       | +| dartlang      | `https://api.dartlang.org/apidocs/channels/stable/dartdoc-viewer/dart:`  | +| emberjs       | `http://emberjs.com/api/#stp=1&stq=`                                     | +| fontello      | `http://fontello.com/#search=`                                           | +| html5please   | `http://html5please.com/#`                                               | +| jquery        | `https://api.jquery.com/?s=`                                             | +| lodash        | `https://devdocs.io/lodash/index#`                                       | +| mdn           | `https://developer.mozilla.org/search?q=`                                | +| npmjs         | `https://www.npmjs.com/search?q=`                                        | +| qunit         | `https://api.qunitjs.com/?s=`                                            | +| reactjs       | `https://google.com/search?as_sitesearch=facebook.github.io/react&as_q=` | +| smacss        | `https://google.com/search?as_sitesearch=smacss.com&as_q=`               | +| stackoverflow | `http://stackoverflow.com/search?q=`                                     | +| unheap        | `http://www.unheap.com/?s=`                                              | + +If you want to have another context, open an Issue and tell us!  ## Author @@ -79,5 +63,3 @@ There are a few aliases presented as well:  + <https://plus.google.com/+WilsonMendes>  + <https://twitter.com/willmendesneto>  + <http://github.com/willmendesneto> - -New features comming soon. diff --git a/plugins/frontend-search/frontend-search.plugin.zsh b/plugins/frontend-search/frontend-search.plugin.zsh index e47735a60..2fd5416b3 100644 --- a/plugins/frontend-search/frontend-search.plugin.zsh +++ b/plugins/frontend-search/frontend-search.plugin.zsh @@ -1,155 +1,91 @@ -# frontend from terminal +alias angularjs='frontend angularjs' +alias aurajs='frontend aurajs' +alias bem='frontend bem' +alias bootsnipp='frontend bootsnipp' +alias caniuse='frontend caniuse' +alias codepen='frontend codepen' +alias compass='frontend compass' +alias cssflow='frontend cssflow' +alias dartlang='frontend dartlang' +alias emberjs='frontend emberjs' +alias fontello='frontend fontello' +alias html5please='frontend html5please' +alias jquery='frontend jquery' +alias lodash='frontend lodash' +alias mdn='frontend mdn' +alias npmjs='frontend npmjs' +alias qunit='frontend qunit' +alias reactjs='frontend reactjs' +alias smacss='frontend smacss' +alias stackoverflow='frontend stackoverflow' +alias unheap='frontend unheap'  function frontend() { - -  # no keyword provided, simply show how call methods -  if [[ $# -le 1 ]]; then -    echo "Please provide a search-content and a search-term for app.\nEx:\nfrontend <search-content> <search-term>\n" -    return 1 +  emulate -L zsh + +  # define search context URLS +  typeset -A urls +  urls=( +    angularjs      'https://google.com/search?as_sitesearch=angularjs.org&as_q=' +    aurajs         'http://aurajs.com/api/#stq=' +    bem            'https://google.com/search?as_sitesearch=bem.info&as_q=' +    bootsnipp      'http://bootsnipp.com/search?q=' +    caniuse        'http://caniuse.com/#search=' +    codepen        'http://codepen.io/search?q=' +    compass        'http://compass-style.org/search?q=' +    cssflow        'http://www.cssflow.com/search?q=' +    dartlang       'https://api.dartlang.org/apidocs/channels/stable/dartdoc-viewer/dart:' +    emberjs        'http://emberjs.com/api/#stp=1&stq=' +    fontello       'http://fontello.com/#search=' +    html5please    'http://html5please.com/#' +    jquery         'https://api.jquery.com/?s=' +    lodash         'https://devdocs.io/lodash/index#' +    mdn            'https://developer.mozilla.org/search?q=' +    npmjs          'https://www.npmjs.com/search?q=' +    qunit          'https://api.qunitjs.com/?s=' +    reactjs        'https://google.com/search?as_sitesearch=facebook.github.io/react&as_q=' +    smacss         'https://google.com/search?as_sitesearch=smacss.com&as_q=' +    stackoverflow  'http://stackoverflow.com/search?q=' +    unheap         'http://www.unheap.com/?s=' +  ) + +  # show help for command list +  if [[ $# -lt 2 ]] +  then +      print -P "Usage: frontend %Ucontext%u %Uterm%u [...%Umore%u] (or just: %Ucontext%u %Uterm%u [...%Umore%u])" +      print -P "" +      print -P "%Uterm%u and what follows is what will be searched for in the %Ucontext%u website," +      print -P "and %Ucontext%u is one of the following:" +      print -P "" +      print -P "  angularjs, aurajs, bem, bootsnipp, caniuse, codepen, compass, cssflow," +      print -P "  dartlang, emberjs, fontello, html5please, jquery, lodash, mdn, npmjs," +      print -P "  qunit, reactjs, smacss, stackoverflow, unheap" +      print -P "" +      print -P "For example: frontend npmjs mocha (or just: npmjs mocha)." +      print -P "" +      return 1    fi -  # check whether the search engine is supported -  if [[ ! $1 =~ '(jquery|mdn|compass|html5please|caniuse|aurajs|dartlang|qunit|fontello|bootsnipp|cssflow|codepen|unheap|bem|smacss|angularjs|reactjs|emberjs|stackoverflow|npmjs)' ]]; +  # check whether the search context is supported +  if [[ -z "$urls[$1]" ]]    then -    echo "Search valid search content $1 not supported." -    echo "Valid contents: (formats 'frontend <search-content>' or '<search-content>')" -    echo "* jquery" -    echo "* mdn" -    echo "* compass" -    echo "* html5please" -    echo "* caniuse" -    echo "* aurajs" -    echo "* dartlang" -    echo "* lodash" -    echo "* qunit" -    echo "* fontello" -    echo "* bootsnipp" -    echo "* cssflow" -    echo "* codepen" -    echo "* unheap" -    echo "* bem" -    echo "* smacss" -    echo "* angularjs" -    echo "* reactjs" -    echo "* emberjs" -    echo "* stackoverflow" -    echo "* npmjs" +    echo "Search context \"$1\" currently not supported." +    echo "" +    echo "Valid contexts are:" +    echo "" +    echo "  angularjs, aurajs, bem, bootsnipp, caniuse, codepen, compass, cssflow, " +    echo "  dartlang, emberjs, fontello, html5please, jquery, lodash, mdn, npmjs,  " +    echo "  qunit, reactjs, smacss, stackoverflow, unheap"      echo "" -      return 1    fi -  local url="http://" -  local query="" +  # build search url: +  # join arguments passed with '+', then append to search context URL +  # TODO substitute for proper urlencode method +  url="${urls[$1]}${(j:+:)@[2,-1]}" -  case "$1" in -    "jquery") -      url="${url}api.jquery.com" -      url="${url}/?s=$2" ;; -    "mdn") -      url="${url}developer.mozilla.org" -      url="${url}/search?q=$2" ;; -    "compass") -      url="${url}compass-style.org" -      url="${url}/search?q=$2" ;; -    "html5please") -      url="${url}html5please.com" -      url="${url}/#$2" ;; -    "caniuse") -      url="${url}caniuse.com" -      url="${url}/#search=$2" ;; -    "aurajs") -      url="${url}aurajs.com" -      url="${url}/api/#stq=$2" ;; -    "dartlang") -      url="${url}api.dartlang.org/apidocs/channels/stable/dartdoc-viewer" -      url="${url}/dart-$2" ;; -    "qunit") -      url="${url}api.qunitjs.com" -      url="${url}/?s=$2" ;; -    "fontello") -      url="${url}fontello.com" -      url="${url}/#search=$2" ;; -    "bootsnipp") -      url="${url}bootsnipp.com" -      url="${url}/search?q=$2" ;; -    "cssflow") -      url="${url}cssflow.com" -      url="${url}/search?q=$2" ;; -    "codepen") -      url="${url}codepen.io" -      url="${url}/search?q=$2" ;; -    "unheap") -      url="${url}www.unheap.com" -      url="${url}/?s=$2" ;; -    "bem") -      url="${url}google.com" -      url="${url}/search?as_q=$2&as_sitesearch=bem.info" ;; -    "smacss") -      url="${url}google.com" -      url="${url}/search?as_q=$2&as_sitesearch=smacss.com" ;; -    "angularjs") -      url="${url}google.com" -      url="${url}/search?as_q=$2&as_sitesearch=angularjs.org" ;; -    "reactjs") -      url="${url}google.com" -      url="${url}/search?as_q=$2&as_sitesearch=facebook.github.io/react" ;; -    "emberjs") -      url="${url}emberjs.com" -      url="${url}/api/#stq=$2&stp=1" ;; -    "stackoverflow") -      url="${url}stackoverflow.com" -      url="${url}/search?q=$2" ;; -    "npmjs") -      url="${url}www.npmjs.com" -      url="${url}/search?q=$2" ;; -    *) echo "INVALID PARAM!" -       return ;; -  esac - -  echo "$url" +  echo "Opening $url ..."    open_command "$url" -  } - -# javascript -alias jquery='frontend jquery' -alias mdn='frontend mdn' - -# pre processors frameworks -alias compassdoc='frontend compass' - -# important links -alias html5please='frontend html5please' -alias caniuse='frontend caniuse' - -# components and libraries -alias aurajs='frontend aurajs' -alias dartlang='frontend dartlang' -alias lodash='frontend lodash' - -#tests -alias qunit='frontend qunit' - -#fonts -alias fontello='frontend fontello' - -# snippets -alias bootsnipp='frontend bootsnipp' -alias cssflow='frontend cssflow' -alias codepen='frontend codepen' -alias unheap='frontend unheap' - -# css architecture -alias bem='frontend bem' -alias smacss='frontend smacss' - -# frameworks -alias angularjs='frontend angularjs' -alias reactjs='frontend reactjs' -alias emberjs='frontend emberjs' - -# search websites -alias stackoverflow='frontend stackoverflow' -alias npmjs='frontend npmjs' | 
