/glossarizer

A jquery plugin to automatically markup glossary terms on a page and display definitions as a tooltip.

Primary LanguageJavaScript

Glossarizer

  • Reads glossary list from json file or object
  • Automatically searches for and marks up glossary terms found on a page with attributes
  • Supports terms exclusion
  • Supports multiple terms
  • Replaces TextNodes only
  • No involvement from authors

What it is

A small jquery plugin that automatically marks up glossary terms on a page. The glossary terms can be read from an external json file. When users hover over the link (dashed line), they get to see the glossary definition as a tooltip.

Tooltips are optional, you can use any third-party tooltips.

Why use it

If you are writing content that uses specialist vocabulary or many acronyms you need to mark up content with tags so that the definitions can show up as a tooltip. But as authors you really should focus on the writing and not on the marking up content. This is where Glossarizer can help. It automatically marks up the glossary terms on a page by reading off a glossary list.

How to use it

1. Prepare your Glossary Data in a JSON File/Object

[
  {
    "term": "death, !death star",
    "description": "Cessation of all biological functions"
  },
  {
    "term": "genetic, !genetic testing, genes, DNA",
    "description": "relating to genes or heredity: genetic abnormalities."
  },
  {
    "term" : "creature",
    "description" : "A living being, especially an animal"
  },
  {
    "term" : "subdue",
    "description" : "To conquer and subjugate; vanquish"
  },
  {
    "term" : "replenish",
    "description" : "To fill or make complete again; add a new stock or supply to"
  },
  {
    "term" : "whales",
    "description" : "An inlet of the Ross Sea in the Ross Ice Shelf of Antarctica. It has been used as a base for Antarctic expeditions since 1911."
  }
]

2. Initialize the plugin

<script src="//ajax.googleapis.com/ajax/libs/jquery/1/jquery.min.js"></script>
<script src="tooltip/tooltip.js"></script>
<script src="jquery.glossarize.js"></script>
<script>

$(function(){

  $('.content').glossarizer({
    sourceURL: 'glossary.json',
    callback: function(){
      
      // Callback fired after glossarizer finishes its job
      
      new tooltip();

    }
  });


});

</script>

Plugin Options

defaults = {
  sourceURL     : '', 
  replaceTag    : 'abbr', 
  lookupTagName : 'p, ul, a',
  callback      : null,
  replaceOnce   : true,
  replaceClass  : glossarizer_replaced,
  caseSensitive : false
}

Options

Attribute Options Default Description
sourceURL string `` JSON file url
replaceTag string abbr html tag used to replace the matching term
lookupTagName string p, ul, a Which nodes to search
replaceOnce boolean true Replace once in a textnode?
replaceClass string glossarizer_replaced Class name of the replaceTag
callback method null Completed callback
caseSensitive boolean false Match case sensitive

External Methods

Attribute Options Example
destroy method $('.content').glossarizer('destroy');