0.1.15 #16

Merged
Thilawyn merged 12 commits from next into master 2024-09-04 00:33:45 +02:00
2 changed files with 14 additions and 19 deletions
Showing only changes of commit 9ee50bfd19 - Show all commits

View File

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

View File

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