npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@compute.ts/date

v2.0.3

Published

Provide date operators for the computeTS package

Downloads

19

Readme

Presentation

The engine is based on incremental computation algorithms. When a calculation is submitted to the engine, all the computed values are memorized. So, if you change some variable and query an evaluation, the engine is able to compute the result very fast because it recomputes only what has changed.

compute.ts

Libraries

The project provides several libraries that each comes with dozens of operators. Please note the cross-compatibility of the libraries.

Imports

Typescript

import {/* required operators */} from '@compute.ts/date';

Javascript

const {/* required operators */} = require('@compute.ts/date');

Operators

date

date(value) ➜ xdate

date() ➜ xdate

The boolean operator allows you to create a boolean expression which evals to the given value. If no value is provided the expression is a variable of the model

import {date} from "@compute.ts/date"

const x = date(new Date('05/08/1992'));
x.affect(new Date('16/03/1996'))

parseDate

parseDate(xstring) ➜ xdate

The parseDate operator allows you to create a date expression which evals to the given value.

import {parseDate} from "@compute.ts/date"

const x = parseDate('April 1, 1992');

const value = x.eval();

isSame

isSame(xdate, ydate) ➜ zboolean
xdate.isSame(ydate) ➜ zboolean

The isSame operator allows to create a boolean expression which evals the true if x is the same date as y

import {date, isSame} from "@compute.ts/date"

const x = date();  
const y = date();  
const z = isSame(x, y) | x.isSame(y);

const value = z.eval();

isNotSame

isNotSame(xdate, ydate) ➜ zboolean
xdate.isNotSame(ydate) ➜ zboolean

The isNotSame operator allows to create a boolean expression which evals the true if x is not the same date as y

import {date, isNotSame} from "@compute.ts/date"

const x = date();  
const y = date();  
const z = isNotSame(x, y) | x.isNotSame(y);

const value = z.eval();

setDate

setDate(xdate, ynumber) ➜ zdate
xdate.setDate(ynumber) ➜ zdate

The setDay operator allows to create a date expression which evals to x where the date has been changed

import {number} from "@compute.ts/number";  
import {date, setDate} from "@compute.ts/date"

const x = date();  
const y = number();  
const z = setDate(x, y) | x.setDate(y);

const value = z.eval();

setMonth

setMonth(xdate, ynumber) ➜ zdate
xdate.setMonth(ynumber) ➜ zdate

The setMonth operator allows to create a date expression which evals to x where the month has been changed

import {number} from "@compute.ts/number";  
import {date, setMonth} from "@compute.ts/date"

const x = date();  
const y = number();  
const z = setMonth(x, y) | x.setMonth(y);

const value = z.eval();

setYear

setYear(xdate, ynumber) ➜ zdate
xdate.setYear(ynumber) ➜ zdate

The setYear operator allows to create a date expression which evals to x where the year has been changed

import {number} from "@compute.ts/number";  
import {date, setYear} from "@compute.ts/date"

const x = date();  
const y = number();  
const z = setYear(x, y) | x.setYear(y);

const value = z.eval();

addDay

addDay(xdate, ynumber) ➜ zdate
xdate.addDay(ynumber) ➜ zdate

The addDay operator allows to create a date expression which evals the date x but y day(s) later

import {number} from "@compute.ts/number";  
import {date, addDay} from "@compute.ts/date"

const x = date();  
const y = number();  
const z = addDay(x, y) | x.addDay(y);

const value = z.eval();

addMonth

addMonth(xdate, ynumber) ➜ zdate
xdate.addMonth(ynumber) ➜ zdate

The addMonth operator allows to create a date expression which evals the date x but y month(s) later

import {number} from "@compute.ts/number";  
import {date, addMonth} from "@compute.ts/date"

const x = date();  
const y = number();  
const z = addMonth(x, y) | x.addMonth(y);

const value = z.eval();

addYear

addYear(xdate, ynumber) ➜ zdate
xdate.addYear(ynumber) ➜ zdate

The addYear operator allows to create a date expression which evals the date x but y year(s) later

import {number} from "@compute.ts/number";  
import {date, addYear} from "@compute.ts/date"

const x = date();  
const y = number();  
const z = addYear(x, y) | x.addYear(y);

const value = z.eval();

minusDay

minusDay(xdate, ynumber) ➜ zdate
xdate.minusDay(ynumber) ➜ zdate

The minusDay operator allows to create a date expression which evals the y day(s) before x

import {number} from "@compute.ts/number";  
import {date, minusDay} from "@compute.ts/date"

const x = date();  
const y = number();  
const z = minusDay(x, y) | x.minusDay(y);

const value = z.eval();

minusMonth

minusMonth(xdate, ynumber) ➜ zdate
xdate.minusMonth(ynumber) ➜ zdate

The minusMonth operator allows to create a date expression which evals the y month(s) before x

import {number} from "@compute.ts/number";  
import {date, minusMonth} from "@compute.ts/date"

const x = date();  
const y = number();  
const z = minusMonth(x, y) | x.minusMonth(y);

const value = z.eval();

²


minusYear

minusYear(xdate, ynumber) ➜ zdate
xdate.minusYear(ynumber) ➜ zdate

The minusYear operator allows to create a date expression which evals the y year(s) before x

import {number} from "@compute.ts/number";  
import {date, minusYear} from "@compute.ts/date"

const x = date();  
const y = number();  
const z = minusYear(x, y) | x.minusYear(y);

const value = z.eval();

getDay

getDay(xdate) ➜ ynumber
xdate.getDay() ➜ ynumber

The getDay operator allows to create a date expression which evals the date of x (x ∈ [0, 6])

import {date, getDay} from "@compute.ts/date"

const x = date();  
const y = getDay(x) | x.getDay();

const value = y.eval();

getDate

getDate(xdate) ➜ ynumber
xdate.getDate() ➜ ynumber

The getDate operator allows to create a date expression which evals the date of x (x ∈ [0, 30])

import {date, getDate} from "@compute.ts/date"

const x = date();  
const y = getDate(x) | x.getDate();

const value = y.eval();

getMonth

getMonth(xdate) ➜ ynumber
xdate.getMonth() ➜ ynumber

The getMonth operator allows to create a date expression which evals the month of x (x ∈ [0, 11])

import {date, getMonth} from "@compute.ts/date"

const x = date();  
const y = getMonth(x) | x.getMonth();

const value = y.eval();

getYear

getYear(xdate) ➜ ynumber
xdate.getYear() ➜ ynumber

The getYear operator allows to create a date expression which evals the year of x

import {date, getYear} from "@compute.ts/date"

const x = date();  
const y = getYear(x) | x.getYear();

const value = y.eval();

getWeek

getWeek(xdate) ➜ ynumber
xdate.getWeek() ➜ ynumber

The getWeek operator allows to create a date expression which evals the week of x (x ∈ [0, 51])

import {date, getWeek} from "@compute.ts/date"

const x = date();  
const y = getWeek(x) | x.getWeek();

const value = y.eval();

toString

toString(xdate) ➜ zstring
xdate.toString() ➜ zstring

import {date, toString} from "@compute.ts/date"

const x = date();  
const y = toString(x) | x.toString();

const value = y.eval();

isLeapYear

isLeapYear(xdate) ➜ yboolean
xdate.isLeapYear() ➜ yboolean

The isLeapYear operator allows to create a boolean expression which evals the true if x a leap year

import {date, isLeapYear} from "@compute.ts/date"

const x = date();  
const y = isLeapYear(x) | x.isLeapYear();

const value = y.eval();

isWeekend

isWeekend(xdate) ➜ yboolean
xdate.isWeekend() ➜ yboolean

The isWeekEnd operator allows to create a boolean expression which evals the true if x a weekend day

import {date, isWeekend} from "@compute.ts/date"

const x = date();  
const y = isWeekend(x) | x.isWeekEnd();

const value = y.eval();

isWeek

isWeek(xdate) ➜ yboolean
xdate.isWeek() ➜ yboolean

The isWeek operator allows to create a boolean expression which evals the true if x is a week day

import {date, isWeek} from "@compute.ts/date"

const x = date();  
const y = isWeek(x) | x.isWeek();

const value = y.eval();

isMonday

isMonday(xdate) ➜ yboolean
xdate.isMonday() ➜ yboolean

The isMonday operator allows to create a boolean expression which evals the true if x is monday

import {date, isMonday} from "@compute.ts/date"

const x = date();  
const y = isMonday(x) | x.isMonday();

const value = y.eval();

isTuesday

isTuesday(xdate) ➜ yboolean
xdate.isTuesday() ➜ yboolean

The isTuesday operator allows to create a boolean expression which evals the true if x is in tuesday

import {date, isTuesday} from "@compute.ts/date"

const x = date();  
const y = isTuesday(x) | x.isTuesday();

const value = y.eval();

isWednesday

isWednesday(xdate) ➜ yboolean
xdate.isWednesday() ➜ yboolean

The isWednesday operator allows to create a boolean expression which evals the true if x is in wednesday

import {date, isWednesday} from "@compute.ts/date"

const x = date();  
const y = isWednesday(x) | x.isWednesday();

const value = y.eval();

isThursday

isThursday(xdate) ➜ yboolean
xdate.isThursday() ➜ yboolean

The isThursday operator allows to create a boolean expression which evals the true if x is thursday

import {date, isThursday} from "@compute.ts/date"

const x = date();  
const y = isThursday(x) | x.isThursday();

const value = y.eval();

isFriday

isFriday(xdate) ➜ yboolean
xdate.isFriday() ➜ yboolean

The isFriday operator allows to create a boolean expression which evals the true if x is friday

import {date, isFriday} from "@compute.ts/date"

const x = date();  
const y = isFriday(x) | x.isFriday();

const value = y.eval();

isSaturday

isSaturday(xdate) ➜ yboolean
xdate.isSaturday() ➜ yboolean

The isSaturday operator allows to create a boolean expression which evals the true if x is in saturday

import {date, isSaturday} from "@compute.ts/date"

const x = date();  
const y = isSaturday(x) | x.isSaturday();

const value = y.eval();

isSunday

isSunday(xdate) ➜ yboolean
xdate.isSunday() ➜ yboolean

The isSunday operator allows to create a boolean expression which evals the true if x is sunday

import {date, isSunday} from "@compute.ts/date"

const x = date();  
const y = isSunday(x) | x.isSunday();

const value = y.eval();

isJanuary

isJanuary(xdate) ➜ yboolean
xdate.isJanuary() ➜ yboolean

The isJanuary operator allows to create a boolean expression which evals the true if x is in january

import {date, isJanuary} from "@compute.ts/date"

const x = date();  
const y = isJanuary(x) | x.isJanuary();

const value = y.eval();

isFebuary

isFebuary(xdate) ➜ yboolean
xdate.isFebuary() ➜ yboolean

The isFebuary operator allows to create a boolean expression which evals the true if x is in febuary

import {date, isFebuary} from "@compute.ts/date"

const x = date();  
const y = isFebuary(x) | x.isFebuary();

const value = y.eval();

isMarch

isMarch(xdate) ➜ yboolean
xdate.isMarch() ➜ yboolean

The isMarch operator allows to create a boolean expression which evals the true if x is in march

import {date, isMarch} from "@compute.ts/date"

const x = date();  
const y = isMarch(x) | x.isMarch();

const value = y.eval();

isApril

isApril(xdate) ➜ yboolean
xdate.isApril() ➜ yboolean

The isApril operator allows to create a boolean expression which evals the true if x is in april

import {date, isApril} from "@compute.ts/date"

const x = date();  
const y = isApril(x) | x.isApril();

const value = y.eval();

isMay

isMay(xdate) ➜ yboolean
xdate.isMay() ➜ yboolean

The isMay operator allows to create a boolean expression which evals the true if x is in may

import {date, isMay} from "@compute.ts/date"

const x = date();  
const y = isMay(x) | x.isMay();

const value = y.eval();

isJune

isJune(xdate) ➜ yboolean
xdate.isJune() ➜ yboolean

The isJune operator allows to create a boolean expression which evals the true if x is in june

import {date, isJune} from "@compute.ts/date"

const x = date();  
const y = isJune(x) | x.isJune();

const value = y.eval();

isJuly

isJuly(xdate) ➜ yboolean
xdate.isJuly() ➜ yboolean

The isJuly operator allows to create a boolean expression which evals the true if x is in july

import {date, isJuly} from "@compute.ts/date"

const x = date();  
const y = isJuly(x) | x.isJuly();

const value = y.eval();

isAugust

isAugust(xdate) ➜ yboolean
xdate.isAugust() ➜ yboolean

The isAugust operator allows to create a boolean expression which evals the true if x is in august

import {date, isAugust} from "@compute.ts/date"

const x = date();  
const y = isAugust(x)| x.isAugust();

const value = y.eval();

isSeptember

isSeptember(xdate) ➜ yboolean
xdate.isSeptember() ➜ yboolean

The isSeptember operator allows to create a boolean expression which evals the true if x is in september

import {date, isSeptember} from "@compute.ts/date"

const x = date();  
const y = isSeptember(x) | x.isSeptember();

const value = y.eval();

isOctober

isOctober(xdate) ➜ yboolean
xdate.isOctober() ➜ yboolean

The isOctober operator allows to create a boolean expression which evals the true if x is in october

import {date, isOctober} from "@compute.ts/date"

const x = date();  
const y = isOctober(x) | x.isOctober();

const value = y.eval();

isNovember

isNovember(xdate) ➜ yboolean
xdate.isNovember() ➜ yboolean

The isNovember operator allows to create a boolean expression which evals the true if x is in november

import {date, isNovember} from "@compute.ts/date"

const x = date();  
const y = isNovember(x) | x.isNovember();

const value = y.eval();

isDecember

isDecember(xdate) ➜ yboolean
xdate.isDecember() ➜ yboolean

The isDecember operator allows to create a boolean expression which evals the true if x is in december

import {date, isDecember} from "@compute.ts/date"

const x = date();  
const y = isDecember(x) | x.isDecember();

const value = y.eval();

isBefore

isBefore(xdate, ydate) ➜ zboolean
xdate.isBefore(ydate) ➜ zboolean

The isBefore operator allows to create a boolean expression which evals the true if x is before y

import {date, isBefore} from "@compute.ts/date"

const x = date();  
const y = date();  
const z = isBefore(x, y) | x.isBefore(y);

const value = z.eval();

isBeforeOrSame

isBeforeOrSame(xdate, ydate) ➜ zboolean
xdate.isBeforeOrSame(ydate) ➜ zboolean

The isBeforeOrSame operator allows to create a boolean expression which evals the true if x is before or same as y

import {date, isBeforeOrSame} from "@compute.ts/date"

const x = date();  
const y = date();  
const z = isBeforeOrSame(x, y) | x.isBeforeOrSame(y);

const value = z.eval();

isAfter

isAfter(xdate, ydate) ➜ zboolean
xdate.isAfter(ydate) ➜ zboolean

The isAfter operator allows to create a boolean expression which evals the true if x is after y

import {date, isAfter} from "@compute.ts/date"

const x = date();  
const y = date();  
const z = isAfter(x, y) | x.isAfter(y);

const value = z.eval();

isAfterOrSame

isAfterOrSame(xdate, ydate) ➜ zboolean
xdate.isAfterOrSame(ydate) ➜ zboolean

The isAfterOrSame operator allows to create a boolean expression which evals the true if x is after or same as y

import {date, isAfterOrSame} from "@compute.ts/date"

const x = date();  
const y = date();  
const z = isAfterOrSame(x, y) | x.isAfterOrSame(y);

const value = z.eval();

About the author

I am a software developer with 4 years of project specializing in the development of web solutions. Digital Nomad, I work while traveling. After 3 years into the french industry, I've started to work as a freelance software architect or fullstack developer.

Based on state-of-the-art web technologies, I offer you to architect & develop the best version of your project. My experience in the web app development assure you to build a nice looking, performant and stable product.

Minimalist, I like to travel, to meet people, learn new things and handmade stuff. Scuba & sky diving licenced. I like also hamburgers, Kinder chocolate and crepes. Karate black belt.

https://berthellemy.com/