@zsviczian/excalidraw 0.10.0-obsidian-18 → 0.10.0-obsidian-19

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.
@@ -575,7 +575,7 @@ eval("eval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony export */
575
575
  /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
576
576
 
577
577
  "use strict";
578
- eval("eval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */ \\\"line\\\": () => (/* binding */ line),\\n/* harmony export */ \\\"linearPath\\\": () => (/* binding */ linearPath),\\n/* harmony export */ \\\"polygon\\\": () => (/* binding */ polygon),\\n/* harmony export */ \\\"rectangle\\\": () => (/* binding */ rectangle),\\n/* harmony export */ \\\"curve\\\": () => (/* binding */ curve),\\n/* harmony export */ \\\"ellipse\\\": () => (/* binding */ ellipse),\\n/* harmony export */ \\\"generateEllipseParams\\\": () => (/* binding */ generateEllipseParams),\\n/* harmony export */ \\\"ellipseWithParams\\\": () => (/* binding */ ellipseWithParams),\\n/* harmony export */ \\\"arc\\\": () => (/* binding */ arc),\\n/* harmony export */ \\\"svgPath\\\": () => (/* binding */ svgPath),\\n/* harmony export */ \\\"solidFillPolygon\\\": () => (/* binding */ solidFillPolygon),\\n/* harmony export */ \\\"patternFillPolygons\\\": () => (/* binding */ patternFillPolygons),\\n/* harmony export */ \\\"patternFillArc\\\": () => (/* binding */ patternFillArc),\\n/* harmony export */ \\\"randOffset\\\": () => (/* binding */ randOffset),\\n/* harmony export */ \\\"randOffsetWithRange\\\": () => (/* binding */ randOffsetWithRange),\\n/* harmony export */ \\\"doubleLineFillOps\\\": () => (/* binding */ doubleLineFillOps)\\n/* harmony export */ });\\n/* harmony import */ var _fillers_filler_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./fillers/filler.js */ \\\"../../../node_modules/roughjs/bin/fillers/filler.js\\\");\\n/* harmony import */ var _math_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./math.js */ \\\"../../../node_modules/roughjs/bin/math.js\\\");\\n/* harmony import */ var path_data_parser__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! path-data-parser */ \\\"../../../node_modules/path-data-parser/lib/index.js\\\");\\n\\n\\n\\nconst helper = {\\n randOffset,\\n randOffsetWithRange,\\n ellipse,\\n doubleLineOps: doubleLineFillOps,\\n};\\nfunction line(x1, y1, x2, y2, o) {\\n return { type: 'path', ops: _doubleLine(x1, y1, x2, y2, o) };\\n}\\nfunction linearPath(points, close, o) {\\n const len = (points || []).length;\\n if (len > 2) {\\n const ops = [];\\n for (let i = 0; i < (len - 1); i++) {\\n ops.push(..._doubleLine(points[i][0], points[i][1], points[i + 1][0], points[i + 1][1], o));\\n }\\n if (close) {\\n ops.push(..._doubleLine(points[len - 1][0], points[len - 1][1], points[0][0], points[0][1], o));\\n }\\n return { type: 'path', ops };\\n }\\n else if (len === 2) {\\n return line(points[0][0], points[0][1], points[1][0], points[1][1], o);\\n }\\n return { type: 'path', ops: [] };\\n}\\nfunction polygon(points, o) {\\n return linearPath(points, true, o);\\n}\\nfunction rectangle(x, y, width, height, o) {\\n const points = [\\n [x, y],\\n [x + width, y],\\n [x + width, y + height],\\n [x, y + height],\\n ];\\n return polygon(points, o);\\n}\\nfunction curve(points, o) {\\n let o1 = _curveWithOffset(points, 1 * (1 + o.roughness * 0.2), o);\\n if (!o.disableMultiStroke) {\\n const o2 = _curveWithOffset(points, 1.5 * (1 + o.roughness * 0.22), cloneOptionsAlterSeed(o));\\n o1 = o1.concat(o2);\\n }\\n return { type: 'path', ops: o1 };\\n}\\nfunction ellipse(x, y, width, height, o) {\\n const params = generateEllipseParams(width, height, o);\\n return ellipseWithParams(x, y, o, params).opset;\\n}\\nfunction generateEllipseParams(width, height, o) {\\n const psq = Math.sqrt(Math.PI * 2 * Math.sqrt((Math.pow(width / 2, 2) + Math.pow(height / 2, 2)) / 2));\\n const stepCount = Math.max(o.curveStepCount, (o.curveStepCount / Math.sqrt(200)) * psq);\\n const increment = (Math.PI * 2) / stepCount;\\n let rx = Math.abs(width / 2);\\n let ry = Math.abs(height / 2);\\n const curveFitRandomness = 1 - o.curveFitting;\\n rx += _offsetOpt(rx * curveFitRandomness, o);\\n ry += _offsetOpt(ry * curveFitRandomness, o);\\n return { increment, rx, ry };\\n}\\nfunction ellipseWithParams(x, y, o, ellipseParams) {\\n const [ap1, cp1] = _computeEllipsePoints(ellipseParams.increment, x, y, ellipseParams.rx, ellipseParams.ry, 1, ellipseParams.increment * _offset(0.1, _offset(0.4, 1, o), o), o);\\n let o1 = _curve(ap1, null, o);\\n if ((!o.disableMultiStroke) && (o.roughness !== 0)) {\\n const [ap2] = _computeEllipsePoints(ellipseParams.increment, x, y, ellipseParams.rx, ellipseParams.ry, 1.5, 0, o);\\n const o2 = _curve(ap2, null, o);\\n o1 = o1.concat(o2);\\n }\\n return {\\n estimatedPoints: cp1,\\n opset: { type: 'path', ops: o1 },\\n };\\n}\\nfunction arc(x, y, width, height, start, stop, closed, roughClosure, o) {\\n const cx = x;\\n const cy = y;\\n let rx = Math.abs(width / 2);\\n let ry = Math.abs(height / 2);\\n rx += _offsetOpt(rx * 0.01, o);\\n ry += _offsetOpt(ry * 0.01, o);\\n let strt = start;\\n let stp = stop;\\n while (strt < 0) {\\n strt += Math.PI * 2;\\n stp += Math.PI * 2;\\n }\\n if ((stp - strt) > (Math.PI * 2)) {\\n strt = 0;\\n stp = Math.PI * 2;\\n }\\n const ellipseInc = (Math.PI * 2) / o.curveStepCount;\\n const arcInc = Math.min(ellipseInc / 2, (stp - strt) / 2);\\n const ops = _arc(arcInc, cx, cy, rx, ry, strt, stp, 1, o);\\n if (!o.disableMultiStroke) {\\n const o2 = _arc(arcInc, cx, cy, rx, ry, strt, stp, 1.5, o);\\n ops.push(...o2);\\n }\\n if (closed) {\\n if (roughClosure) {\\n ops.push(..._doubleLine(cx, cy, cx + rx * Math.cos(strt), cy + ry * Math.sin(strt), o), ..._doubleLine(cx, cy, cx + rx * Math.cos(stp), cy + ry * Math.sin(stp), o));\\n }\\n else {\\n ops.push({ op: 'lineTo', data: [cx, cy] }, { op: 'lineTo', data: [cx + rx * Math.cos(strt), cy + ry * Math.sin(strt)] });\\n }\\n }\\n return { type: 'path', ops };\\n}\\nfunction svgPath(path, o) {\\n const segments = (0,path_data_parser__WEBPACK_IMPORTED_MODULE_2__.normalize)((0,path_data_parser__WEBPACK_IMPORTED_MODULE_2__.absolutize)((0,path_data_parser__WEBPACK_IMPORTED_MODULE_2__.parsePath)(path)));\\n const ops = [];\\n let first = [0, 0];\\n let current = [0, 0];\\n for (const { key, data } of segments) {\\n switch (key) {\\n case 'M': {\\n const ro = 1 * (o.maxRandomnessOffset || 0);\\n const pv = o.preserveVertices;\\n ops.push({ op: 'move', data: data.map((d) => d + (pv ? 0 : _offsetOpt(ro, o))) });\\n current = [data[0], data[1]];\\n first = [data[0], data[1]];\\n break;\\n }\\n case 'L':\\n ops.push(..._doubleLine(current[0], current[1], data[0], data[1], o));\\n current = [data[0], data[1]];\\n break;\\n case 'C': {\\n const [x1, y1, x2, y2, x, y] = data;\\n ops.push(..._bezierTo(x1, y1, x2, y2, x, y, current, o));\\n current = [x, y];\\n break;\\n }\\n case 'Z':\\n ops.push(..._doubleLine(current[0], current[1], first[0], first[1], o));\\n current = [first[0], first[1]];\\n break;\\n }\\n }\\n return { type: 'path', ops };\\n}\\n// Fills\\nfunction solidFillPolygon(polygonList, o) {\\n const ops = [];\\n for (const points of polygonList) {\\n if (points.length) {\\n const offset = o.maxRandomnessOffset || 0;\\n const len = points.length;\\n if (len > 2) {\\n ops.push({ op: 'move', data: [points[0][0] + _offsetOpt(offset, o), points[0][1] + _offsetOpt(offset, o)] });\\n for (let i = 1; i < len; i++) {\\n ops.push({ op: 'lineTo', data: [points[i][0] + _offsetOpt(offset, o), points[i][1] + _offsetOpt(offset, o)] });\\n }\\n }\\n }\\n }\\n return { type: 'fillPath', ops };\\n}\\nfunction patternFillPolygons(polygonList, o) {\\n return (0,_fillers_filler_js__WEBPACK_IMPORTED_MODULE_0__.getFiller)(o, helper).fillPolygons(polygonList, o);\\n}\\nfunction patternFillArc(x, y, width, height, start, stop, o) {\\n const cx = x;\\n const cy = y;\\n let rx = Math.abs(width / 2);\\n let ry = Math.abs(height / 2);\\n rx += _offsetOpt(rx * 0.01, o);\\n ry += _offsetOpt(ry * 0.01, o);\\n let strt = start;\\n let stp = stop;\\n while (strt < 0) {\\n strt += Math.PI * 2;\\n stp += Math.PI * 2;\\n }\\n if ((stp - strt) > (Math.PI * 2)) {\\n strt = 0;\\n stp = Math.PI * 2;\\n }\\n const increment = (stp - strt) / o.curveStepCount;\\n const points = [];\\n for (let angle = strt; angle <= stp; angle = angle + increment) {\\n points.push([cx + rx * Math.cos(angle), cy + ry * Math.sin(angle)]);\\n }\\n points.push([cx + rx * Math.cos(stp), cy + ry * Math.sin(stp)]);\\n points.push([cx, cy]);\\n return patternFillPolygons([points], o);\\n}\\nfunction randOffset(x, o) {\\n return _offsetOpt(x, o);\\n}\\nfunction randOffsetWithRange(min, max, o) {\\n return _offset(min, max, o);\\n}\\nfunction doubleLineFillOps(x1, y1, x2, y2, o) {\\n return _doubleLine(x1, y1, x2, y2, o, true);\\n}\\n// Private helpers\\nfunction cloneOptionsAlterSeed(ops) {\\n const result = Object.assign({}, ops);\\n result.randomizer = undefined;\\n if (ops.seed) {\\n result.seed = ops.seed + 1;\\n }\\n return result;\\n}\\nfunction random(ops) {\\n if (!ops.randomizer) {\\n ops.randomizer = new _math_js__WEBPACK_IMPORTED_MODULE_1__.Random(ops.seed || 0);\\n }\\n return ops.randomizer.next();\\n}\\nfunction _offset(min, max, ops, roughnessGain = 1) {\\n return ops.roughness * roughnessGain * ((random(ops) * (max - min)) + min);\\n}\\nfunction _offsetOpt(x, ops, roughnessGain = 1) {\\n return _offset(-x, x, ops, roughnessGain);\\n}\\nfunction _doubleLine(x1, y1, x2, y2, o, filling = false) {\\n const singleStroke = filling ? o.disableMultiStrokeFill : o.disableMultiStroke;\\n const o1 = _line(x1, y1, x2, y2, o, true, false);\\n if (singleStroke) {\\n return o1;\\n }\\n const o2 = _line(x1, y1, x2, y2, o, true, true);\\n return o1.concat(o2);\\n}\\nfunction _line(x1, y1, x2, y2, o, move, overlay) {\\n const lengthSq = Math.pow((x1 - x2), 2) + Math.pow((y1 - y2), 2);\\n const length = Math.sqrt(lengthSq);\\n let roughnessGain = 1;\\n if (length < 200) {\\n roughnessGain = 1;\\n }\\n else if (length > 500) {\\n roughnessGain = 0.4;\\n }\\n else {\\n roughnessGain = (-0.0016668) * length + 1.233334;\\n }\\n let offset = o.maxRandomnessOffset || 0;\\n if ((offset * offset * 100) > lengthSq) {\\n offset = length / 10;\\n }\\n const halfOffset = offset / 2;\\n const divergePoint = 0.2 + random(o) * 0.2;\\n let midDispX = o.bowing * o.maxRandomnessOffset * (y2 - y1) / 200;\\n let midDispY = o.bowing * o.maxRandomnessOffset * (x1 - x2) / 200;\\n midDispX = _offsetOpt(midDispX, o, roughnessGain);\\n midDispY = _offsetOpt(midDispY, o, roughnessGain);\\n const ops = [];\\n const randomHalf = () => _offsetOpt(halfOffset, o, roughnessGain);\\n const randomFull = () => _offsetOpt(offset, o, roughnessGain);\\n const preserveVertices = o.preserveVertices;\\n if (move) {\\n if (overlay) {\\n ops.push({\\n op: 'move', data: [\\n x1 + (preserveVertices ? 0 : randomHalf()),\\n y1 + (preserveVertices ? 0 : randomHalf()),\\n ],\\n });\\n }\\n else {\\n ops.push({\\n op: 'move', data: [\\n x1 + (preserveVertices ? 0 : _offsetOpt(offset, o, roughnessGain)),\\n y1 + (preserveVertices ? 0 : _offsetOpt(offset, o, roughnessGain)),\\n ],\\n });\\n }\\n }\\n if (overlay) {\\n ops.push({\\n op: 'bcurveTo',\\n data: [\\n midDispX + x1 + (x2 - x1) * divergePoint + randomHalf(),\\n midDispY + y1 + (y2 - y1) * divergePoint + randomHalf(),\\n midDispX + x1 + 2 * (x2 - x1) * divergePoint + randomHalf(),\\n midDispY + y1 + 2 * (y2 - y1) * divergePoint + randomHalf(),\\n x2 + (preserveVertices ? 0 : randomHalf()),\\n y2 + (preserveVertices ? 0 : randomHalf()),\\n ],\\n });\\n }\\n else {\\n ops.push({\\n op: 'bcurveTo',\\n data: [\\n midDispX + x1 + (x2 - x1) * divergePoint + randomFull(),\\n midDispY + y1 + (y2 - y1) * divergePoint + randomFull(),\\n midDispX + x1 + 2 * (x2 - x1) * divergePoint + randomFull(),\\n midDispY + y1 + 2 * (y2 - y1) * divergePoint + randomFull(),\\n x2 + (preserveVertices ? 0 : randomFull()),\\n y2 + (preserveVertices ? 0 : randomFull()),\\n ],\\n });\\n }\\n return ops;\\n}\\nfunction _curveWithOffset(points, offset, o) {\\n const ps = [];\\n ps.push([\\n points[0][0] + _offsetOpt(offset, o),\\n points[0][1] + _offsetOpt(offset, o),\\n ]);\\n ps.push([\\n points[0][0] + _offsetOpt(offset, o),\\n points[0][1] + _offsetOpt(offset, o),\\n ]);\\n for (let i = 1; i < points.length; i++) {\\n ps.push([\\n points[i][0] + _offsetOpt(offset, o),\\n points[i][1] + _offsetOpt(offset, o),\\n ]);\\n if (i === (points.length - 1)) {\\n ps.push([\\n points[i][0] + _offsetOpt(offset, o),\\n points[i][1] + _offsetOpt(offset, o),\\n ]);\\n }\\n }\\n return _curve(ps, null, o);\\n}\\nfunction _curve(points, closePoint, o) {\\n const len = points.length;\\n const ops = [];\\n if (len > 3) {\\n const b = [];\\n const s = 1 - o.curveTightness;\\n ops.push({ op: 'move', data: [points[1][0], points[1][1]] });\\n for (let i = 1; (i + 2) < len; i++) {\\n const cachedVertArray = points[i];\\n b[0] = [cachedVertArray[0], cachedVertArray[1]];\\n b[1] = [cachedVertArray[0] + (s * points[i + 1][0] - s * points[i - 1][0]) / 6, cachedVertArray[1] + (s * points[i + 1][1] - s * points[i - 1][1]) / 6];\\n b[2] = [points[i + 1][0] + (s * points[i][0] - s * points[i + 2][0]) / 6, points[i + 1][1] + (s * points[i][1] - s * points[i + 2][1]) / 6];\\n b[3] = [points[i + 1][0], points[i + 1][1]];\\n ops.push({ op: 'bcurveTo', data: [b[1][0], b[1][1], b[2][0], b[2][1], b[3][0], b[3][1]] });\\n }\\n if (closePoint && closePoint.length === 2) {\\n const ro = o.maxRandomnessOffset;\\n ops.push({ op: 'lineTo', data: [closePoint[0] + _offsetOpt(ro, o), closePoint[1] + _offsetOpt(ro, o)] });\\n }\\n }\\n else if (len === 3) {\\n ops.push({ op: 'move', data: [points[1][0], points[1][1]] });\\n ops.push({\\n op: 'bcurveTo',\\n data: [\\n points[1][0], points[1][1],\\n points[2][0], points[2][1],\\n points[2][0], points[2][1],\\n ],\\n });\\n }\\n else if (len === 2) {\\n ops.push(..._doubleLine(points[0][0], points[0][1], points[1][0], points[1][1], o));\\n }\\n return ops;\\n}\\nfunction _computeEllipsePoints(increment, cx, cy, rx, ry, offset, overlap, o) {\\n const corePoints = [];\\n const allPoints = [];\\n const radOffset = _offsetOpt(0.5, o) - (Math.PI / 2);\\n const coreOnly = o.roughness === 0;\\n if (!coreOnly) {\\n allPoints.push([\\n _offsetOpt(offset, o) + cx + 0.9 * rx * Math.cos(radOffset - increment),\\n _offsetOpt(offset, o) + cy + 0.9 * ry * Math.sin(radOffset - increment),\\n ]);\\n }\\n const endAngle = Math.PI * 2 + (coreOnly ? 0 : (radOffset - 0.01));\\n for (let angle = radOffset; angle < endAngle; angle = angle + increment) {\\n const p = [\\n _offsetOpt(offset, o) + cx + rx * Math.cos(angle),\\n _offsetOpt(offset, o) + cy + ry * Math.sin(angle),\\n ];\\n corePoints.push(p);\\n allPoints.push(p);\\n }\\n if (!coreOnly) {\\n allPoints.push([\\n _offsetOpt(offset, o) + cx + rx * Math.cos(radOffset + Math.PI * 2 + overlap * 0.5),\\n _offsetOpt(offset, o) + cy + ry * Math.sin(radOffset + Math.PI * 2 + overlap * 0.5),\\n ]);\\n allPoints.push([\\n _offsetOpt(offset, o) + cx + 0.98 * rx * Math.cos(radOffset + overlap),\\n _offsetOpt(offset, o) + cy + 0.98 * ry * Math.sin(radOffset + overlap),\\n ]);\\n allPoints.push([\\n _offsetOpt(offset, o) + cx + 0.9 * rx * Math.cos(radOffset + overlap * 0.5),\\n _offsetOpt(offset, o) + cy + 0.9 * ry * Math.sin(radOffset + overlap * 0.5),\\n ]);\\n }\\n return [allPoints, corePoints];\\n}\\nfunction _arc(increment, cx, cy, rx, ry, strt, stp, offset, o) {\\n const radOffset = strt + _offsetOpt(0.1, o);\\n const points = [];\\n points.push([\\n _offsetOpt(offset, o) + cx + 0.9 * rx * Math.cos(radOffset - increment),\\n _offsetOpt(offset, o) + cy + 0.9 * ry * Math.sin(radOffset - increment),\\n ]);\\n for (let angle = radOffset; angle <= stp; angle = angle + increment) {\\n points.push([\\n _offsetOpt(offset, o) + cx + rx * Math.cos(angle),\\n _offsetOpt(offset, o) + cy + ry * Math.sin(angle),\\n ]);\\n }\\n points.push([\\n cx + rx * Math.cos(stp),\\n cy + ry * Math.sin(stp),\\n ]);\\n points.push([\\n cx + rx * Math.cos(stp),\\n cy + ry * Math.sin(stp),\\n ]);\\n return _curve(points, null, o);\\n}\\nfunction _bezierTo(x1, y1, x2, y2, x, y, current, o) {\\n const ops = [];\\n const ros = [o.maxRandomnessOffset || 1, (o.maxRandomnessOffset || 1) + 0.3];\\n let f = [0, 0];\\n const iterations = o.disableMultiStroke ? 1 : 2;\\n const preserveVertices = o.preserveVertices;\\n for (let i = 0; i < iterations; i++) {\\n if (i === 0) {\\n ops.push({ op: 'move', data: [current[0], current[1]] });\\n }\\n else {\\n ops.push({ op: 'move', data: [current[0] + (preserveVertices ? 0 : _offsetOpt(ros[0], o)), current[1] + (preserveVertices ? 0 : _offsetOpt(ros[0], o))] });\\n }\\n f = preserveVertices ? [x, y] : [x + _offsetOpt(ros[i], o), y + _offsetOpt(ros[i], o)];\\n ops.push({\\n op: 'bcurveTo',\\n data: [\\n x1 + _offsetOpt(ros[i], o), y1 + _offsetOpt(ros[i], o),\\n x2 + _offsetOpt(ros[i], o), y2 + _offsetOpt(ros[i], o),\\n f[0], f[1],\\n ],\\n });\\n }\\n return ops;\\n}\\n//# sourceURL=[module]\\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../../node_modules/roughjs/bin/renderer.js.js","mappings":";;;;;;;;;;;;;;;;;;;;;;AAAgD;AACb;AACiC;AACpE;AACA;AACA;AACA;AACA;AACA;AACO;AACP,aAAa;AACb;AACO;AACP;AACA;AACA;AACA,wBAAwB,eAAe;AACvC;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA,aAAa;AACb;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACO;AACP;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,uBAAuB;AACxC;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,8BAA8B,IAAI,0EAA0E;AACnI;AACA;AACA,aAAa;AACb;AACO;AACP,qBAAqB,2DAAS,CAAC,4DAAU,CAAC,2DAAS;AACnD;AACA;AACA;AACA,iBAAiB,YAAY;AAC7B;AACA;AACA;AACA;AACA,2BAA2B,qEAAqE;AAChG;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,2BAA2B,gGAAgG;AAC3H,gCAAgC,SAAS;AACzC,+BAA+B,kGAAkG;AACjI;AACA;AACA;AACA;AACA,aAAa;AACb;AACO;AACP,WAAW,6DAAS;AACpB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2BAA2B,cAAc;AACzC;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACA;AACA,mCAAmC;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6BAA6B,4CAAM;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,mBAAmB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,gDAAgD;AACnE,wBAAwB,eAAe;AACvC;AACA;AACA;AACA;AACA;AACA,uBAAuB,8EAA8E;AACrG;AACA;AACA;AACA,uBAAuB,4FAA4F;AACnH;AACA;AACA;AACA,mBAAmB,gDAAgD;AACnE;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gCAAgC,kBAAkB;AAClD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gCAAgC,cAAc;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,gBAAgB;AACpC;AACA,uBAAuB,4CAA4C;AACnE;AACA;AACA,uBAAuB,8IAA8I;AACrK;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA","sources":["webpack:///../../../node_modules/roughjs/bin/renderer.js?0d3e"],"sourcesContent":["import { getFiller } from './fillers/filler.js';\nimport { Random } from './math.js';\nimport { parsePath, normalize, absolutize } from 'path-data-parser';\nconst helper = {\n    randOffset,\n    randOffsetWithRange,\n    ellipse,\n    doubleLineOps: doubleLineFillOps,\n};\nexport function line(x1, y1, x2, y2, o) {\n    return { type: 'path', ops: _doubleLine(x1, y1, x2, y2, o) };\n}\nexport function linearPath(points, close, o) {\n    const len = (points || []).length;\n    if (len > 2) {\n        const ops = [];\n        for (let i = 0; i < (len - 1); i++) {\n            ops.push(..._doubleLine(points[i][0], points[i][1], points[i + 1][0], points[i + 1][1], o));\n        }\n        if (close) {\n            ops.push(..._doubleLine(points[len - 1][0], points[len - 1][1], points[0][0], points[0][1], o));\n        }\n        return { type: 'path', ops };\n    }\n    else if (len === 2) {\n        return line(points[0][0], points[0][1], points[1][0], points[1][1], o);\n    }\n    return { type: 'path', ops: [] };\n}\nexport function polygon(points, o) {\n    return linearPath(points, true, o);\n}\nexport function rectangle(x, y, width, height, o) {\n    const points = [\n        [x, y],\n        [x + width, y],\n        [x + width, y + height],\n        [x, y + height],\n    ];\n    return polygon(points, o);\n}\nexport function curve(points, o) {\n    let o1 = _curveWithOffset(points, 1 * (1 + o.roughness * 0.2), o);\n    if (!o.disableMultiStroke) {\n        const o2 = _curveWithOffset(points, 1.5 * (1 + o.roughness * 0.22), cloneOptionsAlterSeed(o));\n        o1 = o1.concat(o2);\n    }\n    return { type: 'path', ops: o1 };\n}\nexport function ellipse(x, y, width, height, o) {\n    const params = generateEllipseParams(width, height, o);\n    return ellipseWithParams(x, y, o, params).opset;\n}\nexport function generateEllipseParams(width, height, o) {\n    const psq = Math.sqrt(Math.PI * 2 * Math.sqrt((Math.pow(width / 2, 2) + Math.pow(height / 2, 2)) / 2));\n    const stepCount = Math.max(o.curveStepCount, (o.curveStepCount / Math.sqrt(200)) * psq);\n    const increment = (Math.PI * 2) / stepCount;\n    let rx = Math.abs(width / 2);\n    let ry = Math.abs(height / 2);\n    const curveFitRandomness = 1 - o.curveFitting;\n    rx += _offsetOpt(rx * curveFitRandomness, o);\n    ry += _offsetOpt(ry * curveFitRandomness, o);\n    return { increment, rx, ry };\n}\nexport function ellipseWithParams(x, y, o, ellipseParams) {\n    const [ap1, cp1] = _computeEllipsePoints(ellipseParams.increment, x, y, ellipseParams.rx, ellipseParams.ry, 1, ellipseParams.increment * _offset(0.1, _offset(0.4, 1, o), o), o);\n    let o1 = _curve(ap1, null, o);\n    if ((!o.disableMultiStroke) && (o.roughness !== 0)) {\n        const [ap2] = _computeEllipsePoints(ellipseParams.increment, x, y, ellipseParams.rx, ellipseParams.ry, 1.5, 0, o);\n        const o2 = _curve(ap2, null, o);\n        o1 = o1.concat(o2);\n    }\n    return {\n        estimatedPoints: cp1,\n        opset: { type: 'path', ops: o1 },\n    };\n}\nexport function arc(x, y, width, height, start, stop, closed, roughClosure, o) {\n    const cx = x;\n    const cy = y;\n    let rx = Math.abs(width / 2);\n    let ry = Math.abs(height / 2);\n    rx += _offsetOpt(rx * 0.01, o);\n    ry += _offsetOpt(ry * 0.01, o);\n    let strt = start;\n    let stp = stop;\n    while (strt < 0) {\n        strt += Math.PI * 2;\n        stp += Math.PI * 2;\n    }\n    if ((stp - strt) > (Math.PI * 2)) {\n        strt = 0;\n        stp = Math.PI * 2;\n    }\n    const ellipseInc = (Math.PI * 2) / o.curveStepCount;\n    const arcInc = Math.min(ellipseInc / 2, (stp - strt) / 2);\n    const ops = _arc(arcInc, cx, cy, rx, ry, strt, stp, 1, o);\n    if (!o.disableMultiStroke) {\n        const o2 = _arc(arcInc, cx, cy, rx, ry, strt, stp, 1.5, o);\n        ops.push(...o2);\n    }\n    if (closed) {\n        if (roughClosure) {\n            ops.push(..._doubleLine(cx, cy, cx + rx * Math.cos(strt), cy + ry * Math.sin(strt), o), ..._doubleLine(cx, cy, cx + rx * Math.cos(stp), cy + ry * Math.sin(stp), o));\n        }\n        else {\n            ops.push({ op: 'lineTo', data: [cx, cy] }, { op: 'lineTo', data: [cx + rx * Math.cos(strt), cy + ry * Math.sin(strt)] });\n        }\n    }\n    return { type: 'path', ops };\n}\nexport function svgPath(path, o) {\n    const segments = normalize(absolutize(parsePath(path)));\n    const ops = [];\n    let first = [0, 0];\n    let current = [0, 0];\n    for (const { key, data } of segments) {\n        switch (key) {\n            case 'M': {\n                const ro = 1 * (o.maxRandomnessOffset || 0);\n                const pv = o.preserveVertices;\n                ops.push({ op: 'move', data: data.map((d) => d + (pv ? 0 : _offsetOpt(ro, o))) });\n                current = [data[0], data[1]];\n                first = [data[0], data[1]];\n                break;\n            }\n            case 'L':\n                ops.push(..._doubleLine(current[0], current[1], data[0], data[1], o));\n                current = [data[0], data[1]];\n                break;\n            case 'C': {\n                const [x1, y1, x2, y2, x, y] = data;\n                ops.push(..._bezierTo(x1, y1, x2, y2, x, y, current, o));\n                current = [x, y];\n                break;\n            }\n            case 'Z':\n                ops.push(..._doubleLine(current[0], current[1], first[0], first[1], o));\n                current = [first[0], first[1]];\n                break;\n        }\n    }\n    return { type: 'path', ops };\n}\n// Fills\nexport function solidFillPolygon(polygonList, o) {\n    const ops = [];\n    for (const points of polygonList) {\n        if (points.length) {\n            const offset = o.maxRandomnessOffset || 0;\n            const len = points.length;\n            if (len > 2) {\n                ops.push({ op: 'move', data: [points[0][0] + _offsetOpt(offset, o), points[0][1] + _offsetOpt(offset, o)] });\n                for (let i = 1; i < len; i++) {\n                    ops.push({ op: 'lineTo', data: [points[i][0] + _offsetOpt(offset, o), points[i][1] + _offsetOpt(offset, o)] });\n                }\n            }\n        }\n    }\n    return { type: 'fillPath', ops };\n}\nexport function patternFillPolygons(polygonList, o) {\n    return getFiller(o, helper).fillPolygons(polygonList, o);\n}\nexport function patternFillArc(x, y, width, height, start, stop, o) {\n    const cx = x;\n    const cy = y;\n    let rx = Math.abs(width / 2);\n    let ry = Math.abs(height / 2);\n    rx += _offsetOpt(rx * 0.01, o);\n    ry += _offsetOpt(ry * 0.01, o);\n    let strt = start;\n    let stp = stop;\n    while (strt < 0) {\n        strt += Math.PI * 2;\n        stp += Math.PI * 2;\n    }\n    if ((stp - strt) > (Math.PI * 2)) {\n        strt = 0;\n        stp = Math.PI * 2;\n    }\n    const increment = (stp - strt) / o.curveStepCount;\n    const points = [];\n    for (let angle = strt; angle <= stp; angle = angle + increment) {\n        points.push([cx + rx * Math.cos(angle), cy + ry * Math.sin(angle)]);\n    }\n    points.push([cx + rx * Math.cos(stp), cy + ry * Math.sin(stp)]);\n    points.push([cx, cy]);\n    return patternFillPolygons([points], o);\n}\nexport function randOffset(x, o) {\n    return _offsetOpt(x, o);\n}\nexport function randOffsetWithRange(min, max, o) {\n    return _offset(min, max, o);\n}\nexport function doubleLineFillOps(x1, y1, x2, y2, o) {\n    return _doubleLine(x1, y1, x2, y2, o, true);\n}\n// Private helpers\nfunction cloneOptionsAlterSeed(ops) {\n    const result = Object.assign({}, ops);\n    result.randomizer = undefined;\n    if (ops.seed) {\n        result.seed = ops.seed + 1;\n    }\n    return result;\n}\nfunction random(ops) {\n    if (!ops.randomizer) {\n        ops.randomizer = new Random(ops.seed || 0);\n    }\n    return ops.randomizer.next();\n}\nfunction _offset(min, max, ops, roughnessGain = 1) {\n    return ops.roughness * roughnessGain * ((random(ops) * (max - min)) + min);\n}\nfunction _offsetOpt(x, ops, roughnessGain = 1) {\n    return _offset(-x, x, ops, roughnessGain);\n}\nfunction _doubleLine(x1, y1, x2, y2, o, filling = false) {\n    const singleStroke = filling ? o.disableMultiStrokeFill : o.disableMultiStroke;\n    const o1 = _line(x1, y1, x2, y2, o, true, false);\n    if (singleStroke) {\n        return o1;\n    }\n    const o2 = _line(x1, y1, x2, y2, o, true, true);\n    return o1.concat(o2);\n}\nfunction _line(x1, y1, x2, y2, o, move, overlay) {\n    const lengthSq = Math.pow((x1 - x2), 2) + Math.pow((y1 - y2), 2);\n    const length = Math.sqrt(lengthSq);\n    let roughnessGain = 1;\n    if (length < 200) {\n        roughnessGain = 1;\n    }\n    else if (length > 500) {\n        roughnessGain = 0.4;\n    }\n    else {\n        roughnessGain = (-0.0016668) * length + 1.233334;\n    }\n    let offset = o.maxRandomnessOffset || 0;\n    if ((offset * offset * 100) > lengthSq) {\n        offset = length / 10;\n    }\n    const halfOffset = offset / 2;\n    const divergePoint = 0.2 + random(o) * 0.2;\n    let midDispX = o.bowing * o.maxRandomnessOffset * (y2 - y1) / 200;\n    let midDispY = o.bowing * o.maxRandomnessOffset * (x1 - x2) / 200;\n    midDispX = _offsetOpt(midDispX, o, roughnessGain);\n    midDispY = _offsetOpt(midDispY, o, roughnessGain);\n    const ops = [];\n    const randomHalf = () => _offsetOpt(halfOffset, o, roughnessGain);\n    const randomFull = () => _offsetOpt(offset, o, roughnessGain);\n    const preserveVertices = o.preserveVertices;\n    if (move) {\n        if (overlay) {\n            ops.push({\n                op: 'move', data: [\n                    x1 + (preserveVertices ? 0 : randomHalf()),\n                    y1 + (preserveVertices ? 0 : randomHalf()),\n                ],\n            });\n        }\n        else {\n            ops.push({\n                op: 'move', data: [\n                    x1 + (preserveVertices ? 0 : _offsetOpt(offset, o, roughnessGain)),\n                    y1 + (preserveVertices ? 0 : _offsetOpt(offset, o, roughnessGain)),\n                ],\n            });\n        }\n    }\n    if (overlay) {\n        ops.push({\n            op: 'bcurveTo',\n            data: [\n                midDispX + x1 + (x2 - x1) * divergePoint + randomHalf(),\n                midDispY + y1 + (y2 - y1) * divergePoint + randomHalf(),\n                midDispX + x1 + 2 * (x2 - x1) * divergePoint + randomHalf(),\n                midDispY + y1 + 2 * (y2 - y1) * divergePoint + randomHalf(),\n                x2 + (preserveVertices ? 0 : randomHalf()),\n                y2 + (preserveVertices ? 0 : randomHalf()),\n            ],\n        });\n    }\n    else {\n        ops.push({\n            op: 'bcurveTo',\n            data: [\n                midDispX + x1 + (x2 - x1) * divergePoint + randomFull(),\n                midDispY + y1 + (y2 - y1) * divergePoint + randomFull(),\n                midDispX + x1 + 2 * (x2 - x1) * divergePoint + randomFull(),\n                midDispY + y1 + 2 * (y2 - y1) * divergePoint + randomFull(),\n                x2 + (preserveVertices ? 0 : randomFull()),\n                y2 + (preserveVertices ? 0 : randomFull()),\n            ],\n        });\n    }\n    return ops;\n}\nfunction _curveWithOffset(points, offset, o) {\n    const ps = [];\n    ps.push([\n        points[0][0] + _offsetOpt(offset, o),\n        points[0][1] + _offsetOpt(offset, o),\n    ]);\n    ps.push([\n        points[0][0] + _offsetOpt(offset, o),\n        points[0][1] + _offsetOpt(offset, o),\n    ]);\n    for (let i = 1; i < points.length; i++) {\n        ps.push([\n            points[i][0] + _offsetOpt(offset, o),\n            points[i][1] + _offsetOpt(offset, o),\n        ]);\n        if (i === (points.length - 1)) {\n            ps.push([\n                points[i][0] + _offsetOpt(offset, o),\n                points[i][1] + _offsetOpt(offset, o),\n            ]);\n        }\n    }\n    return _curve(ps, null, o);\n}\nfunction _curve(points, closePoint, o) {\n    const len = points.length;\n    const ops = [];\n    if (len > 3) {\n        const b = [];\n        const s = 1 - o.curveTightness;\n        ops.push({ op: 'move', data: [points[1][0], points[1][1]] });\n        for (let i = 1; (i + 2) < len; i++) {\n            const cachedVertArray = points[i];\n            b[0] = [cachedVertArray[0], cachedVertArray[1]];\n            b[1] = [cachedVertArray[0] + (s * points[i + 1][0] - s * points[i - 1][0]) / 6, cachedVertArray[1] + (s * points[i + 1][1] - s * points[i - 1][1]) / 6];\n            b[2] = [points[i + 1][0] + (s * points[i][0] - s * points[i + 2][0]) / 6, points[i + 1][1] + (s * points[i][1] - s * points[i + 2][1]) / 6];\n            b[3] = [points[i + 1][0], points[i + 1][1]];\n            ops.push({ op: 'bcurveTo', data: [b[1][0], b[1][1], b[2][0], b[2][1], b[3][0], b[3][1]] });\n        }\n        if (closePoint && closePoint.length === 2) {\n            const ro = o.maxRandomnessOffset;\n            ops.push({ op: 'lineTo', data: [closePoint[0] + _offsetOpt(ro, o), closePoint[1] + _offsetOpt(ro, o)] });\n        }\n    }\n    else if (len === 3) {\n        ops.push({ op: 'move', data: [points[1][0], points[1][1]] });\n        ops.push({\n            op: 'bcurveTo',\n            data: [\n                points[1][0], points[1][1],\n                points[2][0], points[2][1],\n                points[2][0], points[2][1],\n            ],\n        });\n    }\n    else if (len === 2) {\n        ops.push(..._doubleLine(points[0][0], points[0][1], points[1][0], points[1][1], o));\n    }\n    return ops;\n}\nfunction _computeEllipsePoints(increment, cx, cy, rx, ry, offset, overlap, o) {\n    const corePoints = [];\n    const allPoints = [];\n    const radOffset = _offsetOpt(0.5, o) - (Math.PI / 2);\n    const coreOnly = o.roughness === 0;\n    if (!coreOnly) {\n        allPoints.push([\n            _offsetOpt(offset, o) + cx + 0.9 * rx * Math.cos(radOffset - increment),\n            _offsetOpt(offset, o) + cy + 0.9 * ry * Math.sin(radOffset - increment),\n        ]);\n    }\n    const endAngle = Math.PI * 2 + (coreOnly ? 0 : (radOffset - 0.01));\n    for (let angle = radOffset; angle < endAngle; angle = angle + increment) {\n        const p = [\n            _offsetOpt(offset, o) + cx + rx * Math.cos(angle),\n            _offsetOpt(offset, o) + cy + ry * Math.sin(angle),\n        ];\n        corePoints.push(p);\n        allPoints.push(p);\n    }\n    if (!coreOnly) {\n        allPoints.push([\n            _offsetOpt(offset, o) + cx + rx * Math.cos(radOffset + Math.PI * 2 + overlap * 0.5),\n            _offsetOpt(offset, o) + cy + ry * Math.sin(radOffset + Math.PI * 2 + overlap * 0.5),\n        ]);\n        allPoints.push([\n            _offsetOpt(offset, o) + cx + 0.98 * rx * Math.cos(radOffset + overlap),\n            _offsetOpt(offset, o) + cy + 0.98 * ry * Math.sin(radOffset + overlap),\n        ]);\n        allPoints.push([\n            _offsetOpt(offset, o) + cx + 0.9 * rx * Math.cos(radOffset + overlap * 0.5),\n            _offsetOpt(offset, o) + cy + 0.9 * ry * Math.sin(radOffset + overlap * 0.5),\n        ]);\n    }\n    return [allPoints, corePoints];\n}\nfunction _arc(increment, cx, cy, rx, ry, strt, stp, offset, o) {\n    const radOffset = strt + _offsetOpt(0.1, o);\n    const points = [];\n    points.push([\n        _offsetOpt(offset, o) + cx + 0.9 * rx * Math.cos(radOffset - increment),\n        _offsetOpt(offset, o) + cy + 0.9 * ry * Math.sin(radOffset - increment),\n    ]);\n    for (let angle = radOffset; angle <= stp; angle = angle + increment) {\n        points.push([\n            _offsetOpt(offset, o) + cx + rx * Math.cos(angle),\n            _offsetOpt(offset, o) + cy + ry * Math.sin(angle),\n        ]);\n    }\n    points.push([\n        cx + rx * Math.cos(stp),\n        cy + ry * Math.sin(stp),\n    ]);\n    points.push([\n        cx + rx * Math.cos(stp),\n        cy + ry * Math.sin(stp),\n    ]);\n    return _curve(points, null, o);\n}\nfunction _bezierTo(x1, y1, x2, y2, x, y, current, o) {\n    const ops = [];\n    const ros = [o.maxRandomnessOffset || 1, (o.maxRandomnessOffset || 1) + 0.3];\n    let f = [0, 0];\n    const iterations = o.disableMultiStroke ? 1 : 2;\n    const preserveVertices = o.preserveVertices;\n    for (let i = 0; i < iterations; i++) {\n        if (i === 0) {\n            ops.push({ op: 'move', data: [current[0], current[1]] });\n        }\n        else {\n            ops.push({ op: 'move', data: [current[0] + (preserveVertices ? 0 : _offsetOpt(ros[0], o)), current[1] + (preserveVertices ? 0 : _offsetOpt(ros[0], o))] });\n        }\n        f = preserveVertices ? [x, y] : [x + _offsetOpt(ros[i], o), y + _offsetOpt(ros[i], o)];\n        ops.push({\n            op: 'bcurveTo',\n            data: [\n                x1 + _offsetOpt(ros[i], o), y1 + _offsetOpt(ros[i], o),\n                x2 + _offsetOpt(ros[i], o), y2 + _offsetOpt(ros[i], o),\n                f[0], f[1],\n            ],\n        });\n    }\n    return ops;\n}\n"],"names":[],"sourceRoot":""}\\n//# sourceURL=webpack-internal:///../../../node_modules/roughjs/bin/renderer.js\\n\");\n\n//# sourceURL=webpack://Excalidraw/../../../node_modules/roughjs/bin/renderer.js?");
578
+ eval("eval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */ \\\"line\\\": () => (/* binding */ line),\\n/* harmony export */ \\\"linearPath\\\": () => (/* binding */ linearPath),\\n/* harmony export */ \\\"polygon\\\": () => (/* binding */ polygon),\\n/* harmony export */ \\\"rectangle\\\": () => (/* binding */ rectangle),\\n/* harmony export */ \\\"curve\\\": () => (/* binding */ curve),\\n/* harmony export */ \\\"ellipse\\\": () => (/* binding */ ellipse),\\n/* harmony export */ \\\"generateEllipseParams\\\": () => (/* binding */ generateEllipseParams),\\n/* harmony export */ \\\"ellipseWithParams\\\": () => (/* binding */ ellipseWithParams),\\n/* harmony export */ \\\"arc\\\": () => (/* binding */ arc),\\n/* harmony export */ \\\"svgPath\\\": () => (/* binding */ svgPath),\\n/* harmony export */ \\\"solidFillPolygon\\\": () => (/* binding */ solidFillPolygon),\\n/* harmony export */ \\\"patternFillPolygons\\\": () => (/* binding */ patternFillPolygons),\\n/* harmony export */ \\\"patternFillArc\\\": () => (/* binding */ patternFillArc),\\n/* harmony export */ \\\"randOffset\\\": () => (/* binding */ randOffset),\\n/* harmony export */ \\\"randOffsetWithRange\\\": () => (/* binding */ randOffsetWithRange),\\n/* harmony export */ \\\"doubleLineFillOps\\\": () => (/* binding */ doubleLineFillOps)\\n/* harmony export */ });\\n/* harmony import */ var _fillers_filler_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./fillers/filler.js */ \\\"../../../node_modules/roughjs/bin/fillers/filler.js\\\");\\n/* harmony import */ var _math_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./math.js */ \\\"../../../node_modules/roughjs/bin/math.js\\\");\\n/* harmony import */ var path_data_parser__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! path-data-parser */ \\\"../../../node_modules/path-data-parser/lib/index.js\\\");\\n\\n\\n\\nconst helper = {\\n randOffset,\\n randOffsetWithRange,\\n ellipse,\\n doubleLineOps: doubleLineFillOps,\\n};\\nfunction line(x1, y1, x2, y2, o) {\\n return { type: 'path', ops: _doubleLine(x1, y1, x2, y2, o) };\\n}\\nfunction linearPath(points, close, o) {\\n const len = (points || []).length;\\n if (len > 2) {\\n const ops = [];\\n for (let i = 0; i < (len - 1); i++) {\\n ops.push(..._doubleLine(points[i][0], points[i][1], points[i + 1][0], points[i + 1][1], o));\\n }\\n if (close) {\\n ops.push(..._doubleLine(points[len - 1][0], points[len - 1][1], points[0][0], points[0][1], o));\\n }\\n return { type: 'path', ops };\\n }\\n else if (len === 2) {\\n return line(points[0][0], points[0][1], points[1][0], points[1][1], o);\\n }\\n return { type: 'path', ops: [] };\\n}\\nfunction polygon(points, o) {\\n return linearPath(points, true, o);\\n}\\nfunction rectangle(x, y, width, height, o) {\\n const points = [\\n [x, y],\\n [x + width, y],\\n [x + width, y + height],\\n [x, y + height],\\n ];\\n return polygon(points, o);\\n}\\nfunction curve(points, o) {\\n let o1 = _curveWithOffset(points, 1 * (1 + o.roughness * 0.2), o);\\n if (!o.disableMultiStroke) {\\n const o2 = _curveWithOffset(points, 1.5 * (1 + o.roughness * 0.22), cloneOptionsAlterSeed(o));\\n o1 = o1.concat(o2);\\n }\\n return { type: 'path', ops: o1 };\\n}\\nfunction ellipse(x, y, width, height, o) {\\n const params = generateEllipseParams(width, height, o);\\n return ellipseWithParams(x, y, o, params).opset;\\n}\\nfunction generateEllipseParams(width, height, o) {\\n const psq = Math.sqrt(Math.PI * 2 * Math.sqrt((Math.pow(width / 2, 2) + Math.pow(height / 2, 2)) / 2));\\n const stepCount = Math.ceil(Math.max(o.curveStepCount, (o.curveStepCount / Math.sqrt(200)) * psq));\\n const increment = (Math.PI * 2) / stepCount;\\n let rx = Math.abs(width / 2);\\n let ry = Math.abs(height / 2);\\n const curveFitRandomness = 1 - o.curveFitting;\\n rx += _offsetOpt(rx * curveFitRandomness, o);\\n ry += _offsetOpt(ry * curveFitRandomness, o);\\n return { increment, rx, ry };\\n}\\nfunction ellipseWithParams(x, y, o, ellipseParams) {\\n const [ap1, cp1] = _computeEllipsePoints(ellipseParams.increment, x, y, ellipseParams.rx, ellipseParams.ry, 1, ellipseParams.increment * _offset(0.1, _offset(0.4, 1, o), o), o);\\n let o1 = _curve(ap1, null, o);\\n if ((!o.disableMultiStroke) && (o.roughness !== 0)) {\\n const [ap2] = _computeEllipsePoints(ellipseParams.increment, x, y, ellipseParams.rx, ellipseParams.ry, 1.5, 0, o);\\n const o2 = _curve(ap2, null, o);\\n o1 = o1.concat(o2);\\n }\\n return {\\n estimatedPoints: cp1,\\n opset: { type: 'path', ops: o1 },\\n };\\n}\\nfunction arc(x, y, width, height, start, stop, closed, roughClosure, o) {\\n const cx = x;\\n const cy = y;\\n let rx = Math.abs(width / 2);\\n let ry = Math.abs(height / 2);\\n rx += _offsetOpt(rx * 0.01, o);\\n ry += _offsetOpt(ry * 0.01, o);\\n let strt = start;\\n let stp = stop;\\n while (strt < 0) {\\n strt += Math.PI * 2;\\n stp += Math.PI * 2;\\n }\\n if ((stp - strt) > (Math.PI * 2)) {\\n strt = 0;\\n stp = Math.PI * 2;\\n }\\n const ellipseInc = (Math.PI * 2) / o.curveStepCount;\\n const arcInc = Math.min(ellipseInc / 2, (stp - strt) / 2);\\n const ops = _arc(arcInc, cx, cy, rx, ry, strt, stp, 1, o);\\n if (!o.disableMultiStroke) {\\n const o2 = _arc(arcInc, cx, cy, rx, ry, strt, stp, 1.5, o);\\n ops.push(...o2);\\n }\\n if (closed) {\\n if (roughClosure) {\\n ops.push(..._doubleLine(cx, cy, cx + rx * Math.cos(strt), cy + ry * Math.sin(strt), o), ..._doubleLine(cx, cy, cx + rx * Math.cos(stp), cy + ry * Math.sin(stp), o));\\n }\\n else {\\n ops.push({ op: 'lineTo', data: [cx, cy] }, { op: 'lineTo', data: [cx + rx * Math.cos(strt), cy + ry * Math.sin(strt)] });\\n }\\n }\\n return { type: 'path', ops };\\n}\\nfunction svgPath(path, o) {\\n const segments = (0,path_data_parser__WEBPACK_IMPORTED_MODULE_2__.normalize)((0,path_data_parser__WEBPACK_IMPORTED_MODULE_2__.absolutize)((0,path_data_parser__WEBPACK_IMPORTED_MODULE_2__.parsePath)(path)));\\n const ops = [];\\n let first = [0, 0];\\n let current = [0, 0];\\n for (const { key, data } of segments) {\\n switch (key) {\\n case 'M': {\\n const ro = 1 * (o.maxRandomnessOffset || 0);\\n const pv = o.preserveVertices;\\n ops.push({ op: 'move', data: data.map((d) => d + (pv ? 0 : _offsetOpt(ro, o))) });\\n current = [data[0], data[1]];\\n first = [data[0], data[1]];\\n break;\\n }\\n case 'L':\\n ops.push(..._doubleLine(current[0], current[1], data[0], data[1], o));\\n current = [data[0], data[1]];\\n break;\\n case 'C': {\\n const [x1, y1, x2, y2, x, y] = data;\\n ops.push(..._bezierTo(x1, y1, x2, y2, x, y, current, o));\\n current = [x, y];\\n break;\\n }\\n case 'Z':\\n ops.push(..._doubleLine(current[0], current[1], first[0], first[1], o));\\n current = [first[0], first[1]];\\n break;\\n }\\n }\\n return { type: 'path', ops };\\n}\\n// Fills\\nfunction solidFillPolygon(polygonList, o) {\\n const ops = [];\\n for (const points of polygonList) {\\n if (points.length) {\\n const offset = o.maxRandomnessOffset || 0;\\n const len = points.length;\\n if (len > 2) {\\n ops.push({ op: 'move', data: [points[0][0] + _offsetOpt(offset, o), points[0][1] + _offsetOpt(offset, o)] });\\n for (let i = 1; i < len; i++) {\\n ops.push({ op: 'lineTo', data: [points[i][0] + _offsetOpt(offset, o), points[i][1] + _offsetOpt(offset, o)] });\\n }\\n }\\n }\\n }\\n return { type: 'fillPath', ops };\\n}\\nfunction patternFillPolygons(polygonList, o) {\\n return (0,_fillers_filler_js__WEBPACK_IMPORTED_MODULE_0__.getFiller)(o, helper).fillPolygons(polygonList, o);\\n}\\nfunction patternFillArc(x, y, width, height, start, stop, o) {\\n const cx = x;\\n const cy = y;\\n let rx = Math.abs(width / 2);\\n let ry = Math.abs(height / 2);\\n rx += _offsetOpt(rx * 0.01, o);\\n ry += _offsetOpt(ry * 0.01, o);\\n let strt = start;\\n let stp = stop;\\n while (strt < 0) {\\n strt += Math.PI * 2;\\n stp += Math.PI * 2;\\n }\\n if ((stp - strt) > (Math.PI * 2)) {\\n strt = 0;\\n stp = Math.PI * 2;\\n }\\n const increment = (stp - strt) / o.curveStepCount;\\n const points = [];\\n for (let angle = strt; angle <= stp; angle = angle + increment) {\\n points.push([cx + rx * Math.cos(angle), cy + ry * Math.sin(angle)]);\\n }\\n points.push([cx + rx * Math.cos(stp), cy + ry * Math.sin(stp)]);\\n points.push([cx, cy]);\\n return patternFillPolygons([points], o);\\n}\\nfunction randOffset(x, o) {\\n return _offsetOpt(x, o);\\n}\\nfunction randOffsetWithRange(min, max, o) {\\n return _offset(min, max, o);\\n}\\nfunction doubleLineFillOps(x1, y1, x2, y2, o) {\\n return _doubleLine(x1, y1, x2, y2, o, true);\\n}\\n// Private helpers\\nfunction cloneOptionsAlterSeed(ops) {\\n const result = Object.assign({}, ops);\\n result.randomizer = undefined;\\n if (ops.seed) {\\n result.seed = ops.seed + 1;\\n }\\n return result;\\n}\\nfunction random(ops) {\\n if (!ops.randomizer) {\\n ops.randomizer = new _math_js__WEBPACK_IMPORTED_MODULE_1__.Random(ops.seed || 0);\\n }\\n return ops.randomizer.next();\\n}\\nfunction _offset(min, max, ops, roughnessGain = 1) {\\n return ops.roughness * roughnessGain * ((random(ops) * (max - min)) + min);\\n}\\nfunction _offsetOpt(x, ops, roughnessGain = 1) {\\n return _offset(-x, x, ops, roughnessGain);\\n}\\nfunction _doubleLine(x1, y1, x2, y2, o, filling = false) {\\n const singleStroke = filling ? o.disableMultiStrokeFill : o.disableMultiStroke;\\n const o1 = _line(x1, y1, x2, y2, o, true, false);\\n if (singleStroke) {\\n return o1;\\n }\\n const o2 = _line(x1, y1, x2, y2, o, true, true);\\n return o1.concat(o2);\\n}\\nfunction _line(x1, y1, x2, y2, o, move, overlay) {\\n const lengthSq = Math.pow((x1 - x2), 2) + Math.pow((y1 - y2), 2);\\n const length = Math.sqrt(lengthSq);\\n let roughnessGain = 1;\\n if (length < 200) {\\n roughnessGain = 1;\\n }\\n else if (length > 500) {\\n roughnessGain = 0.4;\\n }\\n else {\\n roughnessGain = (-0.0016668) * length + 1.233334;\\n }\\n let offset = o.maxRandomnessOffset || 0;\\n if ((offset * offset * 100) > lengthSq) {\\n offset = length / 10;\\n }\\n const halfOffset = offset / 2;\\n const divergePoint = 0.2 + random(o) * 0.2;\\n let midDispX = o.bowing * o.maxRandomnessOffset * (y2 - y1) / 200;\\n let midDispY = o.bowing * o.maxRandomnessOffset * (x1 - x2) / 200;\\n midDispX = _offsetOpt(midDispX, o, roughnessGain);\\n midDispY = _offsetOpt(midDispY, o, roughnessGain);\\n const ops = [];\\n const randomHalf = () => _offsetOpt(halfOffset, o, roughnessGain);\\n const randomFull = () => _offsetOpt(offset, o, roughnessGain);\\n const preserveVertices = o.preserveVertices;\\n if (move) {\\n if (overlay) {\\n ops.push({\\n op: 'move', data: [\\n x1 + (preserveVertices ? 0 : randomHalf()),\\n y1 + (preserveVertices ? 0 : randomHalf()),\\n ],\\n });\\n }\\n else {\\n ops.push({\\n op: 'move', data: [\\n x1 + (preserveVertices ? 0 : _offsetOpt(offset, o, roughnessGain)),\\n y1 + (preserveVertices ? 0 : _offsetOpt(offset, o, roughnessGain)),\\n ],\\n });\\n }\\n }\\n if (overlay) {\\n ops.push({\\n op: 'bcurveTo',\\n data: [\\n midDispX + x1 + (x2 - x1) * divergePoint + randomHalf(),\\n midDispY + y1 + (y2 - y1) * divergePoint + randomHalf(),\\n midDispX + x1 + 2 * (x2 - x1) * divergePoint + randomHalf(),\\n midDispY + y1 + 2 * (y2 - y1) * divergePoint + randomHalf(),\\n x2 + (preserveVertices ? 0 : randomHalf()),\\n y2 + (preserveVertices ? 0 : randomHalf()),\\n ],\\n });\\n }\\n else {\\n ops.push({\\n op: 'bcurveTo',\\n data: [\\n midDispX + x1 + (x2 - x1) * divergePoint + randomFull(),\\n midDispY + y1 + (y2 - y1) * divergePoint + randomFull(),\\n midDispX + x1 + 2 * (x2 - x1) * divergePoint + randomFull(),\\n midDispY + y1 + 2 * (y2 - y1) * divergePoint + randomFull(),\\n x2 + (preserveVertices ? 0 : randomFull()),\\n y2 + (preserveVertices ? 0 : randomFull()),\\n ],\\n });\\n }\\n return ops;\\n}\\nfunction _curveWithOffset(points, offset, o) {\\n const ps = [];\\n ps.push([\\n points[0][0] + _offsetOpt(offset, o),\\n points[0][1] + _offsetOpt(offset, o),\\n ]);\\n ps.push([\\n points[0][0] + _offsetOpt(offset, o),\\n points[0][1] + _offsetOpt(offset, o),\\n ]);\\n for (let i = 1; i < points.length; i++) {\\n ps.push([\\n points[i][0] + _offsetOpt(offset, o),\\n points[i][1] + _offsetOpt(offset, o),\\n ]);\\n if (i === (points.length - 1)) {\\n ps.push([\\n points[i][0] + _offsetOpt(offset, o),\\n points[i][1] + _offsetOpt(offset, o),\\n ]);\\n }\\n }\\n return _curve(ps, null, o);\\n}\\nfunction _curve(points, closePoint, o) {\\n const len = points.length;\\n const ops = [];\\n if (len > 3) {\\n const b = [];\\n const s = 1 - o.curveTightness;\\n ops.push({ op: 'move', data: [points[1][0], points[1][1]] });\\n for (let i = 1; (i + 2) < len; i++) {\\n const cachedVertArray = points[i];\\n b[0] = [cachedVertArray[0], cachedVertArray[1]];\\n b[1] = [cachedVertArray[0] + (s * points[i + 1][0] - s * points[i - 1][0]) / 6, cachedVertArray[1] + (s * points[i + 1][1] - s * points[i - 1][1]) / 6];\\n b[2] = [points[i + 1][0] + (s * points[i][0] - s * points[i + 2][0]) / 6, points[i + 1][1] + (s * points[i][1] - s * points[i + 2][1]) / 6];\\n b[3] = [points[i + 1][0], points[i + 1][1]];\\n ops.push({ op: 'bcurveTo', data: [b[1][0], b[1][1], b[2][0], b[2][1], b[3][0], b[3][1]] });\\n }\\n if (closePoint && closePoint.length === 2) {\\n const ro = o.maxRandomnessOffset;\\n ops.push({ op: 'lineTo', data: [closePoint[0] + _offsetOpt(ro, o), closePoint[1] + _offsetOpt(ro, o)] });\\n }\\n }\\n else if (len === 3) {\\n ops.push({ op: 'move', data: [points[1][0], points[1][1]] });\\n ops.push({\\n op: 'bcurveTo',\\n data: [\\n points[1][0], points[1][1],\\n points[2][0], points[2][1],\\n points[2][0], points[2][1],\\n ],\\n });\\n }\\n else if (len === 2) {\\n ops.push(..._doubleLine(points[0][0], points[0][1], points[1][0], points[1][1], o));\\n }\\n return ops;\\n}\\nfunction _computeEllipsePoints(increment, cx, cy, rx, ry, offset, overlap, o) {\\n const coreOnly = o.roughness === 0;\\n const corePoints = [];\\n const allPoints = [];\\n if (coreOnly) {\\n increment = increment / 4;\\n allPoints.push([\\n cx + rx * Math.cos(-increment),\\n cy + ry * Math.sin(-increment),\\n ]);\\n for (let angle = 0; angle <= Math.PI * 2; angle = angle + increment) {\\n const p = [\\n cx + rx * Math.cos(angle),\\n cy + ry * Math.sin(angle),\\n ];\\n corePoints.push(p);\\n allPoints.push(p);\\n }\\n allPoints.push([\\n cx + rx * Math.cos(0),\\n cy + ry * Math.sin(0),\\n ]);\\n allPoints.push([\\n cx + rx * Math.cos(increment),\\n cy + ry * Math.sin(increment),\\n ]);\\n }\\n else {\\n const radOffset = _offsetOpt(0.5, o) - (Math.PI / 2);\\n allPoints.push([\\n _offsetOpt(offset, o) + cx + 0.9 * rx * Math.cos(radOffset - increment),\\n _offsetOpt(offset, o) + cy + 0.9 * ry * Math.sin(radOffset - increment),\\n ]);\\n const endAngle = Math.PI * 2 + radOffset - 0.01;\\n for (let angle = radOffset; angle < endAngle; angle = angle + increment) {\\n const p = [\\n _offsetOpt(offset, o) + cx + rx * Math.cos(angle),\\n _offsetOpt(offset, o) + cy + ry * Math.sin(angle),\\n ];\\n corePoints.push(p);\\n allPoints.push(p);\\n }\\n allPoints.push([\\n _offsetOpt(offset, o) + cx + rx * Math.cos(radOffset + Math.PI * 2 + overlap * 0.5),\\n _offsetOpt(offset, o) + cy + ry * Math.sin(radOffset + Math.PI * 2 + overlap * 0.5),\\n ]);\\n allPoints.push([\\n _offsetOpt(offset, o) + cx + 0.98 * rx * Math.cos(radOffset + overlap),\\n _offsetOpt(offset, o) + cy + 0.98 * ry * Math.sin(radOffset + overlap),\\n ]);\\n allPoints.push([\\n _offsetOpt(offset, o) + cx + 0.9 * rx * Math.cos(radOffset + overlap * 0.5),\\n _offsetOpt(offset, o) + cy + 0.9 * ry * Math.sin(radOffset + overlap * 0.5),\\n ]);\\n }\\n return [allPoints, corePoints];\\n}\\nfunction _arc(increment, cx, cy, rx, ry, strt, stp, offset, o) {\\n const radOffset = strt + _offsetOpt(0.1, o);\\n const points = [];\\n points.push([\\n _offsetOpt(offset, o) + cx + 0.9 * rx * Math.cos(radOffset - increment),\\n _offsetOpt(offset, o) + cy + 0.9 * ry * Math.sin(radOffset - increment),\\n ]);\\n for (let angle = radOffset; angle <= stp; angle = angle + increment) {\\n points.push([\\n _offsetOpt(offset, o) + cx + rx * Math.cos(angle),\\n _offsetOpt(offset, o) + cy + ry * Math.sin(angle),\\n ]);\\n }\\n points.push([\\n cx + rx * Math.cos(stp),\\n cy + ry * Math.sin(stp),\\n ]);\\n points.push([\\n cx + rx * Math.cos(stp),\\n cy + ry * Math.sin(stp),\\n ]);\\n return _curve(points, null, o);\\n}\\nfunction _bezierTo(x1, y1, x2, y2, x, y, current, o) {\\n const ops = [];\\n const ros = [o.maxRandomnessOffset || 1, (o.maxRandomnessOffset || 1) + 0.3];\\n let f = [0, 0];\\n const iterations = o.disableMultiStroke ? 1 : 2;\\n const preserveVertices = o.preserveVertices;\\n for (let i = 0; i < iterations; i++) {\\n if (i === 0) {\\n ops.push({ op: 'move', data: [current[0], current[1]] });\\n }\\n else {\\n ops.push({ op: 'move', data: [current[0] + (preserveVertices ? 0 : _offsetOpt(ros[0], o)), current[1] + (preserveVertices ? 0 : _offsetOpt(ros[0], o))] });\\n }\\n f = preserveVertices ? [x, y] : [x + _offsetOpt(ros[i], o), y + _offsetOpt(ros[i], o)];\\n ops.push({\\n op: 'bcurveTo',\\n data: [\\n x1 + _offsetOpt(ros[i], o), y1 + _offsetOpt(ros[i], o),\\n x2 + _offsetOpt(ros[i], o), y2 + _offsetOpt(ros[i], o),\\n f[0], f[1],\\n ],\\n });\\n }\\n return ops;\\n}\\n//# sourceURL=[module]\\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../../../node_modules/roughjs/bin/renderer.js.js","mappings":";;;;;;;;;;;;;;;;;;;;;;AAAgD;AACb;AACiC;AACpE;AACA;AACA;AACA;AACA;AACA;AACO;AACP,aAAa;AACb;AACO;AACP;AACA;AACA;AACA,wBAAwB,eAAe;AACvC;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB;AACA;AACA;AACA;AACA,aAAa;AACb;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACO;AACP;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB,uBAAuB;AACxC;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,8BAA8B,IAAI,0EAA0E;AACnI;AACA;AACA,aAAa;AACb;AACO;AACP,qBAAqB,2DAAS,CAAC,4DAAU,CAAC,2DAAS;AACnD;AACA;AACA;AACA,iBAAiB,YAAY;AAC7B;AACA;AACA;AACA;AACA,2BAA2B,qEAAqE;AAChG;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,2BAA2B,gGAAgG;AAC3H,gCAAgC,SAAS;AACzC,+BAA+B,kGAAkG;AACjI;AACA;AACA;AACA;AACA,aAAa;AACb;AACO;AACP,WAAW,6DAAS;AACpB;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2BAA2B,cAAc;AACzC;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACO;AACP;AACA;AACA;AACA;AACA,mCAAmC;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6BAA6B,4CAAM;AACnC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,mBAAmB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,gDAAgD;AACnE,wBAAwB,eAAe;AACvC;AACA;AACA;AACA;AACA;AACA,uBAAuB,8EAA8E;AACrG;AACA;AACA;AACA,uBAAuB,4FAA4F;AACnH;AACA;AACA;AACA,mBAAmB,gDAAgD;AACnE;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B,sBAAsB;AAClD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oCAAoC,kBAAkB;AACtD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gCAAgC,cAAc;AAC9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,gBAAgB;AACpC;AACA,uBAAuB,4CAA4C;AACnE;AACA;AACA,uBAAuB,8IAA8I;AACrK;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA","sources":["webpack:///../../../node_modules/roughjs/bin/renderer.js?0d3e"],"sourcesContent":["import { getFiller } from './fillers/filler.js';\nimport { Random } from './math.js';\nimport { parsePath, normalize, absolutize } from 'path-data-parser';\nconst helper = {\n    randOffset,\n    randOffsetWithRange,\n    ellipse,\n    doubleLineOps: doubleLineFillOps,\n};\nexport function line(x1, y1, x2, y2, o) {\n    return { type: 'path', ops: _doubleLine(x1, y1, x2, y2, o) };\n}\nexport function linearPath(points, close, o) {\n    const len = (points || []).length;\n    if (len > 2) {\n        const ops = [];\n        for (let i = 0; i < (len - 1); i++) {\n            ops.push(..._doubleLine(points[i][0], points[i][1], points[i + 1][0], points[i + 1][1], o));\n        }\n        if (close) {\n            ops.push(..._doubleLine(points[len - 1][0], points[len - 1][1], points[0][0], points[0][1], o));\n        }\n        return { type: 'path', ops };\n    }\n    else if (len === 2) {\n        return line(points[0][0], points[0][1], points[1][0], points[1][1], o);\n    }\n    return { type: 'path', ops: [] };\n}\nexport function polygon(points, o) {\n    return linearPath(points, true, o);\n}\nexport function rectangle(x, y, width, height, o) {\n    const points = [\n        [x, y],\n        [x + width, y],\n        [x + width, y + height],\n        [x, y + height],\n    ];\n    return polygon(points, o);\n}\nexport function curve(points, o) {\n    let o1 = _curveWithOffset(points, 1 * (1 + o.roughness * 0.2), o);\n    if (!o.disableMultiStroke) {\n        const o2 = _curveWithOffset(points, 1.5 * (1 + o.roughness * 0.22), cloneOptionsAlterSeed(o));\n        o1 = o1.concat(o2);\n    }\n    return { type: 'path', ops: o1 };\n}\nexport function ellipse(x, y, width, height, o) {\n    const params = generateEllipseParams(width, height, o);\n    return ellipseWithParams(x, y, o, params).opset;\n}\nexport function generateEllipseParams(width, height, o) {\n    const psq = Math.sqrt(Math.PI * 2 * Math.sqrt((Math.pow(width / 2, 2) + Math.pow(height / 2, 2)) / 2));\n    const stepCount = Math.ceil(Math.max(o.curveStepCount, (o.curveStepCount / Math.sqrt(200)) * psq));\n    const increment = (Math.PI * 2) / stepCount;\n    let rx = Math.abs(width / 2);\n    let ry = Math.abs(height / 2);\n    const curveFitRandomness = 1 - o.curveFitting;\n    rx += _offsetOpt(rx * curveFitRandomness, o);\n    ry += _offsetOpt(ry * curveFitRandomness, o);\n    return { increment, rx, ry };\n}\nexport function ellipseWithParams(x, y, o, ellipseParams) {\n    const [ap1, cp1] = _computeEllipsePoints(ellipseParams.increment, x, y, ellipseParams.rx, ellipseParams.ry, 1, ellipseParams.increment * _offset(0.1, _offset(0.4, 1, o), o), o);\n    let o1 = _curve(ap1, null, o);\n    if ((!o.disableMultiStroke) && (o.roughness !== 0)) {\n        const [ap2] = _computeEllipsePoints(ellipseParams.increment, x, y, ellipseParams.rx, ellipseParams.ry, 1.5, 0, o);\n        const o2 = _curve(ap2, null, o);\n        o1 = o1.concat(o2);\n    }\n    return {\n        estimatedPoints: cp1,\n        opset: { type: 'path', ops: o1 },\n    };\n}\nexport function arc(x, y, width, height, start, stop, closed, roughClosure, o) {\n    const cx = x;\n    const cy = y;\n    let rx = Math.abs(width / 2);\n    let ry = Math.abs(height / 2);\n    rx += _offsetOpt(rx * 0.01, o);\n    ry += _offsetOpt(ry * 0.01, o);\n    let strt = start;\n    let stp = stop;\n    while (strt < 0) {\n        strt += Math.PI * 2;\n        stp += Math.PI * 2;\n    }\n    if ((stp - strt) > (Math.PI * 2)) {\n        strt = 0;\n        stp = Math.PI * 2;\n    }\n    const ellipseInc = (Math.PI * 2) / o.curveStepCount;\n    const arcInc = Math.min(ellipseInc / 2, (stp - strt) / 2);\n    const ops = _arc(arcInc, cx, cy, rx, ry, strt, stp, 1, o);\n    if (!o.disableMultiStroke) {\n        const o2 = _arc(arcInc, cx, cy, rx, ry, strt, stp, 1.5, o);\n        ops.push(...o2);\n    }\n    if (closed) {\n        if (roughClosure) {\n            ops.push(..._doubleLine(cx, cy, cx + rx * Math.cos(strt), cy + ry * Math.sin(strt), o), ..._doubleLine(cx, cy, cx + rx * Math.cos(stp), cy + ry * Math.sin(stp), o));\n        }\n        else {\n            ops.push({ op: 'lineTo', data: [cx, cy] }, { op: 'lineTo', data: [cx + rx * Math.cos(strt), cy + ry * Math.sin(strt)] });\n        }\n    }\n    return { type: 'path', ops };\n}\nexport function svgPath(path, o) {\n    const segments = normalize(absolutize(parsePath(path)));\n    const ops = [];\n    let first = [0, 0];\n    let current = [0, 0];\n    for (const { key, data } of segments) {\n        switch (key) {\n            case 'M': {\n                const ro = 1 * (o.maxRandomnessOffset || 0);\n                const pv = o.preserveVertices;\n                ops.push({ op: 'move', data: data.map((d) => d + (pv ? 0 : _offsetOpt(ro, o))) });\n                current = [data[0], data[1]];\n                first = [data[0], data[1]];\n                break;\n            }\n            case 'L':\n                ops.push(..._doubleLine(current[0], current[1], data[0], data[1], o));\n                current = [data[0], data[1]];\n                break;\n            case 'C': {\n                const [x1, y1, x2, y2, x, y] = data;\n                ops.push(..._bezierTo(x1, y1, x2, y2, x, y, current, o));\n                current = [x, y];\n                break;\n            }\n            case 'Z':\n                ops.push(..._doubleLine(current[0], current[1], first[0], first[1], o));\n                current = [first[0], first[1]];\n                break;\n        }\n    }\n    return { type: 'path', ops };\n}\n// Fills\nexport function solidFillPolygon(polygonList, o) {\n    const ops = [];\n    for (const points of polygonList) {\n        if (points.length) {\n            const offset = o.maxRandomnessOffset || 0;\n            const len = points.length;\n            if (len > 2) {\n                ops.push({ op: 'move', data: [points[0][0] + _offsetOpt(offset, o), points[0][1] + _offsetOpt(offset, o)] });\n                for (let i = 1; i < len; i++) {\n                    ops.push({ op: 'lineTo', data: [points[i][0] + _offsetOpt(offset, o), points[i][1] + _offsetOpt(offset, o)] });\n                }\n            }\n        }\n    }\n    return { type: 'fillPath', ops };\n}\nexport function patternFillPolygons(polygonList, o) {\n    return getFiller(o, helper).fillPolygons(polygonList, o);\n}\nexport function patternFillArc(x, y, width, height, start, stop, o) {\n    const cx = x;\n    const cy = y;\n    let rx = Math.abs(width / 2);\n    let ry = Math.abs(height / 2);\n    rx += _offsetOpt(rx * 0.01, o);\n    ry += _offsetOpt(ry * 0.01, o);\n    let strt = start;\n    let stp = stop;\n    while (strt < 0) {\n        strt += Math.PI * 2;\n        stp += Math.PI * 2;\n    }\n    if ((stp - strt) > (Math.PI * 2)) {\n        strt = 0;\n        stp = Math.PI * 2;\n    }\n    const increment = (stp - strt) / o.curveStepCount;\n    const points = [];\n    for (let angle = strt; angle <= stp; angle = angle + increment) {\n        points.push([cx + rx * Math.cos(angle), cy + ry * Math.sin(angle)]);\n    }\n    points.push([cx + rx * Math.cos(stp), cy + ry * Math.sin(stp)]);\n    points.push([cx, cy]);\n    return patternFillPolygons([points], o);\n}\nexport function randOffset(x, o) {\n    return _offsetOpt(x, o);\n}\nexport function randOffsetWithRange(min, max, o) {\n    return _offset(min, max, o);\n}\nexport function doubleLineFillOps(x1, y1, x2, y2, o) {\n    return _doubleLine(x1, y1, x2, y2, o, true);\n}\n// Private helpers\nfunction cloneOptionsAlterSeed(ops) {\n    const result = Object.assign({}, ops);\n    result.randomizer = undefined;\n    if (ops.seed) {\n        result.seed = ops.seed + 1;\n    }\n    return result;\n}\nfunction random(ops) {\n    if (!ops.randomizer) {\n        ops.randomizer = new Random(ops.seed || 0);\n    }\n    return ops.randomizer.next();\n}\nfunction _offset(min, max, ops, roughnessGain = 1) {\n    return ops.roughness * roughnessGain * ((random(ops) * (max - min)) + min);\n}\nfunction _offsetOpt(x, ops, roughnessGain = 1) {\n    return _offset(-x, x, ops, roughnessGain);\n}\nfunction _doubleLine(x1, y1, x2, y2, o, filling = false) {\n    const singleStroke = filling ? o.disableMultiStrokeFill : o.disableMultiStroke;\n    const o1 = _line(x1, y1, x2, y2, o, true, false);\n    if (singleStroke) {\n        return o1;\n    }\n    const o2 = _line(x1, y1, x2, y2, o, true, true);\n    return o1.concat(o2);\n}\nfunction _line(x1, y1, x2, y2, o, move, overlay) {\n    const lengthSq = Math.pow((x1 - x2), 2) + Math.pow((y1 - y2), 2);\n    const length = Math.sqrt(lengthSq);\n    let roughnessGain = 1;\n    if (length < 200) {\n        roughnessGain = 1;\n    }\n    else if (length > 500) {\n        roughnessGain = 0.4;\n    }\n    else {\n        roughnessGain = (-0.0016668) * length + 1.233334;\n    }\n    let offset = o.maxRandomnessOffset || 0;\n    if ((offset * offset * 100) > lengthSq) {\n        offset = length / 10;\n    }\n    const halfOffset = offset / 2;\n    const divergePoint = 0.2 + random(o) * 0.2;\n    let midDispX = o.bowing * o.maxRandomnessOffset * (y2 - y1) / 200;\n    let midDispY = o.bowing * o.maxRandomnessOffset * (x1 - x2) / 200;\n    midDispX = _offsetOpt(midDispX, o, roughnessGain);\n    midDispY = _offsetOpt(midDispY, o, roughnessGain);\n    const ops = [];\n    const randomHalf = () => _offsetOpt(halfOffset, o, roughnessGain);\n    const randomFull = () => _offsetOpt(offset, o, roughnessGain);\n    const preserveVertices = o.preserveVertices;\n    if (move) {\n        if (overlay) {\n            ops.push({\n                op: 'move', data: [\n                    x1 + (preserveVertices ? 0 : randomHalf()),\n                    y1 + (preserveVertices ? 0 : randomHalf()),\n                ],\n            });\n        }\n        else {\n            ops.push({\n                op: 'move', data: [\n                    x1 + (preserveVertices ? 0 : _offsetOpt(offset, o, roughnessGain)),\n                    y1 + (preserveVertices ? 0 : _offsetOpt(offset, o, roughnessGain)),\n                ],\n            });\n        }\n    }\n    if (overlay) {\n        ops.push({\n            op: 'bcurveTo',\n            data: [\n                midDispX + x1 + (x2 - x1) * divergePoint + randomHalf(),\n                midDispY + y1 + (y2 - y1) * divergePoint + randomHalf(),\n                midDispX + x1 + 2 * (x2 - x1) * divergePoint + randomHalf(),\n                midDispY + y1 + 2 * (y2 - y1) * divergePoint + randomHalf(),\n                x2 + (preserveVertices ? 0 : randomHalf()),\n                y2 + (preserveVertices ? 0 : randomHalf()),\n            ],\n        });\n    }\n    else {\n        ops.push({\n            op: 'bcurveTo',\n            data: [\n                midDispX + x1 + (x2 - x1) * divergePoint + randomFull(),\n                midDispY + y1 + (y2 - y1) * divergePoint + randomFull(),\n                midDispX + x1 + 2 * (x2 - x1) * divergePoint + randomFull(),\n                midDispY + y1 + 2 * (y2 - y1) * divergePoint + randomFull(),\n                x2 + (preserveVertices ? 0 : randomFull()),\n                y2 + (preserveVertices ? 0 : randomFull()),\n            ],\n        });\n    }\n    return ops;\n}\nfunction _curveWithOffset(points, offset, o) {\n    const ps = [];\n    ps.push([\n        points[0][0] + _offsetOpt(offset, o),\n        points[0][1] + _offsetOpt(offset, o),\n    ]);\n    ps.push([\n        points[0][0] + _offsetOpt(offset, o),\n        points[0][1] + _offsetOpt(offset, o),\n    ]);\n    for (let i = 1; i < points.length; i++) {\n        ps.push([\n            points[i][0] + _offsetOpt(offset, o),\n            points[i][1] + _offsetOpt(offset, o),\n        ]);\n        if (i === (points.length - 1)) {\n            ps.push([\n                points[i][0] + _offsetOpt(offset, o),\n                points[i][1] + _offsetOpt(offset, o),\n            ]);\n        }\n    }\n    return _curve(ps, null, o);\n}\nfunction _curve(points, closePoint, o) {\n    const len = points.length;\n    const ops = [];\n    if (len > 3) {\n        const b = [];\n        const s = 1 - o.curveTightness;\n        ops.push({ op: 'move', data: [points[1][0], points[1][1]] });\n        for (let i = 1; (i + 2) < len; i++) {\n            const cachedVertArray = points[i];\n            b[0] = [cachedVertArray[0], cachedVertArray[1]];\n            b[1] = [cachedVertArray[0] + (s * points[i + 1][0] - s * points[i - 1][0]) / 6, cachedVertArray[1] + (s * points[i + 1][1] - s * points[i - 1][1]) / 6];\n            b[2] = [points[i + 1][0] + (s * points[i][0] - s * points[i + 2][0]) / 6, points[i + 1][1] + (s * points[i][1] - s * points[i + 2][1]) / 6];\n            b[3] = [points[i + 1][0], points[i + 1][1]];\n            ops.push({ op: 'bcurveTo', data: [b[1][0], b[1][1], b[2][0], b[2][1], b[3][0], b[3][1]] });\n        }\n        if (closePoint && closePoint.length === 2) {\n            const ro = o.maxRandomnessOffset;\n            ops.push({ op: 'lineTo', data: [closePoint[0] + _offsetOpt(ro, o), closePoint[1] + _offsetOpt(ro, o)] });\n        }\n    }\n    else if (len === 3) {\n        ops.push({ op: 'move', data: [points[1][0], points[1][1]] });\n        ops.push({\n            op: 'bcurveTo',\n            data: [\n                points[1][0], points[1][1],\n                points[2][0], points[2][1],\n                points[2][0], points[2][1],\n            ],\n        });\n    }\n    else if (len === 2) {\n        ops.push(..._doubleLine(points[0][0], points[0][1], points[1][0], points[1][1], o));\n    }\n    return ops;\n}\nfunction _computeEllipsePoints(increment, cx, cy, rx, ry, offset, overlap, o) {\n    const coreOnly = o.roughness === 0;\n    const corePoints = [];\n    const allPoints = [];\n    if (coreOnly) {\n        increment = increment / 4;\n        allPoints.push([\n            cx + rx * Math.cos(-increment),\n            cy + ry * Math.sin(-increment),\n        ]);\n        for (let angle = 0; angle <= Math.PI * 2; angle = angle + increment) {\n            const p = [\n                cx + rx * Math.cos(angle),\n                cy + ry * Math.sin(angle),\n            ];\n            corePoints.push(p);\n            allPoints.push(p);\n        }\n        allPoints.push([\n            cx + rx * Math.cos(0),\n            cy + ry * Math.sin(0),\n        ]);\n        allPoints.push([\n            cx + rx * Math.cos(increment),\n            cy + ry * Math.sin(increment),\n        ]);\n    }\n    else {\n        const radOffset = _offsetOpt(0.5, o) - (Math.PI / 2);\n        allPoints.push([\n            _offsetOpt(offset, o) + cx + 0.9 * rx * Math.cos(radOffset - increment),\n            _offsetOpt(offset, o) + cy + 0.9 * ry * Math.sin(radOffset - increment),\n        ]);\n        const endAngle = Math.PI * 2 + radOffset - 0.01;\n        for (let angle = radOffset; angle < endAngle; angle = angle + increment) {\n            const p = [\n                _offsetOpt(offset, o) + cx + rx * Math.cos(angle),\n                _offsetOpt(offset, o) + cy + ry * Math.sin(angle),\n            ];\n            corePoints.push(p);\n            allPoints.push(p);\n        }\n        allPoints.push([\n            _offsetOpt(offset, o) + cx + rx * Math.cos(radOffset + Math.PI * 2 + overlap * 0.5),\n            _offsetOpt(offset, o) + cy + ry * Math.sin(radOffset + Math.PI * 2 + overlap * 0.5),\n        ]);\n        allPoints.push([\n            _offsetOpt(offset, o) + cx + 0.98 * rx * Math.cos(radOffset + overlap),\n            _offsetOpt(offset, o) + cy + 0.98 * ry * Math.sin(radOffset + overlap),\n        ]);\n        allPoints.push([\n            _offsetOpt(offset, o) + cx + 0.9 * rx * Math.cos(radOffset + overlap * 0.5),\n            _offsetOpt(offset, o) + cy + 0.9 * ry * Math.sin(radOffset + overlap * 0.5),\n        ]);\n    }\n    return [allPoints, corePoints];\n}\nfunction _arc(increment, cx, cy, rx, ry, strt, stp, offset, o) {\n    const radOffset = strt + _offsetOpt(0.1, o);\n    const points = [];\n    points.push([\n        _offsetOpt(offset, o) + cx + 0.9 * rx * Math.cos(radOffset - increment),\n        _offsetOpt(offset, o) + cy + 0.9 * ry * Math.sin(radOffset - increment),\n    ]);\n    for (let angle = radOffset; angle <= stp; angle = angle + increment) {\n        points.push([\n            _offsetOpt(offset, o) + cx + rx * Math.cos(angle),\n            _offsetOpt(offset, o) + cy + ry * Math.sin(angle),\n        ]);\n    }\n    points.push([\n        cx + rx * Math.cos(stp),\n        cy + ry * Math.sin(stp),\n    ]);\n    points.push([\n        cx + rx * Math.cos(stp),\n        cy + ry * Math.sin(stp),\n    ]);\n    return _curve(points, null, o);\n}\nfunction _bezierTo(x1, y1, x2, y2, x, y, current, o) {\n    const ops = [];\n    const ros = [o.maxRandomnessOffset || 1, (o.maxRandomnessOffset || 1) + 0.3];\n    let f = [0, 0];\n    const iterations = o.disableMultiStroke ? 1 : 2;\n    const preserveVertices = o.preserveVertices;\n    for (let i = 0; i < iterations; i++) {\n        if (i === 0) {\n            ops.push({ op: 'move', data: [current[0], current[1]] });\n        }\n        else {\n            ops.push({ op: 'move', data: [current[0] + (preserveVertices ? 0 : _offsetOpt(ros[0], o)), current[1] + (preserveVertices ? 0 : _offsetOpt(ros[0], o))] });\n        }\n        f = preserveVertices ? [x, y] : [x + _offsetOpt(ros[i], o), y + _offsetOpt(ros[i], o)];\n        ops.push({\n            op: 'bcurveTo',\n            data: [\n                x1 + _offsetOpt(ros[i], o), y1 + _offsetOpt(ros[i], o),\n                x2 + _offsetOpt(ros[i], o), y2 + _offsetOpt(ros[i], o),\n                f[0], f[1],\n            ],\n        });\n    }\n    return ops;\n}\n"],"names":[],"sourceRoot":""}\\n//# sourceURL=webpack-internal:///../../../node_modules/roughjs/bin/renderer.js\\n\");\n\n//# sourceURL=webpack://Excalidraw/../../../node_modules/roughjs/bin/renderer.js?");
579
579
 
580
580
  /***/ }),
581
581
 
@@ -3734,7 +3734,7 @@ eval("module.exports = JSON.parse('{\"labels\":{\"paste\":\"貼上\",\"pasteChar
3734
3734
  /***/ ((module) => {
3735
3735
 
3736
3736
  "use strict";
3737
- eval("module.exports = JSON.parse('{\"name\":\"@zsviczian/excalidraw\",\"version\":\"0.10.0-obsidian-18\",\"main\":\"main.js\",\"types\":\"types/packages/excalidraw/index.d.ts\",\"files\":[\"dist/*\",\"types/*\"],\"publishConfig\":{\"access\":\"public\"},\"description\":\"Excalidraw as a React component\",\"repository\":\"https://github.com/excalidraw/excalidraw\",\"license\":\"MIT\",\"keywords\":[\"excalidraw\",\"excalidraw-embed\",\"react\",\"npm\",\"npm excalidraw\"],\"browserslist\":{\"production\":[\">0.2%\",\"not dead\",\"not ie <= 11\",\"not op_mini all\",\"not safari < 12\",\"not kaios <= 2.5\",\"not edge < 79\",\"not chrome < 70\",\"not and_uc < 13\",\"not samsung < 10\"],\"development\":[\"last 1 chrome version\",\"last 1 firefox version\",\"last 1 safari version\"]},\"peerDependencies\":{\"react\":\"^17.0.2\",\"react-dom\":\"^17.0.2\"},\"devDependencies\":{\"@babel/core\":\"7.16.0\",\"@babel/plugin-transform-arrow-functions\":\"7.16.0\",\"@babel/plugin-transform-async-to-generator\":\"7.16.0\",\"@babel/plugin-transform-runtime\":\"7.16.4\",\"@babel/plugin-transform-typescript\":\"7.16.1\",\"@babel/preset-env\":\"7.16.4\",\"@babel/preset-react\":\"7.16.0\",\"@babel/preset-typescript\":\"7.16.0\",\"autoprefixer\":\"10.4.0\",\"babel-loader\":\"8.2.3\",\"babel-plugin-transform-class-properties\":\"6.24.1\",\"cross-env\":\"7.0.3\",\"css-loader\":\"6.5.1\",\"file-loader\":\"6.2.0\",\"mini-css-extract-plugin\":\"2.4.5\",\"postcss-loader\":\"6.2.1\",\"sass-loader\":\"12.3.0\",\"terser-webpack-plugin\":\"5.2.5\",\"ts-loader\":\"9.2.6\",\"typescript\":\"4.5.2\",\"webpack\":\"5.64.4\",\"webpack-bundle-analyzer\":\"4.5.0\",\"webpack-cli\":\"4.9.1\"},\"bugs\":\"https://github.com/excalidraw/excalidraw/issues\",\"homepage\":\"https://github.com/excalidraw/excalidraw/tree/master/src/packages/excalidraw\",\"scripts\":{\"gen:types\":\"tsc --project ../../../tsconfig-types.json\",\"build:umd\":\"cross-env NODE_ENV=production webpack --config webpack.prod.config.js && cross-env NODE_ENV=development webpack --config webpack.dev.config.js && yarn gen:types\",\"build:umd:withAnalyzer\":\"cross-env NODE_ENV=production ANALYZER=true webpack --config webpack.prod.config.js\",\"pack\":\"yarn build:umd && yarn pack\"},\"dependencies\":{\"dotenv\":\"10.0.0\"}}');\n\n//# sourceURL=webpack://Excalidraw/./package.json?");
3737
+ eval("module.exports = JSON.parse('{\"name\":\"@zsviczian/excalidraw\",\"version\":\"0.10.0-obsidian-19\",\"main\":\"main.js\",\"types\":\"types/packages/excalidraw/index.d.ts\",\"files\":[\"dist/*\",\"types/*\"],\"publishConfig\":{\"access\":\"public\"},\"description\":\"Excalidraw as a React component\",\"repository\":\"https://github.com/excalidraw/excalidraw\",\"license\":\"MIT\",\"keywords\":[\"excalidraw\",\"excalidraw-embed\",\"react\",\"npm\",\"npm excalidraw\"],\"browserslist\":{\"production\":[\">0.2%\",\"not dead\",\"not ie <= 11\",\"not op_mini all\",\"not safari < 12\",\"not kaios <= 2.5\",\"not edge < 79\",\"not chrome < 70\",\"not and_uc < 13\",\"not samsung < 10\"],\"development\":[\"last 1 chrome version\",\"last 1 firefox version\",\"last 1 safari version\"]},\"peerDependencies\":{\"react\":\"^17.0.2\",\"react-dom\":\"^17.0.2\"},\"devDependencies\":{\"@babel/core\":\"7.16.0\",\"@babel/plugin-transform-arrow-functions\":\"7.16.0\",\"@babel/plugin-transform-async-to-generator\":\"7.16.0\",\"@babel/plugin-transform-runtime\":\"7.16.4\",\"@babel/plugin-transform-typescript\":\"7.16.1\",\"@babel/preset-env\":\"7.16.4\",\"@babel/preset-react\":\"7.16.0\",\"@babel/preset-typescript\":\"7.16.0\",\"autoprefixer\":\"10.4.0\",\"babel-loader\":\"8.2.3\",\"babel-plugin-transform-class-properties\":\"6.24.1\",\"cross-env\":\"7.0.3\",\"css-loader\":\"6.5.1\",\"mini-css-extract-plugin\":\"2.4.5\",\"postcss-loader\":\"6.2.1\",\"sass-loader\":\"12.3.0\",\"terser-webpack-plugin\":\"5.2.5\",\"ts-loader\":\"9.2.6\",\"typescript\":\"4.5.2\",\"webpack\":\"5.64.4\",\"webpack-bundle-analyzer\":\"4.5.0\",\"webpack-cli\":\"4.9.1\"},\"bugs\":\"https://github.com/excalidraw/excalidraw/issues\",\"homepage\":\"https://github.com/excalidraw/excalidraw/tree/master/src/packages/excalidraw\",\"scripts\":{\"gen:types\":\"tsc --project ../../../tsconfig-types.json\",\"build:umd\":\"cross-env NODE_ENV=production webpack --config webpack.prod.config.js && cross-env NODE_ENV=development webpack --config webpack.dev.config.js && yarn gen:types\",\"build:umd:withAnalyzer\":\"cross-env NODE_ENV=production ANALYZER=true webpack --config webpack.prod.config.js\",\"pack\":\"yarn build:umd && yarn pack\"},\"dependencies\":{\"dotenv\":\"10.0.0\"}}');\n\n//# sourceURL=webpack://Excalidraw/./package.json?");
3738
3738
 
3739
3739
  /***/ })
3740
3740