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,
[
{
series: { number: 1, of: 1 },
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,
[
{
series: { number: 1, of: 1 },
element: { number: 1, of: 2 }
},
{
series: { number: 2, of: 2 },
element: { number: 2, of: 3 }
}
]
)
)