GitXplorerGitXplorer
b

purescript-signal

public
260 stars
41 forks
9 issues

Commits

List of commits on branch master.
Unverified
5a2e9745be5d4adf47918cc820290d8db5764c3d

v12.0.1 → v13.0.0

CCarstenKoenig committed 3 years ago
Unverified
6c85ce7b6eab415901ee10da31df9c14f0fe03cb

bump bower.json

CCarstenKoenig committed 3 years ago
Unverified
1105067aa95af5c12bd80ae6c6fd62a0240d957b

[temp]get the old tests working over purescript-spec

CCarstenKoenig committed 3 years ago
Unverified
d513f753bd98cc639b47414856efb181e06ba503

Updated library to PureScript 0.15 / ESM

CCarstenKoenig committed 3 years ago
Unverified
0276f5b0c25993420e1707710f1a530e9cfee625

v12.0.1

CCarstenKoenig committed 4 years ago
Unverified
c1e11ac14b9c37f46b265ff8695609357dab0ce1

v12.0.0

CCarstenKoenig committed 4 years ago

README

The README file for this repository.

purescript-signal

Build Status

Signal is a lightweight FRP-like library heavily inspired by the Elm Signal implementation. Where possible and sensible, it tries to maintain API equivalence with Elm.

See the Elm documentation for details on usage and principles.

PureScript Usage Patterns

PureScript depends on effects (specifically, the Effect monad) to manage side effects, where Elm's runtime generally manages them for you. purescript-signal provides the Signal.runSignal function for running effectful signals.

module Main where

import Effect.Console
import Effect (Effect)
import Prelude
import Signal

hello :: Signal String
hello = constant "Hello Joe!"

helloEffect :: Signal (Effect Unit)
helloEffect = hello ~> log

main = runSignal helloEffect

This simple example takes a constant signal which contains the string "Hello Joe!" and maps it over the Effect.Console.log function, which has the type String -> Effect Unit, thus taking the String content of the signal and turning it into an effect which logs the provided string to the user's console.

This gives us a Signal (Effect Unit). We use runSignal to take the signal of effects and run each effect in turn—in our case, just the one effect which prints "Hello Joe!" to the console.

API Documentation

Usage Examples