@eluvio/elv-js-helpers
v6.3.3
Published
A collection of Javascript helper functions used by several Eluvio libraries.
Downloads
111
Readme
elv-js-helpers
A collection of Javascript helper functions used by several Eluvio libraries.
THIS LIBRARY IS CURRENTLY IN PRE-RELEASE: FUNCTION NAMES AND SIGNATURES ARE STILL IN FLUX.
API Documentation
https://eluv-io.github.io/elv-js-helpers/api.html
Installation
Install from NPM:
npm install --save @eluvio/elv-js-helpers
Usage
It is possible to import individual items or the entire library, depending on whether code size is a concern.
Entire library (CommonJS)
// namespace entire suite to a const
const H = require('@eluvio/elv-js-helpers')
console.log(H.Datetime.now())
// create references to particular items in order to avoid needing to use H.Category prefix
const { etaDurStr, etaTimeStr } = H.Datetime
const {_boundLowerErrMsg} = H.ModelAssertion
// Get reference to 1 category (note that this will still wind up incuding the entire package)
const { Datetime } = require('@eluvio/elv-js-helpers')
console.log(Datetime.now())
Entire library (JS Modules)
// namespace entire suite to H
import H from '@eluvio/elv-js-helpers'
// create references to particular items in order to avoid needing to use H. prefix
const { etaDurStr, etaTimeStr } = H.Datetime
const {_boundLowerErrMsg} = H.ModelAssertion
// Note that the following syntax still causes entire library to be bundled into your project
import { Datetime } from '@eluvio/elv-js-helpers'
Individual items (CommonJS)
Importing individual items will minimize code size.
// require in each item directly
const etaDurStr = require('@eluvio/elv-js-helpers/Datetime/etaDurStr')
const etaTimeStr = require('@eluvio/elv-js-helpers/Datetime/etaTimeStr')
const _boundLowerErrMsg = require('@eluvio/elv-js-helpers/ModelAssertion/_boundLowerErrMsg')
Individual items (JS Modules)
// import in each item directly
import etaDurStr from '@eluvio/elv-js-helpers/Datetime/etaDurStr'
import etaTimeStr from '@eluvio/elv-js-helpers/Datetime/etaTimeStr'
import _boundLowerErrMsg from '@eluvio/elv-js-helpers/ModelAssertion/_boundLowerErrMsg'
Entire library (browser)
Although not recommended, it is also possible to import the entire library directly into a browser via a <script>
tag
pointing to a copy of either dist/elv-js-helpers.js
or dist/elv-js-helpers.min.js
. This will create a variable named
ElvJsHelpers
in the global namespace. There is no support for importing individual items via a <script>
tag. (It
is expected that browser apps would be built using a bundling tool like Webpack/Rollup/Parcel)
<!-- Import entire library as ElvJsHelper -->
<script src="elv-js-helpers.js"></script>
<script type="application/javascript">
console.log('System locale is: ' + ElvJsHelpers.Datetime.sysLocale())
console.log('_boundLowerErrMsg(0,true)= "' + ElvJsHelpers.ModelAssertion._boundLowerErrMsg(0,true) + '"')
</script>
Conventions
Source Files (src/CATEGORY/*.js
)
- Each function (or exported constant) has its own source file.
- Each source file exports exactly 1 item.
- Files have the same case-sensitive name as the function or constant it defines (with
.js
extension added) - Files are stored in subdirectories of
src/
according to category (1 category per subdirectory)
Naming / Capitalization
Abbreviations
- Names tend to err on the side of not abbreviating, prioritizing clarity over brevity:
conditionalCheck
notcondlChk
(function)sysTimezone
notsysTZ
(function)
- When an item name would be cumbersome or excessively long otherwise, abbreviations and/or acronyms are used for words where the meaning remains reasonably clear and obvious:
assertPropMaxGTEMin
notassertPropertyMaximumGreaterThanOrEqualToMinimum
(function)defNonEmptyArrModel
notdefineNonEmptyArrayModel
(function)RE_UTC_TIMESTAMP
notREGEXP_UNIVERSAL_TIME_COORDINATED_TIMESTAMP
(constant)
- A few abbreviations stretch the "reasonably clear and obvious" condition:
ADT
notAlgebraicDataType
(category)resultToPOJO
notresultToPlainOldJavascriptObject
(function)
Capitalization (general)
- Compound words that are widely treated as single words do not capitalize the second word:
Datetime
notDateTime
(category)sysTimezone
notsysTimeZone
(function)RE_UTC_TIMESTAMP
notRE_UTC_TIME_STAMP
(constant)
- Acronyms are kept all the same case, either upper or lower depending on kind of item and position within name:
ADT
notAdt
(category)parseUTCStr
notparseUtcStr
(function)utcStrToDate
notuTCStrToDate
(function)etaDurStr
noteTADurStr
(function)
- For greater legibility, the prefix "non" is treated as a word:
NonBlankStrModel
notNonblankStrModel
(model)wrapNonArray
notwrapNonarray
(function)
Capitalization (by item type)
- ADTs: PascalCase (
List
,Ok
) - Categories: PascalCase (
ModelAssertion
,ModelFactory
) - Constants: UPPER_SNAKE_CASE (
RE_UTC_TIMESTAMP
)- Regular expression names start with "RE_"
- Models: PascalCase (
NonBlankStrModel
)- Model names always end with "Model"
- Functions: camelCase (
mapWithIndex
,resultUnwrap
)- Note that ADTs and Models are actually functions but are named using PascalCase because they are used more like classes.
- ModelFactory names always start with "def" and end with "Model" (
defArrModel
,defObjModel
)
Private Items
- Have names beginning with underscore (
_boundLowerErrMsg
) - Are not truly private, they are available for use but are filtered from the documentation page unless
Show private
is checked. - Contain internal code shared by more than one function but considered too specialized to be useful outside the package