cmap-core 0.0.8 → 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"file":"index.umd.js","sources":["../src/utils/validate.ts","../src/core/Cache/index.ts","../node_modules/.pnpm/quickselect@3.0.0/node_modules/quickselect/index.js","../node_modules/.pnpm/rbush@4.0.1/node_modules/rbush/index.js","../src/types/Collision/item.ts","../src/core/Collision/CollisionItem.ts","../src/core/Collision/index.ts","../src/config/index.ts","../src/types/IconManager/index.ts","../node_modules/.pnpm/@turf+helpers@7.3.2/node_modules/@turf/helpers/dist/esm/index.js","../node_modules/.pnpm/@turf+invariant@7.3.2/node_modules/@turf/invariant/dist/esm/index.js","../node_modules/.pnpm/@turf+rhumb-bearing@7.3.2/node_modules/@turf/rhumb-bearing/dist/esm/index.js","../node_modules/.pnpm/@turf+meta@7.3.2/node_modules/@turf/meta/dist/esm/index.js","../node_modules/.pnpm/@turf+bbox@7.3.2/node_modules/@turf/bbox/dist/esm/index.js","../node_modules/.pnpm/@turf+centroid@7.3.2/node_modules/@turf/centroid/dist/esm/index.js","../node_modules/.pnpm/@turf+clone@7.3.2/node_modules/@turf/clone/dist/esm/index.js","../node_modules/.pnpm/@turf+rhumb-distance@7.3.2/node_modules/@turf/rhumb-distance/dist/esm/index.js","../node_modules/.pnpm/@turf+rhumb-destination@7.3.2/node_modules/@turf/rhumb-destination/dist/esm/index.js","../node_modules/.pnpm/@turf+transform-rotate@7.3.2/node_modules/@turf/transform-rotate/dist/esm/index.js","../node_modules/.pnpm/@turf+line-to-polygon@7.3.2/node_modules/@turf/line-to-polygon/dist/esm/index.js","../src/utils/util.ts","../src/core/IconManager/index.ts","../node_modules/.pnpm/eventemitter3@5.0.1/node_modules/eventemitter3/index.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_freeGlobal.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_root.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_Symbol.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_getRawTag.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_objectToString.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_baseGetTag.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/isObjectLike.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/isSymbol.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_arrayMap.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/isArray.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_baseToString.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/isObject.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/isFunction.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_coreJsData.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_isMasked.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_toSource.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_baseIsNative.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_getValue.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_getNative.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_defineProperty.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_isIndex.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_baseAssignValue.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/eq.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_assignValue.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_isKey.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_nativeCreate.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_hashClear.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_hashDelete.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_hashGet.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_hashHas.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_hashSet.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_Hash.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_listCacheClear.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_assocIndexOf.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_listCacheDelete.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_listCacheGet.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_listCacheHas.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_listCacheSet.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_ListCache.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_Map.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_mapCacheClear.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_isKeyable.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_getMapData.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_mapCacheDelete.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_mapCacheGet.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_mapCacheHas.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_mapCacheSet.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_MapCache.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/memoize.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_memoizeCapped.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_stringToPath.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/toString.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_castPath.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_toKey.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/_baseSet.js","../node_modules/.pnpm/lodash-es@4.17.22/node_modules/lodash-es/set.js","../node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm-browser/stringify.js","../node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm-browser/rng.js","../node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm-browser/native.js","../node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm-browser/v4.js","../src/core/ResourceRegister/index.ts","../src/core/Focus/vars.ts","../src/core/Focus/index.ts","../src/core/Module/Context.ts","../src/core/Module/index.ts","../src/core/Tooltip/vars.ts","../src/core/Tooltip/index.ts","../src/modules/Ship/vars.ts","../src/types/CMap/index.ts","../src/modules/CMap/vars.ts","../src/modules/CMap/index.ts","../src/types/EventState/index.ts","../src/core/EventState/index.ts","../src/modules/Ship/Events/ResidentEvent.ts","../src/modules/Ship/index.ts","../src/modules/Ship/BaseShip.ts","../node_modules/.pnpm/dayjs@1.11.19/node_modules/dayjs/dayjs.min.js","../src/modules/Ship/plugins/AisShip.ts"],"sourcesContent":["/**\n * 判断是否为空\n */\nexport function isNull(val: any): boolean {\n if (['boolean', 'number'].includes(typeof val)) {\n return false;\n } else if (val instanceof Array) {\n return val.length === 0;\n } else if (val instanceof Object) {\n return JSON.stringify(val) === '{}';\n } else {\n return ['null', null, undefined, 'undefined', ''].includes(val);\n }\n}\n","import type { CacheItem, CacheOptions, CacheType } from '@/types/Cache'\nimport { isNull } from '@/utils/validate.ts'\n\nclass Cache {\n _options: CacheOptions\n cacheKey: string\n cacheType: CacheType\n\n constructor(options: CacheOptions) {\n this._options = options\n this.cacheKey = options.uniqueKey + '-'\n this.cacheType = options.type\n }\n\n set({ name, content }: { name: string; content: unknown }): void {\n const cacheName = `${this.cacheKey}${name}`\n if (typeof content === 'function') {\n content = content.toString()\n }\n const obj: CacheItem = {\n dataType: typeof content,\n content: content,\n type: this.cacheType,\n datetime: new Date().getTime(),\n }\n if (this.cacheType === 'sessionstorage') {\n window.sessionStorage.setItem(cacheName, JSON.stringify(obj))\n } else {\n window.localStorage.setItem(cacheName, JSON.stringify(obj))\n }\n }\n\n get(name: string) {\n const cacheName = `${this.cacheKey}${name}`\n let cacheString: string | null = ''\n if (this.cacheType === 'sessionstorage') {\n cacheString = window.sessionStorage.getItem(cacheName)\n } else {\n cacheString = window.localStorage.getItem(cacheName)\n }\n if (isNull(cacheString)) {\n console.warn(`未找到缓存,${name}不存在!`)\n return\n }\n\n try {\n const cacheObj = JSON.parse(cacheString!) as CacheItem\n\n const basicTypes = ['string', 'number', 'boolean', 'object']\n if (basicTypes.includes(cacheObj.dataType)) {\n return cacheObj.content\n } else if (cacheObj.dataType === 'function') {\n return this.stringParseToFunction(cacheObj.content)\n }\n return cacheObj.content\n } catch (e) {\n return cacheString\n }\n }\n\n remove(name: string) {\n const cacheName = `${this.cacheKey}${name}`\n if (this.cacheType === 'sessionstorage') {\n window.sessionStorage.removeItem(cacheName)\n } else {\n window.localStorage.removeItem(cacheName)\n }\n }\n\n removeAll() {\n const list = []\n if (this.cacheType === 'sessionstorage') {\n for (let i = 0; i <= window.sessionStorage.length; i++) {\n list.push({\n name: window.sessionStorage.key(i),\n content: this.get(window.sessionStorage.key(i)!),\n })\n }\n } else {\n for (let i = 0; i <= window.localStorage.length; i++) {\n list.push({\n name: window.localStorage.key(i),\n content: this.get(window.localStorage.key(i)!),\n })\n }\n }\n return list\n }\n\n /**\n * 把字符串化的函数还原为可执行函数\n * 请确保传入的字符串可信任\n */\n stringParseToFunction(str: any) {\n return new Function('\"use strict\"; return (' + str + ')')()\n }\n}\n\nexport default Cache\n","\n/**\n * Rearranges items so that all items in the [left, k] are the smallest.\n * The k-th element will have the (k - left + 1)-th smallest value in [left, right].\n *\n * @template T\n * @param {T[]} arr the array to partially sort (in place)\n * @param {number} k middle index for partial sorting (as defined above)\n * @param {number} [left=0] left index of the range to sort\n * @param {number} [right=arr.length-1] right index\n * @param {(a: T, b: T) => number} [compare = (a, b) => a - b] compare function\n */\nexport default function quickselect(arr, k, left = 0, right = arr.length - 1, compare = defaultCompare) {\n\n while (right > left) {\n if (right - left > 600) {\n const n = right - left + 1;\n const m = k - left + 1;\n const z = Math.log(n);\n const s = 0.5 * Math.exp(2 * z / 3);\n const sd = 0.5 * Math.sqrt(z * s * (n - s) / n) * (m - n / 2 < 0 ? -1 : 1);\n const newLeft = Math.max(left, Math.floor(k - m * s / n + sd));\n const newRight = Math.min(right, Math.floor(k + (n - m) * s / n + sd));\n quickselect(arr, k, newLeft, newRight, compare);\n }\n\n const t = arr[k];\n let i = left;\n /** @type {number} */\n let j = right;\n\n swap(arr, left, k);\n if (compare(arr[right], t) > 0) swap(arr, left, right);\n\n while (i < j) {\n swap(arr, i, j);\n i++;\n j--;\n while (compare(arr[i], t) < 0) i++;\n while (compare(arr[j], t) > 0) j--;\n }\n\n if (compare(arr[left], t) === 0) swap(arr, left, j);\n else {\n j++;\n swap(arr, j, right);\n }\n\n if (j <= k) left = j + 1;\n if (k <= j) right = j - 1;\n }\n}\n\n/**\n * @template T\n * @param {T[]} arr\n * @param {number} i\n * @param {number} j\n */\nfunction swap(arr, i, j) {\n const tmp = arr[i];\n arr[i] = arr[j];\n arr[j] = tmp;\n}\n\n/**\n * @template T\n * @param {T} a\n * @param {T} b\n * @returns {number}\n */\nfunction defaultCompare(a, b) {\n return a < b ? -1 : a > b ? 1 : 0;\n}\n","import quickselect from 'quickselect';\n\nexport default class RBush {\n constructor(maxEntries = 9) {\n // max entries in a node is 9 by default; min node fill is 40% for best performance\n this._maxEntries = Math.max(4, maxEntries);\n this._minEntries = Math.max(2, Math.ceil(this._maxEntries * 0.4));\n this.clear();\n }\n\n all() {\n return this._all(this.data, []);\n }\n\n search(bbox) {\n let node = this.data;\n const result = [];\n\n if (!intersects(bbox, node)) return result;\n\n const toBBox = this.toBBox;\n const nodesToSearch = [];\n\n while (node) {\n for (let i = 0; i < node.children.length; i++) {\n const child = node.children[i];\n const childBBox = node.leaf ? toBBox(child) : child;\n\n if (intersects(bbox, childBBox)) {\n if (node.leaf) result.push(child);\n else if (contains(bbox, childBBox)) this._all(child, result);\n else nodesToSearch.push(child);\n }\n }\n node = nodesToSearch.pop();\n }\n\n return result;\n }\n\n collides(bbox) {\n let node = this.data;\n\n if (!intersects(bbox, node)) return false;\n\n const nodesToSearch = [];\n while (node) {\n for (let i = 0; i < node.children.length; i++) {\n const child = node.children[i];\n const childBBox = node.leaf ? this.toBBox(child) : child;\n\n if (intersects(bbox, childBBox)) {\n if (node.leaf || contains(bbox, childBBox)) return true;\n nodesToSearch.push(child);\n }\n }\n node = nodesToSearch.pop();\n }\n\n return false;\n }\n\n load(data) {\n if (!(data && data.length)) return this;\n\n if (data.length < this._minEntries) {\n for (let i = 0; i < data.length; i++) {\n this.insert(data[i]);\n }\n return this;\n }\n\n // recursively build the tree with the given data from scratch using OMT algorithm\n let node = this._build(data.slice(), 0, data.length - 1, 0);\n\n if (!this.data.children.length) {\n // save as is if tree is empty\n this.data = node;\n\n } else if (this.data.height === node.height) {\n // split root if trees have the same height\n this._splitRoot(this.data, node);\n\n } else {\n if (this.data.height < node.height) {\n // swap trees if inserted one is bigger\n const tmpNode = this.data;\n this.data = node;\n node = tmpNode;\n }\n\n // insert the small tree into the large tree at appropriate level\n this._insert(node, this.data.height - node.height - 1, true);\n }\n\n return this;\n }\n\n insert(item) {\n if (item) this._insert(item, this.data.height - 1);\n return this;\n }\n\n clear() {\n this.data = createNode([]);\n return this;\n }\n\n remove(item, equalsFn) {\n if (!item) return this;\n\n let node = this.data;\n const bbox = this.toBBox(item);\n const path = [];\n const indexes = [];\n let i, parent, goingUp;\n\n // depth-first iterative tree traversal\n while (node || path.length) {\n\n if (!node) { // go up\n node = path.pop();\n parent = path[path.length - 1];\n i = indexes.pop();\n goingUp = true;\n }\n\n if (node.leaf) { // check current node\n const index = findItem(item, node.children, equalsFn);\n\n if (index !== -1) {\n // item found, remove the item and condense tree upwards\n node.children.splice(index, 1);\n path.push(node);\n this._condense(path);\n return this;\n }\n }\n\n if (!goingUp && !node.leaf && contains(node, bbox)) { // go down\n path.push(node);\n indexes.push(i);\n i = 0;\n parent = node;\n node = node.children[0];\n\n } else if (parent) { // go right\n i++;\n node = parent.children[i];\n goingUp = false;\n\n } else node = null; // nothing found\n }\n\n return this;\n }\n\n toBBox(item) { return item; }\n\n compareMinX(a, b) { return a.minX - b.minX; }\n compareMinY(a, b) { return a.minY - b.minY; }\n\n toJSON() { return this.data; }\n\n fromJSON(data) {\n this.data = data;\n return this;\n }\n\n _all(node, result) {\n const nodesToSearch = [];\n while (node) {\n if (node.leaf) result.push(...node.children);\n else nodesToSearch.push(...node.children);\n\n node = nodesToSearch.pop();\n }\n return result;\n }\n\n _build(items, left, right, height) {\n\n const N = right - left + 1;\n let M = this._maxEntries;\n let node;\n\n if (N <= M) {\n // reached leaf level; return leaf\n node = createNode(items.slice(left, right + 1));\n calcBBox(node, this.toBBox);\n return node;\n }\n\n if (!height) {\n // target height of the bulk-loaded tree\n height = Math.ceil(Math.log(N) / Math.log(M));\n\n // target number of root entries to maximize storage utilization\n M = Math.ceil(N / Math.pow(M, height - 1));\n }\n\n node = createNode([]);\n node.leaf = false;\n node.height = height;\n\n // split the items into M mostly square tiles\n\n const N2 = Math.ceil(N / M);\n const N1 = N2 * Math.ceil(Math.sqrt(M));\n\n multiSelect(items, left, right, N1, this.compareMinX);\n\n for (let i = left; i <= right; i += N1) {\n\n const right2 = Math.min(i + N1 - 1, right);\n\n multiSelect(items, i, right2, N2, this.compareMinY);\n\n for (let j = i; j <= right2; j += N2) {\n\n const right3 = Math.min(j + N2 - 1, right2);\n\n // pack each entry recursively\n node.children.push(this._build(items, j, right3, height - 1));\n }\n }\n\n calcBBox(node, this.toBBox);\n\n return node;\n }\n\n _chooseSubtree(bbox, node, level, path) {\n while (true) {\n path.push(node);\n\n if (node.leaf || path.length - 1 === level) break;\n\n let minArea = Infinity;\n let minEnlargement = Infinity;\n let targetNode;\n\n for (let i = 0; i < node.children.length; i++) {\n const child = node.children[i];\n const area = bboxArea(child);\n const enlargement = enlargedArea(bbox, child) - area;\n\n // choose entry with the least area enlargement\n if (enlargement < minEnlargement) {\n minEnlargement = enlargement;\n minArea = area < minArea ? area : minArea;\n targetNode = child;\n\n } else if (enlargement === minEnlargement) {\n // otherwise choose one with the smallest area\n if (area < minArea) {\n minArea = area;\n targetNode = child;\n }\n }\n }\n\n node = targetNode || node.children[0];\n }\n\n return node;\n }\n\n _insert(item, level, isNode) {\n const bbox = isNode ? item : this.toBBox(item);\n const insertPath = [];\n\n // find the best node for accommodating the item, saving all nodes along the path too\n const node = this._chooseSubtree(bbox, this.data, level, insertPath);\n\n // put the item into the node\n node.children.push(item);\n extend(node, bbox);\n\n // split on node overflow; propagate upwards if necessary\n while (level >= 0) {\n if (insertPath[level].children.length > this._maxEntries) {\n this._split(insertPath, level);\n level--;\n } else break;\n }\n\n // adjust bboxes along the insertion path\n this._adjustParentBBoxes(bbox, insertPath, level);\n }\n\n // split overflowed node into two\n _split(insertPath, level) {\n const node = insertPath[level];\n const M = node.children.length;\n const m = this._minEntries;\n\n this._chooseSplitAxis(node, m, M);\n\n const splitIndex = this._chooseSplitIndex(node, m, M);\n\n const newNode = createNode(node.children.splice(splitIndex, node.children.length - splitIndex));\n newNode.height = node.height;\n newNode.leaf = node.leaf;\n\n calcBBox(node, this.toBBox);\n calcBBox(newNode, this.toBBox);\n\n if (level) insertPath[level - 1].children.push(newNode);\n else this._splitRoot(node, newNode);\n }\n\n _splitRoot(node, newNode) {\n // split root node\n this.data = createNode([node, newNode]);\n this.data.height = node.height + 1;\n this.data.leaf = false;\n calcBBox(this.data, this.toBBox);\n }\n\n _chooseSplitIndex(node, m, M) {\n let index;\n let minOverlap = Infinity;\n let minArea = Infinity;\n\n for (let i = m; i <= M - m; i++) {\n const bbox1 = distBBox(node, 0, i, this.toBBox);\n const bbox2 = distBBox(node, i, M, this.toBBox);\n\n const overlap = intersectionArea(bbox1, bbox2);\n const area = bboxArea(bbox1) + bboxArea(bbox2);\n\n // choose distribution with minimum overlap\n if (overlap < minOverlap) {\n minOverlap = overlap;\n index = i;\n\n minArea = area < minArea ? area : minArea;\n\n } else if (overlap === minOverlap) {\n // otherwise choose distribution with minimum area\n if (area < minArea) {\n minArea = area;\n index = i;\n }\n }\n }\n\n return index || M - m;\n }\n\n // sorts node children by the best axis for split\n _chooseSplitAxis(node, m, M) {\n const compareMinX = node.leaf ? this.compareMinX : compareNodeMinX;\n const compareMinY = node.leaf ? this.compareMinY : compareNodeMinY;\n const xMargin = this._allDistMargin(node, m, M, compareMinX);\n const yMargin = this._allDistMargin(node, m, M, compareMinY);\n\n // if total distributions margin value is minimal for x, sort by minX,\n // otherwise it's already sorted by minY\n if (xMargin < yMargin) node.children.sort(compareMinX);\n }\n\n // total margin of all possible split distributions where each node is at least m full\n _allDistMargin(node, m, M, compare) {\n node.children.sort(compare);\n\n const toBBox = this.toBBox;\n const leftBBox = distBBox(node, 0, m, toBBox);\n const rightBBox = distBBox(node, M - m, M, toBBox);\n let margin = bboxMargin(leftBBox) + bboxMargin(rightBBox);\n\n for (let i = m; i < M - m; i++) {\n const child = node.children[i];\n extend(leftBBox, node.leaf ? toBBox(child) : child);\n margin += bboxMargin(leftBBox);\n }\n\n for (let i = M - m - 1; i >= m; i--) {\n const child = node.children[i];\n extend(rightBBox, node.leaf ? toBBox(child) : child);\n margin += bboxMargin(rightBBox);\n }\n\n return margin;\n }\n\n _adjustParentBBoxes(bbox, path, level) {\n // adjust bboxes along the given tree path\n for (let i = level; i >= 0; i--) {\n extend(path[i], bbox);\n }\n }\n\n _condense(path) {\n // go through the path, removing empty nodes and updating bboxes\n for (let i = path.length - 1, siblings; i >= 0; i--) {\n if (path[i].children.length === 0) {\n if (i > 0) {\n siblings = path[i - 1].children;\n siblings.splice(siblings.indexOf(path[i]), 1);\n\n } else this.clear();\n\n } else calcBBox(path[i], this.toBBox);\n }\n }\n}\n\nfunction findItem(item, items, equalsFn) {\n if (!equalsFn) return items.indexOf(item);\n\n for (let i = 0; i < items.length; i++) {\n if (equalsFn(item, items[i])) return i;\n }\n return -1;\n}\n\n// calculate node's bbox from bboxes of its children\nfunction calcBBox(node, toBBox) {\n distBBox(node, 0, node.children.length, toBBox, node);\n}\n\n// min bounding rectangle of node children from k to p-1\nfunction distBBox(node, k, p, toBBox, destNode) {\n if (!destNode) destNode = createNode(null);\n destNode.minX = Infinity;\n destNode.minY = Infinity;\n destNode.maxX = -Infinity;\n destNode.maxY = -Infinity;\n\n for (let i = k; i < p; i++) {\n const child = node.children[i];\n extend(destNode, node.leaf ? toBBox(child) : child);\n }\n\n return destNode;\n}\n\nfunction extend(a, b) {\n a.minX = Math.min(a.minX, b.minX);\n a.minY = Math.min(a.minY, b.minY);\n a.maxX = Math.max(a.maxX, b.maxX);\n a.maxY = Math.max(a.maxY, b.maxY);\n return a;\n}\n\nfunction compareNodeMinX(a, b) { return a.minX - b.minX; }\nfunction compareNodeMinY(a, b) { return a.minY - b.minY; }\n\nfunction bboxArea(a) { return (a.maxX - a.minX) * (a.maxY - a.minY); }\nfunction bboxMargin(a) { return (a.maxX - a.minX) + (a.maxY - a.minY); }\n\nfunction enlargedArea(a, b) {\n return (Math.max(b.maxX, a.maxX) - Math.min(b.minX, a.minX)) *\n (Math.max(b.maxY, a.maxY) - Math.min(b.minY, a.minY));\n}\n\nfunction intersectionArea(a, b) {\n const minX = Math.max(a.minX, b.minX);\n const minY = Math.max(a.minY, b.minY);\n const maxX = Math.min(a.maxX, b.maxX);\n const maxY = Math.min(a.maxY, b.maxY);\n\n return Math.max(0, maxX - minX) *\n Math.max(0, maxY - minY);\n}\n\nfunction contains(a, b) {\n return a.minX <= b.minX &&\n a.minY <= b.minY &&\n b.maxX <= a.maxX &&\n b.maxY <= a.maxY;\n}\n\nfunction intersects(a, b) {\n return b.minX <= a.maxX &&\n b.minY <= a.maxY &&\n b.maxX >= a.minX &&\n b.maxY >= a.minY;\n}\n\nfunction createNode(children) {\n return {\n children,\n height: 1,\n leaf: true,\n minX: Infinity,\n minY: Infinity,\n maxX: -Infinity,\n maxY: -Infinity\n };\n}\n\n// sort an array so that items come in groups of n unsorted items, with groups sorted between each other;\n// combines selection algorithm with binary divide & conquer approach\n\nfunction multiSelect(arr, left, right, n, compare) {\n const stack = [left, right];\n\n while (stack.length) {\n right = stack.pop();\n left = stack.pop();\n\n if (right - left <= n) continue;\n\n const mid = left + Math.ceil((right - left) / n / 2) * n;\n quickselect(arr, mid, left, right, compare);\n\n stack.push(left, mid, mid, right);\n }\n}\n","import { BBox } from 'rbush';\n\nexport type Id = string | number | undefined;\n\n/**\n * 初始基准点的位置\n */\nexport enum Directions {\n // TOP,\n // RIGHT,\n // BOTTOM,\n // LEFT,\n TOP_LEFT,\n TOP_RIGHT,\n BOTTOM_RIGHT,\n BOTTOM_LEFT,\n // CENTER,\n}\n\n/**\n * 范围值枚举\n */\nexport enum Scopes {\n MIN_X,\n MIN_Y,\n MAX_X,\n MAX_Y,\n}\n\n/**\n * bbox-范围 dir-初始基准点的位置 options-配置\n */\nexport interface CollisionItemOptions {\n id: string | number;\n center: BBox;\n top: BBox;\n bottom: BBox;\n left: BBox;\n right: BBox;\n 'top-left': BBox;\n 'top-right': BBox;\n 'bottom-left': BBox;\n 'bottom-right': BBox;\n}\n","import type { BBox } from 'rbush'\n\nimport type { CollisionItemOptions } from '@/types/Collision/item.ts'\nimport { Scopes } from '@/types/Collision/item.ts'\nimport type { Anchor } from '@/types/Toolip/index.ts'\n\nclass CollisionItem {\n // 最小X\n static MIN_X: Scopes = Scopes.MIN_X\n // 最小Y\n static MIN_Y: Scopes = Scopes.MIN_Y\n // 最大X\n static MAX_X: Scopes = Scopes.MAX_X\n // 最大Y\n static MAX_Y: Scopes = Scopes.MAX_Y\n\n id: CollisionItemOptions['id']\n\n visible = true\n\n dir: Anchor = 'top-left'\n\n dirs: Anchor[] = [\n 'top-left',\n 'top-right',\n 'bottom-left',\n 'bottom-right',\n 'center',\n 'top',\n 'bottom',\n 'left',\n 'right',\n ]\n\n _options: CollisionItemOptions\n\n /**\n *\n * @param options\n */\n constructor(options: CollisionItemOptions) {\n this.id = options.id\n this._options = options\n }\n\n get minX(): number {\n return this._options[this.dir].minX\n }\n\n get minY(): number {\n return this._options[this.dir].minY\n }\n\n get maxX(): number {\n return this._options[this.dir].maxX\n }\n\n get maxY(): number {\n return this._options[this.dir].maxY\n }\n\n /**\n *\n */\n getBBox(): BBox {\n return this._options[this.dir]\n }\n\n /**\n * 设置是否显示\n * @param visible\n */\n setVisible(visible: boolean): void {\n this.visible = visible\n }\n\n setDir(dir: Anchor): void {\n this.dir = dir\n }\n\n /**\n * 判断item与box是否相交\n * @param box\n * @return true-相交 false-不相交\n */\n isIntersect(box: BBox): boolean {\n const { minX, minY, maxX, maxY } = box\n return minX <= this.minX && minY <= this.minY && this.maxX <= maxX && this.maxY <= maxY\n }\n}\n\nexport default CollisionItem\n","import type { Map } from 'mapbox-gl'\nimport RBush from 'rbush'\n\nimport type { CollisionOptions } from '@/types/Collision'\nimport type { CollisionItemOptions } from '@/types/Collision/item.ts'\n\nimport CollisionItem from './CollisionItem.ts'\n\nclass Collision {\n _tree = new RBush<CollisionItem>()\n\n _map: Map | undefined\n\n _collisionList: CollisionItem[] = []\n\n constructor(map: Map, config?: CollisionOptions) {\n this._map = map\n if (Array.isArray(config?.collisions) && config.collisions.length > 0) {\n this.load(config.collisions)\n }\n }\n\n load(collisions: CollisionItemOptions[]): CollisionItem[] {\n this._tree.clear()\n\n this._collisionList = collisions.map((item) => new CollisionItem(item))\n\n return this.collides()\n }\n\n getItem(id: string | number): CollisionItem | undefined {\n return this._collisionList.find((item) => item.id === id)\n }\n\n clear(): void {\n this._tree.clear()\n }\n\n getCollisions(): CollisionItem[] {\n return this._collisionList\n }\n\n collides(): CollisionItem[] {\n // const dpr: number = window.devicePixelRatio || 1\n // const canvas_bbox: BBox = {\n // minX: 0,\n // minY: 0,\n // maxX: this._map._canvas.width / dpr,\n // maxY: this._map._canvas.height / dpr,\n // }\n for (const item of this._collisionList) {\n for (const dir of item.dirs) {\n item.setDir(dir)\n\n const isCollides = this._tree.collides(item)\n item.setVisible(!isCollides)\n\n if (item.visible) {\n this._tree.insert(item)\n break\n }\n }\n }\n\n return this.getCollisions()\n }\n}\n\nexport default Collision\n","export const version = '0.0.1'\n\nexport const prefix = 'mapbox-gl'\n\nexport const cacheKey = `${prefix}-cache`\n\nexport default {\n version,\n prefix,\n cacheKey,\n}\n","export interface Icon {\n name: string\n url: string\n options?: Partial<StyleImageMetadata>\n}\n\nexport interface SvgIcon {\n name: string\n svg: string\n}\n\ninterface StyleImageMetadata {\n pixelRatio: number\n sdf: boolean\n usvg: boolean\n stretchX?: [number, number][]\n stretchY?: [number, number][]\n content?: [number, number, number, number]\n}\n\nexport interface Image {\n width: number\n height: number\n image: ImageBitmap | HTMLImageElement | ImageData\n}\n\nexport enum RESULT_CODE {\n SUCCESS = 0,\n FAIL = -1,\n}\nexport interface result {\n code: RESULT_CODE\n data: Icon\n msg: string | Error\n}\n\nexport interface loadOptions {}\n","// index.ts\nvar earthRadius = 63710088e-1;\nvar factors = {\n centimeters: earthRadius * 100,\n centimetres: earthRadius * 100,\n degrees: 360 / (2 * Math.PI),\n feet: earthRadius * 3.28084,\n inches: earthRadius * 39.37,\n kilometers: earthRadius / 1e3,\n kilometres: earthRadius / 1e3,\n meters: earthRadius,\n metres: earthRadius,\n miles: earthRadius / 1609.344,\n millimeters: earthRadius * 1e3,\n millimetres: earthRadius * 1e3,\n nauticalmiles: earthRadius / 1852,\n radians: 1,\n yards: earthRadius * 1.0936\n};\nvar areaFactors = {\n acres: 247105e-9,\n centimeters: 1e4,\n centimetres: 1e4,\n feet: 10.763910417,\n hectares: 1e-4,\n inches: 1550.003100006,\n kilometers: 1e-6,\n kilometres: 1e-6,\n meters: 1,\n metres: 1,\n miles: 386e-9,\n nauticalmiles: 29155334959812285e-23,\n millimeters: 1e6,\n millimetres: 1e6,\n yards: 1.195990046\n};\nfunction feature(geom, properties, options = {}) {\n const feat = { type: \"Feature\" };\n if (options.id === 0 || options.id) {\n feat.id = options.id;\n }\n if (options.bbox) {\n feat.bbox = options.bbox;\n }\n feat.properties = properties || {};\n feat.geometry = geom;\n return feat;\n}\nfunction geometry(type, coordinates, _options = {}) {\n switch (type) {\n case \"Point\":\n return point(coordinates).geometry;\n case \"LineString\":\n return lineString(coordinates).geometry;\n case \"Polygon\":\n return polygon(coordinates).geometry;\n case \"MultiPoint\":\n return multiPoint(coordinates).geometry;\n case \"MultiLineString\":\n return multiLineString(coordinates).geometry;\n case \"MultiPolygon\":\n return multiPolygon(coordinates).geometry;\n default:\n throw new Error(type + \" is invalid\");\n }\n}\nfunction point(coordinates, properties, options = {}) {\n if (!coordinates) {\n throw new Error(\"coordinates is required\");\n }\n if (!Array.isArray(coordinates)) {\n throw new Error(\"coordinates must be an Array\");\n }\n if (coordinates.length < 2) {\n throw new Error(\"coordinates must be at least 2 numbers long\");\n }\n if (!isNumber(coordinates[0]) || !isNumber(coordinates[1])) {\n throw new Error(\"coordinates must contain numbers\");\n }\n const geom = {\n type: \"Point\",\n coordinates\n };\n return feature(geom, properties, options);\n}\nfunction points(coordinates, properties, options = {}) {\n return featureCollection(\n coordinates.map((coords) => {\n return point(coords, properties);\n }),\n options\n );\n}\nfunction polygon(coordinates, properties, options = {}) {\n for (const ring of coordinates) {\n if (ring.length < 4) {\n throw new Error(\n \"Each LinearRing of a Polygon must have 4 or more Positions.\"\n );\n }\n if (ring[ring.length - 1].length !== ring[0].length) {\n throw new Error(\"First and last Position are not equivalent.\");\n }\n for (let j = 0; j < ring[ring.length - 1].length; j++) {\n if (ring[ring.length - 1][j] !== ring[0][j]) {\n throw new Error(\"First and last Position are not equivalent.\");\n }\n }\n }\n const geom = {\n type: \"Polygon\",\n coordinates\n };\n return feature(geom, properties, options);\n}\nfunction polygons(coordinates, properties, options = {}) {\n return featureCollection(\n coordinates.map((coords) => {\n return polygon(coords, properties);\n }),\n options\n );\n}\nfunction lineString(coordinates, properties, options = {}) {\n if (coordinates.length < 2) {\n throw new Error(\"coordinates must be an array of two or more positions\");\n }\n const geom = {\n type: \"LineString\",\n coordinates\n };\n return feature(geom, properties, options);\n}\nfunction lineStrings(coordinates, properties, options = {}) {\n return featureCollection(\n coordinates.map((coords) => {\n return lineString(coords, properties);\n }),\n options\n );\n}\nfunction featureCollection(features, options = {}) {\n const fc = { type: \"FeatureCollection\" };\n if (options.id) {\n fc.id = options.id;\n }\n if (options.bbox) {\n fc.bbox = options.bbox;\n }\n fc.features = features;\n return fc;\n}\nfunction multiLineString(coordinates, properties, options = {}) {\n const geom = {\n type: \"MultiLineString\",\n coordinates\n };\n return feature(geom, properties, options);\n}\nfunction multiPoint(coordinates, properties, options = {}) {\n const geom = {\n type: \"MultiPoint\",\n coordinates\n };\n return feature(geom, properties, options);\n}\nfunction multiPolygon(coordinates, properties, options = {}) {\n const geom = {\n type: \"MultiPolygon\",\n coordinates\n };\n return feature(geom, properties, options);\n}\nfunction geometryCollection(geometries, properties, options = {}) {\n const geom = {\n type: \"GeometryCollection\",\n geometries\n };\n return feature(geom, properties, options);\n}\nfunction round(num, precision = 0) {\n if (precision && !(precision >= 0)) {\n throw new Error(\"precision must be a positive number\");\n }\n const multiplier = Math.pow(10, precision || 0);\n return Math.round(num * multiplier) / multiplier;\n}\nfunction radiansToLength(radians, units = \"kilometers\") {\n const factor = factors[units];\n if (!factor) {\n throw new Error(units + \" units is invalid\");\n }\n return radians * factor;\n}\nfunction lengthToRadians(distance, units = \"kilometers\") {\n const factor = factors[units];\n if (!factor) {\n throw new Error(units + \" units is invalid\");\n }\n return distance / factor;\n}\nfunction lengthToDegrees(distance, units) {\n return radiansToDegrees(lengthToRadians(distance, units));\n}\nfunction bearingToAzimuth(bearing) {\n let angle = bearing % 360;\n if (angle < 0) {\n angle += 360;\n }\n return angle;\n}\nfunction azimuthToBearing(angle) {\n angle = angle % 360;\n if (angle > 180) {\n return angle - 360;\n } else if (angle < -180) {\n return angle + 360;\n }\n return angle;\n}\nfunction radiansToDegrees(radians) {\n const normalisedRadians = radians % (2 * Math.PI);\n return normalisedRadians * 180 / Math.PI;\n}\nfunction degreesToRadians(degrees) {\n const normalisedDegrees = degrees % 360;\n return normalisedDegrees * Math.PI / 180;\n}\nfunction convertLength(length, originalUnit = \"kilometers\", finalUnit = \"kilometers\") {\n if (!(length >= 0)) {\n throw new Error(\"length must be a positive number\");\n }\n return radiansToLength(lengthToRadians(length, originalUnit), finalUnit);\n}\nfunction convertArea(area, originalUnit = \"meters\", finalUnit = \"kilometers\") {\n if (!(area >= 0)) {\n throw new Error(\"area must be a positive number\");\n }\n const startFactor = areaFactors[originalUnit];\n if (!startFactor) {\n throw new Error(\"invalid original units\");\n }\n const finalFactor = areaFactors[finalUnit];\n if (!finalFactor) {\n throw new Error(\"invalid final units\");\n }\n return area / startFactor * finalFactor;\n}\nfunction isNumber(num) {\n return !isNaN(num) && num !== null && !Array.isArray(num);\n}\nfunction isObject(input) {\n return input !== null && typeof input === \"object\" && !Array.isArray(input);\n}\nfunction validateBBox(bbox) {\n if (!bbox) {\n throw new Error(\"bbox is required\");\n }\n if (!Array.isArray(bbox)) {\n throw new Error(\"bbox must be an Array\");\n }\n if (bbox.length !== 4 && bbox.length !== 6) {\n throw new Error(\"bbox must be an Array of 4 or 6 numbers\");\n }\n bbox.forEach((num) => {\n if (!isNumber(num)) {\n throw new Error(\"bbox must only contain numbers\");\n }\n });\n}\nfunction validateId(id) {\n if (!id) {\n throw new Error(\"id is required\");\n }\n if ([\"string\", \"number\"].indexOf(typeof id) === -1) {\n throw new Error(\"id must be a number or a string\");\n }\n}\nexport {\n areaFactors,\n azimuthToBearing,\n bearingToAzimuth,\n convertArea,\n convertLength,\n degreesToRadians,\n earthRadius,\n factors,\n feature,\n featureCollection,\n geometry,\n geometryCollection,\n isNumber,\n isObject,\n lengthToDegrees,\n lengthToRadians,\n lineString,\n lineStrings,\n multiLineString,\n multiPoint,\n multiPolygon,\n point,\n points,\n polygon,\n polygons,\n radiansToDegrees,\n radiansToLength,\n round,\n validateBBox,\n validateId\n};\n//# sourceMappingURL=index.js.map","// index.ts\nimport { isNumber } from \"@turf/helpers\";\nfunction getCoord(coord) {\n if (!coord) {\n throw new Error(\"coord is required\");\n }\n if (!Array.isArray(coord)) {\n if (coord.type === \"Feature\" && coord.geometry !== null && coord.geometry.type === \"Point\") {\n return [...coord.geometry.coordinates];\n }\n if (coord.type === \"Point\") {\n return [...coord.coordinates];\n }\n }\n if (Array.isArray(coord) && coord.length >= 2 && !Array.isArray(coord[0]) && !Array.isArray(coord[1])) {\n return [...coord];\n }\n throw new Error(\"coord must be GeoJSON Point or an Array of numbers\");\n}\nfunction getCoords(coords) {\n if (Array.isArray(coords)) {\n return coords;\n }\n if (coords.type === \"Feature\") {\n if (coords.geometry !== null) {\n return coords.geometry.coordinates;\n }\n } else {\n if (coords.coordinates) {\n return coords.coordinates;\n }\n }\n throw new Error(\n \"coords must be GeoJSON Feature, Geometry Object or an Array\"\n );\n}\nfunction containsNumber(coordinates) {\n if (coordinates.length > 1 && isNumber(coordinates[0]) && isNumber(coordinates[1])) {\n return true;\n }\n if (Array.isArray(coordinates[0]) && coordinates[0].length) {\n return containsNumber(coordinates[0]);\n }\n throw new Error(\"coordinates must only contain numbers\");\n}\nfunction geojsonType(value, type, name) {\n if (!type || !name) {\n throw new Error(\"type and name required\");\n }\n if (!value || value.type !== type) {\n throw new Error(\n \"Invalid input to \" + name + \": must be a \" + type + \", given \" + value.type\n );\n }\n}\nfunction featureOf(feature, type, name) {\n if (!feature) {\n throw new Error(\"No feature passed\");\n }\n if (!name) {\n throw new Error(\".featureOf() requires a name\");\n }\n if (!feature || feature.type !== \"Feature\" || !feature.geometry) {\n throw new Error(\n \"Invalid input to \" + name + \", Feature with geometry required\"\n );\n }\n if (!feature.geometry || feature.geometry.type !== type) {\n throw new Error(\n \"Invalid input to \" + name + \": must be a \" + type + \", given \" + feature.geometry.type\n );\n }\n}\nfunction collectionOf(featureCollection, type, name) {\n if (!featureCollection) {\n throw new Error(\"No featureCollection passed\");\n }\n if (!name) {\n throw new Error(\".collectionOf() requires a name\");\n }\n if (!featureCollection || featureCollection.type !== \"FeatureCollection\") {\n throw new Error(\n \"Invalid input to \" + name + \", FeatureCollection required\"\n );\n }\n for (const feature of featureCollection.features) {\n if (!feature || feature.type !== \"Feature\" || !feature.geometry) {\n throw new Error(\n \"Invalid input to \" + name + \", Feature with geometry required\"\n );\n }\n if (!feature.geometry || feature.geometry.type !== type) {\n throw new Error(\n \"Invalid input to \" + name + \": must be a \" + type + \", given \" + feature.geometry.type\n );\n }\n }\n}\nfunction getGeom(geojson) {\n if (geojson.type === \"Feature\") {\n return geojson.geometry;\n }\n return geojson;\n}\nfunction getType(geojson, _name) {\n if (geojson.type === \"FeatureCollection\") {\n return \"FeatureCollection\";\n }\n if (geojson.type === \"GeometryCollection\") {\n return \"GeometryCollection\";\n }\n if (geojson.type === \"Feature\" && geojson.geometry !== null) {\n return geojson.geometry.type;\n }\n return geojson.type;\n}\nexport {\n collectionOf,\n containsNumber,\n featureOf,\n geojsonType,\n getCoord,\n getCoords,\n getGeom,\n getType\n};\n//# sourceMappingURL=index.js.map","// index.ts\nimport { degreesToRadians, radiansToDegrees } from \"@turf/helpers\";\nimport { getCoord } from \"@turf/invariant\";\nfunction rhumbBearing(start, end, options = {}) {\n let bear360;\n if (options.final) {\n bear360 = calculateRhumbBearing(getCoord(end), getCoord(start));\n } else {\n bear360 = calculateRhumbBearing(getCoord(start), getCoord(end));\n }\n const bear180 = bear360 > 180 ? -(360 - bear360) : bear360;\n return bear180;\n}\nfunction calculateRhumbBearing(from, to) {\n const phi1 = degreesToRadians(from[1]);\n const phi2 = degreesToRadians(to[1]);\n let deltaLambda = degreesToRadians(to[0] - from[0]);\n if (deltaLambda > Math.PI) {\n deltaLambda -= 2 * Math.PI;\n }\n if (deltaLambda < -Math.PI) {\n deltaLambda += 2 * Math.PI;\n }\n const deltaPsi = Math.log(\n Math.tan(phi2 / 2 + Math.PI / 4) / Math.tan(phi1 / 2 + Math.PI / 4)\n );\n const theta = Math.atan2(deltaLambda, deltaPsi);\n return (radiansToDegrees(theta) + 360) % 360;\n}\nvar index_default = rhumbBearing;\nexport {\n index_default as default,\n rhumbBearing\n};\n//# sourceMappingURL=index.js.map","// index.ts\nimport { feature, point, lineString, isObject } from \"@turf/helpers\";\nfunction coordEach(geojson, callback, excludeWrapCoord) {\n if (geojson === null) return;\n var j, k, l, geometry, stopG, coords, geometryMaybeCollection, wrapShrink = 0, coordIndex = 0, isGeometryCollection, type = geojson.type, isFeatureCollection = type === \"FeatureCollection\", isFeature = type === \"Feature\", stop = isFeatureCollection ? geojson.features.length : 1;\n for (var featureIndex = 0; featureIndex < stop; featureIndex++) {\n geometryMaybeCollection = isFeatureCollection ? (\n // @ts-expect-error: Known type conflict\n geojson.features[featureIndex].geometry\n ) : isFeature ? (\n // @ts-expect-error: Known type conflict\n geojson.geometry\n ) : geojson;\n isGeometryCollection = geometryMaybeCollection ? geometryMaybeCollection.type === \"GeometryCollection\" : false;\n stopG = isGeometryCollection ? geometryMaybeCollection.geometries.length : 1;\n for (var geomIndex = 0; geomIndex < stopG; geomIndex++) {\n var multiFeatureIndex = 0;\n var geometryIndex = 0;\n geometry = isGeometryCollection ? geometryMaybeCollection.geometries[geomIndex] : geometryMaybeCollection;\n if (geometry === null) continue;\n coords = geometry.coordinates;\n var geomType = geometry.type;\n wrapShrink = excludeWrapCoord && (geomType === \"Polygon\" || geomType === \"MultiPolygon\") ? 1 : 0;\n switch (geomType) {\n case null:\n break;\n case \"Point\":\n if (\n // @ts-expect-error: Known type conflict\n callback(\n coords,\n coordIndex,\n featureIndex,\n multiFeatureIndex,\n geometryIndex\n ) === false\n )\n return false;\n coordIndex++;\n multiFeatureIndex++;\n break;\n case \"LineString\":\n case \"MultiPoint\":\n for (j = 0; j < coords.length; j++) {\n if (\n // @ts-expect-error: Known type conflict\n callback(\n coords[j],\n coordIndex,\n featureIndex,\n multiFeatureIndex,\n geometryIndex\n ) === false\n )\n return false;\n coordIndex++;\n if (geomType === \"MultiPoint\") multiFeatureIndex++;\n }\n if (geomType === \"LineString\") multiFeatureIndex++;\n break;\n case \"Polygon\":\n case \"MultiLineString\":\n for (j = 0; j < coords.length; j++) {\n for (k = 0; k < coords[j].length - wrapShrink; k++) {\n if (\n // @ts-expect-error: Known type conflict\n callback(\n coords[j][k],\n coordIndex,\n featureIndex,\n multiFeatureIndex,\n geometryIndex\n ) === false\n )\n return false;\n coordIndex++;\n }\n if (geomType === \"MultiLineString\") multiFeatureIndex++;\n if (geomType === \"Polygon\") geometryIndex++;\n }\n if (geomType === \"Polygon\") multiFeatureIndex++;\n break;\n case \"MultiPolygon\":\n for (j = 0; j < coords.length; j++) {\n geometryIndex = 0;\n for (k = 0; k < coords[j].length; k++) {\n for (l = 0; l < coords[j][k].length - wrapShrink; l++) {\n if (\n // @ts-expect-error: Known type conflict\n callback(\n coords[j][k][l],\n coordIndex,\n featureIndex,\n multiFeatureIndex,\n geometryIndex\n ) === false\n )\n return false;\n coordIndex++;\n }\n geometryIndex++;\n }\n multiFeatureIndex++;\n }\n break;\n case \"GeometryCollection\":\n for (j = 0; j < geometry.geometries.length; j++)\n if (\n // @ts-expect-error: Known type conflict\n coordEach(geometry.geometries[j], callback, excludeWrapCoord) === false\n )\n return false;\n break;\n default:\n throw new Error(\"Unknown Geometry Type\");\n }\n }\n }\n}\nfunction coordReduce(geojson, callback, initialValue, excludeWrapCoord) {\n var previousValue = initialValue;\n coordEach(\n geojson,\n function(currentCoord, coordIndex, featureIndex, multiFeatureIndex, geometryIndex) {\n if (coordIndex === 0 && initialValue === void 0)\n previousValue = currentCoord;\n else\n previousValue = callback(\n // @ts-expect-error: Known type conflict\n previousValue,\n currentCoord,\n coordIndex,\n featureIndex,\n multiFeatureIndex,\n geometryIndex\n );\n },\n excludeWrapCoord\n );\n return previousValue;\n}\nfunction propEach(geojson, callback) {\n var i;\n switch (geojson.type) {\n case \"FeatureCollection\":\n for (i = 0; i < geojson.features.length; i++) {\n if (callback(geojson.features[i].properties, i) === false) break;\n }\n break;\n case \"Feature\":\n callback(geojson.properties, 0);\n break;\n }\n}\nfunction propReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n propEach(geojson, function(currentProperties, featureIndex) {\n if (featureIndex === 0 && initialValue === void 0)\n previousValue = currentProperties;\n else\n previousValue = callback(previousValue, currentProperties, featureIndex);\n });\n return previousValue;\n}\nfunction featureEach(geojson, callback) {\n if (geojson.type === \"Feature\") {\n callback(geojson, 0);\n } else if (geojson.type === \"FeatureCollection\") {\n for (var i = 0; i < geojson.features.length; i++) {\n if (callback(geojson.features[i], i) === false) break;\n }\n }\n}\nfunction featureReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n featureEach(geojson, function(currentFeature, featureIndex) {\n if (featureIndex === 0 && initialValue === void 0)\n previousValue = currentFeature;\n else previousValue = callback(previousValue, currentFeature, featureIndex);\n });\n return previousValue;\n}\nfunction coordAll(geojson) {\n var coords = [];\n coordEach(geojson, function(coord) {\n coords.push(coord);\n });\n return coords;\n}\nfunction geomEach(geojson, callback) {\n var i, j, g, geometry, stopG, geometryMaybeCollection, isGeometryCollection, featureProperties, featureBBox, featureId, featureIndex = 0, isFeatureCollection = geojson.type === \"FeatureCollection\", isFeature = geojson.type === \"Feature\", stop = isFeatureCollection ? geojson.features.length : 1;\n for (i = 0; i < stop; i++) {\n geometryMaybeCollection = isFeatureCollection ? (\n // @ts-expect-error: Known type conflict\n geojson.features[i].geometry\n ) : isFeature ? (\n // @ts-expect-error: Known type conflict\n geojson.geometry\n ) : geojson;\n featureProperties = isFeatureCollection ? (\n // @ts-expect-error: Known type conflict\n geojson.features[i].properties\n ) : isFeature ? (\n // @ts-expect-error: Known type conflict\n geojson.properties\n ) : {};\n featureBBox = isFeatureCollection ? (\n // @ts-expect-error: Known type conflict\n geojson.features[i].bbox\n ) : isFeature ? (\n // @ts-expect-error: Known type conflict\n geojson.bbox\n ) : void 0;\n featureId = isFeatureCollection ? (\n // @ts-expect-error: Known type conflict\n geojson.features[i].id\n ) : isFeature ? (\n // @ts-expect-error: Known type conflict\n geojson.id\n ) : void 0;\n isGeometryCollection = geometryMaybeCollection ? geometryMaybeCollection.type === \"GeometryCollection\" : false;\n stopG = isGeometryCollection ? geometryMaybeCollection.geometries.length : 1;\n for (g = 0; g < stopG; g++) {\n geometry = isGeometryCollection ? geometryMaybeCollection.geometries[g] : geometryMaybeCollection;\n if (geometry === null) {\n if (\n // @ts-expect-error: Known type conflict\n callback(\n // @ts-expect-error: Known type conflict\n null,\n featureIndex,\n featureProperties,\n featureBBox,\n featureId\n ) === false\n )\n return false;\n continue;\n }\n switch (geometry.type) {\n case \"Point\":\n case \"LineString\":\n case \"MultiPoint\":\n case \"Polygon\":\n case \"MultiLineString\":\n case \"MultiPolygon\": {\n if (\n // @ts-expect-error: Known type conflict\n callback(\n geometry,\n featureIndex,\n featureProperties,\n featureBBox,\n featureId\n ) === false\n )\n return false;\n break;\n }\n case \"GeometryCollection\": {\n for (j = 0; j < geometry.geometries.length; j++) {\n if (\n // @ts-expect-error: Known type conflict\n callback(\n geometry.geometries[j],\n featureIndex,\n featureProperties,\n featureBBox,\n featureId\n ) === false\n )\n return false;\n }\n break;\n }\n default:\n throw new Error(\"Unknown Geometry Type\");\n }\n }\n featureIndex++;\n }\n}\nfunction geomReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n geomEach(\n geojson,\n function(currentGeometry, featureIndex, featureProperties, featureBBox, featureId) {\n if (featureIndex === 0 && initialValue === void 0)\n previousValue = currentGeometry;\n else\n previousValue = callback(\n // @ts-expect-error: Known type conflict\n previousValue,\n currentGeometry,\n featureIndex,\n featureProperties,\n featureBBox,\n featureId\n );\n }\n );\n return previousValue;\n}\nfunction flattenEach(geojson, callback) {\n geomEach(geojson, function(geometry, featureIndex, properties, bbox, id) {\n var type = geometry === null ? null : geometry.type;\n switch (type) {\n case null:\n case \"Point\":\n case \"LineString\":\n case \"Polygon\":\n if (\n // @ts-expect-error: Known type conflict\n callback(\n feature(geometry, properties, { bbox, id }),\n featureIndex,\n 0\n ) === false\n )\n return false;\n return;\n }\n var geomType;\n switch (type) {\n case \"MultiPoint\":\n geomType = \"Point\";\n break;\n case \"MultiLineString\":\n geomType = \"LineString\";\n break;\n case \"MultiPolygon\":\n geomType = \"Polygon\";\n break;\n }\n for (\n var multiFeatureIndex = 0;\n // @ts-expect-error: Known type conflict\n multiFeatureIndex < geometry.coordinates.length;\n multiFeatureIndex++\n ) {\n var coordinate = geometry.coordinates[multiFeatureIndex];\n var geom = {\n type: geomType,\n coordinates: coordinate\n };\n if (\n // @ts-expect-error: Known type conflict\n callback(feature(geom, properties), featureIndex, multiFeatureIndex) === false\n )\n return false;\n }\n });\n}\nfunction flattenReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n flattenEach(\n geojson,\n function(currentFeature, featureIndex, multiFeatureIndex) {\n if (featureIndex === 0 && multiFeatureIndex === 0 && initialValue === void 0)\n previousValue = currentFeature;\n else\n previousValue = callback(\n // @ts-expect-error: Known type conflict\n previousValue,\n currentFeature,\n featureIndex,\n multiFeatureIndex\n );\n }\n );\n return previousValue;\n}\nfunction segmentEach(geojson, callback) {\n flattenEach(geojson, function(feature2, featureIndex, multiFeatureIndex) {\n var segmentIndex = 0;\n if (!feature2.geometry) return;\n var type = feature2.geometry.type;\n if (type === \"Point\" || type === \"MultiPoint\") return;\n var previousCoords;\n var previousFeatureIndex = 0;\n var previousMultiIndex = 0;\n var prevGeomIndex = 0;\n if (\n // @ts-expect-error: Known type conflict\n coordEach(\n feature2,\n function(currentCoord, coordIndex, featureIndexCoord, multiPartIndexCoord, geometryIndex) {\n if (\n // @ts-expect-error: Known type conflict\n previousCoords === void 0 || featureIndex > previousFeatureIndex || multiPartIndexCoord > previousMultiIndex || geometryIndex > prevGeomIndex\n ) {\n previousCoords = currentCoord;\n previousFeatureIndex = featureIndex;\n previousMultiIndex = multiPartIndexCoord;\n prevGeomIndex = geometryIndex;\n segmentIndex = 0;\n return;\n }\n var currentSegment = lineString(\n // @ts-expect-error: Known type conflict\n [previousCoords, currentCoord],\n feature2.properties\n );\n if (\n // @ts-expect-error: Known type conflict\n callback(\n // @ts-expect-error: Known type conflict\n currentSegment,\n featureIndex,\n multiFeatureIndex,\n geometryIndex,\n segmentIndex\n ) === false\n )\n return false;\n segmentIndex++;\n previousCoords = currentCoord;\n }\n ) === false\n )\n return false;\n });\n}\nfunction segmentReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n var started = false;\n segmentEach(\n geojson,\n function(currentSegment, featureIndex, multiFeatureIndex, geometryIndex, segmentIndex) {\n if (started === false && initialValue === void 0)\n previousValue = currentSegment;\n else\n previousValue = callback(\n previousValue,\n // @ts-expect-error: Known type conflict\n currentSegment,\n featureIndex,\n multiFeatureIndex,\n geometryIndex,\n segmentIndex\n );\n started = true;\n }\n );\n return previousValue;\n}\nfunction lineEach(geojson, callback) {\n if (!geojson) throw new Error(\"geojson is required\");\n flattenEach(geojson, function(feature2, featureIndex, multiFeatureIndex) {\n if (feature2.geometry === null) return;\n var type = feature2.geometry.type;\n var coords = feature2.geometry.coordinates;\n switch (type) {\n case \"LineString\":\n if (callback(feature2, featureIndex, multiFeatureIndex, 0, 0) === false)\n return false;\n break;\n case \"Polygon\":\n for (var geometryIndex = 0; geometryIndex < coords.length; geometryIndex++) {\n if (\n // @ts-expect-error: Known type conflict\n callback(\n // @ts-expect-error: Known type conflict\n lineString(coords[geometryIndex], feature2.properties),\n featureIndex,\n multiFeatureIndex,\n geometryIndex\n ) === false\n )\n return false;\n }\n break;\n }\n });\n}\nfunction lineReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n lineEach(\n geojson,\n function(currentLine, featureIndex, multiFeatureIndex, geometryIndex) {\n if (featureIndex === 0 && initialValue === void 0)\n previousValue = currentLine;\n else\n previousValue = callback(\n previousValue,\n currentLine,\n featureIndex,\n multiFeatureIndex,\n geometryIndex\n );\n }\n );\n return previousValue;\n}\nfunction findSegment(geojson, options) {\n options = options || {};\n if (!isObject(options)) throw new Error(\"options is invalid\");\n var featureIndex = options.featureIndex || 0;\n var multiFeatureIndex = options.multiFeatureIndex || 0;\n var geometryIndex = options.geometryIndex || 0;\n var segmentIndex = options.segmentIndex || 0;\n var properties = options.properties;\n var geometry;\n switch (geojson.type) {\n case \"FeatureCollection\":\n if (featureIndex < 0)\n featureIndex = geojson.features.length + featureIndex;\n properties = properties || geojson.features[featureIndex].properties;\n geometry = geojson.features[featureIndex].geometry;\n break;\n case \"Feature\":\n properties = properties || geojson.properties;\n geometry = geojson.geometry;\n break;\n case \"Point\":\n case \"MultiPoint\":\n return null;\n case \"LineString\":\n case \"Polygon\":\n case \"MultiLineString\":\n case \"MultiPolygon\":\n geometry = geojson;\n break;\n default:\n throw new Error(\"geojson is invalid\");\n }\n if (geometry === null) return null;\n var coords = geometry.coordinates;\n switch (geometry.type) {\n case \"Point\":\n case \"MultiPoint\":\n return null;\n case \"LineString\":\n if (segmentIndex < 0) segmentIndex = coords.length + segmentIndex - 1;\n return lineString(\n // @ts-expect-error: Known type conflict\n [coords[segmentIndex], coords[segmentIndex + 1]],\n properties,\n options\n );\n case \"Polygon\":\n if (geometryIndex < 0) geometryIndex = coords.length + geometryIndex;\n if (segmentIndex < 0)\n segmentIndex = coords[geometryIndex].length + segmentIndex - 1;\n return lineString(\n [\n // @ts-expect-error: Known type conflict\n coords[geometryIndex][segmentIndex],\n // @ts-expect-error: Known type conflict\n coords[geometryIndex][segmentIndex + 1]\n ],\n properties,\n options\n );\n case \"MultiLineString\":\n if (multiFeatureIndex < 0)\n multiFeatureIndex = coords.length + multiFeatureIndex;\n if (segmentIndex < 0)\n segmentIndex = coords[multiFeatureIndex].length + segmentIndex - 1;\n return lineString(\n [\n // @ts-expect-error: Known type conflict\n coords[multiFeatureIndex][segmentIndex],\n // @ts-expect-error: Known type conflict\n coords[multiFeatureIndex][segmentIndex + 1]\n ],\n properties,\n options\n );\n case \"MultiPolygon\":\n if (multiFeatureIndex < 0)\n multiFeatureIndex = coords.length + multiFeatureIndex;\n if (geometryIndex < 0)\n geometryIndex = coords[multiFeatureIndex].length + geometryIndex;\n if (segmentIndex < 0)\n segmentIndex = // @ts-expect-error: Known type conflict\n coords[multiFeatureIndex][geometryIndex].length - segmentIndex - 1;\n return lineString(\n [\n // @ts-expect-error: Known type conflict\n coords[multiFeatureIndex][geometryIndex][segmentIndex],\n // @ts-expect-error: Known type conflict\n coords[multiFeatureIndex][geometryIndex][segmentIndex + 1]\n ],\n properties,\n options\n );\n }\n throw new Error(\"geojson is invalid\");\n}\nfunction findPoint(geojson, options) {\n options = options || {};\n if (!isObject(options)) throw new Error(\"options is invalid\");\n var featureIndex = options.featureIndex || 0;\n var multiFeatureIndex = options.multiFeatureIndex || 0;\n var geometryIndex = options.geometryIndex || 0;\n var coordIndex = options.coordIndex || 0;\n var properties = options.properties;\n var geometry;\n switch (geojson.type) {\n case \"FeatureCollection\":\n if (featureIndex < 0)\n featureIndex = geojson.features.length + featureIndex;\n properties = properties || geojson.features[featureIndex].properties;\n geometry = geojson.features[featureIndex].geometry;\n break;\n case \"Feature\":\n properties = properties || geojson.properties;\n geometry = geojson.geometry;\n break;\n case \"Point\":\n case \"MultiPoint\":\n return null;\n case \"LineString\":\n case \"Polygon\":\n case \"MultiLineString\":\n case \"MultiPolygon\":\n geometry = geojson;\n break;\n default:\n throw new Error(\"geojson is invalid\");\n }\n if (geometry === null) return null;\n var coords = geometry.coordinates;\n switch (geometry.type) {\n case \"Point\":\n return point(coords, properties, options);\n case \"MultiPoint\":\n if (multiFeatureIndex < 0)\n multiFeatureIndex = coords.length + multiFeatureIndex;\n return point(coords[multiFeatureIndex], properties, options);\n case \"LineString\":\n if (coordIndex < 0) coordIndex = coords.length + coordIndex;\n return point(coords[coordIndex], properties, options);\n case \"Polygon\":\n if (geometryIndex < 0) geometryIndex = coords.length + geometryIndex;\n if (coordIndex < 0)\n coordIndex = coords[geometryIndex].length + coordIndex;\n return point(coords[geometryIndex][coordIndex], properties, options);\n case \"MultiLineString\":\n if (multiFeatureIndex < 0)\n multiFeatureIndex = coords.length + multiFeatureIndex;\n if (coordIndex < 0)\n coordIndex = coords[multiFeatureIndex].length + coordIndex;\n return point(coords[multiFeatureIndex][coordIndex], properties, options);\n case \"MultiPolygon\":\n if (multiFeatureIndex < 0)\n multiFeatureIndex = coords.length + multiFeatureIndex;\n if (geometryIndex < 0)\n geometryIndex = coords[multiFeatureIndex].length + geometryIndex;\n if (coordIndex < 0)\n coordIndex = coords[multiFeatureIndex][geometryIndex].length - coordIndex;\n return point(\n coords[multiFeatureIndex][geometryIndex][coordIndex],\n properties,\n options\n );\n }\n throw new Error(\"geojson is invalid\");\n}\nexport {\n coordAll,\n coordEach,\n coordReduce,\n featureEach,\n featureReduce,\n findPoint,\n findSegment,\n flattenEach,\n flattenReduce,\n geomEach,\n geomReduce,\n lineEach,\n lineReduce,\n propEach,\n propReduce,\n segmentEach,\n segmentReduce\n};\n//# sourceMappingURL=index.js.map","// index.ts\nimport { coordEach } from \"@turf/meta\";\nfunction bbox(geojson, options = {}) {\n if (geojson.bbox != null && true !== options.recompute) {\n return geojson.bbox;\n }\n const result = [Infinity, Infinity, -Infinity, -Infinity];\n coordEach(geojson, (coord) => {\n if (result[0] > coord[0]) {\n result[0] = coord[0];\n }\n if (result[1] > coord[1]) {\n result[1] = coord[1];\n }\n if (result[2] < coord[0]) {\n result[2] = coord[0];\n }\n if (result[3] < coord[1]) {\n result[3] = coord[1];\n }\n });\n return result;\n}\nvar index_default = bbox;\nexport {\n bbox,\n index_default as default\n};\n//# sourceMappingURL=index.js.map","// index.ts\nimport { point } from \"@turf/helpers\";\nimport { coordEach } from \"@turf/meta\";\nfunction centroid(geojson, options = {}) {\n let xSum = 0;\n let ySum = 0;\n let len = 0;\n coordEach(\n geojson,\n function(coord) {\n xSum += coord[0];\n ySum += coord[1];\n len++;\n },\n true\n );\n return point([xSum / len, ySum / len], options.properties);\n}\nvar index_default = centroid;\nexport {\n centroid,\n index_default as default\n};\n//# sourceMappingURL=index.js.map","// index.ts\nfunction clone(geojson) {\n if (!geojson) {\n throw new Error(\"geojson is required\");\n }\n switch (geojson.type) {\n case \"Feature\":\n return cloneFeature(geojson);\n case \"FeatureCollection\":\n return cloneFeatureCollection(geojson);\n case \"Point\":\n case \"LineString\":\n case \"Polygon\":\n case \"MultiPoint\":\n case \"MultiLineString\":\n case \"MultiPolygon\":\n case \"GeometryCollection\":\n return cloneGeometry(geojson);\n default:\n throw new Error(\"unknown GeoJSON type\");\n }\n}\nfunction cloneFeature(geojson) {\n const cloned = { type: \"Feature\" };\n Object.keys(geojson).forEach((key) => {\n switch (key) {\n case \"type\":\n case \"properties\":\n case \"geometry\":\n return;\n default:\n cloned[key] = geojson[key];\n }\n });\n cloned.properties = cloneProperties(geojson.properties);\n if (geojson.geometry == null) {\n cloned.geometry = null;\n } else {\n cloned.geometry = cloneGeometry(geojson.geometry);\n }\n return cloned;\n}\nfunction cloneProperties(properties) {\n const cloned = {};\n if (!properties) {\n return cloned;\n }\n Object.keys(properties).forEach((key) => {\n const value = properties[key];\n if (typeof value === \"object\") {\n if (value === null) {\n cloned[key] = null;\n } else if (Array.isArray(value)) {\n cloned[key] = value.map((item) => {\n return item;\n });\n } else {\n cloned[key] = cloneProperties(value);\n }\n } else {\n cloned[key] = value;\n }\n });\n return cloned;\n}\nfunction cloneFeatureCollection(geojson) {\n const cloned = { type: \"FeatureCollection\" };\n Object.keys(geojson).forEach((key) => {\n switch (key) {\n case \"type\":\n case \"features\":\n return;\n default:\n cloned[key] = geojson[key];\n }\n });\n cloned.features = geojson.features.map((feature) => {\n return cloneFeature(feature);\n });\n return cloned;\n}\nfunction cloneGeometry(geometry) {\n const geom = { type: geometry.type };\n if (geometry.bbox) {\n geom.bbox = geometry.bbox;\n }\n if (geometry.type === \"GeometryCollection\") {\n geom.geometries = geometry.geometries.map((g) => {\n return cloneGeometry(g);\n });\n return geom;\n }\n geom.coordinates = deepSlice(geometry.coordinates);\n return geom;\n}\nfunction deepSlice(coords) {\n const cloned = coords;\n if (typeof cloned[0] !== \"object\") {\n return cloned.slice();\n }\n return cloned.map((coord) => {\n return deepSlice(coord);\n });\n}\nvar index_default = clone;\nexport {\n clone,\n cloneProperties,\n index_default as default\n};\n//# sourceMappingURL=index.js.map","// index.ts\nimport { convertLength, earthRadius } from \"@turf/helpers\";\nimport { getCoord } from \"@turf/invariant\";\nfunction rhumbDistance(from, to, options = {}) {\n const origin = getCoord(from);\n const destination = getCoord(to);\n destination[0] += destination[0] - origin[0] > 180 ? -360 : origin[0] - destination[0] > 180 ? 360 : 0;\n const distanceInMeters = calculateRhumbDistance(origin, destination);\n const distance = convertLength(distanceInMeters, \"meters\", options.units);\n return distance;\n}\nfunction calculateRhumbDistance(origin, destination, radius) {\n radius = radius === void 0 ? earthRadius : Number(radius);\n const R = radius;\n const phi1 = origin[1] * Math.PI / 180;\n const phi2 = destination[1] * Math.PI / 180;\n const DeltaPhi = phi2 - phi1;\n let DeltaLambda = Math.abs(destination[0] - origin[0]) * Math.PI / 180;\n if (DeltaLambda > Math.PI) {\n DeltaLambda -= 2 * Math.PI;\n }\n const DeltaPsi = Math.log(\n Math.tan(phi2 / 2 + Math.PI / 4) / Math.tan(phi1 / 2 + Math.PI / 4)\n );\n const q = Math.abs(DeltaPsi) > 1e-11 ? DeltaPhi / DeltaPsi : Math.cos(phi1);\n const delta = Math.sqrt(\n DeltaPhi * DeltaPhi + q * q * DeltaLambda * DeltaLambda\n );\n const dist = delta * R;\n return dist;\n}\nvar index_default = rhumbDistance;\nexport {\n index_default as default,\n rhumbDistance\n};\n//# sourceMappingURL=index.js.map","// index.ts\nimport {\n convertLength,\n degreesToRadians,\n earthRadius,\n point\n} from \"@turf/helpers\";\nimport { getCoord } from \"@turf/invariant\";\nfunction rhumbDestination(origin, distance, bearing, options = {}) {\n const wasNegativeDistance = distance < 0;\n let distanceInMeters = convertLength(\n Math.abs(distance),\n options.units,\n \"meters\"\n );\n if (wasNegativeDistance) distanceInMeters = -Math.abs(distanceInMeters);\n const coords = getCoord(origin);\n const destination = calculateRhumbDestination(\n coords,\n distanceInMeters,\n bearing\n );\n destination[0] += destination[0] - coords[0] > 180 ? -360 : coords[0] - destination[0] > 180 ? 360 : 0;\n return point(destination, options.properties);\n}\nfunction calculateRhumbDestination(origin, distance, bearing, radius) {\n radius = radius === void 0 ? earthRadius : Number(radius);\n const delta = distance / radius;\n const lambda1 = origin[0] * Math.PI / 180;\n const phi1 = degreesToRadians(origin[1]);\n const theta = degreesToRadians(bearing);\n const DeltaPhi = delta * Math.cos(theta);\n let phi2 = phi1 + DeltaPhi;\n if (Math.abs(phi2) > Math.PI / 2) {\n phi2 = phi2 > 0 ? Math.PI - phi2 : -Math.PI - phi2;\n }\n const DeltaPsi = Math.log(\n Math.tan(phi2 / 2 + Math.PI / 4) / Math.tan(phi1 / 2 + Math.PI / 4)\n );\n const q = Math.abs(DeltaPsi) > 1e-11 ? DeltaPhi / DeltaPsi : Math.cos(phi1);\n const DeltaLambda = delta * Math.sin(theta) / q;\n const lambda2 = lambda1 + DeltaLambda;\n return [\n (lambda2 * 180 / Math.PI + 540) % 360 - 180,\n phi2 * 180 / Math.PI\n ];\n}\nvar index_default = rhumbDestination;\nexport {\n index_default as default,\n rhumbDestination\n};\n//# sourceMappingURL=index.js.map","// index.ts\nimport { centroid } from \"@turf/centroid\";\nimport { rhumbBearing } from \"@turf/rhumb-bearing\";\nimport { rhumbDistance } from \"@turf/rhumb-distance\";\nimport { rhumbDestination } from \"@turf/rhumb-destination\";\nimport { clone } from \"@turf/clone\";\nimport { coordEach } from \"@turf/meta\";\nimport { getCoords } from \"@turf/invariant\";\nimport { isObject } from \"@turf/helpers\";\nfunction transformRotate(geojson, angle, options) {\n options = options || {};\n if (!isObject(options)) throw new Error(\"options is invalid\");\n const pivot = options.pivot;\n const mutate = options.mutate;\n if (!geojson) throw new Error(\"geojson is required\");\n if (angle === void 0 || angle === null || isNaN(angle))\n throw new Error(\"angle is required\");\n if (angle === 0) return geojson;\n const pivotCoord = pivot != null ? pivot : centroid(geojson);\n if (mutate === false || mutate === void 0) geojson = clone(geojson);\n coordEach(geojson, function(pointCoords) {\n const initialAngle = rhumbBearing(pivotCoord, pointCoords);\n const finalAngle = initialAngle + angle;\n const distance = rhumbDistance(pivotCoord, pointCoords);\n const newCoords = getCoords(\n rhumbDestination(pivotCoord, distance, finalAngle)\n );\n pointCoords[0] = newCoords[0];\n pointCoords[1] = newCoords[1];\n });\n return geojson;\n}\nvar index_default = transformRotate;\nexport {\n index_default as default,\n transformRotate\n};\n//# sourceMappingURL=index.js.map","// index.ts\nimport { bbox as turfBBox } from \"@turf/bbox\";\nimport { getCoords, getGeom } from \"@turf/invariant\";\nimport { polygon, multiPolygon, lineString } from \"@turf/helpers\";\nimport { clone } from \"@turf/clone\";\nfunction lineToPolygon(lines, options = {}) {\n var _a, _b, _c;\n var properties = options.properties;\n var autoComplete = (_a = options.autoComplete) != null ? _a : true;\n var orderCoords = (_b = options.orderCoords) != null ? _b : true;\n var mutate = (_c = options.mutate) != null ? _c : false;\n if (!mutate) {\n lines = clone(lines);\n }\n switch (lines.type) {\n case \"FeatureCollection\":\n var coords = [];\n lines.features.forEach(function(line) {\n coords.push(\n getCoords(lineStringToPolygon(line, {}, autoComplete, orderCoords))\n );\n });\n return multiPolygon(coords, properties);\n default:\n return lineStringToPolygon(lines, properties, autoComplete, orderCoords);\n }\n}\nfunction lineStringToPolygon(line, properties, autoComplete, orderCoords) {\n properties = properties ? properties : line.type === \"Feature\" ? line.properties : {};\n var geom = getGeom(line);\n var coords = geom.coordinates;\n var type = geom.type;\n if (!coords.length) throw new Error(\"line must contain coordinates\");\n switch (type) {\n case \"LineString\":\n if (autoComplete) coords = autoCompleteCoords(coords);\n return polygon([coords], properties);\n case \"MultiLineString\":\n var multiCoords = [];\n var largestArea = 0;\n coords.forEach(function(coord) {\n if (autoComplete) coord = autoCompleteCoords(coord);\n if (orderCoords) {\n var area = calculateArea(turfBBox(lineString(coord)));\n if (area > largestArea) {\n multiCoords.unshift(coord);\n largestArea = area;\n } else multiCoords.push(coord);\n } else {\n multiCoords.push(coord);\n }\n });\n return polygon(multiCoords, properties);\n default:\n throw new Error(\"geometry type \" + type + \" is not supported\");\n }\n}\nfunction autoCompleteCoords(coords) {\n var first = coords[0];\n var x1 = first[0];\n var y1 = first[1];\n var last = coords[coords.length - 1];\n var x2 = last[0];\n var y2 = last[1];\n if (x1 !== x2 || y1 !== y2) {\n coords.push(first);\n }\n return coords;\n}\nfunction calculateArea(bbox) {\n var west = bbox[0];\n var south = bbox[1];\n var east = bbox[2];\n var north = bbox[3];\n return Math.abs(west - east) * Math.abs(south - north);\n}\nvar index_default = lineToPolygon;\nexport {\n index_default as default,\n lineToPolygon\n};\n//# sourceMappingURL=index.js.map","import { envelope, featureCollection, point } from '@turf/turf'\nimport type { BBox } from 'geojson'\nimport type { Map } from 'mapbox-gl'\n\n/**\n * 将物理距离(米)转换为当前地图层级下的屏幕像素(px)\n * @param map Mapbox 地图实例\n * @param distance 距离(单位:米)\n * @param latitude 计算基准纬度(默认取当前地图中心)\n */\nexport function distanceToPx(map: Map, distance: number, latitude?: number): number {\n const EARTH_CIRCUMFERENCE = 40075017\n\n const lat = latitude ?? map.getCenter().lat\n\n const zoom = map.getZoom()\n\n const latRad = lat * (Math.PI / 180)\n const metersPerPixel = (EARTH_CIRCUMFERENCE * Math.cos(latRad)) / Math.pow(2, zoom + 9)\n\n return distance / metersPerPixel\n}\n\nexport function getPointScope(map: Map, x: number, y: number, width: number): BBox {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n return envelope(\n featureCollection([\n point(map.unproject([x - width / 2, y - width / 2]).toArray()),\n point(map.unproject([x + width / 2, y + width / 2]).toArray()),\n ]),\n ).bbox!\n}\n\nexport async function convertSvgToImageObjects(\n svgString: string,\n width?: number,\n height?: number,\n): Promise<{\n image: HTMLImageElement\n bitmap: ImageBitmap\n imageData: ImageData\n}> {\n // 1. 创建一个临时的Image对象并加载SVG\n const loadSvgAsImage = (svgStr: string): Promise<HTMLImageElement> => {\n return new Promise((resolve, reject) => {\n // 将SVG字符串转换为Blob URL\n const blob = new Blob([svgStr], { type: 'image/svg+xml;charset=utf-8' })\n const url = URL.createObjectURL(blob)\n\n const img = new Image()\n img.crossOrigin = 'anonymous' // 重要:避免转换后canvas被\"污染\"\n\n img.onload = (): void => {\n URL.revokeObjectURL(url) // 清理URL,释放内存\n resolve(img)\n }\n\n img.onerror = (event): void => {\n URL.revokeObjectURL(url)\n reject(new Error(`SVG图片加载失败:${JSON.stringify(event)}`))\n }\n\n img.src = url\n })\n }\n\n const svgImage = await loadSvgAsImage(svgString)\n\n // 2. 确定输出尺寸\n const outputWidth = (width ?? svgImage.naturalWidth) || svgImage.width || 300\n const outputHeight = (height ?? svgImage.naturalHeight) || svgImage.height || 150\n\n // 3. 绘制到Canvas\n const canvas = document.createElement('canvas')\n canvas.width = outputWidth\n canvas.height = outputHeight\n\n const ctx = canvas.getContext('2d')\n if (!ctx) {\n throw new Error('无法获取Canvas 2D上下文')\n }\n\n // 清空并绘制SVG\n ctx.clearRect(0, 0, outputWidth, outputHeight)\n ctx.drawImage(svgImage, 0, 0, outputWidth, outputHeight)\n\n // 4. 并行转换获取所有目标格式\n const [bitmap, imageData] = await Promise.all([\n // 转换为ImageBitmap\n createImageBitmap(canvas),\n // 转换为ImageData\n Promise.resolve(ctx.getImageData(0, 0, outputWidth, outputHeight)),\n ])\n\n return {\n image: svgImage, // HTMLImageElement\n bitmap: bitmap, // ImageBitmap\n imageData: imageData, // ImageData\n }\n}\n","import type { Map } from 'mapbox-gl'\n\nimport { cacheKey } from '@/config'\nimport Cache from '@/core/Cache'\nimport type { Icon, Image, result, SvgIcon } from '@/types/IconManager'\nimport { RESULT_CODE } from '@/types/IconManager'\nimport { convertSvgToImageObjects } from '@/utils/util.ts'\n\nclass IconManager {\n static SUCCESS = RESULT_CODE.SUCCESS\n static FAIL = RESULT_CODE.FAIL\n\n _map: Map\n _cache: Cache = new Cache({ uniqueKey: `${cacheKey}-icon`, type: 'localstorage' })\n\n constructor(map: Map) {\n this._map = map\n }\n\n async load(icons: Icon[]): Promise<{ success: result[]; error: result[] }> {\n const results = await Promise.allSettled(icons.map((icon) => this.add(icon)))\n\n const success: result[] = []\n const error: result[] = []\n\n results.forEach((item) => {\n if (item.status === 'fulfilled') {\n success.push(item.value)\n } else {\n // TypeScript 中 rejected 的 reason 类型通常是 any/unknown\n // 根据你的 add 方法逻辑,这里 reject 的内容应该是 result 类型,所以做个断言\n error.push(item.reason as result)\n }\n })\n\n return { success, error }\n }\n\n async addSvg(icon: SvgIcon): Promise<void> {\n if (!this.has(icon.name)) {\n const data = await convertSvgToImageObjects(icon.svg)\n this._cache.set({\n name: icon.name,\n content: { width: data.image.width, height: data.image.height, image: data.image },\n })\n\n this._map.addImage(icon.name, data.image)\n } else {\n console.log('有了')\n }\n }\n\n add(icon: Icon): Promise<result> {\n return new Promise((resolve, reject) => {\n if (!this.has(icon.name)) {\n // const url = new URL(icon.url, import.meta.url).href\n // console.log(url, 'url')\n this._map.loadImage(icon.url, (err, image) => {\n if (err) {\n // eslint-disable-next-line @typescript-eslint/prefer-promise-reject-errors\n reject(this.error(icon, err))\n return\n }\n\n if (image) {\n this._cache.set({\n name: icon.name,\n content: { width: image.width, height: image.height, image },\n })\n this._map.addImage(icon.name, image, icon.options)\n resolve(this.success(icon))\n } else {\n // eslint-disable-next-line @typescript-eslint/prefer-promise-reject-errors\n reject(this.error(icon, 'The image has not found!'))\n return\n }\n })\n } else {\n // eslint-disable-next-line @typescript-eslint/prefer-promise-reject-errors\n reject(this.error(icon, 'The image has been loaded!'))\n }\n })\n }\n\n has(name: Icon['name']): boolean {\n return this._map.hasImage(name)\n }\n\n getImage(name: string): Image | undefined {\n return this._cache.get(name) as Image | undefined\n }\n\n update(icon: Icon): Promise<result> {\n return new Promise((resolve, reject) => {\n if (!this._map.hasImage(icon.name)) {\n // eslint-disable-next-line @typescript-eslint/prefer-promise-reject-errors\n reject(this.error(icon, 'The image has not been loaded!'))\n return\n }\n\n this._map.loadImage(icon.url, (err, image) => {\n if (err) {\n // eslint-disable-next-line @typescript-eslint/prefer-promise-reject-errors\n reject(this.error(icon, err))\n return\n }\n\n if (image) {\n this._cache.set({\n name: icon.name,\n content: { width: image.width, height: image.height },\n })\n this._map.updateImage(icon.name, image)\n resolve(this.success(icon))\n } else {\n // eslint-disable-next-line @typescript-eslint/prefer-promise-reject-errors\n reject(this.error(icon, 'The image has not found!'))\n return\n }\n })\n })\n }\n\n delete(name: string): void {\n if (this._map.hasImage(name)) {\n this._map.removeImage(name)\n this._cache.remove(name)\n }\n }\n\n success(icon: Icon): result {\n return {\n code: IconManager.SUCCESS,\n data: icon,\n msg: `The ${icon.name} was successfully added`,\n }\n }\n\n error(icon: Icon, err: string | Error): result {\n return {\n code: IconManager.FAIL,\n data: icon,\n msg: err,\n }\n }\n}\n\nexport default IconManager\n","'use strict';\n\nvar has = Object.prototype.hasOwnProperty\n , prefix = '~';\n\n/**\n * Constructor to create a storage for our `EE` objects.\n * An `Events` instance is a plain object whose properties are event names.\n *\n * @constructor\n * @private\n */\nfunction Events() {}\n\n//\n// We try to not inherit from `Object.prototype`. In some engines creating an\n// instance in this way is faster than calling `Object.create(null)` directly.\n// If `Object.create(null)` is not supported we prefix the event names with a\n// character to make sure that the built-in object properties are not\n// overridden or used as an attack vector.\n//\nif (Object.create) {\n Events.prototype = Object.create(null);\n\n //\n // This hack is needed because the `__proto__` property is still inherited in\n // some old browsers like Android 4, iPhone 5.1, Opera 11 and Safari 5.\n //\n if (!new Events().__proto__) prefix = false;\n}\n\n/**\n * Representation of a single event listener.\n *\n * @param {Function} fn The listener function.\n * @param {*} context The context to invoke the listener with.\n * @param {Boolean} [once=false] Specify if the listener is a one-time listener.\n * @constructor\n * @private\n */\nfunction EE(fn, context, once) {\n this.fn = fn;\n this.context = context;\n this.once = once || false;\n}\n\n/**\n * Add a listener for a given event.\n *\n * @param {EventEmitter} emitter Reference to the `EventEmitter` instance.\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} context The context to invoke the listener with.\n * @param {Boolean} once Specify if the listener is a one-time listener.\n * @returns {EventEmitter}\n * @private\n */\nfunction addListener(emitter, event, fn, context, once) {\n if (typeof fn !== 'function') {\n throw new TypeError('The listener must be a function');\n }\n\n var listener = new EE(fn, context || emitter, once)\n , evt = prefix ? prefix + event : event;\n\n if (!emitter._events[evt]) emitter._events[evt] = listener, emitter._eventsCount++;\n else if (!emitter._events[evt].fn) emitter._events[evt].push(listener);\n else emitter._events[evt] = [emitter._events[evt], listener];\n\n return emitter;\n}\n\n/**\n * Clear event by name.\n *\n * @param {EventEmitter} emitter Reference to the `EventEmitter` instance.\n * @param {(String|Symbol)} evt The Event name.\n * @private\n */\nfunction clearEvent(emitter, evt) {\n if (--emitter._eventsCount === 0) emitter._events = new Events();\n else delete emitter._events[evt];\n}\n\n/**\n * Minimal `EventEmitter` interface that is molded against the Node.js\n * `EventEmitter` interface.\n *\n * @constructor\n * @public\n */\nfunction EventEmitter() {\n this._events = new Events();\n this._eventsCount = 0;\n}\n\n/**\n * Return an array listing the events for which the emitter has registered\n * listeners.\n *\n * @returns {Array}\n * @public\n */\nEventEmitter.prototype.eventNames = function eventNames() {\n var names = []\n , events\n , name;\n\n if (this._eventsCount === 0) return names;\n\n for (name in (events = this._events)) {\n if (has.call(events, name)) names.push(prefix ? name.slice(1) : name);\n }\n\n if (Object.getOwnPropertySymbols) {\n return names.concat(Object.getOwnPropertySymbols(events));\n }\n\n return names;\n};\n\n/**\n * Return the listeners registered for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Array} The registered listeners.\n * @public\n */\nEventEmitter.prototype.listeners = function listeners(event) {\n var evt = prefix ? prefix + event : event\n , handlers = this._events[evt];\n\n if (!handlers) return [];\n if (handlers.fn) return [handlers.fn];\n\n for (var i = 0, l = handlers.length, ee = new Array(l); i < l; i++) {\n ee[i] = handlers[i].fn;\n }\n\n return ee;\n};\n\n/**\n * Return the number of listeners listening to a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Number} The number of listeners.\n * @public\n */\nEventEmitter.prototype.listenerCount = function listenerCount(event) {\n var evt = prefix ? prefix + event : event\n , listeners = this._events[evt];\n\n if (!listeners) return 0;\n if (listeners.fn) return 1;\n return listeners.length;\n};\n\n/**\n * Calls each of the listeners registered for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Boolean} `true` if the event had listeners, else `false`.\n * @public\n */\nEventEmitter.prototype.emit = function emit(event, a1, a2, a3, a4, a5) {\n var evt = prefix ? prefix + event : event;\n\n if (!this._events[evt]) return false;\n\n var listeners = this._events[evt]\n , len = arguments.length\n , args\n , i;\n\n if (listeners.fn) {\n if (listeners.once) this.removeListener(event, listeners.fn, undefined, true);\n\n switch (len) {\n case 1: return listeners.fn.call(listeners.context), true;\n case 2: return listeners.fn.call(listeners.context, a1), true;\n case 3: return listeners.fn.call(listeners.context, a1, a2), true;\n case 4: return listeners.fn.call(listeners.context, a1, a2, a3), true;\n case 5: return listeners.fn.call(listeners.context, a1, a2, a3, a4), true;\n case 6: return listeners.fn.call(listeners.context, a1, a2, a3, a4, a5), true;\n }\n\n for (i = 1, args = new Array(len -1); i < len; i++) {\n args[i - 1] = arguments[i];\n }\n\n listeners.fn.apply(listeners.context, args);\n } else {\n var length = listeners.length\n , j;\n\n for (i = 0; i < length; i++) {\n if (listeners[i].once) this.removeListener(event, listeners[i].fn, undefined, true);\n\n switch (len) {\n case 1: listeners[i].fn.call(listeners[i].context); break;\n case 2: listeners[i].fn.call(listeners[i].context, a1); break;\n case 3: listeners[i].fn.call(listeners[i].context, a1, a2); break;\n case 4: listeners[i].fn.call(listeners[i].context, a1, a2, a3); break;\n default:\n if (!args) for (j = 1, args = new Array(len -1); j < len; j++) {\n args[j - 1] = arguments[j];\n }\n\n listeners[i].fn.apply(listeners[i].context, args);\n }\n }\n }\n\n return true;\n};\n\n/**\n * Add a listener for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} [context=this] The context to invoke the listener with.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.on = function on(event, fn, context) {\n return addListener(this, event, fn, context, false);\n};\n\n/**\n * Add a one-time listener for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} [context=this] The context to invoke the listener with.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.once = function once(event, fn, context) {\n return addListener(this, event, fn, context, true);\n};\n\n/**\n * Remove the listeners of a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn Only remove the listeners that match this function.\n * @param {*} context Only remove the listeners that have this context.\n * @param {Boolean} once Only remove one-time listeners.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.removeListener = function removeListener(event, fn, context, once) {\n var evt = prefix ? prefix + event : event;\n\n if (!this._events[evt]) return this;\n if (!fn) {\n clearEvent(this, evt);\n return this;\n }\n\n var listeners = this._events[evt];\n\n if (listeners.fn) {\n if (\n listeners.fn === fn &&\n (!once || listeners.once) &&\n (!context || listeners.context === context)\n ) {\n clearEvent(this, evt);\n }\n } else {\n for (var i = 0, events = [], length = listeners.length; i < length; i++) {\n if (\n listeners[i].fn !== fn ||\n (once && !listeners[i].once) ||\n (context && listeners[i].context !== context)\n ) {\n events.push(listeners[i]);\n }\n }\n\n //\n // Reset the array, or remove it completely if we have no more listeners.\n //\n if (events.length) this._events[evt] = events.length === 1 ? events[0] : events;\n else clearEvent(this, evt);\n }\n\n return this;\n};\n\n/**\n * Remove all listeners, or those of the specified event.\n *\n * @param {(String|Symbol)} [event] The event name.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.removeAllListeners = function removeAllListeners(event) {\n var evt;\n\n if (event) {\n evt = prefix ? prefix + event : event;\n if (this._events[evt]) clearEvent(this, evt);\n } else {\n this._events = new Events();\n this._eventsCount = 0;\n }\n\n return this;\n};\n\n//\n// Alias methods names because people roll like that.\n//\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\nEventEmitter.prototype.addListener = EventEmitter.prototype.on;\n\n//\n// Expose the prefix.\n//\nEventEmitter.prefixed = prefix;\n\n//\n// Allow `EventEmitter` to be imported as module namespace.\n//\nEventEmitter.EventEmitter = EventEmitter;\n\n//\n// Expose the module.\n//\nif ('undefined' !== typeof module) {\n module.exports = EventEmitter;\n}\n","/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\nexport default freeGlobal;\n","import freeGlobal from './_freeGlobal.js';\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\nexport default root;\n","import root from './_root.js';\n\n/** Built-in value references. */\nvar Symbol = root.Symbol;\n\nexport default Symbol;\n","import Symbol from './_Symbol.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n\n try {\n value[symToStringTag] = undefined;\n var unmasked = true;\n } catch (e) {}\n\n var result = nativeObjectToString.call(value);\n if (unmasked) {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n}\n\nexport default getRawTag;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n return nativeObjectToString.call(value);\n}\n\nexport default objectToString;\n","import Symbol from './_Symbol.js';\nimport getRawTag from './_getRawTag.js';\nimport objectToString from './_objectToString.js';\n\n/** `Object#toString` result references. */\nvar nullTag = '[object Null]',\n undefinedTag = '[object Undefined]';\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return (symToStringTag && symToStringTag in Object(value))\n ? getRawTag(value)\n : objectToString(value);\n}\n\nexport default baseGetTag;\n","/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return value != null && typeof value == 'object';\n}\n\nexport default isObjectLike;\n","import baseGetTag from './_baseGetTag.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar symbolTag = '[object Symbol]';\n\n/**\n * Checks if `value` is classified as a `Symbol` primitive or object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\nfunction isSymbol(value) {\n return typeof value == 'symbol' ||\n (isObjectLike(value) && baseGetTag(value) == symbolTag);\n}\n\nexport default isSymbol;\n","/**\n * A specialized version of `_.map` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\nfunction arrayMap(array, iteratee) {\n var index = -1,\n length = array == null ? 0 : array.length,\n result = Array(length);\n\n while (++index < length) {\n result[index] = iteratee(array[index], index, array);\n }\n return result;\n}\n\nexport default arrayMap;\n","/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\nexport default isArray;\n","import Symbol from './_Symbol.js';\nimport arrayMap from './_arrayMap.js';\nimport isArray from './isArray.js';\nimport isSymbol from './isSymbol.js';\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolToString = symbolProto ? symbolProto.toString : undefined;\n\n/**\n * The base implementation of `_.toString` which doesn't convert nullish\n * values to empty strings.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {string} Returns the string.\n */\nfunction baseToString(value) {\n // Exit early for strings to avoid a performance hit in some environments.\n if (typeof value == 'string') {\n return value;\n }\n if (isArray(value)) {\n // Recursively convert values (susceptible to call stack limits).\n return arrayMap(value, baseToString) + '';\n }\n if (isSymbol(value)) {\n return symbolToString ? symbolToString.call(value) : '';\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nexport default baseToString;\n","/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n}\n\nexport default isObject;\n","import baseGetTag from './_baseGetTag.js';\nimport isObject from './isObject.js';\n\n/** `Object#toString` result references. */\nvar asyncTag = '[object AsyncFunction]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n proxyTag = '[object Proxy]';\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n if (!isObject(value)) {\n return false;\n }\n // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 9 which returns 'object' for typed arrays and other constructors.\n var tag = baseGetTag(value);\n return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n}\n\nexport default isFunction;\n","import root from './_root.js';\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\nexport default coreJsData;\n","import coreJsData from './_coreJsData.js';\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = (function() {\n var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n return uid ? ('Symbol(src)_1.' + uid) : '';\n}());\n\n/**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\nfunction isMasked(func) {\n return !!maskSrcKey && (maskSrcKey in func);\n}\n\nexport default isMasked;\n","/** Used for built-in method references. */\nvar funcProto = Function.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to convert.\n * @returns {string} Returns the source code.\n */\nfunction toSource(func) {\n if (func != null) {\n try {\n return funcToString.call(func);\n } catch (e) {}\n try {\n return (func + '');\n } catch (e) {}\n }\n return '';\n}\n\nexport default toSource;\n","import isFunction from './isFunction.js';\nimport isMasked from './_isMasked.js';\nimport isObject from './isObject.js';\nimport toSource from './_toSource.js';\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n * else `false`.\n */\nfunction baseIsNative(value) {\n if (!isObject(value) || isMasked(value)) {\n return false;\n }\n var pattern = isFunction(value) ? reIsNative : reIsHostCtor;\n return pattern.test(toSource(value));\n}\n\nexport default baseIsNative;\n","/**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction getValue(object, key) {\n return object == null ? undefined : object[key];\n}\n\nexport default getValue;\n","import baseIsNative from './_baseIsNative.js';\nimport getValue from './_getValue.js';\n\n/**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\nfunction getNative(object, key) {\n var value = getValue(object, key);\n return baseIsNative(value) ? value : undefined;\n}\n\nexport default getNative;\n","import getNative from './_getNative.js';\n\nvar defineProperty = (function() {\n try {\n var func = getNative(Object, 'defineProperty');\n func({}, '', {});\n return func;\n } catch (e) {}\n}());\n\nexport default defineProperty;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n var type = typeof value;\n length = length == null ? MAX_SAFE_INTEGER : length;\n\n return !!length &&\n (type == 'number' ||\n (type != 'symbol' && reIsUint.test(value))) &&\n (value > -1 && value % 1 == 0 && value < length);\n}\n\nexport default isIndex;\n","import defineProperty from './_defineProperty.js';\n\n/**\n * The base implementation of `assignValue` and `assignMergeValue` without\n * value checks.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction baseAssignValue(object, key, value) {\n if (key == '__proto__' && defineProperty) {\n defineProperty(object, key, {\n 'configurable': true,\n 'enumerable': true,\n 'value': value,\n 'writable': true\n });\n } else {\n object[key] = value;\n }\n}\n\nexport default baseAssignValue;\n","/**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\nfunction eq(value, other) {\n return value === other || (value !== value && other !== other);\n}\n\nexport default eq;\n","import baseAssignValue from './_baseAssignValue.js';\nimport eq from './eq.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Assigns `value` to `key` of `object` if the existing value is not equivalent\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction assignValue(object, key, value) {\n var objValue = object[key];\n if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) ||\n (value === undefined && !(key in object))) {\n baseAssignValue(object, key, value);\n }\n}\n\nexport default assignValue;\n","import isArray from './isArray.js';\nimport isSymbol from './isSymbol.js';\n\n/** Used to match property names within property paths. */\nvar reIsDeepProp = /\\.|\\[(?:[^[\\]]*|([\"'])(?:(?!\\1)[^\\\\]|\\\\.)*?\\1)\\]/,\n reIsPlainProp = /^\\w*$/;\n\n/**\n * Checks if `value` is a property name and not a property path.\n *\n * @private\n * @param {*} value The value to check.\n * @param {Object} [object] The object to query keys on.\n * @returns {boolean} Returns `true` if `value` is a property name, else `false`.\n */\nfunction isKey(value, object) {\n if (isArray(value)) {\n return false;\n }\n var type = typeof value;\n if (type == 'number' || type == 'symbol' || type == 'boolean' ||\n value == null || isSymbol(value)) {\n return true;\n }\n return reIsPlainProp.test(value) || !reIsDeepProp.test(value) ||\n (object != null && value in Object(object));\n}\n\nexport default isKey;\n","import getNative from './_getNative.js';\n\n/* Built-in method references that are verified to be native. */\nvar nativeCreate = getNative(Object, 'create');\n\nexport default nativeCreate;\n","import nativeCreate from './_nativeCreate.js';\n\n/**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\nfunction hashClear() {\n this.__data__ = nativeCreate ? nativeCreate(null) : {};\n this.size = 0;\n}\n\nexport default hashClear;\n","/**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction hashDelete(key) {\n var result = this.has(key) && delete this.__data__[key];\n this.size -= result ? 1 : 0;\n return result;\n}\n\nexport default hashDelete;\n","import nativeCreate from './_nativeCreate.js';\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction hashGet(key) {\n var data = this.__data__;\n if (nativeCreate) {\n var result = data[key];\n return result === HASH_UNDEFINED ? undefined : result;\n }\n return hasOwnProperty.call(data, key) ? data[key] : undefined;\n}\n\nexport default hashGet;\n","import nativeCreate from './_nativeCreate.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Hash\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction hashHas(key) {\n var data = this.__data__;\n return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\n}\n\nexport default hashHas;\n","import nativeCreate from './_nativeCreate.js';\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Hash\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the hash instance.\n */\nfunction hashSet(key, value) {\n var data = this.__data__;\n this.size += this.has(key) ? 0 : 1;\n data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n return this;\n}\n\nexport default hashSet;\n","import hashClear from './_hashClear.js';\nimport hashDelete from './_hashDelete.js';\nimport hashGet from './_hashGet.js';\nimport hashHas from './_hashHas.js';\nimport hashSet from './_hashSet.js';\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Hash(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\nexport default Hash;\n","/**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\nfunction listCacheClear() {\n this.__data__ = [];\n this.size = 0;\n}\n\nexport default listCacheClear;\n","import eq from './eq.js';\n\n/**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction assocIndexOf(array, key) {\n var length = array.length;\n while (length--) {\n if (eq(array[length][0], key)) {\n return length;\n }\n }\n return -1;\n}\n\nexport default assocIndexOf;\n","import assocIndexOf from './_assocIndexOf.js';\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype;\n\n/** Built-in value references. */\nvar splice = arrayProto.splice;\n\n/**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction listCacheDelete(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n return false;\n }\n var lastIndex = data.length - 1;\n if (index == lastIndex) {\n data.pop();\n } else {\n splice.call(data, index, 1);\n }\n --this.size;\n return true;\n}\n\nexport default listCacheDelete;\n","import assocIndexOf from './_assocIndexOf.js';\n\n/**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction listCacheGet(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n return index < 0 ? undefined : data[index][1];\n}\n\nexport default listCacheGet;\n","import assocIndexOf from './_assocIndexOf.js';\n\n/**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction listCacheHas(key) {\n return assocIndexOf(this.__data__, key) > -1;\n}\n\nexport default listCacheHas;\n","import assocIndexOf from './_assocIndexOf.js';\n\n/**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\nfunction listCacheSet(key, value) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n ++this.size;\n data.push([key, value]);\n } else {\n data[index][1] = value;\n }\n return this;\n}\n\nexport default listCacheSet;\n","import listCacheClear from './_listCacheClear.js';\nimport listCacheDelete from './_listCacheDelete.js';\nimport listCacheGet from './_listCacheGet.js';\nimport listCacheHas from './_listCacheHas.js';\nimport listCacheSet from './_listCacheSet.js';\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction ListCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\n\nexport default ListCache;\n","import getNative from './_getNative.js';\nimport root from './_root.js';\n\n/* Built-in method references that are verified to be native. */\nvar Map = getNative(root, 'Map');\n\nexport default Map;\n","import Hash from './_Hash.js';\nimport ListCache from './_ListCache.js';\nimport Map from './_Map.js';\n\n/**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\nfunction mapCacheClear() {\n this.size = 0;\n this.__data__ = {\n 'hash': new Hash,\n 'map': new (Map || ListCache),\n 'string': new Hash\n };\n}\n\nexport default mapCacheClear;\n","/**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\nfunction isKeyable(value) {\n var type = typeof value;\n return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\n ? (value !== '__proto__')\n : (value === null);\n}\n\nexport default isKeyable;\n","import isKeyable from './_isKeyable.js';\n\n/**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\nfunction getMapData(map, key) {\n var data = map.__data__;\n return isKeyable(key)\n ? data[typeof key == 'string' ? 'string' : 'hash']\n : data.map;\n}\n\nexport default getMapData;\n","import getMapData from './_getMapData.js';\n\n/**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction mapCacheDelete(key) {\n var result = getMapData(this, key)['delete'](key);\n this.size -= result ? 1 : 0;\n return result;\n}\n\nexport default mapCacheDelete;\n","import getMapData from './_getMapData.js';\n\n/**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction mapCacheGet(key) {\n return getMapData(this, key).get(key);\n}\n\nexport default mapCacheGet;\n","import getMapData from './_getMapData.js';\n\n/**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction mapCacheHas(key) {\n return getMapData(this, key).has(key);\n}\n\nexport default mapCacheHas;\n","import getMapData from './_getMapData.js';\n\n/**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\nfunction mapCacheSet(key, value) {\n var data = getMapData(this, key),\n size = data.size;\n\n data.set(key, value);\n this.size += data.size == size ? 0 : 1;\n return this;\n}\n\nexport default mapCacheSet;\n","import mapCacheClear from './_mapCacheClear.js';\nimport mapCacheDelete from './_mapCacheDelete.js';\nimport mapCacheGet from './_mapCacheGet.js';\nimport mapCacheHas from './_mapCacheHas.js';\nimport mapCacheSet from './_mapCacheSet.js';\n\n/**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction MapCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `MapCache`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\n\nexport default MapCache;\n","import MapCache from './_MapCache.js';\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/**\n * Creates a function that memoizes the result of `func`. If `resolver` is\n * provided, it determines the cache key for storing the result based on the\n * arguments provided to the memoized function. By default, the first argument\n * provided to the memoized function is used as the map cache key. The `func`\n * is invoked with the `this` binding of the memoized function.\n *\n * **Note:** The cache is exposed as the `cache` property on the memoized\n * function. Its creation may be customized by replacing the `_.memoize.Cache`\n * constructor with one whose instances implement the\n * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object)\n * method interface of `clear`, `delete`, `get`, `has`, and `set`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to have its output memoized.\n * @param {Function} [resolver] The function to resolve the cache key.\n * @returns {Function} Returns the new memoized function.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n * var other = { 'c': 3, 'd': 4 };\n *\n * var values = _.memoize(_.values);\n * values(object);\n * // => [1, 2]\n *\n * values(other);\n * // => [3, 4]\n *\n * object.a = 2;\n * values(object);\n * // => [1, 2]\n *\n * // Modify the result cache.\n * values.cache.set(object, ['a', 'b']);\n * values(object);\n * // => ['a', 'b']\n *\n * // Replace `_.memoize.Cache`.\n * _.memoize.Cache = WeakMap;\n */\nfunction memoize(func, resolver) {\n if (typeof func != 'function' || (resolver != null && typeof resolver != 'function')) {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n var memoized = function() {\n var args = arguments,\n key = resolver ? resolver.apply(this, args) : args[0],\n cache = memoized.cache;\n\n if (cache.has(key)) {\n return cache.get(key);\n }\n var result = func.apply(this, args);\n memoized.cache = cache.set(key, result) || cache;\n return result;\n };\n memoized.cache = new (memoize.Cache || MapCache);\n return memoized;\n}\n\n// Expose `MapCache`.\nmemoize.Cache = MapCache;\n\nexport default memoize;\n","import memoize from './memoize.js';\n\n/** Used as the maximum memoize cache size. */\nvar MAX_MEMOIZE_SIZE = 500;\n\n/**\n * A specialized version of `_.memoize` which clears the memoized function's\n * cache when it exceeds `MAX_MEMOIZE_SIZE`.\n *\n * @private\n * @param {Function} func The function to have its output memoized.\n * @returns {Function} Returns the new memoized function.\n */\nfunction memoizeCapped(func) {\n var result = memoize(func, function(key) {\n if (cache.size === MAX_MEMOIZE_SIZE) {\n cache.clear();\n }\n return key;\n });\n\n var cache = result.cache;\n return result;\n}\n\nexport default memoizeCapped;\n","import memoizeCapped from './_memoizeCapped.js';\n\n/** Used to match property names within property paths. */\nvar rePropName = /[^.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|$))/g;\n\n/** Used to match backslashes in property paths. */\nvar reEscapeChar = /\\\\(\\\\)?/g;\n\n/**\n * Converts `string` to a property path array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the property path array.\n */\nvar stringToPath = memoizeCapped(function(string) {\n var result = [];\n if (string.charCodeAt(0) === 46 /* . */) {\n result.push('');\n }\n string.replace(rePropName, function(match, number, quote, subString) {\n result.push(quote ? subString.replace(reEscapeChar, '$1') : (number || match));\n });\n return result;\n});\n\nexport default stringToPath;\n","import baseToString from './_baseToString.js';\n\n/**\n * Converts `value` to a string. An empty string is returned for `null`\n * and `undefined` values. The sign of `-0` is preserved.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n * @example\n *\n * _.toString(null);\n * // => ''\n *\n * _.toString(-0);\n * // => '-0'\n *\n * _.toString([1, 2, 3]);\n * // => '1,2,3'\n */\nfunction toString(value) {\n return value == null ? '' : baseToString(value);\n}\n\nexport default toString;\n","import isArray from './isArray.js';\nimport isKey from './_isKey.js';\nimport stringToPath from './_stringToPath.js';\nimport toString from './toString.js';\n\n/**\n * Casts `value` to a path array if it's not one.\n *\n * @private\n * @param {*} value The value to inspect.\n * @param {Object} [object] The object to query keys on.\n * @returns {Array} Returns the cast property path array.\n */\nfunction castPath(value, object) {\n if (isArray(value)) {\n return value;\n }\n return isKey(value, object) ? [value] : stringToPath(toString(value));\n}\n\nexport default castPath;\n","import isSymbol from './isSymbol.js';\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/**\n * Converts `value` to a string key if it's not a string or symbol.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {string|symbol} Returns the key.\n */\nfunction toKey(value) {\n if (typeof value == 'string' || isSymbol(value)) {\n return value;\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nexport default toKey;\n","import assignValue from './_assignValue.js';\nimport castPath from './_castPath.js';\nimport isIndex from './_isIndex.js';\nimport isObject from './isObject.js';\nimport toKey from './_toKey.js';\n\n/**\n * The base implementation of `_.set`.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {*} value The value to set.\n * @param {Function} [customizer] The function to customize path creation.\n * @returns {Object} Returns `object`.\n */\nfunction baseSet(object, path, value, customizer) {\n if (!isObject(object)) {\n return object;\n }\n path = castPath(path, object);\n\n var index = -1,\n length = path.length,\n lastIndex = length - 1,\n nested = object;\n\n while (nested != null && ++index < length) {\n var key = toKey(path[index]),\n newValue = value;\n\n if (key === '__proto__' || key === 'constructor' || key === 'prototype') {\n return object;\n }\n\n if (index != lastIndex) {\n var objValue = nested[key];\n newValue = customizer ? customizer(objValue, key, nested) : undefined;\n if (newValue === undefined) {\n newValue = isObject(objValue)\n ? objValue\n : (isIndex(path[index + 1]) ? [] : {});\n }\n }\n assignValue(nested, key, newValue);\n nested = nested[key];\n }\n return object;\n}\n\nexport default baseSet;\n","import baseSet from './_baseSet.js';\n\n/**\n * Sets the value at `path` of `object`. If a portion of `path` doesn't exist,\n * it's created. Arrays are created for missing index properties while objects\n * are created for all other missing properties. Use `_.setWith` to customize\n * `path` creation.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 3.7.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\n *\n * _.set(object, 'a[0].b.c', 4);\n * console.log(object.a[0].b.c);\n * // => 4\n *\n * _.set(object, ['x', '0', 'y', 'z'], 5);\n * console.log(object.x[0].y.z);\n * // => 5\n */\nfunction set(object, path, value) {\n return object == null ? object : baseSet(object, path, value);\n}\n\nexport default set;\n","import validate from './validate.js';\nconst byteToHex = [];\nfor (let i = 0; i < 256; ++i) {\n byteToHex.push((i + 0x100).toString(16).slice(1));\n}\nexport function unsafeStringify(arr, offset = 0) {\n return (byteToHex[arr[offset + 0]] +\n byteToHex[arr[offset + 1]] +\n byteToHex[arr[offset + 2]] +\n byteToHex[arr[offset + 3]] +\n '-' +\n byteToHex[arr[offset + 4]] +\n byteToHex[arr[offset + 5]] +\n '-' +\n byteToHex[arr[offset + 6]] +\n byteToHex[arr[offset + 7]] +\n '-' +\n byteToHex[arr[offset + 8]] +\n byteToHex[arr[offset + 9]] +\n '-' +\n byteToHex[arr[offset + 10]] +\n byteToHex[arr[offset + 11]] +\n byteToHex[arr[offset + 12]] +\n byteToHex[arr[offset + 13]] +\n byteToHex[arr[offset + 14]] +\n byteToHex[arr[offset + 15]]).toLowerCase();\n}\nfunction stringify(arr, offset = 0) {\n const uuid = unsafeStringify(arr, offset);\n if (!validate(uuid)) {\n throw TypeError('Stringified UUID is invalid');\n }\n return uuid;\n}\nexport default stringify;\n","let getRandomValues;\nconst rnds8 = new Uint8Array(16);\nexport default function rng() {\n if (!getRandomValues) {\n if (typeof crypto === 'undefined' || !crypto.getRandomValues) {\n throw new Error('crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported');\n }\n getRandomValues = crypto.getRandomValues.bind(crypto);\n }\n return getRandomValues(rnds8);\n}\n","const randomUUID = typeof crypto !== 'undefined' && crypto.randomUUID && crypto.randomUUID.bind(crypto);\nexport default { randomUUID };\n","import native from './native.js';\nimport rng from './rng.js';\nimport { unsafeStringify } from './stringify.js';\nfunction v4(options, buf, offset) {\n if (native.randomUUID && !buf && !options) {\n return native.randomUUID();\n }\n options = options || {};\n const rnds = options.random ?? options.rng?.() ?? rng();\n if (rnds.length < 16) {\n throw new Error('Random bytes length must be >= 16');\n }\n rnds[6] = (rnds[6] & 0x0f) | 0x40;\n rnds[8] = (rnds[8] & 0x3f) | 0x80;\n if (buf) {\n offset = offset || 0;\n if (offset < 0 || offset + 16 > buf.length) {\n throw new RangeError(`UUID byte range ${offset}:${offset + 15} is out of buffer bounds`);\n }\n for (let i = 0; i < 16; ++i) {\n buf[offset + i] = rnds[i];\n }\n return buf;\n }\n return unsafeStringify(rnds);\n}\nexport default v4;\n","import type * as GeoJSON from 'geojson'\nimport type { LayerSpecification, Map, Source, SourceSpecification } from 'mapbox-gl'\n\nclass ResourceRegister {\n private map: Map\n\n constructor(map: Map) {\n this.map = map\n }\n\n /**\n * 幂等地添加 Source\n * 如果已存在,则忽略;如果不存在,则创建。\n */\n public addSource(id: string, source: SourceSpecification): void {\n if (!this.map.getSource(id)) {\n this.map.addSource(id, source)\n }\n }\n\n /**\n * 幂等地添加 Layer\n */\n public addLayer(layer: LayerSpecification, beforeId?: string): void {\n if (!this.map.getLayer(layer.id)) {\n this.map.addLayer(layer, beforeId)\n }\n }\n\n /**\n * 获取 Source 的强类型辅助方法\n */\n public getSource(id: string): Source | undefined {\n return this.map.getSource<Source>(id)\n }\n\n // /**\n // * 安全更新 Source 数据 (针对 GeoJSON)\n // */\n // public updateGeoJSONData(id: string, feature: GeoJSON.Feature<null | GeoJSON.Geometry>): void {\n // const source = this.getSource(id)\n // if (source?.type === 'geojson') {\n // source.updateData(feature as GeoJSON.GeoJSON)\n // }\n // }\n\n /**\n * 安全更新 Source 数据 (针对 GeoJSON)\n */\n public updateGeoJSONData(id: string, feature: GeoJSON.GeoJSON<null | GeoJSON.Geometry>): void {\n const source = this.getSource(id)\n if (source?.type === 'geojson') {\n source.updateData(feature as GeoJSON.GeoJSON)\n }\n }\n}\n\nexport default ResourceRegister\n","import type { LayerSpecification } from 'mapbox-gl'\n\n/** ------------------------------------------------ 聚焦图层 --------------------------------------------------------**/\n\nexport const FOCUS_SOURCE_NAME = 'mapbox-gl-focus-source'\n\nexport const FOCUS_LAYER_NAME = 'mapbox-gl-focus-layer'\n\nexport const FOCUS_LAYER: LayerSpecification = {\n id: FOCUS_LAYER_NAME,\n type: 'line',\n source: FOCUS_SOURCE_NAME,\n paint: {\n 'line-color': '#f00',\n 'line-width': 3,\n },\n layout: {},\n}\n","import { bbox, multiLineString } from '@turf/turf'\nimport EventEmitter from 'eventemitter3'\nimport type { BBox, Feature, MultiLineString } from 'geojson'\nimport { set } from 'lodash-es'\nimport type { GeoJSONSource } from 'mapbox-gl'\nimport type { Map } from 'mapbox-gl'\nimport { v4 } from 'uuid'\n\nimport ResourceRegister from '@/core/ResourceRegister'\nimport type { FocusItem, IFocusOptions } from '@/types/Focus'\nimport { distanceToPx } from '@/utils/util.ts'\n\nimport { FOCUS_LAYER, FOCUS_SOURCE_NAME } from './vars.ts'\n\nclass Focus extends EventEmitter {\n private readonly map: Map\n focusItems: FocusItem[] = []\n private register: ResourceRegister\n\n zoomendFunc = this._zoomend.bind(this)\n\n constructor(map: Map) {\n super()\n\n this.map = map\n this.register = new ResourceRegister(map)\n this.onAdd()\n }\n\n get features(): FocusItem['feature'][] {\n return this.focusItems.map((item) => item.border)\n }\n\n onAdd(): void {\n this.register.addSource(FOCUS_SOURCE_NAME, {\n type: 'geojson',\n dynamic: true,\n data: {\n type: 'FeatureCollection',\n features: [],\n },\n })\n\n this.register.addLayer(FOCUS_LAYER)\n }\n onRemove(): void {\n this.removeAll()\n }\n\n set(feature: Feature, options?: IFocusOptions): string | number {\n const uuid = feature.id ?? v4()\n\n this._onHandle(uuid, feature, options)\n\n return uuid\n }\n\n get(id: string): FocusItem | undefined {\n return this.focusItems.find((item) => item.id === id)\n }\n\n remove(id: string): void {\n const i = this.focusItems.findIndex((item) => item.id === id)\n if (i !== -1) {\n this.focusItems.splice(i, 1)\n }\n this.render()\n }\n\n removeAll(): void {\n this.focusItems = []\n this.render()\n }\n\n render(): void {\n const source = this.map.getSource<GeoJSONSource>(FOCUS_SOURCE_NAME)\n\n if (source) {\n if (this.features.length > 0) {\n source.updateData({\n type: 'FeatureCollection',\n features: this.features,\n })\n } else {\n source.setData({\n type: 'FeatureCollection',\n features: this.features,\n })\n }\n }\n }\n\n private _zoomend(): void {\n // this.focusItems.forEach((item) => {\n // this.set(item.feature, { ...item.options, id: item.id })\n // })\n\n this.render()\n }\n\n private _onHandle(uuid: string | number, feature: Feature, options?: IFocusOptions): void {\n const border = this.getFocusBorder(feature, options)\n const item: FocusItem = { id: uuid, border, feature, options }\n\n const i = this.focusItems.findIndex((item) => item.id === uuid)\n if (i !== -1) {\n set(this.focusItems, i, item)\n } else {\n this.focusItems.push(item)\n }\n\n this.render()\n\n if (this.features.length > 0) {\n this.map.on('zoomend', this.zoomendFunc)\n } else {\n this.map.off('zoomend', this.zoomendFunc)\n }\n }\n\n /**\n * 通用聚焦边框生成方法\n * @param feature 目标要素 (Point | LineString | Polygon)\n * @param options 配置项\n * @returns 聚焦框 Feature\n */\n public getFocusBorder(\n feature: Feature,\n options: IFocusOptions = {},\n ): Feature<MultiLineString, { id: string }> {\n const id = String(feature.id ?? v4())\n const { padding = 10, armLength = 20, size = 40 } = options\n\n // 1. 计算原始 BBox\n // 如果是 Point,bbox 是一个点;如果是 Line/Poly,是外包矩形\n const rawBBox = bbox(feature) // [minLng, minLat, maxLng, maxLat]\n\n // 2. 准备计算参数\n // 计算当前缩放级别下,1 像素代表多少米 (用于像素 -> 地理坐标转换)\n // distanceToPx(map, 1) 返回的是 1米多少像素,取倒数就是 1像素多少米\n const metersPerPixel = 1 / distanceToPx(this.map, 1)\n\n // 3. 差异化处理\n let finalBBox = rawBBox\n let finalArmLengthMeters = 0\n\n if (feature.geometry.type === 'Point') {\n // === Point 逻辑 ===\n // 主要是基于 icon size 向外扩张\n // 假设 pointSize 是图标宽/高,padding 是额外留白\n const halfSizePx = size / 2\n const expandMeters = halfSizePx * metersPerPixel\n\n // 计算手臂长度:保持你原来的比例 (size * 0.3)\n finalArmLengthMeters = size * 0.3 * metersPerPixel\n\n // 扩展 BBox (中心点向四周扩散)\n finalBBox = this._expandBBox(rawBBox, expandMeters, rawBBox[1])\n } else {\n // === LineString / Polygon 逻辑 ===\n // 基于几何体 BBox,加上固定的 Padding\n const paddingMeters = padding * metersPerPixel\n\n // 手臂长度:使用固定的像素长度 (防止大物体出现巨大手臂)\n // 同时做一个限制:手臂不能超过边长的一半,否则四个角会这就连在一起了\n // 简单起见,这里先用固定长度\n finalArmLengthMeters = armLength * metersPerPixel\n\n // 扩展 BBox\n finalBBox = this._expandBBox(rawBBox, paddingMeters, rawBBox[1])\n }\n\n // 4. 调用核心绘制逻辑\n return this._createBracketGeometry(id, finalBBox, finalArmLengthMeters)\n }\n\n /**\n * 辅助:向外扩展 BBox (米 -> 经纬度)\n */\n private _expandBBox(rawBBox: number[], expandMeters: number, baseLat: number): BBox {\n const [minLng, minLat, maxLng, maxLat] = rawBBox\n\n const METERS_PER_DEGREE_LAT = 111319\n const dLat = expandMeters / METERS_PER_DEGREE_LAT\n const dLng = dLat / Math.cos((baseLat * Math.PI) / 180)\n\n return [minLng - dLng, minLat - dLat, maxLng + dLng, maxLat + dLat]\n }\n\n /**\n * 核心绘制:根据 BBox 和 手臂物理长度 生成括号坐标\n * (这是你原来那个方法的纯净版,去掉了业务逻辑,只负责画图)\n */\n private _createBracketGeometry(\n id: string,\n bbox: number[],\n armLengthMeters: number,\n ): Feature<MultiLineString, { id: string }> {\n const [minLng, minLat, maxLng, maxLat] = bbox\n\n // 经纬度转换\n const METERS_PER_DEGREE_LAT = 111319\n const dLat = armLengthMeters / METERS_PER_DEGREE_LAT\n const latRad = (minLat * Math.PI) / 180\n const dLng = dLat / Math.cos(latRad)\n\n // 限制手臂长度,防止重叠 (可选优化)\n // 如果 BBox 特别小,dLat 可能大于高度的一半\n const actualDLat = Math.min(dLat, (maxLat - minLat) / 2)\n const actualDLng = Math.min(dLng, (maxLng - minLng) / 2)\n\n const coordinates = [\n // 左下角 (BL)\n [\n [minLng + actualDLng, minLat],\n [minLng, minLat],\n [minLng, minLat + actualDLat],\n ],\n // 左上角 (TL)\n [\n [minLng, maxLat - actualDLat],\n [minLng, maxLat],\n [minLng + actualDLng, maxLat],\n ],\n // 右上角 (TR)\n [\n [maxLng - actualDLng, maxLat],\n [maxLng, maxLat],\n [maxLng, maxLat - actualDLat],\n ],\n // 右下角 (BR)\n [\n [maxLng, minLat + actualDLat],\n [maxLng, minLat],\n [maxLng - actualDLng, minLat],\n ],\n ]\n\n return multiLineString(coordinates, { id }, { id })\n }\n}\n\nexport default Focus\n","import EventEmitter from 'eventemitter3'\nimport type { Map } from 'mapbox-gl'\n\nimport Focus from '@/core/Focus'\nimport IconManager from '@/core/IconManager'\nimport ResourceRegister from '@/core/ResourceRegister'\nimport type { IContextOptions } from '@/types/Module/Context.ts'\n\nexport class Context {\n public readonly map: Map\n public readonly events: EventEmitter\n public readonly register: ResourceRegister\n public readonly iconManage: IconManager\n public readonly focus: Focus\n\n // 4. 一个通用的状态存储 (替代原来的 Store._listeners 等)\n // public readonly state: Map<string, any> = new Map();\n\n public constructor(options: IContextOptions) {\n this.map = options.map\n this.events = new EventEmitter()\n this.register = new ResourceRegister(this.map)\n this.iconManage = new IconManager(this.map)\n this.focus = new Focus(this.map)\n\n // this.map.on('load', () => {\n // this.focus.onAdd()\n // })\n }\n\n // 提供一个销毁方法,统一清理资源\n public destroy(): void {\n this.events.removeAllListeners()\n // this.icons.clear();\n // this.map.remove(); // map 的销毁通常由外部控制,这里视情况而定\n return\n }\n}\n\nconst registry = new WeakMap<Map, Context>()\n\n/**\n * 获取或创建上下文\n * 这是整个单例逻辑的入口,但它是“每个 Map 一个单例”\n */\nexport function getOrCreateContext(map: Map): Context {\n const existing = registry.get(map)\n\n // 2. 如果存在,直接返回\n if (existing) {\n return existing\n }\n\n const context = new Context({ map })\n registry.set(map, context)\n\n // 监听移除,防止内存泄漏\n map.once('remove', () => {\n context.destroy()\n registry.delete(map)\n })\n\n return context\n}\n","import type { Map } from 'mapbox-gl'\n\nimport type { BeforeRemoveEvent } from '@/types/CMap'\n\nimport type { Context } from './Context.ts'\nimport { getOrCreateContext } from './Context.ts'\n\nexport abstract class Module {\n protected context: Context\n\n /**\n * 构造函数,初始化地图上下文和选项配置\n * @param map - 地图实例对象\n */\n protected constructor(map: Map) {\n this.context = getOrCreateContext(map)\n\n this.onAdd()\n\n this.context.map.once('beforeRemove', (e: BeforeRemoveEvent) => {\n console.log(e.cancel, 'beforeRemove')\n })\n }\n\n // eslint-disable-next-line @typescript-eslint/explicit-function-return-type\n public emit() {\n this.context.events.emit('')\n }\n\n public destroy(): void {\n this.onRemove()\n }\n\n abstract onAdd(): void\n\n abstract onRemove(): void\n}\n","import type { LayerSpecification } from 'mapbox-gl'\n\nexport const CONNECT_LINE_LAYER_NAME = 'mapbox-gl-tooltip-connect-line'\n\nexport const TOOLTIP_SOURCE_NAME = 'mapbox-gl-tooltip-source'\n\nexport const CONNECT_LINE_LAYER: LayerSpecification = {\n id: CONNECT_LINE_LAYER_NAME,\n source: TOOLTIP_SOURCE_NAME,\n type: 'line',\n paint: {\n 'line-color': '#000',\n 'line-width': 1,\n },\n}\n","import { lineString } from '@turf/turf'\nimport type * as GeoJSON from 'geojson'\nimport type { LngLat, Map } from 'mapbox-gl'\nimport { Marker, Point } from 'mapbox-gl'\nimport type { BBox } from 'rbush'\n\nimport { Module } from '@/core/Module'\nimport type { AllAnchor, ITooltipOptions } from '@/types/Toolip'\n\nimport { CONNECT_LINE_LAYER, TOOLTIP_SOURCE_NAME } from './vars.ts'\n\nexport class Tooltip extends Module {\n options: ITooltipOptions\n\n private visible = false\n\n private mark: Marker | null = null\n\n zoomFunc: () => void = this._zoom.bind(this)\n zoomEndFunc: () => void = this._zoom.bind(this)\n\n constructor(map: Map, options: ITooltipOptions) {\n super(map)\n this.options = options\n this.visible = !!options.visible\n\n this._create()\n }\n\n get id(): string | number {\n return this.options.id\n }\n\n override onAdd(): void {\n this.context.register.addSource(TOOLTIP_SOURCE_NAME, {\n type: 'geojson',\n dynamic: true,\n data: {\n type: 'FeatureCollection',\n features: [],\n },\n })\n\n this.context.register.addLayer(CONNECT_LINE_LAYER)\n }\n\n override onRemove(): void {\n if (this.mark) {\n this.mark.remove()\n this.mark = null\n }\n }\n\n hide(): void {\n this.visible = false\n this.render()\n this.context.map.off('zoom', this.zoomFunc)\n this.context.map.off('zoomend', this.zoomFunc)\n }\n\n show(): void {\n this.visible = true\n this.render()\n this.context.map.on('zoom', this.zoomFunc)\n this.context.map.on('zoomend', this.zoomFunc)\n }\n\n setAnchor(anchor: ITooltipOptions['anchor']): void {\n if (this.mark) {\n this.mark.remove()\n this.mark = null\n }\n this.context.map.off('zoom', this.zoomFunc)\n this.context.map.off('zoomend', this.zoomFunc)\n\n this.options.anchor = anchor\n this._create()\n\n this.render()\n }\n\n getAllBbox(): AllAnchor {\n return {\n center: this.getBbox('center'),\n top: this.getBbox('top'),\n bottom: this.getBbox('bottom'),\n left: this.getBbox('left'),\n right: this.getBbox('right'),\n 'top-left': this.getBbox('top-left'),\n 'top-right': this.getBbox('top-right'),\n 'bottom-left': this.getBbox('bottom-left'),\n 'bottom-right': this.getBbox('bottom-right'),\n }\n }\n\n getBbox(val?: ITooltipOptions['anchor']): BBox {\n if (this.mark === null) {\n return {\n minX: 0,\n minY: 0,\n maxX: 0,\n maxY: 0,\n }\n }\n\n const anchor = val ?? this.options.anchor\n\n const point = this.context.map.project(this.mark.getLngLat())\n // const offset = this.mark.getOffset() || new Point(0, 0)\n const offset = this.mark.getOffset()\n const { offsetWidth, offsetHeight } = this.mark.getElement()\n\n const bbox: BBox = {\n minX: point.x,\n minY: point.y,\n maxX: point.x,\n maxY: point.y,\n }\n\n if (anchor === 'top') {\n bbox.minX = point.x - offsetWidth / 2\n bbox.maxX = point.x + offsetWidth / 2\n bbox.maxY = point.y + offsetHeight + Math.abs(offset.y)\n } else if (anchor === 'bottom') {\n bbox.minX = point.x - offsetWidth / 2\n bbox.maxX = point.x + offsetWidth / 2\n bbox.minY = point.y - offsetHeight + offset.y\n } else if (anchor === 'left') {\n bbox.maxY = point.y + offsetHeight / 2\n bbox.minY = point.y - offsetHeight / 2\n bbox.maxX = point.x + offsetWidth + Math.abs(offset.x)\n } else if (anchor === 'right') {\n bbox.maxY = point.y + offsetHeight / 2\n bbox.minY = point.y - offsetHeight / 2\n bbox.minX = point.x - offsetWidth + offset.x\n } else if (anchor === 'center') {\n bbox.maxY = point.y + offsetHeight / 2\n bbox.minY = point.y - offsetHeight / 2\n bbox.maxX = point.x + offsetWidth / 2\n bbox.minX = point.x - offsetWidth / 2\n } else if (anchor === 'top-left') {\n bbox.maxY = point.y + offsetHeight + Math.abs(offset.y)\n bbox.maxX = point.x + offsetWidth + Math.abs(offset.x)\n } else if (anchor === 'top-right') {\n bbox.maxY = point.y + offsetHeight + Math.abs(offset.y)\n bbox.minX = point.x - offsetWidth + offset.x\n } else if (anchor === 'bottom-left') {\n bbox.minY = point.y - offsetHeight + offset.y\n bbox.maxX = point.x + offsetWidth + Math.abs(offset.x)\n } else if (anchor === 'bottom-right') {\n bbox.minY = point.y - offsetHeight + offset.y\n bbox.minX = point.x - offsetWidth + offset.x\n }\n\n return bbox\n }\n\n remove(): void {\n if (this.mark) {\n this.mark.remove()\n this.mark = null\n }\n\n this.visible = false\n this.connectLine()\n this.context.map.off('zoom', this.zoomFunc)\n this.context.map.off('zoomend', this.zoomFunc)\n }\n\n _create(): void {\n this.mark = new Marker({\n className: this.options.className ?? 'mapbox-gl-tooltip',\n element: this.options.element,\n offset: this._getOffsetByAnchor(),\n anchor: this.options.anchor,\n }).setLngLat(this.options.position)\n\n if (this.visible) {\n this.render()\n this.context.map.on('zoom', this.zoomFunc)\n this.context.map.on('zoomend', this.zoomFunc)\n }\n }\n\n _getOffsetByAnchor(): Point {\n const offset = new Point(0, 0)\n if (this.options.anchor === 'center') {\n offset.x = 0\n offset.y = 0\n } else if (this.options.anchor === 'top') {\n offset.x = 0\n offset.y = this.options.offsetY ?? 0\n } else if (this.options.anchor === 'bottom') {\n offset.x = 0\n offset.y = -(this.options.offsetY ?? 0)\n } else if (this.options.anchor === 'left') {\n offset.x = this.options.offsetX ?? 0\n offset.y = 0\n } else if (this.options.anchor === 'right') {\n offset.x = -(this.options.offsetX ?? 0)\n offset.y = 0\n } else if (this.options.anchor === 'top-left') {\n offset.x = this.options.offsetX ?? 0\n offset.y = this.options.offsetY ?? 0\n } else if (this.options.anchor === 'top-right') {\n offset.x = -(this.options.offsetX ?? 0)\n offset.y = this.options.offsetY ?? 0\n } else if (this.options.anchor === 'bottom-left') {\n offset.x = this.options.offsetX ?? 0\n offset.y = -(this.options.offsetY ?? 0)\n } else if (this.options.anchor === 'bottom-right') {\n offset.x = -(this.options.offsetX ?? 0)\n offset.y = -(this.options.offsetY ?? 0)\n }\n\n return offset\n }\n\n setLngLat(lngLat: LngLat): this {\n this.options.position = lngLat\n\n if (this.mark) {\n this.mark.setLngLat(lngLat)\n }\n\n return this\n }\n\n connectLine(): void {\n const id = `${String(this.options.id)}-tooltip-connect-line`\n\n const endPoint = this.connectPoint()\n if (!endPoint || !this.visible) {\n const emptyFeature: GeoJSON.Feature<GeoJSON.Point> = {\n type: 'Feature',\n geometry: {\n type: 'Point',\n coordinates: [0, 0],\n },\n id,\n properties: {},\n }\n\n this.context.register.updateGeoJSONData(TOOLTIP_SOURCE_NAME, emptyFeature)\n return\n }\n\n const lonLat = [this.options.position.toArray(), endPoint.toArray()]\n\n const feature: GeoJSON.Feature<GeoJSON.LineString> = lineString(\n lonLat,\n {},\n {\n id,\n },\n )\n\n this.context.register.updateGeoJSONData(TOOLTIP_SOURCE_NAME, feature)\n }\n\n connectPoint(): LngLat | null {\n if (!this.mark || !this.visible) return null\n\n const point = this.context.map.project(this.mark.getLngLat())\n const offset = this.mark.getOffset()\n\n point.x += offset.x\n point.y += offset.y\n\n if (this.options.anchor === 'top-left') {\n point.x += this.mark.getElement().offsetWidth / 2\n } else if (this.options.anchor === 'top-right') {\n point.x -= this.mark.getElement().offsetWidth / 2\n } else if (this.options.anchor === 'bottom-left') {\n point.x += this.mark.getElement().offsetWidth / 2\n } else if (this.options.anchor === 'bottom-right') {\n point.x -= this.mark.getElement().offsetWidth / 2\n }\n\n return this.context.map.unproject(point)\n }\n\n render(): this {\n if (!this.mark) {\n console.warn(this, 'tooltip尚未初始化')\n return this\n }\n\n if (this.visible) {\n this.mark.addTo(this.context.map)\n } else {\n this.mark.remove()\n }\n\n this.connectLine()\n return this\n }\n\n _zoom(): void {\n if (!this.mark || !this.visible) return\n\n this.connectLine()\n }\n}\n","import type { LayerSpecification } from 'mapbox-gl'\n\nimport type { SvgIcon } from '@/types/IconManager'\n\nexport const NAME = 'Ais'\n\nexport const SHIP_SOURCE_NAME = 'mapbox-gl-ship-source'\n\nexport const SHIP_ICON_LAYER_NAME = 'mapbox-gl-ship-icon-layer'\n\nexport const SHIP_REAL_LAYER_NAME = 'mapbox-gl-ship-real-layer'\n\nexport const SHIP_REAL_OUTLINE_LAYER_NAME = 'mapbox-gl-ship-real-outline-layer'\n\nexport const MIN_ICON_SIZE = 0.2\n\nexport const MAX_ICON_SIZE = 0.5\n\nexport enum UPDATE_STATUS {\n ONLINE = 'Online',\n DELAY = 'Delay',\n OFFLINE = 'Offline',\n}\n\nexport enum SHIP_COLOR {\n ONLINE = '#03CC02',\n DELAY = '#FFFD6C',\n OFFLINE = '#999999',\n}\n\nexport const SHIP_ICON_LAYER: LayerSpecification = {\n id: SHIP_ICON_LAYER_NAME,\n source: SHIP_SOURCE_NAME,\n filter: ['==', '$type', 'Point'],\n type: 'symbol',\n layout: {\n 'icon-allow-overlap': true,\n 'icon-image': ['get', 'icon'],\n 'icon-rotate': ['get', 'direction'],\n 'icon-size': [\n 'interpolate',\n ['linear'],\n ['zoom'],\n 0,\n ['coalesce', ['get', 'minIconSize'], 0.2],\n 19,\n ['coalesce', ['get', 'maxIconSize'], 0.5],\n ],\n },\n}\n\nexport const SHIP_REAL_LAYER: LayerSpecification = {\n id: SHIP_REAL_LAYER_NAME,\n source: SHIP_SOURCE_NAME,\n type: 'fill',\n layout: {},\n paint: {\n 'fill-color': [\n 'case',\n ['==', ['get', 'updateStatus'], UPDATE_STATUS.ONLINE],\n SHIP_COLOR.ONLINE,\n ['==', ['get', 'updateStatus'], UPDATE_STATUS.DELAY],\n SHIP_COLOR.DELAY,\n ['==', ['get', 'updateStatus'], UPDATE_STATUS.OFFLINE],\n SHIP_COLOR.OFFLINE,\n SHIP_COLOR.OFFLINE,\n ],\n },\n}\n\nexport const SHIP_REAL_OUTLINE_LAYER: LayerSpecification = {\n id: SHIP_REAL_OUTLINE_LAYER_NAME,\n source: SHIP_SOURCE_NAME,\n type: 'line',\n layout: {},\n paint: {\n 'line-color': [\n 'case',\n ['boolean', ['feature-state', 'hover'], false],\n '#f00',\n ['boolean', ['feature-state', 'focus'], false],\n '#f00',\n '#000',\n ],\n 'line-width': 2,\n },\n}\n\nexport const LAYER_LIST: LayerSpecification[] = [\n SHIP_ICON_LAYER,\n SHIP_REAL_LAYER,\n SHIP_REAL_OUTLINE_LAYER,\n]\n\nexport const SHIP_ICON: SvgIcon[] = [\n {\n name: `${NAME}-$color-static`,\n svg:\n '<?xml version=\"1.0\" encoding=\"UTF-8\"?>\\n' +\n '<svg width=\"33px\" height=\"49px\" viewBox=\"0 0 33 49\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\\n' +\n ' <title>delay_nospeed</title>\\n' +\n ' <g id=\"页面-1\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\\n' +\n ' <g id=\"delay_nospeed\" fill=\"$color\" stroke=\"#000000\" stroke-width=\"2\">\\n' +\n ' <path d=\"M16.5,3.13354433 L31.6080922,48 L1.39190779,48 L16.5,3.13354433 Z\" id=\"三角形\"></path>\\n' +\n ' </g>\\n' +\n ' </g>\\n' +\n '</svg>',\n },\n {\n name: `${NAME}-$color-static-active`,\n svg:\n '<?xml version=\"1.0\" encoding=\"UTF-8\"?>\\n' +\n '<svg width=\"33px\" height=\"49px\" viewBox=\"0 0 33 49\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\\n' +\n ' <title>delay_nospeed_select</title>\\n' +\n ' <g id=\"页面-1\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\\n' +\n ' <g id=\"delay_nospeed_select\" fill=\"$color\" stroke=\"#FF0000\" stroke-width=\"2\">\\n' +\n ' <path d=\"M16.5,3.13354433 L31.6080922,48 L1.39190779,48 L16.5,3.13354433 Z\" id=\"三角形\"></path>\\n' +\n ' </g>\\n' +\n ' </g>\\n' +\n '</svg>',\n },\n {\n name: `${NAME}-$color-straight`,\n svg:\n '<?xml version=\"1.0\" encoding=\"UTF-8\"?>\\n' +\n '<svg width=\"33px\" height=\"87px\" viewBox=\"0 0 33 87\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\\n' +\n ' <title>delay_straight</title>\\n' +\n ' <g id=\"页面-1\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\\n' +\n ' <g id=\"delay_straight\" transform=\"translate(0, 1)\" stroke=\"#000000\" stroke-width=\"2\">\\n' +\n ' <path d=\"M16.5,40.1335443 L31.6080922,85 L1.39190779,85 L16.5,40.1335443 Z\" id=\"三角形\" fill=\"$color\"></path>\\n' +\n ' <line x1=\"16.5\" y1=\"0.5\" x2=\"16.5\" y2=\"41.5\" id=\"直线\" stroke-linecap=\"square\"></line>\\n' +\n ' </g>\\n' +\n ' </g>\\n' +\n '</svg>',\n },\n {\n name: `${NAME}-$color-straight-active`,\n svg:\n '<?xml version=\"1.0\" encoding=\"UTF-8\"?>\\n' +\n '<svg width=\"33px\" height=\"87px\" viewBox=\"0 0 33 87\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\\n' +\n ' <title>delay_straight_select</title>\\n' +\n ' <g id=\"页面-1\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\\n' +\n ' <g id=\"delay_straight_select\" transform=\"translate(0, 1)\" stroke=\"#FF0000\" stroke-width=\"2\">\\n' +\n ' <path d=\"M16.5,40.1335443 L31.6080922,85 L1.39190779,85 L16.5,40.1335443 Z\" id=\"三角形\" fill=\"$color\"></path>\\n' +\n ' <line x1=\"16.5\" y1=\"0.5\" x2=\"16.5\" y2=\"41.5\" id=\"直线\" stroke-linecap=\"square\"></line>\\n' +\n ' </g>\\n' +\n ' </g>\\n' +\n '</svg>',\n },\n {\n name: `${NAME}-$color-left`,\n svg:\n '<?xml version=\"1.0\" encoding=\"UTF-8\"?>\\n' +\n '<svg width=\"40px\" height=\"87px\" viewBox=\"0 0 40 87\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\\n' +\n ' <title>delay_left</title>\\n' +\n ' <g id=\"页面-1\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\\n' +\n ' <g id=\"delay_left\" transform=\"translate(20.5, 44) scale(-1, 1) translate(-20.5, -44)translate(1, 1)\" stroke=\"#000000\" stroke-width=\"2\">\\n' +\n ` <path d=\"M16.5,40.1335443 L31.6080922,85 L1.39190779,85 L16.5,40.1335443 Z\" id=\"三角形\" fill=\"$color\"></path>\n` +\n ' <line x1=\"16.5\" y1=\"0.5\" x2=\"16.5\" y2=\"41.5\" id=\"直线\" stroke-linecap=\"square\"></line>\\n' +\n ' <line x1=\"16.5\" y1=\"0.5\" x2=\"38.5\" y2=\"0.5\" id=\"直线-2\" stroke-linecap=\"square\"></line>\\n' +\n ' </g>\\n' +\n ' </g>\\n' +\n '</svg>',\n },\n {\n name: `${NAME}-$color-left-active`,\n svg:\n '<?xml version=\"1.0\" encoding=\"UTF-8\"?>\\n' +\n '<svg width=\"41px\" height=\"87px\" viewBox=\"0 0 41 87\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\\n' +\n ' <title>delay_left_select</title>\\n' +\n ' <g id=\"页面-1\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\\n' +\n ' <g id=\"delay_left_select\" transform=\"translate(20.75, 43.75) scale(-1, 1) translate(-20.75, -43.75)translate(1, 0.5)\" stroke=\"#FF0000\" stroke-width=\"2\">\\n' +\n ' <path d=\"M16.5,40.6335443 L31.6080922,85.5 L1.39190779,85.5 L16.5,40.6335443 Z\" id=\"三角形\" fill=\"$color\"></path>\\n' +\n ' <line x1=\"16.5\" y1=\"1\" x2=\"16.5\" y2=\"42\" id=\"直线\" stroke-linecap=\"square\"></line>\\n' +\n ' <line x1=\"17\" y1=\"0.5\" x2=\"39\" y2=\"0.5\" id=\"直线-2\" stroke-linecap=\"square\"></line>\\n' +\n ' </g>\\n' +\n ' </g>\\n' +\n '</svg>',\n },\n {\n name: `${NAME}-$color-right`,\n svg:\n '<?xml version=\"1.0\" encoding=\"UTF-8\"?>\\n' +\n '<svg width=\"40px\" height=\"87px\" viewBox=\"0 0 40 87\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\\n' +\n ' <title>delay_right</title>\\n' +\n ' <g id=\"页面-1\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\\n' +\n ' <g id=\"delay_right\" transform=\"translate(0, 1)\" stroke=\"#000000\" stroke-width=\"2\">\\n' +\n ' <path d=\"M16.5,40.1335443 L31.6080922,85 L1.39190779,85 L16.5,40.1335443 Z\" id=\"三角形\" fill=\"$color\"></path>\\n' +\n ' <line x1=\"16.5\" y1=\"0.5\" x2=\"16.5\" y2=\"41.5\" id=\"直线\" stroke-linecap=\"square\"></line>\\n' +\n ' <line x1=\"16.5\" y1=\"0.5\" x2=\"38.5\" y2=\"0.5\" id=\"直线-2\" stroke-linecap=\"square\"></line>\\n' +\n ' </g>\\n' +\n ' </g>\\n' +\n '</svg>',\n },\n {\n name: `${NAME}-$color-right-active`,\n svg:\n '<?xml version=\"1.0\" encoding=\"UTF-8\"?>\\n' +\n '<svg width=\"40px\" height=\"87px\" viewBox=\"0 0 40 87\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\\n' +\n ' <title>delay_right_select</title>\\n' +\n ' <g id=\"页面-1\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\\n' +\n ' <g id=\"delay_right_select\" transform=\"translate(0, 0.5)\" stroke=\"#FF0000\" stroke-width=\"2\">\\n' +\n ' <path d=\"M16.5,40.6335443 L31.6080922,85.5 L1.39190779,85.5 L16.5,40.6335443 Z\" id=\"三角形\" fill=\"$color\"></path>\\n' +\n ' <line x1=\"16.5\" y1=\"1\" x2=\"16.5\" y2=\"42\" id=\"直线\" stroke-linecap=\"square\"></line>\\n' +\n ' <line x1=\"17\" y1=\"0.5\" x2=\"39\" y2=\"0.5\" id=\"直线-2\" stroke-linecap=\"square\"></line>\\n' +\n ' </g>\\n' +\n ' </g>\\n' +\n '</svg>',\n },\n]\n","import type { LngLatLike, MapOptions, PopupOptions } from 'mapbox-gl'\n\nexport interface BeforeRemoveEvent {\n /**\n * 阻止销毁的方法\n * @param isCancel - true: 阻止销毁; false: 继续销毁\n */\n cancel: (isCancel: boolean) => void\n}\n\nexport enum MapType {\n LAND = 'land',\n SATELLITE = 'satellite',\n}\n\nexport interface formatOptions {\n value: string | number\n data: object\n}\n\nexport interface InfoFormConfig {\n label: string | number\n\n prop: string | number\n\n format(formatOptions: formatOptions): string\n}\n\nexport type customPopupOptions = PopupOptions & {\n center: LngLatLike\n\n config: InfoFormConfig[]\n\n data: object\n\n template: string\n}\n\nexport interface ICMapOptions extends MapOptions {\n type?: MapType\n}\n","import type { StyleSpecification } from 'mapbox-gl'\n\nexport const landStyle: StyleSpecification = {\n version: 8,\n name: 'Basic',\n glyphs: 'https://sdkinteligenceberth.zhonganhse.com:21333/app/font/{fontstack}/{range}.pbf',\n sources: {\n base: {\n tiles: [\n // \"http://t0.tianditu.gov.cn/vec_w/wmts?tk=645d596e234d96fb5b919937f46c9a00\",\n `http://tianditu.ehanghai.cn/DataServer?T=vec_w&x={x}&y={y}&l={z}&tk=468826a92a07c852cefab31f9bed06d4`,\n ],\n type: 'raster',\n tileSize: 256,\n minzoom: 0,\n maxzoom: 17,\n },\n label: {\n tiles: [\n // \"http://t0.tianditu.gov.cn/cva_w/wmts?tk=645d596e234d96fb5b919937f46c9a00\",\n `http://tianditu.ehanghai.cn/DataServer?T=cva_w&x={x}&y={y}&l={z}&tk=468826a92a07c852cefab31f9bed06d4`,\n ],\n type: 'raster',\n tileSize: 256,\n minzoom: 0,\n maxzoom: 217,\n },\n },\n layers: [\n {\n id: 'background',\n type: 'background',\n paint: {\n 'background-color': 'rgba(212,234,238,1)',\n },\n },\n {\n id: 'base_layer',\n source: 'base',\n type: 'raster',\n },\n {\n id: 'label_layer',\n source: 'label',\n type: 'raster',\n },\n {\n id: 'base-end',\n type: 'background',\n paint: {\n 'background-color': 'transparent',\n },\n },\n {\n id: 'point-end',\n type: 'background',\n paint: {\n 'background-color': 'transparent',\n },\n },\n ],\n}\n","import EventEmitter from 'eventemitter3'\nimport { Map } from 'mapbox-gl'\n\nimport IconManager from '@/core/IconManager'\nimport { SHIP_COLOR, SHIP_ICON, UPDATE_STATUS } from '@/modules/Ship/vars.ts'\nimport type { ICMapOptions } from '@/types/CMap'\nimport { MapType } from '@/types/CMap'\nimport type { SvgIcon } from '@/types/IconManager'\n\nimport { landStyle } from './vars.ts'\n\nexport class CMap extends EventEmitter {\n public readonly map: Map\n private readonly options: ICMapOptions\n private cache = new Set<(map: Map) => void>()\n private timer: number | null = null\n private readonly originalRemove: () => void\n\n readonly icon: IconManager\n\n static LAND: MapType = MapType.LAND\n static SATELLITE: MapType = MapType.SATELLITE\n\n constructor(options: ICMapOptions) {\n super()\n\n // if (options.type === CMap.LAND) {\n // this.options = {\n // ...options,\n // style: landStyle,\n // }\n // }\n this.options = options\n Map.prototype._authenticate = (): void => {\n /* empty */\n }\n\n this.map = new Map({ ...this.options, style: landStyle })\n this.icon = new IconManager(this.map)\n\n this.originalRemove = this.map.remove.bind(this.map)\n\n this.map.remove = (): void => {\n this.map.fire('beforeRemove', {\n cancel: (isCancel: boolean) => {\n if (!isCancel) {\n this.originalRemove()\n }\n },\n })\n }\n\n this.map.once('load', () => {\n // eslint-disable-next-line @typescript-eslint/no-misused-promises\n SHIP_ICON.forEach(async (icon: SvgIcon) => {\n await Promise.all([\n this.icon.addSvg({\n name: icon.name.replace('$color', UPDATE_STATUS.ONLINE),\n svg: icon.svg.replace('$color', SHIP_COLOR.ONLINE),\n }),\n this.icon.addSvg({\n name: icon.name.replace('$color', UPDATE_STATUS.DELAY),\n svg: icon.svg.replace('$color', SHIP_COLOR.DELAY),\n }),\n this.icon.addSvg({\n name: icon.name.replace('$color', UPDATE_STATUS.OFFLINE),\n svg: icon.svg.replace('$color', SHIP_COLOR.OFFLINE),\n }),\n ])\n })\n this.emit('loaded', this.map)\n })\n }\n\n getMap(): Map {\n return this.map\n }\n\n zoomIn(): void {\n if (!this.getMap().isZooming()) {\n this.getMap().zoomIn()\n }\n }\n\n zoomOut(): void {\n if (!this.getMap().isZooming()) {\n this.getMap().zoomOut()\n }\n }\n\n mapLoaded(): Promise<Map> {\n const load = (resolve: (mao: Map) => void): void => {\n if (!this.getMap()._loaded) {\n if (!this.timer) {\n this.timer = setInterval(() => {\n load(resolve)\n }, 16) as unknown as number\n } else {\n this.cache.add(resolve)\n }\n } else {\n if (this.timer) {\n clearInterval(this.timer)\n this.timer = null\n }\n if (this.cache.size > 0) {\n this.cache.forEach((cb): void => {\n cb(this.getMap())\n })\n this.cache.clear()\n }\n\n resolve(this.getMap())\n }\n }\n\n return new Promise((resolve, reject) => {\n try {\n load(resolve)\n } catch (e) {\n if (this.timer) {\n clearInterval(this.timer)\n this.timer = null\n }\n\n reject(new Error(`mapLoaded错误:${e as string}`))\n }\n })\n }\n}\n","export enum EventStatus {\n ON = 'On',\n OFF = 'Off',\n}\n\nexport interface EventItem {\n emit: () => void\n on: () => void\n}\n","import type { Map } from 'mapbox-gl'\n\nimport { Module } from '@/core/Module'\nimport { EventStatus } from '@/types/EventState'\n\nexport abstract class EventState extends Module {\n private status: EventStatus = EventStatus.OFF\n static ON: EventStatus = EventStatus.ON\n static OFF: EventStatus = EventStatus.OFF\n\n protected constructor(map: Map) {\n super(map)\n }\n\n public abstract override onAdd(): void\n\n public abstract override onRemove(): void\n\n public switch(): EventStatus {\n if (this.status === EventState.ON) {\n this.status = EventState.OFF\n this.off()\n } else if (this.status === EventState.OFF) {\n this.status = EventState.ON\n this.on()\n }\n\n return this.status\n }\n\n public abstract on(): void\n\n public abstract off(): void\n}\n","import type { Map, MapMouseEvent } from 'mapbox-gl'\n\nimport { EventState } from '@/core/EventState'\nimport type { AisShip } from '@/modules/Ship/plugins/AisShip.ts'\nimport { SHIP_ICON_LAYER_NAME, SHIP_REAL_LAYER_NAME } from '@/modules/Ship/vars.ts'\nimport type { IAisShipOptions } from '@/types/Ship/AisShip.ts'\n\nexport class ResidentEvent extends EventState {\n private ships: AisShip[] = []\n protected hoverId: IAisShipOptions['id'] | null | undefined = null\n protected _click: OmitThisParameter<(e: MapMouseEvent) => void> = (): void => {\n /* empty */\n }\n protected _move: OmitThisParameter<(e: MapMouseEvent) => void> = (): void => {\n /* empty */\n }\n protected _leave: OmitThisParameter<(e: MapMouseEvent) => void> = (): void => {\n /* empty */\n }\n protected _zoomEnd = (): void => {\n /* empty */\n }\n\n constructor(map: Map, ships?: AisShip[]) {\n super(map)\n\n if (ships) {\n this.ships = ships\n }\n }\n\n override on(): void {\n this.context.map.on('click', SHIP_ICON_LAYER_NAME, this._click)\n this.context.map.on('mousemove', SHIP_ICON_LAYER_NAME, this._move)\n this.context.map.on('mouseleave', SHIP_ICON_LAYER_NAME, this._leave)\n\n this.context.map.on('click', SHIP_REAL_LAYER_NAME, this._click)\n this.context.map.on('mousemove', SHIP_REAL_LAYER_NAME, this._move)\n this.context.map.on('mouseleave', SHIP_REAL_LAYER_NAME, this._leave)\n\n this.context.map.on('zoomend', this._zoomEnd)\n }\n\n override off(): void {\n this.context.map.off('click', SHIP_ICON_LAYER_NAME, this._click)\n this.context.map.off('mousemove', SHIP_ICON_LAYER_NAME, this._move)\n this.context.map.off('mouseleave', SHIP_ICON_LAYER_NAME, this._leave)\n\n this.context.map.off('click', SHIP_REAL_LAYER_NAME, this._click)\n this.context.map.off('mousemove', SHIP_REAL_LAYER_NAME, this._move)\n this.context.map.off('mouseleave', SHIP_REAL_LAYER_NAME, this._leave)\n\n this.context.map.off('zoomend', this._zoomEnd)\n }\n\n onAdd(): void {\n this._click = this.onClick.bind(this)\n this._move = this.onMove.bind(this)\n this._leave = this.onLeave.bind(this)\n this._zoomEnd = this.onZoomEnd.bind(this)\n\n this.on()\n }\n\n onRemove(): void {\n this.off()\n }\n\n add(ship: AisShip): void {\n const data = this.findShip(ship.id)\n if (data) {\n ship.update(data.options)\n } else {\n this.ships.push(ship)\n }\n }\n\n remove(id: IAisShipOptions['id']): void {\n const i = this.ships.findIndex((item) => item.id === id)\n if (i !== -1) {\n this.ships.splice(i, 1)\n }\n }\n\n removeAll(): void {\n this.ships = []\n }\n\n onZoomEnd(): void {\n this.ships.forEach((ship) => {\n ship.render()\n })\n }\n\n onMove(e: MapMouseEvent): void {\n if (e.features?.length) {\n this.context.map.getCanvasContainer().style.cursor = 'pointer'\n\n if (this.hoverId === e.features[0].id) return\n\n if (this.hoverId) {\n this.unhover()\n }\n\n this.hoverId = e.features[0].id as string\n this.hover()\n }\n }\n\n onLeave(): void {\n this.unhover()\n this.hoverId = null\n this.context.map.getCanvasContainer().style.cursor = ''\n }\n\n onClick(e: MapMouseEvent): void {\n if (e.features?.length) {\n const id = e.features[0].id\n if (id) {\n const ship = this.findShip(id)\n ship?.focus()\n\n console.log(ship, 'ship')\n this.context.events.emit('click', ship)\n }\n }\n }\n\n hover(): void {\n if (!this.hoverId) return\n\n const ship = this.findShip(this.hoverId)\n ship?.setState({ hover: true })\n ship?.render()\n this.context.events.emit('hover', ship)\n }\n\n unhover(): void {\n if (!this.hoverId) return\n\n const ship = this.findShip(this.hoverId)\n ship?.setState({ hover: false })\n ship?.render()\n this.context.events.emit('unhover', ship)\n }\n\n findShip(id: IAisShipOptions['id']): AisShip | undefined {\n return this.ships.find((item) => String(item.id) === String(id))\n }\n}\n","import type { Map as MapboxGlMap } from 'mapbox-gl'\n\nimport Collision from '@/core/Collision'\nimport { Module } from '@/core/Module'\nimport type { Tooltip } from '@/core/Tooltip'\nimport type { BaseShip } from '@/modules/Ship/BaseShip.ts'\nimport { ResidentEvent } from '@/modules/Ship/Events/ResidentEvent'\nimport type { CollisionItemOptions } from '@/types/Collision/item.ts'\nimport type { IShipOptions } from '@/types/Ship'\nimport type { BaseShipConstructor, IBaseShipOptions } from '@/types/Ship/BaseShip.ts'\n\nclass Ship extends Module {\n options: IShipOptions\n ships: BaseShip<any>[] = []\n event: ResidentEvent\n\n private pluginRegistry = new Map<string, BaseShipConstructor>()\n private collision: Collision\n\n constructor(map: MapboxGlMap, options: IShipOptions) {\n super(map)\n this.options = options\n this.collision = new Collision(this.context.map)\n this.event = new ResidentEvent(map)\n\n this.registerPlugins(options.plugins)\n }\n\n override onAdd(): void {\n // throw new Error('Method not implemented.')\n }\n override onRemove(): void {\n // throw new Error('Method not implemented.')\n }\n\n get tooltips(): Tooltip[] {\n return this.ships.flatMap((ship) => ship.tooltip ?? [])\n }\n\n private registerPlugins(plugins: BaseShipConstructor[] = []): void {\n plugins.forEach((PluginClass) => {\n if (PluginClass.NAME) {\n this.pluginRegistry.set(PluginClass.NAME, PluginClass)\n } else {\n console.warn('Ship Plugin missing static NAME property:', PluginClass)\n }\n })\n }\n\n private createCollisions(): CollisionItemOptions[] {\n return this.tooltips.map((tooltip) => {\n return {\n ...tooltip.getAllBbox(),\n id: tooltip.id,\n }\n })\n }\n\n private collisionTooltip(): void {\n this.collision.load(this.createCollisions()).forEach((collision) => {\n const tooltip = this.tooltips.find((tooltip) => tooltip.id === collision.id)\n if (!tooltip) return\n\n if (collision.visible) {\n tooltip.setAnchor(collision.dir)\n } else {\n tooltip.hide()\n }\n })\n }\n\n add(data: IBaseShipOptions): BaseShip<any> | undefined {\n const Constructor = this.pluginRegistry.get(data.type)\n\n if (!Constructor) {\n console.warn(`No plugin registered for ship type: \"${data.type}\"`)\n return undefined\n }\n\n const ship = new Constructor(this.context.map, data)\n this.ships.push(ship)\n this.event.add(ship)\n\n return ship\n }\n\n load(list: IBaseShipOptions[]): BaseShip<any>[] {\n this.removeAll()\n\n const newShips: BaseShip<any>[] = []\n list.forEach((item) => {\n const ship = this.add(item)\n if (ship) {\n newShips.push(ship)\n }\n })\n\n this.render()\n this.collisionTooltip()\n\n return newShips\n }\n\n remove(id: IBaseShipOptions['id']): void {\n this.event.remove(id)\n\n const i = this.ships.findIndex((ship) => ship.id === id)\n if (i !== -1) {\n this.ships[i].remove()\n this.ships.splice(i, 1)\n }\n }\n\n removeAll(): void {\n this.collision.clear()\n\n this.ships.forEach((ship) => {\n ship.remove()\n })\n this.ships = []\n\n this.event.removeAll()\n }\n\n render(): void {\n this.ships.forEach((ship) => {\n ship.render()\n })\n }\n\n get(id: string | number): BaseShip<any> | undefined {\n return this.ships.find((item) => item.id === id)\n }\n\n select(id: IBaseShipOptions['id']): void {\n const ship = this.get(id)\n if (ship) {\n ship.select()\n }\n }\n\n unselect(id: IBaseShipOptions['id']): void {\n const ship = this.get(id)\n if (ship) {\n ship.unselect()\n }\n }\n}\n\nexport default Ship\n","import type * as GeoJSON from 'geojson'\nimport type { Map, MapMouseEvent, Point } from 'mapbox-gl'\n\nimport { Module } from '@/core/Module'\nimport type { Tooltip } from '@/core/Tooltip'\nimport type { UPDATE_STATUS } from '@/modules/Ship/vars.ts'\nimport type { IAisShipOptions } from '@/types/Ship/AisShip.ts'\nimport type { IBaseShipOptions, Orientation, Shape } from '@/types/Ship/BaseShip.ts'\n\nexport abstract class BaseShip<T extends IBaseShipOptions> extends Module {\n public options: T\n readonly SOURCE: string = 'mapbox-gl-ship-source'\n static NAME = 'Base'\n // readonly NAME: string = 'Base'\n\n public tooltip: Tooltip | null = null\n\n visible = true\n\n protected constructor(map: Map, options: T) {\n super(map)\n\n this.options = options\n }\n\n override destroy(): void {\n throw new Error('Method not implemented.')\n }\n get isFocus(): boolean {\n const state = this.getState()\n if (state) {\n return !!state.focus\n } else {\n return false\n }\n }\n\n public abstract override onAdd(): void\n\n public abstract override onRemove(): void\n\n abstract get id(): IBaseShipOptions['id']\n\n abstract get updateStatus(): UPDATE_STATUS\n\n abstract getIconName(): string\n\n abstract position(): IBaseShipOptions['position']\n\n abstract get direction(): IBaseShipOptions['direction']\n\n abstract get orientation(): Orientation\n\n abstract getShape(): Shape | null\n\n abstract getFeature(): GeoJSON.Feature<GeoJSON.Polygon, T> | GeoJSON.Feature<GeoJSON.Point, T>\n\n abstract remove(): void\n\n abstract setTooltip(tooltip: Tooltip): void\n\n abstract update(options: IAisShipOptions): void\n\n abstract select(): void\n\n abstract unselect(): void\n\n abstract focus(): void\n\n abstract unfocus(): void\n\n abstract icon(): GeoJSON.Feature<GeoJSON.Point, T>\n\n abstract real(): GeoJSON.Feature<GeoJSON.Polygon, T> | GeoJSON.Feature<GeoJSON.Point, T>\n\n abstract render(): void\n\n abstract label(): HTMLElement\n\n abstract offset(): Point\n\n public setState(states: Record<string, unknown>): void {\n this.context.map.setFeatureState(\n {\n source: this.SOURCE,\n id: this.id,\n },\n states,\n )\n }\n\n public getState(): Record<string, unknown> | null | undefined {\n return this.context.map.getFeatureState({\n source: this.SOURCE,\n id: this.id,\n })\n }\n\n public isSelf(e: MapMouseEvent): boolean {\n if (e.features && e.features.length > 0) {\n const data = e.features[0]\n return String(data.id) === this.id\n } else {\n return false\n }\n }\n\n public getName(): string {\n return BaseShip.NAME\n }\n}\n","!function(t,e){\"object\"==typeof exports&&\"undefined\"!=typeof module?module.exports=e():\"function\"==typeof define&&define.amd?define(e):(t=\"undefined\"!=typeof globalThis?globalThis:t||self).dayjs=e()}(this,(function(){\"use strict\";var t=1e3,e=6e4,n=36e5,r=\"millisecond\",i=\"second\",s=\"minute\",u=\"hour\",a=\"day\",o=\"week\",c=\"month\",f=\"quarter\",h=\"year\",d=\"date\",l=\"Invalid Date\",$=/^(\\d{4})[-/]?(\\d{1,2})?[-/]?(\\d{0,2})[Tt\\s]*(\\d{1,2})?:?(\\d{1,2})?:?(\\d{1,2})?[.:]?(\\d+)?$/,y=/\\[([^\\]]+)]|Y{1,4}|M{1,4}|D{1,2}|d{1,4}|H{1,2}|h{1,2}|a|A|m{1,2}|s{1,2}|Z{1,2}|SSS/g,M={name:\"en\",weekdays:\"Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday\".split(\"_\"),months:\"January_February_March_April_May_June_July_August_September_October_November_December\".split(\"_\"),ordinal:function(t){var e=[\"th\",\"st\",\"nd\",\"rd\"],n=t%100;return\"[\"+t+(e[(n-20)%10]||e[n]||e[0])+\"]\"}},m=function(t,e,n){var r=String(t);return!r||r.length>=e?t:\"\"+Array(e+1-r.length).join(n)+t},v={s:m,z:function(t){var e=-t.utcOffset(),n=Math.abs(e),r=Math.floor(n/60),i=n%60;return(e<=0?\"+\":\"-\")+m(r,2,\"0\")+\":\"+m(i,2,\"0\")},m:function t(e,n){if(e.date()<n.date())return-t(n,e);var r=12*(n.year()-e.year())+(n.month()-e.month()),i=e.clone().add(r,c),s=n-i<0,u=e.clone().add(r+(s?-1:1),c);return+(-(r+(n-i)/(s?i-u:u-i))||0)},a:function(t){return t<0?Math.ceil(t)||0:Math.floor(t)},p:function(t){return{M:c,y:h,w:o,d:a,D:d,h:u,m:s,s:i,ms:r,Q:f}[t]||String(t||\"\").toLowerCase().replace(/s$/,\"\")},u:function(t){return void 0===t}},g=\"en\",D={};D[g]=M;var p=\"$isDayjsObject\",S=function(t){return t instanceof _||!(!t||!t[p])},w=function t(e,n,r){var i;if(!e)return g;if(\"string\"==typeof e){var s=e.toLowerCase();D[s]&&(i=s),n&&(D[s]=n,i=s);var u=e.split(\"-\");if(!i&&u.length>1)return t(u[0])}else{var a=e.name;D[a]=e,i=a}return!r&&i&&(g=i),i||!r&&g},O=function(t,e){if(S(t))return t.clone();var n=\"object\"==typeof e?e:{};return n.date=t,n.args=arguments,new _(n)},b=v;b.l=w,b.i=S,b.w=function(t,e){return O(t,{locale:e.$L,utc:e.$u,x:e.$x,$offset:e.$offset})};var _=function(){function M(t){this.$L=w(t.locale,null,!0),this.parse(t),this.$x=this.$x||t.x||{},this[p]=!0}var m=M.prototype;return m.parse=function(t){this.$d=function(t){var e=t.date,n=t.utc;if(null===e)return new Date(NaN);if(b.u(e))return new Date;if(e instanceof Date)return new Date(e);if(\"string\"==typeof e&&!/Z$/i.test(e)){var r=e.match($);if(r){var i=r[2]-1||0,s=(r[7]||\"0\").substring(0,3);return n?new Date(Date.UTC(r[1],i,r[3]||1,r[4]||0,r[5]||0,r[6]||0,s)):new Date(r[1],i,r[3]||1,r[4]||0,r[5]||0,r[6]||0,s)}}return new Date(e)}(t),this.init()},m.init=function(){var t=this.$d;this.$y=t.getFullYear(),this.$M=t.getMonth(),this.$D=t.getDate(),this.$W=t.getDay(),this.$H=t.getHours(),this.$m=t.getMinutes(),this.$s=t.getSeconds(),this.$ms=t.getMilliseconds()},m.$utils=function(){return b},m.isValid=function(){return!(this.$d.toString()===l)},m.isSame=function(t,e){var n=O(t);return this.startOf(e)<=n&&n<=this.endOf(e)},m.isAfter=function(t,e){return O(t)<this.startOf(e)},m.isBefore=function(t,e){return this.endOf(e)<O(t)},m.$g=function(t,e,n){return b.u(t)?this[e]:this.set(n,t)},m.unix=function(){return Math.floor(this.valueOf()/1e3)},m.valueOf=function(){return this.$d.getTime()},m.startOf=function(t,e){var n=this,r=!!b.u(e)||e,f=b.p(t),l=function(t,e){var i=b.w(n.$u?Date.UTC(n.$y,e,t):new Date(n.$y,e,t),n);return r?i:i.endOf(a)},$=function(t,e){return b.w(n.toDate()[t].apply(n.toDate(\"s\"),(r?[0,0,0,0]:[23,59,59,999]).slice(e)),n)},y=this.$W,M=this.$M,m=this.$D,v=\"set\"+(this.$u?\"UTC\":\"\");switch(f){case h:return r?l(1,0):l(31,11);case c:return r?l(1,M):l(0,M+1);case o:var g=this.$locale().weekStart||0,D=(y<g?y+7:y)-g;return l(r?m-D:m+(6-D),M);case a:case d:return $(v+\"Hours\",0);case u:return $(v+\"Minutes\",1);case s:return $(v+\"Seconds\",2);case i:return $(v+\"Milliseconds\",3);default:return this.clone()}},m.endOf=function(t){return this.startOf(t,!1)},m.$set=function(t,e){var n,o=b.p(t),f=\"set\"+(this.$u?\"UTC\":\"\"),l=(n={},n[a]=f+\"Date\",n[d]=f+\"Date\",n[c]=f+\"Month\",n[h]=f+\"FullYear\",n[u]=f+\"Hours\",n[s]=f+\"Minutes\",n[i]=f+\"Seconds\",n[r]=f+\"Milliseconds\",n)[o],$=o===a?this.$D+(e-this.$W):e;if(o===c||o===h){var y=this.clone().set(d,1);y.$d[l]($),y.init(),this.$d=y.set(d,Math.min(this.$D,y.daysInMonth())).$d}else l&&this.$d[l]($);return this.init(),this},m.set=function(t,e){return this.clone().$set(t,e)},m.get=function(t){return this[b.p(t)]()},m.add=function(r,f){var d,l=this;r=Number(r);var $=b.p(f),y=function(t){var e=O(l);return b.w(e.date(e.date()+Math.round(t*r)),l)};if($===c)return this.set(c,this.$M+r);if($===h)return this.set(h,this.$y+r);if($===a)return y(1);if($===o)return y(7);var M=(d={},d[s]=e,d[u]=n,d[i]=t,d)[$]||1,m=this.$d.getTime()+r*M;return b.w(m,this)},m.subtract=function(t,e){return this.add(-1*t,e)},m.format=function(t){var e=this,n=this.$locale();if(!this.isValid())return n.invalidDate||l;var r=t||\"YYYY-MM-DDTHH:mm:ssZ\",i=b.z(this),s=this.$H,u=this.$m,a=this.$M,o=n.weekdays,c=n.months,f=n.meridiem,h=function(t,n,i,s){return t&&(t[n]||t(e,r))||i[n].slice(0,s)},d=function(t){return b.s(s%12||12,t,\"0\")},$=f||function(t,e,n){var r=t<12?\"AM\":\"PM\";return n?r.toLowerCase():r};return r.replace(y,(function(t,r){return r||function(t){switch(t){case\"YY\":return String(e.$y).slice(-2);case\"YYYY\":return b.s(e.$y,4,\"0\");case\"M\":return a+1;case\"MM\":return b.s(a+1,2,\"0\");case\"MMM\":return h(n.monthsShort,a,c,3);case\"MMMM\":return h(c,a);case\"D\":return e.$D;case\"DD\":return b.s(e.$D,2,\"0\");case\"d\":return String(e.$W);case\"dd\":return h(n.weekdaysMin,e.$W,o,2);case\"ddd\":return h(n.weekdaysShort,e.$W,o,3);case\"dddd\":return o[e.$W];case\"H\":return String(s);case\"HH\":return b.s(s,2,\"0\");case\"h\":return d(1);case\"hh\":return d(2);case\"a\":return $(s,u,!0);case\"A\":return $(s,u,!1);case\"m\":return String(u);case\"mm\":return b.s(u,2,\"0\");case\"s\":return String(e.$s);case\"ss\":return b.s(e.$s,2,\"0\");case\"SSS\":return b.s(e.$ms,3,\"0\");case\"Z\":return i}return null}(t)||i.replace(\":\",\"\")}))},m.utcOffset=function(){return 15*-Math.round(this.$d.getTimezoneOffset()/15)},m.diff=function(r,d,l){var $,y=this,M=b.p(d),m=O(r),v=(m.utcOffset()-this.utcOffset())*e,g=this-m,D=function(){return b.m(y,m)};switch(M){case h:$=D()/12;break;case c:$=D();break;case f:$=D()/3;break;case o:$=(g-v)/6048e5;break;case a:$=(g-v)/864e5;break;case u:$=g/n;break;case s:$=g/e;break;case i:$=g/t;break;default:$=g}return l?$:b.a($)},m.daysInMonth=function(){return this.endOf(c).$D},m.$locale=function(){return D[this.$L]},m.locale=function(t,e){if(!t)return this.$L;var n=this.clone(),r=w(t,e,!0);return r&&(n.$L=r),n},m.clone=function(){return b.w(this.$d,this)},m.toDate=function(){return new Date(this.valueOf())},m.toJSON=function(){return this.isValid()?this.toISOString():null},m.toISOString=function(){return this.$d.toISOString()},m.toString=function(){return this.$d.toUTCString()},M}(),k=_.prototype;return O.prototype=k,[[\"$ms\",r],[\"$s\",i],[\"$m\",s],[\"$H\",u],[\"$W\",a],[\"$M\",c],[\"$y\",h],[\"$D\",d]].forEach((function(t){k[t[1]]=function(e){return this.$g(e,t[0],t[1])}})),O.extend=function(t,e){return t.$i||(t(e,_,O),t.$i=!0),O},O.locale=w,O.isDayjs=S,O.unix=function(t){return O(1e3*t)},O.en=D[g],O.Ls=D,O.p={},O}));","import { lineString, lineToPolygon, point, transformRotate } from '@turf/turf'\nimport dayjs from 'dayjs'\nimport type * as GeoJSON from 'geojson'\nimport type { LngLat, Map } from 'mapbox-gl'\nimport { Point } from 'mapbox-gl'\n\nimport { Tooltip } from '@/core/Tooltip/index.ts'\nimport { BaseShip } from '@/modules/Ship/BaseShip.ts'\nimport { LAYER_LIST, NAME, SHIP_SOURCE_NAME, UPDATE_STATUS } from '@/modules/Ship/vars.ts'\nimport type { IAisShipOptions } from '@/types/Ship/AisShip.ts'\nimport type { Orientation, Shape } from '@/types/Ship/BaseShip'\nimport { distanceToPx } from '@/utils/util.ts'\n\nexport class AisShip extends BaseShip<IAisShipOptions> {\n override readonly SOURCE: string = SHIP_SOURCE_NAME\n static override NAME: string = NAME\n\n constructor(map: Map, options: IAisShipOptions) {\n super(map, options)\n\n if (this.options.tooltip) {\n this.setTooltip(\n new Tooltip(this.context.map, {\n id: this.id,\n position: this.position(),\n className: 'mapbox-gl-ship-name-tooltip',\n offsetX: 5,\n offsetY: 25,\n element: this.label(),\n anchor: 'bottom-right',\n visible: true,\n }),\n )\n\n this.render()\n }\n }\n\n public override onAdd(): void {\n this.context.register.addSource(SHIP_SOURCE_NAME, {\n type: 'geojson',\n dynamic: true,\n data: {\n type: 'FeatureCollection',\n features: [],\n },\n })\n\n LAYER_LIST.forEach((layer) => {\n this.context.register.addLayer(layer)\n })\n\n // SHIP_ICON.forEach((icon) => this.context.iconManage.addSvg(icon))\n // await this.context.iconManage.load(SHIP_ICON)\n }\n public override onRemove(): void {\n throw new Error('Method not implemented.')\n }\n\n override get id(): string | number {\n return this.options.id\n }\n\n override get updateStatus(): UPDATE_STATUS {\n const betweenTime = Date.now() - dayjs(Number(this.options.time)).valueOf()\n if (betweenTime <= 1800000) {\n return UPDATE_STATUS.ONLINE\n } else if (betweenTime > 1800000 && betweenTime <= 7200000) {\n return UPDATE_STATUS.DELAY\n } else if (betweenTime > 7200000) {\n return UPDATE_STATUS.OFFLINE\n } else {\n return UPDATE_STATUS.OFFLINE\n }\n }\n\n public override getIconName(): string {\n const state = this.getState()\n let icon = null\n\n if (this.options.icon) {\n icon = this.options.icon\n } else {\n icon = `${AisShip.NAME}-${this.updateStatus}-${this.orientation}`\n\n if (state?.hover || state?.focus) {\n icon = `${icon}-active`\n }\n }\n\n return icon\n }\n\n override position(): LngLat {\n const orientation: Point = this.context.map.project(this.options.position)\n const x = orientation.x + this.offset().x\n const y = orientation.y + this.offset().y\n return this.context.map.unproject(new Point(x, y))\n }\n override get direction(): number {\n if (this.options.hdg && this.options.hdg >= 0 && this.options.hdg < 360) {\n if (\n this.options.statusId === 0 ||\n this.options.statusId === 7 ||\n this.options.statusId === 8\n ) {\n if (this.options.speed <= 0.5) {\n return this.options.hdg || this.options.cog || 0\n } else {\n if (Math.abs(this.options.hdg - this.options.cog) > 30) {\n return this.options.cog\n }\n return this.options.cog || this.options.hdg || 0\n }\n } else {\n return this.options.hdg || this.options.cog || 0\n }\n } else {\n return this.options.cog || 0\n }\n }\n\n override get orientation(): Orientation {\n let _rateOfTurn = 0\n if (this.options.rot > 180) {\n _rateOfTurn = this.options.rot - 180\n }\n if (this.options.rot < -180) {\n _rateOfTurn = this.options.rot + 180\n }\n\n if (this.options.speed === 0 || !this.options.speed) return 'static'\n if (_rateOfTurn === -128.0) return 'static' //-128为特殊值,无转向\n if (_rateOfTurn < 0 && _rateOfTurn > -180) return 'left' //0到-180 左转,-127为每30秒5度以上右转\n if (_rateOfTurn > 0 && _rateOfTurn <= 180) return 'right' //0到 180 右转,127为每30秒5度以上左转\n if (_rateOfTurn === 0) return 'straight'\n\n return 'static'\n }\n\n override getShape(): Shape | null {\n if (this.options.width && this.options.height) {\n const { x, y }: Point = this.context.map.project(this.position())\n const ex: number = distanceToPx(this.context.map, this.options.width) / 2\n const ey: number = distanceToPx(this.context.map, this.options.height) / 2\n\n return {\n leftDirection: new Point(x - ex, y - ey * 2),\n rightDirection: new Point(x + ex, y - ey * 2),\n turn: new Point(x, y - ey * 2),\n head: new Point(x, y - ey),\n rightBow: new Point(x + ex, y - ey * 0.5),\n rightQuarter: new Point(x + ex, y + ey * 0.85),\n rightStern: new Point(x + ex * 0.7, y + ey),\n leftStern: new Point(x - ex * 0.7, y + ey),\n leftQuarter: new Point(x - ex, y + ey * 0.85),\n leftBow: new Point(x - ex, y - ey * 0.5),\n }\n } else {\n return null\n }\n }\n override getFeature():\n | GeoJSON.Feature<GeoJSON.Polygon, IAisShipOptions>\n | GeoJSON.Feature<GeoJSON.Point, IAisShipOptions> {\n const zoom = this.options.realZoom ?? 16\n\n return this.context.map.getZoom() >= zoom ? this.real() : this.icon()\n }\n override remove(): void {\n this.tooltip?.remove()\n\n const emptyFeature: GeoJSON.Feature<null> = {\n type: 'Feature',\n geometry: null,\n id: this.id,\n properties: {},\n }\n this.context.register.updateGeoJSONData(this.SOURCE, emptyFeature)\n }\n override setTooltip(tooltip: Tooltip): void {\n this.tooltip = tooltip\n }\n\n override update(options: IAisShipOptions): void {\n this.options = options\n this.render()\n }\n\n override select(): void {\n this.context.map.flyTo({\n center: this.position(),\n zoom: 16,\n })\n\n this.context.map.once('moveend', () => {\n this.focus()\n })\n }\n override unselect(): void {\n this.unfocus()\n }\n\n override focus(): void {\n this.setState({ focus: true })\n\n this.render()\n }\n override unfocus(): void {\n this.setState({ focus: false })\n\n this.render()\n }\n override icon(): GeoJSON.Feature<GeoJSON.Point, IAisShipOptions> {\n return point<IAisShipOptions>(\n this.position().toArray(),\n {\n ...this.options,\n icon: this.getIconName(),\n direction: this.direction,\n updateStatus: this.updateStatus,\n },\n {\n id: this.id,\n },\n )\n }\n override real():\n | GeoJSON.Feature<GeoJSON.Polygon, IAisShipOptions>\n | GeoJSON.Feature<GeoJSON.Point, IAisShipOptions> {\n const shape = this.getShape()\n\n if (!shape) {\n return this.icon()\n } else {\n const {\n head,\n rightBow,\n rightQuarter,\n rightStern,\n leftStern,\n leftQuarter,\n leftBow,\n leftDirection,\n rightDirection,\n turn,\n } = shape\n let points: Point[] = [\n head,\n rightBow,\n rightQuarter,\n rightStern,\n leftStern,\n leftQuarter,\n leftBow,\n head,\n ]\n\n if (this.orientation === 'left') {\n points = [leftDirection, turn, ...points, turn, leftDirection]\n } else if (this.orientation === 'right') {\n points = [rightDirection, turn, ...points, turn, rightDirection]\n } else if (this.orientation === 'straight') {\n points = [turn, ...points, turn]\n }\n\n const line: GeoJSON.Feature<GeoJSON.LineString, IAisShipOptions> =\n lineString<IAisShipOptions>(\n points.map((item) => this.context.map.unproject(item).toArray()),\n )\n\n let ship: GeoJSON.Feature<GeoJSON.Polygon, IAisShipOptions> = lineToPolygon(line, {\n properties: {\n ...this.options,\n updateStatus: this.updateStatus,\n outLine: true,\n },\n }) as GeoJSON.Feature<GeoJSON.Polygon, IAisShipOptions>\n\n ship = transformRotate<GeoJSON.Feature<GeoJSON.Polygon>>(ship, this.direction, {\n pivot: this.position().toArray(),\n }) as GeoJSON.Feature<GeoJSON.Polygon, IAisShipOptions>\n\n ship.id = this.id\n return ship\n }\n }\n\n override render(): void {\n this.tooltip?.setLngLat(this.position())\n this.tooltip?.render()\n\n this.context.register.updateGeoJSONData(this.SOURCE, this.getFeature())\n\n if (this.isFocus) {\n const icon = this.context.iconManage.getImage(this.getIconName())\n this.context.focus.set(this.getFeature(), {\n size: icon?.width,\n armLength: 10,\n padding: 10,\n })\n }\n }\n override label(): HTMLElement {\n const id = `${String(this.id)}-ship-name-box`\n let shipNameBox = document.getElementById(id)\n if (shipNameBox) {\n return shipNameBox\n }\n\n shipNameBox = document.createElement('div')\n shipNameBox.id = id\n shipNameBox.classList.add('ship-name-box')\n\n const shipName = document.createElement('div')\n shipName.innerText = this.options.name\n shipName.classList.add('ship-name')\n\n shipNameBox.appendChild(shipName)\n\n return shipNameBox\n }\n override offset(): Point {\n const offset = new Point(0, 0)\n\n if (this.options.top && this.options.bottom && this.options.left && this.options.right) {\n const ey = distanceToPx(\n this.context.map,\n Math.abs(this.options.top - this.options.bottom) / 2,\n )\n const ex = distanceToPx(\n this.context.map,\n Math.abs(this.options.left - this.options.right) / 2,\n )\n\n offset.x = this.options.right > this.options.left ? ex : -ex\n offset.y = this.options.top > this.options.bottom ? ey : -ey\n }\n\n return offset\n }\n}\n"],"names":["isNull","val","Cache","options","name","content","cacheName","obj","cacheString","cacheObj","list","i","str","quickselect","arr","k","left","right","compare","defaultCompare","n","m","z","s","sd","newLeft","newRight","t","j","swap","tmp","a","b","RBush","maxEntries","bbox","node","result","intersects","toBBox","nodesToSearch","child","childBBox","contains","data","tmpNode","item","createNode","equalsFn","path","indexes","parent","goingUp","index","findItem","items","height","N","M","calcBBox","N2","N1","multiSelect","right2","right3","level","minArea","minEnlargement","targetNode","area","bboxArea","enlargement","enlargedArea","isNode","insertPath","extend","splitIndex","newNode","minOverlap","bbox1","distBBox","bbox2","overlap","intersectionArea","compareMinX","compareNodeMinX","compareMinY","compareNodeMinY","xMargin","yMargin","leftBBox","rightBBox","margin","bboxMargin","siblings","p","destNode","minX","minY","maxX","maxY","children","stack","mid","Scopes","CollisionItem","visible","dir","box","Collision","map","config","collisions","id","isCollides","cacheKey","RESULT_CODE","earthRadius","factors","feature","geom","properties","feat","point","coordinates","isNumber","polygon","ring","lineString","multiLineString","multiPolygon","radiansToLength","radians","units","factor","lengthToRadians","distance","radiansToDegrees","degreesToRadians","degrees","convertLength","length","originalUnit","finalUnit","num","isObject","input","getCoord","coord","getCoords","coords","getGeom","geojson","rhumbBearing","start","end","bear360","calculateRhumbBearing","from","to","phi1","phi2","deltaLambda","deltaPsi","theta","coordEach","callback","excludeWrapCoord","l","geometry","stopG","geometryMaybeCollection","wrapShrink","coordIndex","isGeometryCollection","type","isFeatureCollection","isFeature","stop","featureIndex","geomIndex","multiFeatureIndex","geometryIndex","geomType","centroid","xSum","ySum","len","clone","cloneFeature","cloneFeatureCollection","cloneGeometry","cloned","key","cloneProperties","value","g","deepSlice","rhumbDistance","origin","destination","distanceInMeters","calculateRhumbDistance","radius","R","DeltaPhi","DeltaLambda","DeltaPsi","q","rhumbDestination","bearing","wasNegativeDistance","calculateRhumbDestination","delta","lambda1","transformRotate","angle","pivot","mutate","pivotCoord","pointCoords","finalAngle","newCoords","lineToPolygon","lines","_a","_b","_c","autoComplete","orderCoords","line","lineStringToPolygon","autoCompleteCoords","multiCoords","largestArea","calculateArea","turfBBox","first","x1","y1","last","x2","y2","west","south","east","north","distanceToPx","latitude","lat","zoom","latRad","metersPerPixel","convertSvgToImageObjects","svgString","width","svgImage","svgStr","resolve","reject","blob","url","img","event","outputWidth","outputHeight","canvas","ctx","bitmap","imageData","IconManager","icons","results","icon","success","error","err","image","has","prefix","Events","EE","fn","context","once","addListener","emitter","listener","evt","clearEvent","EventEmitter","names","events","handlers","ee","listeners","a1","a2","a3","a4","a5","args","module","freeGlobal","freeSelf","root","Symbol","objectProto","hasOwnProperty","nativeObjectToString","symToStringTag","getRawTag","isOwn","tag","unmasked","objectToString","nullTag","undefinedTag","baseGetTag","isObjectLike","symbolTag","isSymbol","arrayMap","array","iteratee","isArray","symbolProto","symbolToString","baseToString","asyncTag","funcTag","genTag","proxyTag","isFunction","coreJsData","maskSrcKey","uid","isMasked","func","funcProto","funcToString","toSource","reRegExpChar","reIsHostCtor","reIsNative","baseIsNative","pattern","getValue","object","getNative","defineProperty","MAX_SAFE_INTEGER","reIsUint","isIndex","baseAssignValue","eq","other","assignValue","objValue","reIsDeepProp","reIsPlainProp","isKey","nativeCreate","hashClear","hashDelete","HASH_UNDEFINED","hashGet","hashHas","hashSet","Hash","entries","entry","listCacheClear","assocIndexOf","arrayProto","splice","listCacheDelete","lastIndex","listCacheGet","listCacheHas","listCacheSet","ListCache","Map","mapCacheClear","isKeyable","getMapData","mapCacheDelete","mapCacheGet","mapCacheHas","mapCacheSet","size","MapCache","FUNC_ERROR_TEXT","memoize","resolver","memoized","cache","MAX_MEMOIZE_SIZE","memoizeCapped","rePropName","reEscapeChar","stringToPath","string","match","number","quote","subString","toString","castPath","toKey","baseSet","customizer","nested","newValue","set","byteToHex","unsafeStringify","offset","getRandomValues","rnds8","rng","native","v4","buf","rnds","ResourceRegister","source","layer","beforeId","FOCUS_SOURCE_NAME","FOCUS_LAYER","Focus","uuid","border","padding","armLength","rawBBox","finalBBox","finalArmLengthMeters","expandMeters","paddingMeters","baseLat","minLng","minLat","maxLng","maxLat","dLat","dLng","armLengthMeters","actualDLat","actualDLng","Context","registry","getOrCreateContext","existing","Module","e","CONNECT_LINE_LAYER_NAME","TOOLTIP_SOURCE_NAME","CONNECT_LINE_LAYER","Tooltip","anchor","offsetWidth","offsetHeight","Marker","Point","lngLat","endPoint","emptyFeature","lonLat","NAME","SHIP_SOURCE_NAME","SHIP_ICON_LAYER_NAME","SHIP_REAL_LAYER_NAME","SHIP_REAL_OUTLINE_LAYER_NAME","UPDATE_STATUS","SHIP_COLOR","LAYER_LIST","SHIP_ICON","MapType","landStyle","CMap","isCancel","load","cb","EventStatus","EventState","ResidentEvent","ships","ship","Ship","plugins","PluginClass","tooltip","collision","Constructor","newShips","BaseShip","state","states","this","u","o","c","f","h","d","$","y","r","v","D","S","_","w","O","AisShip","betweenTime","dayjs","orientation","x","_rateOfTurn","ex","ey","shape","head","rightBow","rightQuarter","rightStern","leftStern","leftQuarter","leftBow","leftDirection","rightDirection","turn","points","shipNameBox","shipName"],"mappings":"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","x_google_ignoreList":[2,3,9,10,11,12,13,14,15,16,17,18,19,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,99]}
1
+ {"version":3,"file":"index.umd.js","sources":["../src/utils/validate.ts","../src/core/Cache/index.ts","../node_modules/.pnpm/quickselect@3.0.0/node_modules/quickselect/index.js","../node_modules/.pnpm/rbush@4.0.1/node_modules/rbush/index.js","../src/types/Collision/item.ts","../src/core/Collision/CollisionItem.ts","../src/core/Collision/index.ts","../src/config/index.ts","../src/types/IconManager/index.ts","../node_modules/.pnpm/@turf+helpers@7.3.4/node_modules/@turf/helpers/dist/esm/index.js","../node_modules/.pnpm/@turf+invariant@7.3.4/node_modules/@turf/invariant/dist/esm/index.js","../node_modules/.pnpm/@turf+bearing@7.3.4/node_modules/@turf/bearing/dist/esm/index.js","../node_modules/.pnpm/@turf+destination@7.3.4/node_modules/@turf/destination/dist/esm/index.js","../node_modules/.pnpm/@turf+distance@7.3.4/node_modules/@turf/distance/dist/esm/index.js","../node_modules/.pnpm/@turf+along@7.3.4/node_modules/@turf/along/dist/esm/index.js","../node_modules/.pnpm/@turf+rhumb-bearing@7.3.4/node_modules/@turf/rhumb-bearing/dist/esm/index.js","../node_modules/.pnpm/@turf+meta@7.3.4/node_modules/@turf/meta/dist/esm/index.js","../node_modules/.pnpm/@turf+bbox@7.3.4/node_modules/@turf/bbox/dist/esm/index.js","../node_modules/.pnpm/@turf+bbox-polygon@7.3.4/node_modules/@turf/bbox-polygon/dist/esm/index.js","../node_modules/.pnpm/robust-predicates@3.0.2/node_modules/robust-predicates/esm/util.js","../node_modules/.pnpm/robust-predicates@3.0.2/node_modules/robust-predicates/esm/orient2d.js","../node_modules/.pnpm/point-in-polygon-hao@1.2.4/node_modules/point-in-polygon-hao/dist/esm/index.js","../node_modules/.pnpm/@turf+boolean-point-in-polygon@7.3.4/node_modules/@turf/boolean-point-in-polygon/dist/esm/index.js","../node_modules/.pnpm/@turf+centroid@7.3.4/node_modules/@turf/centroid/dist/esm/index.js","../node_modules/.pnpm/rbush@3.0.1/node_modules/rbush/rbush.min.js","../node_modules/.pnpm/tinyqueue@2.0.3/node_modules/tinyqueue/index.js","../node_modules/.pnpm/point-in-polygon@1.1.0/node_modules/point-in-polygon/flat.js","../node_modules/.pnpm/point-in-polygon@1.1.0/node_modules/point-in-polygon/nested.js","../node_modules/.pnpm/point-in-polygon@1.1.0/node_modules/point-in-polygon/index.js","../node_modules/.pnpm/robust-predicates@2.0.4/node_modules/robust-predicates/umd/orient2d.min.js","../node_modules/.pnpm/concaveman@1.2.1/node_modules/concaveman/index.js","../node_modules/.pnpm/@turf+convex@7.3.4/node_modules/@turf/convex/dist/esm/index.js","../node_modules/.pnpm/@turf+center-of-mass@7.3.4/node_modules/@turf/center-of-mass/dist/esm/index.js","../node_modules/.pnpm/@turf+clone@7.3.4/node_modules/@turf/clone/dist/esm/index.js","../node_modules/.pnpm/@turf+rhumb-distance@7.3.4/node_modules/@turf/rhumb-distance/dist/esm/index.js","../node_modules/.pnpm/@turf+rhumb-destination@7.3.4/node_modules/@turf/rhumb-destination/dist/esm/index.js","../node_modules/.pnpm/@turf+transform-rotate@7.3.4/node_modules/@turf/transform-rotate/dist/esm/index.js","../node_modules/.pnpm/@turf+length@7.3.4/node_modules/@turf/length/dist/esm/index.js","../node_modules/.pnpm/@turf+line-to-polygon@7.3.4/node_modules/@turf/line-to-polygon/dist/esm/index.js","../src/utils/util.ts","../src/core/IconManager/index.ts","../node_modules/.pnpm/eventemitter3@5.0.4/node_modules/eventemitter3/index.js","../src/core/EventManager/index.ts","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_freeGlobal.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_root.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_Symbol.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_getRawTag.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_objectToString.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_baseGetTag.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/isObjectLike.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/isSymbol.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_arrayMap.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/isArray.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_baseToString.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/isObject.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/isFunction.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_coreJsData.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_isMasked.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_toSource.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_baseIsNative.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_getValue.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_getNative.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_WeakMap.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_baseCreate.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_defineProperty.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_arrayEach.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_isIndex.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_baseAssignValue.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/eq.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_assignValue.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/isLength.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/isArrayLike.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_isPrototype.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_baseTimes.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_baseIsArguments.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/isArguments.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/stubFalse.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/isBuffer.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_baseIsTypedArray.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_baseUnary.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_nodeUtil.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/isTypedArray.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_arrayLikeKeys.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_overArg.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_nativeKeys.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_baseKeys.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/keys.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_isKey.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_nativeCreate.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_hashClear.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_hashDelete.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_hashGet.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_hashHas.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_hashSet.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_Hash.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_listCacheClear.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_assocIndexOf.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_listCacheDelete.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_listCacheGet.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_listCacheHas.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_listCacheSet.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_ListCache.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_Map.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_mapCacheClear.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_isKeyable.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_getMapData.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_mapCacheDelete.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_mapCacheGet.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_mapCacheHas.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_mapCacheSet.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_MapCache.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/memoize.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_memoizeCapped.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_stringToPath.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/toString.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_castPath.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_toKey.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_arrayPush.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_getPrototype.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_stackClear.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_stackDelete.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_stackGet.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_stackHas.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_stackSet.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_Stack.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_cloneBuffer.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_arrayFilter.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/stubArray.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_getSymbols.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_baseGetAllKeys.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_getAllKeys.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_DataView.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_Promise.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_Set.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_getTag.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_initCloneArray.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_Uint8Array.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_cloneArrayBuffer.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_cloneDataView.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_cloneRegExp.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_cloneSymbol.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_cloneTypedArray.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_initCloneByTag.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_initCloneObject.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_baseIsMap.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/isMap.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_baseIsSet.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/isSet.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_baseClone.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/cloneDeep.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/isEmpty.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/_baseSet.js","../node_modules/.pnpm/lodash-es@4.17.23/node_modules/lodash-es/set.js","../node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm-browser/stringify.js","../node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm-browser/rng.js","../node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm-browser/native.js","../node_modules/.pnpm/uuid@11.1.0/node_modules/uuid/dist/esm-browser/v4.js","../src/core/ResourceRegister/index.ts","../src/core/Focus/vars.ts","../src/core/Focus/index.ts","../src/core/Module/Context.ts","../src/core/Module/index.ts","../src/core/Tooltip/vars.ts","../src/core/Tooltip/index.ts","../src/modules/Ship/vars.ts","../src/types/CMap/index.ts","../src/modules/CMap/vars.ts","../src/modules/CMap/index.ts","../src/types/EventState/index.ts","../src/core/EventState/index.ts","../src/modules/Plot/vars.ts","../src/modules/Plot/plugins/Events/PointEvents.ts","../src/modules/Plot/plugins/Poi.ts","../src/types/Plot/Poi.ts","../src/modules/Plot/plugins/IndexPoint/vars.ts","../src/modules/Plot/plugins/Point/vars.ts","../src/modules/Plot/plugins/Point/index.ts","../src/modules/Plot/plugins/IconPoint/vars.ts","../src/modules/Plot/plugins/IconPoint/index.ts","../src/modules/Plot/plugins/Events/LineEvents.ts","../src/types/Plot/Line.ts","../src/modules/Plot/plugins/Line/vars.ts","../src/modules/Plot/plugins/Line/index.ts","../src/modules/Plot/plugins/ArrowLine/index.ts","../node_modules/.pnpm/tinyqueue@3.0.0/node_modules/tinyqueue/index.js","../node_modules/.pnpm/polylabel@2.0.1/node_modules/polylabel/polylabel.js","../src/modules/Plot/plugins/Events/FillEvents.ts","../src/modules/Plot/plugins/Fill/vars.ts","../src/modules/Plot/plugins/Fill/index.ts","../src/modules/Plot/plugins/IndexPoint/index.ts","../src/modules/Plot/plugins/IndexLine/index.ts","../src/modules/Ship/Events/ResidentEvent.ts","../src/modules/Ship/index.ts","../src/modules/Ship/BaseShip.ts","../node_modules/.pnpm/dayjs@1.11.19/node_modules/dayjs/dayjs.min.js","../src/modules/Ship/plugins/AisShip.ts","../src/types/Track/index.ts","../src/modules/Track/vars.ts","../src/modules/Track/index.ts"],"sourcesContent":["/**\n * 判断是否为空\n */\nexport function isNull(val: any): boolean {\n if (['boolean', 'number'].includes(typeof val)) {\n return false;\n } else if (val instanceof Array) {\n return val.length === 0;\n } else if (val instanceof Object) {\n return JSON.stringify(val) === '{}';\n } else {\n return ['null', null, undefined, 'undefined', ''].includes(val);\n }\n}\n","import type { CacheItem, CacheOptions, CacheType } from '@/types/Cache'\nimport { isNull } from '@/utils/validate.ts'\n\nclass Cache {\n _options: CacheOptions\n cacheKey: string\n cacheType: CacheType\n\n constructor(options: CacheOptions) {\n this._options = options\n this.cacheKey = options.uniqueKey + '-'\n this.cacheType = options.type\n }\n\n set({ name, content }: { name: string; content: unknown }): void {\n const cacheName = `${this.cacheKey}${name}`\n if (typeof content === 'function') {\n content = content.toString()\n }\n const obj: CacheItem = {\n dataType: typeof content,\n content: content,\n type: this.cacheType,\n datetime: new Date().getTime(),\n }\n if (this.cacheType === 'sessionstorage') {\n window.sessionStorage.setItem(cacheName, JSON.stringify(obj))\n } else {\n window.localStorage.setItem(cacheName, JSON.stringify(obj))\n }\n }\n\n get(name: string) {\n const cacheName = `${this.cacheKey}${name}`\n let cacheString: string | null = ''\n if (this.cacheType === 'sessionstorage') {\n cacheString = window.sessionStorage.getItem(cacheName)\n } else {\n cacheString = window.localStorage.getItem(cacheName)\n }\n if (isNull(cacheString)) {\n console.warn(`未找到缓存,${name}不存在!`)\n return\n }\n\n try {\n const cacheObj = JSON.parse(cacheString!) as CacheItem\n\n const basicTypes = ['string', 'number', 'boolean', 'object']\n if (basicTypes.includes(cacheObj.dataType)) {\n return cacheObj.content\n } else if (cacheObj.dataType === 'function') {\n return this.stringParseToFunction(cacheObj.content)\n }\n return cacheObj.content\n } catch (e) {\n return cacheString\n }\n }\n\n remove(name: string) {\n const cacheName = `${this.cacheKey}${name}`\n if (this.cacheType === 'sessionstorage') {\n window.sessionStorage.removeItem(cacheName)\n } else {\n window.localStorage.removeItem(cacheName)\n }\n }\n\n removeAll() {\n const list = []\n if (this.cacheType === 'sessionstorage') {\n for (let i = 0; i <= window.sessionStorage.length; i++) {\n list.push({\n name: window.sessionStorage.key(i),\n content: this.get(window.sessionStorage.key(i)!),\n })\n }\n } else {\n for (let i = 0; i <= window.localStorage.length; i++) {\n list.push({\n name: window.localStorage.key(i),\n content: this.get(window.localStorage.key(i)!),\n })\n }\n }\n return list\n }\n\n /**\n * 把字符串化的函数还原为可执行函数\n * 请确保传入的字符串可信任\n */\n stringParseToFunction(str: any) {\n return new Function('\"use strict\"; return (' + str + ')')()\n }\n}\n\nexport default Cache\n","\n/**\n * Rearranges items so that all items in the [left, k] are the smallest.\n * The k-th element will have the (k - left + 1)-th smallest value in [left, right].\n *\n * @template T\n * @param {T[]} arr the array to partially sort (in place)\n * @param {number} k middle index for partial sorting (as defined above)\n * @param {number} [left=0] left index of the range to sort\n * @param {number} [right=arr.length-1] right index\n * @param {(a: T, b: T) => number} [compare = (a, b) => a - b] compare function\n */\nexport default function quickselect(arr, k, left = 0, right = arr.length - 1, compare = defaultCompare) {\n\n while (right > left) {\n if (right - left > 600) {\n const n = right - left + 1;\n const m = k - left + 1;\n const z = Math.log(n);\n const s = 0.5 * Math.exp(2 * z / 3);\n const sd = 0.5 * Math.sqrt(z * s * (n - s) / n) * (m - n / 2 < 0 ? -1 : 1);\n const newLeft = Math.max(left, Math.floor(k - m * s / n + sd));\n const newRight = Math.min(right, Math.floor(k + (n - m) * s / n + sd));\n quickselect(arr, k, newLeft, newRight, compare);\n }\n\n const t = arr[k];\n let i = left;\n /** @type {number} */\n let j = right;\n\n swap(arr, left, k);\n if (compare(arr[right], t) > 0) swap(arr, left, right);\n\n while (i < j) {\n swap(arr, i, j);\n i++;\n j--;\n while (compare(arr[i], t) < 0) i++;\n while (compare(arr[j], t) > 0) j--;\n }\n\n if (compare(arr[left], t) === 0) swap(arr, left, j);\n else {\n j++;\n swap(arr, j, right);\n }\n\n if (j <= k) left = j + 1;\n if (k <= j) right = j - 1;\n }\n}\n\n/**\n * @template T\n * @param {T[]} arr\n * @param {number} i\n * @param {number} j\n */\nfunction swap(arr, i, j) {\n const tmp = arr[i];\n arr[i] = arr[j];\n arr[j] = tmp;\n}\n\n/**\n * @template T\n * @param {T} a\n * @param {T} b\n * @returns {number}\n */\nfunction defaultCompare(a, b) {\n return a < b ? -1 : a > b ? 1 : 0;\n}\n","import quickselect from 'quickselect';\n\nexport default class RBush {\n constructor(maxEntries = 9) {\n // max entries in a node is 9 by default; min node fill is 40% for best performance\n this._maxEntries = Math.max(4, maxEntries);\n this._minEntries = Math.max(2, Math.ceil(this._maxEntries * 0.4));\n this.clear();\n }\n\n all() {\n return this._all(this.data, []);\n }\n\n search(bbox) {\n let node = this.data;\n const result = [];\n\n if (!intersects(bbox, node)) return result;\n\n const toBBox = this.toBBox;\n const nodesToSearch = [];\n\n while (node) {\n for (let i = 0; i < node.children.length; i++) {\n const child = node.children[i];\n const childBBox = node.leaf ? toBBox(child) : child;\n\n if (intersects(bbox, childBBox)) {\n if (node.leaf) result.push(child);\n else if (contains(bbox, childBBox)) this._all(child, result);\n else nodesToSearch.push(child);\n }\n }\n node = nodesToSearch.pop();\n }\n\n return result;\n }\n\n collides(bbox) {\n let node = this.data;\n\n if (!intersects(bbox, node)) return false;\n\n const nodesToSearch = [];\n while (node) {\n for (let i = 0; i < node.children.length; i++) {\n const child = node.children[i];\n const childBBox = node.leaf ? this.toBBox(child) : child;\n\n if (intersects(bbox, childBBox)) {\n if (node.leaf || contains(bbox, childBBox)) return true;\n nodesToSearch.push(child);\n }\n }\n node = nodesToSearch.pop();\n }\n\n return false;\n }\n\n load(data) {\n if (!(data && data.length)) return this;\n\n if (data.length < this._minEntries) {\n for (let i = 0; i < data.length; i++) {\n this.insert(data[i]);\n }\n return this;\n }\n\n // recursively build the tree with the given data from scratch using OMT algorithm\n let node = this._build(data.slice(), 0, data.length - 1, 0);\n\n if (!this.data.children.length) {\n // save as is if tree is empty\n this.data = node;\n\n } else if (this.data.height === node.height) {\n // split root if trees have the same height\n this._splitRoot(this.data, node);\n\n } else {\n if (this.data.height < node.height) {\n // swap trees if inserted one is bigger\n const tmpNode = this.data;\n this.data = node;\n node = tmpNode;\n }\n\n // insert the small tree into the large tree at appropriate level\n this._insert(node, this.data.height - node.height - 1, true);\n }\n\n return this;\n }\n\n insert(item) {\n if (item) this._insert(item, this.data.height - 1);\n return this;\n }\n\n clear() {\n this.data = createNode([]);\n return this;\n }\n\n remove(item, equalsFn) {\n if (!item) return this;\n\n let node = this.data;\n const bbox = this.toBBox(item);\n const path = [];\n const indexes = [];\n let i, parent, goingUp;\n\n // depth-first iterative tree traversal\n while (node || path.length) {\n\n if (!node) { // go up\n node = path.pop();\n parent = path[path.length - 1];\n i = indexes.pop();\n goingUp = true;\n }\n\n if (node.leaf) { // check current node\n const index = findItem(item, node.children, equalsFn);\n\n if (index !== -1) {\n // item found, remove the item and condense tree upwards\n node.children.splice(index, 1);\n path.push(node);\n this._condense(path);\n return this;\n }\n }\n\n if (!goingUp && !node.leaf && contains(node, bbox)) { // go down\n path.push(node);\n indexes.push(i);\n i = 0;\n parent = node;\n node = node.children[0];\n\n } else if (parent) { // go right\n i++;\n node = parent.children[i];\n goingUp = false;\n\n } else node = null; // nothing found\n }\n\n return this;\n }\n\n toBBox(item) { return item; }\n\n compareMinX(a, b) { return a.minX - b.minX; }\n compareMinY(a, b) { return a.minY - b.minY; }\n\n toJSON() { return this.data; }\n\n fromJSON(data) {\n this.data = data;\n return this;\n }\n\n _all(node, result) {\n const nodesToSearch = [];\n while (node) {\n if (node.leaf) result.push(...node.children);\n else nodesToSearch.push(...node.children);\n\n node = nodesToSearch.pop();\n }\n return result;\n }\n\n _build(items, left, right, height) {\n\n const N = right - left + 1;\n let M = this._maxEntries;\n let node;\n\n if (N <= M) {\n // reached leaf level; return leaf\n node = createNode(items.slice(left, right + 1));\n calcBBox(node, this.toBBox);\n return node;\n }\n\n if (!height) {\n // target height of the bulk-loaded tree\n height = Math.ceil(Math.log(N) / Math.log(M));\n\n // target number of root entries to maximize storage utilization\n M = Math.ceil(N / Math.pow(M, height - 1));\n }\n\n node = createNode([]);\n node.leaf = false;\n node.height = height;\n\n // split the items into M mostly square tiles\n\n const N2 = Math.ceil(N / M);\n const N1 = N2 * Math.ceil(Math.sqrt(M));\n\n multiSelect(items, left, right, N1, this.compareMinX);\n\n for (let i = left; i <= right; i += N1) {\n\n const right2 = Math.min(i + N1 - 1, right);\n\n multiSelect(items, i, right2, N2, this.compareMinY);\n\n for (let j = i; j <= right2; j += N2) {\n\n const right3 = Math.min(j + N2 - 1, right2);\n\n // pack each entry recursively\n node.children.push(this._build(items, j, right3, height - 1));\n }\n }\n\n calcBBox(node, this.toBBox);\n\n return node;\n }\n\n _chooseSubtree(bbox, node, level, path) {\n while (true) {\n path.push(node);\n\n if (node.leaf || path.length - 1 === level) break;\n\n let minArea = Infinity;\n let minEnlargement = Infinity;\n let targetNode;\n\n for (let i = 0; i < node.children.length; i++) {\n const child = node.children[i];\n const area = bboxArea(child);\n const enlargement = enlargedArea(bbox, child) - area;\n\n // choose entry with the least area enlargement\n if (enlargement < minEnlargement) {\n minEnlargement = enlargement;\n minArea = area < minArea ? area : minArea;\n targetNode = child;\n\n } else if (enlargement === minEnlargement) {\n // otherwise choose one with the smallest area\n if (area < minArea) {\n minArea = area;\n targetNode = child;\n }\n }\n }\n\n node = targetNode || node.children[0];\n }\n\n return node;\n }\n\n _insert(item, level, isNode) {\n const bbox = isNode ? item : this.toBBox(item);\n const insertPath = [];\n\n // find the best node for accommodating the item, saving all nodes along the path too\n const node = this._chooseSubtree(bbox, this.data, level, insertPath);\n\n // put the item into the node\n node.children.push(item);\n extend(node, bbox);\n\n // split on node overflow; propagate upwards if necessary\n while (level >= 0) {\n if (insertPath[level].children.length > this._maxEntries) {\n this._split(insertPath, level);\n level--;\n } else break;\n }\n\n // adjust bboxes along the insertion path\n this._adjustParentBBoxes(bbox, insertPath, level);\n }\n\n // split overflowed node into two\n _split(insertPath, level) {\n const node = insertPath[level];\n const M = node.children.length;\n const m = this._minEntries;\n\n this._chooseSplitAxis(node, m, M);\n\n const splitIndex = this._chooseSplitIndex(node, m, M);\n\n const newNode = createNode(node.children.splice(splitIndex, node.children.length - splitIndex));\n newNode.height = node.height;\n newNode.leaf = node.leaf;\n\n calcBBox(node, this.toBBox);\n calcBBox(newNode, this.toBBox);\n\n if (level) insertPath[level - 1].children.push(newNode);\n else this._splitRoot(node, newNode);\n }\n\n _splitRoot(node, newNode) {\n // split root node\n this.data = createNode([node, newNode]);\n this.data.height = node.height + 1;\n this.data.leaf = false;\n calcBBox(this.data, this.toBBox);\n }\n\n _chooseSplitIndex(node, m, M) {\n let index;\n let minOverlap = Infinity;\n let minArea = Infinity;\n\n for (let i = m; i <= M - m; i++) {\n const bbox1 = distBBox(node, 0, i, this.toBBox);\n const bbox2 = distBBox(node, i, M, this.toBBox);\n\n const overlap = intersectionArea(bbox1, bbox2);\n const area = bboxArea(bbox1) + bboxArea(bbox2);\n\n // choose distribution with minimum overlap\n if (overlap < minOverlap) {\n minOverlap = overlap;\n index = i;\n\n minArea = area < minArea ? area : minArea;\n\n } else if (overlap === minOverlap) {\n // otherwise choose distribution with minimum area\n if (area < minArea) {\n minArea = area;\n index = i;\n }\n }\n }\n\n return index || M - m;\n }\n\n // sorts node children by the best axis for split\n _chooseSplitAxis(node, m, M) {\n const compareMinX = node.leaf ? this.compareMinX : compareNodeMinX;\n const compareMinY = node.leaf ? this.compareMinY : compareNodeMinY;\n const xMargin = this._allDistMargin(node, m, M, compareMinX);\n const yMargin = this._allDistMargin(node, m, M, compareMinY);\n\n // if total distributions margin value is minimal for x, sort by minX,\n // otherwise it's already sorted by minY\n if (xMargin < yMargin) node.children.sort(compareMinX);\n }\n\n // total margin of all possible split distributions where each node is at least m full\n _allDistMargin(node, m, M, compare) {\n node.children.sort(compare);\n\n const toBBox = this.toBBox;\n const leftBBox = distBBox(node, 0, m, toBBox);\n const rightBBox = distBBox(node, M - m, M, toBBox);\n let margin = bboxMargin(leftBBox) + bboxMargin(rightBBox);\n\n for (let i = m; i < M - m; i++) {\n const child = node.children[i];\n extend(leftBBox, node.leaf ? toBBox(child) : child);\n margin += bboxMargin(leftBBox);\n }\n\n for (let i = M - m - 1; i >= m; i--) {\n const child = node.children[i];\n extend(rightBBox, node.leaf ? toBBox(child) : child);\n margin += bboxMargin(rightBBox);\n }\n\n return margin;\n }\n\n _adjustParentBBoxes(bbox, path, level) {\n // adjust bboxes along the given tree path\n for (let i = level; i >= 0; i--) {\n extend(path[i], bbox);\n }\n }\n\n _condense(path) {\n // go through the path, removing empty nodes and updating bboxes\n for (let i = path.length - 1, siblings; i >= 0; i--) {\n if (path[i].children.length === 0) {\n if (i > 0) {\n siblings = path[i - 1].children;\n siblings.splice(siblings.indexOf(path[i]), 1);\n\n } else this.clear();\n\n } else calcBBox(path[i], this.toBBox);\n }\n }\n}\n\nfunction findItem(item, items, equalsFn) {\n if (!equalsFn) return items.indexOf(item);\n\n for (let i = 0; i < items.length; i++) {\n if (equalsFn(item, items[i])) return i;\n }\n return -1;\n}\n\n// calculate node's bbox from bboxes of its children\nfunction calcBBox(node, toBBox) {\n distBBox(node, 0, node.children.length, toBBox, node);\n}\n\n// min bounding rectangle of node children from k to p-1\nfunction distBBox(node, k, p, toBBox, destNode) {\n if (!destNode) destNode = createNode(null);\n destNode.minX = Infinity;\n destNode.minY = Infinity;\n destNode.maxX = -Infinity;\n destNode.maxY = -Infinity;\n\n for (let i = k; i < p; i++) {\n const child = node.children[i];\n extend(destNode, node.leaf ? toBBox(child) : child);\n }\n\n return destNode;\n}\n\nfunction extend(a, b) {\n a.minX = Math.min(a.minX, b.minX);\n a.minY = Math.min(a.minY, b.minY);\n a.maxX = Math.max(a.maxX, b.maxX);\n a.maxY = Math.max(a.maxY, b.maxY);\n return a;\n}\n\nfunction compareNodeMinX(a, b) { return a.minX - b.minX; }\nfunction compareNodeMinY(a, b) { return a.minY - b.minY; }\n\nfunction bboxArea(a) { return (a.maxX - a.minX) * (a.maxY - a.minY); }\nfunction bboxMargin(a) { return (a.maxX - a.minX) + (a.maxY - a.minY); }\n\nfunction enlargedArea(a, b) {\n return (Math.max(b.maxX, a.maxX) - Math.min(b.minX, a.minX)) *\n (Math.max(b.maxY, a.maxY) - Math.min(b.minY, a.minY));\n}\n\nfunction intersectionArea(a, b) {\n const minX = Math.max(a.minX, b.minX);\n const minY = Math.max(a.minY, b.minY);\n const maxX = Math.min(a.maxX, b.maxX);\n const maxY = Math.min(a.maxY, b.maxY);\n\n return Math.max(0, maxX - minX) *\n Math.max(0, maxY - minY);\n}\n\nfunction contains(a, b) {\n return a.minX <= b.minX &&\n a.minY <= b.minY &&\n b.maxX <= a.maxX &&\n b.maxY <= a.maxY;\n}\n\nfunction intersects(a, b) {\n return b.minX <= a.maxX &&\n b.minY <= a.maxY &&\n b.maxX >= a.minX &&\n b.maxY >= a.minY;\n}\n\nfunction createNode(children) {\n return {\n children,\n height: 1,\n leaf: true,\n minX: Infinity,\n minY: Infinity,\n maxX: -Infinity,\n maxY: -Infinity\n };\n}\n\n// sort an array so that items come in groups of n unsorted items, with groups sorted between each other;\n// combines selection algorithm with binary divide & conquer approach\n\nfunction multiSelect(arr, left, right, n, compare) {\n const stack = [left, right];\n\n while (stack.length) {\n right = stack.pop();\n left = stack.pop();\n\n if (right - left <= n) continue;\n\n const mid = left + Math.ceil((right - left) / n / 2) * n;\n quickselect(arr, mid, left, right, compare);\n\n stack.push(left, mid, mid, right);\n }\n}\n","import type { BBox } from 'rbush'\n\nexport type Id = string | number | undefined\n\n/**\n * 初始基准点的位置\n */\nexport enum Directions {\n TOP,\n RIGHT,\n BOTTOM,\n LEFT,\n TOP_LEFT,\n TOP_RIGHT,\n BOTTOM_RIGHT,\n BOTTOM_LEFT,\n CENTER,\n}\n\n/**\n * 范围值枚举\n */\nexport enum Scopes {\n MIN_X,\n MIN_Y,\n MAX_X,\n MAX_Y,\n}\n\n/**\n * bbox-范围 dir-初始基准点的位置 options-配置\n */\nexport interface CollisionItemOptions {\n id: string | number\n center: BBox\n top: BBox\n bottom: BBox\n left: BBox\n right: BBox\n 'top-left': BBox\n 'top-right': BBox\n 'bottom-left': BBox\n 'bottom-right': BBox\n}\n","import type { BBox } from 'rbush'\n\nimport type { CollisionItemOptions } from '@/types/Collision/item.ts'\nimport { Scopes } from '@/types/Collision/item.ts'\nimport type { Anchor } from '@/types/Toolip/index.ts'\n\nclass CollisionItem {\n // 最小X\n static MIN_X: Scopes = Scopes.MIN_X\n // 最小Y\n static MIN_Y: Scopes = Scopes.MIN_Y\n // 最大X\n static MAX_X: Scopes = Scopes.MAX_X\n // 最大Y\n static MAX_Y: Scopes = Scopes.MAX_Y\n\n id: CollisionItemOptions['id']\n\n visible = true\n\n dir: Anchor = 'top-left'\n\n dirs: Anchor[] = [\n 'top-left',\n 'top-right',\n 'bottom-left',\n 'bottom-right',\n // 'center',\n // 'top',\n // 'bottom',\n // 'left',\n // 'right',\n ]\n\n _options: CollisionItemOptions\n\n /**\n *\n * @param options\n */\n constructor(options: CollisionItemOptions) {\n this.id = options.id\n this._options = options\n }\n\n get minX(): number {\n return this._options[this.dir].minX\n }\n\n get minY(): number {\n return this._options[this.dir].minY\n }\n\n get maxX(): number {\n return this._options[this.dir].maxX\n }\n\n get maxY(): number {\n return this._options[this.dir].maxY\n }\n\n /**\n *\n */\n getBBox(): BBox {\n return this._options[this.dir]\n }\n\n /**\n * 设置是否显示\n * @param visible\n */\n setVisible(visible: boolean): void {\n this.visible = visible\n }\n\n setDir(dir: Anchor): void {\n this.dir = dir\n }\n\n /**\n * 判断item与box是否相交\n * @param box\n * @return true-相交 false-不相交\n */\n isIntersect(box: BBox): boolean {\n const { minX, minY, maxX, maxY } = box\n return minX <= this.minX && minY <= this.minY && this.maxX <= maxX && this.maxY <= maxY\n }\n}\n\nexport default CollisionItem\n","import type { Map } from 'mapbox-gl'\nimport RBush from 'rbush'\n\nimport type { CollisionOptions } from '@/types/Collision'\nimport type { CollisionItemOptions } from '@/types/Collision/item.ts'\n\nimport CollisionItem from './CollisionItem.ts'\n\nclass Collision {\n _tree = new RBush<CollisionItem>()\n\n _map: Map\n\n _collisionList: CollisionItem[] = []\n\n constructor(map: Map, config?: CollisionOptions) {\n this._map = map\n if (Array.isArray(config?.collisions) && config.collisions.length > 0) {\n this.load(config.collisions)\n }\n }\n\n load(collisions: CollisionItemOptions[]): CollisionItem[] {\n this._tree.clear()\n\n this._collisionList = collisions.map((item) => new CollisionItem(item))\n\n return this.collides()\n }\n\n getItem(id: string | number): CollisionItem | undefined {\n return this._collisionList.find((item) => item.id === id)\n }\n\n clear(): void {\n this._tree.clear()\n }\n\n getCollisions(): CollisionItem[] {\n return this._collisionList\n }\n\n collides(): CollisionItem[] {\n // const { width, height } = this._map.getCanvas()\n // const viewportBBox: BBox = {\n // minX: 0,\n // minY: 0,\n // maxX: width,\n // maxY: height,\n // }\n\n for (const item of this._collisionList) {\n for (const dir of item.dirs) {\n item.setDir(dir)\n\n const isCollides = this._tree.collides(item)\n item.setVisible(!isCollides)\n\n if (item.visible) {\n this._tree.insert(item)\n break\n }\n }\n }\n\n return this.getCollisions()\n }\n}\n\nexport default Collision\n","export const version = '0.0.1'\n\nexport const prefix = 'mapbox-gl'\n\nexport const cacheKey = `${prefix}-cache`\n\nexport default {\n version,\n prefix,\n cacheKey,\n}\n","export interface Icon {\n name: string\n url: string\n options?: Partial<StyleImageMetadata>\n}\n\nexport interface SvgIcon {\n name: string\n svg: string\n}\n\ninterface StyleImageMetadata {\n pixelRatio: number\n sdf: boolean\n usvg: boolean\n stretchX?: [number, number][]\n stretchY?: [number, number][]\n content?: [number, number, number, number]\n}\n\nexport interface Image {\n width: number\n height: number\n image: ImageBitmap | HTMLImageElement | ImageData\n}\n\nexport enum RESULT_CODE {\n SUCCESS = 0,\n FAIL = -1,\n}\nexport interface result {\n code: RESULT_CODE\n data: Icon | SvgIcon\n msg: string | Error\n}\n\nexport interface loadOptions {}\n","// index.ts\nvar earthRadius = 63710088e-1;\nvar factors = {\n centimeters: earthRadius * 100,\n centimetres: earthRadius * 100,\n degrees: 360 / (2 * Math.PI),\n feet: earthRadius * 3.28084,\n inches: earthRadius * 39.37,\n kilometers: earthRadius / 1e3,\n kilometres: earthRadius / 1e3,\n meters: earthRadius,\n metres: earthRadius,\n miles: earthRadius / 1609.344,\n millimeters: earthRadius * 1e3,\n millimetres: earthRadius * 1e3,\n nauticalmiles: earthRadius / 1852,\n radians: 1,\n yards: earthRadius * 1.0936\n};\nvar areaFactors = {\n acres: 247105e-9,\n centimeters: 1e4,\n centimetres: 1e4,\n feet: 10.763910417,\n hectares: 1e-4,\n inches: 1550.003100006,\n kilometers: 1e-6,\n kilometres: 1e-6,\n meters: 1,\n metres: 1,\n miles: 386e-9,\n nauticalmiles: 29155334959812285e-23,\n millimeters: 1e6,\n millimetres: 1e6,\n yards: 1.195990046\n};\nfunction feature(geom, properties, options = {}) {\n const feat = { type: \"Feature\" };\n if (options.id === 0 || options.id) {\n feat.id = options.id;\n }\n if (options.bbox) {\n feat.bbox = options.bbox;\n }\n feat.properties = properties || {};\n feat.geometry = geom;\n return feat;\n}\nfunction geometry(type, coordinates, _options = {}) {\n switch (type) {\n case \"Point\":\n return point(coordinates).geometry;\n case \"LineString\":\n return lineString(coordinates).geometry;\n case \"Polygon\":\n return polygon(coordinates).geometry;\n case \"MultiPoint\":\n return multiPoint(coordinates).geometry;\n case \"MultiLineString\":\n return multiLineString(coordinates).geometry;\n case \"MultiPolygon\":\n return multiPolygon(coordinates).geometry;\n default:\n throw new Error(type + \" is invalid\");\n }\n}\nfunction point(coordinates, properties, options = {}) {\n if (!coordinates) {\n throw new Error(\"coordinates is required\");\n }\n if (!Array.isArray(coordinates)) {\n throw new Error(\"coordinates must be an Array\");\n }\n if (coordinates.length < 2) {\n throw new Error(\"coordinates must be at least 2 numbers long\");\n }\n if (!isNumber(coordinates[0]) || !isNumber(coordinates[1])) {\n throw new Error(\"coordinates must contain numbers\");\n }\n const geom = {\n type: \"Point\",\n coordinates\n };\n return feature(geom, properties, options);\n}\nfunction points(coordinates, properties, options = {}) {\n return featureCollection(\n coordinates.map((coords) => {\n return point(coords, properties);\n }),\n options\n );\n}\nfunction polygon(coordinates, properties, options = {}) {\n for (const ring of coordinates) {\n if (ring.length < 4) {\n throw new Error(\n \"Each LinearRing of a Polygon must have 4 or more Positions.\"\n );\n }\n if (ring[ring.length - 1].length !== ring[0].length) {\n throw new Error(\"First and last Position are not equivalent.\");\n }\n for (let j = 0; j < ring[ring.length - 1].length; j++) {\n if (ring[ring.length - 1][j] !== ring[0][j]) {\n throw new Error(\"First and last Position are not equivalent.\");\n }\n }\n }\n const geom = {\n type: \"Polygon\",\n coordinates\n };\n return feature(geom, properties, options);\n}\nfunction polygons(coordinates, properties, options = {}) {\n return featureCollection(\n coordinates.map((coords) => {\n return polygon(coords, properties);\n }),\n options\n );\n}\nfunction lineString(coordinates, properties, options = {}) {\n if (coordinates.length < 2) {\n throw new Error(\"coordinates must be an array of two or more positions\");\n }\n const geom = {\n type: \"LineString\",\n coordinates\n };\n return feature(geom, properties, options);\n}\nfunction lineStrings(coordinates, properties, options = {}) {\n return featureCollection(\n coordinates.map((coords) => {\n return lineString(coords, properties);\n }),\n options\n );\n}\nfunction featureCollection(features, options = {}) {\n const fc = { type: \"FeatureCollection\" };\n if (options.id) {\n fc.id = options.id;\n }\n if (options.bbox) {\n fc.bbox = options.bbox;\n }\n fc.features = features;\n return fc;\n}\nfunction multiLineString(coordinates, properties, options = {}) {\n const geom = {\n type: \"MultiLineString\",\n coordinates\n };\n return feature(geom, properties, options);\n}\nfunction multiPoint(coordinates, properties, options = {}) {\n const geom = {\n type: \"MultiPoint\",\n coordinates\n };\n return feature(geom, properties, options);\n}\nfunction multiPolygon(coordinates, properties, options = {}) {\n const geom = {\n type: \"MultiPolygon\",\n coordinates\n };\n return feature(geom, properties, options);\n}\nfunction geometryCollection(geometries, properties, options = {}) {\n const geom = {\n type: \"GeometryCollection\",\n geometries\n };\n return feature(geom, properties, options);\n}\nfunction round(num, precision = 0) {\n if (precision && !(precision >= 0)) {\n throw new Error(\"precision must be a positive number\");\n }\n const multiplier = Math.pow(10, precision || 0);\n return Math.round(num * multiplier) / multiplier;\n}\nfunction radiansToLength(radians, units = \"kilometers\") {\n const factor = factors[units];\n if (!factor) {\n throw new Error(units + \" units is invalid\");\n }\n return radians * factor;\n}\nfunction lengthToRadians(distance, units = \"kilometers\") {\n const factor = factors[units];\n if (!factor) {\n throw new Error(units + \" units is invalid\");\n }\n return distance / factor;\n}\nfunction lengthToDegrees(distance, units) {\n return radiansToDegrees(lengthToRadians(distance, units));\n}\nfunction bearingToAzimuth(bearing) {\n let angle = bearing % 360;\n if (angle < 0) {\n angle += 360;\n }\n return angle;\n}\nfunction azimuthToBearing(angle) {\n angle = angle % 360;\n if (angle > 180) {\n return angle - 360;\n } else if (angle < -180) {\n return angle + 360;\n }\n return angle;\n}\nfunction radiansToDegrees(radians) {\n const normalisedRadians = radians % (2 * Math.PI);\n return normalisedRadians * 180 / Math.PI;\n}\nfunction degreesToRadians(degrees) {\n const normalisedDegrees = degrees % 360;\n return normalisedDegrees * Math.PI / 180;\n}\nfunction convertLength(length, originalUnit = \"kilometers\", finalUnit = \"kilometers\") {\n if (!(length >= 0)) {\n throw new Error(\"length must be a positive number\");\n }\n return radiansToLength(lengthToRadians(length, originalUnit), finalUnit);\n}\nfunction convertArea(area, originalUnit = \"meters\", finalUnit = \"kilometers\") {\n if (!(area >= 0)) {\n throw new Error(\"area must be a positive number\");\n }\n const startFactor = areaFactors[originalUnit];\n if (!startFactor) {\n throw new Error(\"invalid original units\");\n }\n const finalFactor = areaFactors[finalUnit];\n if (!finalFactor) {\n throw new Error(\"invalid final units\");\n }\n return area / startFactor * finalFactor;\n}\nfunction isNumber(num) {\n return !isNaN(num) && num !== null && !Array.isArray(num);\n}\nfunction isObject(input) {\n return input !== null && typeof input === \"object\" && !Array.isArray(input);\n}\nfunction validateBBox(bbox) {\n if (!bbox) {\n throw new Error(\"bbox is required\");\n }\n if (!Array.isArray(bbox)) {\n throw new Error(\"bbox must be an Array\");\n }\n if (bbox.length !== 4 && bbox.length !== 6) {\n throw new Error(\"bbox must be an Array of 4 or 6 numbers\");\n }\n bbox.forEach((num) => {\n if (!isNumber(num)) {\n throw new Error(\"bbox must only contain numbers\");\n }\n });\n}\nfunction validateId(id) {\n if (!id) {\n throw new Error(\"id is required\");\n }\n if ([\"string\", \"number\"].indexOf(typeof id) === -1) {\n throw new Error(\"id must be a number or a string\");\n }\n}\nexport {\n areaFactors,\n azimuthToBearing,\n bearingToAzimuth,\n convertArea,\n convertLength,\n degreesToRadians,\n earthRadius,\n factors,\n feature,\n featureCollection,\n geometry,\n geometryCollection,\n isNumber,\n isObject,\n lengthToDegrees,\n lengthToRadians,\n lineString,\n lineStrings,\n multiLineString,\n multiPoint,\n multiPolygon,\n point,\n points,\n polygon,\n polygons,\n radiansToDegrees,\n radiansToLength,\n round,\n validateBBox,\n validateId\n};\n//# sourceMappingURL=index.js.map","// index.ts\nimport { isNumber } from \"@turf/helpers\";\nfunction getCoord(coord) {\n if (!coord) {\n throw new Error(\"coord is required\");\n }\n if (!Array.isArray(coord)) {\n if (coord.type === \"Feature\" && coord.geometry !== null && coord.geometry.type === \"Point\") {\n return [...coord.geometry.coordinates];\n }\n if (coord.type === \"Point\") {\n return [...coord.coordinates];\n }\n }\n if (Array.isArray(coord) && coord.length >= 2 && !Array.isArray(coord[0]) && !Array.isArray(coord[1])) {\n return [...coord];\n }\n throw new Error(\"coord must be GeoJSON Point or an Array of numbers\");\n}\nfunction getCoords(coords) {\n if (Array.isArray(coords)) {\n return coords;\n }\n if (coords.type === \"Feature\") {\n if (coords.geometry !== null) {\n return coords.geometry.coordinates;\n }\n } else {\n if (coords.coordinates) {\n return coords.coordinates;\n }\n }\n throw new Error(\n \"coords must be GeoJSON Feature, Geometry Object or an Array\"\n );\n}\nfunction containsNumber(coordinates) {\n if (coordinates.length > 1 && isNumber(coordinates[0]) && isNumber(coordinates[1])) {\n return true;\n }\n if (Array.isArray(coordinates[0]) && coordinates[0].length) {\n return containsNumber(coordinates[0]);\n }\n throw new Error(\"coordinates must only contain numbers\");\n}\nfunction geojsonType(value, type, name) {\n if (!type || !name) {\n throw new Error(\"type and name required\");\n }\n if (!value || value.type !== type) {\n throw new Error(\n \"Invalid input to \" + name + \": must be a \" + type + \", given \" + value.type\n );\n }\n}\nfunction featureOf(feature, type, name) {\n if (!feature) {\n throw new Error(\"No feature passed\");\n }\n if (!name) {\n throw new Error(\".featureOf() requires a name\");\n }\n if (!feature || feature.type !== \"Feature\" || !feature.geometry) {\n throw new Error(\n \"Invalid input to \" + name + \", Feature with geometry required\"\n );\n }\n if (!feature.geometry || feature.geometry.type !== type) {\n throw new Error(\n \"Invalid input to \" + name + \": must be a \" + type + \", given \" + feature.geometry.type\n );\n }\n}\nfunction collectionOf(featureCollection, type, name) {\n if (!featureCollection) {\n throw new Error(\"No featureCollection passed\");\n }\n if (!name) {\n throw new Error(\".collectionOf() requires a name\");\n }\n if (!featureCollection || featureCollection.type !== \"FeatureCollection\") {\n throw new Error(\n \"Invalid input to \" + name + \", FeatureCollection required\"\n );\n }\n for (const feature of featureCollection.features) {\n if (!feature || feature.type !== \"Feature\" || !feature.geometry) {\n throw new Error(\n \"Invalid input to \" + name + \", Feature with geometry required\"\n );\n }\n if (!feature.geometry || feature.geometry.type !== type) {\n throw new Error(\n \"Invalid input to \" + name + \": must be a \" + type + \", given \" + feature.geometry.type\n );\n }\n }\n}\nfunction getGeom(geojson) {\n if (geojson.type === \"Feature\") {\n return geojson.geometry;\n }\n return geojson;\n}\nfunction getType(geojson, _name) {\n if (geojson.type === \"FeatureCollection\") {\n return \"FeatureCollection\";\n }\n if (geojson.type === \"GeometryCollection\") {\n return \"GeometryCollection\";\n }\n if (geojson.type === \"Feature\" && geojson.geometry !== null) {\n return geojson.geometry.type;\n }\n return geojson.type;\n}\nexport {\n collectionOf,\n containsNumber,\n featureOf,\n geojsonType,\n getCoord,\n getCoords,\n getGeom,\n getType\n};\n//# sourceMappingURL=index.js.map","// index.ts\nimport { degreesToRadians, radiansToDegrees } from \"@turf/helpers\";\nimport { getCoord } from \"@turf/invariant\";\nfunction bearing(start, end, options = {}) {\n if (options.final === true) {\n return calculateFinalBearing(start, end);\n }\n const coordinates1 = getCoord(start);\n const coordinates2 = getCoord(end);\n const lon1 = degreesToRadians(coordinates1[0]);\n const lon2 = degreesToRadians(coordinates2[0]);\n const lat1 = degreesToRadians(coordinates1[1]);\n const lat2 = degreesToRadians(coordinates2[1]);\n const a = Math.sin(lon2 - lon1) * Math.cos(lat2);\n const b = Math.cos(lat1) * Math.sin(lat2) - Math.sin(lat1) * Math.cos(lat2) * Math.cos(lon2 - lon1);\n return radiansToDegrees(Math.atan2(a, b));\n}\nfunction calculateFinalBearing(start, end) {\n let bear = bearing(end, start);\n bear = (bear + 180) % 360;\n return bear;\n}\nvar index_default = bearing;\nexport {\n bearing,\n index_default as default\n};\n//# sourceMappingURL=index.js.map","// index.ts\nimport {\n degreesToRadians,\n lengthToRadians,\n point,\n radiansToDegrees\n} from \"@turf/helpers\";\nimport { getCoord } from \"@turf/invariant\";\nfunction destination(origin, distance, bearing, options = {}) {\n const coordinates1 = getCoord(origin);\n const longitude1 = degreesToRadians(coordinates1[0]);\n const latitude1 = degreesToRadians(coordinates1[1]);\n const bearingRad = degreesToRadians(bearing);\n const radians = lengthToRadians(distance, options.units);\n const latitude2 = Math.asin(\n Math.sin(latitude1) * Math.cos(radians) + Math.cos(latitude1) * Math.sin(radians) * Math.cos(bearingRad)\n );\n const longitude2 = longitude1 + Math.atan2(\n Math.sin(bearingRad) * Math.sin(radians) * Math.cos(latitude1),\n Math.cos(radians) - Math.sin(latitude1) * Math.sin(latitude2)\n );\n const lng = radiansToDegrees(longitude2);\n const lat = radiansToDegrees(latitude2);\n if (coordinates1[2] !== void 0) {\n return point([lng, lat, coordinates1[2]], options.properties);\n }\n return point([lng, lat], options.properties);\n}\nvar index_default = destination;\nexport {\n index_default as default,\n destination\n};\n//# sourceMappingURL=index.js.map","// index.ts\nimport { getCoord } from \"@turf/invariant\";\nimport { radiansToLength, degreesToRadians } from \"@turf/helpers\";\nfunction distance(from, to, options = {}) {\n var coordinates1 = getCoord(from);\n var coordinates2 = getCoord(to);\n var dLat = degreesToRadians(coordinates2[1] - coordinates1[1]);\n var dLon = degreesToRadians(coordinates2[0] - coordinates1[0]);\n var lat1 = degreesToRadians(coordinates1[1]);\n var lat2 = degreesToRadians(coordinates2[1]);\n var a = Math.pow(Math.sin(dLat / 2), 2) + Math.pow(Math.sin(dLon / 2), 2) * Math.cos(lat1) * Math.cos(lat2);\n return radiansToLength(\n 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a)),\n options.units\n );\n}\nvar index_default = distance;\nexport {\n index_default as default,\n distance\n};\n//# sourceMappingURL=index.js.map","// index.ts\nimport { bearing } from \"@turf/bearing\";\nimport { destination } from \"@turf/destination\";\nimport { distance as measureDistance } from \"@turf/distance\";\nimport { point } from \"@turf/helpers\";\nimport { getGeom } from \"@turf/invariant\";\nfunction along(line, distance, options = {}) {\n const geom = getGeom(line);\n const coords = geom.coordinates;\n let travelled = 0;\n for (let i = 0; i < coords.length; i++) {\n if (distance >= travelled && i === coords.length - 1) {\n break;\n } else if (travelled >= distance) {\n const overshot = distance - travelled;\n if (!overshot) {\n return point(coords[i]);\n } else {\n const direction = bearing(coords[i], coords[i - 1]) - 180;\n const interpolated = destination(\n coords[i],\n overshot,\n direction,\n options\n );\n return interpolated;\n }\n } else {\n travelled += measureDistance(coords[i], coords[i + 1], options);\n }\n }\n return point(coords[coords.length - 1]);\n}\nvar index_default = along;\nexport {\n along,\n index_default as default\n};\n//# sourceMappingURL=index.js.map","// index.ts\nimport { degreesToRadians, radiansToDegrees } from \"@turf/helpers\";\nimport { getCoord } from \"@turf/invariant\";\nfunction rhumbBearing(start, end, options = {}) {\n let bear360;\n if (options.final) {\n bear360 = calculateRhumbBearing(getCoord(end), getCoord(start));\n } else {\n bear360 = calculateRhumbBearing(getCoord(start), getCoord(end));\n }\n const bear180 = bear360 > 180 ? -(360 - bear360) : bear360;\n return bear180;\n}\nfunction calculateRhumbBearing(from, to) {\n const phi1 = degreesToRadians(from[1]);\n const phi2 = degreesToRadians(to[1]);\n let deltaLambda = degreesToRadians(to[0] - from[0]);\n if (deltaLambda > Math.PI) {\n deltaLambda -= 2 * Math.PI;\n }\n if (deltaLambda < -Math.PI) {\n deltaLambda += 2 * Math.PI;\n }\n const deltaPsi = Math.log(\n Math.tan(phi2 / 2 + Math.PI / 4) / Math.tan(phi1 / 2 + Math.PI / 4)\n );\n const theta = Math.atan2(deltaLambda, deltaPsi);\n return (radiansToDegrees(theta) + 360) % 360;\n}\nvar index_default = rhumbBearing;\nexport {\n index_default as default,\n rhumbBearing\n};\n//# sourceMappingURL=index.js.map","// index.ts\nimport { feature, point, lineString, isObject } from \"@turf/helpers\";\nfunction coordEach(geojson, callback, excludeWrapCoord) {\n if (geojson === null) return;\n var j, k, l, geometry, stopG, coords, geometryMaybeCollection, wrapShrink = 0, coordIndex = 0, isGeometryCollection, type = geojson.type, isFeatureCollection = type === \"FeatureCollection\", isFeature = type === \"Feature\", stop = isFeatureCollection ? geojson.features.length : 1;\n for (var featureIndex = 0; featureIndex < stop; featureIndex++) {\n geometryMaybeCollection = isFeatureCollection ? (\n // @ts-expect-error: Known type conflict\n geojson.features[featureIndex].geometry\n ) : isFeature ? (\n // @ts-expect-error: Known type conflict\n geojson.geometry\n ) : geojson;\n isGeometryCollection = geometryMaybeCollection ? geometryMaybeCollection.type === \"GeometryCollection\" : false;\n stopG = isGeometryCollection ? geometryMaybeCollection.geometries.length : 1;\n for (var geomIndex = 0; geomIndex < stopG; geomIndex++) {\n var multiFeatureIndex = 0;\n var geometryIndex = 0;\n geometry = isGeometryCollection ? geometryMaybeCollection.geometries[geomIndex] : geometryMaybeCollection;\n if (geometry === null) continue;\n coords = geometry.coordinates;\n var geomType = geometry.type;\n wrapShrink = excludeWrapCoord && (geomType === \"Polygon\" || geomType === \"MultiPolygon\") ? 1 : 0;\n switch (geomType) {\n case null:\n break;\n case \"Point\":\n if (\n // @ts-expect-error: Known type conflict\n callback(\n coords,\n coordIndex,\n featureIndex,\n multiFeatureIndex,\n geometryIndex\n ) === false\n )\n return false;\n coordIndex++;\n multiFeatureIndex++;\n break;\n case \"LineString\":\n case \"MultiPoint\":\n for (j = 0; j < coords.length; j++) {\n if (\n // @ts-expect-error: Known type conflict\n callback(\n coords[j],\n coordIndex,\n featureIndex,\n multiFeatureIndex,\n geometryIndex\n ) === false\n )\n return false;\n coordIndex++;\n if (geomType === \"MultiPoint\") multiFeatureIndex++;\n }\n if (geomType === \"LineString\") multiFeatureIndex++;\n break;\n case \"Polygon\":\n case \"MultiLineString\":\n for (j = 0; j < coords.length; j++) {\n for (k = 0; k < coords[j].length - wrapShrink; k++) {\n if (\n // @ts-expect-error: Known type conflict\n callback(\n coords[j][k],\n coordIndex,\n featureIndex,\n multiFeatureIndex,\n geometryIndex\n ) === false\n )\n return false;\n coordIndex++;\n }\n if (geomType === \"MultiLineString\") multiFeatureIndex++;\n if (geomType === \"Polygon\") geometryIndex++;\n }\n if (geomType === \"Polygon\") multiFeatureIndex++;\n break;\n case \"MultiPolygon\":\n for (j = 0; j < coords.length; j++) {\n geometryIndex = 0;\n for (k = 0; k < coords[j].length; k++) {\n for (l = 0; l < coords[j][k].length - wrapShrink; l++) {\n if (\n // @ts-expect-error: Known type conflict\n callback(\n coords[j][k][l],\n coordIndex,\n featureIndex,\n multiFeatureIndex,\n geometryIndex\n ) === false\n )\n return false;\n coordIndex++;\n }\n geometryIndex++;\n }\n multiFeatureIndex++;\n }\n break;\n case \"GeometryCollection\":\n for (j = 0; j < geometry.geometries.length; j++)\n if (\n // @ts-expect-error: Known type conflict\n coordEach(geometry.geometries[j], callback, excludeWrapCoord) === false\n )\n return false;\n break;\n default:\n throw new Error(\"Unknown Geometry Type\");\n }\n }\n }\n}\nfunction coordReduce(geojson, callback, initialValue, excludeWrapCoord) {\n var previousValue = initialValue;\n coordEach(\n geojson,\n function(currentCoord, coordIndex, featureIndex, multiFeatureIndex, geometryIndex) {\n if (coordIndex === 0 && initialValue === void 0)\n previousValue = currentCoord;\n else\n previousValue = callback(\n // @ts-expect-error: Known type conflict\n previousValue,\n currentCoord,\n coordIndex,\n featureIndex,\n multiFeatureIndex,\n geometryIndex\n );\n },\n excludeWrapCoord\n );\n return previousValue;\n}\nfunction propEach(geojson, callback) {\n var i;\n switch (geojson.type) {\n case \"FeatureCollection\":\n for (i = 0; i < geojson.features.length; i++) {\n if (callback(geojson.features[i].properties, i) === false) break;\n }\n break;\n case \"Feature\":\n callback(geojson.properties, 0);\n break;\n }\n}\nfunction propReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n propEach(geojson, function(currentProperties, featureIndex) {\n if (featureIndex === 0 && initialValue === void 0)\n previousValue = currentProperties;\n else\n previousValue = callback(previousValue, currentProperties, featureIndex);\n });\n return previousValue;\n}\nfunction featureEach(geojson, callback) {\n if (geojson.type === \"Feature\") {\n callback(geojson, 0);\n } else if (geojson.type === \"FeatureCollection\") {\n for (var i = 0; i < geojson.features.length; i++) {\n if (callback(geojson.features[i], i) === false) break;\n }\n }\n}\nfunction featureReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n featureEach(geojson, function(currentFeature, featureIndex) {\n if (featureIndex === 0 && initialValue === void 0)\n previousValue = currentFeature;\n else previousValue = callback(previousValue, currentFeature, featureIndex);\n });\n return previousValue;\n}\nfunction coordAll(geojson) {\n var coords = [];\n coordEach(geojson, function(coord) {\n coords.push(coord);\n });\n return coords;\n}\nfunction geomEach(geojson, callback) {\n var i, j, g, geometry, stopG, geometryMaybeCollection, isGeometryCollection, featureProperties, featureBBox, featureId, featureIndex = 0, isFeatureCollection = geojson.type === \"FeatureCollection\", isFeature = geojson.type === \"Feature\", stop = isFeatureCollection ? geojson.features.length : 1;\n for (i = 0; i < stop; i++) {\n geometryMaybeCollection = isFeatureCollection ? (\n // @ts-expect-error: Known type conflict\n geojson.features[i].geometry\n ) : isFeature ? (\n // @ts-expect-error: Known type conflict\n geojson.geometry\n ) : geojson;\n featureProperties = isFeatureCollection ? (\n // @ts-expect-error: Known type conflict\n geojson.features[i].properties\n ) : isFeature ? (\n // @ts-expect-error: Known type conflict\n geojson.properties\n ) : {};\n featureBBox = isFeatureCollection ? (\n // @ts-expect-error: Known type conflict\n geojson.features[i].bbox\n ) : isFeature ? (\n // @ts-expect-error: Known type conflict\n geojson.bbox\n ) : void 0;\n featureId = isFeatureCollection ? (\n // @ts-expect-error: Known type conflict\n geojson.features[i].id\n ) : isFeature ? (\n // @ts-expect-error: Known type conflict\n geojson.id\n ) : void 0;\n isGeometryCollection = geometryMaybeCollection ? geometryMaybeCollection.type === \"GeometryCollection\" : false;\n stopG = isGeometryCollection ? geometryMaybeCollection.geometries.length : 1;\n for (g = 0; g < stopG; g++) {\n geometry = isGeometryCollection ? geometryMaybeCollection.geometries[g] : geometryMaybeCollection;\n if (geometry === null) {\n if (\n // @ts-expect-error: Known type conflict\n callback(\n // @ts-expect-error: Known type conflict\n null,\n featureIndex,\n featureProperties,\n featureBBox,\n featureId\n ) === false\n )\n return false;\n continue;\n }\n switch (geometry.type) {\n case \"Point\":\n case \"LineString\":\n case \"MultiPoint\":\n case \"Polygon\":\n case \"MultiLineString\":\n case \"MultiPolygon\": {\n if (\n // @ts-expect-error: Known type conflict\n callback(\n geometry,\n featureIndex,\n featureProperties,\n featureBBox,\n featureId\n ) === false\n )\n return false;\n break;\n }\n case \"GeometryCollection\": {\n for (j = 0; j < geometry.geometries.length; j++) {\n if (\n // @ts-expect-error: Known type conflict\n callback(\n geometry.geometries[j],\n featureIndex,\n featureProperties,\n featureBBox,\n featureId\n ) === false\n )\n return false;\n }\n break;\n }\n default:\n throw new Error(\"Unknown Geometry Type\");\n }\n }\n featureIndex++;\n }\n}\nfunction geomReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n geomEach(\n geojson,\n function(currentGeometry, featureIndex, featureProperties, featureBBox, featureId) {\n if (featureIndex === 0 && initialValue === void 0)\n previousValue = currentGeometry;\n else\n previousValue = callback(\n // @ts-expect-error: Known type conflict\n previousValue,\n currentGeometry,\n featureIndex,\n featureProperties,\n featureBBox,\n featureId\n );\n }\n );\n return previousValue;\n}\nfunction flattenEach(geojson, callback) {\n geomEach(geojson, function(geometry, featureIndex, properties, bbox, id) {\n var type = geometry === null ? null : geometry.type;\n switch (type) {\n case null:\n case \"Point\":\n case \"LineString\":\n case \"Polygon\":\n if (\n // @ts-expect-error: Known type conflict\n callback(\n feature(geometry, properties, { bbox, id }),\n featureIndex,\n 0\n ) === false\n )\n return false;\n return;\n }\n var geomType;\n switch (type) {\n case \"MultiPoint\":\n geomType = \"Point\";\n break;\n case \"MultiLineString\":\n geomType = \"LineString\";\n break;\n case \"MultiPolygon\":\n geomType = \"Polygon\";\n break;\n }\n for (\n var multiFeatureIndex = 0;\n // @ts-expect-error: Known type conflict\n multiFeatureIndex < geometry.coordinates.length;\n multiFeatureIndex++\n ) {\n var coordinate = geometry.coordinates[multiFeatureIndex];\n var geom = {\n type: geomType,\n coordinates: coordinate\n };\n if (\n // @ts-expect-error: Known type conflict\n callback(feature(geom, properties), featureIndex, multiFeatureIndex) === false\n )\n return false;\n }\n });\n}\nfunction flattenReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n flattenEach(\n geojson,\n function(currentFeature, featureIndex, multiFeatureIndex) {\n if (featureIndex === 0 && multiFeatureIndex === 0 && initialValue === void 0)\n previousValue = currentFeature;\n else\n previousValue = callback(\n // @ts-expect-error: Known type conflict\n previousValue,\n currentFeature,\n featureIndex,\n multiFeatureIndex\n );\n }\n );\n return previousValue;\n}\nfunction segmentEach(geojson, callback) {\n flattenEach(geojson, function(feature2, featureIndex, multiFeatureIndex) {\n var segmentIndex = 0;\n if (!feature2.geometry) return;\n var type = feature2.geometry.type;\n if (type === \"Point\" || type === \"MultiPoint\") return;\n var previousCoords;\n var previousFeatureIndex = 0;\n var previousMultiIndex = 0;\n var prevGeomIndex = 0;\n if (\n // @ts-expect-error: Known type conflict\n coordEach(\n feature2,\n function(currentCoord, coordIndex, featureIndexCoord, multiPartIndexCoord, geometryIndex) {\n if (\n // @ts-expect-error: Known type conflict\n previousCoords === void 0 || featureIndex > previousFeatureIndex || multiPartIndexCoord > previousMultiIndex || geometryIndex > prevGeomIndex\n ) {\n previousCoords = currentCoord;\n previousFeatureIndex = featureIndex;\n previousMultiIndex = multiPartIndexCoord;\n prevGeomIndex = geometryIndex;\n segmentIndex = 0;\n return;\n }\n var currentSegment = lineString(\n // @ts-expect-error: Known type conflict\n [previousCoords, currentCoord],\n feature2.properties\n );\n if (\n // @ts-expect-error: Known type conflict\n callback(\n // @ts-expect-error: Known type conflict\n currentSegment,\n featureIndex,\n multiFeatureIndex,\n geometryIndex,\n segmentIndex\n ) === false\n )\n return false;\n segmentIndex++;\n previousCoords = currentCoord;\n }\n ) === false\n )\n return false;\n });\n}\nfunction segmentReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n var started = false;\n segmentEach(\n geojson,\n function(currentSegment, featureIndex, multiFeatureIndex, geometryIndex, segmentIndex) {\n if (started === false && initialValue === void 0)\n previousValue = currentSegment;\n else\n previousValue = callback(\n previousValue,\n // @ts-expect-error: Known type conflict\n currentSegment,\n featureIndex,\n multiFeatureIndex,\n geometryIndex,\n segmentIndex\n );\n started = true;\n }\n );\n return previousValue;\n}\nfunction lineEach(geojson, callback) {\n if (!geojson) throw new Error(\"geojson is required\");\n flattenEach(geojson, function(feature2, featureIndex, multiFeatureIndex) {\n if (feature2.geometry === null) return;\n var type = feature2.geometry.type;\n var coords = feature2.geometry.coordinates;\n switch (type) {\n case \"LineString\":\n if (callback(feature2, featureIndex, multiFeatureIndex, 0, 0) === false)\n return false;\n break;\n case \"Polygon\":\n for (var geometryIndex = 0; geometryIndex < coords.length; geometryIndex++) {\n if (\n // @ts-expect-error: Known type conflict\n callback(\n // @ts-expect-error: Known type conflict\n lineString(coords[geometryIndex], feature2.properties),\n featureIndex,\n multiFeatureIndex,\n geometryIndex\n ) === false\n )\n return false;\n }\n break;\n }\n });\n}\nfunction lineReduce(geojson, callback, initialValue) {\n var previousValue = initialValue;\n lineEach(\n geojson,\n function(currentLine, featureIndex, multiFeatureIndex, geometryIndex) {\n if (featureIndex === 0 && initialValue === void 0)\n previousValue = currentLine;\n else\n previousValue = callback(\n previousValue,\n currentLine,\n featureIndex,\n multiFeatureIndex,\n geometryIndex\n );\n }\n );\n return previousValue;\n}\nfunction findSegment(geojson, options) {\n options = options || {};\n if (!isObject(options)) throw new Error(\"options is invalid\");\n var featureIndex = options.featureIndex || 0;\n var multiFeatureIndex = options.multiFeatureIndex || 0;\n var geometryIndex = options.geometryIndex || 0;\n var segmentIndex = options.segmentIndex || 0;\n var properties = options.properties;\n var geometry;\n switch (geojson.type) {\n case \"FeatureCollection\":\n if (featureIndex < 0)\n featureIndex = geojson.features.length + featureIndex;\n properties = properties || geojson.features[featureIndex].properties;\n geometry = geojson.features[featureIndex].geometry;\n break;\n case \"Feature\":\n properties = properties || geojson.properties;\n geometry = geojson.geometry;\n break;\n case \"Point\":\n case \"MultiPoint\":\n return null;\n case \"LineString\":\n case \"Polygon\":\n case \"MultiLineString\":\n case \"MultiPolygon\":\n geometry = geojson;\n break;\n default:\n throw new Error(\"geojson is invalid\");\n }\n if (geometry === null) return null;\n var coords = geometry.coordinates;\n switch (geometry.type) {\n case \"Point\":\n case \"MultiPoint\":\n return null;\n case \"LineString\":\n if (segmentIndex < 0) segmentIndex = coords.length + segmentIndex - 1;\n return lineString(\n // @ts-expect-error: Known type conflict\n [coords[segmentIndex], coords[segmentIndex + 1]],\n properties,\n options\n );\n case \"Polygon\":\n if (geometryIndex < 0) geometryIndex = coords.length + geometryIndex;\n if (segmentIndex < 0)\n segmentIndex = coords[geometryIndex].length + segmentIndex - 1;\n return lineString(\n [\n // @ts-expect-error: Known type conflict\n coords[geometryIndex][segmentIndex],\n // @ts-expect-error: Known type conflict\n coords[geometryIndex][segmentIndex + 1]\n ],\n properties,\n options\n );\n case \"MultiLineString\":\n if (multiFeatureIndex < 0)\n multiFeatureIndex = coords.length + multiFeatureIndex;\n if (segmentIndex < 0)\n segmentIndex = coords[multiFeatureIndex].length + segmentIndex - 1;\n return lineString(\n [\n // @ts-expect-error: Known type conflict\n coords[multiFeatureIndex][segmentIndex],\n // @ts-expect-error: Known type conflict\n coords[multiFeatureIndex][segmentIndex + 1]\n ],\n properties,\n options\n );\n case \"MultiPolygon\":\n if (multiFeatureIndex < 0)\n multiFeatureIndex = coords.length + multiFeatureIndex;\n if (geometryIndex < 0)\n geometryIndex = coords[multiFeatureIndex].length + geometryIndex;\n if (segmentIndex < 0)\n segmentIndex = // @ts-expect-error: Known type conflict\n coords[multiFeatureIndex][geometryIndex].length - segmentIndex - 1;\n return lineString(\n [\n // @ts-expect-error: Known type conflict\n coords[multiFeatureIndex][geometryIndex][segmentIndex],\n // @ts-expect-error: Known type conflict\n coords[multiFeatureIndex][geometryIndex][segmentIndex + 1]\n ],\n properties,\n options\n );\n }\n throw new Error(\"geojson is invalid\");\n}\nfunction findPoint(geojson, options) {\n options = options || {};\n if (!isObject(options)) throw new Error(\"options is invalid\");\n var featureIndex = options.featureIndex || 0;\n var multiFeatureIndex = options.multiFeatureIndex || 0;\n var geometryIndex = options.geometryIndex || 0;\n var coordIndex = options.coordIndex || 0;\n var properties = options.properties;\n var geometry;\n switch (geojson.type) {\n case \"FeatureCollection\":\n if (featureIndex < 0)\n featureIndex = geojson.features.length + featureIndex;\n properties = properties || geojson.features[featureIndex].properties;\n geometry = geojson.features[featureIndex].geometry;\n break;\n case \"Feature\":\n properties = properties || geojson.properties;\n geometry = geojson.geometry;\n break;\n case \"Point\":\n case \"MultiPoint\":\n return null;\n case \"LineString\":\n case \"Polygon\":\n case \"MultiLineString\":\n case \"MultiPolygon\":\n geometry = geojson;\n break;\n default:\n throw new Error(\"geojson is invalid\");\n }\n if (geometry === null) return null;\n var coords = geometry.coordinates;\n switch (geometry.type) {\n case \"Point\":\n return point(coords, properties, options);\n case \"MultiPoint\":\n if (multiFeatureIndex < 0)\n multiFeatureIndex = coords.length + multiFeatureIndex;\n return point(coords[multiFeatureIndex], properties, options);\n case \"LineString\":\n if (coordIndex < 0) coordIndex = coords.length + coordIndex;\n return point(coords[coordIndex], properties, options);\n case \"Polygon\":\n if (geometryIndex < 0) geometryIndex = coords.length + geometryIndex;\n if (coordIndex < 0)\n coordIndex = coords[geometryIndex].length + coordIndex;\n return point(coords[geometryIndex][coordIndex], properties, options);\n case \"MultiLineString\":\n if (multiFeatureIndex < 0)\n multiFeatureIndex = coords.length + multiFeatureIndex;\n if (coordIndex < 0)\n coordIndex = coords[multiFeatureIndex].length + coordIndex;\n return point(coords[multiFeatureIndex][coordIndex], properties, options);\n case \"MultiPolygon\":\n if (multiFeatureIndex < 0)\n multiFeatureIndex = coords.length + multiFeatureIndex;\n if (geometryIndex < 0)\n geometryIndex = coords[multiFeatureIndex].length + geometryIndex;\n if (coordIndex < 0)\n coordIndex = coords[multiFeatureIndex][geometryIndex].length - coordIndex;\n return point(\n coords[multiFeatureIndex][geometryIndex][coordIndex],\n properties,\n options\n );\n }\n throw new Error(\"geojson is invalid\");\n}\nexport {\n coordAll,\n coordEach,\n coordReduce,\n featureEach,\n featureReduce,\n findPoint,\n findSegment,\n flattenEach,\n flattenReduce,\n geomEach,\n geomReduce,\n lineEach,\n lineReduce,\n propEach,\n propReduce,\n segmentEach,\n segmentReduce\n};\n//# sourceMappingURL=index.js.map","// index.ts\nimport { coordEach } from \"@turf/meta\";\nfunction bbox(geojson, options = {}) {\n if (geojson.bbox != null && true !== options.recompute) {\n return geojson.bbox;\n }\n const result = [Infinity, Infinity, -Infinity, -Infinity];\n coordEach(geojson, (coord) => {\n if (result[0] > coord[0]) {\n result[0] = coord[0];\n }\n if (result[1] > coord[1]) {\n result[1] = coord[1];\n }\n if (result[2] < coord[0]) {\n result[2] = coord[0];\n }\n if (result[3] < coord[1]) {\n result[3] = coord[1];\n }\n });\n return result;\n}\nvar index_default = bbox;\nexport {\n bbox,\n index_default as default\n};\n//# sourceMappingURL=index.js.map","// index.ts\nimport { polygon } from \"@turf/helpers\";\nfunction bboxPolygon(bbox, options = {}) {\n const west = Number(bbox[0]);\n const south = Number(bbox[1]);\n const east = Number(bbox[2]);\n const north = Number(bbox[3]);\n if (bbox.length === 6) {\n throw new Error(\n \"@turf/bbox-polygon does not support BBox with 6 positions\"\n );\n }\n const lowLeft = [west, south];\n const topLeft = [west, north];\n const topRight = [east, north];\n const lowRight = [east, south];\n return polygon(\n [[lowLeft, lowRight, topRight, topLeft, lowLeft]],\n options.properties,\n { bbox, id: options.id }\n );\n}\nvar index_default = bboxPolygon;\nexport {\n bboxPolygon,\n index_default as default\n};\n//# sourceMappingURL=index.js.map","export const epsilon = 1.1102230246251565e-16;\nexport const splitter = 134217729;\nexport const resulterrbound = (3 + 8 * epsilon) * epsilon;\n\n// fast_expansion_sum_zeroelim routine from oritinal code\nexport function sum(elen, e, flen, f, h) {\n let Q, Qnew, hh, bvirt;\n let enow = e[0];\n let fnow = f[0];\n let eindex = 0;\n let findex = 0;\n if ((fnow > enow) === (fnow > -enow)) {\n Q = enow;\n enow = e[++eindex];\n } else {\n Q = fnow;\n fnow = f[++findex];\n }\n let hindex = 0;\n if (eindex < elen && findex < flen) {\n if ((fnow > enow) === (fnow > -enow)) {\n Qnew = enow + Q;\n hh = Q - (Qnew - enow);\n enow = e[++eindex];\n } else {\n Qnew = fnow + Q;\n hh = Q - (Qnew - fnow);\n fnow = f[++findex];\n }\n Q = Qnew;\n if (hh !== 0) {\n h[hindex++] = hh;\n }\n while (eindex < elen && findex < flen) {\n if ((fnow > enow) === (fnow > -enow)) {\n Qnew = Q + enow;\n bvirt = Qnew - Q;\n hh = Q - (Qnew - bvirt) + (enow - bvirt);\n enow = e[++eindex];\n } else {\n Qnew = Q + fnow;\n bvirt = Qnew - Q;\n hh = Q - (Qnew - bvirt) + (fnow - bvirt);\n fnow = f[++findex];\n }\n Q = Qnew;\n if (hh !== 0) {\n h[hindex++] = hh;\n }\n }\n }\n while (eindex < elen) {\n Qnew = Q + enow;\n bvirt = Qnew - Q;\n hh = Q - (Qnew - bvirt) + (enow - bvirt);\n enow = e[++eindex];\n Q = Qnew;\n if (hh !== 0) {\n h[hindex++] = hh;\n }\n }\n while (findex < flen) {\n Qnew = Q + fnow;\n bvirt = Qnew - Q;\n hh = Q - (Qnew - bvirt) + (fnow - bvirt);\n fnow = f[++findex];\n Q = Qnew;\n if (hh !== 0) {\n h[hindex++] = hh;\n }\n }\n if (Q !== 0 || hindex === 0) {\n h[hindex++] = Q;\n }\n return hindex;\n}\n\nexport function sum_three(alen, a, blen, b, clen, c, tmp, out) {\n return sum(sum(alen, a, blen, b, tmp), tmp, clen, c, out);\n}\n\n// scale_expansion_zeroelim routine from oritinal code\nexport function scale(elen, e, b, h) {\n let Q, sum, hh, product1, product0;\n let bvirt, c, ahi, alo, bhi, blo;\n\n c = splitter * b;\n bhi = c - (c - b);\n blo = b - bhi;\n let enow = e[0];\n Q = enow * b;\n c = splitter * enow;\n ahi = c - (c - enow);\n alo = enow - ahi;\n hh = alo * blo - (Q - ahi * bhi - alo * bhi - ahi * blo);\n let hindex = 0;\n if (hh !== 0) {\n h[hindex++] = hh;\n }\n for (let i = 1; i < elen; i++) {\n enow = e[i];\n product1 = enow * b;\n c = splitter * enow;\n ahi = c - (c - enow);\n alo = enow - ahi;\n product0 = alo * blo - (product1 - ahi * bhi - alo * bhi - ahi * blo);\n sum = Q + product0;\n bvirt = sum - Q;\n hh = Q - (sum - bvirt) + (product0 - bvirt);\n if (hh !== 0) {\n h[hindex++] = hh;\n }\n Q = product1 + sum;\n hh = sum - (Q - product1);\n if (hh !== 0) {\n h[hindex++] = hh;\n }\n }\n if (Q !== 0 || hindex === 0) {\n h[hindex++] = Q;\n }\n return hindex;\n}\n\nexport function negate(elen, e) {\n for (let i = 0; i < elen; i++) e[i] = -e[i];\n return elen;\n}\n\nexport function estimate(elen, e) {\n let Q = e[0];\n for (let i = 1; i < elen; i++) Q += e[i];\n return Q;\n}\n\nexport function vec(n) {\n return new Float64Array(n);\n}\n","import {epsilon, splitter, resulterrbound, estimate, vec, sum} from './util.js';\n\nconst ccwerrboundA = (3 + 16 * epsilon) * epsilon;\nconst ccwerrboundB = (2 + 12 * epsilon) * epsilon;\nconst ccwerrboundC = (9 + 64 * epsilon) * epsilon * epsilon;\n\nconst B = vec(4);\nconst C1 = vec(8);\nconst C2 = vec(12);\nconst D = vec(16);\nconst u = vec(4);\n\nfunction orient2dadapt(ax, ay, bx, by, cx, cy, detsum) {\n let acxtail, acytail, bcxtail, bcytail;\n let bvirt, c, ahi, alo, bhi, blo, _i, _j, _0, s1, s0, t1, t0, u3;\n\n const acx = ax - cx;\n const bcx = bx - cx;\n const acy = ay - cy;\n const bcy = by - cy;\n\n s1 = acx * bcy;\n c = splitter * acx;\n ahi = c - (c - acx);\n alo = acx - ahi;\n c = splitter * bcy;\n bhi = c - (c - bcy);\n blo = bcy - bhi;\n s0 = alo * blo - (s1 - ahi * bhi - alo * bhi - ahi * blo);\n t1 = acy * bcx;\n c = splitter * acy;\n ahi = c - (c - acy);\n alo = acy - ahi;\n c = splitter * bcx;\n bhi = c - (c - bcx);\n blo = bcx - bhi;\n t0 = alo * blo - (t1 - ahi * bhi - alo * bhi - ahi * blo);\n _i = s0 - t0;\n bvirt = s0 - _i;\n B[0] = s0 - (_i + bvirt) + (bvirt - t0);\n _j = s1 + _i;\n bvirt = _j - s1;\n _0 = s1 - (_j - bvirt) + (_i - bvirt);\n _i = _0 - t1;\n bvirt = _0 - _i;\n B[1] = _0 - (_i + bvirt) + (bvirt - t1);\n u3 = _j + _i;\n bvirt = u3 - _j;\n B[2] = _j - (u3 - bvirt) + (_i - bvirt);\n B[3] = u3;\n\n let det = estimate(4, B);\n let errbound = ccwerrboundB * detsum;\n if (det >= errbound || -det >= errbound) {\n return det;\n }\n\n bvirt = ax - acx;\n acxtail = ax - (acx + bvirt) + (bvirt - cx);\n bvirt = bx - bcx;\n bcxtail = bx - (bcx + bvirt) + (bvirt - cx);\n bvirt = ay - acy;\n acytail = ay - (acy + bvirt) + (bvirt - cy);\n bvirt = by - bcy;\n bcytail = by - (bcy + bvirt) + (bvirt - cy);\n\n if (acxtail === 0 && acytail === 0 && bcxtail === 0 && bcytail === 0) {\n return det;\n }\n\n errbound = ccwerrboundC * detsum + resulterrbound * Math.abs(det);\n det += (acx * bcytail + bcy * acxtail) - (acy * bcxtail + bcx * acytail);\n if (det >= errbound || -det >= errbound) return det;\n\n s1 = acxtail * bcy;\n c = splitter * acxtail;\n ahi = c - (c - acxtail);\n alo = acxtail - ahi;\n c = splitter * bcy;\n bhi = c - (c - bcy);\n blo = bcy - bhi;\n s0 = alo * blo - (s1 - ahi * bhi - alo * bhi - ahi * blo);\n t1 = acytail * bcx;\n c = splitter * acytail;\n ahi = c - (c - acytail);\n alo = acytail - ahi;\n c = splitter * bcx;\n bhi = c - (c - bcx);\n blo = bcx - bhi;\n t0 = alo * blo - (t1 - ahi * bhi - alo * bhi - ahi * blo);\n _i = s0 - t0;\n bvirt = s0 - _i;\n u[0] = s0 - (_i + bvirt) + (bvirt - t0);\n _j = s1 + _i;\n bvirt = _j - s1;\n _0 = s1 - (_j - bvirt) + (_i - bvirt);\n _i = _0 - t1;\n bvirt = _0 - _i;\n u[1] = _0 - (_i + bvirt) + (bvirt - t1);\n u3 = _j + _i;\n bvirt = u3 - _j;\n u[2] = _j - (u3 - bvirt) + (_i - bvirt);\n u[3] = u3;\n const C1len = sum(4, B, 4, u, C1);\n\n s1 = acx * bcytail;\n c = splitter * acx;\n ahi = c - (c - acx);\n alo = acx - ahi;\n c = splitter * bcytail;\n bhi = c - (c - bcytail);\n blo = bcytail - bhi;\n s0 = alo * blo - (s1 - ahi * bhi - alo * bhi - ahi * blo);\n t1 = acy * bcxtail;\n c = splitter * acy;\n ahi = c - (c - acy);\n alo = acy - ahi;\n c = splitter * bcxtail;\n bhi = c - (c - bcxtail);\n blo = bcxtail - bhi;\n t0 = alo * blo - (t1 - ahi * bhi - alo * bhi - ahi * blo);\n _i = s0 - t0;\n bvirt = s0 - _i;\n u[0] = s0 - (_i + bvirt) + (bvirt - t0);\n _j = s1 + _i;\n bvirt = _j - s1;\n _0 = s1 - (_j - bvirt) + (_i - bvirt);\n _i = _0 - t1;\n bvirt = _0 - _i;\n u[1] = _0 - (_i + bvirt) + (bvirt - t1);\n u3 = _j + _i;\n bvirt = u3 - _j;\n u[2] = _j - (u3 - bvirt) + (_i - bvirt);\n u[3] = u3;\n const C2len = sum(C1len, C1, 4, u, C2);\n\n s1 = acxtail * bcytail;\n c = splitter * acxtail;\n ahi = c - (c - acxtail);\n alo = acxtail - ahi;\n c = splitter * bcytail;\n bhi = c - (c - bcytail);\n blo = bcytail - bhi;\n s0 = alo * blo - (s1 - ahi * bhi - alo * bhi - ahi * blo);\n t1 = acytail * bcxtail;\n c = splitter * acytail;\n ahi = c - (c - acytail);\n alo = acytail - ahi;\n c = splitter * bcxtail;\n bhi = c - (c - bcxtail);\n blo = bcxtail - bhi;\n t0 = alo * blo - (t1 - ahi * bhi - alo * bhi - ahi * blo);\n _i = s0 - t0;\n bvirt = s0 - _i;\n u[0] = s0 - (_i + bvirt) + (bvirt - t0);\n _j = s1 + _i;\n bvirt = _j - s1;\n _0 = s1 - (_j - bvirt) + (_i - bvirt);\n _i = _0 - t1;\n bvirt = _0 - _i;\n u[1] = _0 - (_i + bvirt) + (bvirt - t1);\n u3 = _j + _i;\n bvirt = u3 - _j;\n u[2] = _j - (u3 - bvirt) + (_i - bvirt);\n u[3] = u3;\n const Dlen = sum(C2len, C2, 4, u, D);\n\n return D[Dlen - 1];\n}\n\nexport function orient2d(ax, ay, bx, by, cx, cy) {\n const detleft = (ay - cy) * (bx - cx);\n const detright = (ax - cx) * (by - cy);\n const det = detleft - detright;\n\n const detsum = Math.abs(detleft + detright);\n if (Math.abs(det) >= ccwerrboundA * detsum) return det;\n\n return -orient2dadapt(ax, ay, bx, by, cx, cy, detsum);\n}\n\nexport function orient2dfast(ax, ay, bx, by, cx, cy) {\n return (ay - cy) * (bx - cx) - (ax - cx) * (by - cy);\n}\n","import { orient2d } from 'robust-predicates';\n\nfunction pointInPolygon(p, polygon) {\n var i;\n var ii;\n var k = 0;\n var f;\n var u1;\n var v1;\n var u2;\n var v2;\n var currentP;\n var nextP;\n\n var x = p[0];\n var y = p[1];\n\n var numContours = polygon.length;\n for (i = 0; i < numContours; i++) {\n ii = 0;\n var contour = polygon[i];\n var contourLen = contour.length - 1;\n\n currentP = contour[0];\n if (currentP[0] !== contour[contourLen][0] &&\n currentP[1] !== contour[contourLen][1]) {\n throw new Error('First and last coordinates in a ring must be the same')\n }\n\n u1 = currentP[0] - x;\n v1 = currentP[1] - y;\n\n for (ii; ii < contourLen; ii++) {\n nextP = contour[ii + 1];\n\n u2 = nextP[0] - x;\n v2 = nextP[1] - y;\n\n if (v1 === 0 && v2 === 0) {\n if ((u2 <= 0 && u1 >= 0) || (u1 <= 0 && u2 >= 0)) { return 0 }\n } else if ((v2 >= 0 && v1 <= 0) || (v2 <= 0 && v1 >= 0)) {\n f = orient2d(u1, u2, v1, v2, 0, 0);\n if (f === 0) { return 0 }\n if ((f > 0 && v2 > 0 && v1 <= 0) || (f < 0 && v2 <= 0 && v1 > 0)) { k++; }\n }\n currentP = nextP;\n v1 = v2;\n u1 = u2;\n }\n }\n\n if (k % 2 === 0) { return false }\n return true\n}\n\nexport { pointInPolygon as default };\n","// index.ts\nimport pip from \"point-in-polygon-hao\";\nimport { getCoord, getGeom } from \"@turf/invariant\";\nfunction booleanPointInPolygon(point, polygon, options = {}) {\n if (!point) {\n throw new Error(\"point is required\");\n }\n if (!polygon) {\n throw new Error(\"polygon is required\");\n }\n const pt = getCoord(point);\n const geom = getGeom(polygon);\n const type = geom.type;\n const bbox = polygon.bbox;\n let polys = geom.coordinates;\n if (bbox && inBBox(pt, bbox) === false) {\n return false;\n }\n if (type === \"Polygon\") {\n polys = [polys];\n }\n let result = false;\n for (var i = 0; i < polys.length; ++i) {\n const polyResult = pip(pt, polys[i]);\n if (polyResult === 0) return options.ignoreBoundary ? false : true;\n else if (polyResult) result = true;\n }\n return result;\n}\nfunction inBBox(pt, bbox) {\n return bbox[0] <= pt[0] && bbox[1] <= pt[1] && bbox[2] >= pt[0] && bbox[3] >= pt[1];\n}\nvar index_default = booleanPointInPolygon;\nexport {\n booleanPointInPolygon,\n index_default as default\n};\n//# sourceMappingURL=index.js.map","// index.ts\nimport { point } from \"@turf/helpers\";\nimport { coordEach } from \"@turf/meta\";\nfunction centroid(geojson, options = {}) {\n let xSum = 0;\n let ySum = 0;\n let len = 0;\n coordEach(\n geojson,\n function(coord) {\n xSum += coord[0];\n ySum += coord[1];\n len++;\n },\n true\n );\n return point([xSum / len, ySum / len], options.properties);\n}\nvar index_default = centroid;\nexport {\n centroid,\n index_default as default\n};\n//# sourceMappingURL=index.js.map","!function(t,i){\"object\"==typeof exports&&\"undefined\"!=typeof module?module.exports=i():\"function\"==typeof define&&define.amd?define(i):(t=t||self).RBush=i()}(this,function(){\"use strict\";function t(t,r,e,a,h){!function t(n,r,e,a,h){for(;a>e;){if(a-e>600){var o=a-e+1,s=r-e+1,l=Math.log(o),f=.5*Math.exp(2*l/3),u=.5*Math.sqrt(l*f*(o-f)/o)*(s-o/2<0?-1:1),m=Math.max(e,Math.floor(r-s*f/o+u)),c=Math.min(a,Math.floor(r+(o-s)*f/o+u));t(n,r,m,c,h)}var p=n[r],d=e,x=a;for(i(n,e,r),h(n[a],p)>0&&i(n,e,a);d<x;){for(i(n,d,x),d++,x--;h(n[d],p)<0;)d++;for(;h(n[x],p)>0;)x--}0===h(n[e],p)?i(n,e,x):i(n,++x,a),x<=r&&(e=x+1),r<=x&&(a=x-1)}}(t,r,e||0,a||t.length-1,h||n)}function i(t,i,n){var r=t[i];t[i]=t[n],t[n]=r}function n(t,i){return t<i?-1:t>i?1:0}var r=function(t){void 0===t&&(t=9),this._maxEntries=Math.max(4,t),this._minEntries=Math.max(2,Math.ceil(.4*this._maxEntries)),this.clear()};function e(t,i,n){if(!n)return i.indexOf(t);for(var r=0;r<i.length;r++)if(n(t,i[r]))return r;return-1}function a(t,i){h(t,0,t.children.length,i,t)}function h(t,i,n,r,e){e||(e=p(null)),e.minX=1/0,e.minY=1/0,e.maxX=-1/0,e.maxY=-1/0;for(var a=i;a<n;a++){var h=t.children[a];o(e,t.leaf?r(h):h)}return e}function o(t,i){return t.minX=Math.min(t.minX,i.minX),t.minY=Math.min(t.minY,i.minY),t.maxX=Math.max(t.maxX,i.maxX),t.maxY=Math.max(t.maxY,i.maxY),t}function s(t,i){return t.minX-i.minX}function l(t,i){return t.minY-i.minY}function f(t){return(t.maxX-t.minX)*(t.maxY-t.minY)}function u(t){return t.maxX-t.minX+(t.maxY-t.minY)}function m(t,i){return t.minX<=i.minX&&t.minY<=i.minY&&i.maxX<=t.maxX&&i.maxY<=t.maxY}function c(t,i){return i.minX<=t.maxX&&i.minY<=t.maxY&&i.maxX>=t.minX&&i.maxY>=t.minY}function p(t){return{children:t,height:1,leaf:!0,minX:1/0,minY:1/0,maxX:-1/0,maxY:-1/0}}function d(i,n,r,e,a){for(var h=[n,r];h.length;)if(!((r=h.pop())-(n=h.pop())<=e)){var o=n+Math.ceil((r-n)/e/2)*e;t(i,o,n,r,a),h.push(n,o,o,r)}}return r.prototype.all=function(){return this._all(this.data,[])},r.prototype.search=function(t){var i=this.data,n=[];if(!c(t,i))return n;for(var r=this.toBBox,e=[];i;){for(var a=0;a<i.children.length;a++){var h=i.children[a],o=i.leaf?r(h):h;c(t,o)&&(i.leaf?n.push(h):m(t,o)?this._all(h,n):e.push(h))}i=e.pop()}return n},r.prototype.collides=function(t){var i=this.data;if(!c(t,i))return!1;for(var n=[];i;){for(var r=0;r<i.children.length;r++){var e=i.children[r],a=i.leaf?this.toBBox(e):e;if(c(t,a)){if(i.leaf||m(t,a))return!0;n.push(e)}}i=n.pop()}return!1},r.prototype.load=function(t){if(!t||!t.length)return this;if(t.length<this._minEntries){for(var i=0;i<t.length;i++)this.insert(t[i]);return this}var n=this._build(t.slice(),0,t.length-1,0);if(this.data.children.length)if(this.data.height===n.height)this._splitRoot(this.data,n);else{if(this.data.height<n.height){var r=this.data;this.data=n,n=r}this._insert(n,this.data.height-n.height-1,!0)}else this.data=n;return this},r.prototype.insert=function(t){return t&&this._insert(t,this.data.height-1),this},r.prototype.clear=function(){return this.data=p([]),this},r.prototype.remove=function(t,i){if(!t)return this;for(var n,r,a,h=this.data,o=this.toBBox(t),s=[],l=[];h||s.length;){if(h||(h=s.pop(),r=s[s.length-1],n=l.pop(),a=!0),h.leaf){var f=e(t,h.children,i);if(-1!==f)return h.children.splice(f,1),s.push(h),this._condense(s),this}a||h.leaf||!m(h,o)?r?(n++,h=r.children[n],a=!1):h=null:(s.push(h),l.push(n),n=0,r=h,h=h.children[0])}return this},r.prototype.toBBox=function(t){return t},r.prototype.compareMinX=function(t,i){return t.minX-i.minX},r.prototype.compareMinY=function(t,i){return t.minY-i.minY},r.prototype.toJSON=function(){return this.data},r.prototype.fromJSON=function(t){return this.data=t,this},r.prototype._all=function(t,i){for(var n=[];t;)t.leaf?i.push.apply(i,t.children):n.push.apply(n,t.children),t=n.pop();return i},r.prototype._build=function(t,i,n,r){var e,h=n-i+1,o=this._maxEntries;if(h<=o)return a(e=p(t.slice(i,n+1)),this.toBBox),e;r||(r=Math.ceil(Math.log(h)/Math.log(o)),o=Math.ceil(h/Math.pow(o,r-1))),(e=p([])).leaf=!1,e.height=r;var s=Math.ceil(h/o),l=s*Math.ceil(Math.sqrt(o));d(t,i,n,l,this.compareMinX);for(var f=i;f<=n;f+=l){var u=Math.min(f+l-1,n);d(t,f,u,s,this.compareMinY);for(var m=f;m<=u;m+=s){var c=Math.min(m+s-1,u);e.children.push(this._build(t,m,c,r-1))}}return a(e,this.toBBox),e},r.prototype._chooseSubtree=function(t,i,n,r){for(;r.push(i),!i.leaf&&r.length-1!==n;){for(var e=1/0,a=1/0,h=void 0,o=0;o<i.children.length;o++){var s=i.children[o],l=f(s),u=(m=t,c=s,(Math.max(c.maxX,m.maxX)-Math.min(c.minX,m.minX))*(Math.max(c.maxY,m.maxY)-Math.min(c.minY,m.minY))-l);u<a?(a=u,e=l<e?l:e,h=s):u===a&&l<e&&(e=l,h=s)}i=h||i.children[0]}var m,c;return i},r.prototype._insert=function(t,i,n){var r=n?t:this.toBBox(t),e=[],a=this._chooseSubtree(r,this.data,i,e);for(a.children.push(t),o(a,r);i>=0&&e[i].children.length>this._maxEntries;)this._split(e,i),i--;this._adjustParentBBoxes(r,e,i)},r.prototype._split=function(t,i){var n=t[i],r=n.children.length,e=this._minEntries;this._chooseSplitAxis(n,e,r);var h=this._chooseSplitIndex(n,e,r),o=p(n.children.splice(h,n.children.length-h));o.height=n.height,o.leaf=n.leaf,a(n,this.toBBox),a(o,this.toBBox),i?t[i-1].children.push(o):this._splitRoot(n,o)},r.prototype._splitRoot=function(t,i){this.data=p([t,i]),this.data.height=t.height+1,this.data.leaf=!1,a(this.data,this.toBBox)},r.prototype._chooseSplitIndex=function(t,i,n){for(var r,e,a,o,s,l,u,m=1/0,c=1/0,p=i;p<=n-i;p++){var d=h(t,0,p,this.toBBox),x=h(t,p,n,this.toBBox),v=(e=d,a=x,o=void 0,s=void 0,l=void 0,u=void 0,o=Math.max(e.minX,a.minX),s=Math.max(e.minY,a.minY),l=Math.min(e.maxX,a.maxX),u=Math.min(e.maxY,a.maxY),Math.max(0,l-o)*Math.max(0,u-s)),M=f(d)+f(x);v<m?(m=v,r=p,c=M<c?M:c):v===m&&M<c&&(c=M,r=p)}return r||n-i},r.prototype._chooseSplitAxis=function(t,i,n){var r=t.leaf?this.compareMinX:s,e=t.leaf?this.compareMinY:l;this._allDistMargin(t,i,n,r)<this._allDistMargin(t,i,n,e)&&t.children.sort(r)},r.prototype._allDistMargin=function(t,i,n,r){t.children.sort(r);for(var e=this.toBBox,a=h(t,0,i,e),s=h(t,n-i,n,e),l=u(a)+u(s),f=i;f<n-i;f++){var m=t.children[f];o(a,t.leaf?e(m):m),l+=u(a)}for(var c=n-i-1;c>=i;c--){var p=t.children[c];o(s,t.leaf?e(p):p),l+=u(s)}return l},r.prototype._adjustParentBBoxes=function(t,i,n){for(var r=n;r>=0;r--)o(i[r],t)},r.prototype._condense=function(t){for(var i=t.length-1,n=void 0;i>=0;i--)0===t[i].children.length?i>0?(n=t[i-1].children).splice(n.indexOf(t[i]),1):this.clear():a(t[i],this.toBBox)},r});\n","\nexport default class TinyQueue {\n constructor(data = [], compare = defaultCompare) {\n this.data = data;\n this.length = this.data.length;\n this.compare = compare;\n\n if (this.length > 0) {\n for (let i = (this.length >> 1) - 1; i >= 0; i--) this._down(i);\n }\n }\n\n push(item) {\n this.data.push(item);\n this.length++;\n this._up(this.length - 1);\n }\n\n pop() {\n if (this.length === 0) return undefined;\n\n const top = this.data[0];\n const bottom = this.data.pop();\n this.length--;\n\n if (this.length > 0) {\n this.data[0] = bottom;\n this._down(0);\n }\n\n return top;\n }\n\n peek() {\n return this.data[0];\n }\n\n _up(pos) {\n const {data, compare} = this;\n const item = data[pos];\n\n while (pos > 0) {\n const parent = (pos - 1) >> 1;\n const current = data[parent];\n if (compare(item, current) >= 0) break;\n data[pos] = current;\n pos = parent;\n }\n\n data[pos] = item;\n }\n\n _down(pos) {\n const {data, compare} = this;\n const halfLength = this.length >> 1;\n const item = data[pos];\n\n while (pos < halfLength) {\n let left = (pos << 1) + 1;\n let best = data[left];\n const right = left + 1;\n\n if (right < this.length && compare(data[right], best) < 0) {\n left = right;\n best = data[right];\n }\n if (compare(best, item) >= 0) break;\n\n data[pos] = best;\n pos = left;\n }\n\n data[pos] = item;\n }\n}\n\nfunction defaultCompare(a, b) {\n return a < b ? -1 : a > b ? 1 : 0;\n}\n","module.exports = function pointInPolygonFlat (point, vs, start, end) {\n var x = point[0], y = point[1];\n var inside = false;\n if (start === undefined) start = 0;\n if (end === undefined) end = vs.length;\n var len = (end-start)/2;\n for (var i = 0, j = len - 1; i < len; j = i++) {\n var xi = vs[start+i*2+0], yi = vs[start+i*2+1];\n var xj = vs[start+j*2+0], yj = vs[start+j*2+1];\n var intersect = ((yi > y) !== (yj > y))\n && (x < (xj - xi) * (y - yi) / (yj - yi) + xi);\n if (intersect) inside = !inside;\n }\n return inside;\n};\n","// ray-casting algorithm based on\n// https://wrf.ecse.rpi.edu/Research/Short_Notes/pnpoly.html\n\nmodule.exports = function pointInPolygonNested (point, vs, start, end) {\n var x = point[0], y = point[1];\n var inside = false;\n if (start === undefined) start = 0;\n if (end === undefined) end = vs.length;\n var len = end - start;\n for (var i = 0, j = len - 1; i < len; j = i++) {\n var xi = vs[i+start][0], yi = vs[i+start][1];\n var xj = vs[j+start][0], yj = vs[j+start][1];\n var intersect = ((yi > y) !== (yj > y))\n && (x < (xj - xi) * (y - yi) / (yj - yi) + xi);\n if (intersect) inside = !inside;\n }\n return inside;\n};\n","var pointInPolygonFlat = require('./flat.js')\nvar pointInPolygonNested = require('./nested.js')\n\nmodule.exports = function pointInPolygon (point, vs, start, end) {\n if (vs.length > 0 && Array.isArray(vs[0])) {\n return pointInPolygonNested(point, vs, start, end);\n } else {\n return pointInPolygonFlat(point, vs, start, end);\n }\n}\nmodule.exports.nested = pointInPolygonNested\nmodule.exports.flat = pointInPolygonFlat\n","!function(t,e){\"object\"==typeof exports&&\"undefined\"!=typeof module?e(exports):\"function\"==typeof define&&define.amd?define([\"exports\"],e):e((t=t||self).predicates={})}(this,function(t){\"use strict\";const e=134217729,n=33306690738754706e-32;function r(t,e,n,r,o){let f,i,u,c,s=e[0],a=r[0],d=0,l=0;a>s==a>-s?(f=s,s=e[++d]):(f=a,a=r[++l]);let p=0;if(d<t&&l<n)for(a>s==a>-s?(u=f-((i=s+f)-s),s=e[++d]):(u=f-((i=a+f)-a),a=r[++l]),f=i,0!==u&&(o[p++]=u);d<t&&l<n;)a>s==a>-s?(u=f-((i=f+s)-(c=i-f))+(s-c),s=e[++d]):(u=f-((i=f+a)-(c=i-f))+(a-c),a=r[++l]),f=i,0!==u&&(o[p++]=u);for(;d<t;)u=f-((i=f+s)-(c=i-f))+(s-c),s=e[++d],f=i,0!==u&&(o[p++]=u);for(;l<n;)u=f-((i=f+a)-(c=i-f))+(a-c),a=r[++l],f=i,0!==u&&(o[p++]=u);return 0===f&&0!==p||(o[p++]=f),p}function o(t){return new Float64Array(t)}const f=33306690738754716e-32,i=22204460492503146e-32,u=11093356479670487e-47,c=o(4),s=o(8),a=o(12),d=o(16),l=o(4);t.orient2d=function(t,o,p,b,y,h){const M=(o-h)*(p-y),x=(t-y)*(b-h),j=M-x;if(0===M||0===x||M>0!=x>0)return j;const m=Math.abs(M+x);return Math.abs(j)>=f*m?j:-function(t,o,f,p,b,y,h){let M,x,j,m,_,v,w,A,F,O,P,g,k,q,z,B,C,D;const E=t-b,G=f-b,H=o-y,I=p-y;_=(z=(A=E-(w=(v=e*E)-(v-E)))*(O=I-(F=(v=e*I)-(v-I)))-((q=E*I)-w*F-A*F-w*O))-(P=z-(C=(A=H-(w=(v=e*H)-(v-H)))*(O=G-(F=(v=e*G)-(v-G)))-((B=H*G)-w*F-A*F-w*O))),c[0]=z-(P+_)+(_-C),_=(k=q-((g=q+P)-(_=g-q))+(P-_))-(P=k-B),c[1]=k-(P+_)+(_-B),_=(D=g+P)-g,c[2]=g-(D-_)+(P-_),c[3]=D;let J=function(t,e){let n=e[0];for(let r=1;r<t;r++)n+=e[r];return n}(4,c),K=i*h;if(J>=K||-J>=K)return J;if(M=t-(E+(_=t-E))+(_-b),j=f-(G+(_=f-G))+(_-b),x=o-(H+(_=o-H))+(_-y),m=p-(I+(_=p-I))+(_-y),0===M&&0===x&&0===j&&0===m)return J;if(K=u*h+n*Math.abs(J),(J+=E*m+I*M-(H*j+G*x))>=K||-J>=K)return J;_=(z=(A=M-(w=(v=e*M)-(v-M)))*(O=I-(F=(v=e*I)-(v-I)))-((q=M*I)-w*F-A*F-w*O))-(P=z-(C=(A=x-(w=(v=e*x)-(v-x)))*(O=G-(F=(v=e*G)-(v-G)))-((B=x*G)-w*F-A*F-w*O))),l[0]=z-(P+_)+(_-C),_=(k=q-((g=q+P)-(_=g-q))+(P-_))-(P=k-B),l[1]=k-(P+_)+(_-B),_=(D=g+P)-g,l[2]=g-(D-_)+(P-_),l[3]=D;const L=r(4,c,4,l,s);_=(z=(A=E-(w=(v=e*E)-(v-E)))*(O=m-(F=(v=e*m)-(v-m)))-((q=E*m)-w*F-A*F-w*O))-(P=z-(C=(A=H-(w=(v=e*H)-(v-H)))*(O=j-(F=(v=e*j)-(v-j)))-((B=H*j)-w*F-A*F-w*O))),l[0]=z-(P+_)+(_-C),_=(k=q-((g=q+P)-(_=g-q))+(P-_))-(P=k-B),l[1]=k-(P+_)+(_-B),_=(D=g+P)-g,l[2]=g-(D-_)+(P-_),l[3]=D;const N=r(L,s,4,l,a);_=(z=(A=M-(w=(v=e*M)-(v-M)))*(O=m-(F=(v=e*m)-(v-m)))-((q=M*m)-w*F-A*F-w*O))-(P=z-(C=(A=x-(w=(v=e*x)-(v-x)))*(O=j-(F=(v=e*j)-(v-j)))-((B=x*j)-w*F-A*F-w*O))),l[0]=z-(P+_)+(_-C),_=(k=q-((g=q+P)-(_=g-q))+(P-_))-(P=k-B),l[1]=k-(P+_)+(_-B),_=(D=g+P)-g,l[2]=g-(D-_)+(P-_),l[3]=D;const Q=r(N,a,4,l,d);return d[Q-1]}(t,o,p,b,y,h,m)},t.orient2dfast=function(t,e,n,r,o,f){return(e-f)*(n-o)-(t-o)*(r-f)},Object.defineProperty(t,\"__esModule\",{value:!0})});\n","'use strict';\n\nvar RBush = require('rbush');\nvar Queue = require('tinyqueue');\nvar pointInPolygon = require('point-in-polygon');\nvar orient = require('robust-predicates/umd/orient2d.min.js').orient2d;\n\n// Fix for require issue in webpack https://github.com/mapbox/concaveman/issues/18\nif (Queue.default) {\n Queue = Queue.default;\n}\n\nmodule.exports = concaveman;\nmodule.exports.default = concaveman;\n\nfunction concaveman(points, concavity, lengthThreshold) {\n // a relative measure of concavity; higher value means simpler hull\n concavity = Math.max(0, concavity === undefined ? 2 : concavity);\n\n // when a segment goes below this length threshold, it won't be drilled down further\n lengthThreshold = lengthThreshold || 0;\n\n // start with a convex hull of the points\n var hull = fastConvexHull(points);\n\n // index the points with an R-tree\n var tree = new RBush(16);\n tree.toBBox = function (a) {\n return {\n minX: a[0],\n minY: a[1],\n maxX: a[0],\n maxY: a[1]\n };\n };\n tree.compareMinX = function (a, b) { return a[0] - b[0]; };\n tree.compareMinY = function (a, b) { return a[1] - b[1]; };\n\n tree.load(points);\n\n // turn the convex hull into a linked list and populate the initial edge queue with the nodes\n var queue = [];\n for (var i = 0, last; i < hull.length; i++) {\n var p = hull[i];\n tree.remove(p);\n last = insertNode(p, last);\n queue.push(last);\n }\n\n // index the segments with an R-tree (for intersection checks)\n var segTree = new RBush(16);\n for (i = 0; i < queue.length; i++) segTree.insert(updateBBox(queue[i]));\n\n var sqConcavity = concavity * concavity;\n var sqLenThreshold = lengthThreshold * lengthThreshold;\n\n // process edges one by one\n while (queue.length) {\n var node = queue.shift();\n var a = node.p;\n var b = node.next.p;\n\n // skip the edge if it's already short enough\n var sqLen = getSqDist(a, b);\n if (sqLen < sqLenThreshold) continue;\n\n var maxSqLen = sqLen / sqConcavity;\n\n // find the best connection point for the current edge to flex inward to\n p = findCandidate(tree, node.prev.p, a, b, node.next.next.p, maxSqLen, segTree);\n\n // if we found a connection and it satisfies our concavity measure\n if (p && Math.min(getSqDist(p, a), getSqDist(p, b)) <= maxSqLen) {\n // connect the edge endpoints through this point and add 2 new edges to the queue\n queue.push(node);\n queue.push(insertNode(p, node));\n\n // update point and segment indexes\n tree.remove(p);\n segTree.remove(node);\n segTree.insert(updateBBox(node));\n segTree.insert(updateBBox(node.next));\n }\n }\n\n // convert the resulting hull linked list to an array of points\n node = last;\n var concave = [];\n do {\n concave.push(node.p);\n node = node.next;\n } while (node !== last);\n\n concave.push(node.p);\n\n return concave;\n}\n\nfunction findCandidate(tree, a, b, c, d, maxDist, segTree) {\n var queue = new Queue([], compareDist);\n var node = tree.data;\n\n // search through the point R-tree with a depth-first search using a priority queue\n // in the order of distance to the edge (b, c)\n while (node) {\n for (var i = 0; i < node.children.length; i++) {\n var child = node.children[i];\n\n var dist = node.leaf ? sqSegDist(child, b, c) : sqSegBoxDist(b, c, child);\n if (dist > maxDist) continue; // skip the node if it's farther than we ever need\n\n queue.push({\n node: child,\n dist: dist\n });\n }\n\n while (queue.length && !queue.peek().node.children) {\n var item = queue.pop();\n var p = item.node;\n\n // skip all points that are as close to adjacent edges (a,b) and (c,d),\n // and points that would introduce self-intersections when connected\n var d0 = sqSegDist(p, a, b);\n var d1 = sqSegDist(p, c, d);\n if (item.dist < d0 && item.dist < d1 &&\n noIntersections(b, p, segTree) &&\n noIntersections(c, p, segTree)) return p;\n }\n\n node = queue.pop();\n if (node) node = node.node;\n }\n\n return null;\n}\n\nfunction compareDist(a, b) {\n return a.dist - b.dist;\n}\n\n// square distance from a segment bounding box to the given one\nfunction sqSegBoxDist(a, b, bbox) {\n if (inside(a, bbox) || inside(b, bbox)) return 0;\n var d1 = sqSegSegDist(a[0], a[1], b[0], b[1], bbox.minX, bbox.minY, bbox.maxX, bbox.minY);\n if (d1 === 0) return 0;\n var d2 = sqSegSegDist(a[0], a[1], b[0], b[1], bbox.minX, bbox.minY, bbox.minX, bbox.maxY);\n if (d2 === 0) return 0;\n var d3 = sqSegSegDist(a[0], a[1], b[0], b[1], bbox.maxX, bbox.minY, bbox.maxX, bbox.maxY);\n if (d3 === 0) return 0;\n var d4 = sqSegSegDist(a[0], a[1], b[0], b[1], bbox.minX, bbox.maxY, bbox.maxX, bbox.maxY);\n if (d4 === 0) return 0;\n return Math.min(d1, d2, d3, d4);\n}\n\nfunction inside(a, bbox) {\n return a[0] >= bbox.minX &&\n a[0] <= bbox.maxX &&\n a[1] >= bbox.minY &&\n a[1] <= bbox.maxY;\n}\n\n// check if the edge (a,b) doesn't intersect any other edges\nfunction noIntersections(a, b, segTree) {\n var minX = Math.min(a[0], b[0]);\n var minY = Math.min(a[1], b[1]);\n var maxX = Math.max(a[0], b[0]);\n var maxY = Math.max(a[1], b[1]);\n\n var edges = segTree.search({minX: minX, minY: minY, maxX: maxX, maxY: maxY});\n for (var i = 0; i < edges.length; i++) {\n if (intersects(edges[i].p, edges[i].next.p, a, b)) return false;\n }\n return true;\n}\n\nfunction cross(p1, p2, p3) {\n return orient(p1[0], p1[1], p2[0], p2[1], p3[0], p3[1]);\n}\n\n// check if the edges (p1,q1) and (p2,q2) intersect\nfunction intersects(p1, q1, p2, q2) {\n return p1 !== q2 && q1 !== p2 &&\n cross(p1, q1, p2) > 0 !== cross(p1, q1, q2) > 0 &&\n cross(p2, q2, p1) > 0 !== cross(p2, q2, q1) > 0;\n}\n\n// update the bounding box of a node's edge\nfunction updateBBox(node) {\n var p1 = node.p;\n var p2 = node.next.p;\n node.minX = Math.min(p1[0], p2[0]);\n node.minY = Math.min(p1[1], p2[1]);\n node.maxX = Math.max(p1[0], p2[0]);\n node.maxY = Math.max(p1[1], p2[1]);\n return node;\n}\n\n// speed up convex hull by filtering out points inside quadrilateral formed by 4 extreme points\nfunction fastConvexHull(points) {\n var left = points[0];\n var top = points[0];\n var right = points[0];\n var bottom = points[0];\n\n // find the leftmost, rightmost, topmost and bottommost points\n for (var i = 0; i < points.length; i++) {\n var p = points[i];\n if (p[0] < left[0]) left = p;\n if (p[0] > right[0]) right = p;\n if (p[1] < top[1]) top = p;\n if (p[1] > bottom[1]) bottom = p;\n }\n\n // filter out points that are inside the resulting quadrilateral\n var cull = [left, top, right, bottom];\n var filtered = cull.slice();\n for (i = 0; i < points.length; i++) {\n if (!pointInPolygon(points[i], cull)) filtered.push(points[i]);\n }\n\n // get convex hull around the filtered points\n return convexHull(filtered);\n}\n\n// create a new node in a doubly linked list\nfunction insertNode(p, prev) {\n var node = {\n p: p,\n prev: null,\n next: null,\n minX: 0,\n minY: 0,\n maxX: 0,\n maxY: 0\n };\n\n if (!prev) {\n node.prev = node;\n node.next = node;\n\n } else {\n node.next = prev.next;\n node.prev = prev;\n prev.next.prev = node;\n prev.next = node;\n }\n return node;\n}\n\n// square distance between 2 points\nfunction getSqDist(p1, p2) {\n\n var dx = p1[0] - p2[0],\n dy = p1[1] - p2[1];\n\n return dx * dx + dy * dy;\n}\n\n// square distance from a point to a segment\nfunction sqSegDist(p, p1, p2) {\n\n var x = p1[0],\n y = p1[1],\n dx = p2[0] - x,\n dy = p2[1] - y;\n\n if (dx !== 0 || dy !== 0) {\n\n var t = ((p[0] - x) * dx + (p[1] - y) * dy) / (dx * dx + dy * dy);\n\n if (t > 1) {\n x = p2[0];\n y = p2[1];\n\n } else if (t > 0) {\n x += dx * t;\n y += dy * t;\n }\n }\n\n dx = p[0] - x;\n dy = p[1] - y;\n\n return dx * dx + dy * dy;\n}\n\n// segment to segment distance, ported from http://geomalgorithms.com/a07-_distance.html by Dan Sunday\nfunction sqSegSegDist(x0, y0, x1, y1, x2, y2, x3, y3) {\n var ux = x1 - x0;\n var uy = y1 - y0;\n var vx = x3 - x2;\n var vy = y3 - y2;\n var wx = x0 - x2;\n var wy = y0 - y2;\n var a = ux * ux + uy * uy;\n var b = ux * vx + uy * vy;\n var c = vx * vx + vy * vy;\n var d = ux * wx + uy * wy;\n var e = vx * wx + vy * wy;\n var D = a * c - b * b;\n\n var sc, sN, tc, tN;\n var sD = D;\n var tD = D;\n\n if (D === 0) {\n sN = 0;\n sD = 1;\n tN = e;\n tD = c;\n } else {\n sN = b * e - c * d;\n tN = a * e - b * d;\n if (sN < 0) {\n sN = 0;\n tN = e;\n tD = c;\n } else if (sN > sD) {\n sN = sD;\n tN = e + b;\n tD = c;\n }\n }\n\n if (tN < 0.0) {\n tN = 0.0;\n if (-d < 0.0) sN = 0.0;\n else if (-d > a) sN = sD;\n else {\n sN = -d;\n sD = a;\n }\n } else if (tN > tD) {\n tN = tD;\n if ((-d + b) < 0.0) sN = 0;\n else if (-d + b > a) sN = sD;\n else {\n sN = -d + b;\n sD = a;\n }\n }\n\n sc = sN === 0 ? 0 : sN / sD;\n tc = tN === 0 ? 0 : tN / tD;\n\n var cx = (1 - sc) * x0 + sc * x1;\n var cy = (1 - sc) * y0 + sc * y1;\n var cx2 = (1 - tc) * x2 + tc * x3;\n var cy2 = (1 - tc) * y2 + tc * y3;\n var dx = cx2 - cx;\n var dy = cy2 - cy;\n\n return dx * dx + dy * dy;\n}\n\nfunction compareByX(a, b) {\n return a[0] === b[0] ? a[1] - b[1] : a[0] - b[0];\n}\n\nfunction convexHull(points) {\n points.sort(compareByX);\n\n var lower = [];\n for (var i = 0; i < points.length; i++) {\n while (lower.length >= 2 && cross(lower[lower.length - 2], lower[lower.length - 1], points[i]) <= 0) {\n lower.pop();\n }\n lower.push(points[i]);\n }\n\n var upper = [];\n for (var ii = points.length - 1; ii >= 0; ii--) {\n while (upper.length >= 2 && cross(upper[upper.length - 2], upper[upper.length - 1], points[ii]) <= 0) {\n upper.pop();\n }\n upper.push(points[ii]);\n }\n\n upper.pop();\n lower.pop();\n return lower.concat(upper);\n}\n","// index.ts\nimport { polygon } from \"@turf/helpers\";\nimport { coordEach } from \"@turf/meta\";\nimport concaveman from \"concaveman\";\nfunction convex(geojson, options = {}) {\n options.concavity = options.concavity || Infinity;\n const points = [];\n coordEach(geojson, (coord) => {\n points.push([coord[0], coord[1]]);\n });\n if (!points.length) {\n return null;\n }\n const convexHull = concaveman(points, options.concavity);\n if (convexHull.length > 3) {\n return polygon([convexHull]);\n }\n return null;\n}\nvar index_default = convex;\nexport {\n convex,\n index_default as default\n};\n//# sourceMappingURL=index.js.map","// index.ts\nimport { convex } from \"@turf/convex\";\nimport { centroid } from \"@turf/centroid\";\nimport { point } from \"@turf/helpers\";\nimport { getType, getCoord } from \"@turf/invariant\";\nimport { coordEach } from \"@turf/meta\";\nfunction centerOfMass(geojson, options = {}) {\n switch (getType(geojson)) {\n case \"Point\":\n return point(getCoord(geojson), options.properties);\n case \"Polygon\":\n var coords = [];\n coordEach(geojson, function(coord) {\n coords.push(coord);\n });\n var centre = centroid(geojson, { properties: options.properties });\n var translation = centre.geometry.coordinates;\n var sx = 0;\n var sy = 0;\n var sArea = 0;\n var i, pi, pj, xi, xj, yi, yj, a;\n var neutralizedPoints = coords.map(function(point2) {\n return [point2[0] - translation[0], point2[1] - translation[1]];\n });\n for (i = 0; i < coords.length - 1; i++) {\n pi = neutralizedPoints[i];\n xi = pi[0];\n yi = pi[1];\n pj = neutralizedPoints[i + 1];\n xj = pj[0];\n yj = pj[1];\n a = xi * yj - xj * yi;\n sArea += a;\n sx += (xi + xj) * a;\n sy += (yi + yj) * a;\n }\n if (sArea === 0) {\n return centre;\n } else {\n var area = sArea * 0.5;\n var areaFactor = 1 / (6 * area);\n return point(\n [translation[0] + areaFactor * sx, translation[1] + areaFactor * sy],\n options.properties\n );\n }\n default:\n var hull = convex(geojson);\n if (hull) return centerOfMass(hull, { properties: options.properties });\n else return centroid(geojson, { properties: options.properties });\n }\n}\nvar index_default = centerOfMass;\nexport {\n centerOfMass,\n index_default as default\n};\n//# sourceMappingURL=index.js.map","// index.ts\nfunction clone(geojson) {\n if (!geojson) {\n throw new Error(\"geojson is required\");\n }\n switch (geojson.type) {\n case \"Feature\":\n return cloneFeature(geojson);\n case \"FeatureCollection\":\n return cloneFeatureCollection(geojson);\n case \"Point\":\n case \"LineString\":\n case \"Polygon\":\n case \"MultiPoint\":\n case \"MultiLineString\":\n case \"MultiPolygon\":\n case \"GeometryCollection\":\n return cloneGeometry(geojson);\n default:\n throw new Error(\"unknown GeoJSON type\");\n }\n}\nfunction cloneFeature(geojson) {\n const cloned = { type: \"Feature\" };\n Object.keys(geojson).forEach((key) => {\n switch (key) {\n case \"type\":\n case \"properties\":\n case \"geometry\":\n return;\n default:\n cloned[key] = geojson[key];\n }\n });\n cloned.properties = cloneProperties(geojson.properties);\n if (geojson.geometry == null) {\n cloned.geometry = null;\n } else {\n cloned.geometry = cloneGeometry(geojson.geometry);\n }\n return cloned;\n}\nfunction cloneProperties(properties) {\n const cloned = {};\n if (!properties) {\n return cloned;\n }\n Object.keys(properties).forEach((key) => {\n const value = properties[key];\n if (typeof value === \"object\") {\n if (value === null) {\n cloned[key] = null;\n } else if (Array.isArray(value)) {\n cloned[key] = value.map((item) => {\n return item;\n });\n } else {\n cloned[key] = cloneProperties(value);\n }\n } else {\n cloned[key] = value;\n }\n });\n return cloned;\n}\nfunction cloneFeatureCollection(geojson) {\n const cloned = { type: \"FeatureCollection\" };\n Object.keys(geojson).forEach((key) => {\n switch (key) {\n case \"type\":\n case \"features\":\n return;\n default:\n cloned[key] = geojson[key];\n }\n });\n cloned.features = geojson.features.map((feature) => {\n return cloneFeature(feature);\n });\n return cloned;\n}\nfunction cloneGeometry(geometry) {\n const geom = { type: geometry.type };\n if (geometry.bbox) {\n geom.bbox = geometry.bbox;\n }\n if (geometry.type === \"GeometryCollection\") {\n geom.geometries = geometry.geometries.map((g) => {\n return cloneGeometry(g);\n });\n return geom;\n }\n geom.coordinates = deepSlice(geometry.coordinates);\n return geom;\n}\nfunction deepSlice(coords) {\n const cloned = coords;\n if (typeof cloned[0] !== \"object\") {\n return cloned.slice();\n }\n return cloned.map((coord) => {\n return deepSlice(coord);\n });\n}\nvar index_default = clone;\nexport {\n clone,\n cloneProperties,\n index_default as default\n};\n//# sourceMappingURL=index.js.map","// index.ts\nimport { convertLength, earthRadius } from \"@turf/helpers\";\nimport { getCoord } from \"@turf/invariant\";\nfunction rhumbDistance(from, to, options = {}) {\n const origin = getCoord(from);\n const destination = getCoord(to);\n destination[0] += destination[0] - origin[0] > 180 ? -360 : origin[0] - destination[0] > 180 ? 360 : 0;\n const distanceInMeters = calculateRhumbDistance(origin, destination);\n const distance = convertLength(distanceInMeters, \"meters\", options.units);\n return distance;\n}\nfunction calculateRhumbDistance(origin, destination, radius) {\n radius = radius === void 0 ? earthRadius : Number(radius);\n const R = radius;\n const phi1 = origin[1] * Math.PI / 180;\n const phi2 = destination[1] * Math.PI / 180;\n const DeltaPhi = phi2 - phi1;\n let DeltaLambda = Math.abs(destination[0] - origin[0]) * Math.PI / 180;\n if (DeltaLambda > Math.PI) {\n DeltaLambda -= 2 * Math.PI;\n }\n const DeltaPsi = Math.log(\n Math.tan(phi2 / 2 + Math.PI / 4) / Math.tan(phi1 / 2 + Math.PI / 4)\n );\n const q = Math.abs(DeltaPsi) > 1e-11 ? DeltaPhi / DeltaPsi : Math.cos(phi1);\n const delta = Math.sqrt(\n DeltaPhi * DeltaPhi + q * q * DeltaLambda * DeltaLambda\n );\n const dist = delta * R;\n return dist;\n}\nvar index_default = rhumbDistance;\nexport {\n index_default as default,\n rhumbDistance\n};\n//# sourceMappingURL=index.js.map","// index.ts\nimport {\n convertLength,\n degreesToRadians,\n earthRadius,\n point\n} from \"@turf/helpers\";\nimport { getCoord } from \"@turf/invariant\";\nfunction rhumbDestination(origin, distance, bearing, options = {}) {\n const wasNegativeDistance = distance < 0;\n let distanceInMeters = convertLength(\n Math.abs(distance),\n options.units,\n \"meters\"\n );\n if (wasNegativeDistance) distanceInMeters = -Math.abs(distanceInMeters);\n const coords = getCoord(origin);\n const destination = calculateRhumbDestination(\n coords,\n distanceInMeters,\n bearing\n );\n destination[0] += destination[0] - coords[0] > 180 ? -360 : coords[0] - destination[0] > 180 ? 360 : 0;\n return point(destination, options.properties);\n}\nfunction calculateRhumbDestination(origin, distance, bearing, radius) {\n radius = radius === void 0 ? earthRadius : Number(radius);\n const delta = distance / radius;\n const lambda1 = origin[0] * Math.PI / 180;\n const phi1 = degreesToRadians(origin[1]);\n const theta = degreesToRadians(bearing);\n const DeltaPhi = delta * Math.cos(theta);\n let phi2 = phi1 + DeltaPhi;\n if (Math.abs(phi2) > Math.PI / 2) {\n phi2 = phi2 > 0 ? Math.PI - phi2 : -Math.PI - phi2;\n }\n const DeltaPsi = Math.log(\n Math.tan(phi2 / 2 + Math.PI / 4) / Math.tan(phi1 / 2 + Math.PI / 4)\n );\n const q = Math.abs(DeltaPsi) > 1e-11 ? DeltaPhi / DeltaPsi : Math.cos(phi1);\n const DeltaLambda = delta * Math.sin(theta) / q;\n const lambda2 = lambda1 + DeltaLambda;\n return [\n (lambda2 * 180 / Math.PI + 540) % 360 - 180,\n phi2 * 180 / Math.PI\n ];\n}\nvar index_default = rhumbDestination;\nexport {\n index_default as default,\n rhumbDestination\n};\n//# sourceMappingURL=index.js.map","// index.ts\nimport { centroid } from \"@turf/centroid\";\nimport { rhumbBearing } from \"@turf/rhumb-bearing\";\nimport { rhumbDistance } from \"@turf/rhumb-distance\";\nimport { rhumbDestination } from \"@turf/rhumb-destination\";\nimport { clone } from \"@turf/clone\";\nimport { coordEach } from \"@turf/meta\";\nimport { getCoords } from \"@turf/invariant\";\nimport { isObject } from \"@turf/helpers\";\nfunction transformRotate(geojson, angle, options) {\n options = options || {};\n if (!isObject(options)) throw new Error(\"options is invalid\");\n const pivot = options.pivot;\n const mutate = options.mutate;\n if (!geojson) throw new Error(\"geojson is required\");\n if (angle === void 0 || angle === null || isNaN(angle))\n throw new Error(\"angle is required\");\n if (angle === 0) return geojson;\n const pivotCoord = pivot != null ? pivot : centroid(geojson);\n if (mutate === false || mutate === void 0) geojson = clone(geojson);\n coordEach(geojson, function(pointCoords) {\n const initialAngle = rhumbBearing(pivotCoord, pointCoords);\n const finalAngle = initialAngle + angle;\n const distance = rhumbDistance(pivotCoord, pointCoords);\n const newCoords = getCoords(\n rhumbDestination(pivotCoord, distance, finalAngle)\n );\n pointCoords[0] = newCoords[0];\n pointCoords[1] = newCoords[1];\n });\n return geojson;\n}\nvar index_default = transformRotate;\nexport {\n index_default as default,\n transformRotate\n};\n//# sourceMappingURL=index.js.map","// index.ts\nimport { distance } from \"@turf/distance\";\nimport { segmentReduce } from \"@turf/meta\";\nfunction length(geojson, options = {}) {\n return segmentReduce(\n geojson,\n (previousValue, segment) => {\n const coords = segment.geometry.coordinates;\n return previousValue + distance(coords[0], coords[1], options);\n },\n 0\n );\n}\nvar index_default = length;\nexport {\n index_default as default,\n length\n};\n//# sourceMappingURL=index.js.map","// index.ts\nimport { bbox as turfBBox } from \"@turf/bbox\";\nimport { getCoords, getGeom } from \"@turf/invariant\";\nimport { polygon, multiPolygon, lineString } from \"@turf/helpers\";\nimport { clone } from \"@turf/clone\";\nfunction lineToPolygon(lines, options = {}) {\n var _a, _b, _c;\n var properties = options.properties;\n var autoComplete = (_a = options.autoComplete) != null ? _a : true;\n var orderCoords = (_b = options.orderCoords) != null ? _b : true;\n var mutate = (_c = options.mutate) != null ? _c : false;\n if (!mutate) {\n lines = clone(lines);\n }\n switch (lines.type) {\n case \"FeatureCollection\":\n var coords = [];\n lines.features.forEach(function(line) {\n coords.push(\n getCoords(lineStringToPolygon(line, {}, autoComplete, orderCoords))\n );\n });\n return multiPolygon(coords, properties);\n default:\n return lineStringToPolygon(lines, properties, autoComplete, orderCoords);\n }\n}\nfunction lineStringToPolygon(line, properties, autoComplete, orderCoords) {\n properties = properties ? properties : line.type === \"Feature\" ? line.properties : {};\n var geom = getGeom(line);\n var coords = geom.coordinates;\n var type = geom.type;\n if (!coords.length) throw new Error(\"line must contain coordinates\");\n switch (type) {\n case \"LineString\":\n if (autoComplete) coords = autoCompleteCoords(coords);\n return polygon([coords], properties);\n case \"MultiLineString\":\n var multiCoords = [];\n var largestArea = 0;\n coords.forEach(function(coord) {\n if (autoComplete) coord = autoCompleteCoords(coord);\n if (orderCoords) {\n var area = calculateArea(turfBBox(lineString(coord)));\n if (area > largestArea) {\n multiCoords.unshift(coord);\n largestArea = area;\n } else multiCoords.push(coord);\n } else {\n multiCoords.push(coord);\n }\n });\n return polygon(multiCoords, properties);\n default:\n throw new Error(\"geometry type \" + type + \" is not supported\");\n }\n}\nfunction autoCompleteCoords(coords) {\n var first = coords[0];\n var x1 = first[0];\n var y1 = first[1];\n var last = coords[coords.length - 1];\n var x2 = last[0];\n var y2 = last[1];\n if (x1 !== x2 || y1 !== y2) {\n coords.push(first);\n }\n return coords;\n}\nfunction calculateArea(bbox) {\n var west = bbox[0];\n var south = bbox[1];\n var east = bbox[2];\n var north = bbox[3];\n return Math.abs(west - east) * Math.abs(south - north);\n}\nvar index_default = lineToPolygon;\nexport {\n index_default as default,\n lineToPolygon\n};\n//# sourceMappingURL=index.js.map","import { envelope, featureCollection, point } from '@turf/turf'\nimport type { BBox } from 'geojson'\nimport type { Map } from 'mapbox-gl'\n\n/**\n * 将物理距离(米)转换为当前地图层级下的屏幕像素(px)\n * @param map Mapbox 地图实例\n * @param distance 距离(单位:米)\n * @param latitude 计算基准纬度(默认取当前地图中心)\n */\nexport function distanceToPx(map: Map, distance: number, latitude?: number): number {\n const EARTH_CIRCUMFERENCE = 40075017\n\n const lat = latitude ?? map.getCenter().lat\n\n const zoom = map.getZoom()\n\n const latRad = lat * (Math.PI / 180)\n const metersPerPixel = (EARTH_CIRCUMFERENCE * Math.cos(latRad)) / Math.pow(2, zoom + 9)\n\n return distance / metersPerPixel\n}\n\nexport function getPointScope(map: Map, x: number, y: number, width: number): BBox {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n return envelope(\n featureCollection([\n point(map.unproject([x - width / 2, y - width / 2]).toArray()),\n point(map.unproject([x + width / 2, y + width / 2]).toArray()),\n ]),\n ).bbox!\n}\n\nexport async function convertSvgToImageObjects(\n svgString: string,\n width?: number,\n height?: number,\n): Promise<{\n image: HTMLImageElement\n bitmap: ImageBitmap\n imageData: ImageData\n}> {\n // 1. 创建一个临时的Image对象并加载SVG\n const loadSvgAsImage = (svgStr: string): Promise<HTMLImageElement> => {\n return new Promise((resolve, reject) => {\n // 将SVG字符串转换为Blob URL\n const blob = new Blob([svgStr], { type: 'image/svg+xml;charset=utf-8' })\n const url = URL.createObjectURL(blob)\n\n const img = new Image()\n img.crossOrigin = 'anonymous' // 重要:避免转换后canvas被\"污染\"\n\n img.onload = (): void => {\n URL.revokeObjectURL(url) // 清理URL,释放内存\n resolve(img)\n }\n\n img.onerror = (event): void => {\n URL.revokeObjectURL(url)\n reject(new Error(`SVG图片加载失败:${JSON.stringify(event)}`))\n }\n\n img.src = url\n })\n }\n\n const svgImage = await loadSvgAsImage(svgString)\n\n // 2. 确定输出尺寸\n const outputWidth = (width ?? svgImage.naturalWidth) || svgImage.width || 300\n const outputHeight = (height ?? svgImage.naturalHeight) || svgImage.height || 150\n\n // 3. 绘制到Canvas\n const canvas = document.createElement('canvas')\n canvas.width = outputWidth\n canvas.height = outputHeight\n\n const ctx = canvas.getContext('2d')\n if (!ctx) {\n throw new Error('无法获取Canvas 2D上下文')\n }\n\n // 清空并绘制SVG\n ctx.clearRect(0, 0, outputWidth, outputHeight)\n ctx.drawImage(svgImage, 0, 0, outputWidth, outputHeight)\n\n // 4. 并行转换获取所有目标格式\n const [bitmap, imageData] = await Promise.all([\n // 转换为ImageBitmap\n createImageBitmap(canvas),\n // 转换为ImageData\n Promise.resolve(ctx.getImageData(0, 0, outputWidth, outputHeight)),\n ])\n\n return {\n image: svgImage, // HTMLImageElement\n bitmap: bitmap, // ImageBitmap\n imageData: imageData, // ImageData\n }\n}\n\n/**\n * 将屏幕像素转换为地理距离(米)\n * @param map Mapbox 地图实例\n * @param lat 当前纬度\n * @param pixels 想要显示的像素长度\n */\nexport function pixelsToMeters(map: Map, lat: number, pixels: number): number {\n const EARTH_CIRCUMFERENCE = 40075017 // 地球赤道周长 (米)\n const zoom = map.getZoom()\n const latRad = (lat * Math.PI) / 180\n\n // 计算当前纬度和缩放下的分辨率 (米/像素)\n // Mapbox 使用 512px 的瓦片大小,所以是 2^(zoom + 9)\n const metersPerPx = (EARTH_CIRCUMFERENCE * Math.cos(latRad)) / Math.pow(2, zoom + 9)\n\n return pixels * metersPerPx\n}\n","import type { Map as MapboxMap } from 'mapbox-gl'\n\nimport { cacheKey } from '@/config'\nimport Cache from '@/core/Cache'\nimport type { Icon, Image, result, SvgIcon } from '@/types/IconManager'\nimport { RESULT_CODE } from '@/types/IconManager'\nimport { convertSvgToImageObjects } from '@/utils/util.ts'\n\nclass IconManager {\n static SUCCESS = RESULT_CODE.SUCCESS\n static FAIL = RESULT_CODE.FAIL\n\n _map: MapboxMap\n _cache: Cache = new Cache({ uniqueKey: `${cacheKey}-icon`, type: 'localstorage' })\n\n // 🌟 核心修复:并发加载锁。防止同一时间多次请求同一个图标\n private loadingPromises = new Map<string, Promise<result>>()\n\n constructor(map: MapboxMap) {\n this._map = map\n }\n\n async load(icons: Icon[]): Promise<{ success: result[]; error: result[] }> {\n const results = await Promise.allSettled(icons.map((icon) => this.add(icon)))\n\n const success: result[] = []\n const error: result[] = []\n\n results.forEach((item) => {\n if (item.status === 'fulfilled') {\n success.push(item.value)\n } else {\n error.push(item.reason as result)\n }\n })\n\n return { success, error }\n }\n\n async loadSvg(icons: SvgIcon[]): Promise<{ success: result[]; error: result[] }> {\n const results = await Promise.allSettled(icons.map((icon) => this.addSvg(icon)))\n\n const success: result[] = []\n const error: result[] = []\n\n results.forEach((item) => {\n if (item.status === 'fulfilled') {\n success.push(item.value)\n } else {\n error.push(item.reason as result)\n }\n })\n\n return { success, error }\n }\n\n async addSvg(icon: SvgIcon): Promise<result> {\n // 1. 如果地图已经加载过了,直接返回\n if (this.has(icon.name)) {\n return this.error(icon, 'The image has been loaded!')\n }\n\n // 2. 如果该图标刚好正在加载中(被其他实例触发了),直接挂载到现有的 Promise 上等待\n if (this.loadingPromises.has(icon.name)) {\n return this.loadingPromises.get(icon.name)!\n }\n\n // 3. 定义并触发真实的加载任务\n const loadTask = (async (): Promise<result> => {\n try {\n const data = await convertSvgToImageObjects(icon.svg)\n\n // 🌟 核心修复:异步操作回来后,再次进行双重检查 (Double-check)\n if (!this.has(icon.name)) {\n this._cache.set({\n name: icon.name,\n content: { width: data.image.width, height: data.image.height, image: data.image },\n })\n this._map.addImage(icon.name, data.image)\n }\n return this.success(icon)\n } catch (err: any) {\n return this.error(icon, err as unknown as string)\n } finally {\n // 无论成功还是失败,执行完毕后释放并发锁\n this.loadingPromises.delete(icon.name)\n }\n })()\n\n // 存入锁字典\n this.loadingPromises.set(icon.name, loadTask)\n return loadTask\n }\n\n add(icon: Icon): Promise<result> {\n // 1. 同步拦截\n if (this.has(icon.name)) {\n return Promise.resolve(this.error(icon, 'The image has been loaded!'))\n }\n\n // 2. 并发锁拦截\n if (this.loadingPromises.has(icon.name)) {\n return this.loadingPromises.get(icon.name)!\n }\n\n const loadTask = new Promise<result>((resolve, reject) => {\n this._map.loadImage(icon.url, (err, image) => {\n // 结束时清理锁\n this.loadingPromises.delete(icon.name)\n\n if (err) {\n // eslint-disable-next-line @typescript-eslint/prefer-promise-reject-errors\n reject(this.error(icon, err as unknown as string))\n return\n }\n\n if (image) {\n // 🌟 核心修复:双重检查\n if (!this.has(icon.name)) {\n this._cache.set({\n name: icon.name,\n content: { width: image.width, height: image.height, image },\n })\n this._map.addImage(icon.name, image, icon.options)\n }\n resolve(this.success(icon))\n } else {\n // eslint-disable-next-line @typescript-eslint/prefer-promise-reject-errors\n reject(this.error(icon, 'The image has not found!'))\n }\n })\n })\n\n this.loadingPromises.set(icon.name, loadTask)\n return loadTask\n }\n\n has(name: Icon['name']): boolean {\n return this._map.hasImage(name)\n }\n\n getImage(name: string): Image | undefined {\n return this._cache.get(name) as Image | undefined\n }\n\n update(icon: Icon): Promise<result> {\n return new Promise((resolve, reject) => {\n if (!this._map.hasImage(icon.name)) {\n // eslint-disable-next-line @typescript-eslint/prefer-promise-reject-errors\n reject(this.error(icon, 'The image has not been loaded!'))\n return\n }\n\n this._map.loadImage(icon.url, (err, image) => {\n if (err) {\n // eslint-disable-next-line @typescript-eslint/prefer-promise-reject-errors\n reject(this.error(icon, err as unknown as string))\n return\n }\n\n if (image) {\n this._cache.set({\n name: icon.name,\n content: { width: image.width, height: image.height },\n })\n this._map.updateImage(icon.name, image)\n resolve(this.success(icon))\n } else {\n // eslint-disable-next-line @typescript-eslint/prefer-promise-reject-errors\n reject(this.error(icon, 'The image has not found!'))\n }\n })\n })\n }\n\n delete(name: string): void {\n if (this._map.hasImage(name)) {\n this._map.removeImage(name)\n this._cache.remove(name)\n }\n }\n\n success(icon: Icon | SvgIcon): result {\n return {\n code: IconManager.SUCCESS,\n data: icon,\n msg: `The ${icon.name} was successfully added`,\n }\n }\n\n error(icon: Icon | SvgIcon, err: string | Error): result {\n return {\n code: IconManager.FAIL,\n data: icon,\n msg: err,\n }\n }\n}\n\nexport default IconManager\n","'use strict';\n\nvar has = Object.prototype.hasOwnProperty\n , prefix = '~';\n\n/**\n * Constructor to create a storage for our `EE` objects.\n * An `Events` instance is a plain object whose properties are event names.\n *\n * @constructor\n * @private\n */\nfunction Events() {}\n\n//\n// We try to not inherit from `Object.prototype`. In some engines creating an\n// instance in this way is faster than calling `Object.create(null)` directly.\n// If `Object.create(null)` is not supported we prefix the event names with a\n// character to make sure that the built-in object properties are not\n// overridden or used as an attack vector.\n//\nif (Object.create) {\n Events.prototype = Object.create(null);\n\n //\n // This hack is needed because the `__proto__` property is still inherited in\n // some old browsers like Android 4, iPhone 5.1, Opera 11 and Safari 5.\n //\n if (!new Events().__proto__) prefix = false;\n}\n\n/**\n * Representation of a single event listener.\n *\n * @param {Function} fn The listener function.\n * @param {*} context The context to invoke the listener with.\n * @param {Boolean} [once=false] Specify if the listener is a one-time listener.\n * @constructor\n * @private\n */\nfunction EE(fn, context, once) {\n this.fn = fn;\n this.context = context;\n this.once = once || false;\n}\n\n/**\n * Add a listener for a given event.\n *\n * @param {EventEmitter} emitter Reference to the `EventEmitter` instance.\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} context The context to invoke the listener with.\n * @param {Boolean} once Specify if the listener is a one-time listener.\n * @returns {EventEmitter}\n * @private\n */\nfunction addListener(emitter, event, fn, context, once) {\n if (typeof fn !== 'function') {\n throw new TypeError('The listener must be a function');\n }\n\n var listener = new EE(fn, context || emitter, once)\n , evt = prefix ? prefix + event : event;\n\n if (!emitter._events[evt]) emitter._events[evt] = listener, emitter._eventsCount++;\n else if (!emitter._events[evt].fn) emitter._events[evt].push(listener);\n else emitter._events[evt] = [emitter._events[evt], listener];\n\n return emitter;\n}\n\n/**\n * Clear event by name.\n *\n * @param {EventEmitter} emitter Reference to the `EventEmitter` instance.\n * @param {(String|Symbol)} evt The Event name.\n * @private\n */\nfunction clearEvent(emitter, evt) {\n if (--emitter._eventsCount === 0) emitter._events = new Events();\n else delete emitter._events[evt];\n}\n\n/**\n * Minimal `EventEmitter` interface that is molded against the Node.js\n * `EventEmitter` interface.\n *\n * @constructor\n * @public\n */\nfunction EventEmitter() {\n this._events = new Events();\n this._eventsCount = 0;\n}\n\n/**\n * Return an array listing the events for which the emitter has registered\n * listeners.\n *\n * @returns {Array}\n * @public\n */\nEventEmitter.prototype.eventNames = function eventNames() {\n var names = []\n , events\n , name;\n\n if (this._eventsCount === 0) return names;\n\n for (name in (events = this._events)) {\n if (has.call(events, name)) names.push(prefix ? name.slice(1) : name);\n }\n\n if (Object.getOwnPropertySymbols) {\n return names.concat(Object.getOwnPropertySymbols(events));\n }\n\n return names;\n};\n\n/**\n * Return the listeners registered for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Array} The registered listeners.\n * @public\n */\nEventEmitter.prototype.listeners = function listeners(event) {\n var evt = prefix ? prefix + event : event\n , handlers = this._events[evt];\n\n if (!handlers) return [];\n if (handlers.fn) return [handlers.fn];\n\n for (var i = 0, l = handlers.length, ee = new Array(l); i < l; i++) {\n ee[i] = handlers[i].fn;\n }\n\n return ee;\n};\n\n/**\n * Return the number of listeners listening to a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Number} The number of listeners.\n * @public\n */\nEventEmitter.prototype.listenerCount = function listenerCount(event) {\n var evt = prefix ? prefix + event : event\n , listeners = this._events[evt];\n\n if (!listeners) return 0;\n if (listeners.fn) return 1;\n return listeners.length;\n};\n\n/**\n * Calls each of the listeners registered for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @returns {Boolean} `true` if the event had listeners, else `false`.\n * @public\n */\nEventEmitter.prototype.emit = function emit(event, a1, a2, a3, a4, a5) {\n var evt = prefix ? prefix + event : event;\n\n if (!this._events[evt]) return false;\n\n var listeners = this._events[evt]\n , len = arguments.length\n , args\n , i;\n\n if (listeners.fn) {\n if (listeners.once) this.removeListener(event, listeners.fn, undefined, true);\n\n switch (len) {\n case 1: return listeners.fn.call(listeners.context), true;\n case 2: return listeners.fn.call(listeners.context, a1), true;\n case 3: return listeners.fn.call(listeners.context, a1, a2), true;\n case 4: return listeners.fn.call(listeners.context, a1, a2, a3), true;\n case 5: return listeners.fn.call(listeners.context, a1, a2, a3, a4), true;\n case 6: return listeners.fn.call(listeners.context, a1, a2, a3, a4, a5), true;\n }\n\n for (i = 1, args = new Array(len -1); i < len; i++) {\n args[i - 1] = arguments[i];\n }\n\n listeners.fn.apply(listeners.context, args);\n } else {\n var length = listeners.length\n , j;\n\n for (i = 0; i < length; i++) {\n if (listeners[i].once) this.removeListener(event, listeners[i].fn, undefined, true);\n\n switch (len) {\n case 1: listeners[i].fn.call(listeners[i].context); break;\n case 2: listeners[i].fn.call(listeners[i].context, a1); break;\n case 3: listeners[i].fn.call(listeners[i].context, a1, a2); break;\n case 4: listeners[i].fn.call(listeners[i].context, a1, a2, a3); break;\n default:\n if (!args) for (j = 1, args = new Array(len -1); j < len; j++) {\n args[j - 1] = arguments[j];\n }\n\n listeners[i].fn.apply(listeners[i].context, args);\n }\n }\n }\n\n return true;\n};\n\n/**\n * Add a listener for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} [context=this] The context to invoke the listener with.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.on = function on(event, fn, context) {\n return addListener(this, event, fn, context, false);\n};\n\n/**\n * Add a one-time listener for a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn The listener function.\n * @param {*} [context=this] The context to invoke the listener with.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.once = function once(event, fn, context) {\n return addListener(this, event, fn, context, true);\n};\n\n/**\n * Remove the listeners of a given event.\n *\n * @param {(String|Symbol)} event The event name.\n * @param {Function} fn Only remove the listeners that match this function.\n * @param {*} context Only remove the listeners that have this context.\n * @param {Boolean} once Only remove one-time listeners.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.removeListener = function removeListener(event, fn, context, once) {\n var evt = prefix ? prefix + event : event;\n\n if (!this._events[evt]) return this;\n if (!fn) {\n clearEvent(this, evt);\n return this;\n }\n\n var listeners = this._events[evt];\n\n if (listeners.fn) {\n if (\n listeners.fn === fn &&\n (!once || listeners.once) &&\n (!context || listeners.context === context)\n ) {\n clearEvent(this, evt);\n }\n } else {\n for (var i = 0, events = [], length = listeners.length; i < length; i++) {\n if (\n listeners[i].fn !== fn ||\n (once && !listeners[i].once) ||\n (context && listeners[i].context !== context)\n ) {\n events.push(listeners[i]);\n }\n }\n\n //\n // Reset the array, or remove it completely if we have no more listeners.\n //\n if (events.length) this._events[evt] = events.length === 1 ? events[0] : events;\n else clearEvent(this, evt);\n }\n\n return this;\n};\n\n/**\n * Remove all listeners, or those of the specified event.\n *\n * @param {(String|Symbol)} [event] The event name.\n * @returns {EventEmitter} `this`.\n * @public\n */\nEventEmitter.prototype.removeAllListeners = function removeAllListeners(event) {\n var evt;\n\n if (event) {\n evt = prefix ? prefix + event : event;\n if (this._events[evt]) clearEvent(this, evt);\n } else {\n this._events = new Events();\n this._eventsCount = 0;\n }\n\n return this;\n};\n\n//\n// Alias methods names because people roll like that.\n//\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\nEventEmitter.prototype.addListener = EventEmitter.prototype.on;\n\n//\n// Expose the prefix.\n//\nEventEmitter.prefixed = prefix;\n\n//\n// Allow `EventEmitter` to be imported as module namespace.\n//\nEventEmitter.EventEmitter = EventEmitter;\n\n//\n// Expose the module.\n//\nif ('undefined' !== typeof module) {\n module.exports = EventEmitter;\n}\n","import type { Map as MapboxMap, MapEventType, MapMouseEvent } from 'mapbox-gl'\n\nimport type { EventHandler } from '@/types/EventManager'\n\n// 内部存储结构:FeatureId (统一强转为 string) -> EventType -> Callback[]\ntype ListenerRegistry = Map<string, Map<string, EventHandler[]>>\n\nexport class EventManager {\n private map: MapboxMap\n\n // 业务回调注册表\n private listeners: ListenerRegistry = new Map()\n\n // 记录底层已注册的监听器,防止重复绑定: \"layerId:eventType\" -> Handler\n private activeLayerListeners = new Map<string, (e: any) => void>()\n\n // 记录当前鼠标悬停的 Feature ID,按 layerId 分开记录,支持多图层同时 hover\n private currentHoverIdByLayer = new Map<string, string>()\n\n constructor(map: MapboxMap) {\n this.map = map\n }\n\n /**\n * 注册事件监听\n * @param id 实例/Feature 的 ID\n * @param layerId Mapbox 图层 ID\n * @param eventType 事件类型 (click, mouseenter, contextmenu 等)\n * @param callback 回调函数\n */\n public on(\n id: string | number,\n layerId: string,\n eventType: MapEventType,\n callback: EventHandler,\n ): void {\n // 🌟 修复核心1:强制转换为 String 键值,避免数字与字符串引起的 Map 查找失败\n const key = String(id)\n\n if (!this.listeners.has(key)) {\n this.listeners.set(key, new Map())\n }\n const instanceEvents = this.listeners.get(key)\n\n if (!instanceEvents) {\n console.error('未找到listener')\n return\n }\n\n if (!instanceEvents.has(eventType)) {\n instanceEvents.set(eventType, [])\n }\n\n const callbacks = instanceEvents.get(eventType)\n\n if (!callbacks) {\n return\n }\n\n callbacks.push(callback)\n\n // 确保底层 Mapbox 监听已激活\n this.ensureMapListener(layerId, eventType)\n }\n\n /**\n * 移除事件监听\n * @param id 实例 ID\n * @param eventType (可选) 事件类型,不传则移除该 ID 所有事件\n * @param callback (可选) 指定回调,不传则移除该类型所有回调\n */\n public off(id: string | number, eventType?: MapEventType, callback?: EventHandler): void {\n const key = String(id)\n const instanceEvents = this.listeners.get(key)\n if (!instanceEvents) return\n\n // 情况 A: 移除该 ID 的所有监听\n if (!eventType) {\n this.listeners.delete(key)\n return\n }\n\n const callbacks = instanceEvents.get(eventType)\n if (!callbacks) return\n\n // 情况 B: 移除该 ID 下某类型的所有监听\n if (!callback) {\n instanceEvents.delete(eventType)\n return\n }\n\n // 情况 C: 移除特定回调\n const idx = callbacks.indexOf(callback)\n if (idx !== -1) {\n callbacks.splice(idx, 1)\n }\n\n // 清理空 Map\n if (callbacks.length === 0) instanceEvents.delete(eventType)\n if (instanceEvents.size === 0) this.listeners.delete(key)\n }\n\n /**\n * 确保 Mapbox 底层对该图层的该事件进行了监听\n */\n private ensureMapListener(layerId: string, eventType: MapEventType): void {\n const key = `${layerId}:${eventType}`\n\n if (this.activeLayerListeners.has(key)) return\n\n // 定义底层通用的分发器\n const handler = (e: MapMouseEvent): void => {\n this.dispatch(e, layerId, eventType)\n }\n\n // @ts-expect-error mapbox-gl types mismatch\n this.map.on(eventType, layerId, handler)\n this.activeLayerListeners.set(key, handler)\n\n // mouseleave 依赖 mouseenter 记录 hover 状态,需确保 mouseenter 底层监听也已激活\n if (eventType === 'mouseleave') {\n this.ensureMapListener(layerId, 'mouseenter' as MapEventType)\n }\n }\n\n /**\n * 核心分发逻辑\n */\n private dispatch(e: MapMouseEvent, layerId: string, eventType: MapEventType): void {\n let targetId: string | undefined\n\n if (eventType === 'mouseleave') {\n // mouseleave 无 features,从按图层记录的 hover 状态中取 ID\n const hoverId = this.currentHoverIdByLayer.get(layerId)\n if (hoverId !== undefined) {\n targetId = hoverId\n this.currentHoverIdByLayer.delete(layerId)\n }\n } else {\n // 对于 click, mouseenter 等,从事件中获取 ID\n if (e.features && e.features.length > 0) {\n const feature = e.features[0]\n\n // 优先读取 properties.id:\n // 因为 ResourceRegister 对所有 GeoJSON source 自动注入了 promoteId: 'id',\n // Mapbox 会用 properties.id 替换顶级 feature.id。\n // 顶级 feature.id 在 promoteId 模式下可能为 undefined,所以 properties.id 是唯一可靠来源。\n // ⚠️ 如果你的 feature 没有 properties.id,事件将无法分发!请确保数据侧同步设置 properties.id。\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n const rawId = feature.properties?.id ?? feature.id\n\n if (rawId !== undefined && rawId !== null) {\n targetId = String(rawId)\n }\n }\n }\n\n if (targetId === undefined) return\n\n // 特殊处理 mouseenter:按图层记录当前 hover ID\n if (eventType === 'mouseenter') {\n this.currentHoverIdByLayer.set(layerId, targetId)\n }\n\n // 查找并执行业务层注入的回调(使用快照迭代,防止回调内部修改数组导致的问题)\n const instanceEvents = this.listeners.get(targetId)\n\n if (instanceEvents) {\n const callbacks = instanceEvents.get(eventType)\n if (callbacks) {\n ;[...callbacks].forEach((fn) => {\n fn(e)\n })\n }\n }\n }\n\n /**\n * 销毁管理器\n * 必须在地图销毁前调用,防止内存泄漏\n */\n public destroy(): void {\n // 解绑所有底层 Mapbox 事件\n this.activeLayerListeners.forEach((handler, key) => {\n // 用 lastIndexOf 分割,避免 layerId 本身含 ':' 时解析错误\n const sep = key.lastIndexOf(':')\n const layerId = key.substring(0, sep)\n const eventType = key.substring(sep + 1) as MapEventType\n try {\n this.map.off(eventType, layerId, handler)\n } catch (err) {\n // 忽略地图已销毁导致的错误\n }\n })\n\n this.activeLayerListeners.clear()\n this.listeners.clear()\n this.currentHoverIdByLayer.clear()\n }\n}\n","/** Detect free variable `global` from Node.js. */\nvar freeGlobal = typeof global == 'object' && global && global.Object === Object && global;\n\nexport default freeGlobal;\n","import freeGlobal from './_freeGlobal.js';\n\n/** Detect free variable `self`. */\nvar freeSelf = typeof self == 'object' && self && self.Object === Object && self;\n\n/** Used as a reference to the global object. */\nvar root = freeGlobal || freeSelf || Function('return this')();\n\nexport default root;\n","import root from './_root.js';\n\n/** Built-in value references. */\nvar Symbol = root.Symbol;\n\nexport default Symbol;\n","import Symbol from './_Symbol.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the raw `toStringTag`.\n */\nfunction getRawTag(value) {\n var isOwn = hasOwnProperty.call(value, symToStringTag),\n tag = value[symToStringTag];\n\n try {\n value[symToStringTag] = undefined;\n var unmasked = true;\n } catch (e) {}\n\n var result = nativeObjectToString.call(value);\n if (unmasked) {\n if (isOwn) {\n value[symToStringTag] = tag;\n } else {\n delete value[symToStringTag];\n }\n }\n return result;\n}\n\nexport default getRawTag;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Used to resolve the\n * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)\n * of values.\n */\nvar nativeObjectToString = objectProto.toString;\n\n/**\n * Converts `value` to a string using `Object.prototype.toString`.\n *\n * @private\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n */\nfunction objectToString(value) {\n return nativeObjectToString.call(value);\n}\n\nexport default objectToString;\n","import Symbol from './_Symbol.js';\nimport getRawTag from './_getRawTag.js';\nimport objectToString from './_objectToString.js';\n\n/** `Object#toString` result references. */\nvar nullTag = '[object Null]',\n undefinedTag = '[object Undefined]';\n\n/** Built-in value references. */\nvar symToStringTag = Symbol ? Symbol.toStringTag : undefined;\n\n/**\n * The base implementation of `getTag` without fallbacks for buggy environments.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nfunction baseGetTag(value) {\n if (value == null) {\n return value === undefined ? undefinedTag : nullTag;\n }\n return (symToStringTag && symToStringTag in Object(value))\n ? getRawTag(value)\n : objectToString(value);\n}\n\nexport default baseGetTag;\n","/**\n * Checks if `value` is object-like. A value is object-like if it's not `null`\n * and has a `typeof` result of \"object\".\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is object-like, else `false`.\n * @example\n *\n * _.isObjectLike({});\n * // => true\n *\n * _.isObjectLike([1, 2, 3]);\n * // => true\n *\n * _.isObjectLike(_.noop);\n * // => false\n *\n * _.isObjectLike(null);\n * // => false\n */\nfunction isObjectLike(value) {\n return value != null && typeof value == 'object';\n}\n\nexport default isObjectLike;\n","import baseGetTag from './_baseGetTag.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar symbolTag = '[object Symbol]';\n\n/**\n * Checks if `value` is classified as a `Symbol` primitive or object.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.\n * @example\n *\n * _.isSymbol(Symbol.iterator);\n * // => true\n *\n * _.isSymbol('abc');\n * // => false\n */\nfunction isSymbol(value) {\n return typeof value == 'symbol' ||\n (isObjectLike(value) && baseGetTag(value) == symbolTag);\n}\n\nexport default isSymbol;\n","/**\n * A specialized version of `_.map` for arrays without support for iteratee\n * shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the new mapped array.\n */\nfunction arrayMap(array, iteratee) {\n var index = -1,\n length = array == null ? 0 : array.length,\n result = Array(length);\n\n while (++index < length) {\n result[index] = iteratee(array[index], index, array);\n }\n return result;\n}\n\nexport default arrayMap;\n","/**\n * Checks if `value` is classified as an `Array` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an array, else `false`.\n * @example\n *\n * _.isArray([1, 2, 3]);\n * // => true\n *\n * _.isArray(document.body.children);\n * // => false\n *\n * _.isArray('abc');\n * // => false\n *\n * _.isArray(_.noop);\n * // => false\n */\nvar isArray = Array.isArray;\n\nexport default isArray;\n","import Symbol from './_Symbol.js';\nimport arrayMap from './_arrayMap.js';\nimport isArray from './isArray.js';\nimport isSymbol from './isSymbol.js';\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolToString = symbolProto ? symbolProto.toString : undefined;\n\n/**\n * The base implementation of `_.toString` which doesn't convert nullish\n * values to empty strings.\n *\n * @private\n * @param {*} value The value to process.\n * @returns {string} Returns the string.\n */\nfunction baseToString(value) {\n // Exit early for strings to avoid a performance hit in some environments.\n if (typeof value == 'string') {\n return value;\n }\n if (isArray(value)) {\n // Recursively convert values (susceptible to call stack limits).\n return arrayMap(value, baseToString) + '';\n }\n if (isSymbol(value)) {\n return symbolToString ? symbolToString.call(value) : '';\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nexport default baseToString;\n","/**\n * Checks if `value` is the\n * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)\n * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an object, else `false`.\n * @example\n *\n * _.isObject({});\n * // => true\n *\n * _.isObject([1, 2, 3]);\n * // => true\n *\n * _.isObject(_.noop);\n * // => true\n *\n * _.isObject(null);\n * // => false\n */\nfunction isObject(value) {\n var type = typeof value;\n return value != null && (type == 'object' || type == 'function');\n}\n\nexport default isObject;\n","import baseGetTag from './_baseGetTag.js';\nimport isObject from './isObject.js';\n\n/** `Object#toString` result references. */\nvar asyncTag = '[object AsyncFunction]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n proxyTag = '[object Proxy]';\n\n/**\n * Checks if `value` is classified as a `Function` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a function, else `false`.\n * @example\n *\n * _.isFunction(_);\n * // => true\n *\n * _.isFunction(/abc/);\n * // => false\n */\nfunction isFunction(value) {\n if (!isObject(value)) {\n return false;\n }\n // The use of `Object#toString` avoids issues with the `typeof` operator\n // in Safari 9 which returns 'object' for typed arrays and other constructors.\n var tag = baseGetTag(value);\n return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;\n}\n\nexport default isFunction;\n","import root from './_root.js';\n\n/** Used to detect overreaching core-js shims. */\nvar coreJsData = root['__core-js_shared__'];\n\nexport default coreJsData;\n","import coreJsData from './_coreJsData.js';\n\n/** Used to detect methods masquerading as native. */\nvar maskSrcKey = (function() {\n var uid = /[^.]+$/.exec(coreJsData && coreJsData.keys && coreJsData.keys.IE_PROTO || '');\n return uid ? ('Symbol(src)_1.' + uid) : '';\n}());\n\n/**\n * Checks if `func` has its source masked.\n *\n * @private\n * @param {Function} func The function to check.\n * @returns {boolean} Returns `true` if `func` is masked, else `false`.\n */\nfunction isMasked(func) {\n return !!maskSrcKey && (maskSrcKey in func);\n}\n\nexport default isMasked;\n","/** Used for built-in method references. */\nvar funcProto = Function.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/**\n * Converts `func` to its source code.\n *\n * @private\n * @param {Function} func The function to convert.\n * @returns {string} Returns the source code.\n */\nfunction toSource(func) {\n if (func != null) {\n try {\n return funcToString.call(func);\n } catch (e) {}\n try {\n return (func + '');\n } catch (e) {}\n }\n return '';\n}\n\nexport default toSource;\n","import isFunction from './isFunction.js';\nimport isMasked from './_isMasked.js';\nimport isObject from './isObject.js';\nimport toSource from './_toSource.js';\n\n/**\n * Used to match `RegExp`\n * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).\n */\nvar reRegExpChar = /[\\\\^$.*+?()[\\]{}|]/g;\n\n/** Used to detect host constructors (Safari). */\nvar reIsHostCtor = /^\\[object .+?Constructor\\]$/;\n\n/** Used for built-in method references. */\nvar funcProto = Function.prototype,\n objectProto = Object.prototype;\n\n/** Used to resolve the decompiled source of functions. */\nvar funcToString = funcProto.toString;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Used to detect if a method is native. */\nvar reIsNative = RegExp('^' +\n funcToString.call(hasOwnProperty).replace(reRegExpChar, '\\\\$&')\n .replace(/hasOwnProperty|(function).*?(?=\\\\\\()| for .+?(?=\\\\\\])/g, '$1.*?') + '$'\n);\n\n/**\n * The base implementation of `_.isNative` without bad shim checks.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a native function,\n * else `false`.\n */\nfunction baseIsNative(value) {\n if (!isObject(value) || isMasked(value)) {\n return false;\n }\n var pattern = isFunction(value) ? reIsNative : reIsHostCtor;\n return pattern.test(toSource(value));\n}\n\nexport default baseIsNative;\n","/**\n * Gets the value at `key` of `object`.\n *\n * @private\n * @param {Object} [object] The object to query.\n * @param {string} key The key of the property to get.\n * @returns {*} Returns the property value.\n */\nfunction getValue(object, key) {\n return object == null ? undefined : object[key];\n}\n\nexport default getValue;\n","import baseIsNative from './_baseIsNative.js';\nimport getValue from './_getValue.js';\n\n/**\n * Gets the native function at `key` of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {string} key The key of the method to get.\n * @returns {*} Returns the function if it's native, else `undefined`.\n */\nfunction getNative(object, key) {\n var value = getValue(object, key);\n return baseIsNative(value) ? value : undefined;\n}\n\nexport default getNative;\n","import getNative from './_getNative.js';\nimport root from './_root.js';\n\n/* Built-in method references that are verified to be native. */\nvar WeakMap = getNative(root, 'WeakMap');\n\nexport default WeakMap;\n","import isObject from './isObject.js';\n\n/** Built-in value references. */\nvar objectCreate = Object.create;\n\n/**\n * The base implementation of `_.create` without support for assigning\n * properties to the created object.\n *\n * @private\n * @param {Object} proto The object to inherit from.\n * @returns {Object} Returns the new object.\n */\nvar baseCreate = (function() {\n function object() {}\n return function(proto) {\n if (!isObject(proto)) {\n return {};\n }\n if (objectCreate) {\n return objectCreate(proto);\n }\n object.prototype = proto;\n var result = new object;\n object.prototype = undefined;\n return result;\n };\n}());\n\nexport default baseCreate;\n","import getNative from './_getNative.js';\n\nvar defineProperty = (function() {\n try {\n var func = getNative(Object, 'defineProperty');\n func({}, '', {});\n return func;\n } catch (e) {}\n}());\n\nexport default defineProperty;\n","/**\n * A specialized version of `_.forEach` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns `array`.\n */\nfunction arrayEach(array, iteratee) {\n var index = -1,\n length = array == null ? 0 : array.length;\n\n while (++index < length) {\n if (iteratee(array[index], index, array) === false) {\n break;\n }\n }\n return array;\n}\n\nexport default arrayEach;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/** Used to detect unsigned integer values. */\nvar reIsUint = /^(?:0|[1-9]\\d*)$/;\n\n/**\n * Checks if `value` is a valid array-like index.\n *\n * @private\n * @param {*} value The value to check.\n * @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index.\n * @returns {boolean} Returns `true` if `value` is a valid index, else `false`.\n */\nfunction isIndex(value, length) {\n var type = typeof value;\n length = length == null ? MAX_SAFE_INTEGER : length;\n\n return !!length &&\n (type == 'number' ||\n (type != 'symbol' && reIsUint.test(value))) &&\n (value > -1 && value % 1 == 0 && value < length);\n}\n\nexport default isIndex;\n","import defineProperty from './_defineProperty.js';\n\n/**\n * The base implementation of `assignValue` and `assignMergeValue` without\n * value checks.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction baseAssignValue(object, key, value) {\n if (key == '__proto__' && defineProperty) {\n defineProperty(object, key, {\n 'configurable': true,\n 'enumerable': true,\n 'value': value,\n 'writable': true\n });\n } else {\n object[key] = value;\n }\n}\n\nexport default baseAssignValue;\n","/**\n * Performs a\n * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * comparison between two values to determine if they are equivalent.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to compare.\n * @param {*} other The other value to compare.\n * @returns {boolean} Returns `true` if the values are equivalent, else `false`.\n * @example\n *\n * var object = { 'a': 1 };\n * var other = { 'a': 1 };\n *\n * _.eq(object, object);\n * // => true\n *\n * _.eq(object, other);\n * // => false\n *\n * _.eq('a', 'a');\n * // => true\n *\n * _.eq('a', Object('a'));\n * // => false\n *\n * _.eq(NaN, NaN);\n * // => true\n */\nfunction eq(value, other) {\n return value === other || (value !== value && other !== other);\n}\n\nexport default eq;\n","import baseAssignValue from './_baseAssignValue.js';\nimport eq from './eq.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Assigns `value` to `key` of `object` if the existing value is not equivalent\n * using [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)\n * for equality comparisons.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {string} key The key of the property to assign.\n * @param {*} value The value to assign.\n */\nfunction assignValue(object, key, value) {\n var objValue = object[key];\n if (!(hasOwnProperty.call(object, key) && eq(objValue, value)) ||\n (value === undefined && !(key in object))) {\n baseAssignValue(object, key, value);\n }\n}\n\nexport default assignValue;\n","/** Used as references for various `Number` constants. */\nvar MAX_SAFE_INTEGER = 9007199254740991;\n\n/**\n * Checks if `value` is a valid array-like length.\n *\n * **Note:** This method is loosely based on\n * [`ToLength`](http://ecma-international.org/ecma-262/7.0/#sec-tolength).\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a valid length, else `false`.\n * @example\n *\n * _.isLength(3);\n * // => true\n *\n * _.isLength(Number.MIN_VALUE);\n * // => false\n *\n * _.isLength(Infinity);\n * // => false\n *\n * _.isLength('3');\n * // => false\n */\nfunction isLength(value) {\n return typeof value == 'number' &&\n value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER;\n}\n\nexport default isLength;\n","import isFunction from './isFunction.js';\nimport isLength from './isLength.js';\n\n/**\n * Checks if `value` is array-like. A value is considered array-like if it's\n * not a function and has a `value.length` that's an integer greater than or\n * equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is array-like, else `false`.\n * @example\n *\n * _.isArrayLike([1, 2, 3]);\n * // => true\n *\n * _.isArrayLike(document.body.children);\n * // => true\n *\n * _.isArrayLike('abc');\n * // => true\n *\n * _.isArrayLike(_.noop);\n * // => false\n */\nfunction isArrayLike(value) {\n return value != null && isLength(value.length) && !isFunction(value);\n}\n\nexport default isArrayLike;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/**\n * Checks if `value` is likely a prototype object.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a prototype, else `false`.\n */\nfunction isPrototype(value) {\n var Ctor = value && value.constructor,\n proto = (typeof Ctor == 'function' && Ctor.prototype) || objectProto;\n\n return value === proto;\n}\n\nexport default isPrototype;\n","/**\n * The base implementation of `_.times` without support for iteratee shorthands\n * or max array length checks.\n *\n * @private\n * @param {number} n The number of times to invoke `iteratee`.\n * @param {Function} iteratee The function invoked per iteration.\n * @returns {Array} Returns the array of results.\n */\nfunction baseTimes(n, iteratee) {\n var index = -1,\n result = Array(n);\n\n while (++index < n) {\n result[index] = iteratee(index);\n }\n return result;\n}\n\nexport default baseTimes;\n","import baseGetTag from './_baseGetTag.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]';\n\n/**\n * The base implementation of `_.isArguments`.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n */\nfunction baseIsArguments(value) {\n return isObjectLike(value) && baseGetTag(value) == argsTag;\n}\n\nexport default baseIsArguments;\n","import baseIsArguments from './_baseIsArguments.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/**\n * Checks if `value` is likely an `arguments` object.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is an `arguments` object,\n * else `false`.\n * @example\n *\n * _.isArguments(function() { return arguments; }());\n * // => true\n *\n * _.isArguments([1, 2, 3]);\n * // => false\n */\nvar isArguments = baseIsArguments(function() { return arguments; }()) ? baseIsArguments : function(value) {\n return isObjectLike(value) && hasOwnProperty.call(value, 'callee') &&\n !propertyIsEnumerable.call(value, 'callee');\n};\n\nexport default isArguments;\n","/**\n * This method returns `false`.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {boolean} Returns `false`.\n * @example\n *\n * _.times(2, _.stubFalse);\n * // => [false, false]\n */\nfunction stubFalse() {\n return false;\n}\n\nexport default stubFalse;\n","import root from './_root.js';\nimport stubFalse from './stubFalse.js';\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeIsBuffer = Buffer ? Buffer.isBuffer : undefined;\n\n/**\n * Checks if `value` is a buffer.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a buffer, else `false`.\n * @example\n *\n * _.isBuffer(new Buffer(2));\n * // => true\n *\n * _.isBuffer(new Uint8Array(2));\n * // => false\n */\nvar isBuffer = nativeIsBuffer || stubFalse;\n\nexport default isBuffer;\n","import baseGetTag from './_baseGetTag.js';\nimport isLength from './isLength.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n objectTag = '[object Object]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/** Used to identify `toStringTag` values of typed arrays. */\nvar typedArrayTags = {};\ntypedArrayTags[float32Tag] = typedArrayTags[float64Tag] =\ntypedArrayTags[int8Tag] = typedArrayTags[int16Tag] =\ntypedArrayTags[int32Tag] = typedArrayTags[uint8Tag] =\ntypedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] =\ntypedArrayTags[uint32Tag] = true;\ntypedArrayTags[argsTag] = typedArrayTags[arrayTag] =\ntypedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] =\ntypedArrayTags[dataViewTag] = typedArrayTags[dateTag] =\ntypedArrayTags[errorTag] = typedArrayTags[funcTag] =\ntypedArrayTags[mapTag] = typedArrayTags[numberTag] =\ntypedArrayTags[objectTag] = typedArrayTags[regexpTag] =\ntypedArrayTags[setTag] = typedArrayTags[stringTag] =\ntypedArrayTags[weakMapTag] = false;\n\n/**\n * The base implementation of `_.isTypedArray` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n */\nfunction baseIsTypedArray(value) {\n return isObjectLike(value) &&\n isLength(value.length) && !!typedArrayTags[baseGetTag(value)];\n}\n\nexport default baseIsTypedArray;\n","/**\n * The base implementation of `_.unary` without support for storing metadata.\n *\n * @private\n * @param {Function} func The function to cap arguments for.\n * @returns {Function} Returns the new capped function.\n */\nfunction baseUnary(func) {\n return function(value) {\n return func(value);\n };\n}\n\nexport default baseUnary;\n","import freeGlobal from './_freeGlobal.js';\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Detect free variable `process` from Node.js. */\nvar freeProcess = moduleExports && freeGlobal.process;\n\n/** Used to access faster Node.js helpers. */\nvar nodeUtil = (function() {\n try {\n // Use `util.types` for Node.js 10+.\n var types = freeModule && freeModule.require && freeModule.require('util').types;\n\n if (types) {\n return types;\n }\n\n // Legacy `process.binding('util')` for Node.js < 10.\n return freeProcess && freeProcess.binding && freeProcess.binding('util');\n } catch (e) {}\n}());\n\nexport default nodeUtil;\n","import baseIsTypedArray from './_baseIsTypedArray.js';\nimport baseUnary from './_baseUnary.js';\nimport nodeUtil from './_nodeUtil.js';\n\n/* Node.js helper references. */\nvar nodeIsTypedArray = nodeUtil && nodeUtil.isTypedArray;\n\n/**\n * Checks if `value` is classified as a typed array.\n *\n * @static\n * @memberOf _\n * @since 3.0.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a typed array, else `false`.\n * @example\n *\n * _.isTypedArray(new Uint8Array);\n * // => true\n *\n * _.isTypedArray([]);\n * // => false\n */\nvar isTypedArray = nodeIsTypedArray ? baseUnary(nodeIsTypedArray) : baseIsTypedArray;\n\nexport default isTypedArray;\n","import baseTimes from './_baseTimes.js';\nimport isArguments from './isArguments.js';\nimport isArray from './isArray.js';\nimport isBuffer from './isBuffer.js';\nimport isIndex from './_isIndex.js';\nimport isTypedArray from './isTypedArray.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Creates an array of the enumerable property names of the array-like `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @param {boolean} inherited Specify returning inherited property names.\n * @returns {Array} Returns the array of property names.\n */\nfunction arrayLikeKeys(value, inherited) {\n var isArr = isArray(value),\n isArg = !isArr && isArguments(value),\n isBuff = !isArr && !isArg && isBuffer(value),\n isType = !isArr && !isArg && !isBuff && isTypedArray(value),\n skipIndexes = isArr || isArg || isBuff || isType,\n result = skipIndexes ? baseTimes(value.length, String) : [],\n length = result.length;\n\n for (var key in value) {\n if ((inherited || hasOwnProperty.call(value, key)) &&\n !(skipIndexes && (\n // Safari 9 has enumerable `arguments.length` in strict mode.\n key == 'length' ||\n // Node.js 0.10 has enumerable non-index properties on buffers.\n (isBuff && (key == 'offset' || key == 'parent')) ||\n // PhantomJS 2 has enumerable non-index properties on typed arrays.\n (isType && (key == 'buffer' || key == 'byteLength' || key == 'byteOffset')) ||\n // Skip index properties.\n isIndex(key, length)\n ))) {\n result.push(key);\n }\n }\n return result;\n}\n\nexport default arrayLikeKeys;\n","/**\n * Creates a unary function that invokes `func` with its argument transformed.\n *\n * @private\n * @param {Function} func The function to wrap.\n * @param {Function} transform The argument transform.\n * @returns {Function} Returns the new function.\n */\nfunction overArg(func, transform) {\n return function(arg) {\n return func(transform(arg));\n };\n}\n\nexport default overArg;\n","import overArg from './_overArg.js';\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeKeys = overArg(Object.keys, Object);\n\nexport default nativeKeys;\n","import isPrototype from './_isPrototype.js';\nimport nativeKeys from './_nativeKeys.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * The base implementation of `_.keys` which doesn't treat sparse arrays as dense.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n */\nfunction baseKeys(object) {\n if (!isPrototype(object)) {\n return nativeKeys(object);\n }\n var result = [];\n for (var key in Object(object)) {\n if (hasOwnProperty.call(object, key) && key != 'constructor') {\n result.push(key);\n }\n }\n return result;\n}\n\nexport default baseKeys;\n","import arrayLikeKeys from './_arrayLikeKeys.js';\nimport baseKeys from './_baseKeys.js';\nimport isArrayLike from './isArrayLike.js';\n\n/**\n * Creates an array of the own enumerable property names of `object`.\n *\n * **Note:** Non-object values are coerced to objects. See the\n * [ES spec](http://ecma-international.org/ecma-262/7.0/#sec-object.keys)\n * for more details.\n *\n * @static\n * @since 0.1.0\n * @memberOf _\n * @category Object\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names.\n * @example\n *\n * function Foo() {\n * this.a = 1;\n * this.b = 2;\n * }\n *\n * Foo.prototype.c = 3;\n *\n * _.keys(new Foo);\n * // => ['a', 'b'] (iteration order is not guaranteed)\n *\n * _.keys('hi');\n * // => ['0', '1']\n */\nfunction keys(object) {\n return isArrayLike(object) ? arrayLikeKeys(object) : baseKeys(object);\n}\n\nexport default keys;\n","import isArray from './isArray.js';\nimport isSymbol from './isSymbol.js';\n\n/** Used to match property names within property paths. */\nvar reIsDeepProp = /\\.|\\[(?:[^[\\]]*|([\"'])(?:(?!\\1)[^\\\\]|\\\\.)*?\\1)\\]/,\n reIsPlainProp = /^\\w*$/;\n\n/**\n * Checks if `value` is a property name and not a property path.\n *\n * @private\n * @param {*} value The value to check.\n * @param {Object} [object] The object to query keys on.\n * @returns {boolean} Returns `true` if `value` is a property name, else `false`.\n */\nfunction isKey(value, object) {\n if (isArray(value)) {\n return false;\n }\n var type = typeof value;\n if (type == 'number' || type == 'symbol' || type == 'boolean' ||\n value == null || isSymbol(value)) {\n return true;\n }\n return reIsPlainProp.test(value) || !reIsDeepProp.test(value) ||\n (object != null && value in Object(object));\n}\n\nexport default isKey;\n","import getNative from './_getNative.js';\n\n/* Built-in method references that are verified to be native. */\nvar nativeCreate = getNative(Object, 'create');\n\nexport default nativeCreate;\n","import nativeCreate from './_nativeCreate.js';\n\n/**\n * Removes all key-value entries from the hash.\n *\n * @private\n * @name clear\n * @memberOf Hash\n */\nfunction hashClear() {\n this.__data__ = nativeCreate ? nativeCreate(null) : {};\n this.size = 0;\n}\n\nexport default hashClear;\n","/**\n * Removes `key` and its value from the hash.\n *\n * @private\n * @name delete\n * @memberOf Hash\n * @param {Object} hash The hash to modify.\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction hashDelete(key) {\n var result = this.has(key) && delete this.__data__[key];\n this.size -= result ? 1 : 0;\n return result;\n}\n\nexport default hashDelete;\n","import nativeCreate from './_nativeCreate.js';\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Gets the hash value for `key`.\n *\n * @private\n * @name get\n * @memberOf Hash\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction hashGet(key) {\n var data = this.__data__;\n if (nativeCreate) {\n var result = data[key];\n return result === HASH_UNDEFINED ? undefined : result;\n }\n return hasOwnProperty.call(data, key) ? data[key] : undefined;\n}\n\nexport default hashGet;\n","import nativeCreate from './_nativeCreate.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Checks if a hash value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Hash\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction hashHas(key) {\n var data = this.__data__;\n return nativeCreate ? (data[key] !== undefined) : hasOwnProperty.call(data, key);\n}\n\nexport default hashHas;\n","import nativeCreate from './_nativeCreate.js';\n\n/** Used to stand-in for `undefined` hash values. */\nvar HASH_UNDEFINED = '__lodash_hash_undefined__';\n\n/**\n * Sets the hash `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Hash\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the hash instance.\n */\nfunction hashSet(key, value) {\n var data = this.__data__;\n this.size += this.has(key) ? 0 : 1;\n data[key] = (nativeCreate && value === undefined) ? HASH_UNDEFINED : value;\n return this;\n}\n\nexport default hashSet;\n","import hashClear from './_hashClear.js';\nimport hashDelete from './_hashDelete.js';\nimport hashGet from './_hashGet.js';\nimport hashHas from './_hashHas.js';\nimport hashSet from './_hashSet.js';\n\n/**\n * Creates a hash object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Hash(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `Hash`.\nHash.prototype.clear = hashClear;\nHash.prototype['delete'] = hashDelete;\nHash.prototype.get = hashGet;\nHash.prototype.has = hashHas;\nHash.prototype.set = hashSet;\n\nexport default Hash;\n","/**\n * Removes all key-value entries from the list cache.\n *\n * @private\n * @name clear\n * @memberOf ListCache\n */\nfunction listCacheClear() {\n this.__data__ = [];\n this.size = 0;\n}\n\nexport default listCacheClear;\n","import eq from './eq.js';\n\n/**\n * Gets the index at which the `key` is found in `array` of key-value pairs.\n *\n * @private\n * @param {Array} array The array to inspect.\n * @param {*} key The key to search for.\n * @returns {number} Returns the index of the matched value, else `-1`.\n */\nfunction assocIndexOf(array, key) {\n var length = array.length;\n while (length--) {\n if (eq(array[length][0], key)) {\n return length;\n }\n }\n return -1;\n}\n\nexport default assocIndexOf;\n","import assocIndexOf from './_assocIndexOf.js';\n\n/** Used for built-in method references. */\nvar arrayProto = Array.prototype;\n\n/** Built-in value references. */\nvar splice = arrayProto.splice;\n\n/**\n * Removes `key` and its value from the list cache.\n *\n * @private\n * @name delete\n * @memberOf ListCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction listCacheDelete(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n return false;\n }\n var lastIndex = data.length - 1;\n if (index == lastIndex) {\n data.pop();\n } else {\n splice.call(data, index, 1);\n }\n --this.size;\n return true;\n}\n\nexport default listCacheDelete;\n","import assocIndexOf from './_assocIndexOf.js';\n\n/**\n * Gets the list cache value for `key`.\n *\n * @private\n * @name get\n * @memberOf ListCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction listCacheGet(key) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n return index < 0 ? undefined : data[index][1];\n}\n\nexport default listCacheGet;\n","import assocIndexOf from './_assocIndexOf.js';\n\n/**\n * Checks if a list cache value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf ListCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction listCacheHas(key) {\n return assocIndexOf(this.__data__, key) > -1;\n}\n\nexport default listCacheHas;\n","import assocIndexOf from './_assocIndexOf.js';\n\n/**\n * Sets the list cache `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf ListCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the list cache instance.\n */\nfunction listCacheSet(key, value) {\n var data = this.__data__,\n index = assocIndexOf(data, key);\n\n if (index < 0) {\n ++this.size;\n data.push([key, value]);\n } else {\n data[index][1] = value;\n }\n return this;\n}\n\nexport default listCacheSet;\n","import listCacheClear from './_listCacheClear.js';\nimport listCacheDelete from './_listCacheDelete.js';\nimport listCacheGet from './_listCacheGet.js';\nimport listCacheHas from './_listCacheHas.js';\nimport listCacheSet from './_listCacheSet.js';\n\n/**\n * Creates an list cache object.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction ListCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `ListCache`.\nListCache.prototype.clear = listCacheClear;\nListCache.prototype['delete'] = listCacheDelete;\nListCache.prototype.get = listCacheGet;\nListCache.prototype.has = listCacheHas;\nListCache.prototype.set = listCacheSet;\n\nexport default ListCache;\n","import getNative from './_getNative.js';\nimport root from './_root.js';\n\n/* Built-in method references that are verified to be native. */\nvar Map = getNative(root, 'Map');\n\nexport default Map;\n","import Hash from './_Hash.js';\nimport ListCache from './_ListCache.js';\nimport Map from './_Map.js';\n\n/**\n * Removes all key-value entries from the map.\n *\n * @private\n * @name clear\n * @memberOf MapCache\n */\nfunction mapCacheClear() {\n this.size = 0;\n this.__data__ = {\n 'hash': new Hash,\n 'map': new (Map || ListCache),\n 'string': new Hash\n };\n}\n\nexport default mapCacheClear;\n","/**\n * Checks if `value` is suitable for use as unique object key.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is suitable, else `false`.\n */\nfunction isKeyable(value) {\n var type = typeof value;\n return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')\n ? (value !== '__proto__')\n : (value === null);\n}\n\nexport default isKeyable;\n","import isKeyable from './_isKeyable.js';\n\n/**\n * Gets the data for `map`.\n *\n * @private\n * @param {Object} map The map to query.\n * @param {string} key The reference key.\n * @returns {*} Returns the map data.\n */\nfunction getMapData(map, key) {\n var data = map.__data__;\n return isKeyable(key)\n ? data[typeof key == 'string' ? 'string' : 'hash']\n : data.map;\n}\n\nexport default getMapData;\n","import getMapData from './_getMapData.js';\n\n/**\n * Removes `key` and its value from the map.\n *\n * @private\n * @name delete\n * @memberOf MapCache\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction mapCacheDelete(key) {\n var result = getMapData(this, key)['delete'](key);\n this.size -= result ? 1 : 0;\n return result;\n}\n\nexport default mapCacheDelete;\n","import getMapData from './_getMapData.js';\n\n/**\n * Gets the map value for `key`.\n *\n * @private\n * @name get\n * @memberOf MapCache\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction mapCacheGet(key) {\n return getMapData(this, key).get(key);\n}\n\nexport default mapCacheGet;\n","import getMapData from './_getMapData.js';\n\n/**\n * Checks if a map value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf MapCache\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction mapCacheHas(key) {\n return getMapData(this, key).has(key);\n}\n\nexport default mapCacheHas;\n","import getMapData from './_getMapData.js';\n\n/**\n * Sets the map `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf MapCache\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the map cache instance.\n */\nfunction mapCacheSet(key, value) {\n var data = getMapData(this, key),\n size = data.size;\n\n data.set(key, value);\n this.size += data.size == size ? 0 : 1;\n return this;\n}\n\nexport default mapCacheSet;\n","import mapCacheClear from './_mapCacheClear.js';\nimport mapCacheDelete from './_mapCacheDelete.js';\nimport mapCacheGet from './_mapCacheGet.js';\nimport mapCacheHas from './_mapCacheHas.js';\nimport mapCacheSet from './_mapCacheSet.js';\n\n/**\n * Creates a map cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction MapCache(entries) {\n var index = -1,\n length = entries == null ? 0 : entries.length;\n\n this.clear();\n while (++index < length) {\n var entry = entries[index];\n this.set(entry[0], entry[1]);\n }\n}\n\n// Add methods to `MapCache`.\nMapCache.prototype.clear = mapCacheClear;\nMapCache.prototype['delete'] = mapCacheDelete;\nMapCache.prototype.get = mapCacheGet;\nMapCache.prototype.has = mapCacheHas;\nMapCache.prototype.set = mapCacheSet;\n\nexport default MapCache;\n","import MapCache from './_MapCache.js';\n\n/** Error message constants. */\nvar FUNC_ERROR_TEXT = 'Expected a function';\n\n/**\n * Creates a function that memoizes the result of `func`. If `resolver` is\n * provided, it determines the cache key for storing the result based on the\n * arguments provided to the memoized function. By default, the first argument\n * provided to the memoized function is used as the map cache key. The `func`\n * is invoked with the `this` binding of the memoized function.\n *\n * **Note:** The cache is exposed as the `cache` property on the memoized\n * function. Its creation may be customized by replacing the `_.memoize.Cache`\n * constructor with one whose instances implement the\n * [`Map`](http://ecma-international.org/ecma-262/7.0/#sec-properties-of-the-map-prototype-object)\n * method interface of `clear`, `delete`, `get`, `has`, and `set`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Function\n * @param {Function} func The function to have its output memoized.\n * @param {Function} [resolver] The function to resolve the cache key.\n * @returns {Function} Returns the new memoized function.\n * @example\n *\n * var object = { 'a': 1, 'b': 2 };\n * var other = { 'c': 3, 'd': 4 };\n *\n * var values = _.memoize(_.values);\n * values(object);\n * // => [1, 2]\n *\n * values(other);\n * // => [3, 4]\n *\n * object.a = 2;\n * values(object);\n * // => [1, 2]\n *\n * // Modify the result cache.\n * values.cache.set(object, ['a', 'b']);\n * values(object);\n * // => ['a', 'b']\n *\n * // Replace `_.memoize.Cache`.\n * _.memoize.Cache = WeakMap;\n */\nfunction memoize(func, resolver) {\n if (typeof func != 'function' || (resolver != null && typeof resolver != 'function')) {\n throw new TypeError(FUNC_ERROR_TEXT);\n }\n var memoized = function() {\n var args = arguments,\n key = resolver ? resolver.apply(this, args) : args[0],\n cache = memoized.cache;\n\n if (cache.has(key)) {\n return cache.get(key);\n }\n var result = func.apply(this, args);\n memoized.cache = cache.set(key, result) || cache;\n return result;\n };\n memoized.cache = new (memoize.Cache || MapCache);\n return memoized;\n}\n\n// Expose `MapCache`.\nmemoize.Cache = MapCache;\n\nexport default memoize;\n","import memoize from './memoize.js';\n\n/** Used as the maximum memoize cache size. */\nvar MAX_MEMOIZE_SIZE = 500;\n\n/**\n * A specialized version of `_.memoize` which clears the memoized function's\n * cache when it exceeds `MAX_MEMOIZE_SIZE`.\n *\n * @private\n * @param {Function} func The function to have its output memoized.\n * @returns {Function} Returns the new memoized function.\n */\nfunction memoizeCapped(func) {\n var result = memoize(func, function(key) {\n if (cache.size === MAX_MEMOIZE_SIZE) {\n cache.clear();\n }\n return key;\n });\n\n var cache = result.cache;\n return result;\n}\n\nexport default memoizeCapped;\n","import memoizeCapped from './_memoizeCapped.js';\n\n/** Used to match property names within property paths. */\nvar rePropName = /[^.[\\]]+|\\[(?:(-?\\d+(?:\\.\\d+)?)|([\"'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|$))/g;\n\n/** Used to match backslashes in property paths. */\nvar reEscapeChar = /\\\\(\\\\)?/g;\n\n/**\n * Converts `string` to a property path array.\n *\n * @private\n * @param {string} string The string to convert.\n * @returns {Array} Returns the property path array.\n */\nvar stringToPath = memoizeCapped(function(string) {\n var result = [];\n if (string.charCodeAt(0) === 46 /* . */) {\n result.push('');\n }\n string.replace(rePropName, function(match, number, quote, subString) {\n result.push(quote ? subString.replace(reEscapeChar, '$1') : (number || match));\n });\n return result;\n});\n\nexport default stringToPath;\n","import baseToString from './_baseToString.js';\n\n/**\n * Converts `value` to a string. An empty string is returned for `null`\n * and `undefined` values. The sign of `-0` is preserved.\n *\n * @static\n * @memberOf _\n * @since 4.0.0\n * @category Lang\n * @param {*} value The value to convert.\n * @returns {string} Returns the converted string.\n * @example\n *\n * _.toString(null);\n * // => ''\n *\n * _.toString(-0);\n * // => '-0'\n *\n * _.toString([1, 2, 3]);\n * // => '1,2,3'\n */\nfunction toString(value) {\n return value == null ? '' : baseToString(value);\n}\n\nexport default toString;\n","import isArray from './isArray.js';\nimport isKey from './_isKey.js';\nimport stringToPath from './_stringToPath.js';\nimport toString from './toString.js';\n\n/**\n * Casts `value` to a path array if it's not one.\n *\n * @private\n * @param {*} value The value to inspect.\n * @param {Object} [object] The object to query keys on.\n * @returns {Array} Returns the cast property path array.\n */\nfunction castPath(value, object) {\n if (isArray(value)) {\n return value;\n }\n return isKey(value, object) ? [value] : stringToPath(toString(value));\n}\n\nexport default castPath;\n","import isSymbol from './isSymbol.js';\n\n/** Used as references for various `Number` constants. */\nvar INFINITY = 1 / 0;\n\n/**\n * Converts `value` to a string key if it's not a string or symbol.\n *\n * @private\n * @param {*} value The value to inspect.\n * @returns {string|symbol} Returns the key.\n */\nfunction toKey(value) {\n if (typeof value == 'string' || isSymbol(value)) {\n return value;\n }\n var result = (value + '');\n return (result == '0' && (1 / value) == -INFINITY) ? '-0' : result;\n}\n\nexport default toKey;\n","/**\n * Appends the elements of `values` to `array`.\n *\n * @private\n * @param {Array} array The array to modify.\n * @param {Array} values The values to append.\n * @returns {Array} Returns `array`.\n */\nfunction arrayPush(array, values) {\n var index = -1,\n length = values.length,\n offset = array.length;\n\n while (++index < length) {\n array[offset + index] = values[index];\n }\n return array;\n}\n\nexport default arrayPush;\n","import overArg from './_overArg.js';\n\n/** Built-in value references. */\nvar getPrototype = overArg(Object.getPrototypeOf, Object);\n\nexport default getPrototype;\n","import ListCache from './_ListCache.js';\n\n/**\n * Removes all key-value entries from the stack.\n *\n * @private\n * @name clear\n * @memberOf Stack\n */\nfunction stackClear() {\n this.__data__ = new ListCache;\n this.size = 0;\n}\n\nexport default stackClear;\n","/**\n * Removes `key` and its value from the stack.\n *\n * @private\n * @name delete\n * @memberOf Stack\n * @param {string} key The key of the value to remove.\n * @returns {boolean} Returns `true` if the entry was removed, else `false`.\n */\nfunction stackDelete(key) {\n var data = this.__data__,\n result = data['delete'](key);\n\n this.size = data.size;\n return result;\n}\n\nexport default stackDelete;\n","/**\n * Gets the stack value for `key`.\n *\n * @private\n * @name get\n * @memberOf Stack\n * @param {string} key The key of the value to get.\n * @returns {*} Returns the entry value.\n */\nfunction stackGet(key) {\n return this.__data__.get(key);\n}\n\nexport default stackGet;\n","/**\n * Checks if a stack value for `key` exists.\n *\n * @private\n * @name has\n * @memberOf Stack\n * @param {string} key The key of the entry to check.\n * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.\n */\nfunction stackHas(key) {\n return this.__data__.has(key);\n}\n\nexport default stackHas;\n","import ListCache from './_ListCache.js';\nimport Map from './_Map.js';\nimport MapCache from './_MapCache.js';\n\n/** Used as the size to enable large array optimizations. */\nvar LARGE_ARRAY_SIZE = 200;\n\n/**\n * Sets the stack `key` to `value`.\n *\n * @private\n * @name set\n * @memberOf Stack\n * @param {string} key The key of the value to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns the stack cache instance.\n */\nfunction stackSet(key, value) {\n var data = this.__data__;\n if (data instanceof ListCache) {\n var pairs = data.__data__;\n if (!Map || (pairs.length < LARGE_ARRAY_SIZE - 1)) {\n pairs.push([key, value]);\n this.size = ++data.size;\n return this;\n }\n data = this.__data__ = new MapCache(pairs);\n }\n data.set(key, value);\n this.size = data.size;\n return this;\n}\n\nexport default stackSet;\n","import ListCache from './_ListCache.js';\nimport stackClear from './_stackClear.js';\nimport stackDelete from './_stackDelete.js';\nimport stackGet from './_stackGet.js';\nimport stackHas from './_stackHas.js';\nimport stackSet from './_stackSet.js';\n\n/**\n * Creates a stack cache object to store key-value pairs.\n *\n * @private\n * @constructor\n * @param {Array} [entries] The key-value pairs to cache.\n */\nfunction Stack(entries) {\n var data = this.__data__ = new ListCache(entries);\n this.size = data.size;\n}\n\n// Add methods to `Stack`.\nStack.prototype.clear = stackClear;\nStack.prototype['delete'] = stackDelete;\nStack.prototype.get = stackGet;\nStack.prototype.has = stackHas;\nStack.prototype.set = stackSet;\n\nexport default Stack;\n","import root from './_root.js';\n\n/** Detect free variable `exports`. */\nvar freeExports = typeof exports == 'object' && exports && !exports.nodeType && exports;\n\n/** Detect free variable `module`. */\nvar freeModule = freeExports && typeof module == 'object' && module && !module.nodeType && module;\n\n/** Detect the popular CommonJS extension `module.exports`. */\nvar moduleExports = freeModule && freeModule.exports === freeExports;\n\n/** Built-in value references. */\nvar Buffer = moduleExports ? root.Buffer : undefined,\n allocUnsafe = Buffer ? Buffer.allocUnsafe : undefined;\n\n/**\n * Creates a clone of `buffer`.\n *\n * @private\n * @param {Buffer} buffer The buffer to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Buffer} Returns the cloned buffer.\n */\nfunction cloneBuffer(buffer, isDeep) {\n if (isDeep) {\n return buffer.slice();\n }\n var length = buffer.length,\n result = allocUnsafe ? allocUnsafe(length) : new buffer.constructor(length);\n\n buffer.copy(result);\n return result;\n}\n\nexport default cloneBuffer;\n","/**\n * A specialized version of `_.filter` for arrays without support for\n * iteratee shorthands.\n *\n * @private\n * @param {Array} [array] The array to iterate over.\n * @param {Function} predicate The function invoked per iteration.\n * @returns {Array} Returns the new filtered array.\n */\nfunction arrayFilter(array, predicate) {\n var index = -1,\n length = array == null ? 0 : array.length,\n resIndex = 0,\n result = [];\n\n while (++index < length) {\n var value = array[index];\n if (predicate(value, index, array)) {\n result[resIndex++] = value;\n }\n }\n return result;\n}\n\nexport default arrayFilter;\n","/**\n * This method returns a new empty array.\n *\n * @static\n * @memberOf _\n * @since 4.13.0\n * @category Util\n * @returns {Array} Returns the new empty array.\n * @example\n *\n * var arrays = _.times(2, _.stubArray);\n *\n * console.log(arrays);\n * // => [[], []]\n *\n * console.log(arrays[0] === arrays[1]);\n * // => false\n */\nfunction stubArray() {\n return [];\n}\n\nexport default stubArray;\n","import arrayFilter from './_arrayFilter.js';\nimport stubArray from './stubArray.js';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Built-in value references. */\nvar propertyIsEnumerable = objectProto.propertyIsEnumerable;\n\n/* Built-in method references for those with the same name as other `lodash` methods. */\nvar nativeGetSymbols = Object.getOwnPropertySymbols;\n\n/**\n * Creates an array of the own enumerable symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of symbols.\n */\nvar getSymbols = !nativeGetSymbols ? stubArray : function(object) {\n if (object == null) {\n return [];\n }\n object = Object(object);\n return arrayFilter(nativeGetSymbols(object), function(symbol) {\n return propertyIsEnumerable.call(object, symbol);\n });\n};\n\nexport default getSymbols;\n","import arrayPush from './_arrayPush.js';\nimport isArray from './isArray.js';\n\n/**\n * The base implementation of `getAllKeys` and `getAllKeysIn` which uses\n * `keysFunc` and `symbolsFunc` to get the enumerable property names and\n * symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @param {Function} keysFunc The function to get the keys of `object`.\n * @param {Function} symbolsFunc The function to get the symbols of `object`.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction baseGetAllKeys(object, keysFunc, symbolsFunc) {\n var result = keysFunc(object);\n return isArray(object) ? result : arrayPush(result, symbolsFunc(object));\n}\n\nexport default baseGetAllKeys;\n","import baseGetAllKeys from './_baseGetAllKeys.js';\nimport getSymbols from './_getSymbols.js';\nimport keys from './keys.js';\n\n/**\n * Creates an array of own enumerable property names and symbols of `object`.\n *\n * @private\n * @param {Object} object The object to query.\n * @returns {Array} Returns the array of property names and symbols.\n */\nfunction getAllKeys(object) {\n return baseGetAllKeys(object, keys, getSymbols);\n}\n\nexport default getAllKeys;\n","import getNative from './_getNative.js';\nimport root from './_root.js';\n\n/* Built-in method references that are verified to be native. */\nvar DataView = getNative(root, 'DataView');\n\nexport default DataView;\n","import getNative from './_getNative.js';\nimport root from './_root.js';\n\n/* Built-in method references that are verified to be native. */\nvar Promise = getNative(root, 'Promise');\n\nexport default Promise;\n","import getNative from './_getNative.js';\nimport root from './_root.js';\n\n/* Built-in method references that are verified to be native. */\nvar Set = getNative(root, 'Set');\n\nexport default Set;\n","import DataView from './_DataView.js';\nimport Map from './_Map.js';\nimport Promise from './_Promise.js';\nimport Set from './_Set.js';\nimport WeakMap from './_WeakMap.js';\nimport baseGetTag from './_baseGetTag.js';\nimport toSource from './_toSource.js';\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]',\n objectTag = '[object Object]',\n promiseTag = '[object Promise]',\n setTag = '[object Set]',\n weakMapTag = '[object WeakMap]';\n\nvar dataViewTag = '[object DataView]';\n\n/** Used to detect maps, sets, and weakmaps. */\nvar dataViewCtorString = toSource(DataView),\n mapCtorString = toSource(Map),\n promiseCtorString = toSource(Promise),\n setCtorString = toSource(Set),\n weakMapCtorString = toSource(WeakMap);\n\n/**\n * Gets the `toStringTag` of `value`.\n *\n * @private\n * @param {*} value The value to query.\n * @returns {string} Returns the `toStringTag`.\n */\nvar getTag = baseGetTag;\n\n// Fallback for data views, maps, sets, and weak maps in IE 11 and promises in Node.js < 6.\nif ((DataView && getTag(new DataView(new ArrayBuffer(1))) != dataViewTag) ||\n (Map && getTag(new Map) != mapTag) ||\n (Promise && getTag(Promise.resolve()) != promiseTag) ||\n (Set && getTag(new Set) != setTag) ||\n (WeakMap && getTag(new WeakMap) != weakMapTag)) {\n getTag = function(value) {\n var result = baseGetTag(value),\n Ctor = result == objectTag ? value.constructor : undefined,\n ctorString = Ctor ? toSource(Ctor) : '';\n\n if (ctorString) {\n switch (ctorString) {\n case dataViewCtorString: return dataViewTag;\n case mapCtorString: return mapTag;\n case promiseCtorString: return promiseTag;\n case setCtorString: return setTag;\n case weakMapCtorString: return weakMapTag;\n }\n }\n return result;\n };\n}\n\nexport default getTag;\n","/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Initializes an array clone.\n *\n * @private\n * @param {Array} array The array to clone.\n * @returns {Array} Returns the initialized clone.\n */\nfunction initCloneArray(array) {\n var length = array.length,\n result = new array.constructor(length);\n\n // Add properties assigned by `RegExp#exec`.\n if (length && typeof array[0] == 'string' && hasOwnProperty.call(array, 'index')) {\n result.index = array.index;\n result.input = array.input;\n }\n return result;\n}\n\nexport default initCloneArray;\n","import root from './_root.js';\n\n/** Built-in value references. */\nvar Uint8Array = root.Uint8Array;\n\nexport default Uint8Array;\n","import Uint8Array from './_Uint8Array.js';\n\n/**\n * Creates a clone of `arrayBuffer`.\n *\n * @private\n * @param {ArrayBuffer} arrayBuffer The array buffer to clone.\n * @returns {ArrayBuffer} Returns the cloned array buffer.\n */\nfunction cloneArrayBuffer(arrayBuffer) {\n var result = new arrayBuffer.constructor(arrayBuffer.byteLength);\n new Uint8Array(result).set(new Uint8Array(arrayBuffer));\n return result;\n}\n\nexport default cloneArrayBuffer;\n","import cloneArrayBuffer from './_cloneArrayBuffer.js';\n\n/**\n * Creates a clone of `dataView`.\n *\n * @private\n * @param {Object} dataView The data view to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned data view.\n */\nfunction cloneDataView(dataView, isDeep) {\n var buffer = isDeep ? cloneArrayBuffer(dataView.buffer) : dataView.buffer;\n return new dataView.constructor(buffer, dataView.byteOffset, dataView.byteLength);\n}\n\nexport default cloneDataView;\n","/** Used to match `RegExp` flags from their coerced string values. */\nvar reFlags = /\\w*$/;\n\n/**\n * Creates a clone of `regexp`.\n *\n * @private\n * @param {Object} regexp The regexp to clone.\n * @returns {Object} Returns the cloned regexp.\n */\nfunction cloneRegExp(regexp) {\n var result = new regexp.constructor(regexp.source, reFlags.exec(regexp));\n result.lastIndex = regexp.lastIndex;\n return result;\n}\n\nexport default cloneRegExp;\n","import Symbol from './_Symbol.js';\n\n/** Used to convert symbols to primitives and strings. */\nvar symbolProto = Symbol ? Symbol.prototype : undefined,\n symbolValueOf = symbolProto ? symbolProto.valueOf : undefined;\n\n/**\n * Creates a clone of the `symbol` object.\n *\n * @private\n * @param {Object} symbol The symbol object to clone.\n * @returns {Object} Returns the cloned symbol object.\n */\nfunction cloneSymbol(symbol) {\n return symbolValueOf ? Object(symbolValueOf.call(symbol)) : {};\n}\n\nexport default cloneSymbol;\n","import cloneArrayBuffer from './_cloneArrayBuffer.js';\n\n/**\n * Creates a clone of `typedArray`.\n *\n * @private\n * @param {Object} typedArray The typed array to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the cloned typed array.\n */\nfunction cloneTypedArray(typedArray, isDeep) {\n var buffer = isDeep ? cloneArrayBuffer(typedArray.buffer) : typedArray.buffer;\n return new typedArray.constructor(buffer, typedArray.byteOffset, typedArray.length);\n}\n\nexport default cloneTypedArray;\n","import cloneArrayBuffer from './_cloneArrayBuffer.js';\nimport cloneDataView from './_cloneDataView.js';\nimport cloneRegExp from './_cloneRegExp.js';\nimport cloneSymbol from './_cloneSymbol.js';\nimport cloneTypedArray from './_cloneTypedArray.js';\n\n/** `Object#toString` result references. */\nvar boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/**\n * Initializes an object clone based on its `toStringTag`.\n *\n * **Note:** This function only supports cloning values with tags of\n * `Boolean`, `Date`, `Error`, `Map`, `Number`, `RegExp`, `Set`, or `String`.\n *\n * @private\n * @param {Object} object The object to clone.\n * @param {string} tag The `toStringTag` of the object to clone.\n * @param {boolean} [isDeep] Specify a deep clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneByTag(object, tag, isDeep) {\n var Ctor = object.constructor;\n switch (tag) {\n case arrayBufferTag:\n return cloneArrayBuffer(object);\n\n case boolTag:\n case dateTag:\n return new Ctor(+object);\n\n case dataViewTag:\n return cloneDataView(object, isDeep);\n\n case float32Tag: case float64Tag:\n case int8Tag: case int16Tag: case int32Tag:\n case uint8Tag: case uint8ClampedTag: case uint16Tag: case uint32Tag:\n return cloneTypedArray(object, isDeep);\n\n case mapTag:\n return new Ctor;\n\n case numberTag:\n case stringTag:\n return new Ctor(object);\n\n case regexpTag:\n return cloneRegExp(object);\n\n case setTag:\n return new Ctor;\n\n case symbolTag:\n return cloneSymbol(object);\n }\n}\n\nexport default initCloneByTag;\n","import baseCreate from './_baseCreate.js';\nimport getPrototype from './_getPrototype.js';\nimport isPrototype from './_isPrototype.js';\n\n/**\n * Initializes an object clone.\n *\n * @private\n * @param {Object} object The object to clone.\n * @returns {Object} Returns the initialized clone.\n */\nfunction initCloneObject(object) {\n return (typeof object.constructor == 'function' && !isPrototype(object))\n ? baseCreate(getPrototype(object))\n : {};\n}\n\nexport default initCloneObject;\n","import getTag from './_getTag.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]';\n\n/**\n * The base implementation of `_.isMap` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a map, else `false`.\n */\nfunction baseIsMap(value) {\n return isObjectLike(value) && getTag(value) == mapTag;\n}\n\nexport default baseIsMap;\n","import baseIsMap from './_baseIsMap.js';\nimport baseUnary from './_baseUnary.js';\nimport nodeUtil from './_nodeUtil.js';\n\n/* Node.js helper references. */\nvar nodeIsMap = nodeUtil && nodeUtil.isMap;\n\n/**\n * Checks if `value` is classified as a `Map` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a map, else `false`.\n * @example\n *\n * _.isMap(new Map);\n * // => true\n *\n * _.isMap(new WeakMap);\n * // => false\n */\nvar isMap = nodeIsMap ? baseUnary(nodeIsMap) : baseIsMap;\n\nexport default isMap;\n","import getTag from './_getTag.js';\nimport isObjectLike from './isObjectLike.js';\n\n/** `Object#toString` result references. */\nvar setTag = '[object Set]';\n\n/**\n * The base implementation of `_.isSet` without Node.js optimizations.\n *\n * @private\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a set, else `false`.\n */\nfunction baseIsSet(value) {\n return isObjectLike(value) && getTag(value) == setTag;\n}\n\nexport default baseIsSet;\n","import baseIsSet from './_baseIsSet.js';\nimport baseUnary from './_baseUnary.js';\nimport nodeUtil from './_nodeUtil.js';\n\n/* Node.js helper references. */\nvar nodeIsSet = nodeUtil && nodeUtil.isSet;\n\n/**\n * Checks if `value` is classified as a `Set` object.\n *\n * @static\n * @memberOf _\n * @since 4.3.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is a set, else `false`.\n * @example\n *\n * _.isSet(new Set);\n * // => true\n *\n * _.isSet(new WeakSet);\n * // => false\n */\nvar isSet = nodeIsSet ? baseUnary(nodeIsSet) : baseIsSet;\n\nexport default isSet;\n","import Stack from './_Stack.js';\nimport arrayEach from './_arrayEach.js';\nimport assignValue from './_assignValue.js';\nimport baseAssign from './_baseAssign.js';\nimport baseAssignIn from './_baseAssignIn.js';\nimport cloneBuffer from './_cloneBuffer.js';\nimport copyArray from './_copyArray.js';\nimport copySymbols from './_copySymbols.js';\nimport copySymbolsIn from './_copySymbolsIn.js';\nimport getAllKeys from './_getAllKeys.js';\nimport getAllKeysIn from './_getAllKeysIn.js';\nimport getTag from './_getTag.js';\nimport initCloneArray from './_initCloneArray.js';\nimport initCloneByTag from './_initCloneByTag.js';\nimport initCloneObject from './_initCloneObject.js';\nimport isArray from './isArray.js';\nimport isBuffer from './isBuffer.js';\nimport isMap from './isMap.js';\nimport isObject from './isObject.js';\nimport isSet from './isSet.js';\nimport keys from './keys.js';\nimport keysIn from './keysIn.js';\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_DEEP_FLAG = 1,\n CLONE_FLAT_FLAG = 2,\n CLONE_SYMBOLS_FLAG = 4;\n\n/** `Object#toString` result references. */\nvar argsTag = '[object Arguments]',\n arrayTag = '[object Array]',\n boolTag = '[object Boolean]',\n dateTag = '[object Date]',\n errorTag = '[object Error]',\n funcTag = '[object Function]',\n genTag = '[object GeneratorFunction]',\n mapTag = '[object Map]',\n numberTag = '[object Number]',\n objectTag = '[object Object]',\n regexpTag = '[object RegExp]',\n setTag = '[object Set]',\n stringTag = '[object String]',\n symbolTag = '[object Symbol]',\n weakMapTag = '[object WeakMap]';\n\nvar arrayBufferTag = '[object ArrayBuffer]',\n dataViewTag = '[object DataView]',\n float32Tag = '[object Float32Array]',\n float64Tag = '[object Float64Array]',\n int8Tag = '[object Int8Array]',\n int16Tag = '[object Int16Array]',\n int32Tag = '[object Int32Array]',\n uint8Tag = '[object Uint8Array]',\n uint8ClampedTag = '[object Uint8ClampedArray]',\n uint16Tag = '[object Uint16Array]',\n uint32Tag = '[object Uint32Array]';\n\n/** Used to identify `toStringTag` values supported by `_.clone`. */\nvar cloneableTags = {};\ncloneableTags[argsTag] = cloneableTags[arrayTag] =\ncloneableTags[arrayBufferTag] = cloneableTags[dataViewTag] =\ncloneableTags[boolTag] = cloneableTags[dateTag] =\ncloneableTags[float32Tag] = cloneableTags[float64Tag] =\ncloneableTags[int8Tag] = cloneableTags[int16Tag] =\ncloneableTags[int32Tag] = cloneableTags[mapTag] =\ncloneableTags[numberTag] = cloneableTags[objectTag] =\ncloneableTags[regexpTag] = cloneableTags[setTag] =\ncloneableTags[stringTag] = cloneableTags[symbolTag] =\ncloneableTags[uint8Tag] = cloneableTags[uint8ClampedTag] =\ncloneableTags[uint16Tag] = cloneableTags[uint32Tag] = true;\ncloneableTags[errorTag] = cloneableTags[funcTag] =\ncloneableTags[weakMapTag] = false;\n\n/**\n * The base implementation of `_.clone` and `_.cloneDeep` which tracks\n * traversed objects.\n *\n * @private\n * @param {*} value The value to clone.\n * @param {boolean} bitmask The bitmask flags.\n * 1 - Deep clone\n * 2 - Flatten inherited properties\n * 4 - Clone symbols\n * @param {Function} [customizer] The function to customize cloning.\n * @param {string} [key] The key of `value`.\n * @param {Object} [object] The parent object of `value`.\n * @param {Object} [stack] Tracks traversed objects and their clone counterparts.\n * @returns {*} Returns the cloned value.\n */\nfunction baseClone(value, bitmask, customizer, key, object, stack) {\n var result,\n isDeep = bitmask & CLONE_DEEP_FLAG,\n isFlat = bitmask & CLONE_FLAT_FLAG,\n isFull = bitmask & CLONE_SYMBOLS_FLAG;\n\n if (customizer) {\n result = object ? customizer(value, key, object, stack) : customizer(value);\n }\n if (result !== undefined) {\n return result;\n }\n if (!isObject(value)) {\n return value;\n }\n var isArr = isArray(value);\n if (isArr) {\n result = initCloneArray(value);\n if (!isDeep) {\n return copyArray(value, result);\n }\n } else {\n var tag = getTag(value),\n isFunc = tag == funcTag || tag == genTag;\n\n if (isBuffer(value)) {\n return cloneBuffer(value, isDeep);\n }\n if (tag == objectTag || tag == argsTag || (isFunc && !object)) {\n result = (isFlat || isFunc) ? {} : initCloneObject(value);\n if (!isDeep) {\n return isFlat\n ? copySymbolsIn(value, baseAssignIn(result, value))\n : copySymbols(value, baseAssign(result, value));\n }\n } else {\n if (!cloneableTags[tag]) {\n return object ? value : {};\n }\n result = initCloneByTag(value, tag, isDeep);\n }\n }\n // Check for circular references and return its corresponding clone.\n stack || (stack = new Stack);\n var stacked = stack.get(value);\n if (stacked) {\n return stacked;\n }\n stack.set(value, result);\n\n if (isSet(value)) {\n value.forEach(function(subValue) {\n result.add(baseClone(subValue, bitmask, customizer, subValue, value, stack));\n });\n } else if (isMap(value)) {\n value.forEach(function(subValue, key) {\n result.set(key, baseClone(subValue, bitmask, customizer, key, value, stack));\n });\n }\n\n var keysFunc = isFull\n ? (isFlat ? getAllKeysIn : getAllKeys)\n : (isFlat ? keysIn : keys);\n\n var props = isArr ? undefined : keysFunc(value);\n arrayEach(props || value, function(subValue, key) {\n if (props) {\n key = subValue;\n subValue = value[key];\n }\n // Recursively populate clone (susceptible to call stack limits).\n assignValue(result, key, baseClone(subValue, bitmask, customizer, key, value, stack));\n });\n return result;\n}\n\nexport default baseClone;\n","import baseClone from './_baseClone.js';\n\n/** Used to compose bitmasks for cloning. */\nvar CLONE_DEEP_FLAG = 1,\n CLONE_SYMBOLS_FLAG = 4;\n\n/**\n * This method is like `_.clone` except that it recursively clones `value`.\n *\n * @static\n * @memberOf _\n * @since 1.0.0\n * @category Lang\n * @param {*} value The value to recursively clone.\n * @returns {*} Returns the deep cloned value.\n * @see _.clone\n * @example\n *\n * var objects = [{ 'a': 1 }, { 'b': 2 }];\n *\n * var deep = _.cloneDeep(objects);\n * console.log(deep[0] === objects[0]);\n * // => false\n */\nfunction cloneDeep(value) {\n return baseClone(value, CLONE_DEEP_FLAG | CLONE_SYMBOLS_FLAG);\n}\n\nexport default cloneDeep;\n","import baseKeys from './_baseKeys.js';\nimport getTag from './_getTag.js';\nimport isArguments from './isArguments.js';\nimport isArray from './isArray.js';\nimport isArrayLike from './isArrayLike.js';\nimport isBuffer from './isBuffer.js';\nimport isPrototype from './_isPrototype.js';\nimport isTypedArray from './isTypedArray.js';\n\n/** `Object#toString` result references. */\nvar mapTag = '[object Map]',\n setTag = '[object Set]';\n\n/** Used for built-in method references. */\nvar objectProto = Object.prototype;\n\n/** Used to check objects for own properties. */\nvar hasOwnProperty = objectProto.hasOwnProperty;\n\n/**\n * Checks if `value` is an empty object, collection, map, or set.\n *\n * Objects are considered empty if they have no own enumerable string keyed\n * properties.\n *\n * Array-like values such as `arguments` objects, arrays, buffers, strings, or\n * jQuery-like collections are considered empty if they have a `length` of `0`.\n * Similarly, maps and sets are considered empty if they have a `size` of `0`.\n *\n * @static\n * @memberOf _\n * @since 0.1.0\n * @category Lang\n * @param {*} value The value to check.\n * @returns {boolean} Returns `true` if `value` is empty, else `false`.\n * @example\n *\n * _.isEmpty(null);\n * // => true\n *\n * _.isEmpty(true);\n * // => true\n *\n * _.isEmpty(1);\n * // => true\n *\n * _.isEmpty([1, 2, 3]);\n * // => false\n *\n * _.isEmpty({ 'a': 1 });\n * // => false\n */\nfunction isEmpty(value) {\n if (value == null) {\n return true;\n }\n if (isArrayLike(value) &&\n (isArray(value) || typeof value == 'string' || typeof value.splice == 'function' ||\n isBuffer(value) || isTypedArray(value) || isArguments(value))) {\n return !value.length;\n }\n var tag = getTag(value);\n if (tag == mapTag || tag == setTag) {\n return !value.size;\n }\n if (isPrototype(value)) {\n return !baseKeys(value).length;\n }\n for (var key in value) {\n if (hasOwnProperty.call(value, key)) {\n return false;\n }\n }\n return true;\n}\n\nexport default isEmpty;\n","import assignValue from './_assignValue.js';\nimport castPath from './_castPath.js';\nimport isIndex from './_isIndex.js';\nimport isObject from './isObject.js';\nimport toKey from './_toKey.js';\n\n/**\n * The base implementation of `_.set`.\n *\n * @private\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {*} value The value to set.\n * @param {Function} [customizer] The function to customize path creation.\n * @returns {Object} Returns `object`.\n */\nfunction baseSet(object, path, value, customizer) {\n if (!isObject(object)) {\n return object;\n }\n path = castPath(path, object);\n\n var index = -1,\n length = path.length,\n lastIndex = length - 1,\n nested = object;\n\n while (nested != null && ++index < length) {\n var key = toKey(path[index]),\n newValue = value;\n\n if (key === '__proto__' || key === 'constructor' || key === 'prototype') {\n return object;\n }\n\n if (index != lastIndex) {\n var objValue = nested[key];\n newValue = customizer ? customizer(objValue, key, nested) : undefined;\n if (newValue === undefined) {\n newValue = isObject(objValue)\n ? objValue\n : (isIndex(path[index + 1]) ? [] : {});\n }\n }\n assignValue(nested, key, newValue);\n nested = nested[key];\n }\n return object;\n}\n\nexport default baseSet;\n","import baseSet from './_baseSet.js';\n\n/**\n * Sets the value at `path` of `object`. If a portion of `path` doesn't exist,\n * it's created. Arrays are created for missing index properties while objects\n * are created for all other missing properties. Use `_.setWith` to customize\n * `path` creation.\n *\n * **Note:** This method mutates `object`.\n *\n * @static\n * @memberOf _\n * @since 3.7.0\n * @category Object\n * @param {Object} object The object to modify.\n * @param {Array|string} path The path of the property to set.\n * @param {*} value The value to set.\n * @returns {Object} Returns `object`.\n * @example\n *\n * var object = { 'a': [{ 'b': { 'c': 3 } }] };\n *\n * _.set(object, 'a[0].b.c', 4);\n * console.log(object.a[0].b.c);\n * // => 4\n *\n * _.set(object, ['x', '0', 'y', 'z'], 5);\n * console.log(object.x[0].y.z);\n * // => 5\n */\nfunction set(object, path, value) {\n return object == null ? object : baseSet(object, path, value);\n}\n\nexport default set;\n","import validate from './validate.js';\nconst byteToHex = [];\nfor (let i = 0; i < 256; ++i) {\n byteToHex.push((i + 0x100).toString(16).slice(1));\n}\nexport function unsafeStringify(arr, offset = 0) {\n return (byteToHex[arr[offset + 0]] +\n byteToHex[arr[offset + 1]] +\n byteToHex[arr[offset + 2]] +\n byteToHex[arr[offset + 3]] +\n '-' +\n byteToHex[arr[offset + 4]] +\n byteToHex[arr[offset + 5]] +\n '-' +\n byteToHex[arr[offset + 6]] +\n byteToHex[arr[offset + 7]] +\n '-' +\n byteToHex[arr[offset + 8]] +\n byteToHex[arr[offset + 9]] +\n '-' +\n byteToHex[arr[offset + 10]] +\n byteToHex[arr[offset + 11]] +\n byteToHex[arr[offset + 12]] +\n byteToHex[arr[offset + 13]] +\n byteToHex[arr[offset + 14]] +\n byteToHex[arr[offset + 15]]).toLowerCase();\n}\nfunction stringify(arr, offset = 0) {\n const uuid = unsafeStringify(arr, offset);\n if (!validate(uuid)) {\n throw TypeError('Stringified UUID is invalid');\n }\n return uuid;\n}\nexport default stringify;\n","let getRandomValues;\nconst rnds8 = new Uint8Array(16);\nexport default function rng() {\n if (!getRandomValues) {\n if (typeof crypto === 'undefined' || !crypto.getRandomValues) {\n throw new Error('crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported');\n }\n getRandomValues = crypto.getRandomValues.bind(crypto);\n }\n return getRandomValues(rnds8);\n}\n","const randomUUID = typeof crypto !== 'undefined' && crypto.randomUUID && crypto.randomUUID.bind(crypto);\nexport default { randomUUID };\n","import native from './native.js';\nimport rng from './rng.js';\nimport { unsafeStringify } from './stringify.js';\nfunction v4(options, buf, offset) {\n if (native.randomUUID && !buf && !options) {\n return native.randomUUID();\n }\n options = options || {};\n const rnds = options.random ?? options.rng?.() ?? rng();\n if (rnds.length < 16) {\n throw new Error('Random bytes length must be >= 16');\n }\n rnds[6] = (rnds[6] & 0x0f) | 0x40;\n rnds[8] = (rnds[8] & 0x3f) | 0x80;\n if (buf) {\n offset = offset || 0;\n if (offset < 0 || offset + 16 > buf.length) {\n throw new RangeError(`UUID byte range ${offset}:${offset + 15} is out of buffer bounds`);\n }\n for (let i = 0; i < 16; ++i) {\n buf[offset + i] = rnds[i];\n }\n return buf;\n }\n return unsafeStringify(rnds);\n}\nexport default v4;\n","import type * as GeoJSON from 'geojson'\nimport type { LayerSpecification, Map as MapboxGlMap, Source, SourceSpecification } from 'mapbox-gl'\n\nexport interface SortLayer {\n zIndex: number\n layer: LayerSpecification\n}\n\n/** 检查 id 是否有效(非 null/undefined) */\nfunction isValidId(id: unknown): id is string | number {\n return id !== null && id !== undefined\n}\n\n/** GeoJSON Source 类型,包含 setData 方法 */\ninterface GeoJSONSource {\n type: 'geojson'\n setData(data: GeoJSON.GeoJSON): void\n}\n\nclass ResourceRegister {\n private map: MapboxGlMap\n private sourceData = new Map<string, GeoJSON.FeatureCollection>()\n /** Feature 索引,key 为 `${sourceId}:${featureId}` */\n private featureIndex = new Map<string, number>()\n private dirtySourceIds = new Set<string>()\n private renderFrameId: number | null = null\n private layerList: SortLayer[] = []\n private destroyed = false\n /** 记录由此类创建的 source id */\n private managedSourceIds = new Set<string>()\n /** 记录由此类创建的 layer id */\n private managedLayerIds = new Set<string>()\n\n constructor(map: MapboxGlMap) {\n this.map = map\n }\n\n private checkDestroyed(): void {\n if (this.destroyed) {\n console.warn('[ResourceRegister] Instance has been destroyed')\n }\n }\n\n /**\n * 幂等地添加 Source\n */\n public addSource(id: string, source: SourceSpecification): void {\n this.checkDestroyed()\n if (!this.map.getSource(id)) {\n const finalSource: SourceSpecification =\n source.type === 'geojson' && !source.promoteId\n ? { ...source, promoteId: 'id' }\n : { ...source }\n this.map.addSource(id, finalSource)\n this.managedSourceIds.add(id)\n }\n }\n\n /**\n * 幂等地添加 Layer\n */\n public addLayer(sortLayer: SortLayer): void {\n this.checkDestroyed()\n const { layer, zIndex } = sortLayer\n\n if (!this.map.getLayer(layer.id)) {\n const i = this.layerList.findIndex((item) => item.zIndex > zIndex)\n if (i === -1) {\n this.map.addLayer(layer)\n this.layerList.push({ zIndex, layer })\n } else {\n const beforeLayer = this.layerList[i].layer\n this.map.addLayer(layer, beforeLayer.id)\n this.layerList.splice(i, 0, { layer, zIndex })\n }\n this.managedLayerIds.add(layer.id)\n }\n }\n\n /**\n * 移除 Layer\n */\n public removeLayer(layerId: string): void {\n this.checkDestroyed()\n if (this.map.getLayer(layerId)) {\n this.map.removeLayer(layerId)\n }\n const index = this.layerList.findIndex((item) => item.layer.id === layerId)\n if (index > -1) {\n this.layerList.splice(index, 1)\n }\n this.managedLayerIds.delete(layerId)\n }\n\n /**\n * 移除 Source(会先移除关联的 Layer)\n */\n public removeSource(sourceId: string): void {\n this.checkDestroyed()\n // 移除使用该 source 的 layer\n const layersToRemove = this.layerList.filter(\n (item) => 'source' in item.layer && item.layer.source === sourceId,\n )\n layersToRemove.forEach((item) => {\n this.removeLayer(item.layer.id)\n })\n\n if (this.map.getSource(sourceId)) {\n this.map.removeSource(sourceId)\n }\n this.sourceData.delete(sourceId)\n this.managedSourceIds.delete(sourceId)\n // 清理该 source 相关的 feature 索引\n for (const key of this.featureIndex.keys()) {\n if (key.startsWith(`${sourceId}:`)) {\n this.featureIndex.delete(key)\n }\n }\n }\n\n public findFeature(source: string, featureId: string): GeoJSON.Feature | undefined {\n const data = this.sourceData.get(source)\n return data?.features.find((item) => item.id === featureId)\n }\n\n /**\n * 获取 Source\n */\n public getSource(id: string): Source | undefined {\n return this.map.getSource(id)\n }\n\n /**\n * 核心逻辑:更新内存数据 -> 标记为脏 -> 调度渲染\n * 支持增、删、改\n */\n public setGeoJSONData(\n id: string,\n data: GeoJSON.Feature<GeoJSON.Geometry | null> | GeoJSON.Feature<GeoJSON.Geometry | null>[],\n ): void {\n this.checkDestroyed()\n const inputFeatures = Array.isArray(data) ? data : [data]\n\n let collection = this.sourceData.get(id)\n if (!collection) {\n collection = { type: 'FeatureCollection', features: [] }\n this.sourceData.set(id, collection)\n }\n\n inputFeatures.forEach((newFeature) => {\n if (!isValidId(newFeature.id)) return\n\n const indexKey = `${id}:${String(newFeature.id)}`\n const existingIndex = this.featureIndex.get(indexKey)\n\n // === 删除逻辑 (Geometry 为 null) ===\n if (newFeature.geometry === null) {\n if (existingIndex !== undefined) {\n collection.features.splice(existingIndex, 1)\n this.featureIndex.delete(indexKey)\n // 更新被删除元素之后的索引\n for (const [key, idx] of this.featureIndex.entries()) {\n if (key.startsWith(`${id}:`) && idx > existingIndex) {\n this.featureIndex.set(key, idx - 1)\n }\n }\n }\n } else {\n const feature = newFeature as GeoJSON.Feature\n if (existingIndex !== undefined) {\n // 替换旧数据\n collection.features[existingIndex] = feature\n } else {\n // 追加新数据\n const newIndex = collection.features.length\n collection.features.push(feature)\n this.featureIndex.set(indexKey, newIndex)\n }\n }\n })\n\n this.dirtySourceIds.add(id)\n this.scheduleRender()\n }\n\n /**\n * 调度器:利用 requestAnimationFrame 防抖\n */\n private scheduleRender(): void {\n if (this.renderFrameId !== null) return\n\n this.renderFrameId = requestAnimationFrame(() => {\n this.flushUpdates()\n this.renderFrameId = null\n })\n }\n\n /**\n * 执行器:真正调用 Mapbox API\n */\n private flushUpdates(): void {\n if (this.destroyed) return\n\n this.dirtySourceIds.forEach((id) => {\n try {\n const source = this.getSource(id)\n const collection = this.sourceData.get(id)\n\n if (source?.type === 'geojson' && collection) {\n ;(source as GeoJSONSource).setData({\n ...collection,\n features: [...collection.features],\n })\n }\n } catch (e) {\n console.warn(`[ResourceRegister] Failed to update source \"${id}\":`, e)\n }\n })\n\n this.dirtySourceIds.clear()\n }\n\n public setState(source: string, id: string, states: Record<string, unknown>): void {\n this.checkDestroyed()\n if (!this.map.getSource(source)) {\n console.warn(`[ResourceRegister] Source \"${source}\" not found`)\n return\n }\n this.map.setFeatureState(\n {\n source,\n id,\n },\n states,\n )\n }\n\n public getState(source: string, id: string): Record<string, unknown> | null | undefined {\n this.checkDestroyed()\n if (!this.map.getSource(source)) {\n return null\n }\n return this.map.getFeatureState({\n source,\n id,\n })\n }\n\n /**\n * 销毁清理\n * @param removeFromMap 是否从地图上移除由此类管理的 Source 和 Layer,默认 false\n */\n public destroy(removeFromMap = false): void {\n if (this.destroyed) return\n this.destroyed = true\n\n if (this.renderFrameId !== null) {\n cancelAnimationFrame(this.renderFrameId)\n this.renderFrameId = null\n }\n\n if (removeFromMap) {\n // 移除由此类管理的 layer\n for (const layerId of this.managedLayerIds) {\n if (this.map.getLayer(layerId)) {\n this.map.removeLayer(layerId)\n }\n }\n // 移除由此类管理的 source\n for (const sourceId of this.managedSourceIds) {\n if (this.map.getSource(sourceId)) {\n this.map.removeSource(sourceId)\n }\n }\n }\n\n this.layerList = []\n this.sourceData.clear()\n this.dirtySourceIds.clear()\n this.featureIndex.clear()\n this.managedSourceIds.clear()\n this.managedLayerIds.clear()\n }\n}\n\nexport default ResourceRegister\n","import type { LayerSpecification } from 'mapbox-gl'\n\n/** ------------------------------------------------ 聚焦图层 --------------------------------------------------------**/\n\nexport const FOCUS_SOURCE_NAME = 'mapbox-gl-focus-source'\n\nexport const FOCUS_LAYER_NAME = 'mapbox-gl-focus-layer'\n\nexport const FOCUS_Z_INDEX = 99999\n\nexport const FOCUS_LAYER: LayerSpecification = {\n id: FOCUS_LAYER_NAME,\n type: 'line',\n source: FOCUS_SOURCE_NAME,\n paint: {\n 'line-color': '#f00',\n 'line-width': 3,\n },\n layout: {},\n}\n","import { bbox, multiLineString } from '@turf/turf'\nimport EventEmitter from 'eventemitter3'\nimport type { BBox, Feature, MultiLineString } from 'geojson'\nimport { set } from 'lodash-es'\nimport type { GeoJSONSource } from 'mapbox-gl'\nimport type { Map } from 'mapbox-gl'\nimport { v4 } from 'uuid'\n\nimport ResourceRegister from '@/core/ResourceRegister'\nimport type { FocusItem, IFocusOptions } from '@/types/Focus'\nimport { distanceToPx } from '@/utils/util.ts'\n\nimport { FOCUS_LAYER, FOCUS_SOURCE_NAME, FOCUS_Z_INDEX } from './vars.ts'\n\nclass Focus extends EventEmitter {\n private readonly map: Map\n focusItems: FocusItem[] = []\n private register: ResourceRegister\n\n zoomendFunc = this._zoomend.bind(this)\n\n constructor(map: Map) {\n super()\n\n this.map = map\n this.register = new ResourceRegister(map)\n this.onAdd()\n }\n\n get features(): FocusItem['feature'][] {\n return this.focusItems.map((item) => item.border)\n }\n\n onAdd(): void {\n this.register.addSource(FOCUS_SOURCE_NAME, {\n type: 'geojson',\n dynamic: true,\n data: {\n type: 'FeatureCollection',\n features: [],\n },\n })\n\n this.register.addLayer({ layer: FOCUS_LAYER, zIndex: FOCUS_Z_INDEX })\n }\n onRemove(): void {\n this.removeAll()\n }\n\n set(feature: Feature, options?: IFocusOptions): string | number {\n const uuid = feature.id ?? v4()\n\n this._onHandle(uuid, feature, options)\n\n return uuid\n }\n\n get(id: string): FocusItem | undefined {\n return this.focusItems.find((item) => item.id === id)\n }\n\n remove(id: string): void {\n const i = this.focusItems.findIndex((item) => item.id === id)\n if (i !== -1) {\n this.focusItems.splice(i, 1)\n }\n this.render()\n }\n\n removeAll(): void {\n this.focusItems = []\n this.render()\n }\n\n render(): void {\n const source = this.map.getSource<GeoJSONSource>(FOCUS_SOURCE_NAME)\n\n if (source) {\n if (this.features.length > 0) {\n source.updateData({\n type: 'FeatureCollection',\n features: this.features,\n })\n } else {\n source.setData({\n type: 'FeatureCollection',\n features: this.features,\n })\n }\n }\n }\n\n private _zoomend(): void {\n // this.focusItems.forEach((item) => {\n // this.set(item.feature, { ...item.options, id: item.id })\n // })\n\n this.render()\n }\n\n private _onHandle(uuid: string | number, feature: Feature, options?: IFocusOptions): void {\n const border = this.getFocusBorder(feature, options)\n const item: FocusItem = { id: uuid, border, feature, options }\n\n const i = this.focusItems.findIndex((item) => item.id === uuid)\n if (i !== -1) {\n set(this.focusItems, i, item)\n } else {\n this.focusItems.push(item)\n }\n\n this.render()\n\n if (this.features.length > 0) {\n this.map.on('zoomend', this.zoomendFunc)\n } else {\n this.map.off('zoomend', this.zoomendFunc)\n }\n }\n\n /**\n * 通用聚焦边框生成方法\n * @param feature 目标要素 (Point | LineString | Polygon)\n * @param options 配置项\n * @returns 聚焦框 Feature\n */\n public getFocusBorder(\n feature: Feature,\n options: IFocusOptions = {},\n ): Feature<MultiLineString, { id: string }> {\n const id = String(feature.id ?? v4())\n const { padding = 10, armLength = 20, size = 40 } = options\n\n // 1. 计算原始 BBox\n // 如果是 Point,bbox 是一个点;如果是 Line/Poly,是外包矩形\n const rawBBox = bbox(feature) // [minLng, minLat, maxLng, maxLat]\n\n // 2. 准备计算参数\n // 计算当前缩放级别下,1 像素代表多少米 (用于像素 -> 地理坐标转换)\n // distanceToPx(map, 1) 返回的是 1米多少像素,取倒数就是 1像素多少米\n const metersPerPixel = 1 / distanceToPx(this.map, 1)\n\n // 3. 差异化处理\n let finalBBox = rawBBox\n let finalArmLengthMeters = 0\n\n if (feature.geometry.type === 'Point') {\n // === Point 逻辑 ===\n // 主要是基于 icon size 向外扩张\n // 假设 pointSize 是图标宽/高,padding 是额外留白\n const halfSizePx = (size + padding) / 2\n const expandMeters = halfSizePx * metersPerPixel\n\n // 计算手臂长度:保持你原来的比例 (size * 0.3)\n finalArmLengthMeters = size * 0.3 * metersPerPixel\n\n // 扩展 BBox (中心点向四周扩散)\n finalBBox = this._expandBBox(rawBBox, expandMeters, rawBBox[1])\n } else {\n // === LineString / Polygon 逻辑 ===\n // 基于几何体 BBox,加上固定的 Padding\n const paddingMeters = padding * metersPerPixel\n\n // 手臂长度:使用固定的像素长度 (防止大物体出现巨大手臂)\n // 同时做一个限制:手臂不能超过边长的一半,否则四个角会这就连在一起了\n // 简单起见,这里先用固定长度\n finalArmLengthMeters = armLength * metersPerPixel\n\n // 扩展 BBox\n finalBBox = this._expandBBox(rawBBox, paddingMeters, rawBBox[1])\n }\n\n // 4. 调用核心绘制逻辑\n return this._createBracketGeometry(id, finalBBox, finalArmLengthMeters)\n }\n\n /**\n * 辅助:向外扩展 BBox (米 -> 经纬度)\n */\n private _expandBBox(rawBBox: number[], expandMeters: number, baseLat: number): BBox {\n const [minLng, minLat, maxLng, maxLat] = rawBBox\n\n const METERS_PER_DEGREE_LAT = 111319\n const dLat = expandMeters / METERS_PER_DEGREE_LAT\n const dLng = dLat / Math.cos((baseLat * Math.PI) / 180)\n\n return [minLng - dLng, minLat - dLat, maxLng + dLng, maxLat + dLat]\n }\n\n /**\n * 核心绘制:根据 BBox 和 手臂物理长度 生成括号坐标\n * (这是你原来那个方法的纯净版,去掉了业务逻辑,只负责画图)\n */\n private _createBracketGeometry(\n id: string,\n bbox: number[],\n armLengthMeters: number,\n ): Feature<MultiLineString, { id: string }> {\n const [minLng, minLat, maxLng, maxLat] = bbox\n\n // 经纬度转换\n const METERS_PER_DEGREE_LAT = 111319\n const dLat = armLengthMeters / METERS_PER_DEGREE_LAT\n const latRad = (minLat * Math.PI) / 180\n const dLng = dLat / Math.cos(latRad)\n\n // 限制手臂长度,防止重叠 (可选优化)\n // 如果 BBox 特别小,dLat 可能大于高度的一半\n const actualDLat = Math.min(dLat, (maxLat - minLat) / 2)\n const actualDLng = Math.min(dLng, (maxLng - minLng) / 2)\n\n const coordinates = [\n // 左下角 (BL)\n [\n [minLng + actualDLng, minLat],\n [minLng, minLat],\n [minLng, minLat + actualDLat],\n ],\n // 左上角 (TL)\n [\n [minLng, maxLat - actualDLat],\n [minLng, maxLat],\n [minLng + actualDLng, maxLat],\n ],\n // 右上角 (TR)\n [\n [maxLng - actualDLng, maxLat],\n [maxLng, maxLat],\n [maxLng, maxLat - actualDLat],\n ],\n // 右下角 (BR)\n [\n [maxLng, minLat + actualDLat],\n [maxLng, minLat],\n [maxLng - actualDLng, minLat],\n ],\n ]\n\n return multiLineString(coordinates, { id }, { id })\n }\n}\n\nexport default Focus\n","import EventEmitter from 'eventemitter3'\nimport type { Map } from 'mapbox-gl'\n\nimport { EventManager } from '@/core/EventManager'\nimport Focus from '@/core/Focus'\nimport IconManager from '@/core/IconManager'\nimport ResourceRegister from '@/core/ResourceRegister'\nimport type { IContextOptions } from '@/types/Module/Context.ts'\n\nexport class Context {\n public readonly map: Map\n public readonly events: EventEmitter\n public readonly register: ResourceRegister\n public readonly iconManage: IconManager\n public readonly focus: Focus\n public readonly eventManager: EventManager\n\n // 4. 一个通用的状态存储 (替代原来的 Store._listeners 等)\n // public readonly state: Map<string, any> = new Map();\n\n public constructor(options: IContextOptions) {\n this.map = options.map\n this.events = new EventEmitter()\n this.register = new ResourceRegister(this.map)\n this.iconManage = new IconManager(this.map)\n this.focus = new Focus(this.map)\n this.eventManager = new EventManager(this.map)\n\n // this.map.on('load', () => {\n // this.focus.onAdd()\n // })\n }\n\n // 提供一个销毁方法,统一清理资源\n public destroy(): void {\n this.events.removeAllListeners()\n // this.icons.clear();\n // this.map.remove(); // map 的销毁通常由外部控制,这里视情况而定\n return\n }\n}\n\nconst registry = new WeakMap<Map, Context>()\n\n/**\n * 获取或创建上下文\n * 这是整个单例逻辑的入口,但它是“每个 Map 一个单例”\n */\nexport function getOrCreateContext(map: Map): Context {\n const existing = registry.get(map)\n\n // 2. 如果存在,直接返回\n if (existing) {\n return existing\n }\n\n const context = new Context({ map })\n registry.set(map, context)\n\n // 监听移除,防止内存泄漏\n map.once('remove', () => {\n context.destroy()\n registry.delete(map)\n })\n\n return context\n}\n","import EventEmitter from 'eventemitter3'\nimport type { Map } from 'mapbox-gl'\n\nimport type { Context } from './Context.ts'\nimport { getOrCreateContext } from './Context.ts'\n\nexport abstract class Module extends EventEmitter {\n protected context: Context\n\n /**\n * 构造函数,初始化地图上下文和选项配置\n * @param map - 地图实例对象\n */\n protected constructor(map: Map) {\n super()\n\n this.context = getOrCreateContext(map)\n\n this.onAdd()\n\n this.context.map.once('beforeRemove', () => {\n this.onRemove()\n })\n }\n\n public mount(): void {\n this.onAdd()\n }\n\n public destroy(): void {\n this.onRemove()\n }\n\n abstract onAdd(): void\n\n abstract onRemove(): void\n}\n","import type { LayerSpecification } from 'mapbox-gl'\n\nimport type { SortLayer } from '@/core/ResourceRegister'\n\nexport const CONNECT_LINE_LAYER_NAME = 'mapbox-gl-tooltip-connect-line'\n\nexport const CONNECT_DEBUG_LINE_LAYER_NAME = 'mapbox-gl-tooltip-connect-debug-line'\n\nexport const CONNECT_DEBUG_FILL_LAYER_NAME = 'mapbox-gl-tooltip-connect-debug-fill'\n\nexport const TOOLTIP_SOURCE_NAME = 'mapbox-gl-tooltip-source'\n\nexport const CONNECT_LINE_LAYER: LayerSpecification = {\n id: CONNECT_LINE_LAYER_NAME,\n source: TOOLTIP_SOURCE_NAME,\n type: 'line',\n paint: {\n 'line-color': '#000',\n 'line-width': 1,\n },\n}\n\nexport const CONNECT_DEBUG_LINE_LAYER: LayerSpecification = {\n id: CONNECT_DEBUG_LINE_LAYER_NAME,\n source: TOOLTIP_SOURCE_NAME,\n type: 'line',\n filter: ['all', ['==', 'meta', 'debug']],\n paint: {\n 'line-color': '#f00',\n 'line-width': 1,\n },\n}\n\nexport const CONNECT_DEBUG_FILL_LAYER: LayerSpecification = {\n id: CONNECT_DEBUG_FILL_LAYER_NAME,\n source: TOOLTIP_SOURCE_NAME,\n type: 'fill',\n filter: ['all', ['==', 'meta', 'debug']],\n paint: {\n 'fill-color': '#f00',\n 'fill-opacity': 0,\n },\n}\n\nexport const LAYERS: SortLayer[] = [\n {\n layer: CONNECT_LINE_LAYER,\n zIndex: 9999,\n },\n {\n layer: CONNECT_DEBUG_FILL_LAYER,\n zIndex: 9999,\n },\n {\n layer: CONNECT_DEBUG_LINE_LAYER,\n zIndex: 9999,\n },\n]\n","import { bboxPolygon, lineString } from '@turf/turf'\nimport type * as GeoJSON from 'geojson'\nimport type { LngLat, Map } from 'mapbox-gl'\nimport { Marker, Point } from 'mapbox-gl'\nimport type { BBox } from 'rbush'\n\nimport { Module } from '@/core/Module'\nimport type { AllAnchor, ITooltipOptions, SimpleAnchor } from '@/types/Toolip'\n\nimport { LAYERS, TOOLTIP_SOURCE_NAME } from './vars.ts'\n\nexport class Tooltip extends Module {\n static DEBUG = false\n\n options: ITooltipOptions\n\n private mark: Marker | null = null\n\n private zoom = (): void => {\n this.render()\n }\n\n constructor(map: Map, options: ITooltipOptions) {\n super(map)\n this.options = options\n\n if (this.visible) {\n this.context.map.on('zoom', this.zoom)\n this.context.map.on('zoomend', this.zoom)\n }\n }\n\n get id(): string | number {\n return this.options.id\n }\n\n get visible(): boolean {\n const bounds = this.context.map.getBounds()\n\n return !!this.options.visible && !!bounds?.contains(this.options.position)\n }\n\n get bbox(): BBox {\n const allBbox = this.getAllBbox()\n const anchor = this.options.anchor ?? 'bottom-right'\n return allBbox[anchor]\n }\n\n override onAdd(): void {\n this.context.register.addSource(TOOLTIP_SOURCE_NAME, {\n type: 'geojson',\n dynamic: true,\n data: {\n type: 'FeatureCollection',\n features: [],\n },\n })\n\n LAYERS.forEach((layer) => {\n this.context.register.addLayer(layer)\n })\n }\n\n override onRemove(): void {\n this.remove()\n }\n\n private debug(): void {\n const { minX, minY, maxX, maxY } = this.bbox\n const { lng: minLon, lat: minLat } = this.context.map.unproject(new Point(minX, minY))\n const { lng: maxLon, lat: maxLat } = this.context.map.unproject(new Point(maxX, maxY))\n const fill = bboxPolygon([minLon, minLat, maxLon, maxLat], {\n properties: { meta: 'debug' },\n id: String(this.id) + 'debug',\n })\n\n this.context.register.setGeoJSONData(TOOLTIP_SOURCE_NAME, fill)\n }\n\n hide(): void {\n this.options.visible = false\n this.render()\n this.context.map.off('zoom', this.zoom)\n this.context.map.off('zoomend', this.zoom)\n }\n\n show(): void {\n this.options.visible = true\n this.render()\n this.context.map.on('zoom', this.zoom)\n this.context.map.on('zoomend', this.zoom)\n }\n\n update(options: ITooltipOptions): void {\n this.options = options\n this.render()\n }\n\n setAnchor(anchor: ITooltipOptions['anchor']): void {\n if (this.mark) {\n this.mark.remove()\n this.mark = null\n }\n\n this.options.anchor = anchor\n\n this.show()\n }\n\n getSimpleBbox(): SimpleAnchor {\n return {\n 'top-left': this.getBbox('top-left'),\n 'top-right': this.getBbox('top-right'),\n 'bottom-left': this.getBbox('bottom-left'),\n 'bottom-right': this.getBbox('bottom-right'),\n }\n }\n\n getAllBbox(): AllAnchor {\n return {\n center: this.getBbox('center'),\n top: this.getBbox('top'),\n bottom: this.getBbox('bottom'),\n left: this.getBbox('left'),\n right: this.getBbox('right'),\n 'top-left': this.getBbox('top-left'),\n 'top-right': this.getBbox('top-right'),\n 'bottom-left': this.getBbox('bottom-left'),\n 'bottom-right': this.getBbox('bottom-right'),\n }\n }\n\n getBbox(val?: ITooltipOptions['anchor']): BBox {\n const anchor = val ?? this.options.anchor\n\n const point = this.context.map.project(this.options.position)\n const offset = new Point(this.options.offsetX ?? 0, this.options.offsetY ?? 0)\n const { width, height } = this.getOffDOMSize(this.options.element)\n\n const bbox: BBox = {\n minX: point.x,\n minY: point.y,\n maxX: point.x,\n maxY: point.y,\n }\n // if (anchor === 'top') {\n // bbox.minX = point.x - offsetWidth / 2\n // bbox.maxX = point.x + offsetWidth / 2\n // bbox.maxY = point.y + offsetHeight + Math.abs(offset.y)\n // } else if (anchor === 'bottom') {\n // bbox.minX = point.x - offsetWidth / 2\n // bbox.maxX = point.x + offsetWidth / 2\n // bbox.minY = point.y - offsetHeight + offset.y\n // } else if (anchor === 'left') {\n // bbox.maxY = point.y + offsetHeight / 2\n // bbox.minY = point.y - offsetHeight / 2\n // bbox.maxX = point.x + offsetWidth + Math.abs(offset.x)\n // } else if (anchor === 'right') {\n // bbox.maxY = point.y + offsetHeight / 2\n // bbox.minY = point.y - offsetHeight / 2\n // bbox.minX = point.x - offsetWidth + offset.x\n // } else if (anchor === 'center') {\n // bbox.maxY = point.y + offsetHeight / 2\n // bbox.minY = point.y - offsetHeight / 2\n // bbox.maxX = point.x + offsetWidth / 2\n // bbox.minX = point.x - offsetWidth / 2\n // } else\n if (anchor === 'top-left') {\n bbox.maxY = point.y + height + Math.abs(offset.y)\n bbox.maxX = point.x + width + Math.abs(offset.x)\n } else if (anchor === 'top-right') {\n bbox.maxY = point.y + height + Math.abs(offset.y)\n bbox.minX = point.x - (width + offset.x)\n } else if (anchor === 'bottom-left') {\n bbox.minY = point.y - (height + offset.y)\n bbox.maxX = point.x + width + Math.abs(offset.x)\n } else if (anchor === 'bottom-right') {\n bbox.minY = point.y - (height + offset.y)\n bbox.minX = point.x - (width + offset.x)\n }\n\n return bbox\n }\n\n private getOffDOMSize(label: HTMLElement): { width: number; height: number } {\n const element = label.cloneNode(true) as HTMLElement\n // 1. 保存原始样式 (为了测量后恢复,避免污染元素)\n const originalStyles = {\n position: element.style.position,\n visibility: element.style.visibility,\n top: element.style.top,\n left: element.style.left,\n display: element.style.display, // 防止元素本身带有 display: none\n }\n\n // 2. 设置“隐形”样式\n // 关键:不能用 display: none,否则拿不到尺寸\n element.style.position = 'absolute'\n element.style.visibility = 'hidden'\n element.style.top = '-9999px'\n element.style.left = '-9999px'\n element.style.display = 'block' // 确保它是块级或行内块,能撑开宽高\n // 可选:如果内容是纯文本且需要自动换行,可能需要指定一个 max-width\n // element.style.width = 'max-content';\n\n // 3. 插入 DOM\n this.context.map.getCanvasContainer().appendChild(element)\n\n // 4. 测量\n const width = element.offsetWidth\n const height = element.offsetHeight\n // 如果需要更精确的小数点,可以用 getBoundingClientRect\n // const rect = element.getBoundingClientRect();\n // const width = rect.width;\n // const height = rect.height;\n\n // 5. 移除 DOM\n this.context.map.getCanvasContainer().removeChild(element)\n\n // 6. 恢复原始样式 (如果是克隆的节点这一步可以省略)\n element.style.position = originalStyles.position\n element.style.visibility = originalStyles.visibility\n element.style.top = originalStyles.top\n element.style.left = originalStyles.left\n element.style.display = originalStyles.display\n\n return { width, height }\n }\n\n remove(): void {\n this.options.visible = false\n this.context.map.off('zoom', this.zoom)\n this.context.map.off('zoomend', this.zoom)\n\n if (this.mark) {\n this.mark.remove()\n this.mark = null\n }\n\n this.connectLine()\n }\n\n _create(): void {\n this.mark = new Marker({\n className: this.options.className ?? 'mapbox-gl-tooltip',\n element: this.options.element,\n offset: this._getOffsetByAnchor(),\n anchor: this.options.anchor,\n }).setLngLat(this.options.position)\n }\n\n _getOffsetByAnchor(): Point {\n const offset = new Point(0, 0)\n if (this.options.anchor === 'center') {\n offset.x = 0\n offset.y = 0\n } else if (this.options.anchor === 'top') {\n offset.x = 0\n offset.y = this.options.offsetY ?? 0\n } else if (this.options.anchor === 'bottom') {\n offset.x = 0\n offset.y = -(this.options.offsetY ?? 0)\n } else if (this.options.anchor === 'left') {\n offset.x = this.options.offsetX ?? 0\n offset.y = 0\n } else if (this.options.anchor === 'right') {\n offset.x = -(this.options.offsetX ?? 0)\n offset.y = 0\n } else if (this.options.anchor === 'top-left') {\n offset.x = this.options.offsetX ?? 0\n offset.y = this.options.offsetY ?? 0\n } else if (this.options.anchor === 'top-right') {\n offset.x = -(this.options.offsetX ?? 0)\n offset.y = this.options.offsetY ?? 0\n } else if (this.options.anchor === 'bottom-left') {\n offset.x = this.options.offsetX ?? 0\n offset.y = -(this.options.offsetY ?? 0)\n } else if (this.options.anchor === 'bottom-right') {\n offset.x = -(this.options.offsetX ?? 0)\n offset.y = -(this.options.offsetY ?? 0)\n }\n\n return offset\n }\n\n setLngLat(lngLat: LngLat): this {\n this.options.position = lngLat\n\n if (this.mark) {\n this.mark.setLngLat(lngLat)\n }\n\n return this\n }\n\n connectLine(): void {\n if (!this.options.line) return\n\n const id = `${String(this.options.id)}-tooltip-connect-line`\n\n const endPoint = this.connectPoint()\n if (!endPoint || !this.visible) {\n const emptyFeature: GeoJSON.Feature<GeoJSON.Point> = {\n type: 'Feature',\n geometry: {\n type: 'Point',\n coordinates: [0, 0],\n },\n id,\n properties: {},\n }\n\n this.context.register.setGeoJSONData(TOOLTIP_SOURCE_NAME, emptyFeature)\n return\n }\n\n const lonLat = [this.options.position.toArray(), endPoint.toArray()]\n\n const feature: GeoJSON.Feature<GeoJSON.LineString> = lineString(\n lonLat,\n {},\n {\n id,\n },\n )\n\n this.context.register.setGeoJSONData(TOOLTIP_SOURCE_NAME, feature)\n }\n\n connectPoint(): LngLat | null {\n if (!this.mark || !this.visible) return null\n\n const point = this.context.map.project(this.mark.getLngLat())\n const offset = this.mark.getOffset()\n\n point.x += offset.x\n point.y += offset.y\n\n const { width } = this.getOffDOMSize(this.options.element)\n\n if (this.options.anchor === 'top-left') {\n point.x += width / 2\n } else if (this.options.anchor === 'top-right') {\n point.x -= width / 2\n } else if (this.options.anchor === 'bottom-left') {\n point.x += width / 2\n } else if (this.options.anchor === 'bottom-right') {\n point.x -= width / 2\n }\n\n return this.context.map.unproject(point)\n }\n\n render(): this {\n if (this.visible) {\n if (!this.mark) {\n this._create()\n }\n\n this.mark?.addTo(this.context.map)\n\n if (Tooltip.DEBUG) {\n this.debug()\n }\n } else {\n this.mark?.remove()\n this.mark = null\n }\n\n this.connectLine()\n return this\n }\n}\n","import type { LayerSpecification } from 'mapbox-gl'\n\nimport type { SortLayer } from '@/core/ResourceRegister'\nimport type { SvgIcon } from '@/types/IconManager'\n\nexport const NAME = 'Ais'\n\nexport const Z_INDEX = 300\n\nexport const SHIP_SOURCE_NAME = 'mapbox-gl-ship-source'\n\nexport const SHIP_ICON_LAYER_NAME = 'mapbox-gl-ship-icon-layer'\n\nexport const SHIP_ICON_DIRECTION_LAYER_NAME = 'mapbox-gl-ship-icon-direction-layer'\n\nexport const SHIP_REAL_LAYER_NAME = 'mapbox-gl-ship-real-layer'\n\nexport const SHIP_REAL_OUTLINE_LAYER_NAME = 'mapbox-gl-ship-real-outline-layer'\n\nexport const MIN_ICON_SIZE = 0.2\n\nexport const MAX_ICON_SIZE = 0.5\n\nexport enum UPDATE_STATUS {\n ONLINE = 'Online',\n DELAY = 'Delay',\n OFFLINE = 'Offline',\n}\n\nexport enum SHIP_COLOR {\n ONLINE = '#03CC02',\n DELAY = '#FFFD6C',\n OFFLINE = '#999999',\n}\n\nexport const SHIP_ICON_DIRECTION_LAYER: LayerSpecification = {\n id: SHIP_ICON_DIRECTION_LAYER_NAME,\n source: SHIP_SOURCE_NAME,\n filter: ['==', ['get', 'meta'], 'directionLine'],\n type: 'line',\n layout: {},\n paint: {\n 'line-color': ['coalesce', ['get', 'line-color'], '#000'],\n 'line-width': 1,\n },\n}\n\nexport const SHIP_ICON_LAYER: LayerSpecification = {\n id: SHIP_ICON_LAYER_NAME,\n source: SHIP_SOURCE_NAME,\n filter: ['==', '$type', 'Point'],\n type: 'symbol',\n layout: {\n 'icon-allow-overlap': true,\n 'icon-image': ['get', 'icon'],\n 'icon-rotate': ['get', 'direction'],\n 'icon-size': [\n 'interpolate',\n ['linear'],\n ['zoom'],\n 0,\n ['coalesce', ['get', 'minIconSize'], 0.2],\n 19,\n ['coalesce', ['get', 'maxIconSize'], 0.5],\n ],\n },\n}\n\nexport const SHIP_REAL_LAYER: LayerSpecification = {\n id: SHIP_REAL_LAYER_NAME,\n source: SHIP_SOURCE_NAME,\n type: 'fill',\n filter: ['!=', ['get', 'meta'], 'directionLine'],\n layout: {},\n paint: {\n 'fill-color': [\n 'case',\n ['==', ['get', 'updateStatus'], UPDATE_STATUS.ONLINE],\n SHIP_COLOR.ONLINE,\n ['==', ['get', 'updateStatus'], UPDATE_STATUS.DELAY],\n SHIP_COLOR.DELAY,\n ['==', ['get', 'updateStatus'], UPDATE_STATUS.OFFLINE],\n SHIP_COLOR.OFFLINE,\n SHIP_COLOR.OFFLINE,\n ],\n },\n}\n\nexport const SHIP_REAL_OUTLINE_LAYER: LayerSpecification = {\n id: SHIP_REAL_OUTLINE_LAYER_NAME,\n source: SHIP_SOURCE_NAME,\n type: 'line',\n filter: ['!=', ['get', 'meta'], 'directionLine'],\n layout: {},\n paint: {\n 'line-color': [\n 'case',\n ['boolean', ['feature-state', 'hover'], false],\n '#f00',\n ['boolean', ['feature-state', 'focus'], false],\n '#f00',\n '#000',\n ],\n 'line-width': 2,\n },\n}\n\nexport const LAYER_LIST: SortLayer[] = [\n {\n layer: SHIP_ICON_DIRECTION_LAYER,\n zIndex: Z_INDEX,\n },\n {\n layer: SHIP_ICON_LAYER,\n zIndex: Z_INDEX,\n },\n {\n layer: SHIP_REAL_LAYER,\n zIndex: Z_INDEX,\n },\n {\n layer: SHIP_REAL_OUTLINE_LAYER,\n zIndex: Z_INDEX,\n },\n]\n\nexport const SHIP_ICON: SvgIcon[] = [\n {\n name: `${NAME}-$color`,\n svg:\n '<?xml version=\"1.0\" encoding=\"UTF-8\"?>\\n' +\n '<svg width=\"33px\" height=\"49px\" viewBox=\"0 0 33 49\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\\n' +\n ' <title>delay_nospeed</title>\\n' +\n ' <g id=\"页面-1\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\\n' +\n ' <g id=\"delay_nospeed\" fill=\"$color\" stroke=\"#000000\" stroke-width=\"2\">\\n' +\n ' <path d=\"M16.5,3.13354433 L31.6080922,48 L1.39190779,48 L16.5,3.13354433 Z\" id=\"三角形\"></path>\\n' +\n ' </g>\\n' +\n ' </g>\\n' +\n '</svg>',\n },\n {\n name: `${NAME}-$color-active`,\n svg:\n '<?xml version=\"1.0\" encoding=\"UTF-8\"?>\\n' +\n '<svg width=\"33px\" height=\"49px\" viewBox=\"0 0 33 49\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\">\\n' +\n ' <title>delay_nospeed_select</title>\\n' +\n ' <g id=\"页面-1\" stroke=\"none\" stroke-width=\"1\" fill=\"none\" fill-rule=\"evenodd\">\\n' +\n ' <g id=\"delay_nospeed_select\" fill=\"$color\" stroke=\"#FF0000\" stroke-width=\"2\">\\n' +\n ' <path d=\"M16.5,3.13354433 L31.6080922,48 L1.39190779,48 L16.5,3.13354433 Z\" id=\"三角形\"></path>\\n' +\n ' </g>\\n' +\n ' </g>\\n' +\n '</svg>',\n },\n]\n","import type { LngLatLike, MapOptions, PopupOptions } from 'mapbox-gl'\n\nexport interface BeforeRemoveEvent {\n /**\n * 阻止销毁的方法\n * @param isCancel - true: 阻止销毁; false: 继续销毁\n */\n cancel: () => void\n next: () => void\n}\n\nexport enum MapType {\n LAND = 'land',\n SATELLITE = 'satellite',\n}\n\nexport interface formatOptions {\n value: string | number\n data: object\n}\n\nexport interface InfoFormConfig {\n label: string | number\n\n prop: string | number\n\n format(formatOptions: formatOptions): string\n}\n\nexport type customPopupOptions = PopupOptions & {\n center: LngLatLike\n\n config: InfoFormConfig[]\n\n data: object\n\n template: string\n}\n\nexport interface ICMapOptions extends MapOptions {\n type?: MapType\n TDTToken?: string\n http2?: boolean\n}\n","import type { StyleSpecification } from 'mapbox-gl'\n\nimport { MapType } from '@/types/CMap'\n\nconst TDT_TOKEN = 'dedbd86f02e50097b36eb7cfc2e0bf5f'\n\nconst TMap: Record<MapType, string> = {\n [MapType.LAND]: 'vec_w',\n [MapType.SATELLITE]: 'img_w',\n}\n\nexport function createStyle(\n type: MapType = MapType.LAND,\n http2 = true,\n tdtToken?: string,\n glyphs?: string,\n): StyleSpecification {\n const protocol = http2 ? 'https' : 'http'\n const token = tdtToken ?? TDT_TOKEN\n\n const T: string = TMap[type]\n\n const baseTiles = Array.from(\n { length: 8 },\n (_, index) =>\n `${protocol}://t${String(index)}.tianditu.gov.cn/DataServer?T=${T}&x={x}&y={y}&l={z}&tk=${token}`,\n )\n\n const labelTiles = Array.from(\n { length: 8 },\n (_, index) =>\n `${protocol}://t${String(index)}.tianditu.gov.cn/DataServer?T=cva_w&x={x}&y={y}&l={z}&tk=${token}`,\n )\n\n return {\n version: 8,\n name: 'Basic',\n glyphs:\n glyphs ?? 'https://sdkinteligenceberth.zhonganhse.com:21333/app/font/{fontstack}/{range}.pbf',\n sources: {\n base: {\n tiles: baseTiles,\n type: 'raster',\n tileSize: 256,\n minzoom: 0,\n maxzoom: 21,\n },\n label: {\n tiles: labelTiles,\n type: 'raster',\n tileSize: 256,\n minzoom: 0,\n maxzoom: 21,\n },\n },\n layers: [\n {\n id: 'background',\n type: 'background',\n paint: {\n 'background-color': 'rgba(212,234,238,1)',\n },\n },\n {\n id: 'base_layer',\n source: 'base',\n type: 'raster',\n },\n {\n id: 'label_layer',\n source: 'label',\n type: 'raster',\n },\n {\n id: 'base-end',\n type: 'background',\n paint: {\n 'background-color': 'transparent',\n },\n },\n {\n id: 'point-end',\n type: 'background',\n paint: {\n 'background-color': 'transparent',\n },\n },\n ],\n }\n}\n","import EventEmitter from 'eventemitter3'\nimport { isEmpty } from 'lodash-es'\nimport type { GeoJSONSource, SourceSpecification } from 'mapbox-gl'\nimport { Map } from 'mapbox-gl'\n\nimport IconManager from '@/core/IconManager'\nimport { SHIP_COLOR, SHIP_ICON, UPDATE_STATUS } from '@/modules/Ship/vars.ts'\nimport type { ICMapOptions } from '@/types/CMap'\nimport { MapType } from '@/types/CMap'\nimport type { SvgIcon } from '@/types/IconManager'\n\nimport { createStyle } from './vars.ts'\n\n// createStyle 生成的底图内置 source/layer,切换时不需要保留\nconst BASE_SOURCE_IDS = new Set(['base', 'label'])\nconst BASE_LAYER_IDS = new Set(['background', 'base_layer', 'label_layer', 'base-end', 'point-end'])\n\nexport class CMap extends EventEmitter {\n public readonly map: Map\n private readonly options: ICMapOptions\n private cache = new Set<(map: Map) => void>()\n private timer: number | null = null\n private readonly originalRemove: () => void\n\n readonly icon: IconManager\n\n static LAND: MapType = MapType.LAND\n static SATELLITE: MapType = MapType.SATELLITE\n\n constructor(options: ICMapOptions) {\n super()\n\n this.options = options\n\n if (isEmpty(this.options.style)) {\n this.options.style = createStyle(options.type, options.http2, options.TDTToken)\n }\n\n Map.prototype._authenticate = (): void => {\n /* empty */\n }\n\n this.map = new Map(this.options)\n this.icon = new IconManager(this.map)\n\n this.originalRemove = this.map.remove.bind(this.map)\n\n this.map.remove = (): void => {\n let isCancelled = false\n\n this.map.fire('beforeRemove', {\n cancel: () => {\n isCancelled = true\n },\n next: () => {\n isCancelled = false\n },\n })\n\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if (!isCancelled) {\n this.originalRemove()\n }\n }\n\n this.map.once('load', () => {\n SHIP_ICON.forEach((icon: SvgIcon) => {\n this.icon.loadSvg([\n {\n name: icon.name.replace('$color', UPDATE_STATUS.ONLINE),\n svg: icon.svg.replace('$color', SHIP_COLOR.ONLINE),\n },\n {\n name: icon.name.replace('$color', UPDATE_STATUS.DELAY),\n svg: icon.svg.replace('$color', SHIP_COLOR.DELAY),\n },\n {\n name: icon.name.replace('$color', UPDATE_STATUS.OFFLINE),\n svg: icon.svg.replace('$color', SHIP_COLOR.OFFLINE),\n },\n ])\n })\n\n this.emit('loaded', this.map)\n })\n }\n\n change(type: MapType): void {\n const map = this.getMap()\n const currentStyle = map.getStyle()\n\n // 备份自定义 sources(GeoJSON 取运行时 data)\n const customSources: { id: string; spec: SourceSpecification }[] = Object.entries(\n currentStyle.sources,\n )\n .filter(([id]) => !BASE_SOURCE_IDS.has(id))\n .map(([id, source]) => {\n if (source.type === 'geojson') {\n const runtime: GeoJSONSource = map.getSource(id)!\n return { id, spec: { ...source, data: runtime._data } as SourceSpecification }\n }\n return { id, spec: source as SourceSpecification }\n })\n\n // 备份自定义 layers(保持原始顺序)\n const customLayers = currentStyle.layers.filter((l) => !BASE_LAYER_IDS.has(l.id))\n\n const restore = (): void => {\n for (const { id, spec } of customSources) {\n map.addSource(id, spec)\n }\n for (const layer of customLayers) {\n map.addLayer(layer)\n }\n }\n\n const onStyleData = (): void => {\n if (map.isStyleLoaded()) {\n restore()\n } else {\n map.once('styledata', onStyleData)\n }\n }\n\n map.setStyle(createStyle(type, this.options.http2, this.options.TDTToken))\n map.once('styledata', onStyleData)\n }\n\n getMap(): Map {\n return this.map\n }\n\n zoomIn(): void {\n if (!this.getMap().isZooming()) {\n this.getMap().zoomIn()\n }\n }\n\n zoomOut(): void {\n if (!this.getMap().isZooming()) {\n this.getMap().zoomOut()\n }\n }\n\n mapLoaded(): Promise<Map> {\n const load = (resolve: (mao: Map) => void): void => {\n if (!this.getMap()._loaded) {\n if (!this.timer) {\n this.timer = setInterval(() => {\n load(resolve)\n }, 16) as unknown as number\n } else {\n this.cache.add(resolve)\n }\n } else {\n if (this.timer) {\n clearInterval(this.timer)\n this.timer = null\n }\n if (this.cache.size > 0) {\n this.cache.forEach((cb): void => {\n cb(this.getMap())\n })\n this.cache.clear()\n }\n\n resolve(this.getMap())\n }\n }\n\n return new Promise((resolve, reject) => {\n try {\n load(resolve)\n } catch (e) {\n if (this.timer) {\n clearInterval(this.timer)\n this.timer = null\n }\n\n reject(new Error(`mapLoaded错误:${e as string}`))\n }\n })\n }\n}\n","import type { MapMouseEvent } from 'mapbox-gl'\n\nexport enum EventStatus {\n ON = 'On',\n OFF = 'Off',\n}\n\nexport interface EventItem {\n emit: () => void\n on: () => void\n}\n\nexport interface EventMessage<T> {\n originEvent: MapMouseEvent\n instance: T\n}\n","import type { Map, MapMouseEvent } from 'mapbox-gl'\n\nimport { Module } from '@/core/Module'\nimport type { EventMessage } from '@/types/EventState'\nimport { EventStatus } from '@/types/EventState'\n\nexport abstract class EventState extends Module {\n public status: EventStatus = EventStatus.OFF\n static ON: EventStatus = EventStatus.ON\n static OFF: EventStatus = EventStatus.OFF\n\n protected constructor(map: Map) {\n super(map)\n }\n\n public abstract override onAdd(): void\n\n public abstract override onRemove(): void\n\n public switch(): EventStatus {\n if (this.status === EventState.ON) {\n this.status = EventState.OFF\n this.disabled()\n } else if (this.status === EventState.OFF) {\n this.status = EventState.ON\n this.enabled()\n }\n\n return this.status\n }\n\n public changeStatus(): void {\n if (this.status === EventState.ON) {\n this.status = EventStatus.OFF\n } else if (this.status === EventStatus.OFF) {\n this.status = EventStatus.ON\n }\n }\n\n public message<T>(e: MapMouseEvent, instance: T): EventMessage<T> {\n return {\n originEvent: e,\n instance,\n }\n }\n\n public abstract enabled(): void\n\n public abstract disabled(): void\n}\n","import type { GeoJSONSourceSpecification } from 'mapbox-gl'\n\nexport const PLOT_SOURCE_NAME = 'mapbox-gl-plot-source'\n\nexport const EMPTY_SOURCE: GeoJSONSourceSpecification = {\n type: 'geojson',\n // dynamic: true,\n data: {\n type: 'FeatureCollection',\n features: [],\n },\n buffer: 256,\n tolerance: 0.2,\n lineMetrics: true,\n}\n\nexport enum CURSOR {\n CREATE = 'crosshair',\n CLICK = 'pointer',\n MOVE = 'move',\n EMPTY = '',\n}\n\nexport enum Event {\n CREATE = 'create',\n BEFORE_UPDATE = 'update.before',\n UPDATE = 'update.execute',\n DONE_UPDATE = 'update.done',\n MID_BEFORE_UPDATE = 'mid.update.before',\n MID_UPDATE = 'mid.update.execute',\n MID_DONE_UPDATE = 'mid.update.done',\n HOVER = 'hover',\n UN_HOVER = 'unhover',\n CLICK = 'click',\n DBL_CLICK = 'dblclick',\n}\n\nexport enum Meta {\n Line = 'Line',\n LINE_TITLE = 'lineTitle',\n}\n","import type { Map, MapMouseEvent } from 'mapbox-gl'\n\nimport { EventState } from '@/core/EventState'\nimport type { Point } from '@/modules/Plot/plugins/Point'\nimport { Event } from '@/modules/Plot/vars.ts'\n\nexport abstract class PointBaseEvent<T extends Point = Point> extends EventState {\n protected point: T\n\n protected constructor(map: Map, point: T) {\n super(map)\n\n this.point = point\n }\n\n public abstract override onAdd(): void\n\n public abstract override onRemove(): void\n\n public abstract override enabled(): void\n\n public abstract override disabled(): void\n}\n\nexport class PointCreateEvent<T extends Point = Point> extends PointBaseEvent<T> {\n private onClick = (e: MapMouseEvent): void => {\n this.point.update({\n ...this.point.options,\n position: e.lngLat,\n })\n\n this.point.emit(Event.CREATE, this.message<Point>(e, this.point))\n\n this.point.stop()\n this.disabled()\n\n this.point.edit()\n }\n\n private onMousemove = (): void => {\n this.context.map.getCanvasContainer().style.cursor = 'crosshair'\n }\n\n constructor(map: Map, point: T) {\n super(map, point)\n }\n\n public override onAdd(): void {\n /* empty */\n }\n public override onRemove(): void {\n this.disabled()\n }\n\n public override enabled(): void {\n this.context.map.on('click', this.onClick)\n this.context.map.on('mousemove', this.onMousemove)\n this.changeStatus()\n }\n public override disabled(): void {\n this.context.map.getCanvasContainer().style.cursor = ''\n this.context.map.off('click', this.onClick)\n this.context.map.off('mousemove', this.onMousemove)\n this.changeStatus()\n }\n}\n\nexport class PointUpdateEvent<T extends Point = Point> extends PointBaseEvent<T> {\n private onMousedown = (e: MapMouseEvent): void => {\n e.preventDefault()\n this.context.map.getCanvasContainer().style.cursor = 'move'\n\n this.context.map.on('mousemove', this.onMousemove)\n this.context.map.once('mouseup', this.onMouseup)\n\n this.point.emit(Event.BEFORE_UPDATE, this.message<Point>(e, this.point))\n }\n\n private onMousemove = (e: MapMouseEvent): void => {\n this.context.map.getCanvasContainer().style.cursor = 'move'\n this.point.move(e.lngLat)\n\n this.point.emit(Event.UPDATE, this.message<Point>(e, this.point))\n }\n\n private onMouseup = (e: MapMouseEvent): void => {\n this.context.map.getCanvasContainer().style.cursor = ''\n // this.disabled()\n this.context.map.off('mousemove', this.onMousemove)\n\n this.point.render()\n\n this.point.emit(Event.DONE_UPDATE, this.message<Point>(e, this.point))\n }\n\n constructor(map: Map, point: T) {\n super(map, point)\n }\n\n public override onAdd(): void {\n // this.on()\n }\n\n public override onRemove(): void {\n this.disabled()\n }\n\n public override enabled(): void {\n this.context.eventManager.on(this.point.id, this.point.LAYER, 'mousedown', this.onMousedown)\n this.changeStatus()\n }\n\n public override disabled(): void {\n this.context.eventManager.off(this.point.id, 'mousedown', this.onMousedown)\n this.changeStatus()\n }\n}\n\nexport class PointResidentEvent<T extends Point = Point> extends PointBaseEvent<T> {\n private onMouseEnter = (e: MapMouseEvent): void => {\n this.context.map.getCanvasContainer().style.cursor = 'pointer'\n const message = this.message<Point>(e, this.point)\n this.point.setState({ hover: true })\n this.point.emit(Event.HOVER, message)\n }\n\n private onMouseLeave = (e: MapMouseEvent): void => {\n this.context.map.getCanvasContainer().style.cursor = ''\n const message = this.message<Point>(e, this.point)\n this.point.setState({ hover: false })\n this.point.emit(Event.UN_HOVER, message)\n }\n\n private onClick = (e: MapMouseEvent): void => {\n const message = this.message<Point>(e, this.point)\n this.point.emit(Event.CLICK, message)\n }\n\n private onDblclick = (e: MapMouseEvent): void => {\n e.preventDefault()\n const message = this.message<Point>(e, this.point)\n this.point.emit(Event.DBL_CLICK, message)\n }\n\n constructor(map: Map, point: T) {\n super(map, point)\n }\n\n public override onAdd(): void {\n // this.on()\n }\n\n public override onRemove(): void {\n this.disabled()\n }\n\n public override enabled(): void {\n this.context.eventManager.on(this.point.id, this.point.LAYER, 'dblclick', this.onDblclick)\n\n this.context.eventManager.on(this.point.id, this.point.LAYER, 'mouseenter', this.onMouseEnter)\n\n this.context.eventManager.on(this.point.id, this.point.LAYER, 'mouseleave', this.onMouseLeave)\n\n this.context.eventManager.on(this.point.id, this.point.LAYER, 'click', this.onClick)\n this.changeStatus()\n }\n\n public override disabled(): void {\n this.context.eventManager.off(this.point.id, 'dblclick', this.onDblclick)\n\n this.context.eventManager.off(this.point.id, 'mouseenter', this.onMouseEnter)\n\n this.context.eventManager.off(this.point.id, 'mouseleave', this.onMouseLeave)\n\n this.context.eventManager.off(this.point.id, 'click', this.onClick)\n this.changeStatus()\n }\n}\n","import type * as GeoJSON from 'geojson'\nimport type { LngLat, Map } from 'mapbox-gl'\n\nimport { Module } from '@/core/Module'\nimport { PLOT_SOURCE_NAME } from '@/modules/Plot/vars.ts'\nimport type { IPoiOptions } from '@/types/Plot/Poi.ts'\nimport type { PlotVisibility } from '@/types/Plot/Poi.ts'\n\nexport abstract class Poi<\n T extends IPoiOptions = IPoiOptions,\n G extends GeoJSON.Geometry | null = GeoJSON.Geometry,\n> extends Module {\n public options: T\n\n readonly SOURCE: string = PLOT_SOURCE_NAME\n\n readonly LAYER: string = ''\n\n protected constructor(map: Map, options: T) {\n super(map)\n\n this.options = options\n }\n\n public abstract override onAdd(): void\n\n public abstract override onRemove(): void\n\n public abstract get id(): T['id']\n\n public get isEdit(): boolean {\n const state = this.getState()\n return !!state?.edit\n }\n\n get isFocus(): boolean {\n const state = this.getState()\n if (state) {\n return !!state.focus\n } else {\n return false\n }\n }\n\n public get isCreate(): boolean {\n const state = this.getState()\n return !!state?.create\n }\n\n public get visibility(): PlotVisibility {\n return this.options.visibility\n }\n\n public abstract get center(): LngLat | null\n\n public abstract get geometry(): G | null\n\n public abstract getFeature(): GeoJSON.Feature<G>\n\n public abstract start(): void\n\n public abstract stop(): void\n\n public abstract edit(): void\n\n public abstract unedit(): void\n\n public abstract focus(): void\n\n public abstract unfocus(): void\n\n public abstract select(): void\n\n public abstract unselect(): void\n\n public abstract move(position: LngLat): void\n\n public abstract update(options: T): void\n\n public abstract remove(): void\n\n public abstract render(): void\n\n public show(): void {\n this.options.visibility = 'visible'\n this.render()\n }\n\n public hide(): void {\n this.options.visibility = 'none'\n this.render()\n }\n\n public setState(states: Record<string, unknown>): void {\n this.context.map.setFeatureState(\n {\n source: this.SOURCE,\n id: this.id,\n },\n states,\n )\n }\n\n public getState(): Record<string, unknown> | null | undefined {\n return this.context.map.getFeatureState({\n source: this.SOURCE,\n id: this.id,\n })\n }\n}\n","import type { LngLat } from 'mapbox-gl'\n\nexport type PlotPosition = LngLat | LineStringPosition | PolygonPosition\n\nexport type PointPosition = LngLat\n\nexport type LineStringPosition = PointPosition[]\n\nexport type PolygonPosition = PointPosition[]\n\nexport enum PlotType {\n POINT = 'Point',\n INDEX_POINT = 'IndexPoint',\n ICON_POINT = 'IconPoint',\n LINE = 'LineString',\n Fill = 'Polygon',\n CIRCLE = 'Circle',\n}\n\nexport type PlotVisibility = 'visible' | 'none'\n\nexport interface IPoiOptions {\n id: string\n name?: string\n visibility: PlotVisibility\n isName?: boolean\n style?: any\n properties?: Record<string, any>\n}\n","import type { LayerSpecification } from 'mapbox-gl'\n\nimport type { SortLayer } from '@/core/ResourceRegister'\nimport { PLOT_SOURCE_NAME } from '@/modules/Plot/vars.ts'\nimport { PlotType } from '@/types/Plot/Poi.ts'\n\nexport const NAME = PlotType.INDEX_POINT\nexport const POINT_INDEX_LAYER_NAME = 'mapbox-gl-plot-point-index-layer'\nexport const DEFAULT_TEXT_COLOR = '#333'\n\nconst baseTextSize = ['coalesce', ['get', 'text-size'], 12]\n\nexport const POINT_INDEX_LAYER: LayerSpecification = {\n id: POINT_INDEX_LAYER_NAME,\n type: 'symbol',\n filter: [\n 'all',\n ['==', '$type', 'Point'],\n ['==', 'meta', 'circle'],\n ['==', 'subMeta', 'indexPoint'],\n ['==', 'visibility', 'visible'],\n ],\n source: PLOT_SOURCE_NAME,\n paint: {\n 'text-color': ['coalesce', ['get', 'text-color'], DEFAULT_TEXT_COLOR],\n },\n layout: {\n 'text-field': ['get', 'index'],\n 'text-font': ['Open Sans Regular', 'Arial Unicode MS Regular'],\n 'text-anchor': 'center',\n 'text-allow-overlap': true,\n // 最外层使用 interpolate 随层级线性变化\n 'text-size': [\n 'interpolate',\n ['linear'],\n ['zoom'],\n 5,\n ['*', baseTextSize, 0.5],\n 14,\n ['*', baseTextSize, 1],\n 22,\n ['*', baseTextSize, 2.5],\n ],\n },\n}\n\nexport const LAYER_LIST: SortLayer[] = [\n {\n layer: POINT_INDEX_LAYER,\n zIndex: 11,\n },\n]\n","import type { LayerSpecification } from 'mapbox-gl'\n\nimport type { SortLayer } from '@/core/ResourceRegister'\nimport { DEFAULT_TEXT_COLOR } from '@/modules/Plot/plugins/IndexPoint/vars.ts'\nimport { PLOT_SOURCE_NAME } from '@/modules/Plot/vars.ts'\nimport { PlotType } from '@/types/Plot/Poi.ts'\n\nexport const NAME = PlotType.POINT\n\nexport const Z_INDEX = 10\nexport const TEXT_Z_INDEX = Z_INDEX + 1\n\nexport const POINT_CIRCLE_LAYER_NAME = 'mapbox-gl-plot-point-circle-layer'\nexport const POINT_TEXT_LAYER_NAME = 'mapbox-gl-plot-point-text-layer'\n\nexport const DEFAULT_TEXT_SIZE = 12\nexport const GAP_PX = 5\nexport const DEFAULT_CIRCLE_RADIUS = 10\nexport const DEFAULT_CIRCLE_COLOR = '#fff'\nexport const DEFAULT_CIRCLE_STROKE_WIDTH = 2\nexport const DEFAULT_CIRCLE_STROKE_COLOR = '#f00'\n\n// 提取基础数据属性\nconst baseRadius = ['coalesce', ['get', 'circle-radius'], DEFAULT_CIRCLE_RADIUS]\nconst baseStrokeWidth = ['coalesce', ['get', 'circle-stroke-width'], DEFAULT_CIRCLE_STROKE_WIDTH]\nconst baseTextSize = ['coalesce', ['get', 'text-size'], DEFAULT_TEXT_SIZE]\n\n// 提取 Hover 悬停时的放大倍数\nconst hoverScale = ['case', ['boolean', ['feature-state', 'hover'], false], 1.2, 1]\n\nexport const POINT_CIRCLE_LAYER: LayerSpecification = {\n id: POINT_CIRCLE_LAYER_NAME,\n type: 'circle',\n filter: [\n 'all',\n ['==', '$type', 'Point'],\n ['==', 'meta', 'circle'],\n ['==', 'visibility', 'visible'],\n ],\n source: PLOT_SOURCE_NAME,\n paint: {\n // 必须把 interpolate ['zoom'] 放在最外层!\n // 内部公式:基础值 * hover缩放 * 当前层级缩放因子\n 'circle-radius': [\n 'interpolate',\n ['linear'],\n ['zoom'],\n 5,\n ['*', baseRadius, hoverScale, 0.5],\n 14,\n ['*', baseRadius, hoverScale, 1],\n 22,\n ['*', baseRadius, hoverScale, 2.5],\n ],\n 'circle-stroke-width': [\n 'interpolate',\n ['linear'],\n ['zoom'],\n 5,\n ['*', baseStrokeWidth, hoverScale, 0.5],\n 14,\n ['*', baseStrokeWidth, hoverScale, 1],\n 22,\n ['*', baseStrokeWidth, hoverScale, 2.5],\n ],\n 'circle-color': ['coalesce', ['get', 'circle-color'], DEFAULT_CIRCLE_COLOR],\n 'circle-stroke-color': [\n 'coalesce',\n ['get', 'circle-stroke-color'],\n DEFAULT_CIRCLE_STROKE_COLOR,\n ],\n },\n}\n\nexport const POINT_TEXT_LAYER: LayerSpecification = {\n id: POINT_TEXT_LAYER_NAME,\n type: 'symbol',\n filter: [\n 'all',\n ['==', '$type', 'Point'],\n ['==', 'isName', true],\n ['==', 'visibility', 'visible'],\n ],\n source: PLOT_SOURCE_NAME,\n layout: {\n 'text-field': ['get', 'text'],\n 'text-font': ['Open Sans Regular', 'Arial Unicode MS Regular'],\n 'text-offset': ['coalesce', ['get', '_calcTextOffset'], ['get', 'text-offset'], [0, 0]],\n 'text-anchor': 'top',\n 'text-rotate': ['coalesce', ['get', 'icon-rotate'], 0],\n 'text-allow-overlap': true,\n // 文字大小同样遵循外层 interpolate\n 'text-size': [\n 'interpolate',\n ['linear'],\n ['zoom'],\n 5,\n ['*', baseTextSize, 0.5],\n 14,\n ['*', baseTextSize, 1],\n 22,\n ['*', baseTextSize, 2.5],\n ],\n },\n paint: {\n 'text-color': ['coalesce', ['get', 'text-color'], DEFAULT_TEXT_COLOR],\n 'text-halo-color': '#ffffff', // 白色描边,防止线条颜色穿透文字\n 'text-halo-width': 1,\n },\n}\n\nexport const LAYER_LIST: SortLayer[] = [\n {\n layer: POINT_CIRCLE_LAYER,\n zIndex: Z_INDEX,\n },\n {\n layer: POINT_TEXT_LAYER,\n zIndex: TEXT_Z_INDEX,\n },\n]\n","import { point } from '@turf/turf'\nimport type * as GeoJSON from 'geojson'\nimport type { LngLat, Map } from 'mapbox-gl'\n\nimport { Poi } from '@/modules/Plot/plugins/Poi.ts'\nimport {\n DEFAULT_CIRCLE_RADIUS,\n DEFAULT_CIRCLE_STROKE_WIDTH,\n DEFAULT_TEXT_SIZE,\n GAP_PX,\n LAYER_LIST,\n NAME,\n POINT_CIRCLE_LAYER_NAME,\n} from '@/modules/Plot/plugins/Point/vars.ts'\nimport { EMPTY_SOURCE, PLOT_SOURCE_NAME } from '@/modules/Plot/vars.ts'\nimport type { CalcOffsetParams } from '@/types/Plot/IconPoint.ts'\nimport type { PlotType } from '@/types/Plot/Poi.ts'\nimport type { IPointOptions } from '@/types/Plot/Point.ts'\n\nimport { PointCreateEvent, PointResidentEvent, PointUpdateEvent } from '../Events/PointEvents'\n\nexport class Point<T extends IPointOptions = IPointOptions> extends Poi<T, GeoJSON.Point | null> {\n static NAME: PlotType = NAME\n\n override readonly LAYER: string = POINT_CIRCLE_LAYER_NAME\n\n public residentEvent: PointResidentEvent\n\n public updateEvent: PointUpdateEvent\n\n public createEvent: PointCreateEvent\n\n constructor(map: Map, options: T) {\n super(map, options)\n\n this.residentEvent = new PointResidentEvent(map, this)\n this.updateEvent = new PointUpdateEvent(map, this)\n this.createEvent = new PointCreateEvent(map, this)\n this.residentEvent.enabled()\n }\n\n public override onAdd(): void {\n this.context.register.addSource(PLOT_SOURCE_NAME, EMPTY_SOURCE)\n\n LAYER_LIST.forEach((layer) => {\n this.context.register.addLayer(layer)\n })\n }\n public override onRemove(): void {\n this.remove()\n }\n\n public override get id(): string {\n return this.options.id\n }\n public override edit(): void {\n this.setState({ edit: true })\n this.residentEvent.disabled()\n this.updateEvent.enabled()\n }\n public override unedit(): void {\n this.setState({ edit: false })\n this.residentEvent.enabled()\n this.updateEvent.disabled()\n }\n\n public override focus(): void {\n throw new Error('Method not implemented.')\n }\n public override unfocus(): void {\n throw new Error('Method not implemented.')\n }\n public override select(): void {\n throw new Error('Method not implemented.')\n }\n public override unselect(): void {\n throw new Error('Method not implemented.')\n }\n\n public override get center(): LngLat | null {\n if (!this.options.position) return null\n\n return this.options.position\n }\n\n public override get geometry(): GeoJSON.Point | null {\n throw new Error('Method not implemented.')\n }\n\n public override getFeature(): GeoJSON.Feature<GeoJSON.Point | null> {\n if (!this.options.position) {\n // const emptyFeature: GeoJSON.Feature<null, T['style'] & T['properties']> = {\n // type: 'Feature',\n // geometry: null,\n // id: this.id,\n // properties: {},\n // }\n\n return {\n type: 'Feature',\n geometry: null,\n id: this.id,\n properties: {},\n }\n }\n\n const h = (DEFAULT_CIRCLE_RADIUS + DEFAULT_CIRCLE_STROKE_WIDTH) * 2\n const scale = 1\n const anchor = 'center'\n\n const calculatedOffset = this.calculateTextOffset({\n iconHeight: h,\n iconScale: scale,\n iconAnchor: anchor,\n textSize: DEFAULT_TEXT_SIZE,\n gap: GAP_PX,\n })\n\n return point(\n this.options.position.toArray(),\n {\n ...this.options.style,\n ...this.options.properties,\n id: this.options.id,\n visibility: this.options.visibility,\n isName: this.options.isName,\n text: this.options.name,\n _calcTextOffset: calculatedOffset,\n meta: 'circle',\n },\n {\n id: this.options.id,\n },\n )\n }\n public override start(): void {\n if (this.center === null) {\n this.createEvent.enabled()\n }\n }\n public override stop(): void {\n this.createEvent.disabled()\n }\n\n public override move(position: T['position']): void {\n this.options.position = position\n this.render()\n }\n public override update(options: T): void {\n this.options = options\n this.render()\n }\n public override remove(): void {\n this.residentEvent.disabled()\n this.updateEvent.disabled()\n this.createEvent.disabled()\n\n this.removeAllListeners()\n\n const emptyFeature: GeoJSON.Feature<null> = {\n type: 'Feature',\n geometry: null,\n id: this.id,\n properties: {},\n }\n\n this.context.register.setGeoJSONData(PLOT_SOURCE_NAME, emptyFeature)\n }\n public override render(): void {\n this.context.register.setGeoJSONData(PLOT_SOURCE_NAME, this.getFeature() as GeoJSON.Feature)\n }\n\n /**\n * 计算文字相对于图标的偏移量\n * 返回单位为 em (Mapbox text-offset 标准单位)\n */\n protected calculateTextOffset(params: CalcOffsetParams): [number, number] {\n const { iconHeight, iconScale = 1, iconAnchor = 'bottom', textSize = 12, gap = GAP_PX } = params\n\n // 1. 计算图标在屏幕上的实际像素高度\n const actualHeight = iconHeight * iconScale\n\n // 2. 计算需要的垂直偏移像素 (Pixel)\n let offsetY_px = 0\n\n // 根据锚点判断图标占据了坐标点下方多少空间\n if (iconAnchor.includes('bottom')) {\n // A. 底部对齐 (bottom, bottom-left, bottom-right)\n // 图标在坐标点上方,完全不挡路,只需要加个间距\n offsetY_px = gap\n } else if (iconAnchor.includes('top')) {\n // B. 顶部对齐 (top, top-left, top-right)\n // 图标挂在坐标点下方,文字要躲开整个图标的高度\n offsetY_px = actualHeight + gap\n } else {\n // C. 居中对齐 (center, left, right)\n // 图标跨越坐标点,文字要躲开半个图标的高度\n offsetY_px = actualHeight / 2 + gap\n }\n\n // 3. 转换为 em 单位 (Mapbox 要求)\n // 公式: 像素 / 字体大小\n const offsetY_em = offsetY_px / textSize\n\n // 返回 [x, y],这里我们只处理垂直偏移\n return [0, offsetY_em]\n }\n}\n","import type { DataDrivenPropertyValueSpecification, LayerSpecification } from 'mapbox-gl'\n\nimport type { SortLayer } from '@/core/ResourceRegister'\nimport { Z_INDEX } from '@/modules/Plot/plugins/Point/vars.ts'\nimport { PLOT_SOURCE_NAME } from '@/modules/Plot/vars.ts'\nimport { PlotType } from '@/types/Plot/Poi.ts'\n\nexport const NAME = PlotType.ICON_POINT\nexport const POINT_ICON_LAYER_NAME = 'mapbox-gl-plot-point-icon-layer'\nexport const DEFAULT_TEXT_SIZE = 12\nexport const DEFAULT_ICON_ANCHOR = 'bottom'\nexport const GAP_PX = 5\nexport const DEFAULT_ICON_SIZE = 1\n\nconst baseIconSize = ['coalesce', ['get', 'icon-size'], DEFAULT_ICON_SIZE]\n\nexport const ICON_ROTATE: DataDrivenPropertyValueSpecification<number> = [\n 'coalesce',\n ['get', 'icon-rotate'],\n 0,\n]\n\nexport const POINT_ICON_LAYER: LayerSpecification = {\n id: POINT_ICON_LAYER_NAME,\n type: 'symbol',\n filter: [\n 'all',\n ['==', '$type', 'Point'],\n ['==', 'meta', 'icon'],\n ['==', 'visibility', 'visible'],\n ],\n source: PLOT_SOURCE_NAME,\n layout: {\n 'icon-allow-overlap': true,\n 'icon-anchor': ['coalesce', ['get', 'icon-anchor'], DEFAULT_ICON_ANCHOR],\n 'icon-image': ['get', 'icon'],\n 'icon-rotate': ICON_ROTATE,\n // 依然是把 interpolate 放最外侧\n 'icon-size': [\n 'interpolate',\n ['linear'],\n ['zoom'],\n 5,\n ['*', baseIconSize, 0],\n 14,\n ['*', baseIconSize, 1],\n 22,\n ['*', baseIconSize, 2.5],\n ],\n },\n paint: {},\n}\n\nexport const LAYER_LIST: SortLayer[] = [\n {\n layer: POINT_ICON_LAYER,\n zIndex: Z_INDEX,\n },\n]\n","import { point } from '@turf/turf'\nimport type * as GeoJSON from 'geojson'\nimport type { Map } from 'mapbox-gl'\n\nimport {\n PointCreateEvent,\n PointResidentEvent,\n PointUpdateEvent,\n} from '@/modules/Plot/plugins/Events/PointEvents.ts'\nimport { Point } from '@/modules/Plot/plugins/Point'\nimport type { IIconPointOptions } from '@/types/Plot/IconPoint.ts'\nimport type { PlotType } from '@/types/Plot/Poi.ts'\n\nimport {\n DEFAULT_ICON_ANCHOR,\n DEFAULT_ICON_SIZE,\n DEFAULT_TEXT_SIZE,\n GAP_PX,\n LAYER_LIST,\n NAME,\n POINT_ICON_LAYER_NAME,\n} from './vars.ts'\n\nexport class IconPoint extends Point<IIconPointOptions> {\n static override NAME: PlotType = NAME\n\n override readonly LAYER: string = POINT_ICON_LAYER_NAME\n\n constructor(map: Map, options: IIconPointOptions) {\n super(map, options)\n\n this.residentEvent = new PointResidentEvent<IconPoint>(map, this)\n this.updateEvent = new PointUpdateEvent<IconPoint>(map, this)\n this.createEvent = new PointCreateEvent<IconPoint>(map, this)\n this.residentEvent.enabled()\n }\n\n public override onAdd(): void {\n super.onAdd()\n\n LAYER_LIST.forEach((layer) => {\n this.context.register.addLayer(layer)\n })\n }\n\n public override getFeature(): GeoJSON.Feature<GeoJSON.Point | null> {\n if (!this.options.position) {\n return {\n type: 'Feature',\n geometry: null,\n id: this.id,\n properties: {},\n }\n }\n\n const h = this.context.iconManage.getImage(this.options.icon)?.height ?? 0\n const scale = this.options.style?.['icon-size'] ?? DEFAULT_ICON_SIZE\n const anchor = this.options.style?.['icon-anchor'] ?? DEFAULT_ICON_ANCHOR\n const tSize = this.options.style?.['text-size'] ?? DEFAULT_TEXT_SIZE\n\n const calculatedOffset = this.calculateTextOffset({\n iconHeight: h,\n iconScale: scale,\n iconAnchor: anchor,\n textSize: tSize,\n gap: GAP_PX,\n })\n\n return point(\n this.options.position.toArray(),\n {\n ...this.options.style,\n ...this.options.properties,\n id: this.options.id,\n icon: this.options.icon,\n text: this.options.name,\n visibility: this.options.visibility,\n isName: this.options.isName,\n _calcTextOffset: calculatedOffset,\n meta: 'icon',\n },\n {\n id: this.options.id,\n },\n )\n }\n}\n","import { cloneDeep } from 'lodash-es'\nimport type { Map, MapMouseEvent } from 'mapbox-gl'\nimport { LngLat } from 'mapbox-gl'\n\nimport { EventState } from '@/core/EventState'\nimport type { Line } from '@/modules/Plot/plugins/Line'\nimport type { Point } from '@/modules/Plot/plugins/Point'\nimport { CURSOR, Event } from '@/modules/Plot/vars.ts'\nimport type { EventMessage } from '@/types/EventState'\n\nexport abstract class LineBaseEvent extends EventState {\n protected line: Line\n\n protected constructor(map: Map, line: Line) {\n super(map)\n\n this.line = line\n }\n\n public abstract override onAdd(): void\n\n public abstract override onRemove(): void\n\n public abstract override enabled(): void\n\n public abstract override disabled(): void\n}\n\nexport class LineCreateEvent extends LineBaseEvent {\n private count = 0\n private drawPoint: LngLat | null = null\n\n private onClick = (e: MapMouseEvent): void => {\n // 点击过一次之后 计算结束事件\n if (this.count >= 1) {\n const layers = new Set(\n [...this.line.points, ...this.line.midPoints].map((item) => item.LAYER),\n )\n\n const features = this.context.map.queryRenderedFeatures(e.point, {\n layers: [...layers],\n })\n\n if (features.length > 0) {\n this.stop(e)\n return\n }\n }\n\n this.line.insertPoint(this.count, e.lngLat)\n this.count++\n }\n\n private onMousemove = (e: MapMouseEvent): void => {\n this.context.map.getCanvasContainer().style.cursor = 'crosshair'\n if (!this.line.options.position) return\n\n this.setDrawLngLat(e.lngLat)\n this.line.render()\n }\n\n private stop = (e: MapMouseEvent): void => {\n e.preventDefault()\n this.line.stop()\n\n this.context.map.getCanvasContainer().style.cursor = ''\n this.setDrawLngLat(null)\n this.count = 0\n\n this.disabled()\n\n this.line.createPoint()\n this.line.edit()\n\n this.line.emit(Event.CREATE, this.message<Line>(e, this.line))\n }\n\n constructor(map: Map, line: Line) {\n super(map, line)\n }\n\n public override onAdd(): void {\n /* empty */\n }\n public override onRemove(): void {\n /* empty */\n }\n\n public setDrawLngLat(position: LngLat | null): void {\n this.drawPoint = position\n }\n\n public getDrawLngLat(): LngLat | null {\n return this.drawPoint\n }\n\n public override enabled(): void {\n this.context.map.doubleClickZoom.disable()\n\n this.context.map.on('click', this.onClick)\n this.context.map.on('mousemove', this.onMousemove)\n this.context.map.on('dblclick', this.stop)\n this.changeStatus()\n }\n public override disabled(): void {\n this.context.map.off('click', this.onClick)\n this.context.map.off('mousemove', this.onMousemove)\n this.context.map.off('dblclick', this.stop)\n\n setTimeout(() => {\n this.context.map.doubleClickZoom.enable()\n }, 0)\n this.changeStatus()\n }\n}\n\nexport class LineUpdateEvent extends LineBaseEvent {\n protected dragStartLngLat: LngLat | null = null\n protected modifyMid: Point | null = null\n\n private onVertexUpdate = (e: EventMessage<Point>): void => {\n const current = e.instance\n const { index } = current.options.properties ?? {}\n\n if (typeof index !== 'number' || !current.center) return\n\n this.line.updatePoint(index, current.center)\n\n this.line.emit(Event.UPDATE, this.message<Line>(e.originEvent, this.line), current)\n }\n\n private onMidBeforeUpdate = (e: EventMessage<Point>): void => {\n this.setModifyLngLat(e.instance)\n this.line.emit(\n Event.MID_BEFORE_UPDATE,\n this.message<Line>(e.originEvent, this.line),\n e.instance,\n )\n }\n\n private onMidUpdate = (e: EventMessage<Point>): void => {\n const { index } = e.instance.options.properties ?? {}\n const { position } = cloneDeep(this.line.options)\n if (position && typeof index === 'number' && e.instance.center) {\n this.line.render()\n this.line.emit(Event.MID_UPDATE, this.message<Line>(e.originEvent, this.line), e.instance)\n }\n }\n\n private onMidDone = (e: MapMouseEvent): void => {\n if (this.line.geometry?.coordinates) {\n const lonLat = this.line.geometry.coordinates\n\n this.line.options.position = lonLat.map((item) => new LngLat(item[0], item[1]))\n this.setModifyLngLat(null)\n\n this.line.update({\n ...this.line.options,\n })\n\n this.line.edit()\n\n this.line.emit(Event.MID_DONE_UPDATE, this.message<Line>(e, this.line))\n }\n }\n\n private onLineMousedown = (e: MapMouseEvent): void => {\n const layers = new Set([...this.line.points, ...this.line.midPoints].map((item) => item.LAYER))\n\n const features = this.context.map.queryRenderedFeatures(e.point, {\n layers: [...layers],\n })\n\n if (features.length > 0) {\n return\n }\n\n e.preventDefault()\n this.context.map.getCanvasContainer().style.cursor = CURSOR.MOVE\n this.dragStartLngLat = e.lngLat\n\n this.context.map.on('mousemove', this.onMousemove)\n this.context.map.once('mouseup', this.onMouseup)\n\n this.line.emit(Event.BEFORE_UPDATE, this.message<Line>(e, this.line))\n }\n\n private onLineMouseenter = (): void => {\n this.context.map.getCanvasContainer().style.cursor = CURSOR.CLICK\n this.context.map.on('mousedown', this.line.LAYER, this.onLineMousedown)\n }\n\n private onLineMouseLeave = (): void => {\n this.context.map.getCanvasContainer().style.cursor = CURSOR.EMPTY\n this.context.map.off('mousedown', this.line.LAYER, this.onLineMousedown)\n }\n\n private onMousemove = (e: MapMouseEvent): void => {\n this.context.map.getCanvasContainer().style.cursor = CURSOR.MOVE\n const current = e.lngLat\n this.line.move(current)\n this.dragStartLngLat = current\n this.line.emit(Event.UPDATE, this.message<Line>(e, this.line))\n }\n\n private onMouseup = (e: MapMouseEvent): void => {\n this.context.map.getCanvasContainer().style.cursor = ''\n this.context.map.off('mousemove', this.onMousemove)\n this.context.map.off('mousedown', this.line.LAYER, this.onLineMousedown)\n this.dragStartLngLat = null\n this.line.render()\n\n this.line.emit(Event.DONE_UPDATE, this.message<Line>(e, this.line))\n }\n\n constructor(map: Map, line: Line) {\n super(map, line)\n }\n\n public override onAdd(): void {\n /* empty */\n }\n\n public override onRemove(): void {\n this.disabled()\n }\n\n public setModifyLngLat(point: Point | null): void {\n this.modifyMid = point\n }\n\n public getModifyLngLat(): Point | null {\n return this.modifyMid\n }\n\n public setDragLngLat(position: LngLat | null): void {\n this.dragStartLngLat ??= position\n }\n\n public getDragLngLat(): LngLat | null {\n return this.dragStartLngLat\n }\n\n public override enabled(): void {\n this.line.points.forEach((point) => {\n point.on(Event.UPDATE, this.onVertexUpdate)\n })\n this.line.midPoints.forEach((mid) => {\n mid.on(Event.BEFORE_UPDATE, this.onMidBeforeUpdate)\n mid.on(Event.UPDATE, this.onMidUpdate)\n mid.on(Event.DONE_UPDATE, this.onMidDone)\n })\n\n this.context.eventManager.on(this.line.id, this.line.LAYER, 'mouseenter', this.onLineMouseenter)\n this.context.eventManager.on(this.line.id, this.line.LAYER, 'mouseleave', this.onLineMouseLeave)\n\n this.changeStatus()\n }\n\n public override disabled(): void {\n this.line.points.forEach((point) => {\n point.off(Event.UPDATE, this.onVertexUpdate)\n })\n this.line.midPoints.forEach((mid) => {\n mid.off(Event.BEFORE_UPDATE, this.onMidBeforeUpdate)\n mid.off(Event.UPDATE, this.onMidUpdate)\n mid.off(Event.DONE_UPDATE, this.onMidDone)\n })\n\n this.context.eventManager.off(this.line.id, 'mouseenter', this.onLineMouseenter)\n this.context.eventManager.off(this.line.id, 'mouseleave', this.onLineMouseLeave)\n this.changeStatus()\n }\n}\n\nexport class LineResidentEvent extends LineBaseEvent {\n private onLineMouseenter = (e: MapMouseEvent): void => {\n this.context.map.getCanvasContainer().style.cursor = 'pointer'\n this.line.setState({ hover: true })\n this.line.points.forEach((point) => {\n point.setState({ hover: true })\n })\n this.line.emit(Event.HOVER, this.message<Line>(e, this.line))\n }\n\n private onLineMouseLeave = (e: MapMouseEvent): void => {\n this.context.map.getCanvasContainer().style.cursor = ''\n this.line.setState({ hover: false })\n this.line.points.forEach((point) => {\n point.setState({ hover: false })\n })\n this.line.emit(Event.UN_HOVER, this.message<Line>(e, this.line))\n }\n\n private onClick = (e: EventMessage<Point>): void => {\n this.line.emit(Event.CLICK, this.message<Line>(e.originEvent, this.line))\n }\n\n private onLineClick = (e: MapMouseEvent): void => {\n const layers = new Set([...this.line.points, ...this.line.midPoints].map((item) => item.LAYER))\n\n const features = this.context.map.queryRenderedFeatures(e.point, {\n layers: [...layers],\n })\n\n if (features.length > 0) {\n return\n }\n\n this.line.emit(Event.CLICK, this.message<Line>(e, this.line))\n }\n\n constructor(map: Map, line: Line) {\n super(map, line)\n }\n\n public override onAdd(): void {\n // this.on()\n }\n\n public override onRemove(): void {\n this.disabled()\n }\n\n public override enabled(): void {\n this.line.points.forEach((point) => {\n point.on(Event.CLICK, this.onClick)\n })\n this.context.eventManager.on(this.line.id, this.line.LAYER, 'mouseenter', this.onLineMouseenter)\n this.context.eventManager.on(this.line.id, this.line.LAYER, 'mouseleave', this.onLineMouseLeave)\n this.context.eventManager.on(this.line.id, this.line.LAYER, 'click', this.onLineClick)\n this.changeStatus()\n }\n\n public override disabled(): void {\n this.line.points.forEach((point) => {\n point.off(Event.CLICK, this.onClick)\n })\n\n this.context.eventManager.off(this.line.id, 'mouseenter', this.onLineMouseenter)\n this.context.eventManager.off(this.line.id, 'mouseleave', this.onLineMouseLeave)\n this.context.eventManager.off(this.line.id, 'click', this.onLineClick)\n this.changeStatus()\n }\n}\n","import type { ColorSpecification, DataDrivenPropertyValueSpecification } from 'mapbox-gl'\n\nimport type { IPoiOptions, LineStringPosition } from '@/types/Plot/Poi.ts'\nimport type { PointStyle } from '@/types/Plot/Point.ts'\n\nexport enum PointType {\n VERTEX = 'Vertex',\n MIDPOINT = 'MidPoint',\n}\n\nexport interface LineStyle {\n 'line-color'?: DataDrivenPropertyValueSpecification<ColorSpecification>\n 'line-width'?: DataDrivenPropertyValueSpecification<number>\n 'text-size'?: DataDrivenPropertyValueSpecification<number>\n}\n\nexport interface ILineOptions extends IPoiOptions {\n position?: LineStringPosition\n style?: LineStyle\n vertexStyle?: PointStyle\n midStyle?: PointStyle\n properties?: Record<string, any>\n}\n","import type {\n ColorSpecification,\n DataDrivenPropertyValueSpecification,\n LayerSpecification,\n} from 'mapbox-gl'\n\nimport type { SortLayer } from '@/core/ResourceRegister'\nimport { Meta, PLOT_SOURCE_NAME } from '@/modules/Plot/vars.ts'\nimport { PlotType } from '@/types/Plot/Poi.ts'\n\nexport const NAME = PlotType.LINE\n\nexport const Z_INDEX = 5\nexport const TEXT_Z_INDEX = Z_INDEX + 1 // 文字层级要比线高一点\n\nexport const LINE_LAYER_NAME = 'mapbox-gl-plot-line-layer'\nexport const DOTTED_LINE_LAYER_NAME = 'mapbox-gl-plot-dotted-line-layer'\nexport const LINE_TEXT_LAYER_NAME = 'mapbox-gl-plot-line-text-layer'\n\nexport const DEFAULT_LINE_COLOR = '#f00'\nexport const DEFAULT_LINE_WIDTH = 3\nexport const DEFAULT_TEXT_COLOR = '#333'\nexport const DEFAULT_TEXT_SIZE = 16\n\nconst lineColor: DataDrivenPropertyValueSpecification<ColorSpecification> = [\n 'coalesce',\n ['get', 'line-color'],\n DEFAULT_LINE_COLOR,\n]\n\nconst lineWidth: DataDrivenPropertyValueSpecification<number> = [\n 'coalesce',\n ['get', 'line-width'],\n DEFAULT_LINE_WIDTH,\n]\n\nconst lineDasharray: DataDrivenPropertyValueSpecification<number[]> = [\n 'coalesce',\n ['get', 'line-dasharray'],\n [99999, 99999],\n]\n\n// 文字大小缩放因子 (随缩放层级线性变化)\nconst baseTextSize = ['coalesce', ['get', 'text-size'], DEFAULT_TEXT_SIZE]\n\nexport const DOTTED_LINE_LAYER: LayerSpecification = {\n id: DOTTED_LINE_LAYER_NAME,\n type: 'line',\n filter: ['all', ['==', '$type', 'LineString'], ['==', 'visibility', 'visible']],\n source: PLOT_SOURCE_NAME,\n paint: {\n 'line-dasharray': lineDasharray,\n 'line-color': lineColor,\n 'line-width': [\n 'case',\n ['boolean', ['feature-state', 'hover'], false],\n ['+', lineWidth, ['%', lineWidth, 1.2]],\n lineWidth,\n ],\n },\n layout: {\n 'line-join': 'round',\n 'line-cap': 'round',\n },\n}\n\nexport const LINE_LAYER: LayerSpecification = {\n id: LINE_LAYER_NAME,\n type: 'line',\n filter: [\n 'all',\n ['==', '$type', 'LineString'],\n ['==', 'visibility', 'visible'],\n ['!=', 'meta', Meta.LINE_TITLE],\n ],\n source: PLOT_SOURCE_NAME,\n paint: {\n // 'line-dasharray': lineDasharray,\n 'line-color': lineColor,\n 'line-width': [\n 'case',\n ['boolean', ['feature-state', 'hover'], false],\n ['+', lineWidth, ['%', lineWidth, 1.2]],\n lineWidth,\n ],\n },\n layout: {\n 'line-join': 'round',\n 'line-cap': 'round',\n },\n}\n\n// 🌟 新增:线段标题文本图层\nexport const LINE_TEXT_LAYER: LayerSpecification = {\n id: LINE_TEXT_LAYER_NAME,\n type: 'symbol',\n filter: [\n 'all',\n ['==', '$type', 'LineString'],\n ['==', 'isName', true],\n // ['==', 'meta', Meta.LINE_TITLE],\n ['==', 'visibility', 'visible'],\n ],\n source: PLOT_SOURCE_NAME,\n layout: {\n 'icon-ignore-placement': true,\n 'text-ignore-placement': false,\n 'text-letter-spacing': 0.01,\n 'symbol-placement': 'line-center', // 让文字居中附着在线上\n 'text-field': ['get', 'text'],\n 'text-font': ['Open Sans Regular', 'Arial Unicode MS Regular'],\n 'text-allow-overlap': true,\n 'text-size': [\n 'interpolate',\n ['linear'],\n ['zoom'],\n 5,\n ['*', baseTextSize, 0.5],\n 14,\n ['*', baseTextSize, 1],\n 22,\n ['*', baseTextSize, 2.5],\n ],\n },\n paint: {\n 'text-color': ['coalesce', ['get', 'text-color'], DEFAULT_TEXT_COLOR],\n 'text-halo-color': '#ffffff', // 白色描边,防止线条颜色穿透文字\n 'text-halo-width': 1,\n },\n}\n\nexport const LAYER_LIST: SortLayer[] = [\n // {\n // layer: DOTTED_LINE_LAYER,\n // zIndex: Z_INDEX,\n // },\n {\n layer: LINE_LAYER,\n zIndex: Z_INDEX,\n },\n {\n layer: LINE_TEXT_LAYER,\n zIndex: TEXT_Z_INDEX, // 注册文字图层\n },\n]\n","import { along, bbox, length, lineString } from '@turf/turf'\nimport type * as GeoJSON from 'geojson'\nimport type { Feature, LineString } from 'geojson'\nimport type { Map } from 'mapbox-gl'\nimport { LngLat } from 'mapbox-gl'\n\nimport {\n LineCreateEvent,\n LineResidentEvent,\n LineUpdateEvent,\n} from '@/modules/Plot/plugins/Events/LineEvents.ts'\nimport { Poi } from '@/modules/Plot/plugins/Poi.ts'\nimport { Point } from '@/modules/Plot/plugins/Point'\nimport { EMPTY_SOURCE, Meta, PLOT_SOURCE_NAME } from '@/modules/Plot/vars.ts'\nimport type { ILineOptions } from '@/types/Plot/Line.ts'\nimport { PointType } from '@/types/Plot/Line.ts'\nimport type { PlotType } from '@/types/Plot/Poi.ts'\nimport type { PointInstance, PointStyle } from '@/types/Plot/Point.ts'\n\nimport { DEFAULT_LINE_COLOR, LAYER_LIST, LINE_LAYER_NAME, NAME } from './vars.ts'\n\nexport class Line<T extends ILineOptions = ILineOptions> extends Poi<T, GeoJSON.LineString | null> {\n static NAME: PlotType = NAME\n override readonly LAYER: string = LINE_LAYER_NAME\n\n public points: PointInstance[] = []\n public midPoints: Point[] = []\n public titles: GeoJSON.Feature<GeoJSON.LineString | null>[] = []\n\n public residentEvent: LineResidentEvent\n public updateEvent: LineUpdateEvent\n public createEvent: LineCreateEvent\n\n constructor(map: Map, options: T) {\n super(map, options)\n\n this.residentEvent = new LineResidentEvent(map, this)\n this.updateEvent = new LineUpdateEvent(map, this)\n this.createEvent = new LineCreateEvent(map, this)\n this.createPoint()\n\n this.residentEvent.enabled()\n }\n\n public override get id(): string {\n return this.options.id\n }\n\n public override get center(): LngLat | null {\n if (!Array.isArray(this.options.position) || this.options.position.length === 0) {\n return null\n }\n\n const feature = this.getFeature() as GeoJSON.Feature<GeoJSON.LineString>\n const distance = length(feature)\n const coordinates = along(feature, distance / 2).geometry.coordinates\n\n return new LngLat(coordinates[0], coordinates[1])\n }\n\n public override get geometry(): GeoJSON.LineString | null {\n return this.getFeature().geometry\n }\n\n public override onAdd(): void {\n this.context.register.addSource(PLOT_SOURCE_NAME, EMPTY_SOURCE)\n\n LAYER_LIST.forEach((layer) => {\n this.context.register.addLayer(layer)\n })\n }\n public override onRemove(): void {\n this.remove()\n }\n\n public override getFeature(): GeoJSON.Feature<GeoJSON.LineString | null> {\n if (\n (!this.options.position || this.options.position.length < 2) &&\n !this.createEvent.getDrawLngLat()\n ) {\n return {\n type: 'Feature',\n geometry: null,\n id: this.id,\n properties: {},\n }\n }\n\n const coordinates = this.points.map((point) => {\n if (point.center) {\n return point.center.toArray()\n } else {\n return []\n }\n })\n\n const modify = this.updateEvent.getModifyLngLat()\n\n if (modify) {\n const { index } = modify.options.properties ?? {}\n if (typeof index === 'number' && modify.center) {\n coordinates.splice(index + 1, 0, modify.center.toArray())\n }\n }\n\n if (this.createEvent.getDrawLngLat()) {\n coordinates.push(this.createEvent.getDrawLngLat()!.toArray())\n }\n\n return lineString(\n coordinates,\n {\n ...this.options.properties,\n ...this.options.style,\n visibility: this.options.visibility,\n isName: this.options.isName,\n text: this.options.name,\n id: this.options.id,\n },\n {\n id: this.id,\n },\n )\n }\n public override start(): void {\n if (this.center === null) {\n this.createEvent.enabled()\n this.updateEvent.disabled()\n this.residentEvent.disabled()\n this.setState({ create: true })\n }\n }\n public override stop(): void {\n this.createEvent.disabled()\n this.residentEvent.enabled()\n this.setState({ create: false })\n }\n\n public override show(): void {\n this.points.forEach((point) => {\n point.show()\n })\n this.midPoints.forEach((mid) => {\n mid.show()\n })\n\n super.show()\n }\n\n public override hide(): void {\n this.points.forEach((point) => {\n point.hide()\n })\n this.midPoints.forEach((mid) => {\n mid.hide()\n })\n\n super.hide()\n }\n\n public override edit(): void {\n this.setState({ edit: true })\n\n this.points.forEach((point) => {\n point.edit()\n })\n\n this.midPoints.forEach((midPoint) => {\n midPoint.edit()\n midPoint.show()\n })\n\n this.residentEvent.disabled()\n this.updateEvent.enabled()\n\n this.render()\n }\n\n public override unedit(): void {\n this.setState({ edit: false })\n this.points.forEach((point) => {\n point.unedit()\n })\n this.midPoints.forEach((midPoint) => {\n midPoint.unedit()\n midPoint.hide()\n })\n\n this.residentEvent.enabled()\n this.updateEvent.disabled()\n\n this.render()\n }\n\n public override focus(): void {\n this.setState({ focus: true })\n this.render()\n }\n public override unfocus(): void {\n this.setState({ focus: false })\n this.render()\n }\n public override select(): void {\n const bounds = bbox(this.getFeature() as GeoJSON.Feature) as [number, number, number, number]\n this.context.map.fitBounds(bounds, {\n padding: {\n left: 60,\n right: 60,\n top: 60,\n bottom: 60,\n },\n })\n\n this.context.map.once('moveend', () => {\n this.focus()\n })\n }\n public override unselect(): void {\n this.unfocus()\n }\n public override move(position: LngLat): void {\n // 如果不借助鼠标拖拽 直接移动以中心为基准点\n const drag: LngLat | null = this.center ?? this.updateEvent.getDragLngLat()\n\n if (!drag) return\n\n const lngDiff = position.lng - drag.lng\n const latDiff = position.lat - drag.lat\n this.points.forEach((point, index) => {\n if (point.center) {\n const newPos = new LngLat(point.center.lng + lngDiff, point.center.lat + latDiff)\n\n this.updatePoint(index, newPos, false)\n }\n })\n\n this.render()\n }\n public override update(options: T): void {\n this.options = options\n this.removePoint()\n this.createPoint()\n\n this.render()\n }\n public override remove(): void {\n this.removePoint()\n // this.removeTitles()\n this.residentEvent.disabled()\n this.createEvent.disabled()\n this.updateEvent.disabled()\n this.removeAllListeners()\n\n this.options.position = []\n this.render()\n }\n public override render(): void {\n this.points.map((point) => {\n point.render()\n })\n\n if (this.isEdit) {\n this.midPoints.map((minPoint) => {\n minPoint.render()\n })\n }\n\n if (this.isFocus) {\n this.context.focus.set(this.getFeature() as GeoJSON.Feature, {\n armLength: 40,\n padding: 30,\n })\n } else {\n this.context.focus.remove(this.id)\n }\n\n // if (Array.isArray(this.options.position) && this.options.position.length > 1) {\n // this.createTitles()\n // } else {\n // this.removeTitles()\n // }\n\n this.context.register.setGeoJSONData(PLOT_SOURCE_NAME, [\n this.getFeature(),\n // ...this.titles,\n ] as GeoJSON.Feature[])\n }\n\n public getMidPoint(index: number): Point | null {\n const data = this.midPoints.at(index)\n if (!data) return null\n\n return Number(data.options.properties?.index) === index ? data : null\n }\n\n public getPoint(index: number): PointInstance | null {\n const point = this.points.at(index)\n if (!point) return null\n\n return Number(point.options.properties?.index) === index ? point : null\n }\n\n public createVertex(id: string, index: number, position: LngLat): PointInstance {\n const style: PointStyle = {\n 'circle-radius': 5,\n 'circle-stroke-color': this.options.style?.['line-color'] ?? DEFAULT_LINE_COLOR,\n ...this.options.vertexStyle,\n }\n\n return new Point(this.context.map, {\n // id: `${this.id}-node-${String(index)}`, // 建议 ID 加上 node 标识\n id, // 建议 ID 加上 node 标识\n isName: false,\n visibility: 'visible',\n position,\n style,\n properties: {\n id: `${this.id}-node-${String(index)}`,\n index,\n type: PointType.VERTEX, // 标记类型,方便点击事件区分\n },\n })\n }\n\n public createMid(id: string, index: number, position: LngLat): Point {\n const style = {\n 'circle-radius': 2,\n 'circle-color': this.options.style?.['line-color'] ?? DEFAULT_LINE_COLOR,\n 'circle-stroke-color': this.options.style?.['line-color'] ?? DEFAULT_LINE_COLOR,\n ...this.options.midStyle,\n }\n\n return new Point(this.context.map, {\n id, // 建议 ID 加上 mid 标识\n isName: false,\n visibility: 'visible',\n position,\n style,\n properties: {\n id: `${this.id}-mid-${String(index)}`, // 建议 ID 加上 mid 标识\n index, // 这里的 index 代表它是第几段线上的中点\n type: PointType.MIDPOINT,\n },\n })\n }\n\n public createTitles(): Feature<LineString>[] {\n if (!Array.isArray(this.points) || this.points.length === 0) return []\n\n const length = this.points.length\n this.titles = this.points.flatMap((current, index) => {\n if (index === length - 1) return []\n if (!current.center) return []\n\n const next = this.points[index + 1]\n if (!next.center) return []\n\n const id = `line-title-${this.id}-${String(index)}`\n return lineString(\n [current.center.toArray(), next.center.toArray()],\n {\n meta: Meta.LINE_TITLE,\n visibility: this.options.visibility,\n isName: true,\n text: this.options.name,\n 'text-size': this.options.style?.['text-size'],\n originId: this.id,\n id,\n },\n {\n id,\n },\n )\n })\n\n return this.titles as GeoJSON.Feature<GeoJSON.LineString>[]\n }\n\n public removeTitles(): GeoJSON.Feature<null>[] {\n this.titles = this.titles.map((item) => {\n return {\n ...item,\n geometry: null,\n }\n })\n\n return this.titles as GeoJSON.Feature<null>[]\n }\n\n public createPoint(): void {\n this.removePoint()\n\n const positions = this.options.position ?? []\n\n positions.forEach((current, i) => {\n this.points.push(this.createVertex(`${this.id}-node-${String(i)}`, i, current))\n })\n\n this.syncMidPoints()\n }\n\n /**\n * 插入一个新节点 (例如: 将中点转为实点时调用)\n * @param index 要插入的位置索引\n * @param position 新节点的坐标\n */\n public insertPoint(index: number, position: LngLat): PointInstance {\n // 1. 同步原始数据\n this.options.position ??= []\n this.options.position.splice(index, 0, position)\n\n // 2. 创建新点实例并插入数组\n const newPoint = this.createVertex(`${this.id}-node-${String(index)}`, index, position)\n this.points.splice(index, 0, newPoint)\n\n // 如果处于编辑状态,让新点立刻表现为编辑态\n if (this.isEdit) {\n newPoint.edit()\n }\n\n // 3. 重新修正索引并全量同步中点\n this.reindexPoints()\n this.syncMidPoints()\n this.render()\n\n return newPoint\n }\n\n /**\n * 更新某个实点的位置 (例如: 拖拽某个节点)\n * @param index 节点索引\n * @param position 拖拽后的新坐标\n * @param isRender 是否立即渲染\n */\n public updatePoint(index: number, position: LngLat, isRender = true): void {\n const point = this.getPoint(index)\n if (!point) return\n\n // 1. 同步原始数据\n if (this.options.position?.[index]) {\n this.options.position[index] = position\n }\n\n // 2. 移动实体点\n point.move(position)\n\n // 3. 局部更新左右两个相邻的中点(提升性能,不用全量重绘)\n this.updateAdjacentMidPoints(index)\n\n // 4. 重绘线段 (触发 getFeature 变更)\n if (isRender) {\n this.render()\n }\n }\n\n /** 更新指定中点的坐标 (例如:拖拽中点时触发,但在松手前它还是个中点) */\n public updateMidPoint(index: number, position: LngLat): void {\n const midPoint = this.getMidPoint(index)\n if (!midPoint) return\n\n midPoint.move(position)\n }\n\n public removePointAt(index: number): void {\n const point = this.points.at(index)\n if (!point) return\n\n // 1. 从地图上移除\n point.remove()\n\n // 2. 从数组中移除\n this.points.splice(index, 1)\n\n // 3. 更新索引并重绘中点\n this._reindexPoints()\n this._syncMidPoints()\n }\n\n /** 清空所有点 (替代原有的 removePoint) */\n public clearAll(): void {\n this.points.forEach((point) => {\n point.remove()\n })\n this.midPoints.forEach((mid) => {\n mid.remove()\n })\n this.points = []\n this.midPoints = []\n }\n\n public removePoint(): void {\n this.points.forEach((point) => {\n point.remove()\n })\n this.points = []\n this.midPoints.forEach((mid) => {\n mid.remove()\n })\n this.midPoints = []\n }\n\n /**\n * 内部机制:全量重新生成所有的中点\n */\n protected syncMidPoints(): void {\n // 1. 清空旧的中点\n this.midPoints.forEach((mid) => {\n mid.remove()\n })\n this.midPoints = []\n\n // 2. 根据现有的实点重新构建\n for (let i = 0; i < this.points.length - 1; i++) {\n const current = this.points[i].center\n const next = this.points[i + 1].center\n\n if (current && next) {\n const midPos = this.calcMidPosition(current, next)\n const midPoint = this.createMid(`${this.id}-mid-${String(i)}`, i, midPos)\n\n // 如果线段正在编辑态,新生成的中点也应表现为编辑态\n if (this.isEdit) midPoint.edit()\n\n this.midPoints.push(midPoint)\n }\n }\n }\n\n /**\n * 内部机制:修补数组增减后的索引及属性ID\n */\n protected reindexPoints(): void {\n this.points.forEach((point, i) => {\n const newId = `${this.id}-node-${String(i)}`\n\n if (point.options.properties) {\n point.options.properties.index = i\n\n point.options.properties.id = newId\n }\n\n // 注意:根据你的底层实现,可能也需要强行覆盖外部的 id\n point.options.id = newId\n })\n }\n\n /**\n * 内部机制:只更新指定节点相邻的两个中点 (用于优化拖拽时的渲染性能)\n */\n protected updateAdjacentMidPoints(index: number): void {\n // 更新左侧中点 (index - 1)\n if (index > 0 && this.points[index - 1]) {\n const p1 = this.points[index - 1].center\n const p2 = this.points[index].center\n if (p1 && p2) {\n this.updateMidPoint(index - 1, this.calcMidPosition(p1, p2))\n }\n }\n // 更新右侧中点 (index)\n if (index < this.points.length - 1 && this.points[index + 1]) {\n const p1 = this.points[index].center\n const p2 = this.points[index + 1].center\n if (p1 && p2) {\n this.updateMidPoint(index, this.calcMidPosition(p1, p2))\n }\n }\n }\n\n /**\n * 内部计算:获取两点之间的中点坐标\n */\n protected calcMidPosition(p1: LngLat, p2: LngLat): LngLat {\n const midLng = (p1.lng + p2.lng) / 2\n const midLat = (p1.lat + p2.lat) / 2\n return new LngLat(midLng, midLat)\n }\n\n /** 内部:当数组发生增删时,修复 properties 中的 index 和 id */\n private _reindexPoints(): void {\n this.points.forEach((point, i) => {\n const newId = `${this.id}-node-${String(i)}`\n // 这里根据你的底层 Point 类 API 进行调整,通常需要更新配置\n if (point.options.properties) {\n point.options.properties.index = i\n point.options.properties.id = newId\n }\n point.options.id = newId\n })\n }\n\n /** 内部:重新计算并全量同步所有中点 */\n private _syncMidPoints(): void {\n // 1. 先清除旧的中点\n this.midPoints.forEach((mid) => {\n mid.remove()\n })\n this.midPoints = []\n\n // 2. 根据当前的顶点重新生成\n for (let i = 0; i < this.points.length - 1; i++) {\n const currentPos = this.points[i].options.position!\n const nextPos = this.points[i + 1].options.position!\n\n const midPos = this.calcMidPosition(currentPos, nextPos)\n this.midPoints.push(this.createMid(`${this.id}-mid-${String(i)}`, i, midPos))\n }\n }\n}\n","import { bearing } from '@turf/turf'\nimport type { LngLat, Map } from 'mapbox-gl'\n\nimport { IconPoint } from '@/modules/Plot/plugins/IconPoint'\nimport { Line } from '@/modules/Plot/plugins/Line'\nimport { EventStatus } from '@/types/EventState'\nimport type { IArrowLineOptions } from '@/types/Plot/ArrowLine.ts'\nimport { PointType } from '@/types/Plot/Line.ts'\nimport type { PointInstance } from '@/types/Plot/Point.ts'\n\nexport class ArrowLine extends Line<IArrowLineOptions> {\n constructor(map: Map, options: IArrowLineOptions) {\n super(map, options)\n }\n\n public override onAdd(): void {\n super.onAdd()\n\n this.context.iconManage.loadSvg([\n {\n name: 'plot-arrow-start',\n svg: '<svg t=\"1772517328676\" class=\"icon\" viewBox=\"0 0 1024 1024\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" p-id=\"41296\" width=\"32\" height=\"32\"><path d=\"M512 512m-512 0a512 512 0 1 0 1024 0 512 512 0 1 0-1024 0Z\" fill=\"#39BF8F\" p-id=\"41297\"></path><path d=\"M803.84 558.08c-5.12 53.76-12.8 89.6-23.04 104.96-10.24 15.36-30.72 25.6-61.44 25.6h-117.76c-38.4 0-56.32-20.48-56.32-56.32v-217.6h181.76v-128h-192V240.64h238.08V460.8h-179.2v153.6c0 17.92 10.24 28.16 28.16 28.16h89.6c17.92 0 30.72-7.68 38.4-20.48 5.12-12.8 7.68-38.4 10.24-76.8l43.52 12.8z m-545.28-43.52l43.52 5.12c-2.56 38.4-5.12 74.24-10.24 107.52 20.48 38.4 43.52 64 69.12 84.48v-240.64H225.28v-43.52h122.88v-97.28H238.08v-43.52h110.08V197.12h48.64v89.6h107.52v43.52h-107.52v97.28H512v43.52h-102.4v94.72h94.72v43.52H409.6v125.44c40.96 10.24 122.88 17.92 245.76 17.92 74.24 0 128-2.56 163.84-2.56l-7.68 46.08H665.6c-156.16 0-253.44-10.24-291.84-28.16-33.28-15.36-64-43.52-89.6-84.48-10.24 43.52-23.04 87.04-40.96 125.44L204.8 775.68c33.28-76.8 51.2-163.84 53.76-261.12z\" fill=\"#FFFFFF\" p-id=\"41298\"></path></svg>',\n },\n {\n name: 'plot-arrow',\n svg: '<svg t=\"1772517045368\" class=\"icon\" viewBox=\"0 0 1024 1024\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" p-id=\"35873\" width=\"32\" height=\"32\"><path d=\"M859.615 662.634c0 15.79300001-6.25500001 30.502-17.606 41.418-22.813 21.967-59.274 21.291-81.271-1.512l-250.406-259.796L263.652 703.5c-21.796 23.016-58.255 24.034-81.29 2.268-11.425-10.837-17.975-26.076-17.975-41.799 0-14.747 5.576-28.771 15.709-39.492L467.923 320.166c16.939-17.94 43.603-22.701 66.333-11.842 1.705 0.781 3.015 1.69300001 3.761 2.231a65.89 65.89 0 0 0 1.399 0.748c2.742 1.45 6.385 3.373 9.855 6.687l0.225 0.218c0.209 0.203 0.397 0.404 0.573 0.59a19.821 19.821 0 0 1 2.609 2.17500001L843.521 622.732c10.382 10.795 16.096 24.962 16.09600001 39.901z\" p-id=\"35874\" fill=\"#ff0000\"></path></svg>',\n },\n {\n name: 'plot-arrow-end',\n svg: '<svg t=\"1772517393676\" class=\"icon\" viewBox=\"0 0 1024 1024\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" p-id=\"42489\" width=\"32\" height=\"32\"><path d=\"M512 512m-512 0a512 512 0 1 0 1024 0 512 512 0 1 0-1024 0Z\" fill=\"#FF343E\" p-id=\"42490\"></path><path d=\"M393.216 277.9136a901.12 901.12 0 0 1-75.9808 155.8528c18.0224-2.2528 36.2496-4.9152 54.272-8.192l31.5392-67.7888 45.056 16.7936a1425.8176 1425.8176 0 0 1-108.544 196.608 634.88 634.88 0 0 0 80.2816-26.624v46.2848a689.3568 689.3568 0 0 1-139.4688 37.888L266.24 582.0416a89.4976 89.4976 0 0 0 22.9376-14.5408A568.7296 568.7296 0 0 0 348.16 472.2688l-78.848 12.0832-12.4928-46.6944a44.8512 44.8512 0 0 0 20.48-19.0464 1016.832 1016.832 0 0 0 66.7648-159.3344z m49.5616 421.0688a1099.776 1099.776 0 0 1-171.8272 46.08l-7.5776-54.272a956.8256 956.8256 0 0 0 179.4048-44.6464z m143.36-432.5376a437.4528 437.4528 0 0 1-14.1312 43.4176h149.504v40.96a466.1248 466.1248 0 0 1-78.2336 111.4112 681.5744 681.5744 0 0 0 122.88 64.1024L739.328 573.44a680.5504 680.5504 0 0 1-132.5056-77.0048 490.2912 490.2912 0 0 1-153.1904 84.1728l-25.6-45.2608a426.5984 426.5984 0 0 0 139.0592-71.0656 696.32 696.32 0 0 1-53.6576-53.248 518.7584 518.7584 0 0 1-40.96 40.96L440.5248 409.6a305.3568 305.3568 0 0 0 93.3888-150.528z m-97.6896 372.736a1465.7536 1465.7536 0 0 1 237.9776 81.92l-27.2384 43.008a1431.3472 1431.3472 0 0 0-240.2304-81.92zM554.1888 552.96a921.6 921.6 0 0 1 151.9616 57.1392l-25.3952 39.1168a904.8064 904.8064 0 0 0-153.8048-56.5248z m108.1344-192.7168h-113.664c-2.048 3.2768-5.12 7.9872-8.6016 14.5408a474.112 474.112 0 0 0 62.464 59.1872 447.0784 447.0784 0 0 0 59.8016-74.5472z\" fill=\"#FFFFFF\" p-id=\"42491\"></path></svg>',\n },\n ])\n }\n\n public override createVertex(id: string, index: number, position: LngLat): PointInstance {\n return new IconPoint(this.context.map, {\n icon: index === 0 ? 'plot-arrow-start' : this.getIconName(index),\n id,\n isName: false,\n position,\n properties: {\n id,\n index,\n type: PointType.VERTEX,\n },\n style: {\n ...this.options.vertexStyle,\n 'icon-anchor': 'center',\n 'icon-rotate': this.getRotate(index),\n },\n visibility: this.options.visibility,\n })\n }\n\n private getIconName(index: number): string {\n if (!Array.isArray(this.options.position)) return ''\n\n if (this.createEvent.status === EventStatus.ON) return 'plot-arrow'\n\n const isLast = this.options.position.length - 1 === index\n const isFirst = index === 0\n\n if (isFirst) {\n return 'plot-arrow-start'\n } else if (isLast) {\n return 'plot-arrow-end'\n } else {\n return 'plot-arrow'\n }\n }\n\n private getRotate(index: number): number {\n if (!Array.isArray(this.options.position)) return 0\n\n if (this.createEvent.status === EventStatus.ON) {\n if (index === 0) return 0\n\n const last = this.options.position[index - 1]\n const current = this.options.position[index]\n return bearing(last.toArray(), current.toArray())\n }\n\n const isLast = this.options.position.length - 1 === index\n const isFirst = index === 0\n if (isFirst || isLast) return 0\n\n const last = this.options.position[index - 1]\n const current = this.options.position[index]\n return bearing(last.toArray(), current.toArray())\n }\n}\n","\nexport default class TinyQueue {\n constructor(data = [], compare = (a, b) => (a < b ? -1 : a > b ? 1 : 0)) {\n this.data = data;\n this.length = this.data.length;\n this.compare = compare;\n\n if (this.length > 0) {\n for (let i = (this.length >> 1) - 1; i >= 0; i--) this._down(i);\n }\n }\n\n push(item) {\n this.data.push(item);\n this._up(this.length++);\n }\n\n pop() {\n if (this.length === 0) return undefined;\n\n const top = this.data[0];\n const bottom = this.data.pop();\n\n if (--this.length > 0) {\n this.data[0] = bottom;\n this._down(0);\n }\n\n return top;\n }\n\n peek() {\n return this.data[0];\n }\n\n _up(pos) {\n const {data, compare} = this;\n const item = data[pos];\n\n while (pos > 0) {\n const parent = (pos - 1) >> 1;\n const current = data[parent];\n if (compare(item, current) >= 0) break;\n data[pos] = current;\n pos = parent;\n }\n\n data[pos] = item;\n }\n\n _down(pos) {\n const {data, compare} = this;\n const halfLength = this.length >> 1;\n const item = data[pos];\n\n while (pos < halfLength) {\n let bestChild = (pos << 1) + 1; // initially it is the left child\n const right = bestChild + 1;\n\n if (right < this.length && compare(data[right], data[bestChild]) < 0) {\n bestChild = right;\n }\n if (compare(data[bestChild], item) >= 0) break;\n\n data[pos] = data[bestChild];\n pos = bestChild;\n }\n\n data[pos] = item;\n }\n}\n","\nimport Queue from 'tinyqueue';\n\nexport default function polylabel(polygon, precision = 1.0, debug = false) {\n // find the bounding box of the outer ring\n let minX = Infinity;\n let minY = Infinity;\n let maxX = -Infinity;\n let maxY = -Infinity;\n\n for (const [x, y] of polygon[0]) {\n if (x < minX) minX = x;\n if (y < minY) minY = y;\n if (x > maxX) maxX = x;\n if (y > maxY) maxY = y;\n }\n\n const width = maxX - minX;\n const height = maxY - minY;\n const cellSize = Math.max(precision, Math.min(width, height));\n\n if (cellSize === precision) {\n const result = [minX, minY];\n result.distance = 0;\n return result;\n }\n\n // a priority queue of cells in order of their \"potential\" (max distance to polygon)\n const cellQueue = new Queue([], (a, b) => b.max - a.max);\n\n // take centroid as the first best guess\n let bestCell = getCentroidCell(polygon);\n\n // second guess: bounding box centroid\n const bboxCell = new Cell(minX + width / 2, minY + height / 2, 0, polygon);\n if (bboxCell.d > bestCell.d) bestCell = bboxCell;\n\n let numProbes = 2;\n\n function potentiallyQueue(x, y, h) {\n const cell = new Cell(x, y, h, polygon);\n numProbes++;\n if (cell.max > bestCell.d + precision) cellQueue.push(cell);\n\n // update the best cell if we found a better one\n if (cell.d > bestCell.d) {\n bestCell = cell;\n if (debug) console.log(`found best ${Math.round(1e4 * cell.d) / 1e4} after ${numProbes} probes`);\n }\n }\n\n // cover polygon with initial cells\n let h = cellSize / 2;\n for (let x = minX; x < maxX; x += cellSize) {\n for (let y = minY; y < maxY; y += cellSize) {\n potentiallyQueue(x + h, y + h, h);\n }\n }\n\n while (cellQueue.length) {\n // pick the most promising cell from the queue\n const {max, x, y, h: ch} = cellQueue.pop();\n\n // do not drill down further if there's no chance of a better solution\n if (max - bestCell.d <= precision) break;\n\n // split the cell into four cells\n h = ch / 2;\n potentiallyQueue(x - h, y - h, h);\n potentiallyQueue(x + h, y - h, h);\n potentiallyQueue(x - h, y + h, h);\n potentiallyQueue(x + h, y + h, h);\n }\n\n if (debug) {\n console.log(`num probes: ${numProbes}\\nbest distance: ${bestCell.d}`);\n }\n\n const result = [bestCell.x, bestCell.y];\n result.distance = bestCell.d;\n return result;\n}\n\nfunction Cell(x, y, h, polygon) {\n this.x = x; // cell center x\n this.y = y; // cell center y\n this.h = h; // half the cell size\n this.d = pointToPolygonDist(x, y, polygon); // distance from cell center to polygon\n this.max = this.d + this.h * Math.SQRT2; // max distance to polygon within a cell\n}\n\n// signed distance from point to polygon outline (negative if point is outside)\nfunction pointToPolygonDist(x, y, polygon) {\n let inside = false;\n let minDistSq = Infinity;\n\n for (const ring of polygon) {\n for (let i = 0, len = ring.length, j = len - 1; i < len; j = i++) {\n const a = ring[i];\n const b = ring[j];\n\n if ((a[1] > y !== b[1] > y) &&\n (x < (b[0] - a[0]) * (y - a[1]) / (b[1] - a[1]) + a[0])) inside = !inside;\n\n minDistSq = Math.min(minDistSq, getSegDistSq(x, y, a, b));\n }\n }\n\n return minDistSq === 0 ? 0 : (inside ? 1 : -1) * Math.sqrt(minDistSq);\n}\n\n// get polygon centroid\nfunction getCentroidCell(polygon) {\n let area = 0;\n let x = 0;\n let y = 0;\n const points = polygon[0];\n\n for (let i = 0, len = points.length, j = len - 1; i < len; j = i++) {\n const a = points[i];\n const b = points[j];\n const f = a[0] * b[1] - b[0] * a[1];\n x += (a[0] + b[0]) * f;\n y += (a[1] + b[1]) * f;\n area += f * 3;\n }\n const centroid = new Cell(x / area, y / area, 0, polygon);\n if (area === 0 || centroid.d < 0) return new Cell(points[0][0], points[0][1], 0, polygon);\n return centroid;\n}\n\n// get squared distance from a point to a segment\nfunction getSegDistSq(px, py, a, b) {\n let x = a[0];\n let y = a[1];\n let dx = b[0] - x;\n let dy = b[1] - y;\n\n if (dx !== 0 || dy !== 0) {\n const t = ((px - x) * dx + (py - y) * dy) / (dx * dx + dy * dy);\n\n if (t > 1) {\n x = b[0];\n y = b[1];\n\n } else if (t > 0) {\n x += dx * t;\n y += dy * t;\n }\n }\n\n dx = px - x;\n dy = py - y;\n\n return dx * dx + dy * dy;\n}\n","import type { Map, MapMouseEvent } from 'mapbox-gl'\nimport type { LngLat } from 'mapbox-gl'\n\nimport { EventState } from '@/core/EventState'\nimport type { Fill } from '@/modules/Plot/plugins/Fill'\nimport type { Line } from '@/modules/Plot/plugins/Line'\nimport { CURSOR, Event } from '@/modules/Plot/vars.ts'\nimport type { EventMessage } from '@/types/EventState'\nimport type { PointInstance } from '@/types/Plot/Point.ts'\n\nexport abstract class FillBaseEvent extends EventState {\n protected fill: Fill\n\n protected constructor(map: Map, fill: Fill) {\n super(map)\n\n this.fill = fill\n }\n\n public abstract override onAdd(): void\n\n public abstract override onRemove(): void\n\n public abstract override enabled(): void\n\n public abstract override disabled(): void\n}\n\nexport class FillCreateEvent extends FillBaseEvent {\n private count = 0\n private drawPoint: LngLat | null = null\n\n private onClick = (e: MapMouseEvent): void => {\n // 点击过一次之后 计算结束事件\n if (this.count > 1) {\n const layers = new Set(\n [...(this.fill.line?.points ?? []), ...(this.fill.line?.midPoints ?? [])].map(\n (item) => item.LAYER,\n ),\n )\n\n const features = this.context.map.queryRenderedFeatures(e.point, {\n layers: [...layers],\n })\n\n if (features.length > 0) {\n this.stop(e)\n return\n }\n }\n\n if (!Array.isArray(this.fill.options.position)) {\n this.fill.options.position = []\n this.fill.createLine()\n }\n\n this.fill.line!.insertPoint(this.count, e.lngLat)\n this.fill.options.position = this.fill.line?.options.position\n\n this.count++\n }\n\n private onMousemove = (e: MapMouseEvent): void => {\n this.context.map.getCanvasContainer().style.cursor = CURSOR.CREATE\n this.setDrawLngLat(e.lngLat)\n this.fill.render()\n\n this.fill.emit(Event.UPDATE, this.message<Fill>(e, this.fill))\n }\n\n private onContextmenu = (e: MapMouseEvent): void => {\n this.fill.line!.insertPoint(this.count, e.lngLat)\n this.stop(e)\n }\n\n private stop = (e: MapMouseEvent): void => {\n e.preventDefault()\n const firstPoint = this.fill.line?.points.at(0)\n\n if (this.fill.line && firstPoint?.center) {\n const point = this.fill.line.insertPoint(this.count + 1, firstPoint.center)\n point.hide()\n }\n\n this.context.map.getCanvasContainer().style.cursor = CURSOR.EMPTY\n this.setDrawLngLat(null)\n this.count = 0\n this.fill.setState({ create: false })\n this.disabled()\n\n this.fill.edit()\n this.fill.emit(Event.CREATE, this.message<Fill>(e, this.fill))\n }\n\n constructor(map: Map, fill: Fill) {\n super(map, fill)\n }\n\n public setDrawLngLat(position: LngLat | null): void {\n this.drawPoint = position\n this.fill.line?.createEvent.setDrawLngLat(position)\n }\n\n public getDrawLngLat(): LngLat | null {\n return this.drawPoint\n }\n\n public override onAdd(): void {\n /* empty */\n }\n public override onRemove(): void {\n /* empty */\n }\n\n public override enabled(): void {\n this.context.map.doubleClickZoom.disable()\n //\n this.context.map.on('click', this.onClick)\n this.context.map.on('mousemove', this.onMousemove)\n this.context.map.on('dblclick', this.stop)\n this.context.map.on('contextmenu', this.onContextmenu)\n this.changeStatus()\n }\n public override disabled(): void {\n this.context.map.off('click', this.onClick)\n this.context.map.off('mousemove', this.onMousemove)\n this.context.map.off('dblclick', this.stop)\n this.context.map.off('contextmenu', this.onContextmenu)\n\n setTimeout(() => {\n this.context.map.doubleClickZoom.enable()\n }, 0)\n this.changeStatus()\n }\n}\n\nexport class FillUpdateEvent extends FillBaseEvent {\n protected dragStartLngLat: LngLat | null = null\n\n private onLineUpdate = (e: EventMessage<Line>, point: PointInstance): void => {\n console.log('onLineUpdate')\n if (!point.center || !this.fill.line) return\n\n const index = point.options.properties?.index as number\n\n if (index === 0) {\n const lastIndex = this.fill.line.points.length - 1\n this.fill.line.updatePoint(lastIndex, point.center)\n }\n\n this.fill.line.updatePoint(index, point.center)\n\n this.fill.render()\n\n this.fill.emit(Event.UPDATE, this.message<Fill>(e.originEvent, this.fill), point)\n }\n\n private onLineMidUpdate = (e: EventMessage<Line>): void => {\n this.fill.render()\n\n this.fill.emit(Event.MID_UPDATE, this.message<Fill>(e.originEvent, this.fill))\n }\n\n private onLineMidDoneUpdate = (e: EventMessage<Line>): void => {\n this.fill.line?.points.at(-1)?.hide()\n\n this.fill.emit(Event.MID_DONE_UPDATE, this.message<Fill>(e.originEvent, this.fill))\n }\n\n private onFillMousedown = (e: MapMouseEvent): void => {\n const layers = new Set(\n [...(this.fill.line?.points ?? []), ...(this.fill.line?.midPoints ?? [])].map(\n (item) => item.LAYER,\n ),\n )\n\n const features = this.context.map.queryRenderedFeatures(e.point, {\n layers: [...layers, this.fill.line?.LAYER ?? ''],\n })\n\n if (features.length > 0) {\n return\n }\n\n e.preventDefault()\n this.context.map.getCanvasContainer().style.cursor = 'move'\n this.setDragLngLat(e.lngLat)\n\n this.context.map.on('mousemove', this.onMousemove)\n this.context.map.once('mouseup', this.onMouseup)\n\n this.fill.emit(Event.BEFORE_UPDATE, this.message<Fill>(e, this.fill))\n }\n\n private onMousemove = (e: MapMouseEvent): void => {\n this.context.map.getCanvasContainer().style.cursor = 'move'\n const current = e.lngLat\n this.fill.move(current)\n this.setDragLngLat(current)\n this.fill.emit(Event.UPDATE, this.message<Fill>(e, this.fill))\n }\n\n private onMouseup = (e: MapMouseEvent): void => {\n this.context.map.getCanvasContainer().style.cursor = 'pointer'\n this.context.map.off('mousemove', this.onMousemove)\n this.setDragLngLat(null)\n this.fill.render()\n\n this.fill.emit(Event.DONE_UPDATE, this.message<Fill>(e, this.fill))\n }\n\n private onFillMouseenter = (): void => {\n this.context.map.getCanvasContainer().style.cursor = 'pointer'\n }\n\n private onFillMouseLeave = (): void => {\n this.context.map.getCanvasContainer().style.cursor = ''\n }\n\n constructor(map: Map, fill: Fill) {\n super(map, fill)\n }\n\n public setDragLngLat(position: LngLat | null): void {\n this.dragStartLngLat = position\n }\n\n public getDragLngLat(): LngLat | null {\n return this.dragStartLngLat\n }\n\n public override onAdd(): void {\n /* empty */\n }\n\n public override onRemove(): void {\n this.disabled()\n }\n\n public override enabled(): void {\n this.fill.line?.on(Event.UPDATE, this.onLineUpdate)\n\n this.fill.line?.on(Event.MID_UPDATE, this.onLineMidUpdate)\n\n this.fill.line?.on(Event.MID_DONE_UPDATE, this.onLineMidDoneUpdate)\n\n this.context.map.on('mousedown', this.fill.LAYER, this.onFillMousedown)\n\n this.context.eventManager.on(this.fill.id, this.fill.LAYER, 'mouseenter', this.onFillMouseenter)\n\n this.context.eventManager.on(this.fill.id, this.fill.LAYER, 'mouseleave', this.onFillMouseLeave)\n\n this.changeStatus()\n }\n\n public override disabled(): void {\n this.fill.line?.off(Event.UPDATE, this.onLineUpdate)\n\n this.fill.line?.off(Event.MID_UPDATE, this.onLineMidUpdate)\n\n this.fill.line?.off(Event.MID_DONE_UPDATE, this.onLineMidDoneUpdate)\n\n this.context.map.off('mousedown', this.fill.LAYER, this.onFillMousedown)\n\n this.context.eventManager.off(this.fill.id, 'mouseenter', this.onFillMouseenter)\n\n this.context.eventManager.off(this.fill.id, 'mouseleave', this.onFillMouseLeave)\n\n this.changeStatus()\n }\n}\n\nexport class FillResidentEvent extends FillBaseEvent {\n constructor(map: Map, fill: Fill) {\n super(map, fill)\n }\n\n public override onAdd(): void {\n // this.on()\n }\n\n public override onRemove(): void {\n this.disabled()\n }\n\n public override enabled(): void {\n this.changeStatus()\n }\n\n public override disabled(): void {\n this.changeStatus()\n }\n}\n","import type {\n ColorSpecification,\n DataDrivenPropertyValueSpecification,\n LayerSpecification,\n} from 'mapbox-gl'\n\nimport type { SortLayer } from '@/core/ResourceRegister'\nimport { PLOT_SOURCE_NAME } from '@/modules/Plot/vars.ts'\nimport { PlotType } from '@/types/Plot/Poi.ts'\n\nexport const NAME = PlotType.Fill\n\nexport const Z_INDEX = 3\n\nexport const FILL_LAYER_NAME = 'mapbox-gl-plot-fill-layer'\n\nexport const FILL_CLOSED_LINE_LAYER_NAME = 'mapbox-gl-plot-closed-line-layer'\n\nexport const DEFAULT_FILL_COLOR = '#009dff'\n\nexport const DEFAULT_FILL_OPACITY = 0.3\n\nconst fillColor: DataDrivenPropertyValueSpecification<ColorSpecification> = [\n 'coalesce',\n ['get', 'fill-color'],\n DEFAULT_FILL_COLOR,\n]\n\nconst fillOpacity: DataDrivenPropertyValueSpecification<number> = [\n 'coalesce',\n ['get', 'fill-opacity'],\n DEFAULT_FILL_OPACITY,\n]\n\nexport const FILL_LAYER: LayerSpecification = {\n id: FILL_LAYER_NAME,\n type: 'fill',\n filter: ['all', ['==', '$type', 'Polygon'], ['==', 'visibility', 'visible']],\n source: PLOT_SOURCE_NAME,\n paint: {\n 'fill-color': fillColor,\n 'fill-opacity': fillOpacity,\n },\n layout: {},\n}\n\nexport const FILL_CLOSED_LINE_LAYER: LayerSpecification = {\n id: FILL_CLOSED_LINE_LAYER_NAME,\n type: 'line',\n filter: ['all', ['==', 'visibility', 'visible']],\n source: PLOT_SOURCE_NAME,\n paint: {\n 'line-color': fillColor,\n 'line-width': ['case', ['boolean', ['feature-state', 'create'], false], 3, 0],\n // 'line-width': 3,\n },\n layout: {},\n}\n\nexport const LAYER_LIST: SortLayer[] = [\n {\n layer: FILL_LAYER,\n zIndex: Z_INDEX,\n },\n {\n layer: FILL_CLOSED_LINE_LAYER,\n zIndex: Z_INDEX,\n },\n]\n","import { bbox, booleanPointInPolygon, centerOfMass, lineToPolygon } from '@turf/turf'\nimport type * as GeoJSON from 'geojson'\nimport type { Feature, Polygon } from 'geojson'\nimport type { Map } from 'mapbox-gl'\nimport { LngLat } from 'mapbox-gl'\nimport polylabel from 'polylabel'\n\nimport { FillResidentEvent } from '@/modules/Plot/plugins/Events/FillEvents.ts'\nimport { FillUpdateEvent } from '@/modules/Plot/plugins/Events/FillEvents.ts'\nimport { FillCreateEvent } from '@/modules/Plot/plugins/Events/FillEvents.ts'\nimport { IconPoint } from '@/modules/Plot/plugins/IconPoint'\nimport { Line } from '@/modules/Plot/plugins/Line'\nimport { Poi } from '@/modules/Plot/plugins/Poi.ts'\nimport { EMPTY_SOURCE, PLOT_SOURCE_NAME } from '@/modules/Plot/vars.ts'\nimport type { IFillOptions } from '@/types/Plot/Fill.ts'\nimport type { PlotType } from '@/types/Plot/Poi.ts'\nimport type { CirclePointStyle } from '@/types/Plot/Point.ts'\n\nimport { DEFAULT_FILL_COLOR, FILL_LAYER_NAME, LAYER_LIST, NAME } from './vars.ts'\n\nexport class Fill<T extends IFillOptions = IFillOptions> extends Poi<T, GeoJSON.Polygon | null> {\n static NAME: PlotType = NAME\n override readonly LAYER: string = FILL_LAYER_NAME\n public title: IconPoint | null = null\n public line: Line | null = null\n\n protected residentEvent: FillResidentEvent\n protected updateEvent: FillUpdateEvent\n protected createEvent: FillCreateEvent\n\n constructor(map: Map, options: T) {\n super(map, options)\n\n if (this.options.position) {\n this.options.position = [...this.options.position, this.options.position[0]]\n }\n\n this.residentEvent = new FillResidentEvent(map, this)\n this.updateEvent = new FillUpdateEvent(map, this)\n this.createEvent = new FillCreateEvent(map, this)\n\n this.createLine()\n\n if (this.center) {\n this.title = new IconPoint(this.context.map, {\n icon: this.options.icon ?? 'normal-fill',\n visibility: this.options.visibility,\n id: this.id + '-fill-title-icon',\n position: this.center,\n name: this.options.name,\n isName: this.options.isName,\n })\n }\n\n this.residentEvent.enabled()\n }\n\n get center(): LngLat | null {\n if (!Array.isArray(this.options.position) || this.options.position.length === 0) {\n return null\n }\n\n if (this.geometry === null) return null\n\n const center = centerOfMass(this.getFeature())\n\n if (booleanPointInPolygon(center, this.getFeature() as GeoJSON.Feature<GeoJSON.Polygon>)) {\n const coordinates = center.geometry.coordinates\n return new LngLat(coordinates[0], coordinates[1])\n } else {\n const coordinates = this.options.position.map((item) => item.toArray())\n\n const [lng, lat]: number[] = polylabel([coordinates], 0.000001)\n return new LngLat(lng, lat)\n }\n }\n\n get geometry(): Polygon | null {\n return this.getFeature().geometry\n }\n\n getFeature(): Feature<Polygon | null> {\n if (\n this.line?.geometry &&\n Array.isArray(this.line.geometry.coordinates) &&\n this.line.geometry.coordinates.length > 2\n ) {\n const polygon = lineToPolygon(this.line.getFeature() as unknown as GeoJSON.LineString, {\n properties: {\n ...this.options.style,\n ...this.options.properties,\n visibility: this.options.visibility,\n id: this.options.id,\n },\n }) as Feature<Polygon | null>\n polygon.id = this.id\n return polygon\n } else {\n return {\n type: 'Feature',\n geometry: null,\n id: this.id,\n properties: {},\n }\n }\n }\n\n public override get id(): string {\n return this.options.id\n }\n\n move(position: LngLat): void {\n // 1. 确保有拖拽参考点和内部关联的 line 对象 如果不借助鼠标拖拽 直接移动以中心为基准点\n const drag: LngLat | null =\n this.center === null ? this.center : this.updateEvent.getDragLngLat()\n if (!this.line || !drag) return\n\n // 2. 计算当前鼠标所在的帧,相对于上一帧鼠标位置的经纬度偏移量 (Delta)\n const lngDiff = position.lng - drag.lng\n const latDiff = position.lat - drag.lat\n\n // 3. 借助底层 Line 实例,遍历并移动所有构成多边形的实点\n this.line.points.forEach((point, index) => {\n if (point.center) {\n const newPos = new LngLat(point.center.lng + lngDiff, point.center.lat + latDiff)\n\n // 🔥 核心思路:复用 Line 的 updatePoint\n // 传入 false 是为了防止在 for 循环中疯狂触发重绘,造成严重的性能问题\n this.line!.updatePoint(index, newPos, false)\n }\n })\n\n // 4. 同步最新坐标给 Fill 自身\n // (因为 line.updatePoint 内部已经更新了 line.options.position)\n this.options.position = this.line.options.position\n\n // 5. 触发真正的统一重绘\n this.render()\n }\n\n public createLine(): void {\n if (!Array.isArray(this.options.position)) return\n\n // 1. 提取 Fill 的颜色,如果没有设置则使用默认的主题色 #f00\n const fillColor = this.options.style?.['fill-color'] ?? DEFAULT_FILL_COLOR\n\n // 2. 组装边框线样式:颜色与 Fill 同步,并合并传入的 outLineStyle\n const lineStyle: IFillOptions['outLineStyle'] = {\n 'line-color': fillColor,\n ...this.options.outLineStyle,\n }\n\n // 3. 组装实点样式:边框颜色与 Fill 同步,并合并传入的 vertexStyle\n const vertexStyle = {\n 'circle-radius': 5,\n 'circle-stroke-color': fillColor,\n // 'circle-color': '#fff', // 内部默认是白色,如果需要全实心也可以改成 fillColor\n ...this.options.vertexStyle,\n } as CirclePointStyle\n\n this.line = new Line(this.context.map, {\n isName: false,\n // midStyle: undefined,\n // name: '',\n position: this.options.position,\n properties: {},\n style: lineStyle,\n vertexStyle: vertexStyle,\n visibility: this.options.visibility,\n id: `${this.id}-line`,\n })\n\n const lastIndex = this.line.points.length - 1\n if (lastIndex > 0) {\n const lastPoint = this.line.points[lastIndex]\n lastPoint.hide()\n }\n }\n\n public removeLine(): void {\n this.line?.remove()\n this.line = null\n }\n\n override onAdd(): void {\n this.context.register.addSource(PLOT_SOURCE_NAME, EMPTY_SOURCE)\n\n LAYER_LIST.forEach((layer) => {\n this.context.register.addLayer(layer)\n })\n\n this.context.iconManage.addSvg({\n name: 'normal-fill',\n svg: '<svg t=\"1773066297467\" class=\"icon\" viewBox=\"0 0 1024 1024\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" p-id=\"15103\" width=\"32\" height=\"32\"><path d=\"M1024 512c0 282.8-229.2 512-512 512S0 794.8 0 512 229.2 0 512 0s512 229.2 512 512\" fill=\"#5A89FF\" p-id=\"15104\"></path><path d=\"M709.76 818.4H314.24a24 24 0 0 1-22.8-16.56L169.2 425.6c-3.2-9.92 0.32-20.72 8.72-26.8l320-232.48c8.4-6.08 19.84-6.08 28.24 0l320 232.48a24 24 0 0 1 8.72 26.8l-122.24 376.16a24.136 24.136 0 0 1-22.88 16.64z m-378.08-48h360.64l111.44-343.04L512 215.36l-291.76 212L331.68 770.4z\" fill=\"#FFFFFF\" p-id=\"15105\"></path></svg>',\n })\n }\n\n override onRemove(): void {\n this.remove()\n }\n\n remove(): void {\n this.options.position = []\n this.removeLine()\n\n this.title?.remove()\n this.title = null\n this.render()\n }\n\n public override show(): void {\n this.line?.show()\n super.show()\n }\n\n public override hide(): void {\n this.line?.hide()\n super.hide()\n }\n\n render(): void {\n if (this.line) {\n this.line.render()\n this.options.position = this.line.options.position\n }\n\n if (this.options.visibility === 'visible') {\n this.title?.show()\n } else {\n this.title?.hide()\n }\n\n if (this.isFocus) {\n this.context.focus.set(this.getFeature() as GeoJSON.Feature, {\n armLength: 40,\n padding: 30,\n })\n } else {\n this.context.focus.remove(this.id)\n }\n\n this.context.register.setGeoJSONData(PLOT_SOURCE_NAME, this.getFeature() as GeoJSON.Feature)\n }\n\n start(): void {\n if (this.center === null) {\n this.createEvent.enabled()\n this.updateEvent.disabled()\n this.residentEvent.disabled()\n\n this.setState({ create: true })\n }\n }\n\n stop(): void {\n this.createEvent.disabled()\n this.residentEvent.enabled()\n this.setState({ create: false })\n }\n\n unedit(): void {\n this.setState({ edit: false })\n this.line?.unedit()\n this.residentEvent.enabled()\n this.updateEvent.disabled()\n\n this.render()\n }\n\n edit(): void {\n this.setState({ edit: true })\n\n this.line?.edit()\n\n this.residentEvent.disabled()\n this.updateEvent.enabled()\n this.render()\n }\n\n focus(): void {\n this.setState({ focus: true })\n\n this.render()\n }\n\n unfocus(): void {\n this.setState({ focus: false })\n\n this.render()\n }\n\n select(): void {\n const bounds = bbox(this.getFeature() as GeoJSON.Feature) as [number, number, number, number]\n this.context.map.fitBounds(bounds, {\n padding: {\n left: 60,\n right: 60,\n top: 60,\n bottom: 60,\n },\n })\n\n this.context.map.once('moveend', () => {\n this.focus()\n })\n }\n\n unselect(): void {\n this.unfocus()\n }\n\n update(options: T): void {\n this.options = options\n\n if (this.options.position) {\n this.options.position = [...this.options.position, this.options.position[0]]\n }\n\n this.removeLine()\n this.createLine()\n }\n}\n","import { point } from '@turf/turf'\nimport type * as GeoJSON from 'geojson'\nimport type { Map } from 'mapbox-gl'\n\nimport { Point } from '@/modules/Plot/plugins/Point'\nimport type { IIndexPointOptions } from '@/types/Plot/IndexPoint.ts'\nimport type { PlotType } from '@/types/Plot/Poi.ts'\n\nimport { LAYER_LIST, NAME, POINT_INDEX_LAYER_NAME } from './vars.ts'\n\nexport class IndexPoint extends Point<IIndexPointOptions> {\n static override NAME: PlotType = NAME\n override readonly LAYER: string = POINT_INDEX_LAYER_NAME\n\n constructor(map: Map, options: IIndexPointOptions) {\n super(map, options)\n }\n\n public override onAdd(): void {\n super.onAdd()\n\n LAYER_LIST.forEach((layer) => {\n this.context.register.addLayer(layer)\n })\n }\n\n public override getFeature(): GeoJSON.Feature<GeoJSON.Point | null> {\n if (!this.options.position) {\n const emptyFeature: GeoJSON.Feature<null> = {\n type: 'Feature',\n geometry: null,\n id: this.id,\n properties: {},\n }\n\n return emptyFeature\n }\n\n return point(\n this.options.position.toArray(),\n {\n ...this.options.style,\n ...this.options.properties,\n id: this.options.id,\n visibility: this.options.visibility,\n isName: false,\n index: this.options.index,\n meta: 'circle',\n subMeta: 'indexPoint',\n },\n {\n id: this.options.id,\n },\n )\n }\n}\n","import type { Map } from 'mapbox-gl'\nimport type { LngLat } from 'mapbox-gl'\n\nimport { IndexPoint } from '@/modules/Plot/plugins/IndexPoint'\nimport { Line } from '@/modules/Plot/plugins/Line'\nimport type { IIndexLineOptions } from '@/types/Plot/IndexLine.ts'\nimport type { IndexPointStyle } from '@/types/Plot/IndexPoint.ts'\nimport { PointType } from '@/types/Plot/Line.ts'\nimport type { PointInstance } from '@/types/Plot/Point.ts'\n\nexport class IndexLine extends Line<IIndexLineOptions> {\n constructor(map: Map, options: IIndexLineOptions) {\n super(map, options)\n }\n\n public override createVertex(id: string, index: number, position: LngLat): PointInstance {\n return new IndexPoint(this.context.map, {\n id, // 建议 ID 加上 node 标识\n isName: false,\n visibility: 'visible',\n position,\n index: index + 1,\n style: this.options.vertexStyle as IndexPointStyle,\n properties: {\n id: `${this.id}-node-${String(index)}`,\n index,\n type: PointType.VERTEX, // 标记类型,方便点击事件区分\n },\n })\n }\n}\n","import type { Map, MapMouseEvent } from 'mapbox-gl'\n\nimport { EventState } from '@/core/EventState'\nimport type { AisShip } from '@/modules/Ship/plugins/AisShip.ts'\nimport { SHIP_ICON_LAYER_NAME, SHIP_REAL_LAYER_NAME } from '@/modules/Ship/vars.ts'\nimport type { IAisShipOptions } from '@/types/Ship/AisShip.ts'\n\nexport class ResidentEvent extends EventState {\n private ships: AisShip[] = []\n protected hoverId: IAisShipOptions['id'] | null | undefined = null\n protected _click: OmitThisParameter<(e: MapMouseEvent) => void> = (): void => {\n /* empty */\n }\n protected _move: OmitThisParameter<(e: MapMouseEvent) => void> = (): void => {\n /* empty */\n }\n protected _leave: OmitThisParameter<(e: MapMouseEvent) => void> = (): void => {\n /* empty */\n }\n protected _zoomEnd = (): void => {\n /* empty */\n }\n\n constructor(map: Map, ships?: AisShip[]) {\n super(map)\n\n if (ships) {\n this.ships = ships\n }\n }\n\n override enabled(): void {\n this.context.map.on('click', SHIP_ICON_LAYER_NAME, this._click)\n this.context.map.on('mousemove', SHIP_ICON_LAYER_NAME, this._move)\n this.context.map.on('mouseleave', SHIP_ICON_LAYER_NAME, this._leave)\n\n this.context.map.on('click', SHIP_REAL_LAYER_NAME, this._click)\n this.context.map.on('mousemove', SHIP_REAL_LAYER_NAME, this._move)\n this.context.map.on('mouseleave', SHIP_REAL_LAYER_NAME, this._leave)\n\n this.context.map.on('zoomend', this._zoomEnd)\n }\n\n override disabled(): void {\n this.context.map.off('click', SHIP_ICON_LAYER_NAME, this._click)\n this.context.map.off('mousemove', SHIP_ICON_LAYER_NAME, this._move)\n this.context.map.off('mouseleave', SHIP_ICON_LAYER_NAME, this._leave)\n\n this.context.map.off('click', SHIP_REAL_LAYER_NAME, this._click)\n this.context.map.off('mousemove', SHIP_REAL_LAYER_NAME, this._move)\n this.context.map.off('mouseleave', SHIP_REAL_LAYER_NAME, this._leave)\n\n this.context.map.off('zoomend', this._zoomEnd)\n }\n\n onAdd(): void {\n this._click = this.onClick.bind(this)\n this._move = this.onMove.bind(this)\n this._leave = this.onLeave.bind(this)\n this._zoomEnd = this.onZoomEnd.bind(this)\n\n this.enabled()\n }\n\n onRemove(): void {\n this.disabled()\n }\n\n add(ship: AisShip): void {\n const data = this.findShip(ship.id)\n if (data) {\n ship.update(data.options)\n } else {\n this.ships.push(ship)\n }\n }\n\n remove(id: IAisShipOptions['id']): void {\n const i = this.ships.findIndex((item) => item.id === id)\n if (i !== -1) {\n this.ships.splice(i, 1)\n }\n }\n\n removeAll(): void {\n this.ships = []\n }\n\n onZoomEnd(): void {\n this.ships.forEach((ship) => {\n ship.render()\n })\n }\n\n onMove(e: MapMouseEvent): void {\n if (e.features?.length) {\n this.context.map.getCanvasContainer().style.cursor = 'pointer'\n\n if (this.hoverId === e.features[0].id) return\n\n if (this.hoverId) {\n this.unhover()\n }\n\n this.hoverId = e.features[0].id as string\n this.hover()\n }\n }\n\n onLeave(): void {\n this.unhover()\n this.hoverId = null\n this.context.map.getCanvasContainer().style.cursor = ''\n }\n\n onClick(e: MapMouseEvent): void {\n if (e.features?.length) {\n const id = e.features[0].id\n if (id) {\n const ship = this.findShip(id)\n\n this.context.events.emit('click', ship)\n this.context.map.fire('ship-click', ship)\n }\n }\n }\n\n hover(): void {\n if (!this.hoverId) return\n\n const ship = this.findShip(this.hoverId)\n ship?.setState({ hover: true })\n ship?.render()\n this.context.events.emit('hover', ship)\n this.context.map.fire('ship-hover', ship)\n }\n\n unhover(): void {\n if (!this.hoverId) return\n\n const ship = this.findShip(this.hoverId)\n ship?.setState({ hover: false })\n ship?.render()\n this.context.events.emit('unhover', ship)\n this.context.map.fire('ship-unhover', ship)\n }\n\n findShip(id: IAisShipOptions['id']): AisShip | undefined {\n return this.ships.find((item) => String(item.id) === String(id))\n }\n}\n","import type { Map as MapboxGlMap } from 'mapbox-gl'\n\nimport Collision from '@/core/Collision'\nimport { Module } from '@/core/Module'\nimport type { Tooltip } from '@/core/Tooltip'\nimport type { BaseShip } from '@/modules/Ship/BaseShip.ts'\nimport { ResidentEvent } from '@/modules/Ship/Events/ResidentEvent'\nimport type { CollisionItemOptions } from '@/types/Collision/item.ts'\nimport type { IShipOptions } from '@/types/Ship'\nimport type { BaseShipConstructor, IBaseShipOptions } from '@/types/Ship/BaseShip.ts'\n\nclass Ship extends Module {\n options: IShipOptions\n ships: BaseShip<any>[] = []\n event: ResidentEvent\n\n private pluginRegistry = new Map<string, BaseShipConstructor>()\n private collision: Collision\n private focusId: IBaseShipOptions['id'] | null = null\n\n constructor(map: MapboxGlMap, options: IShipOptions) {\n super(map)\n this.options = options\n this.collision = new Collision(this.context.map)\n this.event = new ResidentEvent(map)\n\n this.registerPlugins(options.plugins)\n }\n\n override onAdd(): void {\n // throw new Error('Method not implemented.')\n }\n override onRemove(): void {\n // throw new Error('Method not implemented.')\n }\n\n get tooltips(): Tooltip[] {\n return this.ships.flatMap((ship) => ship.tooltip ?? [])\n }\n\n private registerPlugins(plugins: BaseShipConstructor[] = []): void {\n plugins.forEach((PluginClass) => {\n if (PluginClass.NAME) {\n this.pluginRegistry.set(PluginClass.NAME, PluginClass)\n } else {\n console.warn('Ship Plugin missing static NAME property:', PluginClass)\n }\n })\n }\n\n private createCollisions(): CollisionItemOptions[] {\n return this.tooltips.map((tooltip) => {\n return {\n // ...tooltip.getSimpleBbox(),\n ...tooltip.getAllBbox(),\n id: tooltip.id,\n }\n })\n }\n\n private collisionTooltip(): void {\n this.collision.load(this.createCollisions()).forEach((collision) => {\n const tooltip = this.tooltips.find((tooltip) => tooltip.id === collision.id)\n if (!tooltip) return\n\n if (collision.visible) {\n tooltip.setAnchor(collision.dir)\n }\n // tooltip.hide()\n // }\n })\n }\n\n add(data: IBaseShipOptions): BaseShip<any> | undefined {\n const Constructor = this.pluginRegistry.get(data.type)\n\n if (!Constructor) {\n console.warn(`No plugin registered for ship type: \"${data.type}\"`)\n return undefined\n }\n\n const ship = new Constructor(this.context.map, data)\n this.ships.push(ship)\n this.event.add(ship)\n\n return ship\n }\n\n load(list: IBaseShipOptions[]): BaseShip<any>[] {\n this.removeAll()\n\n const newShips: BaseShip<any>[] = []\n list.forEach((item) => {\n const ship = this.add(item)\n if (ship) {\n newShips.push(ship)\n }\n })\n\n this.render()\n\n this.collisionTooltip()\n\n if (this.focusId) {\n const ship = this.get(this.focusId)\n if (ship) {\n ship.focus()\n }\n }\n\n return newShips\n }\n\n remove(id: IBaseShipOptions['id']): void {\n this.event.remove(id)\n\n const i = this.ships.findIndex((ship) => ship.id === id)\n if (i !== -1) {\n this.ships[i].remove()\n this.ships.splice(i, 1)\n }\n }\n\n removeAll(): void {\n this.collision.clear()\n\n this.ships.forEach((ship) => {\n ship.remove()\n })\n this.ships = []\n\n this.event.removeAll()\n }\n\n render(): void {\n this.ships.forEach((ship) => {\n ship.render()\n })\n }\n\n get(id: string | number): BaseShip<any> | undefined {\n return this.ships.find((item) => item.id === id)\n }\n\n focus(id: IBaseShipOptions['id']): void {\n const ship = this.get(id)\n if (ship) {\n ship.focus()\n this.focusId = ship.id\n } else {\n console.warn(`The ship-${String(id)} was not found.`)\n }\n }\n\n unfocus(id: IBaseShipOptions['id']): void {\n const ship = this.get(id)\n if (ship) {\n ship.unfocus()\n this.focusId = null\n } else {\n console.warn(`The ship-${String(id)} was not found.`)\n }\n }\n\n select(id: IBaseShipOptions['id']): void {\n const ship = this.get(id)\n if (ship) {\n ship.select()\n this.focusId = ship.id\n } else {\n console.warn(`The ship-${String(id)} was not found.`)\n }\n }\n\n unselect(id: IBaseShipOptions['id']): void {\n const ship = this.get(id)\n if (ship) {\n ship.unselect()\n this.focusId = null\n } else {\n console.warn(`The ship-${String(id)} was not found.`)\n }\n }\n}\n\nexport default Ship\n","import type * as GeoJSON from 'geojson'\nimport type { Map, MapMouseEvent, Point } from 'mapbox-gl'\n\nimport { Module } from '@/core/Module'\nimport type { Tooltip } from '@/core/Tooltip'\nimport type { UPDATE_STATUS } from '@/modules/Ship/vars.ts'\nimport type { IAisShipOptions } from '@/types/Ship/AisShip.ts'\nimport type { IBaseShipOptions, Orientation, Shape } from '@/types/Ship/BaseShip.ts'\n\nexport abstract class BaseShip<T extends IBaseShipOptions> extends Module {\n public options: T\n readonly SOURCE: string = 'mapbox-gl-ship-source'\n static NAME = 'Base'\n // readonly NAME: string = 'Base'\n\n public tooltip: Tooltip | null = null\n\n visible = true\n\n protected constructor(map: Map, options: T) {\n super(map)\n\n this.options = options\n }\n\n override destroy(): void {\n throw new Error('Method not implemented.')\n }\n\n get isFocus(): boolean {\n const state = this.getState()\n if (state) {\n return !!state.focus\n } else {\n return false\n }\n }\n\n get isHover(): boolean {\n const state = this.getState()\n if (state) {\n return !!state.hover\n } else {\n return false\n }\n }\n\n public abstract override onAdd(): void\n\n public abstract override onRemove(): void\n\n abstract get id(): IBaseShipOptions['id']\n\n abstract get updateStatus(): UPDATE_STATUS\n\n abstract getIconName(): string\n\n abstract position(): IBaseShipOptions['position']\n\n abstract get direction(): IBaseShipOptions['direction']\n\n abstract get orientation(): Orientation\n\n abstract getShape(): Shape | null\n\n abstract getFeature(): GeoJSON.Feature<GeoJSON.Polygon, T> | GeoJSON.Feature<GeoJSON.Point, T>\n\n abstract remove(): void\n\n abstract setTooltip(tooltip: Tooltip): void\n\n abstract removeTooltip(): void\n\n abstract update(options: IAisShipOptions): void\n\n abstract select(): void\n\n abstract unselect(): void\n\n abstract focus(): void\n\n abstract unfocus(): void\n\n abstract icon(): GeoJSON.Feature<GeoJSON.Point, T>\n\n abstract real(): GeoJSON.Feature<GeoJSON.Polygon, T> | GeoJSON.Feature<GeoJSON.Point, T>\n\n abstract headingLine(): GeoJSON.Feature<\n GeoJSON.LineString | null,\n { meta: 'directionLine'; 'line-color': string }\n >\n\n abstract render(): void\n\n abstract label(): HTMLElement\n\n abstract offset(): Point\n\n public setState(states: Record<string, unknown>): void {\n this.context.map.setFeatureState(\n {\n source: this.SOURCE,\n id: this.id,\n },\n states,\n )\n }\n\n public getState(): Record<string, unknown> | null | undefined {\n return this.context.map.getFeatureState({\n source: this.SOURCE,\n id: this.id,\n })\n }\n\n public isSelf(e: MapMouseEvent): boolean {\n if (e.features && e.features.length > 0) {\n const data = e.features[0]\n return String(data.id) === this.id\n } else {\n return false\n }\n }\n\n public getName(): string {\n return BaseShip.NAME\n }\n}\n","!function(t,e){\"object\"==typeof exports&&\"undefined\"!=typeof module?module.exports=e():\"function\"==typeof define&&define.amd?define(e):(t=\"undefined\"!=typeof globalThis?globalThis:t||self).dayjs=e()}(this,(function(){\"use strict\";var t=1e3,e=6e4,n=36e5,r=\"millisecond\",i=\"second\",s=\"minute\",u=\"hour\",a=\"day\",o=\"week\",c=\"month\",f=\"quarter\",h=\"year\",d=\"date\",l=\"Invalid Date\",$=/^(\\d{4})[-/]?(\\d{1,2})?[-/]?(\\d{0,2})[Tt\\s]*(\\d{1,2})?:?(\\d{1,2})?:?(\\d{1,2})?[.:]?(\\d+)?$/,y=/\\[([^\\]]+)]|Y{1,4}|M{1,4}|D{1,2}|d{1,4}|H{1,2}|h{1,2}|a|A|m{1,2}|s{1,2}|Z{1,2}|SSS/g,M={name:\"en\",weekdays:\"Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday\".split(\"_\"),months:\"January_February_March_April_May_June_July_August_September_October_November_December\".split(\"_\"),ordinal:function(t){var e=[\"th\",\"st\",\"nd\",\"rd\"],n=t%100;return\"[\"+t+(e[(n-20)%10]||e[n]||e[0])+\"]\"}},m=function(t,e,n){var r=String(t);return!r||r.length>=e?t:\"\"+Array(e+1-r.length).join(n)+t},v={s:m,z:function(t){var e=-t.utcOffset(),n=Math.abs(e),r=Math.floor(n/60),i=n%60;return(e<=0?\"+\":\"-\")+m(r,2,\"0\")+\":\"+m(i,2,\"0\")},m:function t(e,n){if(e.date()<n.date())return-t(n,e);var r=12*(n.year()-e.year())+(n.month()-e.month()),i=e.clone().add(r,c),s=n-i<0,u=e.clone().add(r+(s?-1:1),c);return+(-(r+(n-i)/(s?i-u:u-i))||0)},a:function(t){return t<0?Math.ceil(t)||0:Math.floor(t)},p:function(t){return{M:c,y:h,w:o,d:a,D:d,h:u,m:s,s:i,ms:r,Q:f}[t]||String(t||\"\").toLowerCase().replace(/s$/,\"\")},u:function(t){return void 0===t}},g=\"en\",D={};D[g]=M;var p=\"$isDayjsObject\",S=function(t){return t instanceof _||!(!t||!t[p])},w=function t(e,n,r){var i;if(!e)return g;if(\"string\"==typeof e){var s=e.toLowerCase();D[s]&&(i=s),n&&(D[s]=n,i=s);var u=e.split(\"-\");if(!i&&u.length>1)return t(u[0])}else{var a=e.name;D[a]=e,i=a}return!r&&i&&(g=i),i||!r&&g},O=function(t,e){if(S(t))return t.clone();var n=\"object\"==typeof e?e:{};return n.date=t,n.args=arguments,new _(n)},b=v;b.l=w,b.i=S,b.w=function(t,e){return O(t,{locale:e.$L,utc:e.$u,x:e.$x,$offset:e.$offset})};var _=function(){function M(t){this.$L=w(t.locale,null,!0),this.parse(t),this.$x=this.$x||t.x||{},this[p]=!0}var m=M.prototype;return m.parse=function(t){this.$d=function(t){var e=t.date,n=t.utc;if(null===e)return new Date(NaN);if(b.u(e))return new Date;if(e instanceof Date)return new Date(e);if(\"string\"==typeof e&&!/Z$/i.test(e)){var r=e.match($);if(r){var i=r[2]-1||0,s=(r[7]||\"0\").substring(0,3);return n?new Date(Date.UTC(r[1],i,r[3]||1,r[4]||0,r[5]||0,r[6]||0,s)):new Date(r[1],i,r[3]||1,r[4]||0,r[5]||0,r[6]||0,s)}}return new Date(e)}(t),this.init()},m.init=function(){var t=this.$d;this.$y=t.getFullYear(),this.$M=t.getMonth(),this.$D=t.getDate(),this.$W=t.getDay(),this.$H=t.getHours(),this.$m=t.getMinutes(),this.$s=t.getSeconds(),this.$ms=t.getMilliseconds()},m.$utils=function(){return b},m.isValid=function(){return!(this.$d.toString()===l)},m.isSame=function(t,e){var n=O(t);return this.startOf(e)<=n&&n<=this.endOf(e)},m.isAfter=function(t,e){return O(t)<this.startOf(e)},m.isBefore=function(t,e){return this.endOf(e)<O(t)},m.$g=function(t,e,n){return b.u(t)?this[e]:this.set(n,t)},m.unix=function(){return Math.floor(this.valueOf()/1e3)},m.valueOf=function(){return this.$d.getTime()},m.startOf=function(t,e){var n=this,r=!!b.u(e)||e,f=b.p(t),l=function(t,e){var i=b.w(n.$u?Date.UTC(n.$y,e,t):new Date(n.$y,e,t),n);return r?i:i.endOf(a)},$=function(t,e){return b.w(n.toDate()[t].apply(n.toDate(\"s\"),(r?[0,0,0,0]:[23,59,59,999]).slice(e)),n)},y=this.$W,M=this.$M,m=this.$D,v=\"set\"+(this.$u?\"UTC\":\"\");switch(f){case h:return r?l(1,0):l(31,11);case c:return r?l(1,M):l(0,M+1);case o:var g=this.$locale().weekStart||0,D=(y<g?y+7:y)-g;return l(r?m-D:m+(6-D),M);case a:case d:return $(v+\"Hours\",0);case u:return $(v+\"Minutes\",1);case s:return $(v+\"Seconds\",2);case i:return $(v+\"Milliseconds\",3);default:return this.clone()}},m.endOf=function(t){return this.startOf(t,!1)},m.$set=function(t,e){var n,o=b.p(t),f=\"set\"+(this.$u?\"UTC\":\"\"),l=(n={},n[a]=f+\"Date\",n[d]=f+\"Date\",n[c]=f+\"Month\",n[h]=f+\"FullYear\",n[u]=f+\"Hours\",n[s]=f+\"Minutes\",n[i]=f+\"Seconds\",n[r]=f+\"Milliseconds\",n)[o],$=o===a?this.$D+(e-this.$W):e;if(o===c||o===h){var y=this.clone().set(d,1);y.$d[l]($),y.init(),this.$d=y.set(d,Math.min(this.$D,y.daysInMonth())).$d}else l&&this.$d[l]($);return this.init(),this},m.set=function(t,e){return this.clone().$set(t,e)},m.get=function(t){return this[b.p(t)]()},m.add=function(r,f){var d,l=this;r=Number(r);var $=b.p(f),y=function(t){var e=O(l);return b.w(e.date(e.date()+Math.round(t*r)),l)};if($===c)return this.set(c,this.$M+r);if($===h)return this.set(h,this.$y+r);if($===a)return y(1);if($===o)return y(7);var M=(d={},d[s]=e,d[u]=n,d[i]=t,d)[$]||1,m=this.$d.getTime()+r*M;return b.w(m,this)},m.subtract=function(t,e){return this.add(-1*t,e)},m.format=function(t){var e=this,n=this.$locale();if(!this.isValid())return n.invalidDate||l;var r=t||\"YYYY-MM-DDTHH:mm:ssZ\",i=b.z(this),s=this.$H,u=this.$m,a=this.$M,o=n.weekdays,c=n.months,f=n.meridiem,h=function(t,n,i,s){return t&&(t[n]||t(e,r))||i[n].slice(0,s)},d=function(t){return b.s(s%12||12,t,\"0\")},$=f||function(t,e,n){var r=t<12?\"AM\":\"PM\";return n?r.toLowerCase():r};return r.replace(y,(function(t,r){return r||function(t){switch(t){case\"YY\":return String(e.$y).slice(-2);case\"YYYY\":return b.s(e.$y,4,\"0\");case\"M\":return a+1;case\"MM\":return b.s(a+1,2,\"0\");case\"MMM\":return h(n.monthsShort,a,c,3);case\"MMMM\":return h(c,a);case\"D\":return e.$D;case\"DD\":return b.s(e.$D,2,\"0\");case\"d\":return String(e.$W);case\"dd\":return h(n.weekdaysMin,e.$W,o,2);case\"ddd\":return h(n.weekdaysShort,e.$W,o,3);case\"dddd\":return o[e.$W];case\"H\":return String(s);case\"HH\":return b.s(s,2,\"0\");case\"h\":return d(1);case\"hh\":return d(2);case\"a\":return $(s,u,!0);case\"A\":return $(s,u,!1);case\"m\":return String(u);case\"mm\":return b.s(u,2,\"0\");case\"s\":return String(e.$s);case\"ss\":return b.s(e.$s,2,\"0\");case\"SSS\":return b.s(e.$ms,3,\"0\");case\"Z\":return i}return null}(t)||i.replace(\":\",\"\")}))},m.utcOffset=function(){return 15*-Math.round(this.$d.getTimezoneOffset()/15)},m.diff=function(r,d,l){var $,y=this,M=b.p(d),m=O(r),v=(m.utcOffset()-this.utcOffset())*e,g=this-m,D=function(){return b.m(y,m)};switch(M){case h:$=D()/12;break;case c:$=D();break;case f:$=D()/3;break;case o:$=(g-v)/6048e5;break;case a:$=(g-v)/864e5;break;case u:$=g/n;break;case s:$=g/e;break;case i:$=g/t;break;default:$=g}return l?$:b.a($)},m.daysInMonth=function(){return this.endOf(c).$D},m.$locale=function(){return D[this.$L]},m.locale=function(t,e){if(!t)return this.$L;var n=this.clone(),r=w(t,e,!0);return r&&(n.$L=r),n},m.clone=function(){return b.w(this.$d,this)},m.toDate=function(){return new Date(this.valueOf())},m.toJSON=function(){return this.isValid()?this.toISOString():null},m.toISOString=function(){return this.$d.toISOString()},m.toString=function(){return this.$d.toUTCString()},M}(),k=_.prototype;return O.prototype=k,[[\"$ms\",r],[\"$s\",i],[\"$m\",s],[\"$H\",u],[\"$W\",a],[\"$M\",c],[\"$y\",h],[\"$D\",d]].forEach((function(t){k[t[1]]=function(e){return this.$g(e,t[0],t[1])}})),O.extend=function(t,e){return t.$i||(t(e,_,O),t.$i=!0),O},O.locale=w,O.isDayjs=S,O.unix=function(t){return O(1e3*t)},O.en=D[g],O.Ls=D,O.p={},O}));","import { lineString, lineToPolygon, point, rhumbDestination, transformRotate } from '@turf/turf'\nimport dayjs from 'dayjs'\nimport type * as GeoJSON from 'geojson'\nimport type { LngLat, Map } from 'mapbox-gl'\nimport { Point } from 'mapbox-gl'\n\nimport { Tooltip } from '@/core/Tooltip/index.ts'\nimport { BaseShip } from '@/modules/Ship/BaseShip.ts'\nimport { LAYER_LIST, NAME, SHIP_SOURCE_NAME, UPDATE_STATUS } from '@/modules/Ship/vars.ts'\nimport type { IAisShipOptions } from '@/types/Ship/AisShip.ts'\nimport type { Orientation, Shape } from '@/types/Ship/BaseShip'\nimport { distanceToPx, pixelsToMeters } from '@/utils/util.ts'\n\nexport class AisShip extends BaseShip<IAisShipOptions> {\n override readonly SOURCE: string = SHIP_SOURCE_NAME\n static override NAME: string = NAME\n\n constructor(map: Map, options: IAisShipOptions) {\n super(map, options)\n\n if (this.options.tooltip) {\n this.setTooltip(\n new Tooltip(this.context.map, {\n id: this.id,\n position: this.position(),\n className: 'mapbox-gl-ship-name-tooltip',\n offsetX: 5,\n offsetY: 25,\n element: this.label(),\n anchor: 'bottom-right',\n line: true,\n visible: false,\n }),\n )\n }\n }\n\n public override onAdd(): void {\n this.context.register.addSource(SHIP_SOURCE_NAME, {\n type: 'geojson',\n // dynamic: true,\n data: {\n type: 'FeatureCollection',\n features: [],\n },\n })\n\n LAYER_LIST.forEach((layer) => {\n this.context.register.addLayer(layer)\n })\n\n // SHIP_ICON.forEach((icon) => this.context.iconManage.addSvg(icon))\n // await this.context.iconManage.load(SHIP_ICON)\n }\n public override onRemove(): void {\n throw new Error('Method not implemented.')\n }\n\n override get id(): string | number {\n return this.options.id\n }\n\n override get updateStatus(): UPDATE_STATUS {\n const betweenTime = Date.now() - dayjs(Number(this.options.time)).valueOf()\n if (betweenTime <= 1800000) {\n return UPDATE_STATUS.ONLINE\n } else if (betweenTime > 1800000 && betweenTime <= 7200000) {\n return UPDATE_STATUS.DELAY\n } else if (betweenTime > 7200000) {\n return UPDATE_STATUS.OFFLINE\n } else {\n return UPDATE_STATUS.OFFLINE\n }\n }\n\n public override getIconName(): string {\n const state = this.getState()\n let icon\n\n if (this.options.icon) {\n icon = this.options.icon\n } else {\n icon = `${AisShip.NAME}-${this.updateStatus}`\n\n if (state?.hover || state?.focus) {\n icon = `${icon}-active`\n }\n }\n\n return icon\n }\n\n override position(): LngLat {\n const orientation: Point = this.context.map.project(this.options.position)\n const x = orientation.x + this.offset().x\n const y = orientation.y + this.offset().y\n return this.context.map.unproject(new Point(x, y))\n }\n\n override get direction(): number {\n // AIS 标准:511 代表无效值\n const HDG_INVALID = 511\n\n // 1. 优先使用 艏向 (HDG)\n // 只有当 hdg 不等于 511,且在 0-360 范围内时才使用\n if (this.options.hdg !== HDG_INVALID && this.options.hdg > 0 && this.options.hdg < 360) {\n return this.options.hdg\n }\n\n // 2. 降级使用 航迹向 (COG)\n // COG 有时会是 360,也代表正北,或者有些设备无效时也是 360+\n if (\n this.options.cog > 0 &&\n this.options.cog < 360 // 360 在某些协议里也可能代表未知,通常取 [0, 360)\n ) {\n return this.options.cog\n }\n\n // 3. 实在没有数据,默认正北\n return 0\n // if (this.options.hdg && this.options.hdg >= 0 && this.options.hdg < 360) {\n // if (\n // this.options.statusId === 0 ||\n // this.options.statusId === 7 ||\n // this.options.statusId === 8\n // ) {\n // if (this.options.speed <= 0.5) {\n // return this.options.hdg || this.options.cog || 0\n // } else {\n // if (Math.abs(this.options.hdg - this.options.cog) > 30) {\n // return this.options.cog\n // }\n // return this.options.cog || this.options.hdg || 0\n // }\n // } else {\n // return this.options.hdg || this.options.cog || 0\n // }\n // } else {\n // return this.options.cog || 0\n // }\n }\n\n override get orientation(): Orientation {\n const SPEED_THRESHOLD = 0.5\n const ROT_NOT_AVAILABLE = -128\n\n if (this.options.speed < SPEED_THRESHOLD) {\n return 'static'\n }\n\n if (this.options.rot === ROT_NOT_AVAILABLE || this.options.rot === 0) {\n return 'straight'\n }\n\n if (this.options.rot > 0) {\n return 'right'\n }\n\n if (this.options.rot < 0) {\n return 'left'\n }\n\n return 'straight'\n }\n\n override getShape(): Shape | null {\n if (this.options.width && this.options.height) {\n const { x, y }: Point = this.context.map.project(this.position())\n const ex: number = distanceToPx(this.context.map, this.options.width) / 2\n const ey: number = distanceToPx(this.context.map, this.options.height) / 2\n\n return {\n leftDirection: new Point(x - ex, y - ey * 2),\n rightDirection: new Point(x + ex, y - ey * 2),\n turn: new Point(x, y - ey - this.options.speed * 3),\n head: new Point(x, y - ey),\n rightBow: new Point(x + ex, y - ey * 0.5),\n rightQuarter: new Point(x + ex, y + ey * 0.85),\n rightStern: new Point(x + ex * 0.7, y + ey),\n leftStern: new Point(x - ex * 0.7, y + ey),\n leftQuarter: new Point(x - ex, y + ey * 0.85),\n leftBow: new Point(x - ex, y - ey * 0.5),\n }\n } else {\n return null\n }\n }\n\n override getFeature():\n | GeoJSON.Feature<GeoJSON.Polygon, IAisShipOptions>\n | GeoJSON.Feature<GeoJSON.Point, IAisShipOptions> {\n const zoom = this.options.realZoom ?? 16\n\n if (this.context.map.getZoom() >= zoom) {\n return this.real()\n } else {\n return this.icon()\n }\n }\n override remove(): void {\n this.removeTooltip()\n\n if (this.isFocus) {\n this.unfocus()\n this.context.focus.remove(String(this.id))\n }\n\n const emptyFeature: GeoJSON.Feature<null> = {\n type: 'Feature',\n geometry: null,\n id: this.id,\n properties: {},\n }\n\n const emptyDirLineFeature: GeoJSON.Feature<null> = {\n type: 'Feature',\n geometry: null,\n id: String(this.id) + '-direction-line',\n properties: {},\n }\n this.context.register.setGeoJSONData(this.SOURCE, [emptyFeature, emptyDirLineFeature])\n\n this.context.map.triggerRepaint()\n }\n override setTooltip(tooltip: Tooltip): void {\n this.tooltip = tooltip\n }\n\n override removeTooltip(): void {\n this.tooltip?.remove()\n this.tooltip = null\n }\n\n override update(options: IAisShipOptions): void {\n this.options = options\n this.render()\n }\n\n override select(): void {\n this.context.map.flyTo({\n center: this.position(),\n zoom: 16,\n })\n\n this.context.map.once('moveend', () => {\n this.focus()\n })\n }\n override unselect(): void {\n this.unfocus()\n }\n\n override focus(): void {\n this.setState({ focus: true })\n\n this.render()\n }\n override unfocus(): void {\n this.setState({ focus: false })\n\n this.render()\n }\n override icon(): GeoJSON.Feature<GeoJSON.Point, IAisShipOptions> {\n return point<IAisShipOptions>(\n this.position().toArray(),\n {\n ...this.options,\n id: this.options.id,\n icon: this.getIconName(),\n direction: this.direction,\n updateStatus: this.updateStatus,\n },\n {\n id: this.id,\n },\n )\n }\n override real():\n | GeoJSON.Feature<GeoJSON.Polygon, IAisShipOptions>\n | GeoJSON.Feature<GeoJSON.Point, IAisShipOptions> {\n const shape = this.getShape()\n\n if (!shape) {\n return this.icon()\n } else {\n const {\n head,\n rightBow,\n rightQuarter,\n rightStern,\n leftStern,\n leftQuarter,\n leftBow,\n leftDirection,\n rightDirection,\n turn,\n } = shape\n let points: Point[] = [\n head,\n rightBow,\n rightQuarter,\n rightStern,\n leftStern,\n leftQuarter,\n leftBow,\n head,\n ]\n\n if (this.orientation === 'left') {\n points = [leftDirection, turn, ...points, turn, leftDirection]\n } else if (this.orientation === 'right') {\n points = [rightDirection, turn, ...points, turn, rightDirection]\n } else if (this.orientation === 'straight') {\n points = [turn, ...points, turn]\n }\n\n const line: GeoJSON.Feature<GeoJSON.LineString, IAisShipOptions> =\n lineString<IAisShipOptions>(\n points.map((item) => this.context.map.unproject(item).toArray()),\n )\n\n let ship: GeoJSON.Feature<GeoJSON.Polygon, IAisShipOptions> = lineToPolygon(line, {\n properties: {\n ...this.options,\n id: this.options.id,\n updateStatus: this.updateStatus,\n outLine: true,\n },\n }) as GeoJSON.Feature<GeoJSON.Polygon, IAisShipOptions>\n\n ship = transformRotate<GeoJSON.Feature<GeoJSON.Polygon>>(ship, this.direction, {\n pivot: this.position().toArray(),\n }) as GeoJSON.Feature<GeoJSON.Polygon, IAisShipOptions>\n\n ship.id = this.id\n return ship\n }\n }\n\n override headingLine(): GeoJSON.Feature<\n GeoJSON.LineString | null,\n { meta: 'directionLine'; 'line-color': string }\n > {\n const head = rhumbDestination(\n this.position().toArray(),\n // pixelsToMeters(this.context.map, this.position().toArray()[1], this.options.speed * 92.52),\n this.options.speed * 92.52,\n this.direction,\n {\n units: 'meters',\n },\n )\n\n const path: GeoJSON.Position[] = []\n if (this.orientation === 'left') {\n const turn = rhumbDestination(\n head,\n pixelsToMeters(this.context.map, this.position().toArray()[1], 10),\n this.direction - 90,\n {\n units: 'meters',\n },\n )\n path.push(this.position().toArray(), head.geometry.coordinates, turn.geometry.coordinates)\n } else if (this.orientation === 'right') {\n const turn = rhumbDestination(\n head,\n pixelsToMeters(this.context.map, this.position().toArray()[1], 10),\n this.direction + 90,\n {\n units: 'meters',\n },\n )\n path.push(this.position().toArray(), head.geometry.coordinates, turn.geometry.coordinates)\n } else if (this.orientation === 'straight') {\n path.push(this.position().toArray(), head.geometry.coordinates)\n }\n\n if (path.length === 0)\n return {\n type: 'Feature',\n geometry: null,\n id: String(this.id) + '-direction-line',\n properties: {\n meta: 'directionLine',\n 'line-color': '#f00',\n },\n }\n\n return lineString(\n path,\n {\n meta: 'directionLine',\n 'line-color': this.isFocus || this.isHover ? '#f00' : '#000',\n },\n { id: String(this.id) + '-direction-line' },\n )\n }\n\n override render(): void {\n const bounds = this.context.map.getBounds()\n if (!bounds?.contains(this.position())) {\n this.tooltip?.hide()\n return\n }\n\n this.tooltip?.render()\n\n this.context.register.setGeoJSONData(this.SOURCE, [this.headingLine(), this.getFeature()])\n\n if (this.isFocus) {\n const icon = this.context.iconManage.getImage(this.getIconName())\n this.context.focus.set(this.getFeature(), {\n size: icon?.width,\n armLength: 10,\n padding: 10,\n })\n } else {\n this.context.focus.remove(String(this.id))\n }\n }\n override label(): HTMLElement {\n const id = `${String(this.id)}-ship-name-box`\n let shipNameBox = document.getElementById(id)\n if (shipNameBox) {\n return shipNameBox\n }\n\n shipNameBox = document.createElement('div')\n shipNameBox.id = id\n shipNameBox.classList.add('ship-name-box')\n\n const shipName = document.createElement('div')\n shipName.innerText = this.options.name\n shipName.classList.add('ship-name')\n\n shipNameBox.appendChild(shipName)\n\n return shipNameBox\n }\n override offset(): Point {\n const offset = new Point(0, 0)\n\n if (this.options.top && this.options.bottom && this.options.left && this.options.right) {\n const ey = distanceToPx(\n this.context.map,\n Math.abs(this.options.top - this.options.bottom) / 2,\n )\n const ex = distanceToPx(\n this.context.map,\n Math.abs(this.options.left - this.options.right) / 2,\n )\n\n offset.x = this.options.right > this.options.left ? ex : -ex\n offset.y = this.options.top > this.options.bottom ? ey : -ey\n }\n\n return offset\n }\n}\n","import type { LngLat } from 'mapbox-gl'\n\nexport interface ITrackOptions {\n startLabel: string\n endLabel: string\n}\n\nexport interface TrackItem {\n id: string\n pId: string\n index: number\n position: LngLat\n cog?: number\n sog?: number\n time: Date\n props?: Record<string, any>\n}\n\nexport interface TrackItemWithLabel extends TrackItem {\n type: TooltipType\n visible: boolean\n}\n\nexport enum TooltipType {\n START_END = 0, // 起终点 (最高)\n SHARP_TURN = 1, // 急转弯\n STOP_GO = 2, // 启停变化\n TIME_ANCHOR = 3, // 时间锚点\n NORMAL = 9, // 普通点\n}\n","import type { LayerSpecification } from 'mapbox-gl'\n\nimport type { SortLayer } from '@/core/ResourceRegister'\n\nexport const NAME = 'Track'\n\nexport const Z_INDEX = 290\n\nexport const TRACK_SOURCE_NAME = 'mapbox-gl-track-source'\n\nexport const TRACK_ARROW_LAYER_NAME = 'mapbox-gl-track-arrow-layer'\n\nexport const TRACK_ICON_LAYER_NAME = 'mapbox-gl-track-icon-layer'\n\nexport const TRACK_LINE_LAYER_NAME = 'mapbox-gl-track-line-layer'\n\nexport const START_ICON_NAME = 'track-start'\n\nexport const START_ICON =\n '<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"74\" height=\"74\" viewBox=\"0 0 74 74\" fill=\"none\"><circle cx=\"37\" cy=\"37\" r=\"32\" stroke=\"rgba(172, 51, 193, 1)\" stroke-width=\"10\" fill=\"#AC33C1\" ></circle><path d=\"M36.4 50.84C40.84 51.08 45.24 51.08 45.24 51.08C50.52 51.08 55.12 50.8 55.12 50.8L54.48 54.36C50.16 54.64 45.24 54.64 45.24 54.64C40.32 54.64 35.96 54.36 35.96 54.36C31.16 54.08 28.16 52.72 28.16 52.72C25.16 51.36 23.4 48.36 23.4 48.36C22.64 51.96 20.84 55.72 20.84 55.72L18 53.52C19.16 51.04 19.76 48.94 19.76 48.94C20.36 46.84 20.62 44.26 20.62 44.26C20.88 41.68 20.88 37.64 20.88 37.64L24.2 37.64C24.2 40.92 24.04 43.12 24.04 43.12C25.16 46.52 27.28 48.24 27.28 48.24L27.28 35.44L18.68 35.44L18.68 32.08L26.32 32.08L26.32 27.12L20.08 27.12L20.08 23.72L26.32 23.72L26.32 19L29.84 19L29.84 23.72L35.64 23.72L35.64 27.12L29.84 27.12L29.84 32.08L36.76 32.08L36.76 35.44L30.72 35.44L30.72 40.96L36.36 40.96L36.36 44.32L30.72 44.32L30.72 49.96C33 50.64 36.4 50.84 36.4 50.84ZM48.96 30.88L48.96 24.64L37.8 24.64L37.8 21.12L52.44 21.12L52.44 34.4L41.84 34.4L41.84 41.52C41.84 42.72 42.02 43.24 42.02 43.24C42.2 43.76 42.68 43.98 42.68 43.98C43.16 44.2 44.28 44.32 44.28 44.32C44.88 44.36 46 44.36 46 44.36C47.12 44.36 47.72 44.32 47.72 44.32C48.88 44.2 49.44 43.98 49.44 43.98C50 43.76 50.22 43.28 50.22 43.28C50.44 42.8 50.52 41.8 50.52 41.8C50.68 39.72 50.68 38.44 50.68 38.44L54.08 39.24C53.96 41.12 53.8 43 53.8 43C53.6 45.04 53.16 45.98 53.16 45.98C52.72 46.92 51.72 47.3 51.72 47.3C50.72 47.68 48.64 47.8 48.64 47.8C46.8 47.88 45.88 47.88 45.88 47.88C44.96 47.88 43.12 47.8 43.12 47.8C41.2 47.68 40.22 47.2 40.22 47.2C39.24 46.72 38.8 45.64 38.8 45.64C38.36 44.56 38.36 42.44 38.36 42.44L38.36 30.88L48.96 30.88Z\" fill=\"#FFFFFF\" ></path></svg>'\n\nexport const END_ICON_NAME = 'track-end'\n\nexport const END_ICON =\n '<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"74\" height=\"74\" viewBox=\"0 0 74 74\" fill=\"none\"><circle cx=\"37\" cy=\"37\" r=\"32\" stroke=\"rgba(172, 51, 193, 1)\" stroke-width=\"10\" fill=\"#AC33C1\" ></circle><path d=\"M45.6 33.64C49.28 36.12 55.28 38.24 55.28 38.24L54 41.8C50.48 40.32 47.78 38.88 47.78 38.88C45.08 37.44 42.92 35.8 42.92 35.8C38.76 38.84 32.04 41.6 32.04 41.6L30.4 38.4C36.28 36.2 40.24 33.56 40.24 33.56C38.2 31.6 36.12 28.8 36.12 28.8C34.56 30.92 32.68 32.88 32.68 32.88L30.72 30.36C32.88 28.08 35.08 24.52 35.08 24.52C37.28 20.96 38.4 18 38.4 18L41.64 18.92C41.2 19.96 40.24 22.04 40.24 22.04L52.04 22.04L52.04 25.48C50.56 27.96 49.02 29.96 49.02 29.96C47.48 31.96 45.6 33.64 45.6 33.64ZM20.76 33.44C19.96 33.48 19 33.76 19 33.76L18.2 30.24C18.72 30.04 18.98 29.82 18.98 29.82C19.24 29.6 19.56 29.2 19.56 29.2C20.44 28 22.06 24.68 22.06 24.68C23.68 21.36 24.92 18.2 24.92 18.2L28.04 19.4C26.8 22.28 25.24 25.4 25.24 25.4C23.68 28.52 22.6 30.04 22.6 30.04C25.92 29.56 26.76 29.44 26.76 29.44C28.16 26.68 29.28 24.16 29.28 24.16L32.16 25.52C30.52 28.92 28.16 33.22 28.16 33.22C25.8 37.52 24.4 39.48 24.4 39.48L27.36 38.76L29.76 38.16L29.84 41.68C29.28 41.72 26.86 42.2 26.86 42.2C24.44 42.68 22.52 43.08 22.52 43.08C21.96 43.2 20.84 43.52 20.84 43.52L19.92 43.76L19.08 40.12C19.96 39.76 20.34 39.48 20.34 39.48C20.72 39.2 21.2 38.64 21.2 38.64C22.84 36.6 24.92 32.84 24.92 32.84C22.24 33.28 20.76 33.44 20.76 33.44ZM38.08 25.92C40.2 29.2 42.88 31.52 42.88 31.52C45.56 29.16 48.12 25.4 48.12 25.4L38.4 25.4L38.08 25.92ZM37.6 39.4L40.8 40.4L49.4 43.08L48.12 46.52C45.76 45.68 42.22 44.5 42.22 44.5C38.68 43.32 36.64 42.76 36.64 42.76L37.6 39.4ZM18 49.08C18.68 48.96 21.08 48.4 21.08 48.4C23.48 47.84 25.2 47.44 25.2 47.44C30.76 46.2 31.08 46.12 31.08 46.12L31.28 49.6C30.12 49.8 22.24 51.6 22.24 51.6C18.8 52.44 18.48 52.48 18.48 52.48L18 49.08ZM34.4 46.48C37.24 47.24 42.46 48.82 42.46 48.82C47.68 50.4 51.12 51.52 51.12 51.52L49.92 55.04C46.44 53.8 41.38 52.2 41.38 52.2C36.32 50.6 33.44 49.84 33.44 49.84L34.4 46.48Z\" fill=\"#FFFFFF\" ></path></svg>'\n\nexport const ARROW_ICON_NAME = 'track-arrow'\n\nexport const NORMAL_ICON =\n '<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"74\" height=\"74\" viewBox=\"0 0 74 74\" fill=\"none\"><circle cx=\"37\" cy=\"37\" r=\"32\" stroke=\"rgba(172, 51, 193, 1)\" stroke-width=\"10\" fill=\"#FFFFFF\" ></circle></svg>'\n\nexport const NORMAL_ICON_NAME = 'track-normal'\n\nexport const ARROW_ICON =\n '<svg t=\"1769503360247\" class=\"icon\" viewBox=\"0 0 1024 1024\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\" p-id=\"24046\" width=\"64\" height=\"64\"><path d=\"M509.093 894.223l-447.093-761.539 452.861 219.23099999 447.139-222.13799999z\" p-id=\"24047\" fill=\"#d81e06\"></path></svg>'\n\nexport const TRACK_ARROW_LAYER: LayerSpecification = {\n id: TRACK_ARROW_LAYER_NAME,\n source: TRACK_SOURCE_NAME,\n type: 'symbol',\n layout: {\n 'symbol-placement': 'line',\n 'symbol-spacing': 250, // 图标间隔,默认为250\n 'icon-image': ARROW_ICON_NAME, // 箭头图标\n 'icon-size': 0.3,\n 'icon-rotate': -90,\n 'icon-allow-overlap': true, // 开启避让\n },\n paint: {},\n}\n\nexport const TRACK_ICON_LAYER: LayerSpecification = {\n id: TRACK_ICON_LAYER_NAME,\n source: TRACK_SOURCE_NAME,\n type: 'symbol',\n filter: ['==', '$type', 'Point'],\n layout: {\n 'icon-image': ['get', 'icon'],\n 'icon-size': ['get', 'iconSize'],\n 'icon-allow-overlap': false, // 开启避让\n 'symbol-sort-key': ['get', 'type'], // 权重排序\n },\n}\n\nexport const TRACK_LINE_LAYER: LayerSpecification = {\n id: TRACK_LINE_LAYER_NAME,\n source: TRACK_SOURCE_NAME,\n type: 'line',\n filter: ['all', ['==', '$type', 'LineString']],\n paint: {\n 'line-color': '#f00',\n 'line-width': 3,\n },\n layout: {},\n}\n\nexport const LAYER_LIST: SortLayer[] = [\n {\n layer: TRACK_LINE_LAYER,\n zIndex: Z_INDEX,\n },\n {\n layer: TRACK_ARROW_LAYER,\n zIndex: Z_INDEX,\n },\n {\n layer: TRACK_ICON_LAYER,\n zIndex: Z_INDEX,\n },\n]\n","import { bearing, lineString, point } from '@turf/turf'\nimport dayjs from 'dayjs'\nimport type * as GeoJSON from 'geojson'\nimport type { Map as MapboxglMap, MapMouseEvent, PointLike } from 'mapbox-gl'\nimport { LngLat } from 'mapbox-gl'\n\nimport Collision from '@/core/Collision'\nimport { EventState } from '@/core/EventState'\nimport { Module } from '@/core/Module'\nimport { Tooltip } from '@/core/Tooltip'\nimport type { CollisionItemOptions } from '@/types/Collision/item.ts'\nimport type { ITrackOptions, TrackItem, TrackItemWithLabel } from '@/types/Track'\nimport { TooltipType } from '@/types/Track'\n\nimport {\n ARROW_ICON,\n ARROW_ICON_NAME,\n END_ICON,\n END_ICON_NAME,\n LAYER_LIST,\n NORMAL_ICON,\n NORMAL_ICON_NAME,\n START_ICON,\n START_ICON_NAME,\n TRACK_ICON_LAYER_NAME,\n TRACK_SOURCE_NAME,\n} from './vars.ts'\n\nexport class TrackEvent extends EventState {\n protected hoverId: string | null | undefined = null\n protected hoverPointId: string | null | undefined = null\n protected track: Track\n\n protected _move: (e: MapMouseEvent) => void = (): void => {\n /* empty */\n }\n protected _leave: OmitThisParameter<(e: MapMouseEvent) => void> = (): void => {\n /* empty */\n }\n protected _moveEnd = (): void => {\n /* empty */\n }\n\n constructor(map: MapboxglMap, track: Track) {\n super(map)\n\n this.track = track\n }\n\n public override disabled(): void {\n this.context.map.off('mousemove', TRACK_ICON_LAYER_NAME, this._move)\n this.context.map.off('mouseleave', TRACK_ICON_LAYER_NAME, this._leave)\n this.context.map.off('moveend', this._moveEnd)\n }\n\n public override enabled(): void {\n this.context.map.on('mousemove', TRACK_ICON_LAYER_NAME, this._move)\n this.context.map.on('mouseleave', TRACK_ICON_LAYER_NAME, this._leave)\n this.context.map.on('moveend', this._moveEnd)\n }\n\n onAdd(): void {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-assignment\n this._move = this.onMove.bind(this) as any\n this._leave = this.onLeave.bind(this)\n this._moveEnd = this.onMoveEnd.bind(this)\n\n this.enabled()\n }\n\n onRemove(): void {\n this.disabled()\n }\n\n onMoveEnd(): void {\n this.track.render()\n }\n\n onMove(\n e: MapMouseEvent & {\n features?: GeoJSON.Feature<GeoJSON.Geometry, { id: string; pId: string }>[]\n },\n ): void {\n if (e.features?.length) {\n this.context.map.getCanvasContainer().style.cursor = 'pointer'\n\n if (this.hoverId === (e.features[0].id ?? e.features[0].properties.id)) return\n\n if (this.hoverId) {\n this.unhover()\n }\n\n this.hoverId = (e.features[0].id ?? e.features[0].properties.id) as string\n this.hoverPointId = e.features[0].properties.pId\n this.hover()\n }\n }\n\n onLeave(): void {\n this.unhover()\n this.hoverId = null\n this.hoverPointId = null\n this.context.map.getCanvasContainer().style.cursor = ''\n }\n\n hover(): void {\n if (!this.hoverId) return\n\n const tracks = this.track.trackData.get(this.hoverId)\n const track = tracks?.find((item) => item.pId === this.hoverPointId)\n\n const eventName = 'track-hover'\n this.context.events.emit(eventName, track)\n this.context.map.fire(eventName, track)\n }\n\n unhover(): void {\n if (!this.hoverId) return\n\n const tracks = this.track.trackData.get(this.hoverId)\n const track = tracks?.find((item) => item.pId === this.hoverPointId)\n\n const eventName = 'track-unhover'\n this.context.events.emit(eventName, track)\n this.context.map.fire(eventName, track)\n }\n}\n\nexport class Track extends Module {\n public options: ITrackOptions\n public trackData = new Map<TrackItem['id'], TrackItemWithLabel[]>()\n private tooltips: Tooltip[] = []\n private collision: Collision\n private event: TrackEvent\n\n constructor(map: MapboxglMap, options: ITrackOptions) {\n super(map)\n\n this.options = options\n this.collision = new Collision(map)\n this.event = new TrackEvent(map, this)\n }\n\n override onAdd(): void {\n this.context.register.addSource(TRACK_SOURCE_NAME, {\n type: 'geojson',\n dynamic: true,\n data: {\n type: 'FeatureCollection',\n features: [],\n },\n })\n\n LAYER_LIST.forEach((layer) => {\n this.context.register.addLayer(layer)\n })\n\n this.context.iconManage.loadSvg([\n {\n name: START_ICON_NAME,\n svg: START_ICON,\n },\n {\n name: END_ICON_NAME,\n svg: END_ICON,\n },\n {\n name: ARROW_ICON_NAME,\n svg: ARROW_ICON,\n },\n {\n name: NORMAL_ICON_NAME,\n svg: NORMAL_ICON,\n },\n ])\n }\n\n override onRemove(): void {\n this.event.disabled()\n }\n\n load(items: TrackItem[]): void {\n const id = items[0].id\n\n // 按照时间升序排列\n const sorts = items\n .filter((item) => item.id === id)\n .sort((a, b) => a.time.getTime() - b.time.getTime())\n\n this.trackData.set(id, this.markItem(sorts))\n }\n\n remove(): void {\n this.removeAllTooltip()\n this.event.disabled()\n this.context.register.setGeoJSONData(TRACK_SOURCE_NAME, this.getFeature())\n }\n\n private markItem(items: TrackItem[]): TrackItemWithLabel[] {\n if (items.length === 0) return []\n\n const result: TrackItemWithLabel[] = items.map((item) => ({\n ...item,\n visible: true,\n type: TooltipType.NORMAL,\n }))\n\n result[0].type = TooltipType.START_END\n result[result.length - 1].type = TooltipType.START_END\n\n let lastTimeAnchor = result[0].time.getTime()\n\n for (let i = 1; i < result.length - 1; i++) {\n const prev = result[i - 1]\n const cur = result[i]\n const next = result[i + 1]\n\n // 2. 计算航向变化\n\n let prevCog = prev.cog\n prevCog ??= bearing(prev.position.toArray(), cur.position.toArray())\n\n let curCog = cur.cog\n curCog ??= bearing(cur.position.toArray(), next.position.toArray())\n\n const angleDiff = Math.abs(curCog - prevCog)\n const normalizedDiff = angleDiff > 180 ? 360 - angleDiff : angleDiff\n\n // 3. 标记急转弯 (> 25度)\n if (normalizedDiff > 25) {\n cur.type = Math.min(cur.type, TooltipType.SHARP_TURN)\n }\n\n // 4. 标记启停变化 (速度 < 0.5 视为静止)\n const isPrevStopped = prevCog < 0.5\n const isCurrStopped = curCog < 0.5\n if (isPrevStopped !== isCurrStopped) {\n cur.type = Math.min(cur.type, TooltipType.STOP_GO)\n }\n\n // 5. 标记时间锚点 (例如:距离上一个标记点超过 30 分钟)\n // 只有当它不是其他重要类型时才标记,避免冗余\n if (cur.type === TooltipType.NORMAL) {\n const timeDiff = cur.time.getTime() - lastTimeAnchor\n // 30分钟 = 1800000ms\n if (timeDiff > 1800000) {\n cur.type = TooltipType.TIME_ANCHOR\n lastTimeAnchor = cur.time.getTime()\n }\n } else {\n // 如果当前已经是重要点位,重置时间锚点计时\n lastTimeAnchor = cur.time.getTime()\n }\n }\n\n return result\n }\n\n private simplifyTrackBySlope(\n track: TrackItemWithLabel[],\n angleThreshold = 2,\n ): TrackItemWithLabel[] {\n if (track.length <= 2) return track\n\n const simplified: TrackItemWithLabel[] = [track[0]] // 始终保留起点\n let lastPoint = track[0]\n\n for (let i = 1; i < track.length - 1; i++) {\n const currentPoint = track[i]\n const nextPoint = track[i + 1]\n\n const bearing1 = bearing(lastPoint.position.toArray(), currentPoint.position.toArray())\n const bearing2 = bearing(currentPoint.position.toArray(), nextPoint.position.toArray())\n\n let diff = Math.abs(bearing1 - bearing2)\n if (diff > 180) diff = 360 - diff\n\n if (diff > angleThreshold) {\n simplified.push(currentPoint)\n lastPoint = currentPoint // 更新基准点\n }\n }\n\n simplified.push(track[track.length - 1])\n\n return simplified\n }\n\n private simplifyTrackByZoom(track: TrackItemWithLabel[], zoom: number): TrackItemWithLabel[] {\n let threshold = 0\n\n if (zoom < 8) threshold = 10\n else if (zoom < 10) threshold = 5\n else if (zoom < 13) threshold = 2\n else if (zoom < 16) threshold = 1\n else threshold = 0 // 高层级保留所有点\n\n if (threshold === 0 || track.length < 10) return track\n\n return this.simplifyTrackBySlope(track, threshold)\n }\n\n getFeature(): GeoJSON.Feature[] {\n const features: GeoJSON.Feature[] = []\n for (const id of this.trackData.keys()) {\n const items = this.trackData.get(id)\n if (items) {\n const list = this.simplifyTrackByZoom(items, this.context.map.getZoom())\n const sortedItems = [...list].sort((a, b) => a.time.getTime() - b.time.getTime())\n const length = sortedItems.length\n\n const coordinates = sortedItems.map((item) => item.position.toArray())\n const latestItem = sortedItems[length - 1]\n const properties = {\n id,\n startTime: sortedItems[0].time.getTime(), // 开始时间\n endTime: latestItem.time.getTime(), // 结束时间\n count: items.length, // 点数量\n }\n\n sortedItems.forEach((item, index) => {\n let icon = NORMAL_ICON_NAME\n let iconSize = 0.2\n if (index === 0) {\n icon = START_ICON_NAME\n iconSize = 0.4\n } else if (index === length - 1) {\n icon = END_ICON_NAME\n iconSize = 0.4\n }\n\n features.push(\n point(\n item.position.toArray(),\n {\n ...item,\n id: item.pId,\n icon,\n iconSize,\n isStartEnd: index === 0 || index === length - 1,\n time: new Date(item.time).getTime(),\n },\n { id: item.pId },\n ),\n )\n })\n\n features.push(lineString(coordinates, properties, { id }))\n }\n }\n\n return features\n }\n\n private collisionTooltip(): void {\n this.collision.load(this.createCollisions()).forEach((collision) => {\n const tooltip = this.tooltips.find((tooltip) => tooltip.id === collision.id)\n if (!tooltip) return\n\n if (collision.visible) {\n tooltip.setAnchor(collision.dir)\n } else {\n tooltip.hide()\n }\n })\n }\n\n private createCollisions(): CollisionItemOptions[] {\n return this.tooltips.map((tooltip) => {\n return {\n // ...tooltip.getSimpleBbox(),\n ...tooltip.getAllBbox(),\n id: tooltip.id,\n }\n })\n }\n\n private createTooltip(): void {\n const { width, height } = this.context.map.getCanvas()\n\n const viewportBBox: [PointLike, PointLike] = [\n [0, 0],\n [width, height],\n ]\n\n const f = this.context.map.queryRenderedFeatures(viewportBBox, {\n layers: [TRACK_ICON_LAYER_NAME],\n }) as unknown as GeoJSON.Feature<GeoJSON.Point, { time: string; pId: string }>[]\n\n if (f.length === 0) return\n\n const createLabel = (id: string, name: string): HTMLElement => {\n let shipNameBox = document.getElementById(id)\n if (shipNameBox) {\n return shipNameBox\n }\n\n shipNameBox = document.createElement('div')\n shipNameBox.id = `${id}-track-name-box`\n shipNameBox.classList.add('track-name-box')\n\n const shipName = document.createElement('div')\n shipName.innerText = name\n shipName.classList.add('track-name')\n\n shipNameBox.appendChild(shipName)\n\n return shipNameBox\n }\n\n this.tooltips = f.map(\n (item) =>\n new Tooltip(this.context.map, {\n id: item.properties.pId,\n position: new LngLat(item.geometry.coordinates[0], item.geometry.coordinates[1]),\n className: 'mapbox-gl-track-name-tooltip',\n offsetX: 5,\n offsetY: 25,\n element: createLabel(\n item.properties.pId,\n dayjs(Number(item.properties.time)).format('YYYY-MM-DD HH:mm:ss'),\n ),\n anchor: 'bottom-right',\n visible: false,\n }),\n )\n\n this.collisionTooltip()\n }\n\n private removeAllTooltip(): void {\n this.tooltips.forEach((tooltip) => {\n tooltip.remove()\n })\n\n this.tooltips = []\n this.collision.clear()\n }\n\n render(): void {\n this.removeAllTooltip()\n this.createTooltip()\n\n this.context.register.setGeoJSONData(TRACK_SOURCE_NAME, this.getFeature())\n }\n}\n"],"names":["isNull","val","Cache","options","name","content","cacheName","obj","cacheString","cacheObj","list","i","str","quickselect","arr","k","left","right","compare","defaultCompare","n","m","z","s","sd","newLeft","newRight","t","j","swap","tmp","a","b","RBush","maxEntries","bbox","node","result","intersects","toBBox","nodesToSearch","child","childBBox","contains","data","tmpNode","item","createNode","equalsFn","path","indexes","parent","goingUp","index","findItem","items","height","N","M","calcBBox","N2","N1","multiSelect","right2","right3","level","minArea","minEnlargement","targetNode","area","bboxArea","enlargement","enlargedArea","isNode","insertPath","extend","splitIndex","newNode","minOverlap","bbox1","distBBox","bbox2","overlap","intersectionArea","compareMinX","compareNodeMinX","compareMinY","compareNodeMinY","xMargin","yMargin","leftBBox","rightBBox","margin","bboxMargin","siblings","p","destNode","minX","minY","maxX","maxY","children","stack","mid","Scopes","CollisionItem","visible","dir","box","Collision","map","config","collisions","id","isCollides","cacheKey","RESULT_CODE","earthRadius","factors","feature","geom","properties","feat","point","coordinates","isNumber","polygon","ring","lineString","multiLineString","multiPolygon","radiansToLength","radians","units","factor","lengthToRadians","distance","radiansToDegrees","degreesToRadians","degrees","convertLength","length","originalUnit","finalUnit","num","isObject","input","getCoord","coord","getCoords","coords","getGeom","geojson","getType","_name","bearing","start","end","calculateFinalBearing","coordinates1","coordinates2","lon1","lon2","lat1","lat2","bear","destination","origin","longitude1","latitude1","bearingRad","latitude2","longitude2","lng","lat","from","to","dLat","dLon","along","line","travelled","overshot","direction","measureDistance","rhumbBearing","bear360","calculateRhumbBearing","phi1","phi2","deltaLambda","deltaPsi","theta","coordEach","callback","excludeWrapCoord","l","geometry","stopG","geometryMaybeCollection","wrapShrink","coordIndex","isGeometryCollection","type","isFeatureCollection","isFeature","stop","featureIndex","geomIndex","multiFeatureIndex","geometryIndex","geomType","geomEach","g","featureProperties","featureBBox","featureId","flattenEach","coordinate","segmentEach","feature2","segmentIndex","previousCoords","previousFeatureIndex","previousMultiIndex","prevGeomIndex","currentCoord","featureIndexCoord","multiPartIndexCoord","currentSegment","segmentReduce","initialValue","previousValue","started","bboxPolygon","west","south","east","north","lowLeft","epsilon","splitter","resulterrbound","sum","elen","e","flen","f","h","Q","Qnew","hh","bvirt","enow","fnow","eindex","findex","hindex","estimate","vec","ccwerrboundA","ccwerrboundB","ccwerrboundC","B","C1","C2","D","u","orient2dadapt","ax","ay","bx","by","cx","cy","detsum","acxtail","acytail","bcxtail","bcytail","c","ahi","alo","bhi","blo","_i","_j","_0","s1","s0","t1","t0","u3","acx","bcx","acy","bcy","det","errbound","C1len","C2len","Dlen","orient2d","detleft","detright","pointInPolygon","ii","u1","v1","u2","v2","currentP","nextP","x","y","numContours","contour","contourLen","booleanPointInPolygon","pt","polys","inBBox","polyResult","pip","centroid","xSum","ySum","len","module","this","r","o","d","v","TinyQueue$1","top","bottom","pos","current","halfLength","best","flat","vs","inside","xi","yi","xj","yj","intersect","nested","pointInPolygonFlat","require$$0","pointInPolygonNested","require$$1","pointInPolygonModule","exports","_","w","A","F","O","P","q","C","E","G","H","I","J","K","L","Queue","require$$2","orient","require$$3","concavemanModule","concaveman","points","concavity","lengthThreshold","hull","fastConvexHull","tree","queue","last","insertNode","segTree","updateBBox","sqConcavity","sqLenThreshold","sqLen","getSqDist","maxSqLen","findCandidate","concave","maxDist","compareDist","dist","sqSegDist","sqSegBoxDist","d0","d1","noIntersections","sqSegSegDist","d2","d3","d4","edges","cross","p1","p2","p3","q1","q2","cull","filtered","convexHull","prev","dx","dy","x0","y0","x1","y1","x2","y2","x3","y3","ux","uy","vx","vy","wx","wy","sc","sN","tc","tN","sD","tD","cx2","cy2","compareByX","lower","upper","convex","centerOfMass","centre","translation","sx","sy","sArea","pi","pj","neutralizedPoints","point2","areaFactor","clone","cloneFeature","cloneFeatureCollection","cloneGeometry","cloned","key","cloneProperties","value","deepSlice","rhumbDistance","distanceInMeters","calculateRhumbDistance","radius","R","DeltaPhi","DeltaLambda","DeltaPsi","rhumbDestination","wasNegativeDistance","calculateRhumbDestination","delta","lambda1","transformRotate","angle","pivot","mutate","pivotCoord","pointCoords","finalAngle","newCoords","segment","lineToPolygon","lines","_a","_b","_c","autoComplete","orderCoords","lineStringToPolygon","autoCompleteCoords","multiCoords","largestArea","calculateArea","turfBBox","first","distanceToPx","latitude","zoom","latRad","metersPerPixel","convertSvgToImageObjects","svgString","width","svgImage","svgStr","resolve","reject","blob","url","img","event","outputWidth","outputHeight","canvas","ctx","bitmap","imageData","pixelsToMeters","pixels","metersPerPx","IconManager","icons","results","icon","success","error","loadTask","err","image","has","prefix","Events","EE","fn","context","once","addListener","emitter","listener","evt","clearEvent","EventEmitter","names","events","handlers","ee","listeners","a1","a2","a3","a4","a5","args","EventManager","layerId","eventType","instanceEvents","callbacks","idx","handler","targetId","hoverId","rawId","sep","freeGlobal","freeSelf","root","Symbol","objectProto","hasOwnProperty","nativeObjectToString","symToStringTag","getRawTag","isOwn","tag","unmasked","objectToString","nullTag","undefinedTag","baseGetTag","isObjectLike","symbolTag","isSymbol","arrayMap","array","iteratee","isArray","symbolProto","symbolToString","baseToString","asyncTag","funcTag","genTag","proxyTag","isFunction","coreJsData","maskSrcKey","uid","isMasked","func","funcProto","funcToString","toSource","reRegExpChar","reIsHostCtor","reIsNative","baseIsNative","pattern","getValue","object","getNative","WeakMap","objectCreate","baseCreate","proto","defineProperty","arrayEach","MAX_SAFE_INTEGER","reIsUint","isIndex","baseAssignValue","eq","other","assignValue","objValue","isLength","isArrayLike","isPrototype","Ctor","baseTimes","argsTag","baseIsArguments","propertyIsEnumerable","isArguments","stubFalse","freeExports","freeModule","moduleExports","Buffer","nativeIsBuffer","isBuffer","arrayTag","boolTag","dateTag","errorTag","mapTag","numberTag","objectTag","regexpTag","setTag","stringTag","weakMapTag","arrayBufferTag","dataViewTag","float32Tag","float64Tag","int8Tag","int16Tag","int32Tag","uint8Tag","uint8ClampedTag","uint16Tag","uint32Tag","typedArrayTags","baseIsTypedArray","baseUnary","freeProcess","nodeUtil","types","nodeIsTypedArray","isTypedArray","arrayLikeKeys","inherited","isArr","isArg","isBuff","isType","skipIndexes","overArg","transform","arg","nativeKeys","baseKeys","keys","reIsDeepProp","reIsPlainProp","isKey","nativeCreate","hashClear","hashDelete","HASH_UNDEFINED","hashGet","hashHas","hashSet","Hash","entries","entry","listCacheClear","assocIndexOf","arrayProto","splice","listCacheDelete","lastIndex","listCacheGet","listCacheHas","listCacheSet","ListCache","Map","mapCacheClear","isKeyable","getMapData","mapCacheDelete","mapCacheGet","mapCacheHas","mapCacheSet","size","MapCache","FUNC_ERROR_TEXT","memoize","resolver","memoized","cache","MAX_MEMOIZE_SIZE","memoizeCapped","rePropName","reEscapeChar","stringToPath","string","match","number","quote","subString","toString","castPath","toKey","arrayPush","values","offset","getPrototype","stackClear","stackDelete","stackGet","stackHas","LARGE_ARRAY_SIZE","stackSet","pairs","Stack","cloneBuffer","buffer","isDeep","arrayFilter","predicate","resIndex","stubArray","nativeGetSymbols","getSymbols","symbol","baseGetAllKeys","keysFunc","symbolsFunc","getAllKeys","DataView","Promise","Set","promiseTag","dataViewCtorString","mapCtorString","promiseCtorString","setCtorString","weakMapCtorString","getTag","ctorString","initCloneArray","Uint8Array","cloneArrayBuffer","arrayBuffer","cloneDataView","dataView","reFlags","cloneRegExp","regexp","symbolValueOf","cloneSymbol","cloneTypedArray","typedArray","initCloneByTag","initCloneObject","baseIsMap","nodeIsMap","isMap","baseIsSet","nodeIsSet","isSet","cloneableTags","baseClone","bitmask","customizer","isFunc","stacked","subValue","props","CLONE_DEEP_FLAG","CLONE_SYMBOLS_FLAG","cloneDeep","isEmpty","baseSet","newValue","set","byteToHex","unsafeStringify","getRandomValues","rnds8","rng","native","v4","buf","rnds","isValidId","ResourceRegister","source","finalSource","sortLayer","layer","zIndex","beforeLayer","sourceId","inputFeatures","collection","newFeature","indexKey","existingIndex","newIndex","states","removeFromMap","FOCUS_SOURCE_NAME","FOCUS_LAYER_NAME","FOCUS_Z_INDEX","FOCUS_LAYER","Focus","uuid","border","padding","armLength","rawBBox","finalBBox","finalArmLengthMeters","expandMeters","paddingMeters","baseLat","minLng","minLat","maxLng","maxLat","dLng","armLengthMeters","actualDLat","actualDLng","Context","registry","getOrCreateContext","existing","Module","CONNECT_LINE_LAYER_NAME","CONNECT_DEBUG_LINE_LAYER_NAME","CONNECT_DEBUG_FILL_LAYER_NAME","TOOLTIP_SOURCE_NAME","LAYERS","Tooltip","bounds","allBbox","anchor","minLon","Point","maxLon","fill","label","element","originalStyles","Marker","lngLat","endPoint","emptyFeature","lonLat","NAME","Z_INDEX","SHIP_SOURCE_NAME","SHIP_ICON_LAYER_NAME","SHIP_ICON_DIRECTION_LAYER_NAME","SHIP_REAL_LAYER_NAME","SHIP_REAL_OUTLINE_LAYER_NAME","MIN_ICON_SIZE","MAX_ICON_SIZE","UPDATE_STATUS","SHIP_COLOR","SHIP_ICON_DIRECTION_LAYER","SHIP_ICON_LAYER","SHIP_REAL_LAYER","SHIP_REAL_OUTLINE_LAYER","LAYER_LIST","SHIP_ICON","MapType","TDT_TOKEN","TMap","createStyle","http2","tdtToken","glyphs","protocol","token","T","baseTiles","labelTiles","BASE_SOURCE_IDS","BASE_LAYER_IDS","CMap","isCancelled","currentStyle","customSources","runtime","customLayers","restore","spec","onStyleData","load","cb","EventStatus","EventState","instance","PLOT_SOURCE_NAME","EMPTY_SOURCE","CURSOR","Event","Meta","PointBaseEvent","PointCreateEvent","PointUpdateEvent","PointResidentEvent","message","Poi","state","PlotType","POINT_INDEX_LAYER_NAME","DEFAULT_TEXT_COLOR","baseTextSize","POINT_INDEX_LAYER","TEXT_Z_INDEX","POINT_CIRCLE_LAYER_NAME","POINT_TEXT_LAYER_NAME","DEFAULT_TEXT_SIZE","GAP_PX","DEFAULT_CIRCLE_RADIUS","DEFAULT_CIRCLE_COLOR","DEFAULT_CIRCLE_STROKE_WIDTH","DEFAULT_CIRCLE_STROKE_COLOR","baseRadius","baseStrokeWidth","hoverScale","POINT_CIRCLE_LAYER","POINT_TEXT_LAYER","calculatedOffset","position","params","iconHeight","iconScale","iconAnchor","textSize","gap","actualHeight","offsetY_px","POINT_ICON_LAYER_NAME","DEFAULT_ICON_ANCHOR","DEFAULT_ICON_SIZE","baseIconSize","ICON_ROTATE","POINT_ICON_LAYER","IconPoint","scale","tSize","LineBaseEvent","LineCreateEvent","layers","LineUpdateEvent","LngLat","LineResidentEvent","PointType","LINE_LAYER_NAME","DOTTED_LINE_LAYER_NAME","LINE_TEXT_LAYER_NAME","DEFAULT_LINE_COLOR","DEFAULT_LINE_WIDTH","lineColor","lineWidth","lineDasharray","DOTTED_LINE_LAYER","LINE_LAYER","LINE_TEXT_LAYER","Line","modify","midPoint","drag","lngDiff","latDiff","newPos","minPoint","style","next","newPoint","isRender","midPos","newId","midLng","midLat","currentPos","nextPos","ArrowLine","isLast","TinyQueue","bestChild","polylabel","precision","debug","cellSize","cellQueue","bestCell","getCentroidCell","bboxCell","Cell","numProbes","potentiallyQueue","cell","max","ch","pointToPolygonDist","minDistSq","getSegDistSq","px","py","FillBaseEvent","FillCreateEvent","firstPoint","FillUpdateEvent","FillResidentEvent","FILL_LAYER_NAME","FILL_CLOSED_LINE_LAYER_NAME","DEFAULT_FILL_COLOR","DEFAULT_FILL_OPACITY","fillColor","FILL_LAYER","FILL_CLOSED_LINE_LAYER","Fill","center","lineStyle","vertexStyle","IndexPoint","IndexLine","ResidentEvent","ships","ship","Ship","plugins","PluginClass","tooltip","collision","Constructor","newShips","BaseShip","$","S","AisShip","betweenTime","dayjs","orientation","ex","ey","emptyDirLineFeature","shape","head","rightBow","rightQuarter","rightStern","leftStern","leftQuarter","leftBow","leftDirection","rightDirection","turn","shipNameBox","shipName","TooltipType","TRACK_SOURCE_NAME","TRACK_ARROW_LAYER_NAME","TRACK_ICON_LAYER_NAME","TRACK_LINE_LAYER_NAME","START_ICON_NAME","START_ICON","END_ICON_NAME","END_ICON","ARROW_ICON_NAME","NORMAL_ICON","NORMAL_ICON_NAME","ARROW_ICON","TRACK_ARROW_LAYER","TRACK_ICON_LAYER","TRACK_LINE_LAYER","TrackEvent","track","eventName","Track","sorts","lastTimeAnchor","cur","prevCog","curCog","angleDiff","isPrevStopped","isCurrStopped","angleThreshold","simplified","lastPoint","currentPoint","nextPoint","bearing1","bearing2","diff","threshold","features","sortedItems","latestItem","iconSize","viewportBBox","createLabel"],"mappings":"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","x_google_ignoreList":[2,3,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,41,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,128,129,130,131,132,133,134,135,136,137,138,139,140,141,142,143,144,145,146,147,148,149,150,151,152,153,154,155,156,184,185,194]}