Co-authored-by: Julien Valverdé <julien.valverde@mailo.com> Reviewed-on: https://git.jvalver.de/Thilawyn/traitify-ts/pulls/20
This commit was merged in pull request #20.
This commit is contained in:
17
package.json
17
package.json
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@thilawyn/traitify-ts",
|
||||
"version": "0.1.19",
|
||||
"version": "0.1.20",
|
||||
"type": "module",
|
||||
"publishConfig": {
|
||||
"registry": "https://git.jvalver.de/api/packages/thilawyn/npm/"
|
||||
@@ -29,16 +29,19 @@
|
||||
"clean:node": "rm -rf node_modules"
|
||||
},
|
||||
"dependencies": {
|
||||
"lodash-es": "^4.17.21",
|
||||
"type-fest": "^4.14.0"
|
||||
"remeda": "^1.61.0",
|
||||
"type-fest": "^4.18.0"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@types/lodash-es": "^4.17.12",
|
||||
"bun-types": "latest",
|
||||
"npm-check-updates": "^16.14.17",
|
||||
"npm-check-updates": "^16.14.20",
|
||||
"npm-sort": "^0.0.4",
|
||||
"tsup": "^8.0.2",
|
||||
"tsx": "^4.7.1",
|
||||
"typescript": "^5.4.3"
|
||||
"tsx": "^4.7.3",
|
||||
"typescript": "^5.4.5"
|
||||
},
|
||||
"optionalDependencies": {
|
||||
"@effect/schema": "^0.66.12",
|
||||
"effect": "^3.1.0"
|
||||
}
|
||||
}
|
||||
|
||||
@@ -13,14 +13,13 @@ export class TraitExpression<
|
||||
readonly traits: Traits,
|
||||
) {}
|
||||
|
||||
|
||||
get extends(): (
|
||||
AbstractClass<
|
||||
InstanceType<Superclass> & // Keep the instance of the superclass outside of any kind of type manipulation
|
||||
// as it can accidentely remove abstract properties
|
||||
Simplify<
|
||||
Extend<
|
||||
TraitTuple.MapImplInstance<Traits>
|
||||
>
|
||||
Extend<TraitTuple.MapImplInstance<Traits>>
|
||||
>,
|
||||
|
||||
ConstructorParameters<Superclass>
|
||||
@@ -39,16 +38,20 @@ export class TraitExpression<
|
||||
) as any
|
||||
}
|
||||
|
||||
staticImplements(target: StaticImplements<typeof this>, context: any) {}
|
||||
|
||||
staticImplements(_target: StaticImplements<typeof this>, _context: any) {}
|
||||
|
||||
get staticImplementsStage2() {
|
||||
return (_target: StaticImplements<typeof this>) => {}
|
||||
}
|
||||
|
||||
|
||||
subtrait<
|
||||
This extends TraitExpression<typeof TraitExpression.NullSuperclass, any>
|
||||
>(
|
||||
this: This
|
||||
) {
|
||||
return new TraitBuilder<
|
||||
This,
|
||||
|
||||
return new TraitBuilder<This,
|
||||
Simplify<
|
||||
Extend<TraitTuple.MapAbstract<Traits>>
|
||||
>,
|
||||
@@ -77,7 +80,7 @@ export namespace TraitExpression {
|
||||
const nullSuperclassSymbol = Symbol()
|
||||
export class NullSuperclass {
|
||||
static readonly [nullSuperclassSymbol]: true
|
||||
constructor(...args: any[]) {}
|
||||
constructor(..._args: any[]) {}
|
||||
}
|
||||
|
||||
export type Superclass<T> = (
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
import { uniq } from "lodash-es"
|
||||
import { unique } from "remeda"
|
||||
import { AbstractClass, IsEqual } from "type-fest"
|
||||
import { Trait, TraitTuple } from "./Trait"
|
||||
import { TraitExpression } from "./TraitExpression"
|
||||
@@ -36,7 +36,7 @@ export class TraitExpressionBuilder<
|
||||
]) as readonly Trait<any, any, any, any>[] as TraitExpressionBuilder.SpreadSupertraits<T>
|
||||
}
|
||||
|
||||
static traitsUniq<
|
||||
static traitsUnique<
|
||||
const T extends readonly Trait<
|
||||
TraitExpression<
|
||||
typeof TraitExpression.NullSuperclass,
|
||||
@@ -49,7 +49,7 @@ export class TraitExpressionBuilder<
|
||||
>(
|
||||
traits: T
|
||||
) {
|
||||
return uniq(traits) as readonly Trait<any, any, any, any>[] as TraitExpressionBuilder.TraitsUniq<T>
|
||||
return unique(traits) as readonly Trait<any, any, any, any>[] as TraitExpressionBuilder.TraitsUnique<T>
|
||||
}
|
||||
|
||||
|
||||
@@ -83,7 +83,7 @@ export class TraitExpressionBuilder<
|
||||
return new this.constructor(
|
||||
this.expressionSuperclass,
|
||||
|
||||
this.constructor.traitsUniq([
|
||||
this.constructor.traitsUnique([
|
||||
...this.expressionTraits,
|
||||
...this.constructor.spreadSupertraits(traits),
|
||||
]),
|
||||
@@ -109,7 +109,7 @@ export class TraitExpressionBuilder<
|
||||
return new this.constructor(
|
||||
this.expressionSuperclass,
|
||||
|
||||
this.constructor.traitsUniq([
|
||||
this.constructor.traitsUnique([
|
||||
...this.constructor.spreadSupertraits(traits),
|
||||
...this.expressionTraits,
|
||||
]),
|
||||
@@ -154,14 +154,14 @@ export namespace TraitExpressionBuilder {
|
||||
: readonly []
|
||||
)
|
||||
|
||||
export type TraitsUniq<Traits> = (
|
||||
export type TraitsUnique<Traits> = (
|
||||
Traits extends readonly [
|
||||
...infer Rest,
|
||||
infer El extends Trait<any, any, any, any>,
|
||||
]
|
||||
? IsTraitInTupleFromRight<Rest, El> extends true
|
||||
? TraitsUniq<Rest>
|
||||
: readonly [...TraitsUniq<Rest>, El]
|
||||
? TraitsUnique<Rest>
|
||||
: readonly [...TraitsUnique<Rest>, El]
|
||||
: readonly []
|
||||
)
|
||||
type IsTraitInTupleFromRight<Traits, T> = (
|
||||
@@ -176,7 +176,7 @@ export namespace TraitExpressionBuilder {
|
||||
Traits extends readonly Trait<any, any, any, any>[],
|
||||
T extends readonly Trait<any, any, any, any>[],
|
||||
> = (
|
||||
TraitExpressionBuilder.TraitsUniq<readonly [
|
||||
TraitExpressionBuilder.TraitsUnique<readonly [
|
||||
...Traits,
|
||||
...TraitExpressionBuilder.SpreadSupertraits<T>,
|
||||
]>
|
||||
@@ -186,7 +186,7 @@ export namespace TraitExpressionBuilder {
|
||||
Traits extends readonly Trait<any, any, any, any>[],
|
||||
T extends readonly Trait<any, any, any, any>[],
|
||||
> = (
|
||||
TraitExpressionBuilder.TraitsUniq<readonly [
|
||||
TraitExpressionBuilder.TraitsUnique<readonly [
|
||||
...TraitExpressionBuilder.SpreadSupertraits<T>,
|
||||
...Traits,
|
||||
]>
|
||||
|
||||
39
src/effect.ts
Normal file
39
src/effect.ts
Normal file
@@ -0,0 +1,39 @@
|
||||
import { Schema as S } from "@effect/schema"
|
||||
import { Simplify } from "type-fest"
|
||||
import { Trait, TraitTuple } from "./Trait"
|
||||
import { TraitExpression } from "./TraitExpression"
|
||||
import { Extend } from "./util"
|
||||
|
||||
|
||||
export function extendsEffectSchemaExpression<
|
||||
Fields extends S.Struct.Fields,
|
||||
A, I, R, C,
|
||||
Inherited extends object,
|
||||
Proto,
|
||||
|
||||
const Traits extends readonly Trait<any, any, any, any>[],
|
||||
>(
|
||||
expression: TraitExpression<
|
||||
S.Class<unknown, Fields, A, I, R, C, Inherited, Proto>,
|
||||
Traits
|
||||
>
|
||||
) {
|
||||
return <Self>(): (
|
||||
S.Class<
|
||||
Self,
|
||||
Fields,
|
||||
A, I, R, C,
|
||||
Simplify<
|
||||
Extend<[
|
||||
Inherited,
|
||||
...TraitTuple.MapImplInstance<Traits>
|
||||
]>
|
||||
>,
|
||||
Proto
|
||||
> &
|
||||
|
||||
Simplify<
|
||||
Extend<TraitTuple.MapImplStaticMembers<Traits>>
|
||||
>
|
||||
) => expression.extends as any
|
||||
}
|
||||
@@ -2,3 +2,4 @@ export { Trait, TraitClass, TraitConcreteClass, TraitInstance, TraitStaticMember
|
||||
export { ImplStatic, TraitBuilder, implStaticInstantiableThis, implStaticThis, trait } from "./TraitBuilder"
|
||||
export { Implements, StaticImplements, TraitExpression, TraitExpressionClass, TraitExpressionConcreteClass, TraitExpressionInstance, TraitExpressionStaticMembers } from "./TraitExpression"
|
||||
export { TraitExpressionBuilder, expression } from "./TraitExpressionBuilder"
|
||||
export { extendsEffectSchemaExpression } from "./effect"
|
||||
|
||||
@@ -2,7 +2,7 @@ import { defineConfig } from "tsup"
|
||||
|
||||
|
||||
export default defineConfig({
|
||||
entry: ["src/lib.ts"],
|
||||
entry: ["./src/lib.ts"],
|
||||
format: ["esm", "cjs"],
|
||||
dts: true,
|
||||
splitting: false,
|
||||
|
||||
Reference in New Issue
Block a user