luxon-jsonata
TypeScript icon, indicating that this package has built-in type declarations

0.0.2 • Public • Published

luxon-jsonata

JSONata bindings for the Luxon date library.

NPM version NPM downloads

JSONata is a great tool for transforming JSON data, but the date and time manipulation functions that it provides are lacklustre. This package adds a simple binding for Luxon's DateTime, Duration and Interval objects so they can be used directly in JSONata expressions.

Getting Started

import addLuxon from "luxon-jsonata";
import jsonata from "jsonata";

const expr = jsonata(
  '$Duration.fromISO("P2M").plus({"months":3, "days":10}).toISO()'
);

addLuxon(expr);

console.log(expr.evaluate({}));

// Result is "P5M10D"

Caveats

Not all methods are going to work. In particular, methods that themselves take functions, or require a standard Date object are a bit awkward to use in JSONata. Perhaps in future we can dynamically remove these from the bound objects.

For Luxon member functions that themselves take functions, like Duration.mapUnits, you can assign a Javascript function to the expression that takes the object and performs the operation you need:

const double = (x: Duration) => x.mapUnits((u) => u * 2);

const expr = jsonata(
  "$double($Duration.fromObject({ 'hours': 1, 'minutes': 30 })).toObject()"
);

addLuxon(expr);
expr.assign("double", double);

console.log(expr.evaluate({}));

// Result is { hours: 2, minutes: 60 }

Supporters

This package is supported by SaaSquatch.

License

This project is licensed under the MIT License - see the LICENSE.md file for details

/luxon-jsonata/

    Package Sidebar

    Install

    npm i luxon-jsonata

    Weekly Downloads

    228

    Version

    0.0.2

    License

    MIT

    Unpacked Size

    13.1 kB

    Total Files

    13

    Last publish

    Collaborators

    • andiluo
    • 00salmon
    • locrian
    • jayden-chan
    • zachharrison
    • logvol
    • lisq
    • johanventer
    • dereksiemens
    • squatch-noahwc
    • ianhitchcock