Skip to main content Link Search Menu Expand Document (external link)

Datum overview

Added in v2.0.0

Represents a value of one of four possible types (a disjoint union).

An instance of Datum is either an instance of Initial, Pending, Refresh or Replete.

A common use of Datum is as a container for dealing with refreshable data values. In this usage, the initial value is Initial. Pending represents in flight activity. Refresh indicates that data exists but is being refreshed, and Replete meands data exists and is not being refreshed.


Table of contents


utils

Alt

Signature

export declare const Alt: Alt1<'@nll/datum/Datum'>

Added in v3.5.0

Alternative

Signature

export declare const Alternative: Alternative1<'@nll/datum/Datum'>

Added in v3.5.0

Applicative

Signature

export declare const Applicative: Applicative1<'@nll/datum/Datum'>

Added in v3.5.0

Apply

Signature

export declare const Apply: Apply1<'@nll/datum/Datum'>

Added in v3.5.0

Note: This instance agrees with the standalone Applicative/Chain/Monad instances but disagrees with the deprecated datum mega-instance.

Chain

Signature

export declare const Chain: Chain1<'@nll/datum/Datum'>

Added in v3.5.0

Compactable

Signature

export declare const Compactable: Compactable1<'@nll/datum/Datum'>

Added in v3.5.0

Datum (type alias)

Signature

export type Datum<D> = Initial | Pending | Refresh<D> | Replete<D>

Added in v2.0.0

Extend

Signature

export declare const Extend: Extend1<'@nll/datum/Datum'>

Added in v3.5.0

Filterable

Signature

export declare const Filterable: Filterable1<'@nll/datum/Datum'>

Added in v3.5.0

Foldable

Signature

export declare const Foldable: Foldable1<'@nll/datum/Datum'>

Added in v3.5.0

Functor

Signature

export declare const Functor: Functor1<'@nll/datum/Datum'>

Added in v3.5.0

Initial (interface)

Signature

export interface Initial {
  readonly _tag: 'Initial'
}

Added in v2.0.0

Monad

Signature

export declare const Monad: Monad1<'@nll/datum/Datum'>

Added in v3.5.0

MonadThrow

Signature

export declare const MonadThrow: MonadThrow1<'@nll/datum/Datum'>

Added in v3.5.0

Pending (interface)

Signature

export interface Pending {
  readonly _tag: 'Pending'
}

Added in v2.0.0

Refresh (interface)

Signature

export interface Refresh<D> {
  readonly _tag: 'Refresh'
  readonly value: D
}

Added in v2.0.0

Replete (interface)

Signature

export interface Replete<D> {
  readonly _tag: 'Replete'
  readonly value: D
}

Added in v2.0.0

Traversable

Signature

export declare const Traversable: Traversable1<'@nll/datum/Datum'>

Added in v3.5.0

URI

Signature

export declare const URI: '@nll/datum/Datum'

Added in v2.0.0

URI (type alias)

Signature

export type URI = typeof URI

Added in v2.0.0

Witherable

Signature

export declare const Witherable: Witherable1<'@nll/datum/Datum'>

Added in v3.5.0

alt

Signature

export declare const alt: <A>(that: Lazy<Datum<A>>) => (fa: Datum<A>) => Datum<A>

Added in v2.0.0

ap

Signature

export declare const ap: <A>(fa: Datum<A>) => <B>(fab: Datum<(a: A) => B>) => Datum<B>

Added in v4.0.0

apFirst

Signature

export declare const apFirst: <B>(fb: Datum<B>) => <A>(fa: Datum<A>) => Datum<A>

Added in v2.0.0

apSecond

Signature

export declare const apSecond: <B>(fb: Datum<B>) => <A>(fa: Datum<A>) => Datum<B>

Added in v2.0.0

chain

Signature

export declare const chain: <A, B>(f: (a: A) => Datum<B>) => (ma: Datum<A>) => Datum<B>

Added in v2.0.0

chainFirst

Signature

export declare const chainFirst: <A, B>(f: (a: A) => Datum<B>) => (ma: Datum<A>) => Datum<A>

Added in v2.0.0

compact

Signature

export declare const compact: <A>(fa: Datum<Option<A>>) => Datum<A>

Added in v2.0.0

constInitial

Signature

export declare const constInitial: Lazy<Initial>

Added in v2.0.0

constPending

Signature

export declare const constPending: Lazy<Pending>

Added in v2.0.0

duplicate

Signature

export declare const duplicate: <A>(wa: Datum<A>) => Datum<Datum<A>>

Added in v2.0.0

elem

Signature

export declare const elem: <A>(E: Eq<A>) => <E>(a: A, ma: Datum<A>) => boolean

Added in v2.0.0

exists

Returns false if Refresh or returns the result of the application of the given predicate to the Replete value.

Signature

export declare const exists: <A>(predicate: Predicate<A>) => <E>(ma: Datum<A>) => boolean

Added in v2.0.0

extend

Signature

export declare const extend: <A, B>(f: (wa: Datum<A>) => B) => (wa: Datum<A>) => Datum<B>

Added in v2.0.0

filter

Signature

export declare const filter: {
  <A, B>(refinement: Refinement<A, B>): (fa: Datum<A>) => Datum<B>
  <A>(predicate: Predicate<A>): (fa: Datum<A>) => Datum<A>
}

Added in v2.0.0

filterMap

Signature

export declare const filterMap: <A, B>(f: (a: A) => Option<B>) => (fa: Datum<A>) => Datum<B>

Added in v2.0.0

filterOrElse

Signature

export declare const filterOrElse: {
  <E, A, B>(refinement: Refinement<A, B>, onFalse: (a: A) => E): (ma: Datum<A>) => Datum<B>
  <E, A>(predicate: Predicate<A>, onFalse: (a: A) => E): (ma: Datum<A>) => Datum<A>
}

Added in v2.6.0

flatten

Signature

export declare const flatten: <A>(mma: Datum<Datum<A>>) => Datum<A>

Added in v2.0.0

fold

Signature

export declare const fold: <A, B>(
  onInitial: () => B,
  onPending: () => B,
  onRefresh: (v: A) => B,
  onReplete: (a: A) => B
) => (ma: Datum<A>) => B

Added in v2.0.0

foldMap

Signature

export declare const foldMap: <M>(M: Monoid<M>) => <A>(f: (a: A) => M) => (fa: Datum<A>) => M

Added in v2.0.0

fromEither

Signature

export declare const fromEither: <E, A>(ma: Either<E, A>) => Datum<A>

Added in v2.0.0

fromNullable

Takes a nullable value, if the value is not nully, turn it into a Replete, otherwise Initial.

Signature

export declare const fromNullable: <A>(a: A | null | undefined) => Datum<A>

Added in v2.0.0

fromOption

Signature

export declare const fromOption: <E>(onNone: Lazy<E>) => <A>(ma: Option<A>) => Datum<A>

Added in v2.6.0

fromPredicate

Signature

export declare const fromPredicate: {
  <E, A, B>(refinement: Refinement<A, B>, onFalse: (a: A) => E): (a: A) => Datum<B>
  <E, A>(predicate: Predicate<A>, onFalse: (a: A) => E): (a: A) => Datum<A>
}

Added in v2.6.0

getApplySemigroup

Apply semigroup

Signature

export declare const getApplySemigroup: <A>(S: Semigroup<A>) => Semigroup<Datum<A>>

Added in v4.0.0

getEq

Signature

export declare const getEq: <A>(E: Eq<A>) => Eq<Datum<A>>

Added in v2.0.0

getMonoid

See getSemigroup. Empty value of initial.

Signature

export declare const getMonoid: <A>(S: Semigroup<A>) => Monoid<Datum<A>>

Added in v4.0.0

getOrElse

Signature

export declare const getOrElse: <A>(onInitial: () => A, onPending: () => A) => (ma: Datum<A>) => A

Added in v2.0.0

getOrd

The Ord instance allows Datum values to be compared with compare, whenever there is an Ord instance for the type the Datum contains.

Initial < Pending < Refresh Replete

Signature

export declare function getOrd<A>(O: Ord<A>): Ord<Datum<A>>

Added in v2.0.0

getSemigroup

Viewing Datum as the following progess of state changes:

Initial -> Pending -> Replete -> Refresh [-> Replete -> …]

This semigroup has a bias towards datums with values and a bias towards Pending/Refresh. Notably, concat(Pending, Replete) gives Refresh. If both datums have a value, they’re combined with the given Semigroup instance.

Signature

export declare const getSemigroup: <A>(S: Semigroup<A>) => Semigroup<Datum<A>>

Added in v4.0.0

getShow

Signature

export declare const getShow: <A>(S: Show<A>) => Show<Datum<A>>

Added in v2.0.0

initial

Constructs an initial Datum holding no value.

Signature

export declare const initial: Datum<never>

Added in v2.0.0

isInitial

Returns true if the Async is an instance of Initial, false otherwise

Signature

export declare const isInitial: <A>(ma: Datum<A>) => ma is Initial

Added in v2.0.0

isPending

Returns true if the Async is an instance of Pending, false otherwise

Signature

export declare const isPending: <A>(ma: Datum<A>) => ma is Pending

Added in v2.0.0

isRefresh

Returns true if the Async is an instance of Refresh, false otherwise

Signature

export declare const isRefresh: <A>(ma: Datum<A>) => ma is Refresh<A>

Added in v2.0.0

isReplete

Returns true if the Async is an instance of Replete, false otherwise

Signature

export declare const isReplete: <A>(ma: Datum<A>) => ma is Replete<A>

Added in v2.0.0

isValued

Signature

export declare const isValued: <A>(ma: Datum<A>) => ma is Refresh<A> | Replete<A>

Added in v2.0.0

map

Signature

export declare const map: <A, B>(f: (a: A) => B) => (fa: Datum<A>) => Datum<B>

Added in v2.0.0

partition

Signature

export declare const partition: {
  <A, B>(refinement: Refinement<A, B>): (fa: Datum<A>) => Separated<Datum<A>, Datum<B>>
  <A>(predicate: Predicate<A>): (fa: Datum<A>) => Separated<Datum<A>, Datum<A>>
}

Added in v2.0.0

partitionMap

Signature

export declare const partitionMap: <A, B, C>(
  f: (a: A) => Either<B, C>
) => (fa: Datum<A>) => Separated<Datum<B>, Datum<C>>

Added in v2.0.0

pending

Constructs a pending Datum holding no value.

Signature

export declare const pending: Datum<never>

Added in v2.0.0

reduce

Signature

export declare const reduce: <A, B>(b: B, f: (b: B, a: A) => B) => (fa: Datum<A>) => B

Added in v2.0.0

reduceRight

Signature

export declare const reduceRight: <A, B>(b: B, f: (a: A, b: B) => B) => (fa: Datum<A>) => B

Added in v2.0.0

refresh

Constructs a new refresh Datum holding a value.

Signature

export declare const refresh: <A = never>(value: A) => Datum<A>

Added in v2.0.0

replete

Constructs a new replete Datum holding a value.

Signature

export declare const replete: <A = never>(value: A) => Datum<A>

Added in v2.0.0

separate

Signature

export declare const separate: <A, B>(fa: Datum<Either<A, B>>) => Separated<Datum<A>, Datum<B>>

Added in v2.0.0