@davidsouther/jiffies 2026.24.0 → 2026.24.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (226) hide show
  1. package/lib/esm/assert.d.ts +26 -0
  2. package/lib/esm/assert.js +38 -0
  3. package/lib/esm/awaitable.js +1 -0
  4. package/lib/esm/case.d.ts +1 -0
  5. package/lib/esm/case.js +5 -0
  6. package/lib/esm/components/accordion.d.ts +5 -0
  7. package/lib/esm/components/accordion.js +9 -0
  8. package/lib/esm/components/alert.d.ts +7 -0
  9. package/lib/esm/components/alert.js +31 -0
  10. package/lib/esm/components/button_bar.d.ts +8 -0
  11. package/lib/esm/components/button_bar.js +25 -0
  12. package/lib/esm/components/card.d.ts +8 -0
  13. package/lib/esm/components/card.js +31 -0
  14. package/lib/esm/components/children.d.ts +2 -0
  15. package/{src/components/children.ts → lib/esm/components/children.js} +2 -6
  16. package/lib/esm/components/form.d.ts +5 -0
  17. package/lib/esm/components/form.js +13 -0
  18. package/{src/components/index.ts → lib/esm/components/index.d.ts} +2 -15
  19. package/lib/esm/components/index.js +10 -0
  20. package/lib/esm/components/inline_edit.d.ts +12 -0
  21. package/lib/esm/components/inline_edit.js +48 -0
  22. package/lib/esm/components/link.d.ts +5 -0
  23. package/lib/esm/components/link.js +11 -0
  24. package/lib/esm/components/logger.d.ts +6 -0
  25. package/lib/esm/components/logger.js +22 -0
  26. package/lib/esm/components/modal.d.ts +2 -0
  27. package/{src/components/modal.ts → lib/esm/components/modal.js} +3 -8
  28. package/lib/esm/components/nav.d.ts +11 -0
  29. package/lib/esm/components/nav.js +27 -0
  30. package/lib/esm/components/property.d.ts +9 -0
  31. package/lib/esm/components/property.js +16 -0
  32. package/lib/esm/components/select.d.ts +10 -0
  33. package/lib/esm/components/select.js +3 -0
  34. package/lib/esm/components/tabs.d.ts +20 -0
  35. package/lib/esm/components/tabs.js +45 -0
  36. package/lib/esm/components/virtual_scroll.d.ts +42 -0
  37. package/lib/esm/components/virtual_scroll.js +94 -0
  38. package/lib/esm/debounce.d.ts +1 -0
  39. package/lib/esm/debounce.js +11 -0
  40. package/lib/esm/diff.d.ts +15 -0
  41. package/lib/esm/diff.js +50 -0
  42. package/lib/esm/display.d.ts +5 -0
  43. package/lib/esm/display.js +11 -0
  44. package/lib/esm/dom/css/border.d.ts +11 -0
  45. package/lib/esm/dom/css/border.js +27 -0
  46. package/lib/esm/dom/css/constants.d.ts +31 -0
  47. package/lib/esm/dom/css/constants.js +28 -0
  48. package/lib/esm/dom/css/core.d.ts +5 -0
  49. package/lib/esm/dom/css/core.js +24 -0
  50. package/lib/esm/dom/css/fstyle.d.ts +5 -0
  51. package/lib/esm/dom/css/fstyle.js +32 -0
  52. package/lib/esm/dom/css/sizing.d.ts +5 -0
  53. package/lib/esm/dom/css/sizing.js +10 -0
  54. package/lib/esm/dom/dom.d.ts +36 -0
  55. package/lib/esm/dom/dom.js +217 -0
  56. package/lib/esm/dom/fc.d.ts +10 -0
  57. package/lib/esm/dom/fc.js +32 -0
  58. package/lib/esm/dom/form/form.app.d.ts +1 -0
  59. package/lib/esm/dom/form/form.app.js +19 -0
  60. package/lib/esm/dom/form/form.d.ts +27 -0
  61. package/lib/esm/dom/form/form.js +65 -0
  62. package/lib/esm/dom/html.d.ts +112 -0
  63. package/{src/dom/html.ts → lib/esm/dom/html.js} +2 -14
  64. package/lib/esm/dom/hydrate.d.ts +39 -0
  65. package/lib/esm/dom/hydrate.js +187 -0
  66. package/lib/esm/dom/index.js +2 -0
  67. package/lib/esm/dom/navigation/index.d.ts +76 -0
  68. package/lib/esm/dom/navigation/index.js +292 -0
  69. package/lib/esm/dom/observable.d.ts +2 -0
  70. package/lib/esm/dom/observable.js +6 -0
  71. package/lib/esm/dom/provide.d.ts +3 -0
  72. package/lib/esm/dom/provide.js +7 -0
  73. package/lib/esm/dom/render.d.ts +8 -0
  74. package/lib/esm/dom/render.js +28 -0
  75. package/lib/esm/dom/router/link.d.ts +6 -0
  76. package/lib/esm/dom/router/link.js +3 -0
  77. package/lib/esm/dom/router/router.d.ts +13 -0
  78. package/lib/esm/dom/router/router.js +52 -0
  79. package/lib/esm/dom/svg.d.ts +64 -0
  80. package/{src/dom/svg.ts → lib/esm/dom/svg.js} +2 -19
  81. package/lib/esm/dom/types/css.d.ts +6590 -0
  82. package/lib/esm/dom/types/css.js +1 -0
  83. package/lib/esm/dom/types/dom.js +1 -0
  84. package/lib/esm/dom/types/html.d.ts +614 -0
  85. package/lib/esm/dom/types/html.js +1 -0
  86. package/lib/esm/dom/xml.d.ts +1 -0
  87. package/lib/esm/dom/xml.js +4 -0
  88. package/lib/esm/equal.d.ts +11 -0
  89. package/lib/esm/equal.js +43 -0
  90. package/lib/esm/fs.d.ts +72 -0
  91. package/lib/esm/fs.js +227 -0
  92. package/lib/esm/fs_node.d.ts +15 -0
  93. package/lib/esm/fs_node.js +45 -0
  94. package/lib/esm/generator.d.ts +1 -0
  95. package/lib/esm/generator.js +10 -0
  96. package/lib/esm/lock.d.ts +1 -0
  97. package/lib/esm/lock.js +23 -0
  98. package/lib/esm/log.d.ts +69 -0
  99. package/lib/esm/log.js +211 -0
  100. package/lib/esm/observable/event.d.ts +35 -0
  101. package/lib/esm/observable/event.js +46 -0
  102. package/lib/esm/observable/observable.d.ts +134 -0
  103. package/lib/esm/observable/observable.js +349 -0
  104. package/lib/esm/range.d.ts +1 -0
  105. package/lib/esm/range.js +7 -0
  106. package/lib/esm/result.d.ts +31 -0
  107. package/lib/esm/result.js +66 -0
  108. package/lib/esm/safe.d.ts +1 -0
  109. package/lib/esm/safe.js +10 -0
  110. package/lib/esm/server/http/apps.d.ts +5 -0
  111. package/lib/esm/server/http/apps.js +23 -0
  112. package/lib/esm/server/http/css.d.ts +5 -0
  113. package/lib/esm/server/http/css.js +43 -0
  114. package/lib/esm/server/http/index.d.ts +16 -0
  115. package/lib/esm/server/http/index.js +78 -0
  116. package/lib/esm/server/http/response.d.ts +4 -0
  117. package/lib/esm/server/http/response.js +43 -0
  118. package/lib/esm/server/http/sitemap.d.ts +2 -0
  119. package/lib/esm/server/http/sitemap.js +22 -0
  120. package/lib/esm/server/http/static.d.ts +2 -0
  121. package/lib/esm/server/http/static.js +22 -0
  122. package/lib/esm/server/http/typescript.d.ts +5 -0
  123. package/lib/esm/server/http/typescript.js +40 -0
  124. package/lib/esm/server/live-reload.d.ts +46 -0
  125. package/lib/esm/server/live-reload.js +161 -0
  126. package/lib/esm/server/main.d.ts +2 -0
  127. package/{src/server/main.ts → lib/esm/server/main.js} +8 -15
  128. package/lib/esm/server/ws/frame.d.ts +2 -0
  129. package/lib/esm/server/ws/frame.js +35 -0
  130. package/lib/esm/server/ws/handshake.d.ts +4 -0
  131. package/lib/esm/server/ws/handshake.js +32 -0
  132. package/lib/esm/server/ws/index.d.ts +14 -0
  133. package/lib/esm/server/ws/index.js +68 -0
  134. package/lib/esm/ssg/bundle.d.ts +14 -0
  135. package/lib/esm/ssg/bundle.js +73 -0
  136. package/lib/esm/ssg/copy-public.d.ts +6 -0
  137. package/lib/esm/ssg/copy-public.js +34 -0
  138. package/lib/esm/ssg/discover.d.ts +15 -0
  139. package/lib/esm/ssg/discover.js +117 -0
  140. package/lib/esm/ssg/main.d.ts +2 -0
  141. package/lib/esm/ssg/main.js +122 -0
  142. package/lib/esm/ssg/rewrite.d.ts +9 -0
  143. package/{src/ssg/rewrite.ts → lib/esm/ssg/rewrite.js} +6 -9
  144. package/lib/esm/ssg/ssg.d.ts +26 -0
  145. package/lib/esm/ssg/ssg.js +84 -0
  146. package/lib/esm/transpile.d.mts +3 -0
  147. package/lib/esm/transpile.mjs +12 -0
  148. package/package.json +11 -7
  149. package/src/404.html +0 -14
  150. package/src/assert.ts +0 -56
  151. package/src/case.ts +0 -5
  152. package/src/components/_notes +0 -33
  153. package/src/components/accordion.ts +0 -25
  154. package/src/components/alert.ts +0 -47
  155. package/src/components/button_bar.ts +0 -42
  156. package/src/components/card.ts +0 -54
  157. package/src/components/form.ts +0 -25
  158. package/src/components/inline_edit.ts +0 -78
  159. package/src/components/link.ts +0 -22
  160. package/src/components/logger.ts +0 -35
  161. package/src/components/nav.ts +0 -42
  162. package/src/components/property.ts +0 -32
  163. package/src/components/select.ts +0 -22
  164. package/src/components/tabs.ts +0 -82
  165. package/src/components/virtual_scroll.ts +0 -199
  166. package/src/debounce.ts +0 -14
  167. package/src/diff.ts +0 -82
  168. package/src/display.ts +0 -18
  169. package/src/dom/README.md +0 -107
  170. package/src/dom/SKILL.md +0 -201
  171. package/src/dom/css/border.ts +0 -47
  172. package/src/dom/css/constants.ts +0 -34
  173. package/src/dom/css/core.ts +0 -28
  174. package/src/dom/css/fstyle.ts +0 -42
  175. package/src/dom/css/sizing.ts +0 -11
  176. package/src/dom/dom.ts +0 -327
  177. package/src/dom/fc.ts +0 -81
  178. package/src/dom/form/form.app.ts +0 -44
  179. package/src/dom/form/form.ts +0 -151
  180. package/src/dom/form/index.html +0 -15
  181. package/src/dom/hydrate.ts +0 -206
  182. package/src/dom/navigation/index.ts +0 -349
  183. package/src/dom/observable.ts +0 -11
  184. package/src/dom/provide.ts +0 -11
  185. package/src/dom/render.ts +0 -41
  186. package/src/dom/router/link.ts +0 -14
  187. package/src/dom/router/router.ts +0 -72
  188. package/src/dom/types/css.ts +0 -10088
  189. package/src/dom/types/html.ts +0 -629
  190. package/src/dom/xml.ts +0 -11
  191. package/src/equal.ts +0 -66
  192. package/src/favicon.ico +0 -0
  193. package/src/fs.ts +0 -300
  194. package/src/fs_node.ts +0 -57
  195. package/src/generator.ts +0 -12
  196. package/src/hooks/_notes +0 -6
  197. package/src/lock.ts +0 -23
  198. package/src/log.ts +0 -307
  199. package/src/observable/_notes +0 -26
  200. package/src/observable/event.ts +0 -93
  201. package/src/observable/observable.ts +0 -484
  202. package/src/range.ts +0 -7
  203. package/src/result.ts +0 -107
  204. package/src/safe.ts +0 -12
  205. package/src/server/http/apps.ts +0 -26
  206. package/src/server/http/css.ts +0 -49
  207. package/src/server/http/index.ts +0 -127
  208. package/src/server/http/response.ts +0 -60
  209. package/src/server/http/sitemap.ts +0 -24
  210. package/src/server/http/static.ts +0 -28
  211. package/src/server/http/typescript.ts +0 -46
  212. package/src/server/live-reload.ts +0 -208
  213. package/src/server/ws/frame.ts +0 -36
  214. package/src/server/ws/handshake.ts +0 -42
  215. package/src/server/ws/index.ts +0 -100
  216. package/src/ssg/bundle.ts +0 -85
  217. package/src/ssg/copy-public.ts +0 -44
  218. package/src/ssg/discover.ts +0 -143
  219. package/src/ssg/main.ts +0 -168
  220. package/src/ssg/ssg.ts +0 -134
  221. package/src/transpile.mjs +0 -16
  222. package/src/zip/spec.txt +0 -3260
  223. package/tsconfig.json +0 -34
  224. /package/{src/awaitable.ts → lib/esm/awaitable.d.ts} +0 -0
  225. /package/{src/dom/index.ts → lib/esm/dom/index.d.ts} +0 -0
  226. /package/{src/dom/types/dom.ts → lib/esm/dom/types/dom.d.ts} +0 -0
@@ -0,0 +1,35 @@
1
+ import type { Observable } from "./observable.ts";
2
+ export interface Next<T> {
3
+ value: T;
4
+ completed: false;
5
+ failed: false;
6
+ }
7
+ export interface Error<E> {
8
+ error: E;
9
+ completed: false;
10
+ failed: true;
11
+ }
12
+ export interface Completed {
13
+ completed: true;
14
+ failed: false;
15
+ }
16
+ export interface Failed {
17
+ completed: true;
18
+ failed: true;
19
+ }
20
+ export type Event<T, E> = Next<T> | Error<E> | Completed | Failed;
21
+ export interface EventSubscriber<T, E> {
22
+ next(e: Event<T, E>): void;
23
+ }
24
+ export declare const next: <T>(value: T) => Next<T>;
25
+ export declare const error: <E>(e: E) => Error<E>;
26
+ export declare const completed: () => Completed;
27
+ export declare const failed: () => Failed;
28
+ export declare const isNext: <T>(event: Event<T, unknown>) => event is Next<T>;
29
+ export declare const isError: <E>(event: Event<unknown, E>) => event is Error<E>;
30
+ export declare const isCompleted: (event: Event<unknown, unknown>) => event is Completed;
31
+ export declare const isFailed: (event: Event<unknown, unknown>) => event is Failed;
32
+ export declare const isEvent: <T, E>(t: T | Event<T, E>) => t is Event<T, E>;
33
+ export declare const asEvents: <T, E>(a: (T | Event<T, E>)[]) => Event<T, E>[];
34
+ export declare const marbles: <T, E>(events: Event<T, E>[]) => string;
35
+ export declare const collect: <T, E>(input$: Observable<T, E>) => Event<T, E>[];
@@ -0,0 +1,46 @@
1
+ import { display } from "../display.js";
2
+ export const next = (value) => ({
3
+ value,
4
+ completed: false,
5
+ failed: false,
6
+ });
7
+ export const error = (e) => ({
8
+ error: e,
9
+ completed: false,
10
+ failed: true,
11
+ });
12
+ export const completed = () => ({ completed: true, failed: false });
13
+ export const failed = () => ({ completed: true, failed: true });
14
+ export const isNext = (event) => !event.completed && !event.failed && event.value !== undefined;
15
+ export const isError = (event) => event.failed && !event.completed;
16
+ export const isCompleted = (event) => event.completed && !event.failed;
17
+ export const isFailed = (event) => event.completed && event.failed;
18
+ export const isEvent = (t) => {
19
+ const b = t;
20
+ return isNext(b) || isError(b) || isCompleted(b);
21
+ };
22
+ export const asEvents = (a) => a.map((e) => (isEvent(e) ? e : next(e)));
23
+ const marble = (event) => isError(event)
24
+ ? "X"
25
+ : isFailed(event)
26
+ ? "!"
27
+ : isCompleted(event)
28
+ ? "|"
29
+ : `(${display(event.value)})`;
30
+ export const marbles = (events) => `:${events.map(marble).join("-")}`;
31
+ export const collect = (input$) => {
32
+ const collected = [];
33
+ const subscription = input$.subscribe({
34
+ next: (x) => {
35
+ collected.push(next(x));
36
+ },
37
+ error: (e) => {
38
+ collected.push(error(e));
39
+ },
40
+ complete: () => {
41
+ collected.push(completed());
42
+ },
43
+ });
44
+ subscription.unsubscribe();
45
+ return collected;
46
+ };
@@ -0,0 +1,134 @@
1
+ import type { Display } from "../display.ts";
2
+ import { type Logger } from "../log.ts";
3
+ export interface FullSubscriber<T, E> {
4
+ next?: (t: T) => void | Promise<void>;
5
+ error?: (e: E) => void | Promise<void>;
6
+ complete?: () => void | Promise<void>;
7
+ }
8
+ export type Subscriber<T, E> = FullSubscriber<T, E> | ((t: T) => void | Promise<void>);
9
+ export interface Subscription {
10
+ unsubscribe(): void;
11
+ }
12
+ export interface Observable<T, E = unknown> {
13
+ subscribe(subscriber: Subscriber<T, E>): Subscription;
14
+ pipe<T1>(o1: Subscriber<T, E> & Observable<T1, E>): Observable<T1, E>;
15
+ pipe<T1, T2>(o1: Subscriber<T, E> & Observable<T1, E>, o2: Subscriber<T1, E> & Observable<T2, E>): Observable<T2, E>;
16
+ filter(fn: (t: T) => boolean): Observable<T, E>;
17
+ distinct(fn?: (t1: T, t2: T) => boolean): Observable<T, E>;
18
+ map<U>(fn: (t: T) => U): Observable<U, E>;
19
+ reduce<A>(fn: (acc: A, t: T) => A, init: A): Observable<A, E>;
20
+ replay(n: number): Observable<T, E>;
21
+ tap(s: Subscriber<T, E>): Observable<T, E>;
22
+ }
23
+ export declare const Observable: {
24
+ of<T, E>(...ts: T[]): Observable<T, E>;
25
+ combineLatest<T1, T2, E>(o1: Observable<T1, E>, o2: Observable<T2, E>): Observable<[T1, T2], E>;
26
+ };
27
+ interface Scheduler {
28
+ execute(fn: () => (void | Promise<void>)[]): void | Promise<void>;
29
+ }
30
+ export declare const AsyncScheduler: Scheduler;
31
+ export declare const SyncScheduler: Scheduler;
32
+ export declare function setDefaultScheduler(scheduler: Scheduler): void;
33
+ export declare class Subject<T, E = unknown, T2 = T> implements FullSubscriber<T, E>, Observable<T, E> {
34
+ #private;
35
+ private readonly scheduler;
36
+ get $(): Observable<T, E>;
37
+ get hot(): boolean;
38
+ get cold(): boolean;
39
+ constructor(scheduler?: Scheduler);
40
+ onWarm(fn: CallableFunction): void;
41
+ next(t: T | T2): void | Promise<void>;
42
+ error(e: E): void | Promise<void>;
43
+ complete(): void | Promise<void>;
44
+ subscribe(subscriber: Subscriber<T, E>): Subscription;
45
+ pipe<T1>(o1: Subscriber<T, E> & Observable<T1, E>): Observable<T1, E>;
46
+ pipe<T1, T2>(o1: Subscriber<T, E> & Observable<T1, E>, o2: Subscriber<T1, E> & Observable<T2, E>): Observable<T2, E>;
47
+ filter(fn: (t: T) => boolean): Observable<T, E>;
48
+ distinct(fn?: (t1: T, t2: T) => boolean): Observable<T, E>;
49
+ map<U>(fn: (t: T) => U): Observable<U, E>;
50
+ reduce<A>(fn: (acc: A, t: T) => A, init: A): Observable<A, E>;
51
+ replay(n: number): Observable<T, E>;
52
+ tap(s: Subscriber<T, E>): Observable<T, E>;
53
+ }
54
+ export declare class BehaviorSubject<T, E = unknown, T2 = T> extends Subject<T, E, T2> {
55
+ #private;
56
+ constructor(t: T, scheduler?: Scheduler);
57
+ next(t: T | T2): void | Promise<void>;
58
+ subscribe(subscriber: Subscriber<T, E>): Subscription;
59
+ get current(): T;
60
+ }
61
+ export declare class ReplaySubject<T, E = unknown> extends Subject<T, E> {
62
+ #private;
63
+ readonly n: number;
64
+ constructor(n: number, scheduler?: Scheduler);
65
+ next(t: T): void | Promise<void>;
66
+ subscribe(subscriber: Subscriber<T, E>): Subscription;
67
+ }
68
+ export declare function eventListener<E extends Event>(): (Subject<E, unknown, E> | ((e: E) => void))[];
69
+ export declare class EventHandler<E extends Event> extends Subject<E> {
70
+ eventFn: (e: E) => void | Promise<void>;
71
+ constructor(eventFn: (e: E) => void | Promise<void>);
72
+ next(e: E): Promise<undefined>;
73
+ }
74
+ export declare const watch: <T extends Display, E extends Display>(logger?: Logger) => (observable: Observable<T, E>) => void;
75
+ declare class MapOperator<T, U, E> extends Subject<U, E, T> implements FullSubscriber<T, E>, Observable<U, E> {
76
+ private readonly mapFn;
77
+ constructor(mapFn: (t: T) => U);
78
+ next(t: T): void | Promise<void>;
79
+ }
80
+ declare class FilterOperator<T, E> extends Subject<T, E> implements FullSubscriber<T, E>, Observable<T, E> {
81
+ private readonly filterFn;
82
+ constructor(filterFn: (t: T) => boolean);
83
+ next(t: T): void | Promise<void>;
84
+ }
85
+ declare class DistinctOperator<T, E> extends Subject<T, E> implements FullSubscriber<T, E>, Observable<T, E> {
86
+ #private;
87
+ private readonly distinctFn;
88
+ constructor(distinctFn?: (t1: T, t2: T) => boolean);
89
+ next(t: T): void | Promise<void>;
90
+ }
91
+ declare class ReduceOperator<A, T, E> extends BehaviorSubject<A, E, T> {
92
+ private readonly fn;
93
+ constructor(fn: (acc: A, t: T) => A, init: A);
94
+ next(t: T): void | Promise<void>;
95
+ }
96
+ export declare class TakeUntilOperator<T, E> extends Subject<T, E> {
97
+ constructor(o: Observable<unknown, unknown>);
98
+ }
99
+ export declare class TapOperator<T, E> extends Subject<T, E> {
100
+ private readonly subscriber;
101
+ constructor(fn: Subscriber<T, E>);
102
+ next(t: T): void | Promise<void>;
103
+ error(e: E): void | Promise<void>;
104
+ complete(): void | Promise<void>;
105
+ }
106
+ declare class FirstOperator<T, E> extends Subject<T, E> {
107
+ next(t: T): void | Promise<void>;
108
+ }
109
+ declare class LastOperator<T, E = Error> extends Subject<T, E> {
110
+ #private;
111
+ next(t: T): void;
112
+ complete(): void | Promise<void>;
113
+ }
114
+ export declare const filter: <T, E>(fn: (t: T) => boolean) => FilterOperator<T, E>;
115
+ export declare const distinct: <T, E>(fn?: (t1: T, t2: T) => boolean) => DistinctOperator<T, E>;
116
+ export declare const first: <T, E>() => FirstOperator<T, E>;
117
+ export declare const last: <T, E>() => LastOperator<T, E>;
118
+ export declare const map: <T1, T2, E>(fn: (t: T1) => T2) => MapOperator<T1, T2, E>;
119
+ export declare const replay: <T, E>(n: number) => ReplaySubject<T, E>;
120
+ export declare const reduce: <A, T, E>(fn: (acc: A, t: T) => A, init: A) => ReduceOperator<A, T, E>;
121
+ export declare const takeUntil: <T, E>(o: Observable<unknown, unknown>) => TakeUntilOperator<T, E>;
122
+ export declare const tap: <T, E>(fn: Subscriber<T, E>) => TapOperator<T, E>;
123
+ export declare const operator: {
124
+ filter: <T, E>(fn: (t: T) => boolean) => FilterOperator<T, E>;
125
+ distinct: <T, E>(fn?: (t1: T, t2: T) => boolean) => DistinctOperator<T, E>;
126
+ first: <T, E>() => FirstOperator<T, E>;
127
+ last: <T, E>() => LastOperator<T, E>;
128
+ map: <T1, T2, E>(fn: (t: T1) => T2) => MapOperator<T1, T2, E>;
129
+ replay: <T, E>(n: number) => ReplaySubject<T, E>;
130
+ reduce: <A, T, E>(fn: (acc: A, t: T) => A, init: A) => ReduceOperator<A, T, E>;
131
+ takeUntil: <T, E>(o: Observable<unknown, unknown>) => TakeUntilOperator<T, E>;
132
+ tap: <T, E>(fn: Subscriber<T, E>) => TapOperator<T, E>;
133
+ };
134
+ export {};
@@ -0,0 +1,349 @@
1
+ import { assertExists } from "../assert.js";
2
+ import { DEFAULT_LOGGER } from "../log.js";
3
+ export const Observable = {
4
+ of(...ts) {
5
+ const subject = new Subject();
6
+ (async function next() {
7
+ if (subject.cold) {
8
+ subject.onWarm(next);
9
+ return;
10
+ }
11
+ if (ts.length === 0) {
12
+ subject.complete();
13
+ return;
14
+ }
15
+ const t = assertExists(ts.shift());
16
+ await subject.next(t);
17
+ next();
18
+ })();
19
+ return subject;
20
+ },
21
+ combineLatest(o1, o2) {
22
+ const latestSubject = new Subject();
23
+ let o1LatestSet = false;
24
+ let o1Latest;
25
+ let o2LatestSet = false;
26
+ let o2Latest;
27
+ function next() {
28
+ if (o1LatestSet && o2LatestSet) {
29
+ latestSubject.next([o1Latest, o2Latest]);
30
+ }
31
+ }
32
+ function error(e) {
33
+ latestSubject.error(e);
34
+ }
35
+ function complete() {
36
+ latestSubject.complete();
37
+ o1sub.unsubscribe();
38
+ o2sub.unsubscribe();
39
+ }
40
+ const o1sub = o1.subscribe({
41
+ next(t) {
42
+ o1Latest = t;
43
+ o1LatestSet = true;
44
+ next();
45
+ },
46
+ error,
47
+ complete,
48
+ });
49
+ const o2sub = o2.subscribe({
50
+ next(t) {
51
+ o2Latest = t;
52
+ o2LatestSet = true;
53
+ next();
54
+ },
55
+ error,
56
+ complete,
57
+ });
58
+ return latestSubject;
59
+ },
60
+ };
61
+ export const AsyncScheduler = {
62
+ execute(fn) {
63
+ return Promise.all(fn()).then(() => undefined);
64
+ },
65
+ };
66
+ export const SyncScheduler = {
67
+ execute(fn) {
68
+ fn();
69
+ },
70
+ };
71
+ let DefaultScheduler = SyncScheduler;
72
+ export function setDefaultScheduler(scheduler) {
73
+ DefaultScheduler = scheduler;
74
+ }
75
+ export class Subject {
76
+ scheduler;
77
+ #coldWaiters = new Set();
78
+ #subscribers = new Set();
79
+ #complete = false;
80
+ get $() {
81
+ return this;
82
+ }
83
+ get hot() {
84
+ return this.#subscribers.size > 0;
85
+ }
86
+ get cold() {
87
+ return !this.hot;
88
+ }
89
+ constructor(scheduler = DefaultScheduler) {
90
+ this.scheduler = scheduler;
91
+ }
92
+ onWarm(fn) {
93
+ if (this.cold)
94
+ this.#coldWaiters.add(fn);
95
+ }
96
+ next(t) {
97
+ if (this.#complete)
98
+ throw new Error("Cannot call next on a completed subject");
99
+ return this.scheduler.execute(() => [...this.#subscribers].map((s) => s.next?.(t)));
100
+ }
101
+ error(e) {
102
+ if (this.#complete)
103
+ throw new Error("Cannot call error on a completed subject");
104
+ return this.scheduler.execute(() => [...this.#subscribers].map((s) => s.error?.(e)));
105
+ }
106
+ complete() {
107
+ if (this.#complete)
108
+ throw new Error("Cannot call complete on a completed subject");
109
+ this.#complete = true;
110
+ const finished = this.scheduler.execute(() => [...this.#subscribers].map((s) => s.complete?.()));
111
+ this.#subscribers.clear(); // Free subscribers for garbage collection
112
+ return finished;
113
+ }
114
+ subscribe(subscriber) {
115
+ if (this.#complete)
116
+ throw new Error("Cannot call subscribe on a completed subject");
117
+ if (subscriber instanceof Function) {
118
+ subscriber = { next: subscriber };
119
+ }
120
+ this.#subscribers.add(subscriber);
121
+ for (const w of this.#coldWaiters)
122
+ w();
123
+ this.#coldWaiters.clear();
124
+ return {
125
+ unsubscribe: () => this.#subscribers.delete(subscriber),
126
+ };
127
+ }
128
+ pipe(...os) {
129
+ this.subscribe(os[0]);
130
+ for (let i = 1; i < os.length; i++) {
131
+ os[i - 1].subscribe(os[i]);
132
+ }
133
+ return os[os.length - 1];
134
+ }
135
+ filter(fn) {
136
+ return this.pipe(operator.filter(fn));
137
+ }
138
+ distinct(fn = Object.is) {
139
+ return this.pipe(operator.distinct(fn));
140
+ }
141
+ map(fn) {
142
+ return this.pipe(operator.map(fn));
143
+ }
144
+ reduce(fn, init) {
145
+ return this.pipe(operator.reduce(fn, init));
146
+ }
147
+ replay(n) {
148
+ return this.pipe(operator.replay(n));
149
+ }
150
+ tap(s) {
151
+ return this.pipe(operator.tap(s));
152
+ }
153
+ }
154
+ export class BehaviorSubject extends Subject {
155
+ #current;
156
+ constructor(t, scheduler) {
157
+ super(scheduler ?? AsyncScheduler);
158
+ this.#current = t;
159
+ }
160
+ next(t) {
161
+ this.#current = t;
162
+ return super.next(t);
163
+ }
164
+ subscribe(subscriber) {
165
+ if (subscriber instanceof Function) {
166
+ subscriber = { next: subscriber };
167
+ }
168
+ subscriber.next?.(this.#current);
169
+ return super.subscribe(subscriber);
170
+ }
171
+ get current() {
172
+ return this.#current;
173
+ }
174
+ }
175
+ export class ReplaySubject extends Subject {
176
+ n;
177
+ #history = [];
178
+ constructor(n, scheduler) {
179
+ super(scheduler ?? SyncScheduler);
180
+ this.n = n;
181
+ }
182
+ next(t) {
183
+ this.#history.push(t);
184
+ if (this.#history.length > this.n) {
185
+ this.#history.shift();
186
+ }
187
+ return super.next(t);
188
+ }
189
+ subscribe(subscriber) {
190
+ if (subscriber instanceof Function) {
191
+ subscriber = { next: subscriber };
192
+ }
193
+ const history = [...this.#history];
194
+ (function send() {
195
+ if (history.length === 0)
196
+ return;
197
+ const t = assertExists(history.shift());
198
+ subscriber.next?.(t);
199
+ new Promise(send);
200
+ })();
201
+ return super.subscribe(subscriber);
202
+ }
203
+ }
204
+ export function eventListener() {
205
+ const observable = new Subject();
206
+ function listener(e) {
207
+ e.preventDefault();
208
+ observable.next(e);
209
+ }
210
+ return [observable, listener];
211
+ }
212
+ export class EventHandler extends Subject {
213
+ eventFn;
214
+ constructor(eventFn) {
215
+ super(AsyncScheduler);
216
+ this.eventFn = eventFn;
217
+ }
218
+ async next(e) {
219
+ e.preventDefault();
220
+ super.next(e);
221
+ }
222
+ }
223
+ export const watch = (logger = DEFAULT_LOGGER) => (observable) => {
224
+ observable.tap({
225
+ async next(t) {
226
+ logger.info(t);
227
+ },
228
+ async complete() {
229
+ logger.info("Observable completed");
230
+ },
231
+ async error(e) {
232
+ logger.warn(e);
233
+ },
234
+ });
235
+ };
236
+ class MapOperator extends Subject {
237
+ mapFn;
238
+ constructor(mapFn) {
239
+ super(SyncScheduler);
240
+ this.mapFn = mapFn;
241
+ }
242
+ next(t) {
243
+ return super.next(this.mapFn(t));
244
+ }
245
+ }
246
+ class FilterOperator extends Subject {
247
+ filterFn;
248
+ constructor(filterFn) {
249
+ super(SyncScheduler);
250
+ this.filterFn = filterFn;
251
+ }
252
+ next(t) {
253
+ return this.filterFn(t) ? super.next(t) : undefined;
254
+ }
255
+ }
256
+ class DistinctOperator extends Subject {
257
+ #prior = undefined;
258
+ distinctFn;
259
+ constructor(distinctFn = Object.is) {
260
+ super(SyncScheduler);
261
+ this.distinctFn = distinctFn;
262
+ }
263
+ next(t) {
264
+ if (this.#prior === undefined) {
265
+ this.#prior = t;
266
+ return super.next(t);
267
+ }
268
+ const same = this.distinctFn(assertExists(this.#prior), t);
269
+ if (!same) {
270
+ this.#prior = t;
271
+ return super.next(t);
272
+ }
273
+ return undefined;
274
+ }
275
+ }
276
+ class ReduceOperator extends BehaviorSubject {
277
+ fn;
278
+ constructor(fn, init) {
279
+ super(init);
280
+ this.fn = fn;
281
+ }
282
+ next(t) {
283
+ return super.next(this.fn(this.current, t));
284
+ }
285
+ }
286
+ export class TakeUntilOperator extends Subject {
287
+ constructor(o) {
288
+ super();
289
+ o.subscribe(() => this.complete());
290
+ }
291
+ }
292
+ export class TapOperator extends Subject {
293
+ subscriber;
294
+ constructor(fn) {
295
+ super();
296
+ this.subscriber = fn instanceof Function ? { next: fn } : fn;
297
+ }
298
+ next(t) {
299
+ this.subscriber.next?.(t);
300
+ return super.next(t);
301
+ }
302
+ error(e) {
303
+ this.subscriber.error?.(e);
304
+ return super.error(e);
305
+ }
306
+ complete() {
307
+ this.subscriber.complete?.();
308
+ return super.complete();
309
+ }
310
+ }
311
+ class FirstOperator extends Subject {
312
+ next(t) {
313
+ const next = super.next(t);
314
+ this.complete();
315
+ return next;
316
+ }
317
+ }
318
+ class LastOperator extends Subject {
319
+ #latest;
320
+ next(t) {
321
+ this.#latest = t;
322
+ }
323
+ complete() {
324
+ if (this.#latest !== undefined) {
325
+ super.next(this.#latest);
326
+ }
327
+ return super.complete();
328
+ }
329
+ }
330
+ export const filter = (fn) => new FilterOperator(fn);
331
+ export const distinct = (fn) => new DistinctOperator(fn ?? Object.is);
332
+ export const first = () => new FirstOperator();
333
+ export const last = () => new LastOperator();
334
+ export const map = (fn) => new MapOperator(fn);
335
+ export const replay = (n) => new ReplaySubject(n);
336
+ export const reduce = (fn, init) => new ReduceOperator(fn, init);
337
+ export const takeUntil = (o) => new TakeUntilOperator(o);
338
+ export const tap = (fn) => new TapOperator(fn);
339
+ export const operator = {
340
+ filter,
341
+ distinct,
342
+ first,
343
+ last,
344
+ map,
345
+ replay,
346
+ reduce,
347
+ takeUntil,
348
+ tap,
349
+ };
@@ -0,0 +1 @@
1
+ export declare function range(start: number, end: number, stride?: number): number[];
@@ -0,0 +1,7 @@
1
+ export function range(start, end, stride = 1) {
2
+ const range = [];
3
+ for (let i = start; i < end; i += stride) {
4
+ range.push(i);
5
+ }
6
+ return range;
7
+ }
@@ -0,0 +1,31 @@
1
+ export declare const isNone: <T>(s: Option<T>) => s is None;
2
+ export declare const isSome: <T>(s: Option<T>) => s is Some<T>;
3
+ export declare function None<T = unknown>(_?: T): Option<T>;
4
+ export declare function Some<T>(t: Option<T>): Option<T>;
5
+ export declare function Some<T>(t: T): Option<T>;
6
+ export declare const isOk: <T, E>(t: Result<T, E>) => t is Ok<T>;
7
+ export declare const isErr: <T, E>(e: Result<T, E>) => e is Err<E>;
8
+ export declare const isResult: <T, E>(t: Result<T, E>) => t is Result<T, E>;
9
+ export declare function Ok<T, _E = unknown>(ok: Ok<T>): T;
10
+ export declare function Ok<T, _E = unknown>(t?: T): Ok<T>;
11
+ export declare function Err<_T, E>(e: Err<E>): E;
12
+ export declare function Err<_T, E>(e: E): Err<E>;
13
+ export declare function Err<_T, E>(e: string): Err<E>;
14
+ export declare function unwrap<T, E>(result: Result<T, E>): T | never;
15
+ export declare function unwrap<O>(some: Option<O>): O | never;
16
+ export declare function unwrapOr<T, E>(result: Result<T, E>, def: T): T;
17
+ export declare function unwrapOr<T>(some: Some<T>, def: T): T;
18
+ export declare function unwrapOrElse<T, E>(result: Result<T, E>, def: () => T): T;
19
+ export declare function unwrapOrElse<T, _E>(some: Some<T>, def: () => T): T;
20
+ export type None = null;
21
+ export type Some<T> = T;
22
+ export type Option<T> = Some<T> | None;
23
+ export type Err<E = Error> = {
24
+ err: E;
25
+ map: <U>(fn: (t: unknown) => Result<U>) => Result<U>;
26
+ };
27
+ export type Ok<T> = {
28
+ ok: T;
29
+ map: <U>(fn: (t: T) => Result<U>) => Result<U>;
30
+ };
31
+ export type Result<T, E = Error> = Ok<T> | Err<E>;
@@ -0,0 +1,66 @@
1
+ export const isNone = (s) => s === null;
2
+ export const isSome = (s) => s != null;
3
+ export function None(_) {
4
+ return null;
5
+ }
6
+ export function Some(t) {
7
+ return t;
8
+ }
9
+ export const isOk = (t) => t && Object.hasOwn(t, "ok");
10
+ export const isErr = (e) => e && Object.hasOwn(e, "err");
11
+ export const isResult = (t) => isOk(t) || isErr(t);
12
+ export function Ok(t) {
13
+ return isOk(t)
14
+ ? t.ok
15
+ : {
16
+ ok: t,
17
+ map(fn) {
18
+ return fn(Ok(this));
19
+ },
20
+ };
21
+ }
22
+ export function Err(e) {
23
+ return (e.err ??
24
+ {
25
+ err: e,
26
+ map(_fn) {
27
+ return this;
28
+ },
29
+ });
30
+ }
31
+ export function unwrap(t) {
32
+ if (isNone(t)) {
33
+ throw new Error("Attempted to unwrap None");
34
+ }
35
+ if (isErr(t)) {
36
+ throw Err(t);
37
+ }
38
+ if (isOk(t)) {
39
+ return Ok(t);
40
+ }
41
+ return t;
42
+ }
43
+ export function unwrapOr(t, def) {
44
+ if (isNone(t)) {
45
+ return def;
46
+ }
47
+ if (isErr(t)) {
48
+ return def;
49
+ }
50
+ if (isOk(t)) {
51
+ return Ok(t);
52
+ }
53
+ return t;
54
+ }
55
+ export function unwrapOrElse(t, def) {
56
+ if (isNone(t)) {
57
+ return def();
58
+ }
59
+ if (isErr(t)) {
60
+ return def();
61
+ }
62
+ if (isOk(t)) {
63
+ return Ok(t);
64
+ }
65
+ return t;
66
+ }
@@ -0,0 +1 @@
1
+ export declare const safe: <A extends unknown[], R>(fn: (...args: A) => R, r: R) => ((...args: A) => R);
@@ -0,0 +1,10 @@
1
+ import { error } from "./log.js";
2
+ export const safe = (fn, r) => (...args) => {
3
+ try {
4
+ return fn(...args);
5
+ }
6
+ catch (e) {
7
+ error(`${e}`);
8
+ return r;
9
+ }
10
+ };
@@ -0,0 +1,5 @@
1
+ import type { MiddlewareFactory } from "./index.ts";
2
+ /**
3
+ * Searches up the request path until the first index is found.
4
+ */
5
+ export declare const findIndex: MiddlewareFactory;