citeproc-plus
Citeproc-js + citation styles bundled
This is an early version so be aware that the API may change. The point of this package is to bundle citeproc-js with the localizations and the 2000+ independent styles from https://github.com/citation-style-language/. You can try a demo at https://fiduswriter.github.io/citeproc-plus/.
This package is meant for those who want to use citeproc-js, but don't want to have to deal with retrieving and storing citation styles and localizations from other places on the web.
How to use
-
Install it from npm together with your other dependencies:
npm install citeproc-plus --save
-
Install a plugin for your bundler to handle resources other than JavaScript files as separate files, for example Webpack's File Loader. Configure it so that it handles files with the ending .csljson
. In the case of Webpack's File Loader, that would be a webpack.config.js with setting such as:
module.exports = {
mode: "production",
output: {
publicPath: "dist/",
},
module: {
rules: [
{
test: /\.(csljson)$/i,
use: [
{
loader: 'file-loader',
},
],
},
],
},
};
- Import
CSL
and styles
in your app:
import {CSL, styles} from "citeproc-plus"
styles
is a dictionary of all the available styles with their title
and styleId
. To create an ordered list of all available styles, do:
dom.innerHTML =
`<select>${
Object.entries(styles).sort(
(a,b) => (a[1] > b[1] ? 1 : -1)
).map(
([key, value]) => `<option value="${key}">${value}</option>`
).join('')
}</select>`
- Where in citeproc-js you would have called:
const citeproc = new CSL.Engine(sys, style, lang, forceLang)
Do instead:
const csl = new CSL()
const citeproc = await csl.getEngine(
sys,
styleId,
lang,
forceLang
)
or if you prefer the then()
-function, do:
const csl = new CSL()
let citeproc
csl.getEngine(
sys,
styleId,
lang,
forceLang
).then(
engine => citeproc = engine
)
Notice that you only need one CSL instance with which you can create any number of citeproc instances with different styles, languages and sys objects connected to them.
Notice also that the method to get an engine is asynchronous as it potentially has to download files from your static files storage.
Advanced uses
JATS
There is an extra style with the styleId jats
that can be used as part of conversion packages. This style is not listed among the list of styles as it is not meant for human consumption.
Manipulating a style in JavaScript
If instead of the styleId you hand it a preprocessed style object it will use it as well without caching.
Importing CSL
Notice that the styles in this package are not stored in the citation style language (CSL) directly. There is a tool to convert CSL to the JSON of preprocessed style object that is needed here.