12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414 |
- /**
- * This file provides type definitions for use with the Flow type checker.
- *
- * An important caveat when using these definitions is that the types for
- * `Collection.Keyed`, `Collection.Indexed`, `Seq.Keyed`, and so on are stubs.
- * When referring to those types, you can get the proper definitions by
- * importing the types `KeyedCollection`, `IndexedCollection`, `KeyedSeq`, etc.
- * For example,
- *
- * import { Seq } from 'immutable'
- * import type { IndexedCollection, IndexedSeq } from 'immutable'
- *
- * const someSeq: IndexedSeq<number> = Seq.Indexed.of(1, 2, 3)
- *
- * function takesASeq<T, TS: IndexedCollection<T>>(iter: TS): TS {
- * return iter.butLast()
- * }
- *
- * takesASeq(someSeq)
- *
- * @flow strict
- */
- // Helper type that represents plain objects allowed as arguments to
- // some constructors and functions.
- type PlainObjInput<K, V> = { +[key: K]: V, __proto__: null };
- type K<T> = $Keys<T>;
- // Helper types to extract the "keys" and "values" use by the *In() methods.
- type $KeyOf<C> = $Call<
- (<K>(?_Collection<K, mixed>) => K) &
- (<T>(?$ReadOnlyArray<T>) => number) &
- (<T>(?RecordInstance<T> | T) => $Keys<T>) &
- (<T: Object>(T) => $Keys<T>),
- C,
- >;
- type $ValOf<C, K = $KeyOf<C>> = $Call<
- (<V>(?_Collection<any, V>) => V) &
- (<T>(?$ReadOnlyArray<T>) => T) &
- (<T, K: $Keys<T>>(?RecordInstance<T> | T, K) => $ElementType<T, K>) &
- (<T: Object>(T) => $Values<T>),
- C,
- K,
- >;
- type $IterableOf<C> = $Call<
- (<V: Array<any> | IndexedCollection<any> | SetCollection<any>>(
- V
- ) => Iterable<$ValOf<V>>) &
- (<
- V:
- | KeyedCollection<any, any>
- | RecordInstance<any>
- | PlainObjInput<any, any>,
- >(
- V
- ) => Iterable<[$KeyOf<V>, $ValOf<V>]>),
- C,
- >;
- const PairSorting: $ReadOnly<{ LeftThenRight: number, RightThenLeft: number }> =
- {
- LeftThenRight: -1,
- RightThenLeft: +1,
- };
- type Comparator<T> = (left: T, right: T) => number;
- declare class _Collection<K, +V> implements ValueObject {
- equals(other: mixed): boolean;
- hashCode(): number;
- get(key: K, ..._: []): V | void;
- get<NSV>(key: K, notSetValue: NSV): V | NSV;
- has(key: K): boolean;
- includes(value: V): boolean;
- contains(value: V): boolean;
- first(): V | void;
- first<NSV>(notSetValue: NSV): V | NSV;
- last(): V | void;
- last<NSV>(notSetValue: NSV): V | NSV;
- hasIn(keyPath: Iterable<mixed>): boolean;
- getIn(keyPath: [], notSetValue?: mixed): this;
- getIn<NSV>(keyPath: [K], notSetValue: NSV): V | NSV;
- getIn<NSV, K2: $KeyOf<V>>(
- keyPath: [K, K2],
- notSetValue: NSV
- ): $ValOf<V, K2> | NSV;
- getIn<NSV, K2: $KeyOf<V>, K3: $KeyOf<$ValOf<V, K2>>>(
- keyPath: [K, K2, K3],
- notSetValue: NSV
- ): $ValOf<$ValOf<V, K2>, K3> | NSV;
- getIn<
- NSV,
- K2: $KeyOf<V>,
- K3: $KeyOf<$ValOf<V, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<V, K2>, K3>>,
- >(
- keyPath: [K, K2, K3, K4],
- notSetValue: NSV
- ): $ValOf<$ValOf<$ValOf<V, K2>, K3>, K4> | NSV;
- getIn<
- NSV,
- K2: $KeyOf<V>,
- K3: $KeyOf<$ValOf<V, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<V, K2>, K3>>,
- K5: $KeyOf<$ValOf<$ValOf<$ValOf<V, K2>, K3>, K4>>,
- >(
- keyPath: [K, K2, K3, K4, K5],
- notSetValue: NSV
- ): $ValOf<$ValOf<$ValOf<$ValOf<V, K2>, K3>, K4>, K5> | NSV;
- update<U>(updater: (value: this) => U): U;
- toJS(): Array<any> | { [key: string]: mixed };
- toJSON(): Array<V> | { [key: string]: V };
- toArray(): Array<V> | Array<[K, V]>;
- toObject(): { [key: string]: V };
- toMap(): Map<K, V>;
- toOrderedMap(): OrderedMap<K, V>;
- toSet(): Set<V>;
- toOrderedSet(): OrderedSet<V>;
- toList(): List<V>;
- toStack(): Stack<V>;
- toSeq(): Seq<K, V>;
- toKeyedSeq(): KeyedSeq<K, V>;
- toIndexedSeq(): IndexedSeq<V>;
- toSetSeq(): SetSeq<V>;
- keys(): Iterator<K>;
- values(): Iterator<V>;
- entries(): Iterator<[K, V]>;
- keySeq(): IndexedSeq<K>;
- valueSeq(): IndexedSeq<V>;
- entrySeq(): IndexedSeq<[K, V]>;
- reverse(): this;
- sort(comparator?: Comparator<V>): this;
- sortBy<C>(
- comparatorValueMapper: (value: V, key: K, iter: this) => C,
- comparator?: Comparator<C>
- ): this;
- groupBy<G>(
- grouper: (value: V, key: K, iter: this) => G,
- context?: mixed
- ): KeyedSeq<G, this>;
- forEach(
- sideEffect: (value: V, key: K, iter: this) => any,
- context?: mixed
- ): number;
- slice(begin?: number, end?: number): this;
- rest(): this;
- butLast(): this;
- skip(amount: number): this;
- skipLast(amount: number): this;
- skipWhile(
- predicate: (value: V, key: K, iter: this) => mixed,
- context?: mixed
- ): this;
- skipUntil(
- predicate: (value: V, key: K, iter: this) => mixed,
- context?: mixed
- ): this;
- take(amount: number): this;
- takeLast(amount: number): this;
- takeWhile(
- predicate: (value: V, key: K, iter: this) => mixed,
- context?: mixed
- ): this;
- takeUntil(
- predicate: (value: V, key: K, iter: this) => mixed,
- context?: mixed
- ): this;
- filterNot(
- predicate: (value: V, key: K, iter: this) => mixed,
- context?: mixed
- ): this;
- reduce<R>(
- reducer: (reduction: R, value: V, key: K, iter: this) => R,
- initialReduction: R,
- context?: mixed
- ): R;
- reduce<R>(reducer: (reduction: V | R, value: V, key: K, iter: this) => R): R;
- reduceRight<R>(
- reducer: (reduction: R, value: V, key: K, iter: this) => R,
- initialReduction: R,
- context?: mixed
- ): R;
- reduceRight<R>(
- reducer: (reduction: V | R, value: V, key: K, iter: this) => R
- ): R;
- every(
- predicate: (value: V, key: K, iter: this) => mixed,
- context?: mixed
- ): boolean;
- some(
- predicate: (value: V, key: K, iter: this) => mixed,
- context?: mixed
- ): boolean;
- join(separator?: string): string;
- isEmpty(): boolean;
- count(
- predicate?: (value: V, key: K, iter: this) => mixed,
- context?: mixed
- ): number;
- countBy<G>(
- grouper: (value: V, key: K, iter: this) => G,
- context?: mixed
- ): Map<G, number>;
- find(
- predicate: (value: V, key: K, iter: this) => mixed,
- context?: mixed,
- notSetValue?: V
- ): V | void;
- findLast(
- predicate: (value: V, key: K, iter: this) => mixed,
- context?: mixed,
- notSetValue?: V
- ): V | void;
- findEntry(predicate: (value: V, key: K, iter: this) => mixed): [K, V] | void;
- findLastEntry(
- predicate: (value: V, key: K, iter: this) => mixed
- ): [K, V] | void;
- findKey(
- predicate: (value: V, key: K, iter: this) => mixed,
- context?: mixed
- ): K | void;
- findLastKey(
- predicate: (value: V, key: K, iter: this) => mixed,
- context?: mixed
- ): K | void;
- keyOf(searchValue: V): K | void;
- lastKeyOf(searchValue: V): K | void;
- max(comparator?: Comparator<V>): V;
- maxBy<C>(
- comparatorValueMapper: (value: V, key: K, iter: this) => C,
- comparator?: Comparator<C>
- ): V;
- min(comparator?: Comparator<V>): V;
- minBy<C>(
- comparatorValueMapper: (value: V, key: K, iter: this) => C,
- comparator?: Comparator<C>
- ): V;
- isSubset(iter: Iterable<V>): boolean;
- isSuperset(iter: Iterable<V>): boolean;
- }
- declare function isImmutable(
- maybeImmutable: mixed
- ): boolean %checks(maybeImmutable instanceof Collection);
- declare function isCollection(
- maybeCollection: mixed
- ): boolean %checks(maybeCollection instanceof Collection);
- declare function isKeyed(
- maybeKeyed: mixed
- ): boolean %checks(maybeKeyed instanceof KeyedCollection);
- declare function isIndexed(
- maybeIndexed: mixed
- ): boolean %checks(maybeIndexed instanceof IndexedCollection);
- declare function isAssociative(
- maybeAssociative: mixed
- ): boolean %checks(maybeAssociative instanceof KeyedCollection ||
- maybeAssociative instanceof IndexedCollection);
- declare function isOrdered(
- maybeOrdered: mixed
- ): boolean %checks(maybeOrdered instanceof IndexedCollection ||
- maybeOrdered instanceof OrderedMap ||
- maybeOrdered instanceof OrderedSet);
- declare function isValueObject(maybeValue: mixed): boolean;
- declare function isSeq(maybeSeq: any): boolean %checks(maybeSeq instanceof Seq);
- declare function isList(maybeList: any): boolean %checks(maybeList instanceof
- List);
- declare function isMap(maybeMap: any): boolean %checks(maybeMap instanceof Map);
- declare function isOrderedMap(
- maybeOrderedMap: any
- ): boolean %checks(maybeOrderedMap instanceof OrderedMap);
- declare function isStack(maybeStack: any): boolean %checks(maybeStack instanceof
- Stack);
- declare function isSet(maybeSet: any): boolean %checks(maybeSet instanceof Set);
- declare function isOrderedSet(
- maybeOrderedSet: any
- ): boolean %checks(maybeOrderedSet instanceof OrderedSet);
- declare function isRecord(
- maybeRecord: any
- ): boolean %checks(maybeRecord instanceof Record);
- declare interface ValueObject {
- equals(other: mixed): boolean;
- hashCode(): number;
- }
- declare class Collection<K, +V> extends _Collection<K, V> {
- static Keyed: typeof KeyedCollection;
- static Indexed: typeof IndexedCollection;
- static Set: typeof SetCollection;
- static isCollection: typeof isCollection;
- static isKeyed: typeof isKeyed;
- static isIndexed: typeof isIndexed;
- static isAssociative: typeof isAssociative;
- static isOrdered: typeof isOrdered;
- }
- declare class KeyedCollection<K, +V> extends Collection<K, V> {
- static <K, V>(
- values?: Iterable<[K, V]> | PlainObjInput<K, V>
- ): KeyedCollection<K, V>;
- toJS(): { [key: string]: mixed };
- toJSON(): { [key: string]: V };
- toArray(): Array<[K, V]>;
- @@iterator(): Iterator<[K, V]>;
- toSeq(): KeyedSeq<K, V>;
- flip(): KeyedCollection<V, K>;
- concat<KC, VC>(
- ...iters: Array<Iterable<[KC, VC]> | PlainObjInput<KC, VC>>
- ): KeyedCollection<K | KC, V | VC>;
- filter(predicate: typeof Boolean): KeyedCollection<K, $NonMaybeType<V>>;
- filter(
- predicate: (value: V, key: K, iter: this) => mixed,
- context?: mixed
- ): KeyedCollection<K, V>;
- partition(
- predicate: (value: V, key: K, iter: this) => mixed,
- context?: mixed
- ): [this, this];
- map<M>(
- mapper: (value: V, key: K, iter: this) => M,
- context?: mixed
- ): KeyedCollection<K, M>;
- mapKeys<M>(
- mapper: (key: K, value: V, iter: this) => M,
- context?: mixed
- ): KeyedCollection<M, V>;
- mapEntries<KM, VM>(
- mapper: (entry: [K, V], index: number, iter: this) => [KM, VM],
- context?: mixed
- ): KeyedCollection<KM, VM>;
- flatMap<KM, VM>(
- mapper: (value: V, key: K, iter: this) => Iterable<[KM, VM]>,
- context?: mixed
- ): KeyedCollection<KM, VM>;
- flatten(depth?: number): KeyedCollection<any, any>;
- flatten(shallow?: boolean): KeyedCollection<any, any>;
- }
- Collection.Keyed = KeyedCollection;
- declare class IndexedCollection<+T> extends Collection<number, T> {
- static <T>(iter?: Iterable<T>): IndexedCollection<T>;
- toJS(): Array<mixed>;
- toJSON(): Array<T>;
- toArray(): Array<T>;
- @@iterator(): Iterator<T>;
- toSeq(): IndexedSeq<T>;
- fromEntrySeq<K, V>(): KeyedSeq<K, V>;
- interpose(separator: T): this;
- interleave(...collections: Iterable<T>[]): this;
- splice(index: number, removeNum: number, ...values: T[]): this;
- zip<A>(a: Iterable<A>, ..._: []): IndexedCollection<[T, A]>;
- zip<A, B>(
- a: Iterable<A>,
- b: Iterable<B>,
- ..._: []
- ): IndexedCollection<[T, A, B]>;
- zip<A, B, C>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- ..._: []
- ): IndexedCollection<[T, A, B, C]>;
- zip<A, B, C, D>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- ..._: []
- ): IndexedCollection<[T, A, B, C, D]>;
- zip<A, B, C, D, E>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- e: Iterable<E>,
- ..._: []
- ): IndexedCollection<[T, A, B, C, D, E]>;
- zipAll<A>(a: Iterable<A>, ..._: []): IndexedCollection<[T | void, A | void]>;
- zipAll<A, B>(
- a: Iterable<A>,
- b: Iterable<B>,
- ..._: []
- ): IndexedCollection<[T | void, A | void, B | void]>;
- zipAll<A, B, C>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- ..._: []
- ): IndexedCollection<[T | void, A | void, B | void, C | void]>;
- zipAll<A, B, C, D>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- ..._: []
- ): IndexedCollection<[T | void, A | void, B | void, C | void, D | void]>;
- zipAll<A, B, C, D, E>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- e: Iterable<E>,
- ..._: []
- ): IndexedCollection<
- [T | void, A | void, B | void, C | void, D | void, E | void],
- >;
- zipWith<A, R>(
- zipper: (value: T, a: A) => R,
- a: Iterable<A>,
- ..._: []
- ): IndexedCollection<R>;
- zipWith<A, B, R>(
- zipper: (value: T, a: A, b: B) => R,
- a: Iterable<A>,
- b: Iterable<B>,
- ..._: []
- ): IndexedCollection<R>;
- zipWith<A, B, C, R>(
- zipper: (value: T, a: A, b: B, c: C) => R,
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- ..._: []
- ): IndexedCollection<R>;
- zipWith<A, B, C, D, R>(
- zipper: (value: T, a: A, b: B, c: C, d: D) => R,
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- ..._: []
- ): IndexedCollection<R>;
- zipWith<A, B, C, D, E, R>(
- zipper: (value: T, a: A, b: B, c: C, d: D, e: E) => R,
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- e: Iterable<E>,
- ..._: []
- ): IndexedCollection<R>;
- indexOf(searchValue: T): number;
- lastIndexOf(searchValue: T): number;
- findIndex(
- predicate: (value: T, index: number, iter: this) => mixed,
- context?: mixed
- ): number;
- findLastIndex(
- predicate: (value: T, index: number, iter: this) => mixed,
- context?: mixed
- ): number;
- concat<C>(...iters: Array<Iterable<C> | C>): IndexedCollection<T | C>;
- filter(predicate: typeof Boolean): IndexedCollection<$NonMaybeType<T>>;
- filter(
- predicate: (value: T, index: number, iter: this) => mixed,
- context?: mixed
- ): IndexedCollection<T>;
- partition(
- predicate: (value: T, index: number, iter: this) => mixed,
- context?: mixed
- ): [this, this];
- map<M>(
- mapper: (value: T, index: number, iter: this) => M,
- context?: mixed
- ): IndexedCollection<M>;
- flatMap<M>(
- mapper: (value: T, index: number, iter: this) => Iterable<M>,
- context?: mixed
- ): IndexedCollection<M>;
- flatten(depth?: number): IndexedCollection<any>;
- flatten(shallow?: boolean): IndexedCollection<any>;
- }
- declare class SetCollection<+T> extends Collection<T, T> {
- static <T>(iter?: Iterable<T>): SetCollection<T>;
- toJS(): Array<mixed>;
- toJSON(): Array<T>;
- toArray(): Array<T>;
- @@iterator(): Iterator<T>;
- toSeq(): SetSeq<T>;
- concat<U>(...collections: Iterable<U>[]): SetCollection<T | U>;
- // `filter`, `map` and `flatMap` cannot be defined further up the hierarchy,
- // because the implementation for `KeyedCollection` allows the value type to
- // change without constraining the key type. That does not work for
- // `SetCollection` - the value and key types *must* match.
- filter(predicate: typeof Boolean): SetCollection<$NonMaybeType<T>>;
- filter(
- predicate: (value: T, value: T, iter: this) => mixed,
- context?: mixed
- ): SetCollection<T>;
- partition(
- predicate: (value: T, value: T, iter: this) => mixed,
- context?: mixed
- ): [this, this];
- map<M>(
- mapper: (value: T, value: T, iter: this) => M,
- context?: mixed
- ): SetCollection<M>;
- flatMap<M>(
- mapper: (value: T, value: T, iter: this) => Iterable<M>,
- context?: mixed
- ): SetCollection<M>;
- flatten(depth?: number): SetCollection<any>;
- flatten(shallow?: boolean): SetCollection<any>;
- }
- declare function isSeq(maybeSeq: mixed): boolean %checks(maybeSeq instanceof
- Seq);
- declare class Seq<K, +V> extends _Collection<K, V> {
- static Keyed: typeof KeyedSeq;
- static Indexed: typeof IndexedSeq;
- static Set: typeof SetSeq;
- static <K, V>(values: KeyedSeq<K, V>): KeyedSeq<K, V>;
- static <T>(values: SetSeq<T>): SetSeq<K, V>;
- static <T>(values: Iterable<T>): IndexedSeq<T>;
- static <K, V>(values?: PlainObjInput<K, V>): KeyedSeq<K, V>;
- static isSeq: typeof isSeq;
- size: number | void;
- cacheResult(): this;
- toSeq(): this;
- }
- declare class KeyedSeq<K, +V> extends Seq<K, V> mixins KeyedCollection<K, V> {
- static <K, V>(
- values?: Iterable<[K, V]> | PlainObjInput<K, V>
- ): KeyedSeq<K, V>;
- // Override specialized return types
- flip(): KeyedSeq<V, K>;
- concat<KC, VC>(
- ...iters: Array<Iterable<[KC, VC]> | PlainObjInput<KC, VC>>
- ): KeyedSeq<K | KC, V | VC>;
- filter(predicate: typeof Boolean): KeyedSeq<K, $NonMaybeType<V>>;
- filter(
- predicate: (value: V, key: K, iter: this) => mixed,
- context?: mixed
- ): KeyedSeq<K, V>;
- partition(
- predicate: (value: V, key: K, iter: this) => mixed,
- context?: mixed
- ): [this, this];
- map<M>(
- mapper: (value: V, key: K, iter: this) => M,
- context?: mixed
- ): KeyedSeq<K, M>;
- mapKeys<M>(
- mapper: (key: K, value: V, iter: this) => M,
- context?: mixed
- ): KeyedSeq<M, V>;
- mapEntries<KM, VM>(
- mapper: (entry: [K, V], index: number, iter: this) => [KM, VM],
- context?: mixed
- ): KeyedSeq<KM, VM>;
- flatMap<KM, VM>(
- mapper: (value: V, key: K, iter: this) => Iterable<[KM, VM]>,
- context?: mixed
- ): KeyedSeq<KM, VM>;
- flatten(depth?: number): KeyedSeq<any, any>;
- flatten(shallow?: boolean): KeyedSeq<any, any>;
- }
- declare class IndexedSeq<+T>
- extends Seq<number, T>
- mixins IndexedCollection<T>
- {
- static <T>(values?: Iterable<T>): IndexedSeq<T>;
- static of<T>(...values: T[]): IndexedSeq<T>;
- // Override specialized return types
- concat<C>(...iters: Array<Iterable<C> | C>): IndexedSeq<T | C>;
- filter(predicate: typeof Boolean): IndexedSeq<$NonMaybeType<T>>;
- filter(
- predicate: (value: T, index: number, iter: this) => mixed,
- context?: mixed
- ): IndexedSeq<T>;
- partition(
- predicate: (value: T, index: number, iter: this) => mixed,
- context?: mixed
- ): [this, this];
- map<M>(
- mapper: (value: T, index: number, iter: this) => M,
- context?: mixed
- ): IndexedSeq<M>;
- flatMap<M>(
- mapper: (value: T, index: number, iter: this) => Iterable<M>,
- context?: mixed
- ): IndexedSeq<M>;
- flatten(depth?: number): IndexedSeq<any>;
- flatten(shallow?: boolean): IndexedSeq<any>;
- zip<A>(a: Iterable<A>, ..._: []): IndexedSeq<[T, A]>;
- zip<A, B>(a: Iterable<A>, b: Iterable<B>, ..._: []): IndexedSeq<[T, A, B]>;
- zip<A, B, C>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- ..._: []
- ): IndexedSeq<[T, A, B, C]>;
- zip<A, B, C, D>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- ..._: []
- ): IndexedSeq<[T, A, B, C, D]>;
- zip<A, B, C, D, E>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- e: Iterable<E>,
- ..._: []
- ): IndexedSeq<[T, A, B, C, D, E]>;
- zipAll<A>(a: Iterable<A>, ..._: []): IndexedSeq<[T | void, A | void]>;
- zipAll<A, B>(
- a: Iterable<A>,
- b: Iterable<B>,
- ..._: []
- ): IndexedSeq<[T | void, A | void, B | void]>;
- zipAll<A, B, C>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- ..._: []
- ): IndexedSeq<[T | void, A | void, B | void, C | void]>;
- zipAll<A, B, C, D>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- ..._: []
- ): IndexedSeq<[T | void, A | void, B | void, C | void, D | void]>;
- zipAll<A, B, C, D, E>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- e: Iterable<E>,
- ..._: []
- ): IndexedSeq<[T | void, A | void, B | void, C | void, D | void, E | void]>;
- zipWith<A, R>(
- zipper: (value: T, a: A) => R,
- a: Iterable<A>,
- ..._: []
- ): IndexedSeq<R>;
- zipWith<A, B, R>(
- zipper: (value: T, a: A, b: B) => R,
- a: Iterable<A>,
- b: Iterable<B>,
- ..._: []
- ): IndexedSeq<R>;
- zipWith<A, B, C, R>(
- zipper: (value: T, a: A, b: B, c: C) => R,
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- ..._: []
- ): IndexedSeq<R>;
- zipWith<A, B, C, D, R>(
- zipper: (value: T, a: A, b: B, c: C, d: D) => R,
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- ..._: []
- ): IndexedSeq<R>;
- zipWith<A, B, C, D, E, R>(
- zipper: (value: T, a: A, b: B, c: C, d: D, e: E) => R,
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- e: Iterable<E>,
- ..._: []
- ): IndexedSeq<R>;
- }
- declare class SetSeq<+T> extends Seq<T, T> mixins SetCollection<T> {
- static <T>(values?: Iterable<T>): SetSeq<T>;
- static of<T>(...values: T[]): SetSeq<T>;
- // Override specialized return types
- concat<U>(...collections: Iterable<U>[]): SetSeq<T | U>;
- filter(predicate: typeof Boolean): SetSeq<$NonMaybeType<T>>;
- filter(
- predicate: (value: T, value: T, iter: this) => mixed,
- context?: mixed
- ): SetSeq<T>;
- partition(
- predicate: (value: T, value: T, iter: this) => mixed,
- context?: mixed
- ): [this, this];
- map<M>(
- mapper: (value: T, value: T, iter: this) => M,
- context?: mixed
- ): SetSeq<M>;
- flatMap<M>(
- mapper: (value: T, value: T, iter: this) => Iterable<M>,
- context?: mixed
- ): SetSeq<M>;
- flatten(depth?: number): SetSeq<any>;
- flatten(shallow?: boolean): SetSeq<any>;
- }
- declare class UpdatableInCollection<K, +V> {
- setIn<S>(keyPath: [], value: S): S;
- setIn(keyPath: [K], value: V): this;
- setIn<K2: $KeyOf<V>, S: $ValOf<V, K2>>(keyPath: [K, K2], value: S): this;
- setIn<K2: $KeyOf<V>, K3: $KeyOf<$ValOf<V, K2>>, S: $ValOf<$ValOf<V, K2>, K3>>(
- keyPath: [K, K2, K3],
- value: S
- ): this;
- setIn<
- K2: $KeyOf<V>,
- K3: $KeyOf<$ValOf<V, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<V, K2>, K3>>,
- S: $ValOf<$ValOf<$ValOf<V, K2>, K3>, K4>,
- >(
- keyPath: [K, K2, K3, K4],
- value: S
- ): this;
- setIn<
- K2: $KeyOf<V>,
- K3: $KeyOf<$ValOf<V, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<V, K2>, K3>>,
- K5: $KeyOf<$ValOf<$ValOf<$ValOf<V, K2>, K3>, K4>>,
- S: $ValOf<$ValOf<$ValOf<$ValOf<V, K2>, K3>, K4>, K5>,
- >(
- keyPath: [K, K2, K3, K4, K5],
- value: S
- ): this;
- deleteIn(keyPath: []): void;
- deleteIn(keyPath: [K]): this;
- deleteIn<K2: $KeyOf<V>>(keyPath: [K, K2]): this;
- deleteIn<K2: $KeyOf<V>, K3: $KeyOf<$ValOf<V, K2>>>(
- keyPath: [K, K2, K3]
- ): this;
- deleteIn<
- K2: $KeyOf<V>,
- K3: $KeyOf<$ValOf<V, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<V, K2>, K3>>,
- >(
- keyPath: [K, K2, K3, K4]
- ): this;
- deleteIn<
- K2: $KeyOf<V>,
- K3: $KeyOf<$ValOf<V, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<V, K2>, K3>>,
- K5: $KeyOf<$ValOf<$ValOf<$ValOf<V, K2>, K3>, K4>>,
- >(
- keyPath: [K, K2, K3, K4, K5]
- ): this;
- removeIn(keyPath: []): void;
- removeIn(keyPath: [K]): this;
- removeIn<K2: $KeyOf<V>>(keyPath: [K, K2]): this;
- removeIn<K2: $KeyOf<V>, K3: $KeyOf<$ValOf<V, K2>>>(
- keyPath: [K, K2, K3]
- ): this;
- removeIn<
- K2: $KeyOf<V>,
- K3: $KeyOf<$ValOf<V, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<V, K2>, K3>>,
- >(
- keyPath: [K, K2, K3, K4]
- ): this;
- removeIn<
- K2: $KeyOf<V>,
- K3: $KeyOf<$ValOf<V, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<V, K2>, K3>>,
- K5: $KeyOf<$ValOf<$ValOf<$ValOf<V, K2>, K3>, K4>>,
- >(
- keyPath: [K, K2, K3, K4, K5]
- ): this;
- updateIn<U>(keyPath: [], notSetValue: mixed, updater: (value: this) => U): U;
- updateIn<U>(keyPath: [], updater: (value: this) => U): U;
- updateIn<NSV>(keyPath: [K], notSetValue: NSV, updater: (value: V) => V): this;
- updateIn(keyPath: [K], updater: (value: V) => V): this;
- updateIn<NSV, K2: $KeyOf<V>, S: $ValOf<V, K2>>(
- keyPath: [K, K2],
- notSetValue: NSV,
- updater: (value: $ValOf<V, K2> | NSV) => S
- ): this;
- updateIn<K2: $KeyOf<V>, S: $ValOf<V, K2>>(
- keyPath: [K, K2],
- updater: (value: $ValOf<V, K2>) => S
- ): this;
- updateIn<
- NSV,
- K2: $KeyOf<V>,
- K3: $KeyOf<$ValOf<V, K2>>,
- S: $ValOf<$ValOf<V, K2>, K3>,
- >(
- keyPath: [K, K2, K3],
- notSetValue: NSV,
- updater: (value: $ValOf<$ValOf<V, K2>, K3> | NSV) => S
- ): this;
- updateIn<
- K2: $KeyOf<V>,
- K3: $KeyOf<$ValOf<V, K2>>,
- S: $ValOf<$ValOf<V, K2>, K3>,
- >(
- keyPath: [K, K2, K3],
- updater: (value: $ValOf<$ValOf<V, K2>, K3>) => S
- ): this;
- updateIn<
- NSV,
- K2: $KeyOf<V>,
- K3: $KeyOf<$ValOf<V, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<V, K2>, K3>>,
- S: $ValOf<$ValOf<$ValOf<V, K2>, K3>, K4>,
- >(
- keyPath: [K, K2, K3, K4],
- notSetValue: NSV,
- updater: (value: $ValOf<$ValOf<$ValOf<V, K2>, K3>, K4> | NSV) => S
- ): this;
- updateIn<
- K2: $KeyOf<V>,
- K3: $KeyOf<$ValOf<V, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<V, K2>, K3>>,
- S: $ValOf<$ValOf<$ValOf<V, K2>, K3>, K4>,
- >(
- keyPath: [K, K2, K3, K4],
- updater: (value: $ValOf<$ValOf<$ValOf<V, K2>, K3>, K4>) => S
- ): this;
- updateIn<
- NSV,
- K2: $KeyOf<V>,
- K3: $KeyOf<$ValOf<V, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<V, K2>, K3>>,
- K5: $KeyOf<$ValOf<$ValOf<$ValOf<V, K2>, K3>, K4>>,
- S: $ValOf<$ValOf<$ValOf<$ValOf<V, K2>, K3>, K4>, K5>,
- >(
- keyPath: [K, K2, K3, K4, K5],
- notSetValue: NSV,
- updater: (
- value: $ValOf<$ValOf<$ValOf<$ValOf<V, K2>, K3>, K4>, K5> | NSV
- ) => S
- ): this;
- updateIn<
- K2: $KeyOf<V>,
- K3: $KeyOf<$ValOf<V, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<V, K2>, K3>>,
- K5: $KeyOf<$ValOf<$ValOf<$ValOf<V, K2>, K3>, K4>>,
- S: $ValOf<$ValOf<$ValOf<$ValOf<V, K2>, K3>, K4>, K5>,
- >(
- keyPath: [K, K2, K3, K4, K5],
- updater: (value: $ValOf<$ValOf<$ValOf<$ValOf<V, K2>, K3>, K4>, K5>) => S
- ): this;
- }
- declare function isList(maybeList: mixed): boolean %checks(maybeList instanceof
- List);
- declare class List<+T>
- extends IndexedCollection<T>
- mixins UpdatableInCollection<number, T>
- {
- static <T>(collection?: Iterable<T>): List<T>;
- static of<T>(...values: T[]): List<T>;
- static isList: typeof isList;
- size: number;
- set<U>(index: number, value: U): List<T | U>;
- delete(index: number): this;
- remove(index: number): this;
- insert<U>(index: number, value: U): List<T | U>;
- clear(): this;
- push<U>(...values: U[]): List<T | U>;
- pop(): this;
- unshift<U>(...values: U[]): List<T | U>;
- shift(): this;
- update<U>(updater: (value: this) => U): U;
- update<U>(index: number, updater: (value: T) => U): List<T | U>;
- update<U>(
- index: number,
- notSetValue: U,
- updater: (value: T) => U
- ): List<T | U>;
- merge<U>(...collections: Iterable<U>[]): List<T | U>;
- setSize(size: number): this;
- mergeIn(keyPath: Iterable<mixed>, ...collections: Iterable<mixed>[]): this;
- mergeDeepIn(
- keyPath: Iterable<mixed>,
- ...collections: Iterable<mixed>[]
- ): this;
- withMutations(mutator: (mutable: this) => mixed): this;
- asMutable(): this;
- wasAltered(): boolean;
- asImmutable(): this;
- // Override specialized return types
- concat<C>(...iters: Array<Iterable<C> | C>): List<T | C>;
- filter(predicate: typeof Boolean): List<$NonMaybeType<T>>;
- filter(
- predicate: (value: T, index: number, iter: this) => mixed,
- context?: mixed
- ): List<T>;
- partition(
- predicate: (value: T, index: number, iter: this) => mixed,
- context?: mixed
- ): [this, this];
- map<M>(
- mapper: (value: T, index: number, iter: this) => M,
- context?: mixed
- ): List<M>;
- flatMap<M>(
- mapper: (value: T, index: number, iter: this) => Iterable<M>,
- context?: mixed
- ): List<M>;
- flatten(depth?: number): List<any>;
- flatten(shallow?: boolean): List<any>;
- zip<A>(a: Iterable<A>, ..._: []): List<[T, A]>;
- zip<A, B>(a: Iterable<A>, b: Iterable<B>, ..._: []): List<[T, A, B]>;
- zip<A, B, C>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- ..._: []
- ): List<[T, A, B, C]>;
- zip<A, B, C, D>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- ..._: []
- ): List<[T, A, B, C, D]>;
- zip<A, B, C, D, E>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- e: Iterable<E>,
- ..._: []
- ): List<[T, A, B, C, D, E]>;
- zipAll<A>(a: Iterable<A>, ..._: []): List<[T | void, A | void]>;
- zipAll<A, B>(
- a: Iterable<A>,
- b: Iterable<B>,
- ..._: []
- ): List<[T | void, A | void, B | void]>;
- zipAll<A, B, C>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- ..._: []
- ): List<[T | void, A | void, B | void, C | void]>;
- zipAll<A, B, C, D>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- ..._: []
- ): List<[T | void, A | void, B | void, C | void, D | void]>;
- zipAll<A, B, C, D, E>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- e: Iterable<E>,
- ..._: []
- ): List<[T | void, A | void, B | void, C | void, D | void, E | void]>;
- zipWith<A, R>(
- zipper: (value: T, a: A) => R,
- a: Iterable<A>,
- ..._: []
- ): List<R>;
- zipWith<A, B, R>(
- zipper: (value: T, a: A, b: B) => R,
- a: Iterable<A>,
- b: Iterable<B>,
- ..._: []
- ): List<R>;
- zipWith<A, B, C, R>(
- zipper: (value: T, a: A, b: B, c: C) => R,
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- ..._: []
- ): List<R>;
- zipWith<A, B, C, D, R>(
- zipper: (value: T, a: A, b: B, c: C, d: D) => R,
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- ..._: []
- ): List<R>;
- zipWith<A, B, C, D, E, R>(
- zipper: (value: T, a: A, b: B, c: C, d: D, e: E) => R,
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- e: Iterable<E>,
- ..._: []
- ): List<R>;
- }
- declare function isMap(maybeMap: mixed): boolean %checks(maybeMap instanceof
- Map);
- declare class Map<K, +V>
- extends KeyedCollection<K, V>
- mixins UpdatableInCollection<K, V>
- {
- static <K, V>(values?: Iterable<[K, V]> | PlainObjInput<K, V>): Map<K, V>;
- static isMap: typeof isMap;
- size: number;
- set<K_, V_>(key: K_, value: V_): Map<K | K_, V | V_>;
- delete(key: K): this;
- remove(key: K): this;
- clear(): this;
- deleteAll(keys: Iterable<K>): Map<K, V>;
- removeAll(keys: Iterable<K>): Map<K, V>;
- update<U>(updater: (value: this) => U): U;
- update<V_>(key: K, updater: (value: V) => V_): Map<K, V | V_>;
- update<V_>(
- key: K,
- notSetValue: V_,
- updater: (value: V) => V_
- ): Map<K, V | V_>;
- merge<K_, V_>(
- ...collections: (Iterable<[K_, V_]> | PlainObjInput<K_, V_>)[]
- ): Map<K | K_, V | V_>;
- concat<K_, V_>(
- ...collections: (Iterable<[K_, V_]> | PlainObjInput<K_, V_>)[]
- ): Map<K | K_, V | V_>;
- mergeWith<K_, W, X>(
- merger: (oldVal: V, newVal: W, key: K) => X,
- ...collections: (Iterable<[K_, W]> | PlainObjInput<K_, W>)[]
- ): Map<K | K_, V | W | X>;
- mergeDeep<K_, V_>(
- ...collections: (Iterable<[K_, V_]> | PlainObjInput<K_, V_>)[]
- ): Map<K | K_, V | V_>;
- mergeDeepWith<K_, V_>(
- merger: (oldVal: any, newVal: any, key: any) => mixed,
- ...collections: (Iterable<[K_, V_]> | PlainObjInput<K_, V_>)[]
- ): Map<K | K_, V | V_>;
- mergeIn(
- keyPath: Iterable<mixed>,
- ...collections: (Iterable<mixed> | PlainObjInput<mixed, mixed>)[]
- ): this;
- mergeDeepIn(
- keyPath: Iterable<mixed>,
- ...collections: (Iterable<mixed> | PlainObjInput<mixed, mixed>)[]
- ): this;
- withMutations(mutator: (mutable: this) => mixed): this;
- asMutable(): this;
- wasAltered(): boolean;
- asImmutable(): this;
- // Override specialized return types
- flip(): Map<V, K>;
- filter(predicate: typeof Boolean): Map<K, $NonMaybeType<V>>;
- filter(
- predicate: (value: V, key: K, iter: this) => mixed,
- context?: mixed
- ): Map<K, V>;
- partition(
- predicate: (value: V, key: K, iter: this) => mixed,
- context?: mixed
- ): [this, this];
- map<M>(
- mapper: (value: V, key: K, iter: this) => M,
- context?: mixed
- ): Map<K, M>;
- mapKeys<M>(
- mapper: (key: K, value: V, iter: this) => M,
- context?: mixed
- ): Map<M, V>;
- mapEntries<KM, VM>(
- mapper: (entry: [K, V], index: number, iter: this) => [KM, VM],
- context?: mixed
- ): Map<KM, VM>;
- flatMap<KM, VM>(
- mapper: (value: V, key: K, iter: this) => Iterable<[KM, VM]>,
- context?: mixed
- ): Map<KM, VM>;
- flatten(depth?: number): Map<any, any>;
- flatten(shallow?: boolean): Map<any, any>;
- }
- declare function isOrderedMap(
- maybeOrderedMap: mixed
- ): boolean %checks(maybeOrderedMap instanceof OrderedMap);
- declare class OrderedMap<K, +V>
- extends Map<K, V>
- mixins UpdatableInCollection<K, V>
- {
- static <K, V>(
- values?: Iterable<[K, V]> | PlainObjInput<K, V>
- ): OrderedMap<K, V>;
- static isOrderedMap: typeof isOrderedMap;
- size: number;
- set<K_, V_>(key: K_, value: V_): OrderedMap<K | K_, V | V_>;
- delete(key: K): this;
- remove(key: K): this;
- clear(): this;
- update<U>(updater: (value: this) => U): U;
- update<V_>(key: K, updater: (value: V) => V_): OrderedMap<K, V | V_>;
- update<V_>(
- key: K,
- notSetValue: V_,
- updater: (value: V) => V_
- ): OrderedMap<K, V | V_>;
- merge<K_, V_>(
- ...collections: (Iterable<[K_, V_]> | PlainObjInput<K_, V_>)[]
- ): OrderedMap<K | K_, V | V_>;
- concat<K_, V_>(
- ...collections: (Iterable<[K_, V_]> | PlainObjInput<K_, V_>)[]
- ): OrderedMap<K | K_, V | V_>;
- mergeWith<K_, W, X>(
- merger: (oldVal: V, newVal: W, key: K) => X,
- ...collections: (Iterable<[K_, W]> | PlainObjInput<K_, W>)[]
- ): OrderedMap<K | K_, V | W | X>;
- mergeDeep<K_, V_>(
- ...collections: (Iterable<[K_, V_]> | PlainObjInput<K_, V_>)[]
- ): OrderedMap<K | K_, V | V_>;
- mergeDeepWith<K_, V_>(
- merger: (oldVal: any, newVal: any, key: any) => mixed,
- ...collections: (Iterable<[K_, V_]> | PlainObjInput<K_, V_>)[]
- ): OrderedMap<K | K_, V | V_>;
- mergeIn(
- keyPath: Iterable<mixed>,
- ...collections: (Iterable<mixed> | PlainObjInput<mixed, mixed>)[]
- ): this;
- mergeDeepIn(
- keyPath: Iterable<mixed>,
- ...collections: (Iterable<mixed> | PlainObjInput<mixed, mixed>)[]
- ): this;
- withMutations(mutator: (mutable: this) => mixed): this;
- asMutable(): this;
- wasAltered(): boolean;
- asImmutable(): this;
- // Override specialized return types
- flip(): OrderedMap<V, K>;
- filter(predicate: typeof Boolean): OrderedMap<K, $NonMaybeType<V>>;
- filter(
- predicate: (value: V, key: K, iter: this) => mixed,
- context?: mixed
- ): OrderedMap<K, V>;
- partition(
- predicate: (value: V, key: K, iter: this) => mixed,
- context?: mixed
- ): [this, this];
- map<M>(
- mapper: (value: V, key: K, iter: this) => M,
- context?: mixed
- ): OrderedMap<K, M>;
- mapKeys<M>(
- mapper: (key: K, value: V, iter: this) => M,
- context?: mixed
- ): OrderedMap<M, V>;
- mapEntries<KM, VM>(
- mapper: (entry: [K, V], index: number, iter: this) => [KM, VM],
- context?: mixed
- ): OrderedMap<KM, VM>;
- flatMap<KM, VM>(
- mapper: (value: V, key: K, iter: this) => Iterable<[KM, VM]>,
- context?: mixed
- ): OrderedMap<KM, VM>;
- flatten(depth?: number): OrderedMap<any, any>;
- flatten(shallow?: boolean): OrderedMap<any, any>;
- }
- declare function isSet(maybeSet: mixed): boolean %checks(maybeSet instanceof
- Set);
- declare class Set<+T> extends SetCollection<T> {
- static <T>(values?: Iterable<T>): Set<T>;
- static of<T>(...values: T[]): Set<T>;
- static fromKeys<T>(
- values: Iterable<[T, mixed]> | PlainObjInput<T, mixed>
- ): Set<T>;
- static intersect<T>(sets: Iterable<Iterable<T>>): Set<T>;
- static union<T>(sets: Iterable<Iterable<T>>): Set<T>;
- static isSet: typeof isSet;
- size: number;
- add<U>(value: U): Set<T | U>;
- delete(value: T): this;
- remove(value: T): this;
- clear(): this;
- union<U>(...collections: Iterable<U>[]): Set<T | U>;
- merge<U>(...collections: Iterable<U>[]): Set<T | U>;
- concat<U>(...collections: Iterable<U>[]): Set<T | U>;
- intersect<U>(...collections: Iterable<U>[]): Set<T & U>;
- subtract(...collections: Iterable<mixed>[]): this;
- withMutations(mutator: (mutable: this) => mixed): this;
- asMutable(): this;
- wasAltered(): boolean;
- asImmutable(): this;
- // Override specialized return types
- filter(predicate: typeof Boolean): Set<$NonMaybeType<T>>;
- filter(
- predicate: (value: T, value: T, iter: this) => mixed,
- context?: mixed
- ): Set<T>;
- partition(
- predicate: (value: T, value: T, iter: this) => mixed,
- context?: mixed
- ): [this, this];
- map<M>(
- mapper: (value: T, value: T, iter: this) => M,
- context?: mixed
- ): Set<M>;
- flatMap<M>(
- mapper: (value: T, value: T, iter: this) => Iterable<M>,
- context?: mixed
- ): Set<M>;
- flatten(depth?: number): Set<any>;
- flatten(shallow?: boolean): Set<any>;
- }
- // Overrides except for `isOrderedSet` are for specialized return types
- declare function isOrderedSet(
- maybeOrderedSet: mixed
- ): boolean %checks(maybeOrderedSet instanceof OrderedSet);
- declare class OrderedSet<+T> extends Set<T> {
- static <T>(values?: Iterable<T>): OrderedSet<T>;
- static of<T>(...values: T[]): OrderedSet<T>;
- static fromKeys<T>(
- values: Iterable<[T, mixed]> | PlainObjInput<T, mixed>
- ): OrderedSet<T>;
- static isOrderedSet: typeof isOrderedSet;
- size: number;
- add<U>(value: U): OrderedSet<T | U>;
- union<U>(...collections: Iterable<U>[]): OrderedSet<T | U>;
- merge<U>(...collections: Iterable<U>[]): OrderedSet<T | U>;
- concat<U>(...collections: Iterable<U>[]): OrderedSet<T | U>;
- intersect<U>(...collections: Iterable<U>[]): OrderedSet<T & U>;
- filter(predicate: typeof Boolean): OrderedSet<$NonMaybeType<T>>;
- filter(
- predicate: (value: T, value: T, iter: this) => mixed,
- context?: mixed
- ): OrderedSet<T>;
- partition(
- predicate: (value: T, value: T, iter: this) => mixed,
- context?: mixed
- ): [this, this];
- map<M>(
- mapper: (value: T, value: T, iter: this) => M,
- context?: mixed
- ): OrderedSet<M>;
- flatMap<M>(
- mapper: (value: T, value: T, iter: this) => Iterable<M>,
- context?: mixed
- ): OrderedSet<M>;
- flatten(depth?: number): OrderedSet<any>;
- flatten(shallow?: boolean): OrderedSet<any>;
- zip<A>(a: Iterable<A>, ..._: []): OrderedSet<[T, A]>;
- zip<A, B>(a: Iterable<A>, b: Iterable<B>, ..._: []): OrderedSet<[T, A, B]>;
- zip<A, B, C>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- ..._: []
- ): OrderedSet<[T, A, B, C]>;
- zip<A, B, C, D>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- ..._: []
- ): OrderedSet<[T, A, B, C, D]>;
- zip<A, B, C, D, E>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- e: Iterable<E>,
- ..._: []
- ): OrderedSet<[T, A, B, C, D, E]>;
- zipAll<A>(a: Iterable<A>, ..._: []): OrderedSet<[T | void, A | void]>;
- zipAll<A, B>(
- a: Iterable<A>,
- b: Iterable<B>,
- ..._: []
- ): OrderedSet<[T | void, A | void, B | void]>;
- zipAll<A, B, C>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- ..._: []
- ): OrderedSet<[T | void, A | void, B | void, C | void]>;
- zipAll<A, B, C, D>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- ..._: []
- ): OrderedSet<[T | void, A | void, B | void, C | void, D | void]>;
- zipAll<A, B, C, D, E>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- e: Iterable<E>,
- ..._: []
- ): OrderedSet<[T | void, A | void, B | void, C | void, D | void, E | void]>;
- zipWith<A, R>(
- zipper: (value: T, a: A) => R,
- a: Iterable<A>,
- ..._: []
- ): OrderedSet<R>;
- zipWith<A, B, R>(
- zipper: (value: T, a: A, b: B) => R,
- a: Iterable<A>,
- b: Iterable<B>,
- ..._: []
- ): OrderedSet<R>;
- zipWith<A, B, C, R>(
- zipper: (value: T, a: A, b: B, c: C) => R,
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- ..._: []
- ): OrderedSet<R>;
- zipWith<A, B, C, D, R>(
- zipper: (value: T, a: A, b: B, c: C, d: D) => R,
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- ..._: []
- ): OrderedSet<R>;
- zipWith<A, B, C, D, E, R>(
- zipper: (value: T, a: A, b: B, c: C, d: D, e: E) => R,
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- e: Iterable<E>,
- ..._: []
- ): OrderedSet<R>;
- }
- declare function isStack(
- maybeStack: mixed
- ): boolean %checks(maybeStack instanceof Stack);
- declare class Stack<+T> extends IndexedCollection<T> {
- static <T>(collection?: Iterable<T>): Stack<T>;
- static isStack(maybeStack: mixed): boolean;
- static of<T>(...values: T[]): Stack<T>;
- static isStack: typeof isStack;
- size: number;
- peek(): T;
- clear(): this;
- unshift<U>(...values: U[]): Stack<T | U>;
- unshiftAll<U>(iter: Iterable<U>): Stack<T | U>;
- shift(): this;
- push<U>(...values: U[]): Stack<T | U>;
- pushAll<U>(iter: Iterable<U>): Stack<T | U>;
- pop(): this;
- withMutations(mutator: (mutable: this) => mixed): this;
- asMutable(): this;
- wasAltered(): boolean;
- asImmutable(): this;
- // Override specialized return types
- concat<C>(...iters: Array<Iterable<C> | C>): Stack<T | C>;
- filter(predicate: typeof Boolean): Stack<$NonMaybeType<T>>;
- filter(
- predicate: (value: T, index: number, iter: this) => mixed,
- context?: mixed
- ): Stack<T>;
- map<M>(
- mapper: (value: T, index: number, iter: this) => M,
- context?: mixed
- ): Stack<M>;
- flatMap<M>(
- mapper: (value: T, index: number, iter: this) => Iterable<M>,
- context?: mixed
- ): Stack<M>;
- flatten(depth?: number): Stack<any>;
- flatten(shallow?: boolean): Stack<any>;
- zip<A>(a: Iterable<A>, ..._: []): Stack<[T, A]>;
- zip<A, B>(a: Iterable<A>, b: Iterable<B>, ..._: []): Stack<[T, A, B]>;
- zip<A, B, C>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- ..._: []
- ): Stack<[T, A, B, C]>;
- zip<A, B, C, D>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- ..._: []
- ): Stack<[T, A, B, C, D]>;
- zip<A, B, C, D, E>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- e: Iterable<E>,
- ..._: []
- ): Stack<[T, A, B, C, D, E]>;
- zipAll<A>(a: Iterable<A>, ..._: []): Stack<[T | void, A | void]>;
- zipAll<A, B>(
- a: Iterable<A>,
- b: Iterable<B>,
- ..._: []
- ): Stack<[T | void, A | void, B | void]>;
- zipAll<A, B, C>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- ..._: []
- ): Stack<[T | void, A | void, B | void, C | void]>;
- zipAll<A, B, C, D>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- ..._: []
- ): Stack<[T | void, A | void, B | void, C | void, D | void]>;
- zipAll<A, B, C, D, E>(
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- e: Iterable<E>,
- ..._: []
- ): Stack<[T | void, A | void, B | void, C | void, D | void, E | void]>;
- zipWith<A, R>(
- zipper: (value: T, a: A) => R,
- a: Iterable<A>,
- ..._: []
- ): Stack<R>;
- zipWith<A, B, R>(
- zipper: (value: T, a: A, b: B) => R,
- a: Iterable<A>,
- b: Iterable<B>,
- ..._: []
- ): Stack<R>;
- zipWith<A, B, C, R>(
- zipper: (value: T, a: A, b: B, c: C) => R,
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- ..._: []
- ): Stack<R>;
- zipWith<A, B, C, D, R>(
- zipper: (value: T, a: A, b: B, c: C, d: D) => R,
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- ..._: []
- ): Stack<R>;
- zipWith<A, B, C, D, E, R>(
- zipper: (value: T, a: A, b: B, c: C, d: D, e: E) => R,
- a: Iterable<A>,
- b: Iterable<B>,
- c: Iterable<C>,
- d: Iterable<D>,
- e: Iterable<E>,
- ..._: []
- ): Stack<R>;
- }
- declare function Range(
- start?: number,
- end?: number,
- step?: number
- ): IndexedSeq<number>;
- declare function Repeat<T>(value: T, times?: number): IndexedSeq<T>;
- // The type of a Record factory function.
- type RecordFactory<Values: Object> = Class<RecordInstance<Values>>;
- // The type of runtime Record instances.
- type RecordOf<Values: Object> = RecordInstance<Values> & $ReadOnly<Values>;
- // The values of a Record instance.
- type _RecordValues<T, R: RecordInstance<T> | T> = R;
- type RecordValues<R> = _RecordValues<*, R>;
- declare function isRecord(
- maybeRecord: any
- ): boolean %checks(maybeRecord instanceof RecordInstance);
- declare class Record {
- static <Values: Object>(spec: Values, name?: string): typeof RecordInstance;
- constructor<Values: Object>(
- spec: Values,
- name?: string
- ): typeof RecordInstance;
- static isRecord: typeof isRecord;
- static getDescriptiveName(record: RecordInstance<any>): string;
- }
- declare class RecordInstance<T: Object = Object> {
- static (values?: Iterable<[$Keys<T>, $ValOf<T>]> | $Shape<T>): RecordOf<T>;
- // Note: a constructor can only create an instance of RecordInstance<T>,
- // it's encouraged to not use `new` when creating Records.
- constructor(values?: Iterable<[$Keys<T>, $ValOf<T>]> | $Shape<T>): void;
- size: number;
- has(key: string): boolean;
- get<K: $Keys<T>>(key: K, ..._: []): $ElementType<T, K>;
- get<K: $Keys<T>, NSV>(key: K, notSetValue: NSV): $ElementType<T, K> | NSV;
- hasIn(keyPath: Iterable<mixed>): boolean;
- getIn(keyPath: [], notSetValue?: mixed): this & $ReadOnly<T>;
- getIn<K: $Keys<T>>(keyPath: [K], notSetValue?: mixed): $ElementType<T, K>;
- getIn<NSV, K: $Keys<T>, K2: $KeyOf<$ValOf<T, K>>>(
- keyPath: [K, K2],
- notSetValue: NSV
- ): $ValOf<$ValOf<T, K>, K2> | NSV;
- getIn<
- NSV,
- K: $Keys<T>,
- K2: $KeyOf<$ValOf<T, K>>,
- K3: $KeyOf<$ValOf<$ValOf<T, K>, K2>>,
- >(
- keyPath: [K, K2, K3],
- notSetValue: NSV
- ): $ValOf<$ValOf<$ValOf<T, K>, K2>, K3> | NSV;
- getIn<
- NSV,
- K: $Keys<T>,
- K2: $KeyOf<$ValOf<T, K>>,
- K3: $KeyOf<$ValOf<$ValOf<T, K>, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>>,
- >(
- keyPath: [K, K2, K3, K4],
- notSetValue: NSV
- ): $ValOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>, K4> | NSV;
- getIn<
- NSV,
- K: $Keys<T>,
- K2: $KeyOf<$ValOf<T, K>>,
- K3: $KeyOf<$ValOf<$ValOf<T, K>, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>>,
- K5: $KeyOf<$ValOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>, K4>>,
- >(
- keyPath: [K, K2, K3, K4, K5],
- notSetValue: NSV
- ): $ValOf<$ValOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>, K4>, K5> | NSV;
- equals(other: any): boolean;
- hashCode(): number;
- set<K: $Keys<T>>(key: K, value: $ElementType<T, K>): this & $ReadOnly<T>;
- update<K: $Keys<T>>(
- key: K,
- updater: (value: $ElementType<T, K>) => $ElementType<T, K>
- ): this & $ReadOnly<T>;
- merge(
- ...collections: Array<Iterable<[$Keys<T>, $ValOf<T>]> | $Shape<T>>
- ): this & $ReadOnly<T>;
- mergeDeep(
- ...collections: Array<Iterable<[$Keys<T>, $ValOf<T>]> | $Shape<T>>
- ): this & $ReadOnly<T>;
- mergeWith(
- merger: (oldVal: $ValOf<T>, newVal: $ValOf<T>, key: $Keys<T>) => $ValOf<T>,
- ...collections: Array<Iterable<[$Keys<T>, $ValOf<T>]> | $Shape<T>>
- ): this & $ReadOnly<T>;
- mergeDeepWith(
- merger: (oldVal: any, newVal: any, key: any) => any,
- ...collections: Array<Iterable<[$Keys<T>, $ValOf<T>]> | $Shape<T>>
- ): this & $ReadOnly<T>;
- delete<K: $Keys<T>>(key: K): this & $ReadOnly<T>;
- remove<K: $Keys<T>>(key: K): this & $ReadOnly<T>;
- clear(): this & $ReadOnly<T>;
- setIn<S>(keyPath: [], value: S): S;
- setIn<K: $Keys<T>, S: $ValOf<T, K>>(
- keyPath: [K],
- value: S
- ): this & $ReadOnly<T>;
- setIn<K: $Keys<T>, K2: $KeyOf<$ValOf<T, K>>, S: $ValOf<$ValOf<T, K>, K2>>(
- keyPath: [K, K2],
- value: S
- ): this & $ReadOnly<T>;
- setIn<
- K: $Keys<T>,
- K2: $KeyOf<$ValOf<T, K>>,
- K3: $KeyOf<$ValOf<$ValOf<T, K>, K2>>,
- S: $ValOf<$ValOf<$ValOf<T, K>, K2>, K3>,
- >(
- keyPath: [K, K2, K3],
- value: S
- ): this & $ReadOnly<T>;
- setIn<
- K: $Keys<T>,
- K2: $KeyOf<$ValOf<T, K>>,
- K3: $KeyOf<$ValOf<$ValOf<T, K>, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>>,
- S: $ValOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>, K4>,
- >(
- keyPath: [K, K2, K3, K4],
- value: S
- ): this & $ReadOnly<T>;
- setIn<
- K: $Keys<T>,
- K2: $KeyOf<$ValOf<T, K>>,
- K3: $KeyOf<$ValOf<$ValOf<T, K>, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>>,
- K5: $KeyOf<$ValOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>, K4>>,
- S: $ValOf<$ValOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>, K4>, K5>,
- >(
- keyPath: [K, K2, K3, K4, K5],
- value: S
- ): this & $ReadOnly<T>;
- deleteIn(keyPath: []): void;
- deleteIn<K: $Keys<T>>(keyPath: [K]): this & $ReadOnly<T>;
- deleteIn<K: $Keys<T>, K2: $KeyOf<$ValOf<T, K>>>(
- keyPath: [K, K2]
- ): this & $ReadOnly<T>;
- deleteIn<
- K: $Keys<T>,
- K2: $KeyOf<$ValOf<T, K>>,
- K3: $KeyOf<$ValOf<$ValOf<T, K>, K2>>,
- >(
- keyPath: [K, K2, K3]
- ): this & $ReadOnly<T>;
- deleteIn<
- K: $Keys<T>,
- K2: $KeyOf<$ValOf<T, K>>,
- K3: $KeyOf<$ValOf<$ValOf<T, K>, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>>,
- >(
- keyPath: [K, K2, K3, K4]
- ): this & $ReadOnly<T>;
- deleteIn<
- K: $Keys<T>,
- K2: $KeyOf<$ValOf<T, K>>,
- K3: $KeyOf<$ValOf<$ValOf<T, K>, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>>,
- K5: $KeyOf<$ValOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>, K4>>,
- >(
- keyPath: [K, K2, K3, K4, K5]
- ): this & $ReadOnly<T>;
- removeIn(keyPath: []): void;
- removeIn<K: $Keys<T>>(keyPath: [K]): this & $ReadOnly<T>;
- removeIn<K: $Keys<T>, K2: $KeyOf<$ValOf<T, K>>>(
- keyPath: [K, K2]
- ): this & $ReadOnly<T>;
- removeIn<
- K: $Keys<T>,
- K2: $KeyOf<$ValOf<T, K>>,
- K3: $KeyOf<$ValOf<$ValOf<T, K>, K2>>,
- >(
- keyPath: [K, K2, K3]
- ): this & $ReadOnly<T>;
- removeIn<
- K: $Keys<T>,
- K2: $KeyOf<$ValOf<T, K>>,
- K3: $KeyOf<$ValOf<$ValOf<T, K>, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>>,
- >(
- keyPath: [K, K2, K3, K4]
- ): this & $ReadOnly<T>;
- removeIn<
- K: $Keys<T>,
- K2: $KeyOf<$ValOf<T, K>>,
- K3: $KeyOf<$ValOf<$ValOf<T, K>, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>>,
- K5: $KeyOf<$ValOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>, K4>>,
- >(
- keyPath: [K, K2, K3, K4, K5]
- ): this & $ReadOnly<T>;
- updateIn<U>(
- keyPath: [],
- notSetValue: mixed,
- updater: (value: this & T) => U
- ): U;
- updateIn<U>(keyPath: [], updater: (value: this & T) => U): U;
- updateIn<NSV, K: $Keys<T>, S: $ValOf<T, K>>(
- keyPath: [K],
- notSetValue: NSV,
- updater: (value: $ValOf<T, K>) => S
- ): this & $ReadOnly<T>;
- updateIn<K: $Keys<T>, S: $ValOf<T, K>>(
- keyPath: [K],
- updater: (value: $ValOf<T, K>) => S
- ): this & $ReadOnly<T>;
- updateIn<
- NSV,
- K: $Keys<T>,
- K2: $KeyOf<$ValOf<T, K>>,
- S: $ValOf<$ValOf<T, K>, K2>,
- >(
- keyPath: [K, K2],
- notSetValue: NSV,
- updater: (value: $ValOf<$ValOf<T, K>, K2> | NSV) => S
- ): this & $ReadOnly<T>;
- updateIn<K: $Keys<T>, K2: $KeyOf<$ValOf<T, K>>, S: $ValOf<$ValOf<T, K>, K2>>(
- keyPath: [K, K2],
- updater: (value: $ValOf<$ValOf<T, K>, K2>) => S
- ): this & $ReadOnly<T>;
- updateIn<
- NSV,
- K: $Keys<T>,
- K2: $KeyOf<$ValOf<T, K>>,
- K3: $KeyOf<$ValOf<$ValOf<T, K>, K2>>,
- S: $ValOf<$ValOf<$ValOf<T, K>, K2>, K3>,
- >(
- keyPath: [K, K2, K3],
- notSetValue: NSV,
- updater: (value: $ValOf<$ValOf<$ValOf<T, K>, K2>, K3> | NSV) => S
- ): this & $ReadOnly<T>;
- updateIn<
- K: $Keys<T>,
- K2: $KeyOf<$ValOf<T, K>>,
- K3: $KeyOf<$ValOf<$ValOf<T, K>, K2>>,
- S: $ValOf<$ValOf<$ValOf<T, K>, K2>, K3>,
- >(
- keyPath: [K, K2, K3],
- updater: (value: $ValOf<$ValOf<$ValOf<T, K>, K2>, K3>) => S
- ): this & $ReadOnly<T>;
- updateIn<
- NSV,
- K: $Keys<T>,
- K2: $KeyOf<$ValOf<T, K>>,
- K3: $KeyOf<$ValOf<$ValOf<T, K>, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>>,
- S: $ValOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>, K4>,
- >(
- keyPath: [K, K2, K3, K4],
- notSetValue: NSV,
- updater: (
- value: $ValOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>, K4> | NSV
- ) => S
- ): this & $ReadOnly<T>;
- updateIn<
- K: $Keys<T>,
- K2: $KeyOf<$ValOf<T, K>>,
- K3: $KeyOf<$ValOf<$ValOf<T, K>, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>>,
- S: $ValOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>, K4>,
- >(
- keyPath: [K, K2, K3, K4],
- updater: (value: $ValOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>, K4>) => S
- ): this & $ReadOnly<T>;
- updateIn<
- NSV,
- K: $Keys<T>,
- K2: $KeyOf<$ValOf<T, K>>,
- K3: $KeyOf<$ValOf<$ValOf<T, K>, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>>,
- K5: $KeyOf<$ValOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>, K4>>,
- S: $ValOf<$ValOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>, K4>, K5>,
- >(
- keyPath: [K, K2, K3, K4, K5],
- notSetValue: NSV,
- updater: (
- value: $ValOf<$ValOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>, K4>, K5> | NSV
- ) => S
- ): this & $ReadOnly<T>;
- updateIn<
- K: $Keys<T>,
- K2: $KeyOf<$ValOf<T, K>>,
- K3: $KeyOf<$ValOf<$ValOf<T, K>, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>>,
- K5: $KeyOf<$ValOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>, K4>>,
- S: $ValOf<$ValOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>, K4>, K5>,
- >(
- keyPath: [K, K2, K3, K4, K5],
- updater: (
- value: $ValOf<$ValOf<$ValOf<$ValOf<$ValOf<T, K>, K2>, K3>, K4>, K5>
- ) => S
- ): this & $ReadOnly<T>;
- mergeIn(
- keyPath: Iterable<mixed>,
- ...collections: Array<any>
- ): this & $ReadOnly<T>;
- mergeDeepIn(
- keyPath: Iterable<mixed>,
- ...collections: Array<any>
- ): this & $ReadOnly<T>;
- toSeq(): KeyedSeq<$Keys<T>, any>;
- toJS(): { [key: $Keys<T>]: mixed };
- toJSON(): T;
- toObject(): T;
- withMutations(mutator: (mutable: this & T) => mixed): this & $ReadOnly<T>;
- asMutable(): this & $ReadOnly<T>;
- wasAltered(): boolean;
- asImmutable(): this & $ReadOnly<T>;
- @@iterator(): Iterator<[$Keys<T>, $ValOf<T>]>;
- }
- declare function fromJS(
- jsValue: mixed,
- reviver?: (
- key: string | number,
- sequence: KeyedCollection<string, mixed> | IndexedCollection<mixed>,
- path?: Array<string | number>
- ) => mixed
- ): Collection<mixed, mixed>;
- declare function is(first: mixed, second: mixed): boolean;
- declare function hash(value: mixed): number;
- declare function get<C: Object, K: $Keys<C>>(
- collection: C,
- key: K,
- notSetValue: mixed
- ): $ValOf<C, K>;
- declare function get<C, K: $KeyOf<C>, NSV>(
- collection: C,
- key: K,
- notSetValue: NSV
- ): $ValOf<C, K> | NSV;
- declare function has(collection: Object, key: mixed): boolean;
- declare function remove<C>(collection: C, key: $KeyOf<C>): C;
- declare function set<C, K: $KeyOf<C>, V: $ValOf<C, K>>(
- collection: C,
- key: K,
- value: V
- ): C;
- declare function update<C, K: $KeyOf<C>, V: $ValOf<C, K>, NSV>(
- collection: C,
- key: K,
- notSetValue: NSV,
- updater: ($ValOf<C, K> | NSV) => V
- ): C;
- declare function update<C, K: $KeyOf<C>, V: $ValOf<C, K>>(
- collection: C,
- key: K,
- updater: ($ValOf<C, K>) => V
- ): C;
- declare function getIn<C>(collection: C, keyPath: [], notSetValue?: mixed): C;
- declare function getIn<C, K: $KeyOf<C>, NSV>(
- collection: C,
- keyPath: [K],
- notSetValue: NSV
- ): $ValOf<C, K> | NSV;
- declare function getIn<C, K: $KeyOf<C>, K2: $KeyOf<$ValOf<C, K>>, NSV>(
- collection: C,
- keyPath: [K, K2],
- notSetValue: NSV
- ): $ValOf<$ValOf<C, K>, K2> | NSV;
- declare function getIn<
- C,
- K: $KeyOf<C>,
- K2: $KeyOf<$ValOf<C, K>>,
- K3: $KeyOf<$ValOf<$ValOf<C, K>, K2>>,
- NSV,
- >(
- collection: C,
- keyPath: [K, K2, K3],
- notSetValue: NSV
- ): $ValOf<$ValOf<$ValOf<C, K>, K2>, K3> | NSV;
- declare function getIn<
- C,
- K: $KeyOf<C>,
- K2: $KeyOf<$ValOf<C, K>>,
- K3: $KeyOf<$ValOf<$ValOf<C, K>, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<$ValOf<C, K>, K2>, K3>>,
- NSV,
- >(
- collection: C,
- keyPath: [K, K2, K3, K4],
- notSetValue: NSV
- ): $ValOf<$ValOf<$ValOf<$ValOf<C, K>, K2>, K3>, K4> | NSV;
- declare function getIn<
- C,
- K: $KeyOf<C>,
- K2: $KeyOf<$ValOf<C, K>>,
- K3: $KeyOf<$ValOf<$ValOf<C, K>, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<$ValOf<C, K>, K2>, K3>>,
- K5: $KeyOf<$ValOf<$ValOf<$ValOf<$ValOf<C, K>, K2>, K3>, K4>>,
- NSV,
- >(
- collection: C,
- keyPath: [K, K2, K3, K4, K5],
- notSetValue: NSV
- ): $ValOf<$ValOf<$ValOf<$ValOf<$ValOf<C, K>, K2>, K3>, K4>, K5> | NSV;
- declare function hasIn(collection: Object, keyPath: Iterable<mixed>): boolean;
- declare function removeIn<C>(collection: C, keyPath: []): void;
- declare function removeIn<C, K: $KeyOf<C>>(collection: C, keyPath: [K]): C;
- declare function removeIn<C, K: $KeyOf<C>, K2: $KeyOf<$ValOf<C, K>>>(
- collection: C,
- keyPath: [K, K2]
- ): C;
- declare function removeIn<
- C,
- K: $KeyOf<C>,
- K2: $KeyOf<$ValOf<C, K>>,
- K3: $KeyOf<$ValOf<$ValOf<C, K>, K2>>,
- >(
- collection: C,
- keyPath: [K, K2, K3]
- ): C;
- declare function removeIn<
- C,
- K: $KeyOf<C>,
- K2: $KeyOf<$ValOf<C, K>>,
- K3: $KeyOf<$ValOf<$ValOf<C, K>, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<$ValOf<C, K>, K2>, K3>>,
- >(
- collection: C,
- keyPath: [K, K2, K3, K4]
- ): C;
- declare function removeIn<
- C,
- K: $KeyOf<C>,
- K2: $KeyOf<$ValOf<C, K>>,
- K3: $KeyOf<$ValOf<$ValOf<C, K>, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<$ValOf<C, K>, K2>, K3>>,
- K5: $KeyOf<$ValOf<$ValOf<$ValOf<$ValOf<C, K>, K2>, K3>, K4>>,
- >(
- collection: C,
- keyPath: [K, K2, K3, K4, K5]
- ): C;
- declare function setIn<S>(collection: Object, keyPath: [], value: S): S;
- declare function setIn<C, K: $KeyOf<C>, S: $ValOf<C, K>>(
- collection: C,
- keyPath: [K],
- value: S
- ): C;
- declare function setIn<
- C,
- K: $KeyOf<C>,
- K2: $KeyOf<$ValOf<C, K>>,
- S: $ValOf<$ValOf<C, K>, K2>,
- >(
- collection: C,
- keyPath: [K, K2],
- value: S
- ): C;
- declare function setIn<
- C,
- K: $KeyOf<C>,
- K2: $KeyOf<$ValOf<C, K>>,
- K3: $KeyOf<$ValOf<$ValOf<C, K>, K2>>,
- S: $ValOf<$ValOf<$ValOf<C, K>, K2>, K3>,
- >(
- collection: C,
- keyPath: [K, K2, K3],
- value: S
- ): C;
- declare function setIn<
- C,
- K: $KeyOf<C>,
- K2: $KeyOf<$ValOf<C, K>>,
- K3: $KeyOf<$ValOf<$ValOf<C, K>, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<$ValOf<C, K>, K2>, K3>>,
- S: $ValOf<$ValOf<$ValOf<$ValOf<C, K>, K2>, K3>, K4>,
- >(
- collection: C,
- keyPath: [K, K2, K3, K4],
- value: S
- ): C;
- declare function setIn<
- C,
- K: $KeyOf<C>,
- K2: $KeyOf<$ValOf<C, K>>,
- K3: $KeyOf<$ValOf<$ValOf<C, K>, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<$ValOf<C, K>, K2>, K3>>,
- K5: $KeyOf<$ValOf<$ValOf<$ValOf<$ValOf<C, K>, K2>, K3>, K4>>,
- S: $ValOf<$ValOf<$ValOf<$ValOf<$ValOf<C, K>, K2>, K3>, K4>, K5>,
- >(
- collection: C,
- keyPath: [K, K2, K3, K4, K5],
- value: S
- ): C;
- declare function updateIn<C, S>(
- collection: C,
- keyPath: [],
- notSetValue: mixed,
- updater: (value: C) => S
- ): S;
- declare function updateIn<C, S>(
- collection: C,
- keyPath: [],
- updater: (value: C) => S
- ): S;
- declare function updateIn<C, K: $KeyOf<C>, S: $ValOf<C, K>, NSV>(
- collection: C,
- keyPath: [K],
- notSetValue: NSV,
- updater: (value: $ValOf<C, K> | NSV) => S
- ): C;
- declare function updateIn<C, K: $KeyOf<C>, S: $ValOf<C, K>>(
- collection: C,
- keyPath: [K],
- updater: (value: $ValOf<C, K>) => S
- ): C;
- declare function updateIn<
- C,
- K: $KeyOf<C>,
- K2: $KeyOf<$ValOf<C, K>>,
- S: $ValOf<$ValOf<C, K>, K2>,
- NSV,
- >(
- collection: C,
- keyPath: [K, K2],
- notSetValue: NSV,
- updater: (value: $ValOf<$ValOf<C, K>, K2> | NSV) => S
- ): C;
- declare function updateIn<
- C,
- K: $KeyOf<C>,
- K2: $KeyOf<$ValOf<C, K>>,
- S: $ValOf<$ValOf<C, K>, K2>,
- >(
- collection: C,
- keyPath: [K, K2],
- updater: (value: $ValOf<$ValOf<C, K>, K2>) => S
- ): C;
- declare function updateIn<
- C,
- K: $KeyOf<C>,
- K2: $KeyOf<$ValOf<C, K>>,
- K3: $KeyOf<$ValOf<$ValOf<C, K>, K2>>,
- S: $ValOf<$ValOf<$ValOf<C, K>, K2>, K3>,
- NSV,
- >(
- collection: C,
- keyPath: [K, K2, K3],
- notSetValue: NSV,
- updater: (value: $ValOf<$ValOf<$ValOf<C, K>, K2>, K3> | NSV) => S
- ): C;
- declare function updateIn<
- C,
- K: $KeyOf<C>,
- K2: $KeyOf<$ValOf<C, K>>,
- K3: $KeyOf<$ValOf<$ValOf<C, K>, K2>>,
- S: $ValOf<$ValOf<$ValOf<C, K>, K2>, K3>,
- >(
- collection: C,
- keyPath: [K, K2, K3],
- updater: (value: $ValOf<$ValOf<$ValOf<C, K>, K2>, K3>) => S
- ): C;
- declare function updateIn<
- C,
- K: $KeyOf<C>,
- K2: $KeyOf<$ValOf<C, K>>,
- K3: $KeyOf<$ValOf<$ValOf<C, K>, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<$ValOf<C, K>, K2>, K3>>,
- S: $ValOf<$ValOf<$ValOf<$ValOf<C, K>, K2>, K3>, K4>,
- NSV,
- >(
- collection: C,
- keyPath: [K, K2, K3, K4],
- notSetValue: NSV,
- updater: (value: $ValOf<$ValOf<$ValOf<$ValOf<C, K>, K2>, K3>, K4> | NSV) => S
- ): C;
- declare function updateIn<
- C,
- K: $KeyOf<C>,
- K2: $KeyOf<$ValOf<C, K>>,
- K3: $KeyOf<$ValOf<$ValOf<C, K>, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<$ValOf<C, K>, K2>, K3>>,
- S: $ValOf<$ValOf<$ValOf<$ValOf<C, K>, K2>, K3>, K4>,
- >(
- collection: C,
- keyPath: [K, K2, K3, K4],
- updater: (value: $ValOf<$ValOf<$ValOf<$ValOf<C, K>, K2>, K3>, K4>) => S
- ): C;
- declare function updateIn<
- C,
- K: $KeyOf<C>,
- K2: $KeyOf<$ValOf<C, K>>,
- K3: $KeyOf<$ValOf<$ValOf<C, K>, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<$ValOf<C, K>, K2>, K3>>,
- K5: $KeyOf<$ValOf<$ValOf<$ValOf<$ValOf<C, K>, K2>, K3>, K4>>,
- S: $ValOf<$ValOf<$ValOf<$ValOf<$ValOf<C, K>, K2>, K3>, K4>, K5>,
- NSV,
- >(
- collection: C,
- keyPath: [K, K2, K3, K4, K5],
- notSetValue: NSV,
- updater: (
- value: $ValOf<$ValOf<$ValOf<$ValOf<$ValOf<C, K>, K2>, K3>, K4>, K5> | NSV
- ) => S
- ): C;
- declare function updateIn<
- C,
- K: $KeyOf<C>,
- K2: $KeyOf<$ValOf<C, K>>,
- K3: $KeyOf<$ValOf<$ValOf<C, K>, K2>>,
- K4: $KeyOf<$ValOf<$ValOf<$ValOf<C, K>, K2>, K3>>,
- K5: $KeyOf<$ValOf<$ValOf<$ValOf<$ValOf<C, K>, K2>, K3>, K4>>,
- S: $ValOf<$ValOf<$ValOf<$ValOf<$ValOf<C, K>, K2>, K3>, K4>, K5>,
- >(
- collection: C,
- keyPath: [K, K2, K3, K4, K5],
- updater: (
- value: $ValOf<$ValOf<$ValOf<$ValOf<$ValOf<C, K>, K2>, K3>, K4>, K5>
- ) => S
- ): C;
- declare function merge<C>(
- collection: C,
- ...collections: Array<
- | $IterableOf<C>
- | $Shape<RecordValues<C>>
- | PlainObjInput<$KeyOf<C>, $ValOf<C>>,
- >
- ): C;
- declare function mergeWith<C>(
- merger: (oldVal: $ValOf<C>, newVal: $ValOf<C>, key: $KeyOf<C>) => $ValOf<C>,
- collection: C,
- ...collections: Array<
- | $IterableOf<C>
- | $Shape<RecordValues<C>>
- | PlainObjInput<$KeyOf<C>, $ValOf<C>>,
- >
- ): C;
- declare function mergeDeep<C>(
- collection: C,
- ...collections: Array<
- | $IterableOf<C>
- | $Shape<RecordValues<C>>
- | PlainObjInput<$KeyOf<C>, $ValOf<C>>,
- >
- ): C;
- declare function mergeDeepWith<C>(
- merger: (oldVal: any, newVal: any, key: any) => mixed,
- collection: C,
- ...collections: Array<
- | $IterableOf<C>
- | $Shape<RecordValues<C>>
- | PlainObjInput<$KeyOf<C>, $ValOf<C>>,
- >
- ): C;
- export {
- Collection,
- Seq,
- List,
- Map,
- OrderedMap,
- OrderedSet,
- Range,
- Repeat,
- Record,
- Set,
- Stack,
- fromJS,
- is,
- hash,
- isImmutable,
- isCollection,
- isKeyed,
- isIndexed,
- isAssociative,
- isOrdered,
- isRecord,
- isValueObject,
- get,
- has,
- remove,
- set,
- update,
- getIn,
- hasIn,
- removeIn,
- setIn,
- updateIn,
- merge,
- mergeWith,
- mergeDeep,
- mergeDeepWith,
- };
- export default {
- Collection,
- Seq,
- List,
- Map,
- OrderedMap,
- OrderedSet,
- PairSorting,
- Range,
- Repeat,
- Record,
- Set,
- Stack,
- fromJS,
- is,
- hash,
- isImmutable,
- isCollection,
- isKeyed,
- isIndexed,
- isAssociative,
- isOrdered,
- isRecord,
- isValueObject,
- get,
- has,
- remove,
- set,
- update,
- getIn,
- hasIn,
- removeIn,
- setIn,
- updateIn,
- merge,
- mergeWith,
- mergeDeep,
- mergeDeepWith,
- };
- export type {
- Comparator,
- KeyedCollection,
- IndexedCollection,
- SetCollection,
- KeyedSeq,
- IndexedSeq,
- SetSeq,
- RecordFactory,
- RecordOf,
- RecordInstance,
- ValueObject,
- $KeyOf,
- $ValOf,
- };
|