⚝
One Hat Cyber Team
⚝
Your IP:
216.73.216.1
Server IP:
185.238.29.86
Server:
Linux server2 6.8.12-6-pve #1 SMP PREEMPT_DYNAMIC PMX 6.8.12-6 (2024-12-19T19:05Z) x86_64
Server Software:
nginx/1.18.0
PHP Version:
8.1.31
Buat File
|
Buat Folder
Eksekusi
Dir :
~
/
var
/
www
/
invoice
/
node_modules
/
type-fest
/
source
/
View File Name :
merge-exclusive.d.ts
// Helper type. Not useful on its own. type Without<FirstType, SecondType> = {[KeyType in Exclude<keyof FirstType, keyof SecondType>]?: never}; /** Create a type that has mutually exclusive keys. This type was inspired by [this comment](https://github.com/Microsoft/TypeScript/issues/14094#issuecomment-373782604). This type works with a helper type, called `Without`. `Without<FirstType, SecondType>` produces a type that has only keys from `FirstType` which are not present on `SecondType` and sets the value type for these keys to `never`. This helper type is then used in `MergeExclusive` to remove keys from either `FirstType` or `SecondType`. @example ``` import {MergeExclusive} from 'type-fest'; interface ExclusiveVariation1 { exclusive1: boolean; } interface ExclusiveVariation2 { exclusive2: string; } type ExclusiveOptions = MergeExclusive<ExclusiveVariation1, ExclusiveVariation2>; let exclusiveOptions: ExclusiveOptions; exclusiveOptions = {exclusive1: true}; //=> Works exclusiveOptions = {exclusive2: 'hi'}; //=> Works exclusiveOptions = {exclusive1: true, exclusive2: 'hi'}; //=> Error ``` */ export type MergeExclusive<FirstType, SecondType> = (FirstType | SecondType) extends object ? (Without<FirstType, SecondType> & SecondType) | (Without<SecondType, FirstType> & FirstType) : FirstType | SecondType;