![Oracle Drags Its Feet in the JavaScript Trademark Dispute](https://cdn.sanity.io/images/cgdhsj6q/production/919c3b22c24f93884c548d60cbb338e819ff2435-1024x1024.webp?w=400&fit=max&auto=format)
Security News
Oracle Drags Its Feet in the JavaScript Trademark Dispute
Oracle seeks to dismiss fraud claims in the JavaScript trademark dispute, delaying the case and avoiding questions about its right to the name.
@citation-js/plugin-bibtex
Advanced tools
Plugin for BibTeX formats for Citation.js.
npm install @citation-js/plugin-bibtex
Register by importing the package:
require('@citation-js/plugin-bibtex')
Formats and other features added by this plugin.
This plugin adds input and output support for BibTeX,
both in text form and as a JSON representation. Input types are called @bibtex/text
and @bibtex/entry+object
, output format is bibtex
. The output has format
dictionary support.
This plugin adds input and output support for BibLaTeX,
both in text form and as a JSON representation. Input types are called @biblatex/text
and @biblatex/entry+object
, output format is biblatex
. The output has format
dictionary support.
This plugin adds input and output support for Bib.TXT,
a simplified and modernised version of BibTeX. Input types are called @bibtxt/text
and @biblatex/entry+object
, output format is bibtxt
. The output has format
dictionary support.
Configuration can be accessed like the following:
const { plugins } = require('@citation-js/core')
const config = plugins.config.get('@bibtex')
Property | Values [default] | Description |
---|---|---|
config.parse.strict | true , [false ] | When true, entries are checked for required fields. |
config.parse.sentenceCase | 'always' , 'english' , ['never' ] | Convert titles to sentence case when parsing. |
config.format.useIdAsLabel | true , [false ] | Use the entry ID as the label instead of generating one. |
Entry type mappings between BibLaTeX or BibTeX and CSL-JSON are available through
config.types.biblatex
and config.types.bibtex
. In both cases, the Bib(La)TeX
mappings are in the source
field and the reverse mappings in the target
field.
config.types.biblatex.source.inproceedings = 'paper-conference'
config.types.biblatex.target['paper-conference'] = 'inproceedings'
The list of required fields for each type for BibLaTeX and BibTeX is available
under config.required.biblatex
and config.required.bibtex
respectively. In
both cases, the list consists of strings for required fields and arrays for sets
of fields where at least one should be present (year OR date for BibLaTeX for
example).
config.required.biblatex.book = [
'title',
['author', 'editor'],
'publisher',
['year', 'date']
]
Field types (used for both BibLaTeX and BibTeX) are available through config.constants.fieldTypes
.
This returns an object mapping Bib(La)TeX field names to an array containing a
field type and a value type. The former is either field
, list
(" and "
-delimited),
or separated
(comma-delimited). As for the latter:
Value type | Description |
---|---|
literal | Normal text or numeric content |
title | Like literal but can be affected by config.parse.sentenceCase |
name | A personal or organizational name |
date | An EDTF Level 1 date |
verbatim | Unaltered text (no expansion of commands, etc.) |
uri | Same as verbatim but if needed the URL is encoded |
other | No special behaviour, treated like literal |
// Add `daturl` for dat:// URLs
config.constants.fieldTypes.daturl = ['field', 'uri']
// Do not treat `publisher` as a list
config.constants.fieldTypes.publisher = ['field', 'literal']
config.constants.diacritics
maps commands (\"
) to diacriticsconfig.constants.commands
maps commands (\textinterrobangdown
) to general unicode characters (⸘
)config.constants.ligatures
maps non-command character sequences (---
, ~
, etc.) to their replacements (emdash, no-breaking space, etc.)config.constants.ligaturePattern
is a RegExp that recognizes the ligatures mapped aboveconfig.constants.mathScripts
maps superscript and subscript (in properties ^
and _
respectively)config.constants.diacritics['"'] = '\u0308'
config.constants.commands.textinterrobangdown = '⸘'
config.constants.ligatures = {
'---': '\u2014',
'~': '\u00A0'
}
config.constants.ligaturePattern = /---|~/g // Don't forget the (g)lobal flag
config.constants.mathScripts = {
'^': { '1': '¹' },
'_': { '1': '₁' }
}
config.constants.formattingEnvs
maps environment commands to formattingconfig.constants.formattingCommands
maps regular commands to formattingconfig.constants.mathScriptFormatting
maps ^
and _
to resp. super- and subscriptconfig.constants.formatting
maps formatting to HTML (though RTF or Markdown could be substituted)config.constants.formattingEnvs.bf = 'bold'
config.constants.formattingCommands.textbf = 'bold'
config.constants.mathScriptFormatting['^'] = 'superscript'
config.constants.formatting = {
bold: ['<b>', '</b>'],
superscript: ['<sup>', '</sup>']
}
The object config.constants.argumentCommands
maps command names to functions
handling them. This does not include commands used above. Braced arguments are
parsed automatically based on how many arguments the function takes. It does not
support optional arguments (i.e. those in square braces) yet.
config.constants.argumentCommands.href = function (url, displayText) {
// Note: <a> tags are not supported by CSL so watch out if you use this
return `<a href="${url}">${displayText}</a>`
}
// You can also use it to replace commands that produce text
config.constants.argumentCommands.LaTeX = () => 'LaTeX'
The array config.constants.sentenceCaseLanguages
affects which languages are
eligible for sentence-casing when config.parse.sentenceCase
is set to 'english'
.
All entries should be lowercase.
config.constants.sentenceCaseLanguages = [
'english',
'en-us',
'en-gb'
]
The object config.constants.defaultStrings
determines which strings are defined
by default.
config.constants.defaultStrings.larsgw = "Willighagen, Lars G"
FAQs
Plugin for BibTeX formats for Citation.js
The npm package @citation-js/plugin-bibtex receives a total of 8,942 weekly downloads. As such, @citation-js/plugin-bibtex popularity was classified as popular.
We found that @citation-js/plugin-bibtex demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Oracle seeks to dismiss fraud claims in the JavaScript trademark dispute, delaying the case and avoiding questions about its right to the name.
Security News
The Linux Foundation is warning open source developers that compliance with global sanctions is mandatory, highlighting legal risks and restrictions on contributions.
Security News
Maven Central now validates Sigstore signatures, making it easier for developers to verify the provenance of Java packages.