"use strict"; /* * ATTENTION: An "eval-source-map" devtool has been used. * This devtool is neither made for production nor for readable output files. * It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools. * If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/) * or disable the default devtool with "devtool: false". * If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/). */ exports.id = "vendor-chunks/d3-delaunay"; exports.ids = ["vendor-chunks/d3-delaunay"]; exports.modules = { /***/ "(ssr)/./node_modules/d3-delaunay/src/delaunay.js": /*!**************************************************!*\ !*** ./node_modules/d3-delaunay/src/delaunay.js ***! \**************************************************/ /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ Delaunay)\n/* harmony export */ });\n/* harmony import */ var delaunator__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! delaunator */ \"(ssr)/./node_modules/delaunator/index.js\");\n/* harmony import */ var _path_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./path.js */ \"(ssr)/./node_modules/d3-delaunay/src/path.js\");\n/* harmony import */ var _polygon_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./polygon.js */ \"(ssr)/./node_modules/d3-delaunay/src/polygon.js\");\n/* harmony import */ var _voronoi_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./voronoi.js */ \"(ssr)/./node_modules/d3-delaunay/src/voronoi.js\");\n\n\n\n\nconst tau = 2 * Math.PI, pow = Math.pow;\nfunction pointX(p) {\n return p[0];\n}\nfunction pointY(p) {\n return p[1];\n}\n// A triangulation is collinear if all its triangles have a non-null area\nfunction collinear(d) {\n const { triangles, coords } = d;\n for(let i = 0; i < triangles.length; i += 3){\n const a = 2 * triangles[i], b = 2 * triangles[i + 1], c = 2 * triangles[i + 2], cross = (coords[c] - coords[a]) * (coords[b + 1] - coords[a + 1]) - (coords[b] - coords[a]) * (coords[c + 1] - coords[a + 1]);\n if (cross > 1e-10) return false;\n }\n return true;\n}\nfunction jitter(x, y, r) {\n return [\n x + Math.sin(x + y) * r,\n y + Math.cos(x - y) * r\n ];\n}\nclass Delaunay {\n static from(points, fx = pointX, fy = pointY, that) {\n return new Delaunay(\"length\" in points ? flatArray(points, fx, fy, that) : Float64Array.from(flatIterable(points, fx, fy, that)));\n }\n constructor(points){\n this._delaunator = new delaunator__WEBPACK_IMPORTED_MODULE_0__[\"default\"](points);\n this.inedges = new Int32Array(points.length / 2);\n this._hullIndex = new Int32Array(points.length / 2);\n this.points = this._delaunator.coords;\n this._init();\n }\n update() {\n this._delaunator.update();\n this._init();\n return this;\n }\n _init() {\n const d = this._delaunator, points = this.points;\n // check for collinear\n if (d.hull && d.hull.length > 2 && collinear(d)) {\n this.collinear = Int32Array.from({\n length: points.length / 2\n }, (_, i)=>i).sort((i, j)=>points[2 * i] - points[2 * j] || points[2 * i + 1] - points[2 * j + 1]); // for exact neighbors\n const e = this.collinear[0], f = this.collinear[this.collinear.length - 1], bounds = [\n points[2 * e],\n points[2 * e + 1],\n points[2 * f],\n points[2 * f + 1]\n ], r = 1e-8 * Math.hypot(bounds[3] - bounds[1], bounds[2] - bounds[0]);\n for(let i = 0, n = points.length / 2; i < n; ++i){\n const p = jitter(points[2 * i], points[2 * i + 1], r);\n points[2 * i] = p[0];\n points[2 * i + 1] = p[1];\n }\n this._delaunator = new delaunator__WEBPACK_IMPORTED_MODULE_0__[\"default\"](points);\n } else {\n delete this.collinear;\n }\n const halfedges = this.halfedges = this._delaunator.halfedges;\n const hull = this.hull = this._delaunator.hull;\n const triangles = this.triangles = this._delaunator.triangles;\n const inedges = this.inedges.fill(-1);\n const hullIndex = this._hullIndex.fill(-1);\n // Compute an index from each point to an (arbitrary) incoming halfedge\n // Used to give the first neighbor of each point; for this reason,\n // on the hull we give priority to exterior halfedges\n for(let e = 0, n = halfedges.length; e < n; ++e){\n const p = triangles[e % 3 === 2 ? e - 2 : e + 1];\n if (halfedges[e] === -1 || inedges[p] === -1) inedges[p] = e;\n }\n for(let i = 0, n = hull.length; i < n; ++i){\n hullIndex[hull[i]] = i;\n }\n // degenerate case: 1 or 2 (distinct) points\n if (hull.length <= 2 && hull.length > 0) {\n this.triangles = new Int32Array(3).fill(-1);\n this.halfedges = new Int32Array(3).fill(-1);\n this.triangles[0] = hull[0];\n inedges[hull[0]] = 1;\n if (hull.length === 2) {\n inedges[hull[1]] = 0;\n this.triangles[1] = hull[1];\n this.triangles[2] = hull[1];\n }\n }\n }\n voronoi(bounds) {\n return new _voronoi_js__WEBPACK_IMPORTED_MODULE_1__[\"default\"](this, bounds);\n }\n *neighbors(i) {\n const { inedges, hull, _hullIndex, halfedges, triangles, collinear } = this;\n // degenerate case with several collinear points\n if (collinear) {\n const l = collinear.indexOf(i);\n if (l > 0) yield collinear[l - 1];\n if (l < collinear.length - 1) yield collinear[l + 1];\n return;\n }\n const e0 = inedges[i];\n if (e0 === -1) return; // coincident point\n let e = e0, p0 = -1;\n do {\n yield p0 = triangles[e];\n e = e % 3 === 2 ? e - 2 : e + 1;\n if (triangles[e] !== i) return; // bad triangulation\n e = halfedges[e];\n if (e === -1) {\n const p = hull[(_hullIndex[i] + 1) % hull.length];\n if (p !== p0) yield p;\n return;\n }\n }while (e !== e0);\n }\n find(x, y, i = 0) {\n if ((x = +x, x !== x) || (y = +y, y !== y)) return -1;\n const i0 = i;\n let c;\n while((c = this._step(i, x, y)) >= 0 && c !== i && c !== i0)i = c;\n return c;\n }\n _step(i, x, y) {\n const { inedges, hull, _hullIndex, halfedges, triangles, points } = this;\n if (inedges[i] === -1 || !points.length) return (i + 1) % (points.length >> 1);\n let c = i;\n let dc = pow(x - points[i * 2], 2) + pow(y - points[i * 2 + 1], 2);\n const e0 = inedges[i];\n let e = e0;\n do {\n let t = triangles[e];\n const dt = pow(x - points[t * 2], 2) + pow(y - points[t * 2 + 1], 2);\n if (dt < dc) dc = dt, c = t;\n e = e % 3 === 2 ? e - 2 : e + 1;\n if (triangles[e] !== i) break; // bad triangulation\n e = halfedges[e];\n if (e === -1) {\n e = hull[(_hullIndex[i] + 1) % hull.length];\n if (e !== t) {\n if (pow(x - points[e * 2], 2) + pow(y - points[e * 2 + 1], 2) < dc) return e;\n }\n break;\n }\n }while (e !== e0);\n return c;\n }\n render(context) {\n const buffer = context == null ? context = new _path_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"] : undefined;\n const { points, halfedges, triangles } = this;\n for(let i = 0, n = halfedges.length; i < n; ++i){\n const j = halfedges[i];\n if (j < i) continue;\n const ti = triangles[i] * 2;\n const tj = triangles[j] * 2;\n context.moveTo(points[ti], points[ti + 1]);\n context.lineTo(points[tj], points[tj + 1]);\n }\n this.renderHull(context);\n return buffer && buffer.value();\n }\n renderPoints(context, r) {\n if (r === undefined && (!context || typeof context.moveTo !== \"function\")) r = context, context = null;\n r = r == undefined ? 2 : +r;\n const buffer = context == null ? context = new _path_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"] : undefined;\n const { points } = this;\n for(let i = 0, n = points.length; i < n; i += 2){\n const x = points[i], y = points[i + 1];\n context.moveTo(x + r, y);\n context.arc(x, y, r, 0, tau);\n }\n return buffer && buffer.value();\n }\n renderHull(context) {\n const buffer = context == null ? context = new _path_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"] : undefined;\n const { hull, points } = this;\n const h = hull[0] * 2, n = hull.length;\n context.moveTo(points[h], points[h + 1]);\n for(let i = 1; i < n; ++i){\n const h = 2 * hull[i];\n context.lineTo(points[h], points[h + 1]);\n }\n context.closePath();\n return buffer && buffer.value();\n }\n hullPolygon() {\n const polygon = new _polygon_js__WEBPACK_IMPORTED_MODULE_3__[\"default\"];\n this.renderHull(polygon);\n return polygon.value();\n }\n renderTriangle(i, context) {\n const buffer = context == null ? context = new _path_js__WEBPACK_IMPORTED_MODULE_2__[\"default\"] : undefined;\n const { points, triangles } = this;\n const t0 = triangles[i *= 3] * 2;\n const t1 = triangles[i + 1] * 2;\n const t2 = triangles[i + 2] * 2;\n context.moveTo(points[t0], points[t0 + 1]);\n context.lineTo(points[t1], points[t1 + 1]);\n context.lineTo(points[t2], points[t2 + 1]);\n context.closePath();\n return buffer && buffer.value();\n }\n *trianglePolygons() {\n const { triangles } = this;\n for(let i = 0, n = triangles.length / 3; i < n; ++i){\n yield this.trianglePolygon(i);\n }\n }\n trianglePolygon(i) {\n const polygon = new _polygon_js__WEBPACK_IMPORTED_MODULE_3__[\"default\"];\n this.renderTriangle(i, polygon);\n return polygon.value();\n }\n}\nfunction flatArray(points, fx, fy, that) {\n const n = points.length;\n const array = new Float64Array(n * 2);\n for(let i = 0; i < n; ++i){\n const p = points[i];\n array[i * 2] = fx.call(that, p, i, points);\n array[i * 2 + 1] = fy.call(that, p, i, points);\n }\n return array;\n}\nfunction* flatIterable(points, fx, fy, that) {\n let i = 0;\n for (const p of points){\n yield fx.call(that, p, i, points);\n yield fy.call(that, p, i, points);\n ++i;\n }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/d3-delaunay/src/delaunay.js","mappings":"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","sources":["webpack://nextchat/./node_modules/d3-delaunay/src/delaunay.js?781e"],"sourcesContent":["import Delaunator from \"delaunator\";\nimport Path from \"./path.js\";\nimport Polygon from \"./polygon.js\";\nimport Voronoi from \"./voronoi.js\";\n\nconst tau = 2 * Math.PI, pow = Math.pow;\n\nfunction pointX(p) {\n  return p[0];\n}\n\nfunction pointY(p) {\n  return p[1];\n}\n\n// A triangulation is collinear if all its triangles have a non-null area\nfunction collinear(d) {\n  const {triangles, coords} = d;\n  for (let i = 0; i < triangles.length; i += 3) {\n    const a = 2 * triangles[i],\n          b = 2 * triangles[i + 1],\n          c = 2 * triangles[i + 2],\n          cross = (coords[c] - coords[a]) * (coords[b + 1] - coords[a + 1])\n                - (coords[b] - coords[a]) * (coords[c + 1] - coords[a + 1]);\n    if (cross > 1e-10) return false;\n  }\n  return true;\n}\n\nfunction jitter(x, y, r) {\n  return [x + Math.sin(x + y) * r, y + Math.cos(x - y) * r];\n}\n\nexport default class Delaunay {\n  static from(points, fx = pointX, fy = pointY, that) {\n    return new Delaunay(\"length\" in points\n        ? flatArray(points, fx, fy, that)\n        : Float64Array.from(flatIterable(points, fx, fy, that)));\n  }\n  constructor(points) {\n    this._delaunator = new Delaunator(points);\n    this.inedges = new Int32Array(points.length / 2);\n    this._hullIndex = new Int32Array(points.length / 2);\n    this.points = this._delaunator.coords;\n    this._init();\n  }\n  update() {\n    this._delaunator.update();\n    this._init();\n    return this;\n  }\n  _init() {\n    const d = this._delaunator, points = this.points;\n\n    // check for collinear\n    if (d.hull && d.hull.length > 2 && collinear(d)) {\n      this.collinear = Int32Array.from({length: points.length/2}, (_,i) => i)\n        .sort((i, j) => points[2 * i] - points[2 * j] || points[2 * i + 1] - points[2 * j + 1]); // for exact neighbors\n      const e = this.collinear[0], f = this.collinear[this.collinear.length - 1],\n        bounds = [ points[2 * e], points[2 * e + 1], points[2 * f], points[2 * f + 1] ],\n        r = 1e-8 * Math.hypot(bounds[3] - bounds[1], bounds[2] - bounds[0]);\n      for (let i = 0, n = points.length / 2; i < n; ++i) {\n        const p = jitter(points[2 * i], points[2 * i + 1], r);\n        points[2 * i] = p[0];\n        points[2 * i + 1] = p[1];\n      }\n      this._delaunator = new Delaunator(points);\n    } else {\n      delete this.collinear;\n    }\n\n    const halfedges = this.halfedges = this._delaunator.halfedges;\n    const hull = this.hull = this._delaunator.hull;\n    const triangles = this.triangles = this._delaunator.triangles;\n    const inedges = this.inedges.fill(-1);\n    const hullIndex = this._hullIndex.fill(-1);\n\n    // Compute an index from each point to an (arbitrary) incoming halfedge\n    // Used to give the first neighbor of each point; for this reason,\n    // on the hull we give priority to exterior halfedges\n    for (let e = 0, n = halfedges.length; e < n; ++e) {\n      const p = triangles[e % 3 === 2 ? e - 2 : e + 1];\n      if (halfedges[e] === -1 || inedges[p] === -1) inedges[p] = e;\n    }\n    for (let i = 0, n = hull.length; i < n; ++i) {\n      hullIndex[hull[i]] = i;\n    }\n\n    // degenerate case: 1 or 2 (distinct) points\n    if (hull.length <= 2 && hull.length > 0) {\n      this.triangles = new Int32Array(3).fill(-1);\n      this.halfedges = new Int32Array(3).fill(-1);\n      this.triangles[0] = hull[0];\n      inedges[hull[0]] = 1;\n      if (hull.length === 2) {\n        inedges[hull[1]] = 0;\n        this.triangles[1] = hull[1];\n        this.triangles[2] = hull[1];\n      }\n    }\n  }\n  voronoi(bounds) {\n    return new Voronoi(this, bounds);\n  }\n  *neighbors(i) {\n    const {inedges, hull, _hullIndex, halfedges, triangles, collinear} = this;\n\n    // degenerate case with several collinear points\n    if (collinear) {\n      const l = collinear.indexOf(i);\n      if (l > 0) yield collinear[l - 1];\n      if (l < collinear.length - 1) yield collinear[l + 1];\n      return;\n    }\n\n    const e0 = inedges[i];\n    if (e0 === -1) return; // coincident point\n    let e = e0, p0 = -1;\n    do {\n      yield p0 = triangles[e];\n      e = e % 3 === 2 ? e - 2 : e + 1;\n      if (triangles[e] !== i) return; // bad triangulation\n      e = halfedges[e];\n      if (e === -1) {\n        const p = hull[(_hullIndex[i] + 1) % hull.length];\n        if (p !== p0) yield p;\n        return;\n      }\n    } while (e !== e0);\n  }\n  find(x, y, i = 0) {\n    if ((x = +x, x !== x) || (y = +y, y !== y)) return -1;\n    const i0 = i;\n    let c;\n    while ((c = this._step(i, x, y)) >= 0 && c !== i && c !== i0) i = c;\n    return c;\n  }\n  _step(i, x, y) {\n    const {inedges, hull, _hullIndex, halfedges, triangles, points} = this;\n    if (inedges[i] === -1 || !points.length) return (i + 1) % (points.length >> 1);\n    let c = i;\n    let dc = pow(x - points[i * 2], 2) + pow(y - points[i * 2 + 1], 2);\n    const e0 = inedges[i];\n    let e = e0;\n    do {\n      let t = triangles[e];\n      const dt = pow(x - points[t * 2], 2) + pow(y - points[t * 2 + 1], 2);\n      if (dt < dc) dc = dt, c = t;\n      e = e % 3 === 2 ? e - 2 : e + 1;\n      if (triangles[e] !== i) break; // bad triangulation\n      e = halfedges[e];\n      if (e === -1) {\n        e = hull[(_hullIndex[i] + 1) % hull.length];\n        if (e !== t) {\n          if (pow(x - points[e * 2], 2) + pow(y - points[e * 2 + 1], 2) < dc) return e;\n        }\n        break;\n      }\n    } while (e !== e0);\n    return c;\n  }\n  render(context) {\n    const buffer = context == null ? context = new Path : undefined;\n    const {points, halfedges, triangles} = this;\n    for (let i = 0, n = halfedges.length; i < n; ++i) {\n      const j = halfedges[i];\n      if (j < i) continue;\n      const ti = triangles[i] * 2;\n      const tj = triangles[j] * 2;\n      context.moveTo(points[ti], points[ti + 1]);\n      context.lineTo(points[tj], points[tj + 1]);\n    }\n    this.renderHull(context);\n    return buffer && buffer.value();\n  }\n  renderPoints(context, r) {\n    if (r === undefined && (!context || typeof context.moveTo !== \"function\")) r = context, context = null;\n    r = r == undefined ? 2 : +r;\n    const buffer = context == null ? context = new Path : undefined;\n    const {points} = this;\n    for (let i = 0, n = points.length; i < n; i += 2) {\n      const x = points[i], y = points[i + 1];\n      context.moveTo(x + r, y);\n      context.arc(x, y, r, 0, tau);\n    }\n    return buffer && buffer.value();\n  }\n  renderHull(context) {\n    const buffer = context == null ? context = new Path : undefined;\n    const {hull, points} = this;\n    const h = hull[0] * 2, n = hull.length;\n    context.moveTo(points[h], points[h + 1]);\n    for (let i = 1; i < n; ++i) {\n      const h = 2 * hull[i];\n      context.lineTo(points[h], points[h + 1]);\n    }\n    context.closePath();\n    return buffer && buffer.value();\n  }\n  hullPolygon() {\n    const polygon = new Polygon;\n    this.renderHull(polygon);\n    return polygon.value();\n  }\n  renderTriangle(i, context) {\n    const buffer = context == null ? context = new Path : undefined;\n    const {points, triangles} = this;\n    const t0 = triangles[i *= 3] * 2;\n    const t1 = triangles[i + 1] * 2;\n    const t2 = triangles[i + 2] * 2;\n    context.moveTo(points[t0], points[t0 + 1]);\n    context.lineTo(points[t1], points[t1 + 1]);\n    context.lineTo(points[t2], points[t2 + 1]);\n    context.closePath();\n    return buffer && buffer.value();\n  }\n  *trianglePolygons() {\n    const {triangles} = this;\n    for (let i = 0, n = triangles.length / 3; i < n; ++i) {\n      yield this.trianglePolygon(i);\n    }\n  }\n  trianglePolygon(i) {\n    const polygon = new Polygon;\n    this.renderTriangle(i, polygon);\n    return polygon.value();\n  }\n}\n\nfunction flatArray(points, fx, fy, that) {\n  const n = points.length;\n  const array = new Float64Array(n * 2);\n  for (let i = 0; i < n; ++i) {\n    const p = points[i];\n    array[i * 2] = fx.call(that, p, i, points);\n    array[i * 2 + 1] = fy.call(that, p, i, points);\n  }\n  return array;\n}\n\nfunction* flatIterable(points, fx, fy, that) {\n  let i = 0;\n  for (const p of points) {\n    yield fx.call(that, p, i, points);\n    yield fy.call(that, p, i, points);\n    ++i;\n  }\n}\n"],"names":["Delaunator","Path","Polygon","Voronoi","tau","Math","PI","pow","pointX","p","pointY","collinear","d","triangles","coords","i","length","a","b","c","cross","jitter","x","y","r","sin","cos","Delaunay","from","points","fx","fy","that","flatArray","Float64Array","flatIterable","constructor","_delaunator","inedges","Int32Array","_hullIndex","_init","update","hull","_","sort","j","e","f","bounds","hypot","n","halfedges","fill","hullIndex","voronoi","neighbors","l","indexOf","e0","p0","find","i0","_step","dc","t","dt","render","context","buffer","undefined","ti","tj","moveTo","lineTo","renderHull","value","renderPoints","arc","h","closePath","hullPolygon","polygon","renderTriangle","t0","t1","t2","trianglePolygons","trianglePolygon","array","call"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/d3-delaunay/src/delaunay.js\n"); /***/ }), /***/ "(ssr)/./node_modules/d3-delaunay/src/index.js": /*!***********************************************!*\ !*** ./node_modules/d3-delaunay/src/index.js ***! \***********************************************/ /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ Delaunay: () => (/* reexport safe */ _delaunay_js__WEBPACK_IMPORTED_MODULE_0__[\"default\"]),\n/* harmony export */ Voronoi: () => (/* reexport safe */ _voronoi_js__WEBPACK_IMPORTED_MODULE_1__[\"default\"])\n/* harmony export */ });\n/* harmony import */ var _delaunay_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./delaunay.js */ \"(ssr)/./node_modules/d3-delaunay/src/delaunay.js\");\n/* harmony import */ var _voronoi_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./voronoi.js */ \"(ssr)/./node_modules/d3-delaunay/src/voronoi.js\");\n\n\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvZDMtZGVsYXVuYXkvc3JjL2luZGV4LmpzIiwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBa0Q7QUFDRiIsInNvdXJjZXMiOlsid2VicGFjazovL25leHRjaGF0Ly4vbm9kZV9tb2R1bGVzL2QzLWRlbGF1bmF5L3NyYy9pbmRleC5qcz84ZGJiIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB7ZGVmYXVsdCBhcyBEZWxhdW5heX0gZnJvbSBcIi4vZGVsYXVuYXkuanNcIjtcbmV4cG9ydCB7ZGVmYXVsdCBhcyBWb3Jvbm9pfSBmcm9tIFwiLi92b3Jvbm9pLmpzXCI7XG4iXSwibmFtZXMiOlsiZGVmYXVsdCIsIkRlbGF1bmF5IiwiVm9yb25vaSJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/d3-delaunay/src/index.js\n"); /***/ }), /***/ "(ssr)/./node_modules/d3-delaunay/src/path.js": /*!**********************************************!*\ !*** ./node_modules/d3-delaunay/src/path.js ***! \**********************************************/ /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ Path)\n/* harmony export */ });\nconst epsilon = 1e-6;\nclass Path {\n constructor(){\n this._x0 = this._y0 = this._x1 = this._y1 = null; // end of current subpath\n this._ = \"\";\n }\n moveTo(x, y) {\n this._ += `M${this._x0 = this._x1 = +x},${this._y0 = this._y1 = +y}`;\n }\n closePath() {\n if (this._x1 !== null) {\n this._x1 = this._x0, this._y1 = this._y0;\n this._ += \"Z\";\n }\n }\n lineTo(x, y) {\n this._ += `L${this._x1 = +x},${this._y1 = +y}`;\n }\n arc(x, y, r) {\n x = +x, y = +y, r = +r;\n const x0 = x + r;\n const y0 = y;\n if (r < 0) throw new Error(\"negative radius\");\n if (this._x1 === null) this._ += `M${x0},${y0}`;\n else if (Math.abs(this._x1 - x0) > epsilon || Math.abs(this._y1 - y0) > epsilon) this._ += \"L\" + x0 + \",\" + y0;\n if (!r) return;\n this._ += `A${r},${r},0,1,1,${x - r},${y}A${r},${r},0,1,1,${this._x1 = x0},${this._y1 = y0}`;\n }\n rect(x, y, w, h) {\n this._ += `M${this._x0 = this._x1 = +x},${this._y0 = this._y1 = +y}h${+w}v${+h}h${-w}Z`;\n }\n value() {\n return this._ || null;\n }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvZDMtZGVsYXVuYXkvc3JjL3BhdGguanMiLCJtYXBwaW5ncyI6Ijs7OztBQUFBLE1BQU1BLFVBQVU7QUFFRCxNQUFNQztJQUNuQkMsYUFBYztRQUNaLElBQUksQ0FBQ0MsR0FBRyxHQUFHLElBQUksQ0FBQ0MsR0FBRyxHQUNuQixJQUFJLENBQUNDLEdBQUcsR0FBRyxJQUFJLENBQUNDLEdBQUcsR0FBRyxNQUFNLHlCQUF5QjtRQUNyRCxJQUFJLENBQUNDLENBQUMsR0FBRztJQUNYO0lBQ0FDLE9BQU9DLENBQUMsRUFBRUMsQ0FBQyxFQUFFO1FBQ1gsSUFBSSxDQUFDSCxDQUFDLElBQUksQ0FBQyxDQUFDLEVBQUUsSUFBSSxDQUFDSixHQUFHLEdBQUcsSUFBSSxDQUFDRSxHQUFHLEdBQUcsQ0FBQ0ksRUFBRSxDQUFDLEVBQUUsSUFBSSxDQUFDTCxHQUFHLEdBQUcsSUFBSSxDQUFDRSxHQUFHLEdBQUcsQ0FBQ0ksRUFBRSxDQUFDO0lBQ3RFO0lBQ0FDLFlBQVk7UUFDVixJQUFJLElBQUksQ0FBQ04sR0FBRyxLQUFLLE1BQU07WUFDckIsSUFBSSxDQUFDQSxHQUFHLEdBQUcsSUFBSSxDQUFDRixHQUFHLEVBQUUsSUFBSSxDQUFDRyxHQUFHLEdBQUcsSUFBSSxDQUFDRixHQUFHO1lBQ3hDLElBQUksQ0FBQ0csQ0FBQyxJQUFJO1FBQ1o7SUFDRjtJQUNBSyxPQUFPSCxDQUFDLEVBQUVDLENBQUMsRUFBRTtRQUNYLElBQUksQ0FBQ0gsQ0FBQyxJQUFJLENBQUMsQ0FBQyxFQUFFLElBQUksQ0FBQ0YsR0FBRyxHQUFHLENBQUNJLEVBQUUsQ0FBQyxFQUFFLElBQUksQ0FBQ0gsR0FBRyxHQUFHLENBQUNJLEVBQUUsQ0FBQztJQUNoRDtJQUNBRyxJQUFJSixDQUFDLEVBQUVDLENBQUMsRUFBRUksQ0FBQyxFQUFFO1FBQ1hMLElBQUksQ0FBQ0EsR0FBR0MsSUFBSSxDQUFDQSxHQUFHSSxJQUFJLENBQUNBO1FBQ3JCLE1BQU1DLEtBQUtOLElBQUlLO1FBQ2YsTUFBTUUsS0FBS047UUFDWCxJQUFJSSxJQUFJLEdBQUcsTUFBTSxJQUFJRyxNQUFNO1FBQzNCLElBQUksSUFBSSxDQUFDWixHQUFHLEtBQUssTUFBTSxJQUFJLENBQUNFLENBQUMsSUFBSSxDQUFDLENBQUMsRUFBRVEsR0FBRyxDQUFDLEVBQUVDLEdBQUcsQ0FBQzthQUMxQyxJQUFJRSxLQUFLQyxHQUFHLENBQUMsSUFBSSxDQUFDZCxHQUFHLEdBQUdVLE1BQU1mLFdBQVdrQixLQUFLQyxHQUFHLENBQUMsSUFBSSxDQUFDYixHQUFHLEdBQUdVLE1BQU1oQixTQUFTLElBQUksQ0FBQ08sQ0FBQyxJQUFJLE1BQU1RLEtBQUssTUFBTUM7UUFDNUcsSUFBSSxDQUFDRixHQUFHO1FBQ1IsSUFBSSxDQUFDUCxDQUFDLElBQUksQ0FBQyxDQUFDLEVBQUVPLEVBQUUsQ0FBQyxFQUFFQSxFQUFFLE9BQU8sRUFBRUwsSUFBSUssRUFBRSxDQUFDLEVBQUVKLEVBQUUsQ0FBQyxFQUFFSSxFQUFFLENBQUMsRUFBRUEsRUFBRSxPQUFPLEVBQUUsSUFBSSxDQUFDVCxHQUFHLEdBQUdVLEdBQUcsQ0FBQyxFQUFFLElBQUksQ0FBQ1QsR0FBRyxHQUFHVSxHQUFHLENBQUM7SUFDOUY7SUFDQUksS0FBS1gsQ0FBQyxFQUFFQyxDQUFDLEVBQUVXLENBQUMsRUFBRUMsQ0FBQyxFQUFFO1FBQ2YsSUFBSSxDQUFDZixDQUFDLElBQUksQ0FBQyxDQUFDLEVBQUUsSUFBSSxDQUFDSixHQUFHLEdBQUcsSUFBSSxDQUFDRSxHQUFHLEdBQUcsQ0FBQ0ksRUFBRSxDQUFDLEVBQUUsSUFBSSxDQUFDTCxHQUFHLEdBQUcsSUFBSSxDQUFDRSxHQUFHLEdBQUcsQ0FBQ0ksRUFBRSxDQUFDLEVBQUUsQ0FBQ1csRUFBRSxDQUFDLEVBQUUsQ0FBQ0MsRUFBRSxDQUFDLEVBQUUsQ0FBQ0QsRUFBRSxDQUFDLENBQUM7SUFDekY7SUFDQUUsUUFBUTtRQUNOLE9BQU8sSUFBSSxDQUFDaEIsQ0FBQyxJQUFJO0lBQ25CO0FBQ0YiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9uZXh0Y2hhdC8uL25vZGVfbW9kdWxlcy9kMy1kZWxhdW5heS9zcmMvcGF0aC5qcz9lNGUxIl0sInNvdXJjZXNDb250ZW50IjpbImNvbnN0IGVwc2lsb24gPSAxZS02O1xuXG5leHBvcnQgZGVmYXVsdCBjbGFzcyBQYXRoIHtcbiAgY29uc3RydWN0b3IoKSB7XG4gICAgdGhpcy5feDAgPSB0aGlzLl95MCA9IC8vIHN0YXJ0IG9mIGN1cnJlbnQgc3VicGF0aFxuICAgIHRoaXMuX3gxID0gdGhpcy5feTEgPSBudWxsOyAvLyBlbmQgb2YgY3VycmVudCBzdWJwYXRoXG4gICAgdGhpcy5fID0gXCJcIjtcbiAgfVxuICBtb3ZlVG8oeCwgeSkge1xuICAgIHRoaXMuXyArPSBgTSR7dGhpcy5feDAgPSB0aGlzLl94MSA9ICt4fSwke3RoaXMuX3kwID0gdGhpcy5feTEgPSAreX1gO1xuICB9XG4gIGNsb3NlUGF0aCgpIHtcbiAgICBpZiAodGhpcy5feDEgIT09IG51bGwpIHtcbiAgICAgIHRoaXMuX3gxID0gdGhpcy5feDAsIHRoaXMuX3kxID0gdGhpcy5feTA7XG4gICAgICB0aGlzLl8gKz0gXCJaXCI7XG4gICAgfVxuICB9XG4gIGxpbmVUbyh4LCB5KSB7XG4gICAgdGhpcy5fICs9IGBMJHt0aGlzLl94MSA9ICt4fSwke3RoaXMuX3kxID0gK3l9YDtcbiAgfVxuICBhcmMoeCwgeSwgcikge1xuICAgIHggPSAreCwgeSA9ICt5LCByID0gK3I7XG4gICAgY29uc3QgeDAgPSB4ICsgcjtcbiAgICBjb25zdCB5MCA9IHk7XG4gICAgaWYgKHIgPCAwKSB0aHJvdyBuZXcgRXJyb3IoXCJuZWdhdGl2ZSByYWRpdXNcIik7XG4gICAgaWYgKHRoaXMuX3gxID09PSBudWxsKSB0aGlzLl8gKz0gYE0ke3gwfSwke3kwfWA7XG4gICAgZWxzZSBpZiAoTWF0aC5hYnModGhpcy5feDEgLSB4MCkgPiBlcHNpbG9uIHx8IE1hdGguYWJzKHRoaXMuX3kxIC0geTApID4gZXBzaWxvbikgdGhpcy5fICs9IFwiTFwiICsgeDAgKyBcIixcIiArIHkwO1xuICAgIGlmICghcikgcmV0dXJuO1xuICAgIHRoaXMuXyArPSBgQSR7cn0sJHtyfSwwLDEsMSwke3ggLSByfSwke3l9QSR7cn0sJHtyfSwwLDEsMSwke3RoaXMuX3gxID0geDB9LCR7dGhpcy5feTEgPSB5MH1gO1xuICB9XG4gIHJlY3QoeCwgeSwgdywgaCkge1xuICAgIHRoaXMuXyArPSBgTSR7dGhpcy5feDAgPSB0aGlzLl94MSA9ICt4fSwke3RoaXMuX3kwID0gdGhpcy5feTEgPSAreX1oJHsrd312JHsraH1oJHstd31aYDtcbiAgfVxuICB2YWx1ZSgpIHtcbiAgICByZXR1cm4gdGhpcy5fIHx8IG51bGw7XG4gIH1cbn1cbiJdLCJuYW1lcyI6WyJlcHNpbG9uIiwiUGF0aCIsImNvbnN0cnVjdG9yIiwiX3gwIiwiX3kwIiwiX3gxIiwiX3kxIiwiXyIsIm1vdmVUbyIsIngiLCJ5IiwiY2xvc2VQYXRoIiwibGluZVRvIiwiYXJjIiwiciIsIngwIiwieTAiLCJFcnJvciIsIk1hdGgiLCJhYnMiLCJyZWN0IiwidyIsImgiLCJ2YWx1ZSJdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/d3-delaunay/src/path.js\n"); /***/ }), /***/ "(ssr)/./node_modules/d3-delaunay/src/polygon.js": /*!*************************************************!*\ !*** ./node_modules/d3-delaunay/src/polygon.js ***! \*************************************************/ /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ Polygon)\n/* harmony export */ });\nclass Polygon {\n constructor(){\n this._ = [];\n }\n moveTo(x, y) {\n this._.push([\n x,\n y\n ]);\n }\n closePath() {\n this._.push(this._[0].slice());\n }\n lineTo(x, y) {\n this._.push([\n x,\n y\n ]);\n }\n value() {\n return this._.length ? this._ : null;\n }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHNzcikvLi9ub2RlX21vZHVsZXMvZDMtZGVsYXVuYXkvc3JjL3BvbHlnb24uanMiLCJtYXBwaW5ncyI6Ijs7OztBQUFlLE1BQU1BO0lBQ25CQyxhQUFjO1FBQ1osSUFBSSxDQUFDQyxDQUFDLEdBQUcsRUFBRTtJQUNiO0lBQ0FDLE9BQU9DLENBQUMsRUFBRUMsQ0FBQyxFQUFFO1FBQ1gsSUFBSSxDQUFDSCxDQUFDLENBQUNJLElBQUksQ0FBQztZQUFDRjtZQUFHQztTQUFFO0lBQ3BCO0lBQ0FFLFlBQVk7UUFDVixJQUFJLENBQUNMLENBQUMsQ0FBQ0ksSUFBSSxDQUFDLElBQUksQ0FBQ0osQ0FBQyxDQUFDLEVBQUUsQ0FBQ00sS0FBSztJQUM3QjtJQUNBQyxPQUFPTCxDQUFDLEVBQUVDLENBQUMsRUFBRTtRQUNYLElBQUksQ0FBQ0gsQ0FBQyxDQUFDSSxJQUFJLENBQUM7WUFBQ0Y7WUFBR0M7U0FBRTtJQUNwQjtJQUNBSyxRQUFRO1FBQ04sT0FBTyxJQUFJLENBQUNSLENBQUMsQ0FBQ1MsTUFBTSxHQUFHLElBQUksQ0FBQ1QsQ0FBQyxHQUFHO0lBQ2xDO0FBQ0YiLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9uZXh0Y2hhdC8uL25vZGVfbW9kdWxlcy9kMy1kZWxhdW5heS9zcmMvcG9seWdvbi5qcz82ZjA3Il0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBkZWZhdWx0IGNsYXNzIFBvbHlnb24ge1xuICBjb25zdHJ1Y3RvcigpIHtcbiAgICB0aGlzLl8gPSBbXTtcbiAgfVxuICBtb3ZlVG8oeCwgeSkge1xuICAgIHRoaXMuXy5wdXNoKFt4LCB5XSk7XG4gIH1cbiAgY2xvc2VQYXRoKCkge1xuICAgIHRoaXMuXy5wdXNoKHRoaXMuX1swXS5zbGljZSgpKTtcbiAgfVxuICBsaW5lVG8oeCwgeSkge1xuICAgIHRoaXMuXy5wdXNoKFt4LCB5XSk7XG4gIH1cbiAgdmFsdWUoKSB7XG4gICAgcmV0dXJuIHRoaXMuXy5sZW5ndGggPyB0aGlzLl8gOiBudWxsO1xuICB9XG59XG4iXSwibmFtZXMiOlsiUG9seWdvbiIsImNvbnN0cnVjdG9yIiwiXyIsIm1vdmVUbyIsIngiLCJ5IiwicHVzaCIsImNsb3NlUGF0aCIsInNsaWNlIiwibGluZVRvIiwidmFsdWUiLCJsZW5ndGgiXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/d3-delaunay/src/polygon.js\n"); /***/ }), /***/ "(ssr)/./node_modules/d3-delaunay/src/voronoi.js": /*!*************************************************!*\ !*** ./node_modules/d3-delaunay/src/voronoi.js ***! \*************************************************/ /***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ Voronoi)\n/* harmony export */ });\n/* harmony import */ var _path_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./path.js */ \"(ssr)/./node_modules/d3-delaunay/src/path.js\");\n/* harmony import */ var _polygon_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./polygon.js */ \"(ssr)/./node_modules/d3-delaunay/src/polygon.js\");\n\n\nclass Voronoi {\n constructor(delaunay, [xmin, ymin, xmax, ymax] = [\n 0,\n 0,\n 960,\n 500\n ]){\n if (!((xmax = +xmax) >= (xmin = +xmin)) || !((ymax = +ymax) >= (ymin = +ymin))) throw new Error(\"invalid bounds\");\n this.delaunay = delaunay;\n this._circumcenters = new Float64Array(delaunay.points.length * 2);\n this.vectors = new Float64Array(delaunay.points.length * 2);\n this.xmax = xmax, this.xmin = xmin;\n this.ymax = ymax, this.ymin = ymin;\n this._init();\n }\n update() {\n this.delaunay.update();\n this._init();\n return this;\n }\n _init() {\n const { delaunay: { points, hull, triangles }, vectors } = this;\n let bx, by; // lazily computed barycenter of the hull\n // Compute circumcenters.\n const circumcenters = this.circumcenters = this._circumcenters.subarray(0, triangles.length / 3 * 2);\n for(let i = 0, j = 0, n = triangles.length, x, y; i < n; i += 3, j += 2){\n const t1 = triangles[i] * 2;\n const t2 = triangles[i + 1] * 2;\n const t3 = triangles[i + 2] * 2;\n const x1 = points[t1];\n const y1 = points[t1 + 1];\n const x2 = points[t2];\n const y2 = points[t2 + 1];\n const x3 = points[t3];\n const y3 = points[t3 + 1];\n const dx = x2 - x1;\n const dy = y2 - y1;\n const ex = x3 - x1;\n const ey = y3 - y1;\n const ab = (dx * ey - dy * ex) * 2;\n if (Math.abs(ab) < 1e-9) {\n // For a degenerate triangle, the circumcenter is at the infinity, in a\n // direction orthogonal to the halfedge and away from the “center” of\n // the diagram , defined as the hull’s barycenter.\n if (bx === undefined) {\n bx = by = 0;\n for (const i of hull)bx += points[i * 2], by += points[i * 2 + 1];\n bx /= hull.length, by /= hull.length;\n }\n const a = 1e9 * Math.sign((bx - x1) * ey - (by - y1) * ex);\n x = (x1 + x3) / 2 - a * ey;\n y = (y1 + y3) / 2 + a * ex;\n } else {\n const d = 1 / ab;\n const bl = dx * dx + dy * dy;\n const cl = ex * ex + ey * ey;\n x = x1 + (ey * bl - dy * cl) * d;\n y = y1 + (dx * cl - ex * bl) * d;\n }\n circumcenters[j] = x;\n circumcenters[j + 1] = y;\n }\n // Compute exterior cell rays.\n let h = hull[hull.length - 1];\n let p0, p1 = h * 4;\n let x0, x1 = points[2 * h];\n let y0, y1 = points[2 * h + 1];\n vectors.fill(0);\n for(let i = 0; i < hull.length; ++i){\n h = hull[i];\n p0 = p1, x0 = x1, y0 = y1;\n p1 = h * 4, x1 = points[2 * h], y1 = points[2 * h + 1];\n vectors[p0 + 2] = vectors[p1] = y0 - y1;\n vectors[p0 + 3] = vectors[p1 + 1] = x1 - x0;\n }\n }\n render(context) {\n const buffer = context == null ? context = new _path_js__WEBPACK_IMPORTED_MODULE_0__[\"default\"] : undefined;\n const { delaunay: { halfedges, inedges, hull }, circumcenters, vectors } = this;\n if (hull.length <= 1) return null;\n for(let i = 0, n = halfedges.length; i < n; ++i){\n const j = halfedges[i];\n if (j < i) continue;\n const ti = Math.floor(i / 3) * 2;\n const tj = Math.floor(j / 3) * 2;\n const xi = circumcenters[ti];\n const yi = circumcenters[ti + 1];\n const xj = circumcenters[tj];\n const yj = circumcenters[tj + 1];\n this._renderSegment(xi, yi, xj, yj, context);\n }\n let h0, h1 = hull[hull.length - 1];\n for(let i = 0; i < hull.length; ++i){\n h0 = h1, h1 = hull[i];\n const t = Math.floor(inedges[h1] / 3) * 2;\n const x = circumcenters[t];\n const y = circumcenters[t + 1];\n const v = h0 * 4;\n const p = this._project(x, y, vectors[v + 2], vectors[v + 3]);\n if (p) this._renderSegment(x, y, p[0], p[1], context);\n }\n return buffer && buffer.value();\n }\n renderBounds(context) {\n const buffer = context == null ? context = new _path_js__WEBPACK_IMPORTED_MODULE_0__[\"default\"] : undefined;\n context.rect(this.xmin, this.ymin, this.xmax - this.xmin, this.ymax - this.ymin);\n return buffer && buffer.value();\n }\n renderCell(i, context) {\n const buffer = context == null ? context = new _path_js__WEBPACK_IMPORTED_MODULE_0__[\"default\"] : undefined;\n const points = this._clip(i);\n if (points === null || !points.length) return;\n context.moveTo(points[0], points[1]);\n let n = points.length;\n while(points[0] === points[n - 2] && points[1] === points[n - 1] && n > 1)n -= 2;\n for(let i = 2; i < n; i += 2){\n if (points[i] !== points[i - 2] || points[i + 1] !== points[i - 1]) context.lineTo(points[i], points[i + 1]);\n }\n context.closePath();\n return buffer && buffer.value();\n }\n *cellPolygons() {\n const { delaunay: { points } } = this;\n for(let i = 0, n = points.length / 2; i < n; ++i){\n const cell = this.cellPolygon(i);\n if (cell) cell.index = i, yield cell;\n }\n }\n cellPolygon(i) {\n const polygon = new _polygon_js__WEBPACK_IMPORTED_MODULE_1__[\"default\"];\n this.renderCell(i, polygon);\n return polygon.value();\n }\n _renderSegment(x0, y0, x1, y1, context) {\n let S;\n const c0 = this._regioncode(x0, y0);\n const c1 = this._regioncode(x1, y1);\n if (c0 === 0 && c1 === 0) {\n context.moveTo(x0, y0);\n context.lineTo(x1, y1);\n } else if (S = this._clipSegment(x0, y0, x1, y1, c0, c1)) {\n context.moveTo(S[0], S[1]);\n context.lineTo(S[2], S[3]);\n }\n }\n contains(i, x, y) {\n if ((x = +x, x !== x) || (y = +y, y !== y)) return false;\n return this.delaunay._step(i, x, y) === i;\n }\n *neighbors(i) {\n const ci = this._clip(i);\n if (ci) for (const j of this.delaunay.neighbors(i)){\n const cj = this._clip(j);\n // find the common edge\n if (cj) loop: for(let ai = 0, li = ci.length; ai < li; ai += 2){\n for(let aj = 0, lj = cj.length; aj < lj; aj += 2){\n if (ci[ai] === cj[aj] && ci[ai + 1] === cj[aj + 1] && ci[(ai + 2) % li] === cj[(aj + lj - 2) % lj] && ci[(ai + 3) % li] === cj[(aj + lj - 1) % lj]) {\n yield j;\n break loop;\n }\n }\n }\n }\n }\n _cell(i) {\n const { circumcenters, delaunay: { inedges, halfedges, triangles } } = this;\n const e0 = inedges[i];\n if (e0 === -1) return null; // coincident point\n const points = [];\n let e = e0;\n do {\n const t = Math.floor(e / 3);\n points.push(circumcenters[t * 2], circumcenters[t * 2 + 1]);\n e = e % 3 === 2 ? e - 2 : e + 1;\n if (triangles[e] !== i) break; // bad triangulation\n e = halfedges[e];\n }while (e !== e0 && e !== -1);\n return points;\n }\n _clip(i) {\n // degenerate case (1 valid point: return the box)\n if (i === 0 && this.delaunay.hull.length === 1) {\n return [\n this.xmax,\n this.ymin,\n this.xmax,\n this.ymax,\n this.xmin,\n this.ymax,\n this.xmin,\n this.ymin\n ];\n }\n const points = this._cell(i);\n if (points === null) return null;\n const { vectors: V } = this;\n const v = i * 4;\n return this._simplify(V[v] || V[v + 1] ? this._clipInfinite(i, points, V[v], V[v + 1], V[v + 2], V[v + 3]) : this._clipFinite(i, points));\n }\n _clipFinite(i, points) {\n const n = points.length;\n let P = null;\n let x0, y0, x1 = points[n - 2], y1 = points[n - 1];\n let c0, c1 = this._regioncode(x1, y1);\n let e0, e1 = 0;\n for(let j = 0; j < n; j += 2){\n x0 = x1, y0 = y1, x1 = points[j], y1 = points[j + 1];\n c0 = c1, c1 = this._regioncode(x1, y1);\n if (c0 === 0 && c1 === 0) {\n e0 = e1, e1 = 0;\n if (P) P.push(x1, y1);\n else P = [\n x1,\n y1\n ];\n } else {\n let S, sx0, sy0, sx1, sy1;\n if (c0 === 0) {\n if ((S = this._clipSegment(x0, y0, x1, y1, c0, c1)) === null) continue;\n [sx0, sy0, sx1, sy1] = S;\n } else {\n if ((S = this._clipSegment(x1, y1, x0, y0, c1, c0)) === null) continue;\n [sx1, sy1, sx0, sy0] = S;\n e0 = e1, e1 = this._edgecode(sx0, sy0);\n if (e0 && e1) this._edge(i, e0, e1, P, P.length);\n if (P) P.push(sx0, sy0);\n else P = [\n sx0,\n sy0\n ];\n }\n e0 = e1, e1 = this._edgecode(sx1, sy1);\n if (e0 && e1) this._edge(i, e0, e1, P, P.length);\n if (P) P.push(sx1, sy1);\n else P = [\n sx1,\n sy1\n ];\n }\n }\n if (P) {\n e0 = e1, e1 = this._edgecode(P[0], P[1]);\n if (e0 && e1) this._edge(i, e0, e1, P, P.length);\n } else if (this.contains(i, (this.xmin + this.xmax) / 2, (this.ymin + this.ymax) / 2)) {\n return [\n this.xmax,\n this.ymin,\n this.xmax,\n this.ymax,\n this.xmin,\n this.ymax,\n this.xmin,\n this.ymin\n ];\n }\n return P;\n }\n _clipSegment(x0, y0, x1, y1, c0, c1) {\n // for more robustness, always consider the segment in the same order\n const flip = c0 < c1;\n if (flip) [x0, y0, x1, y1, c0, c1] = [\n x1,\n y1,\n x0,\n y0,\n c1,\n c0\n ];\n while(true){\n if (c0 === 0 && c1 === 0) return flip ? [\n x1,\n y1,\n x0,\n y0\n ] : [\n x0,\n y0,\n x1,\n y1\n ];\n if (c0 & c1) return null;\n let x, y, c = c0 || c1;\n if (c & 8) x = x0 + (x1 - x0) * (this.ymax - y0) / (y1 - y0), y = this.ymax;\n else if (c & 4) x = x0 + (x1 - x0) * (this.ymin - y0) / (y1 - y0), y = this.ymin;\n else if (c & 2) y = y0 + (y1 - y0) * (this.xmax - x0) / (x1 - x0), x = this.xmax;\n else y = y0 + (y1 - y0) * (this.xmin - x0) / (x1 - x0), x = this.xmin;\n if (c0) x0 = x, y0 = y, c0 = this._regioncode(x0, y0);\n else x1 = x, y1 = y, c1 = this._regioncode(x1, y1);\n }\n }\n _clipInfinite(i, points, vx0, vy0, vxn, vyn) {\n let P = Array.from(points), p;\n if (p = this._project(P[0], P[1], vx0, vy0)) P.unshift(p[0], p[1]);\n if (p = this._project(P[P.length - 2], P[P.length - 1], vxn, vyn)) P.push(p[0], p[1]);\n if (P = this._clipFinite(i, P)) {\n for(let j = 0, n = P.length, c0, c1 = this._edgecode(P[n - 2], P[n - 1]); j < n; j += 2){\n c0 = c1, c1 = this._edgecode(P[j], P[j + 1]);\n if (c0 && c1) j = this._edge(i, c0, c1, P, j), n = P.length;\n }\n } else if (this.contains(i, (this.xmin + this.xmax) / 2, (this.ymin + this.ymax) / 2)) {\n P = [\n this.xmin,\n this.ymin,\n this.xmax,\n this.ymin,\n this.xmax,\n this.ymax,\n this.xmin,\n this.ymax\n ];\n }\n return P;\n }\n _edge(i, e0, e1, P, j) {\n while(e0 !== e1){\n let x, y;\n switch(e0){\n case 5:\n e0 = 4;\n continue; // top-left\n case 4:\n e0 = 6, x = this.xmax, y = this.ymin;\n break; // top\n case 6:\n e0 = 2;\n continue; // top-right\n case 2:\n e0 = 10, x = this.xmax, y = this.ymax;\n break; // right\n case 10:\n e0 = 8;\n continue; // bottom-right\n case 8:\n e0 = 9, x = this.xmin, y = this.ymax;\n break; // bottom\n case 9:\n e0 = 1;\n continue; // bottom-left\n case 1:\n e0 = 5, x = this.xmin, y = this.ymin;\n break; // left\n }\n // Note: this implicitly checks for out of bounds: if P[j] or P[j+1] are\n // undefined, the conditional statement will be executed.\n if ((P[j] !== x || P[j + 1] !== y) && this.contains(i, x, y)) {\n P.splice(j, 0, x, y), j += 2;\n }\n }\n return j;\n }\n _project(x0, y0, vx, vy) {\n let t = Infinity, c, x, y;\n if (vy < 0) {\n if (y0 <= this.ymin) return null;\n if ((c = (this.ymin - y0) / vy) < t) y = this.ymin, x = x0 + (t = c) * vx;\n } else if (vy > 0) {\n if (y0 >= this.ymax) return null;\n if ((c = (this.ymax - y0) / vy) < t) y = this.ymax, x = x0 + (t = c) * vx;\n }\n if (vx > 0) {\n if (x0 >= this.xmax) return null;\n if ((c = (this.xmax - x0) / vx) < t) x = this.xmax, y = y0 + (t = c) * vy;\n } else if (vx < 0) {\n if (x0 <= this.xmin) return null;\n if ((c = (this.xmin - x0) / vx) < t) x = this.xmin, y = y0 + (t = c) * vy;\n }\n return [\n x,\n y\n ];\n }\n _edgecode(x, y) {\n return (x === this.xmin ? 1 : x === this.xmax ? 2 : 0) | (y === this.ymin ? 4 : y === this.ymax ? 8 : 0);\n }\n _regioncode(x, y) {\n return (x < this.xmin ? 1 : x > this.xmax ? 2 : 0) | (y < this.ymin ? 4 : y > this.ymax ? 8 : 0);\n }\n _simplify(P) {\n if (P && P.length > 4) {\n for(let i = 0; i < P.length; i += 2){\n const j = (i + 2) % P.length, k = (i + 4) % P.length;\n if (P[i] === P[j] && P[j] === P[k] || P[i + 1] === P[j + 1] && P[j + 1] === P[k + 1]) {\n P.splice(j, 2), i -= 2;\n }\n }\n if (!P.length) P = null;\n }\n return P;\n }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/d3-delaunay/src/voronoi.js","mappings":";;;;;;AAA6B;AACM;AAEpB,MAAME;IACnBC,YAAYC,QAAQ,EAAE,CAACC,MAAMC,MAAMC,MAAMC,KAAK,GAAG;QAAC;QAAG;QAAG;QAAK;KAAI,CAAE;QACjE,IAAI,CAAE,EAACD,OAAO,CAACA,IAAG,KAAOF,CAAAA,OAAO,CAACA,IAAG,CAAC,KAAM,CAAE,EAACG,OAAO,CAACA,IAAG,KAAOF,CAAAA,OAAO,CAACA,IAAG,CAAC,GAAI,MAAM,IAAIG,MAAM;QAChG,IAAI,CAACL,QAAQ,GAAGA;QAChB,IAAI,CAACM,cAAc,GAAG,IAAIC,aAAaP,SAASQ,MAAM,CAACC,MAAM,GAAG;QAChE,IAAI,CAACC,OAAO,GAAG,IAAIH,aAAaP,SAASQ,MAAM,CAACC,MAAM,GAAG;QACzD,IAAI,CAACN,IAAI,GAAGA,MAAM,IAAI,CAACF,IAAI,GAAGA;QAC9B,IAAI,CAACG,IAAI,GAAGA,MAAM,IAAI,CAACF,IAAI,GAAGA;QAC9B,IAAI,CAACS,KAAK;IACZ;IACAC,SAAS;QACP,IAAI,CAACZ,QAAQ,CAACY,MAAM;QACpB,IAAI,CAACD,KAAK;QACV,OAAO,IAAI;IACb;IACAA,QAAQ;QACN,MAAM,EAACX,UAAU,EAACQ,MAAM,EAAEK,IAAI,EAAEC,SAAS,EAAC,EAAEJ,OAAO,EAAC,GAAG,IAAI;QAC3D,IAAIK,IAAIC,IAAI,yCAAyC;QAErD,yBAAyB;QACzB,MAAMC,gBAAgB,IAAI,CAACA,aAAa,GAAG,IAAI,CAACX,cAAc,CAACY,QAAQ,CAAC,GAAGJ,UAAUL,MAAM,GAAG,IAAI;QAClG,IAAK,IAAIU,IAAI,GAAGC,IAAI,GAAGC,IAAIP,UAAUL,MAAM,EAAEa,GAAGC,GAAGJ,IAAIE,GAAGF,KAAK,GAAGC,KAAK,EAAG;YACxE,MAAMI,KAAKV,SAAS,CAACK,EAAE,GAAG;YAC1B,MAAMM,KAAKX,SAAS,CAACK,IAAI,EAAE,GAAG;YAC9B,MAAMO,KAAKZ,SAAS,CAACK,IAAI,EAAE,GAAG;YAC9B,MAAMQ,KAAKnB,MAAM,CAACgB,GAAG;YACrB,MAAMI,KAAKpB,MAAM,CAACgB,KAAK,EAAE;YACzB,MAAMK,KAAKrB,MAAM,CAACiB,GAAG;YACrB,MAAMK,KAAKtB,MAAM,CAACiB,KAAK,EAAE;YACzB,MAAMM,KAAKvB,MAAM,CAACkB,GAAG;YACrB,MAAMM,KAAKxB,MAAM,CAACkB,KAAK,EAAE;YAEzB,MAAMO,KAAKJ,KAAKF;YAChB,MAAMO,KAAKJ,KAAKF;YAChB,MAAMO,KAAKJ,KAAKJ;YAChB,MAAMS,KAAKJ,KAAKJ;YAChB,MAAMS,KAAK,CAACJ,KAAKG,KAAKF,KAAKC,EAAC,IAAK;YAEjC,IAAIG,KAAKC,GAAG,CAACF,MAAM,MAAM;gBACvB,uEAAuE;gBACvE,qEAAqE;gBACrE,0DAA0D;gBAC1D,IAAItB,OAAOyB,WAAW;oBACpBzB,KAAKC,KAAK;oBACV,KAAK,MAAMG,KAAKN,KAAME,MAAMP,MAAM,CAACW,IAAI,EAAE,EAAEH,MAAMR,MAAM,CAACW,IAAI,IAAI,EAAE;oBAClEJ,MAAMF,KAAKJ,MAAM,EAAEO,MAAMH,KAAKJ,MAAM;gBACtC;gBACA,MAAMgC,IAAI,MAAMH,KAAKI,IAAI,CAAC,CAAC3B,KAAKY,EAAC,IAAKS,KAAK,CAACpB,KAAKY,EAAC,IAAKO;gBACvDb,IAAI,CAACK,KAAKI,EAAC,IAAK,IAAIU,IAAIL;gBACxBb,IAAI,CAACK,KAAKI,EAAC,IAAK,IAAIS,IAAIN;YAC1B,OAAO;gBACL,MAAMQ,IAAI,IAAIN;gBACd,MAAMO,KAAKX,KAAKA,KAAKC,KAAKA;gBAC1B,MAAMW,KAAKV,KAAKA,KAAKC,KAAKA;gBAC1Bd,IAAIK,KAAK,CAACS,KAAKQ,KAAKV,KAAKW,EAAC,IAAKF;gBAC/BpB,IAAIK,KAAK,CAACK,KAAKY,KAAKV,KAAKS,EAAC,IAAKD;YACjC;YACA1B,aAAa,CAACG,EAAE,GAAGE;YACnBL,aAAa,CAACG,IAAI,EAAE,GAAGG;QACzB;QAEA,8BAA8B;QAC9B,IAAIuB,IAAIjC,IAAI,CAACA,KAAKJ,MAAM,GAAG,EAAE;QAC7B,IAAIsC,IAAIC,KAAKF,IAAI;QACjB,IAAIG,IAAItB,KAAKnB,MAAM,CAAC,IAAIsC,EAAE;QAC1B,IAAII,IAAItB,KAAKpB,MAAM,CAAC,IAAIsC,IAAI,EAAE;QAC9BpC,QAAQyC,IAAI,CAAC;QACb,IAAK,IAAIhC,IAAI,GAAGA,IAAIN,KAAKJ,MAAM,EAAE,EAAEU,EAAG;YACpC2B,IAAIjC,IAAI,CAACM,EAAE;YACX4B,KAAKC,IAAIC,KAAKtB,IAAIuB,KAAKtB;YACvBoB,KAAKF,IAAI,GAAGnB,KAAKnB,MAAM,CAAC,IAAIsC,EAAE,EAAElB,KAAKpB,MAAM,CAAC,IAAIsC,IAAI,EAAE;YACtDpC,OAAO,CAACqC,KAAK,EAAE,GAAGrC,OAAO,CAACsC,GAAG,GAAGE,KAAKtB;YACrClB,OAAO,CAACqC,KAAK,EAAE,GAAGrC,OAAO,CAACsC,KAAK,EAAE,GAAGrB,KAAKsB;QAC3C;IACF;IACAG,OAAOC,OAAO,EAAE;QACd,MAAMC,SAASD,WAAW,OAAOA,UAAU,IAAIzD,gDAAIA,GAAG4C;QACtD,MAAM,EAACxC,UAAU,EAACuD,SAAS,EAAEC,OAAO,EAAE3C,IAAI,EAAC,EAAEI,aAAa,EAAEP,OAAO,EAAC,GAAG,IAAI;QAC3E,IAAIG,KAAKJ,MAAM,IAAI,GAAG,OAAO;QAC7B,IAAK,IAAIU,IAAI,GAAGE,IAAIkC,UAAU9C,MAAM,EAAEU,IAAIE,GAAG,EAAEF,EAAG;YAChD,MAAMC,IAAImC,SAAS,CAACpC,EAAE;YACtB,IAAIC,IAAID,GAAG;YACX,MAAMsC,KAAKnB,KAAKoB,KAAK,CAACvC,IAAI,KAAK;YAC/B,MAAMwC,KAAKrB,KAAKoB,KAAK,CAACtC,IAAI,KAAK;YAC/B,MAAMwC,KAAK3C,aAAa,CAACwC,GAAG;YAC5B,MAAMI,KAAK5C,aAAa,CAACwC,KAAK,EAAE;YAChC,MAAMK,KAAK7C,aAAa,CAAC0C,GAAG;YAC5B,MAAMI,KAAK9C,aAAa,CAAC0C,KAAK,EAAE;YAChC,IAAI,CAACK,cAAc,CAACJ,IAAIC,IAAIC,IAAIC,IAAIV;QACtC;QACA,IAAIY,IAAIC,KAAKrD,IAAI,CAACA,KAAKJ,MAAM,GAAG,EAAE;QAClC,IAAK,IAAIU,IAAI,GAAGA,IAAIN,KAAKJ,MAAM,EAAE,EAAEU,EAAG;YACpC8C,KAAKC,IAAIA,KAAKrD,IAAI,CAACM,EAAE;YACrB,MAAMgD,IAAI7B,KAAKoB,KAAK,CAACF,OAAO,CAACU,GAAG,GAAG,KAAK;YACxC,MAAM5C,IAAIL,aAAa,CAACkD,EAAE;YAC1B,MAAM5C,IAAIN,aAAa,CAACkD,IAAI,EAAE;YAC9B,MAAMC,IAAIH,KAAK;YACf,MAAMI,IAAI,IAAI,CAACC,QAAQ,CAAChD,GAAGC,GAAGb,OAAO,CAAC0D,IAAI,EAAE,EAAE1D,OAAO,CAAC0D,IAAI,EAAE;YAC5D,IAAIC,GAAG,IAAI,CAACL,cAAc,CAAC1C,GAAGC,GAAG8C,CAAC,CAAC,EAAE,EAAEA,CAAC,CAAC,EAAE,EAAEhB;QAC/C;QACA,OAAOC,UAAUA,OAAOiB,KAAK;IAC/B;IACAC,aAAanB,OAAO,EAAE;QACpB,MAAMC,SAASD,WAAW,OAAOA,UAAU,IAAIzD,gDAAIA,GAAG4C;QACtDa,QAAQoB,IAAI,CAAC,IAAI,CAACxE,IAAI,EAAE,IAAI,CAACC,IAAI,EAAE,IAAI,CAACC,IAAI,GAAG,IAAI,CAACF,IAAI,EAAE,IAAI,CAACG,IAAI,GAAG,IAAI,CAACF,IAAI;QAC/E,OAAOoD,UAAUA,OAAOiB,KAAK;IAC/B;IACAG,WAAWvD,CAAC,EAAEkC,OAAO,EAAE;QACrB,MAAMC,SAASD,WAAW,OAAOA,UAAU,IAAIzD,gDAAIA,GAAG4C;QACtD,MAAMhC,SAAS,IAAI,CAACmE,KAAK,CAACxD;QAC1B,IAAIX,WAAW,QAAQ,CAACA,OAAOC,MAAM,EAAE;QACvC4C,QAAQuB,MAAM,CAACpE,MAAM,CAAC,EAAE,EAAEA,MAAM,CAAC,EAAE;QACnC,IAAIa,IAAIb,OAAOC,MAAM;QACrB,MAAOD,MAAM,CAAC,EAAE,KAAKA,MAAM,CAACa,IAAE,EAAE,IAAIb,MAAM,CAAC,EAAE,KAAKA,MAAM,CAACa,IAAE,EAAE,IAAIA,IAAI,EAAGA,KAAK;QAC7E,IAAK,IAAIF,IAAI,GAAGA,IAAIE,GAAGF,KAAK,EAAG;YAC7B,IAAIX,MAAM,CAACW,EAAE,KAAKX,MAAM,CAACW,IAAE,EAAE,IAAIX,MAAM,CAACW,IAAE,EAAE,KAAKX,MAAM,CAACW,IAAE,EAAE,EAC1DkC,QAAQwB,MAAM,CAACrE,MAAM,CAACW,EAAE,EAAEX,MAAM,CAACW,IAAI,EAAE;QAC3C;QACAkC,QAAQyB,SAAS;QACjB,OAAOxB,UAAUA,OAAOiB,KAAK;IAC/B;IACA,CAACQ,eAAe;QACd,MAAM,EAAC/E,UAAU,EAACQ,MAAM,EAAC,EAAC,GAAG,IAAI;QACjC,IAAK,IAAIW,IAAI,GAAGE,IAAIb,OAAOC,MAAM,GAAG,GAAGU,IAAIE,GAAG,EAAEF,EAAG;YACjD,MAAM6D,OAAO,IAAI,CAACC,WAAW,CAAC9D;YAC9B,IAAI6D,MAAMA,KAAKE,KAAK,GAAG/D,GAAG,MAAM6D;QAClC;IACF;IACAC,YAAY9D,CAAC,EAAE;QACb,MAAMgE,UAAU,IAAItF,mDAAOA;QAC3B,IAAI,CAAC6E,UAAU,CAACvD,GAAGgE;QACnB,OAAOA,QAAQZ,KAAK;IACtB;IACAP,eAAef,EAAE,EAAEC,EAAE,EAAEvB,EAAE,EAAEC,EAAE,EAAEyB,OAAO,EAAE;QACtC,IAAI+B;QACJ,MAAMC,KAAK,IAAI,CAACC,WAAW,CAACrC,IAAIC;QAChC,MAAMqC,KAAK,IAAI,CAACD,WAAW,CAAC3D,IAAIC;QAChC,IAAIyD,OAAO,KAAKE,OAAO,GAAG;YACxBlC,QAAQuB,MAAM,CAAC3B,IAAIC;YACnBG,QAAQwB,MAAM,CAAClD,IAAIC;QACrB,OAAO,IAAIwD,IAAI,IAAI,CAACI,YAAY,CAACvC,IAAIC,IAAIvB,IAAIC,IAAIyD,IAAIE,KAAK;YACxDlC,QAAQuB,MAAM,CAACQ,CAAC,CAAC,EAAE,EAAEA,CAAC,CAAC,EAAE;YACzB/B,QAAQwB,MAAM,CAACO,CAAC,CAAC,EAAE,EAAEA,CAAC,CAAC,EAAE;QAC3B;IACF;IACAK,SAAStE,CAAC,EAAEG,CAAC,EAAEC,CAAC,EAAE;QAChB,IAAI,CAACD,IAAI,CAACA,GAAGA,MAAMA,CAAAA,KAAOC,CAAAA,IAAI,CAACA,GAAGA,MAAMA,CAAAA,GAAI,OAAO;QACnD,OAAO,IAAI,CAACvB,QAAQ,CAAC0F,KAAK,CAACvE,GAAGG,GAAGC,OAAOJ;IAC1C;IACA,CAACwE,UAAUxE,CAAC,EAAE;QACZ,MAAMyE,KAAK,IAAI,CAACjB,KAAK,CAACxD;QACtB,IAAIyE,IAAI,KAAK,MAAMxE,KAAK,IAAI,CAACpB,QAAQ,CAAC2F,SAAS,CAACxE,GAAI;YAClD,MAAM0E,KAAK,IAAI,CAAClB,KAAK,CAACvD;YACtB,uBAAuB;YACvB,IAAIyE,IAAIC,MAAM,IAAK,IAAIC,KAAK,GAAGC,KAAKJ,GAAGnF,MAAM,EAAEsF,KAAKC,IAAID,MAAM,EAAG;gBAC/D,IAAK,IAAIE,KAAK,GAAGC,KAAKL,GAAGpF,MAAM,EAAEwF,KAAKC,IAAID,MAAM,EAAG;oBACjD,IAAIL,EAAE,CAACG,GAAG,KAAKF,EAAE,CAACI,GAAG,IACdL,EAAE,CAACG,KAAK,EAAE,KAAKF,EAAE,CAACI,KAAK,EAAE,IACzBL,EAAE,CAAC,CAACG,KAAK,KAAKC,GAAG,KAAKH,EAAE,CAAC,CAACI,KAAKC,KAAK,KAAKA,GAAG,IAC5CN,EAAE,CAAC,CAACG,KAAK,KAAKC,GAAG,KAAKH,EAAE,CAAC,CAACI,KAAKC,KAAK,KAAKA,GAAG,EAAE;wBACnD,MAAM9E;wBACN,MAAM0E;oBACR;gBACF;YACF;QACF;IACF;IACAK,MAAMhF,CAAC,EAAE;QACP,MAAM,EAACF,aAAa,EAAEjB,UAAU,EAACwD,OAAO,EAAED,SAAS,EAAEzC,SAAS,EAAC,EAAC,GAAG,IAAI;QACvE,MAAMsF,KAAK5C,OAAO,CAACrC,EAAE;QACrB,IAAIiF,OAAO,CAAC,GAAG,OAAO,MAAM,mBAAmB;QAC/C,MAAM5F,SAAS,EAAE;QACjB,IAAI6F,IAAID;QACR,GAAG;YACD,MAAMjC,IAAI7B,KAAKoB,KAAK,CAAC2C,IAAI;YACzB7F,OAAO8F,IAAI,CAACrF,aAAa,CAACkD,IAAI,EAAE,EAAElD,aAAa,CAACkD,IAAI,IAAI,EAAE;YAC1DkC,IAAIA,IAAI,MAAM,IAAIA,IAAI,IAAIA,IAAI;YAC9B,IAAIvF,SAAS,CAACuF,EAAE,KAAKlF,GAAG,OAAO,oBAAoB;YACnDkF,IAAI9C,SAAS,CAAC8C,EAAE;QAClB,QAASA,MAAMD,MAAMC,MAAM,CAAC,GAAG;QAC/B,OAAO7F;IACT;IACAmE,MAAMxD,CAAC,EAAE;QACP,kDAAkD;QAClD,IAAIA,MAAM,KAAK,IAAI,CAACnB,QAAQ,CAACa,IAAI,CAACJ,MAAM,KAAK,GAAG;YAC9C,OAAO;gBAAC,IAAI,CAACN,IAAI;gBAAE,IAAI,CAACD,IAAI;gBAAE,IAAI,CAACC,IAAI;gBAAE,IAAI,CAACC,IAAI;gBAAE,IAAI,CAACH,IAAI;gBAAE,IAAI,CAACG,IAAI;gBAAE,IAAI,CAACH,IAAI;gBAAE,IAAI,CAACC,IAAI;aAAC;QACjG;QACA,MAAMM,SAAS,IAAI,CAAC2F,KAAK,CAAChF;QAC1B,IAAIX,WAAW,MAAM,OAAO;QAC5B,MAAM,EAACE,SAAS6F,CAAC,EAAC,GAAG,IAAI;QACzB,MAAMnC,IAAIjD,IAAI;QACd,OAAO,IAAI,CAACqF,SAAS,CAACD,CAAC,CAACnC,EAAE,IAAImC,CAAC,CAACnC,IAAI,EAAE,GAChC,IAAI,CAACqC,aAAa,CAACtF,GAAGX,QAAQ+F,CAAC,CAACnC,EAAE,EAAEmC,CAAC,CAACnC,IAAI,EAAE,EAAEmC,CAAC,CAACnC,IAAI,EAAE,EAAEmC,CAAC,CAACnC,IAAI,EAAE,IAChE,IAAI,CAACsC,WAAW,CAACvF,GAAGX;IAC5B;IACAkG,YAAYvF,CAAC,EAAEX,MAAM,EAAE;QACrB,MAAMa,IAAIb,OAAOC,MAAM;QACvB,IAAIkG,IAAI;QACR,IAAI1D,IAAIC,IAAIvB,KAAKnB,MAAM,CAACa,IAAI,EAAE,EAAEO,KAAKpB,MAAM,CAACa,IAAI,EAAE;QAClD,IAAIgE,IAAIE,KAAK,IAAI,CAACD,WAAW,CAAC3D,IAAIC;QAClC,IAAIwE,IAAIQ,KAAK;QACb,IAAK,IAAIxF,IAAI,GAAGA,IAAIC,GAAGD,KAAK,EAAG;YAC7B6B,KAAKtB,IAAIuB,KAAKtB,IAAID,KAAKnB,MAAM,CAACY,EAAE,EAAEQ,KAAKpB,MAAM,CAACY,IAAI,EAAE;YACpDiE,KAAKE,IAAIA,KAAK,IAAI,CAACD,WAAW,CAAC3D,IAAIC;YACnC,IAAIyD,OAAO,KAAKE,OAAO,GAAG;gBACxBa,KAAKQ,IAAIA,KAAK;gBACd,IAAID,GAAGA,EAAEL,IAAI,CAAC3E,IAAIC;qBACb+E,IAAI;oBAAChF;oBAAIC;iBAAG;YACnB,OAAO;gBACL,IAAIwD,GAAGyB,KAAKC,KAAKC,KAAKC;gBACtB,IAAI3B,OAAO,GAAG;oBACZ,IAAI,CAACD,IAAI,IAAI,CAACI,YAAY,CAACvC,IAAIC,IAAIvB,IAAIC,IAAIyD,IAAIE,GAAE,MAAO,MAAM;oBAC9D,CAACsB,KAAKC,KAAKC,KAAKC,IAAI,GAAG5B;gBACzB,OAAO;oBACL,IAAI,CAACA,IAAI,IAAI,CAACI,YAAY,CAAC7D,IAAIC,IAAIqB,IAAIC,IAAIqC,IAAIF,GAAE,MAAO,MAAM;oBAC9D,CAAC0B,KAAKC,KAAKH,KAAKC,IAAI,GAAG1B;oBACvBgB,KAAKQ,IAAIA,KAAK,IAAI,CAACK,SAAS,CAACJ,KAAKC;oBAClC,IAAIV,MAAMQ,IAAI,IAAI,CAACM,KAAK,CAAC/F,GAAGiF,IAAIQ,IAAID,GAAGA,EAAElG,MAAM;oBAC/C,IAAIkG,GAAGA,EAAEL,IAAI,CAACO,KAAKC;yBACdH,IAAI;wBAACE;wBAAKC;qBAAI;gBACrB;gBACAV,KAAKQ,IAAIA,KAAK,IAAI,CAACK,SAAS,CAACF,KAAKC;gBAClC,IAAIZ,MAAMQ,IAAI,IAAI,CAACM,KAAK,CAAC/F,GAAGiF,IAAIQ,IAAID,GAAGA,EAAElG,MAAM;gBAC/C,IAAIkG,GAAGA,EAAEL,IAAI,CAACS,KAAKC;qBACdL,IAAI;oBAACI;oBAAKC;iBAAI;YACrB;QACF;QACA,IAAIL,GAAG;YACLP,KAAKQ,IAAIA,KAAK,IAAI,CAACK,SAAS,CAACN,CAAC,CAAC,EAAE,EAAEA,CAAC,CAAC,EAAE;YACvC,IAAIP,MAAMQ,IAAI,IAAI,CAACM,KAAK,CAAC/F,GAAGiF,IAAIQ,IAAID,GAAGA,EAAElG,MAAM;QACjD,OAAO,IAAI,IAAI,CAACgF,QAAQ,CAACtE,GAAG,CAAC,IAAI,CAAClB,IAAI,GAAG,IAAI,CAACE,IAAI,IAAI,GAAG,CAAC,IAAI,CAACD,IAAI,GAAG,IAAI,CAACE,IAAI,IAAI,IAAI;YACrF,OAAO;gBAAC,IAAI,CAACD,IAAI;gBAAE,IAAI,CAACD,IAAI;gBAAE,IAAI,CAACC,IAAI;gBAAE,IAAI,CAACC,IAAI;gBAAE,IAAI,CAACH,IAAI;gBAAE,IAAI,CAACG,IAAI;gBAAE,IAAI,CAACH,IAAI;gBAAE,IAAI,CAACC,IAAI;aAAC;QACjG;QACA,OAAOyG;IACT;IACAnB,aAAavC,EAAE,EAAEC,EAAE,EAAEvB,EAAE,EAAEC,EAAE,EAAEyD,EAAE,EAAEE,EAAE,EAAE;QACnC,qEAAqE;QACrE,MAAM4B,OAAO9B,KAAKE;QAClB,IAAI4B,MAAM,CAAClE,IAAIC,IAAIvB,IAAIC,IAAIyD,IAAIE,GAAG,GAAG;YAAC5D;YAAIC;YAAIqB;YAAIC;YAAIqC;YAAIF;SAAG;QAC7D,MAAO,KAAM;YACX,IAAIA,OAAO,KAAKE,OAAO,GAAG,OAAO4B,OAAO;gBAACxF;gBAAIC;gBAAIqB;gBAAIC;aAAG,GAAG;gBAACD;gBAAIC;gBAAIvB;gBAAIC;aAAG;YAC3E,IAAIyD,KAAKE,IAAI,OAAO;YACpB,IAAIjE,GAAGC,GAAG6F,IAAI/B,MAAME;YACpB,IAAI6B,IAAI,GAAQ9F,IAAI2B,KAAK,CAACtB,KAAKsB,EAAC,IAAM,KAAI,CAAC7C,IAAI,GAAG8C,EAAC,IAAMtB,CAAAA,KAAKsB,EAAC,GAAI3B,IAAI,IAAI,CAACnB,IAAI;iBAC3E,IAAIgH,IAAI,GAAQ9F,IAAI2B,KAAK,CAACtB,KAAKsB,EAAC,IAAM,KAAI,CAAC/C,IAAI,GAAGgD,EAAC,IAAMtB,CAAAA,KAAKsB,EAAC,GAAI3B,IAAI,IAAI,CAACrB,IAAI;iBAChF,IAAIkH,IAAI,GAAQ7F,IAAI2B,KAAK,CAACtB,KAAKsB,EAAC,IAAM,KAAI,CAAC/C,IAAI,GAAG8C,EAAC,IAAMtB,CAAAA,KAAKsB,EAAC,GAAI3B,IAAI,IAAI,CAACnB,IAAI;iBAChFoB,IAAI2B,KAAK,CAACtB,KAAKsB,EAAC,IAAM,KAAI,CAACjD,IAAI,GAAGgD,EAAC,IAAMtB,CAAAA,KAAKsB,EAAC,GAAI3B,IAAI,IAAI,CAACrB,IAAI;YACrE,IAAIoF,IAAIpC,KAAK3B,GAAG4B,KAAK3B,GAAG8D,KAAK,IAAI,CAACC,WAAW,CAACrC,IAAIC;iBAC7CvB,KAAKL,GAAGM,KAAKL,GAAGgE,KAAK,IAAI,CAACD,WAAW,CAAC3D,IAAIC;QACjD;IACF;IACA6E,cAActF,CAAC,EAAEX,MAAM,EAAE6G,GAAG,EAAEC,GAAG,EAAEC,GAAG,EAAEC,GAAG,EAAE;QAC3C,IAAIb,IAAIc,MAAMC,IAAI,CAAClH,SAAS6D;QAC5B,IAAIA,IAAI,IAAI,CAACC,QAAQ,CAACqC,CAAC,CAAC,EAAE,EAAEA,CAAC,CAAC,EAAE,EAAEU,KAAKC,MAAMX,EAAEgB,OAAO,CAACtD,CAAC,CAAC,EAAE,EAAEA,CAAC,CAAC,EAAE;QACjE,IAAIA,IAAI,IAAI,CAACC,QAAQ,CAACqC,CAAC,CAACA,EAAElG,MAAM,GAAG,EAAE,EAAEkG,CAAC,CAACA,EAAElG,MAAM,GAAG,EAAE,EAAE8G,KAAKC,MAAMb,EAAEL,IAAI,CAACjC,CAAC,CAAC,EAAE,EAAEA,CAAC,CAAC,EAAE;QACpF,IAAIsC,IAAI,IAAI,CAACD,WAAW,CAACvF,GAAGwF,IAAI;YAC9B,IAAK,IAAIvF,IAAI,GAAGC,IAAIsF,EAAElG,MAAM,EAAE4E,IAAIE,KAAK,IAAI,CAAC0B,SAAS,CAACN,CAAC,CAACtF,IAAI,EAAE,EAAEsF,CAAC,CAACtF,IAAI,EAAE,GAAGD,IAAIC,GAAGD,KAAK,EAAG;gBACxFiE,KAAKE,IAAIA,KAAK,IAAI,CAAC0B,SAAS,CAACN,CAAC,CAACvF,EAAE,EAAEuF,CAAC,CAACvF,IAAI,EAAE;gBAC3C,IAAIiE,MAAME,IAAInE,IAAI,IAAI,CAAC8F,KAAK,CAAC/F,GAAGkE,IAAIE,IAAIoB,GAAGvF,IAAIC,IAAIsF,EAAElG,MAAM;YAC7D;QACF,OAAO,IAAI,IAAI,CAACgF,QAAQ,CAACtE,GAAG,CAAC,IAAI,CAAClB,IAAI,GAAG,IAAI,CAACE,IAAI,IAAI,GAAG,CAAC,IAAI,CAACD,IAAI,GAAG,IAAI,CAACE,IAAI,IAAI,IAAI;YACrFuG,IAAI;gBAAC,IAAI,CAAC1G,IAAI;gBAAE,IAAI,CAACC,IAAI;gBAAE,IAAI,CAACC,IAAI;gBAAE,IAAI,CAACD,IAAI;gBAAE,IAAI,CAACC,IAAI;gBAAE,IAAI,CAACC,IAAI;gBAAE,IAAI,CAACH,IAAI;gBAAE,IAAI,CAACG,IAAI;aAAC;QAC9F;QACA,OAAOuG;IACT;IACAO,MAAM/F,CAAC,EAAEiF,EAAE,EAAEQ,EAAE,EAAED,CAAC,EAAEvF,CAAC,EAAE;QACrB,MAAOgF,OAAOQ,GAAI;YAChB,IAAItF,GAAGC;YACP,OAAQ6E;gBACN,KAAK;oBAAQA,KAAK;oBAAQ,UAAU,WAAW;gBAC/C,KAAK;oBAAQA,KAAK,GAAQ9E,IAAI,IAAI,CAACnB,IAAI,EAAEoB,IAAI,IAAI,CAACrB,IAAI;oBAAE,OAAO,MAAM;gBACrE,KAAK;oBAAQkG,KAAK;oBAAQ,UAAU,YAAY;gBAChD,KAAK;oBAAQA,KAAK,IAAQ9E,IAAI,IAAI,CAACnB,IAAI,EAAEoB,IAAI,IAAI,CAACnB,IAAI;oBAAE,OAAO,QAAQ;gBACvE,KAAK;oBAAQgG,KAAK;oBAAQ,UAAU,eAAe;gBACnD,KAAK;oBAAQA,KAAK,GAAQ9E,IAAI,IAAI,CAACrB,IAAI,EAAEsB,IAAI,IAAI,CAACnB,IAAI;oBAAE,OAAO,SAAS;gBACxE,KAAK;oBAAQgG,KAAK;oBAAQ,UAAU,cAAc;gBAClD,KAAK;oBAAQA,KAAK,GAAQ9E,IAAI,IAAI,CAACrB,IAAI,EAAEsB,IAAI,IAAI,CAACrB,IAAI;oBAAE,OAAO,OAAO;YACxE;YACA,wEAAwE;YACxE,yDAAyD;YACzD,IAAI,CAACyG,CAAC,CAACvF,EAAE,KAAKE,KAAKqF,CAAC,CAACvF,IAAI,EAAE,KAAKG,CAAAA,KAAM,IAAI,CAACkE,QAAQ,CAACtE,GAAGG,GAAGC,IAAI;gBAC5DoF,EAAEiB,MAAM,CAACxG,GAAG,GAAGE,GAAGC,IAAIH,KAAK;YAC7B;QACF;QACA,OAAOA;IACT;IACAkD,SAASrB,EAAE,EAAEC,EAAE,EAAE2E,EAAE,EAAEC,EAAE,EAAE;QACvB,IAAI3D,IAAI4D,UAAUX,GAAG9F,GAAGC;QACxB,IAAIuG,KAAK,GAAG;YACV,IAAI5E,MAAM,IAAI,CAAChD,IAAI,EAAE,OAAO;YAC5B,IAAI,CAACkH,IAAI,CAAC,IAAI,CAAClH,IAAI,GAAGgD,EAAC,IAAK4E,EAAC,IAAK3D,GAAG5C,IAAI,IAAI,CAACrB,IAAI,EAAEoB,IAAI2B,KAAK,CAACkB,IAAIiD,CAAAA,IAAKS;QACzE,OAAO,IAAIC,KAAK,GAAG;YACjB,IAAI5E,MAAM,IAAI,CAAC9C,IAAI,EAAE,OAAO;YAC5B,IAAI,CAACgH,IAAI,CAAC,IAAI,CAAChH,IAAI,GAAG8C,EAAC,IAAK4E,EAAC,IAAK3D,GAAG5C,IAAI,IAAI,CAACnB,IAAI,EAAEkB,IAAI2B,KAAK,CAACkB,IAAIiD,CAAAA,IAAKS;QACzE;QACA,IAAIA,KAAK,GAAG;YACV,IAAI5E,MAAM,IAAI,CAAC9C,IAAI,EAAE,OAAO;YAC5B,IAAI,CAACiH,IAAI,CAAC,IAAI,CAACjH,IAAI,GAAG8C,EAAC,IAAK4E,EAAC,IAAK1D,GAAG7C,IAAI,IAAI,CAACnB,IAAI,EAAEoB,IAAI2B,KAAK,CAACiB,IAAIiD,CAAAA,IAAKU;QACzE,OAAO,IAAID,KAAK,GAAG;YACjB,IAAI5E,MAAM,IAAI,CAAChD,IAAI,EAAE,OAAO;YAC5B,IAAI,CAACmH,IAAI,CAAC,IAAI,CAACnH,IAAI,GAAGgD,EAAC,IAAK4E,EAAC,IAAK1D,GAAG7C,IAAI,IAAI,CAACrB,IAAI,EAAEsB,IAAI2B,KAAK,CAACiB,IAAIiD,CAAAA,IAAKU;QACzE;QACA,OAAO;YAACxG;YAAGC;SAAE;IACf;IACA0F,UAAU3F,CAAC,EAAEC,CAAC,EAAE;QACd,OAAO,CAACD,MAAM,IAAI,CAACrB,IAAI,GAAG,IACpBqB,MAAM,IAAI,CAACnB,IAAI,GAAG,IAAS,CAAK,IAC/BoB,CAAAA,MAAM,IAAI,CAACrB,IAAI,GAAG,IACnBqB,MAAM,IAAI,CAACnB,IAAI,GAAG,IAAS,CAAK;IACxC;IACAkF,YAAYhE,CAAC,EAAEC,CAAC,EAAE;QAChB,OAAO,CAACD,IAAI,IAAI,CAACrB,IAAI,GAAG,IAClBqB,IAAI,IAAI,CAACnB,IAAI,GAAG,IAAS,CAAK,IAC7BoB,CAAAA,IAAI,IAAI,CAACrB,IAAI,GAAG,IACjBqB,IAAI,IAAI,CAACnB,IAAI,GAAG,IAAS,CAAK;IACtC;IACAoG,UAAUG,CAAC,EAAE;QACX,IAAIA,KAAKA,EAAElG,MAAM,GAAG,GAAG;YACrB,IAAK,IAAIU,IAAI,GAAGA,IAAIwF,EAAElG,MAAM,EAAEU,KAAI,EAAG;gBACnC,MAAMC,IAAI,CAACD,IAAI,KAAKwF,EAAElG,MAAM,EAAEuH,IAAI,CAAC7G,IAAI,KAAKwF,EAAElG,MAAM;gBACpD,IAAIkG,CAAC,CAACxF,EAAE,KAAKwF,CAAC,CAACvF,EAAE,IAAIuF,CAAC,CAACvF,EAAE,KAAKuF,CAAC,CAACqB,EAAE,IAAIrB,CAAC,CAACxF,IAAI,EAAE,KAAKwF,CAAC,CAACvF,IAAI,EAAE,IAAIuF,CAAC,CAACvF,IAAI,EAAE,KAAKuF,CAAC,CAACqB,IAAI,EAAE,EAAE;oBACpFrB,EAAEiB,MAAM,CAACxG,GAAG,IAAID,KAAK;gBACvB;YACF;YACA,IAAI,CAACwF,EAAElG,MAAM,EAAEkG,IAAI;QACrB;QACA,OAAOA;IACT;AACF","sources":["webpack://nextchat/./node_modules/d3-delaunay/src/voronoi.js?b97e"],"sourcesContent":["import Path from \"./path.js\";\nimport Polygon from \"./polygon.js\";\n\nexport default class Voronoi {\n  constructor(delaunay, [xmin, ymin, xmax, ymax] = [0, 0, 960, 500]) {\n    if (!((xmax = +xmax) >= (xmin = +xmin)) || !((ymax = +ymax) >= (ymin = +ymin))) throw new Error(\"invalid bounds\");\n    this.delaunay = delaunay;\n    this._circumcenters = new Float64Array(delaunay.points.length * 2);\n    this.vectors = new Float64Array(delaunay.points.length * 2);\n    this.xmax = xmax, this.xmin = xmin;\n    this.ymax = ymax, this.ymin = ymin;\n    this._init();\n  }\n  update() {\n    this.delaunay.update();\n    this._init();\n    return this;\n  }\n  _init() {\n    const {delaunay: {points, hull, triangles}, vectors} = this;\n    let bx, by; // lazily computed barycenter of the hull\n\n    // Compute circumcenters.\n    const circumcenters = this.circumcenters = this._circumcenters.subarray(0, triangles.length / 3 * 2);\n    for (let i = 0, j = 0, n = triangles.length, x, y; i < n; i += 3, j += 2) {\n      const t1 = triangles[i] * 2;\n      const t2 = triangles[i + 1] * 2;\n      const t3 = triangles[i + 2] * 2;\n      const x1 = points[t1];\n      const y1 = points[t1 + 1];\n      const x2 = points[t2];\n      const y2 = points[t2 + 1];\n      const x3 = points[t3];\n      const y3 = points[t3 + 1];\n\n      const dx = x2 - x1;\n      const dy = y2 - y1;\n      const ex = x3 - x1;\n      const ey = y3 - y1;\n      const ab = (dx * ey - dy * ex) * 2;\n\n      if (Math.abs(ab) < 1e-9) {\n        // For a degenerate triangle, the circumcenter is at the infinity, in a\n        // direction orthogonal to the halfedge and away from the “center” of\n        // the diagram <bx, by>, defined as the hull’s barycenter.\n        if (bx === undefined) {\n          bx = by = 0;\n          for (const i of hull) bx += points[i * 2], by += points[i * 2 + 1];\n          bx /= hull.length, by /= hull.length;\n        }\n        const a = 1e9 * Math.sign((bx - x1) * ey - (by - y1) * ex);\n        x = (x1 + x3) / 2 - a * ey;\n        y = (y1 + y3) / 2 + a * ex;\n      } else {\n        const d = 1 / ab;\n        const bl = dx * dx + dy * dy;\n        const cl = ex * ex + ey * ey;\n        x = x1 + (ey * bl - dy * cl) * d;\n        y = y1 + (dx * cl - ex * bl) * d;\n      }\n      circumcenters[j] = x;\n      circumcenters[j + 1] = y;\n    }\n\n    // Compute exterior cell rays.\n    let h = hull[hull.length - 1];\n    let p0, p1 = h * 4;\n    let x0, x1 = points[2 * h];\n    let y0, y1 = points[2 * h + 1];\n    vectors.fill(0);\n    for (let i = 0; i < hull.length; ++i) {\n      h = hull[i];\n      p0 = p1, x0 = x1, y0 = y1;\n      p1 = h * 4, x1 = points[2 * h], y1 = points[2 * h + 1];\n      vectors[p0 + 2] = vectors[p1] = y0 - y1;\n      vectors[p0 + 3] = vectors[p1 + 1] = x1 - x0;\n    }\n  }\n  render(context) {\n    const buffer = context == null ? context = new Path : undefined;\n    const {delaunay: {halfedges, inedges, hull}, circumcenters, vectors} = this;\n    if (hull.length <= 1) return null;\n    for (let i = 0, n = halfedges.length; i < n; ++i) {\n      const j = halfedges[i];\n      if (j < i) continue;\n      const ti = Math.floor(i / 3) * 2;\n      const tj = Math.floor(j / 3) * 2;\n      const xi = circumcenters[ti];\n      const yi = circumcenters[ti + 1];\n      const xj = circumcenters[tj];\n      const yj = circumcenters[tj + 1];\n      this._renderSegment(xi, yi, xj, yj, context);\n    }\n    let h0, h1 = hull[hull.length - 1];\n    for (let i = 0; i < hull.length; ++i) {\n      h0 = h1, h1 = hull[i];\n      const t = Math.floor(inedges[h1] / 3) * 2;\n      const x = circumcenters[t];\n      const y = circumcenters[t + 1];\n      const v = h0 * 4;\n      const p = this._project(x, y, vectors[v + 2], vectors[v + 3]);\n      if (p) this._renderSegment(x, y, p[0], p[1], context);\n    }\n    return buffer && buffer.value();\n  }\n  renderBounds(context) {\n    const buffer = context == null ? context = new Path : undefined;\n    context.rect(this.xmin, this.ymin, this.xmax - this.xmin, this.ymax - this.ymin);\n    return buffer && buffer.value();\n  }\n  renderCell(i, context) {\n    const buffer = context == null ? context = new Path : undefined;\n    const points = this._clip(i);\n    if (points === null || !points.length) return;\n    context.moveTo(points[0], points[1]);\n    let n = points.length;\n    while (points[0] === points[n-2] && points[1] === points[n-1] && n > 1) n -= 2;\n    for (let i = 2; i < n; i += 2) {\n      if (points[i] !== points[i-2] || points[i+1] !== points[i-1])\n        context.lineTo(points[i], points[i + 1]);\n    }\n    context.closePath();\n    return buffer && buffer.value();\n  }\n  *cellPolygons() {\n    const {delaunay: {points}} = this;\n    for (let i = 0, n = points.length / 2; i < n; ++i) {\n      const cell = this.cellPolygon(i);\n      if (cell) cell.index = i, yield cell;\n    }\n  }\n  cellPolygon(i) {\n    const polygon = new Polygon;\n    this.renderCell(i, polygon);\n    return polygon.value();\n  }\n  _renderSegment(x0, y0, x1, y1, context) {\n    let S;\n    const c0 = this._regioncode(x0, y0);\n    const c1 = this._regioncode(x1, y1);\n    if (c0 === 0 && c1 === 0) {\n      context.moveTo(x0, y0);\n      context.lineTo(x1, y1);\n    } else if (S = this._clipSegment(x0, y0, x1, y1, c0, c1)) {\n      context.moveTo(S[0], S[1]);\n      context.lineTo(S[2], S[3]);\n    }\n  }\n  contains(i, x, y) {\n    if ((x = +x, x !== x) || (y = +y, y !== y)) return false;\n    return this.delaunay._step(i, x, y) === i;\n  }\n  *neighbors(i) {\n    const ci = this._clip(i);\n    if (ci) for (const j of this.delaunay.neighbors(i)) {\n      const cj = this._clip(j);\n      // find the common edge\n      if (cj) loop: for (let ai = 0, li = ci.length; ai < li; ai += 2) {\n        for (let aj = 0, lj = cj.length; aj < lj; aj += 2) {\n          if (ci[ai] === cj[aj]\n              && ci[ai + 1] === cj[aj + 1]\n              && ci[(ai + 2) % li] === cj[(aj + lj - 2) % lj]\n              && ci[(ai + 3) % li] === cj[(aj + lj - 1) % lj]) {\n            yield j;\n            break loop;\n          }\n        }\n      }\n    }\n  }\n  _cell(i) {\n    const {circumcenters, delaunay: {inedges, halfedges, triangles}} = this;\n    const e0 = inedges[i];\n    if (e0 === -1) return null; // coincident point\n    const points = [];\n    let e = e0;\n    do {\n      const t = Math.floor(e / 3);\n      points.push(circumcenters[t * 2], circumcenters[t * 2 + 1]);\n      e = e % 3 === 2 ? e - 2 : e + 1;\n      if (triangles[e] !== i) break; // bad triangulation\n      e = halfedges[e];\n    } while (e !== e0 && e !== -1);\n    return points;\n  }\n  _clip(i) {\n    // degenerate case (1 valid point: return the box)\n    if (i === 0 && this.delaunay.hull.length === 1) {\n      return [this.xmax, this.ymin, this.xmax, this.ymax, this.xmin, this.ymax, this.xmin, this.ymin];\n    }\n    const points = this._cell(i);\n    if (points === null) return null;\n    const {vectors: V} = this;\n    const v = i * 4;\n    return this._simplify(V[v] || V[v + 1]\n        ? this._clipInfinite(i, points, V[v], V[v + 1], V[v + 2], V[v + 3])\n        : this._clipFinite(i, points));\n  }\n  _clipFinite(i, points) {\n    const n = points.length;\n    let P = null;\n    let x0, y0, x1 = points[n - 2], y1 = points[n - 1];\n    let c0, c1 = this._regioncode(x1, y1);\n    let e0, e1 = 0;\n    for (let j = 0; j < n; j += 2) {\n      x0 = x1, y0 = y1, x1 = points[j], y1 = points[j + 1];\n      c0 = c1, c1 = this._regioncode(x1, y1);\n      if (c0 === 0 && c1 === 0) {\n        e0 = e1, e1 = 0;\n        if (P) P.push(x1, y1);\n        else P = [x1, y1];\n      } else {\n        let S, sx0, sy0, sx1, sy1;\n        if (c0 === 0) {\n          if ((S = this._clipSegment(x0, y0, x1, y1, c0, c1)) === null) continue;\n          [sx0, sy0, sx1, sy1] = S;\n        } else {\n          if ((S = this._clipSegment(x1, y1, x0, y0, c1, c0)) === null) continue;\n          [sx1, sy1, sx0, sy0] = S;\n          e0 = e1, e1 = this._edgecode(sx0, sy0);\n          if (e0 && e1) this._edge(i, e0, e1, P, P.length);\n          if (P) P.push(sx0, sy0);\n          else P = [sx0, sy0];\n        }\n        e0 = e1, e1 = this._edgecode(sx1, sy1);\n        if (e0 && e1) this._edge(i, e0, e1, P, P.length);\n        if (P) P.push(sx1, sy1);\n        else P = [sx1, sy1];\n      }\n    }\n    if (P) {\n      e0 = e1, e1 = this._edgecode(P[0], P[1]);\n      if (e0 && e1) this._edge(i, e0, e1, P, P.length);\n    } else if (this.contains(i, (this.xmin + this.xmax) / 2, (this.ymin + this.ymax) / 2)) {\n      return [this.xmax, this.ymin, this.xmax, this.ymax, this.xmin, this.ymax, this.xmin, this.ymin];\n    }\n    return P;\n  }\n  _clipSegment(x0, y0, x1, y1, c0, c1) {\n    // for more robustness, always consider the segment in the same order\n    const flip = c0 < c1;\n    if (flip) [x0, y0, x1, y1, c0, c1] = [x1, y1, x0, y0, c1, c0];\n    while (true) {\n      if (c0 === 0 && c1 === 0) return flip ? [x1, y1, x0, y0] : [x0, y0, x1, y1];\n      if (c0 & c1) return null;\n      let x, y, c = c0 || c1;\n      if (c & 0b1000) x = x0 + (x1 - x0) * (this.ymax - y0) / (y1 - y0), y = this.ymax;\n      else if (c & 0b0100) x = x0 + (x1 - x0) * (this.ymin - y0) / (y1 - y0), y = this.ymin;\n      else if (c & 0b0010) y = y0 + (y1 - y0) * (this.xmax - x0) / (x1 - x0), x = this.xmax;\n      else y = y0 + (y1 - y0) * (this.xmin - x0) / (x1 - x0), x = this.xmin;\n      if (c0) x0 = x, y0 = y, c0 = this._regioncode(x0, y0);\n      else x1 = x, y1 = y, c1 = this._regioncode(x1, y1);\n    }\n  }\n  _clipInfinite(i, points, vx0, vy0, vxn, vyn) {\n    let P = Array.from(points), p;\n    if (p = this._project(P[0], P[1], vx0, vy0)) P.unshift(p[0], p[1]);\n    if (p = this._project(P[P.length - 2], P[P.length - 1], vxn, vyn)) P.push(p[0], p[1]);\n    if (P = this._clipFinite(i, P)) {\n      for (let j = 0, n = P.length, c0, c1 = this._edgecode(P[n - 2], P[n - 1]); j < n; j += 2) {\n        c0 = c1, c1 = this._edgecode(P[j], P[j + 1]);\n        if (c0 && c1) j = this._edge(i, c0, c1, P, j), n = P.length;\n      }\n    } else if (this.contains(i, (this.xmin + this.xmax) / 2, (this.ymin + this.ymax) / 2)) {\n      P = [this.xmin, this.ymin, this.xmax, this.ymin, this.xmax, this.ymax, this.xmin, this.ymax];\n    }\n    return P;\n  }\n  _edge(i, e0, e1, P, j) {\n    while (e0 !== e1) {\n      let x, y;\n      switch (e0) {\n        case 0b0101: e0 = 0b0100; continue; // top-left\n        case 0b0100: e0 = 0b0110, x = this.xmax, y = this.ymin; break; // top\n        case 0b0110: e0 = 0b0010; continue; // top-right\n        case 0b0010: e0 = 0b1010, x = this.xmax, y = this.ymax; break; // right\n        case 0b1010: e0 = 0b1000; continue; // bottom-right\n        case 0b1000: e0 = 0b1001, x = this.xmin, y = this.ymax; break; // bottom\n        case 0b1001: e0 = 0b0001; continue; // bottom-left\n        case 0b0001: e0 = 0b0101, x = this.xmin, y = this.ymin; break; // left\n      }\n      // Note: this implicitly checks for out of bounds: if P[j] or P[j+1] are\n      // undefined, the conditional statement will be executed.\n      if ((P[j] !== x || P[j + 1] !== y) && this.contains(i, x, y)) {\n        P.splice(j, 0, x, y), j += 2;\n      }\n    }\n    return j;\n  }\n  _project(x0, y0, vx, vy) {\n    let t = Infinity, c, x, y;\n    if (vy < 0) { // top\n      if (y0 <= this.ymin) return null;\n      if ((c = (this.ymin - y0) / vy) < t) y = this.ymin, x = x0 + (t = c) * vx;\n    } else if (vy > 0) { // bottom\n      if (y0 >= this.ymax) return null;\n      if ((c = (this.ymax - y0) / vy) < t) y = this.ymax, x = x0 + (t = c) * vx;\n    }\n    if (vx > 0) { // right\n      if (x0 >= this.xmax) return null;\n      if ((c = (this.xmax - x0) / vx) < t) x = this.xmax, y = y0 + (t = c) * vy;\n    } else if (vx < 0) { // left\n      if (x0 <= this.xmin) return null;\n      if ((c = (this.xmin - x0) / vx) < t) x = this.xmin, y = y0 + (t = c) * vy;\n    }\n    return [x, y];\n  }\n  _edgecode(x, y) {\n    return (x === this.xmin ? 0b0001\n        : x === this.xmax ? 0b0010 : 0b0000)\n        | (y === this.ymin ? 0b0100\n        : y === this.ymax ? 0b1000 : 0b0000);\n  }\n  _regioncode(x, y) {\n    return (x < this.xmin ? 0b0001\n        : x > this.xmax ? 0b0010 : 0b0000)\n        | (y < this.ymin ? 0b0100\n        : y > this.ymax ? 0b1000 : 0b0000);\n  }\n  _simplify(P) {\n    if (P && P.length > 4) {\n      for (let i = 0; i < P.length; i+= 2) {\n        const j = (i + 2) % P.length, k = (i + 4) % P.length;\n        if (P[i] === P[j] && P[j] === P[k] || P[i + 1] === P[j + 1] && P[j + 1] === P[k + 1]) {\n          P.splice(j, 2), i -= 2;\n        }\n      }\n      if (!P.length) P = null;\n    }\n    return P;\n  }\n}\n"],"names":["Path","Polygon","Voronoi","constructor","delaunay","xmin","ymin","xmax","ymax","Error","_circumcenters","Float64Array","points","length","vectors","_init","update","hull","triangles","bx","by","circumcenters","subarray","i","j","n","x","y","t1","t2","t3","x1","y1","x2","y2","x3","y3","dx","dy","ex","ey","ab","Math","abs","undefined","a","sign","d","bl","cl","h","p0","p1","x0","y0","fill","render","context","buffer","halfedges","inedges","ti","floor","tj","xi","yi","xj","yj","_renderSegment","h0","h1","t","v","p","_project","value","renderBounds","rect","renderCell","_clip","moveTo","lineTo","closePath","cellPolygons","cell","cellPolygon","index","polygon","S","c0","_regioncode","c1","_clipSegment","contains","_step","neighbors","ci","cj","loop","ai","li","aj","lj","_cell","e0","e","push","V","_simplify","_clipInfinite","_clipFinite","P","e1","sx0","sy0","sx1","sy1","_edgecode","_edge","flip","c","vx0","vy0","vxn","vyn","Array","from","unshift","splice","vx","vy","Infinity","k"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/d3-delaunay/src/voronoi.js\n"); /***/ }) }; ;