abstract-numbering

3.0.0 • Public • Published

abstract-numbering

JSON schema for abstract numberings of hierarchical document parts

Abstract numberings express how hierarchical document parts like outline sections, headings, or list items should be numbered, without rendering those numberings in any particular way. Other modules in the *-numbering family convert abstract numberings to strings in particular styles, like "1.2" or "1(a)(v)".

Each abstract numbering is an array of numbering components, describing first the top-most "parent" of the relevant document part and continuing down to the document part to be numbered itself.

Here is an example of a numbering for the first of two elements at the very top level of a document:

var schema = require('abstract-numbering')
var ajv = new (require('ajv'))()
var assert = require('assert')
 
assert(
  ajv.validate(
    schema,
    [
      {
        // More on series later.
        series: { number: 1, of: 1 },
        // "Element number 1 of 2"
        element: { number: 1, of: 2 }
      }
    ]
  )
)

Note that positions begin with one, not zero:

assert(
  !ajv.validate(
    schema,
    [
      {
        series: { number: 1, of: 1 },
        element: { number: 0, of: 1 }
      }
    ]
  )
)

Series are used to describe situations when numbering restarts in the middle of a document part. Consider the following structure:

Heading 1. First Major Heading
 
  1. Apples
  2. Oranges
  3. Grapes
 
  1. Lions
  2. Tigers
  3. Bears
 
Heading 2. Second Major Heading

The abstract numbering for the "Tigers" list item would be:

assert(
  ajv.validate(
    schema,
    [
      // The component for "First Major Heading"
      {
        // Numbering of headings does not restart, so there is one series.
        series: { number: 1, of: 1 },
        element: { number: 1, of: 2 }
      },
      // The component for "Tigers"
      {
        // There are two series here, the first for fruit and animals.
        // "Tigers" is in the second series.
        series: { number: 2, of: 2 },
        // There are three total elements, of which "Tigers" is second.
        element: { number: 2, of: 3 }
      }
    ]
  )
)

Package Sidebar

Install

npm i abstract-numbering

Weekly Downloads

1

Version

3.0.0

License

BlueOak-1.0.0

Unpacked Size

5.21 kB

Total Files

4

Last publish

Collaborators

  • kemitchell