Changed ObservableClass API
All checks were successful
Lint / lint (push) Successful in 11s

This commit is contained in:
Julien Valverdé
2024-08-26 03:28:50 +02:00
parent 7b3ed49369
commit 9ee50bfd19
2 changed files with 14 additions and 19 deletions

View File

@@ -8,10 +8,10 @@ interface ObservableClassSelf {
readonly fields: { readonly [K in keyof Schema.Struct.Fields]: Schema.Struct.Fields[K] } readonly fields: { readonly [K in keyof Schema.Struct.Fields]: Schema.Struct.Fields[K] }
} }
export const ObservableClass = <Self extends ObservableClassSelf>( interface ObservableClassOptions extends Omit<CreateObservableOptions, "proxy"> {}
self: Self,
options?: Omit<CreateObservableOptions, "proxy">, export const ObservableClass = (options?: ObservableClassOptions) =>
) => <Self extends ObservableClassSelf>(self: Self) =>
class Observable extends self { class Observable extends self {
declare ["constructor"]: typeof Observable declare ["constructor"]: typeof Observable
@@ -24,8 +24,3 @@ export const ObservableClass = <Self extends ObservableClassSelf>(
) )
} }
} as Self } as Self
export const ObservableClassDual: {
<Self extends ObservableClassSelf>(options?: Omit<CreateObservableOptions, "proxy">): (self: Self) => Self
<Self extends ObservableClassSelf>(self: Self, options?: Omit<CreateObservableOptions, "proxy">): Self
} = () => {}

View File

@@ -22,7 +22,7 @@ class User extends MutableTaggedClass<User>()("User", {
id: S.BigIntFromSelf, id: S.BigIntFromSelf,
role: S.Union(S.Literal("BasicUser"), S.Literal("Admin")), role: S.Union(S.Literal("BasicUser"), S.Literal("Admin")),
}).pipe( }).pipe(
ObservableClass ObservableClass()
) {} ) {}
const JsonifiableUser = User.pipe( const JsonifiableUser = User.pipe(