import { $changes, $childType, $decoder, $deleteByIndex, $onEncodeEnd, $encoder, $filter, $getByIndex, $refId } from "../symbols.js"; import { ChangeTree, IRef } from "../../encoder/ChangeTree.js"; import { Collection } from "../HelperTypes.js"; import type { StateView } from "../../encoder/StateView.js"; import type { Schema } from "../../Schema.js"; export declare class MapSchema implements Map, Collection, IRef { [$changes]: ChangeTree; [$refId]?: number; protected childType: new () => V; protected [$childType]: string | typeof Schema; protected $items: Map; protected $indexes: Map; protected deletedItems: { [index: string]: V; }; static [$encoder]: import("../../encoder/EncodeOperation.js").EncodeOperation; static [$decoder]: import("../../decoder/DecodeOperation.js").DecodeOperation; /** * Determine if a property must be filtered. * - If returns false, the property is NOT going to be encoded. * - If returns true, the property is going to be encoded. * * Encoding with "filters" happens in two steps: * - First, the encoder iterates over all "not owned" properties and encodes them. * - Then, the encoder iterates over all "owned" properties per instance and encodes them. */ static [$filter](ref: MapSchema, index: number, view: StateView): boolean; static is(type: any): boolean; constructor(initialValues?: Map | Record); /** Iterator */ [Symbol.iterator](): IterableIterator<[K, V]>; get [Symbol.toStringTag](): string; static get [Symbol.species](): typeof MapSchema; set(key: K, value: V): this; get(key: K): V | undefined; delete(key: K): boolean; clear(): void; has(key: K): boolean; forEach(callbackfn: (value: V, key: K, map: Map) => void): void; entries(): MapIterator<[K, V]>; keys(): MapIterator; values(): MapIterator; get size(): number; protected setIndex(index: number, key: K): void; protected getIndex(index: number): K; [$getByIndex](index: number): V | undefined; [$deleteByIndex](index: number): void; protected [$onEncodeEnd](): void; toJSON(): any; clone(isDecoding?: boolean): MapSchema; }