Skip to content

Commit

Permalink
Merge pull request #295 from jacob-alford/ja/fix-class-downstream
Browse files Browse the repository at this point in the history
chore: fix downstream type inference
  • Loading branch information
jacob-alford authored Oct 10, 2023
2 parents d9622ef + 0f8a83d commit 8679500
Show file tree
Hide file tree
Showing 4 changed files with 181 additions and 17 deletions.
158 changes: 158 additions & 0 deletions docs/schemata/Struct.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,17 @@ Added in v1.4.0

- [Combinators](#combinators)
- [Struct](#struct)
- [Transformations](#transformations)
- [StructSchema (class)](#structschema-class)
- [pick (property)](#pick-property)
- [omit (property)](#omit-property)
- [partial (property)](#partial-property)
- [partialOption (property)](#partialoption-property)
- [readonly (property)](#readonly-property)
- [strict (property)](#strict-property)
- [addIndexSignature (property)](#addindexsignature-property)
- [extend (property)](#extend-property)
- [intersect (property)](#intersect-property)

---

Expand All @@ -40,3 +51,150 @@ export declare const Struct: <T extends Record<string, Schema<any, any>>, Ix ext
```
Added in v1.0.0
# Transformations
## StructSchema (class)
Use `Struct({})` schema combinator instead
**Signature**
```ts
export declare class StructSchema<T, Ix> {
constructor(private readonly props: T, private readonly indexSignature?: ExtraProps<Ix>)
}
```

Added in v2.1.0

### pick (property)

Re-declares a StructSchema by only including specified properties.

Returns a new `StructSchema`

**Signature**

```ts
readonly pick: <K extends keyof T>(...keys: readonly K[]) => StructSchema<{ [KeyType in keyof Pick<T, K>]: Pick<T, K>[KeyType]; }, Ix>
```

Added in v2.1.0

### omit (property)

Re-declares a StructSchema by excluding specified properties.

Returns a new `StructSchema`

**Signature**

```ts
readonly omit: <K extends keyof T>(...keys: readonly K[]) => StructSchema<{ [KeyType in keyof Pick<T, Exclude<keyof T, K>>]: Pick<T, Exclude<keyof T, K>>[KeyType]; }, Ix>
```

Added in v2.1.0

### partial (property)

Marks all properties as optional; applies `Partial` to both input and output types.

Returns a new schema.

**Signature**

```ts
readonly partial: () => Schema<Simplify<Partial<Input<T, Ix>>>, Simplify<Partial<Output<T, Ix>>>>
```

Added in v2.1.0

### partialOption (property)

A variant of `partial` that applies `Partial` to input properties and maps each
output property to the fp-ts `Option` type.

Returns a new schema.

**Signature**

```ts
readonly partialOption: () => Schema<Simplify<Partial<Input<T, Ix>>>, Simplify<OptionOutput<T, Ix>>>
```

Added in v2.1.0

### readonly (property)

Marks all properties as readonly; applies `Readonly` to both input and output types.

Returns a new schema.

**Signature**

```ts
readonly readonly: () => Schema<Simplify<Readonly<Input<T, Ix>>>, Simplify<Readonly<Output<T, Ix>>>>
```

Added in v2.1.0

### strict (property)

Sets a Struct Schema's index signature to be strict

Returns a new `StructSchema`.

**Signature**

```ts
readonly strict: () => StructSchema<T, undefined>
```

Added in v2.1.0

### addIndexSignature (property)

Adds an index signature to a Struct Schema.

Returns a new `StructSchema`.

**Signature**

```ts
readonly addIndexSignature: <Ix2 extends Schema<any, any>>(indexSignature: Ix2) => StructSchema<T, Ix2>
```

Added in v2.1.0

### extend (property)

Extends a Struct Schema with additional properties. Keys specified in `props` will
overwrite keys in `this`.

Returns a new `StructSchema`.

**Signature**

```ts
readonly extend: <T2 extends Record<string, Schema<any, any>>>(props: T2) => StructSchema<Spread<T, T2>, Ix>
```

Added in v2.1.0

### intersect (property)

Intersects the present Struct Schema with another effectively concatenating their
keys. Keys in `this` will be overwritten with identical keys in `that`.

**Note:** The index signature of `that` will be discarded.

Returns a new `StructSchema`.

**Signature**

```ts
readonly intersect: <T2 extends Record<string, Schema<any, any>>>(that: StructSchema<T2, any>) => StructSchema<Spread<T, T2>, Ix>
```

Added in v2.1.0
30 changes: 15 additions & 15 deletions docs/schemata/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -82,23 +82,23 @@ has_children: true

### String (17)

* Ascii ([docs](https://jacob-alford.github.io/schemata-ts/schemata/Ascii.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/Ascii.ts)) (e.g: `]VadFaS<`, `h2 {`, `6~3n )`)
* Base64 ([docs](https://jacob-alford.github.io/schemata-ts/schemata/Base64.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/Base64.ts)) (e.g: `3/G/+aUW+F+5S80xef/Vuj2W+k3+5Rd/`, `3+8+//h+`, `/o79pZ//++63yV+mV/+1Iu2t/JYy/Oc/+EI6+0==`)
* Base64Url ([docs](https://jacob-alford.github.io/schemata-ts/schemata/Base64Url.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/Base64Url.ts)) (e.g: `b__-bA`, `_CX67Cm`, `-mN-hBs-1b`)
* BitcoinAddress ([docs](https://jacob-alford.github.io/schemata-ts/schemata/BitcoinAddress.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/BitcoinAddress.ts)) (e.g: `bc16wfmybhcf3jozffw2dn30tuhgf39a7s8k7`, `3iyPKiQRyMTqvXUDV3DBFnoAb4`, `2QkQcd7Lkj6JLgAFhLkobsB153Co1GYamADJYQFD`)
* Ascii ([docs](https://jacob-alford.github.io/schemata-ts/schemata/Ascii.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/Ascii.ts)) (e.g: `.2~pj`, `Xzicp`, `(<{nIBab`)
* Base64 ([docs](https://jacob-alford.github.io/schemata-ts/schemata/Base64.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/Base64.ts)) (e.g: `C6/h//++`, `8Z/AD/6p++==`, `phn/++/+/m++8+8W4//vQ2++/EDH`)
* Base64Url ([docs](https://jacob-alford.github.io/schemata-ts/schemata/Base64Url.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/Base64Url.ts)) (e.g: `1w__-e0-_`, `l_-_VZ5_-_`, `pHz7_b5`)
* BitcoinAddress ([docs](https://jacob-alford.github.io/schemata-ts/schemata/BitcoinAddress.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/BitcoinAddress.ts)) (e.g: `3CXSUGbZ85hnkAcLaLL2wRc3FpK8R`, `2J5rM1HcLAKA2CLyhRmsKHJA3wwUWLQn`, `bc1os8pxxfe76tsa6l91nsp518bqh549y`)
* CamelCaseString ([docs](https://jacob-alford.github.io/schemata-ts/schemata/CamelCaseString.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/CamelCaseString.ts)) (e.g: `Camel_case-string``camelCaseString`)
* CreditCard ([docs](https://jacob-alford.github.io/schemata-ts/schemata/CreditCard.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/CreditCard.ts)) (e.g: `6283588107863572`, `65971290953001950`, `62820139863139410`)
* EmailAddress ([docs](https://jacob-alford.github.io/schemata-ts/schemata/EmailAddress.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/EmailAddress.ts)) (e.g: `x}?+/%.+/*%}~#~&&.=%^_}-.^~|+%{5=.#}.#.}+_&+$./=_?&7_{.}G#!+|'.'@[2.8.7.547]`, `"䛐ﭰ챝賅䤄䔚숍�৙"@-F2-W.hS-----.-5-g-l2T.----R--Om.QGGkwcHbWi`, `"銴顳"@[16.68.96.2]`)
* EthereumAddress ([docs](https://jacob-alford.github.io/schemata-ts/schemata/EthereumAddress.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/EthereumAddress.ts)) (e.g: `0x1Eb5aFB9D0F0cee2bB950C7Aa1cBc7EDAaD3B5AD`, `0xB09AFeE9DdECBBE3fA2d2EE51caE0f7EEED2bf65`, `0xAaB1cC2F1a6C0eD11E5Dd6C0d9eEbecAc8ce43cB`)
* HexColor ([docs](https://jacob-alford.github.io/schemata-ts/schemata/HexColor.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/HexColor.ts)) (e.g: `aDC1Ac`, `E7f0Fc`, `a8EC6bDd`)
* Hexadecimal ([docs](https://jacob-alford.github.io/schemata-ts/schemata/Hexadecimal.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/Hexadecimal.ts)) (e.g: `0xeAec99f0`, `0HCC2E`, `0HFDfBD`)
* HslColor ([docs](https://jacob-alford.github.io/schemata-ts/schemata/HslColor.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/HslColor.ts)) (e.g: `hsla(-.60turn,0000.87765e622%,+.0933e57743766624%,186e-22729)`, `hsla(409822e8520+65.015193067e-99652845382%.4444206e98%/99515%)`, `hsla(61058,+003%,0000022e45%)`)
* Jwt ([docs](https://jacob-alford.github.io/schemata-ts/schemata/Jwt.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/Jwt.ts)) (e.g: `--f.-_c3-Q.bZ`, `._Ba__-aG`, `.4K_N_D_L`)
* LatLong ([docs](https://jacob-alford.github.io/schemata-ts/schemata/LatLong.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/LatLong.ts)) (e.g: `(89,180.0000)`, `(-90.0000000000,177)`, `(90,127)`)
* NonEmptyString ([docs](https://jacob-alford.github.io/schemata-ts/schemata/NonEmptyString.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/NonEmptyString.ts)) (e.g: `valueOf=`, `{;%oUQ`, `qC73keycalltoStr`)
* RGB ([docs](https://jacob-alford.github.io/schemata-ts/schemata/RGB.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/RGB.ts)) (e.g: `rgba(100%,100%,100%,0)`, `rgba(99%,2%,100%,.2)`, `rgba(100%,93%,93%,1.0)`)
* CreditCard ([docs](https://jacob-alford.github.io/schemata-ts/schemata/CreditCard.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/CreditCard.ts)) (e.g: `62411770467721586`, `3528751036300588292`, `50864381596660195`)
* EmailAddress ([docs](https://jacob-alford.github.io/schemata-ts/schemata/EmailAddress.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/EmailAddress.ts)) (e.g: `{#/_/!__.$?C.?~{5_-%=.$?'=^?*.7/_'}=~$}%.-.=.^|_+&&^#-!.{}#|%}=!+@[6.39.1.537]`, `!^-A&zs#|}.#%$?+W^{/+~%.+-.}{+''!8{P._#*'~.$?$~_.|8~&@I5w.6-fQ44O-q..u7-fE..195-M-Ei03.0XC-76-c5.-x-C.gMYwxOeuJIHhaF`, `"뾰㷯鏎￳￰"@[30.49.838.25]`)
* EthereumAddress ([docs](https://jacob-alford.github.io/schemata-ts/schemata/EthereumAddress.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/EthereumAddress.ts)) (e.g: `0xAB05bEd1ADA0ADa39ddeFBABEAa0af8300CFbAC9`, `0xC39f07eEc1f5B0d17C3d2FbcddbDBDC0bEAaccCd`, `0xC8AC7ECbC47DFD82e5cF8Beb3eF0fDDDdBB1EAAf`)
* HexColor ([docs](https://jacob-alford.github.io/schemata-ts/schemata/HexColor.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/HexColor.ts)) (e.g: `12d1f625`, `0713CDBA`, `#F1CaCFe9`)
* Hexadecimal ([docs](https://jacob-alford.github.io/schemata-ts/schemata/Hexadecimal.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/Hexadecimal.ts)) (e.g: `2c21AdFd815`, `0Hb21A`, `0H38EBAAd`)
* HslColor ([docs](https://jacob-alford.github.io/schemata-ts/schemata/HslColor.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/HslColor.ts)) (e.g: `hsla(.4384991e+058689613121,0.7438854870%,95e-37766%,8727511084e0)`, `hsl(242.2323248grad00000000.7039915138e+3889361%0100e+97581358157%/187.9e808)`, `hsl(.51e+10turn,00000100%,000.6879%)`)
* Jwt ([docs](https://jacob-alford.github.io/schemata-ts/schemata/Jwt.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/Jwt.ts)) (e.g: `8-._X._3f`, `._aA_s7-`, `_-5-9-_nD.30-PZ`)
* LatLong ([docs](https://jacob-alford.github.io/schemata-ts/schemata/LatLong.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/LatLong.ts)) (e.g: `-90.000000,98.6358`, `90.000,180`, `90.00000,178`)
* NonEmptyString ([docs](https://jacob-alford.github.io/schemata-ts/schemata/NonEmptyString.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/NonEmptyString.ts)) (e.g: `,hP5brRD2W`, `"\_M{#@~!`, `C W`)
* RGB ([docs](https://jacob-alford.github.io/schemata-ts/schemata/RGB.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/RGB.ts)) (e.g: `rgb(206,112,200)`, `rgba(82%,100%,96%,.80)`, `rgba(206,71,200,0.6815)`)
* String ([docs](https://jacob-alford.github.io/schemata-ts/schemata/String.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/String.ts))
* UUID ([docs](https://jacob-alford.github.io/schemata-ts/schemata/UUID.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/UUID.ts)) (e.g: `BaE39c9C-b9DC-c6Ca-3CB8-BEBc2bb2Ac6a`, `6A96fE3D-f88e-ebAD-C8Cf-90C976aA22BF`, `dC2eEAAc-1fd0-bfd0-2bbB-c9DdaF232abC`)
* UUID ([docs](https://jacob-alford.github.io/schemata-ts/schemata/UUID.html)) ([source](https://github.com/jacob-alford/schemata-ts/tree/main/src/schemata/UUID.ts)) (e.g: `eCcAfcbB-b8e5-2CeC-f20c-Bda9DAca8Af9`, `f5ccB60e-9AAC-C68a-Bf1b-F8CEE23Bf9aA`, `8fC88f3F-462b-ecc1-aaA5-bDCacEfbAA2f`)

### Unit (1)

Expand Down
1 change: 1 addition & 0 deletions scripts/gen-docs-schemas.ts
Original file line number Diff line number Diff line change
Expand Up @@ -108,6 +108,7 @@ export const genSchemas: Build<void> = _ =>
RA.findLastMap(line =>
pipe(
O.fromNullable(line.match(/@category\b(.*)\b/)),
O.map(RA.filter(category => !category.includes('Transformations'))),
O.chain(RA.head),
O.map(categoryString =>
tuple(
Expand Down
9 changes: 7 additions & 2 deletions src/schemata/Struct.ts
Original file line number Diff line number Diff line change
Expand Up @@ -64,8 +64,13 @@ type OptionOutput<T extends PropBase, Ix extends IxSigBase> = Simplify<
RestOutput<Ix> & OptionOutputProps<T>
>

/** @since 2.1.0 */
class StructSchema<T extends PropBase, Ix extends IxSigBase>
/**
* Use `Struct({})` schema combinator instead
*
* @since 2.1.0
* @category Transformations
*/
export class StructSchema<T extends PropBase, Ix extends IxSigBase>
extends SchemaImplementation<Input<T, Ix>, Output<T, Ix>>
implements Schema<Input<T, Ix>, Output<T, Ix>>
{
Expand Down

0 comments on commit 8679500

Please sign in to comment.