@zsviczian/excalidraw 0.10.0-obsidian-15 → 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.
- package/dist/excalidraw.development.js +5 -5
- package/dist/excalidraw.production.min.js +1 -1
- package/package.json +1 -2
- package/types/packages/excalidraw/index.d.ts +1 -1
- package/types/packages/excalidraw/webpack.dev.config.d.ts +1 -0
- package/types/packages/excalidraw/webpack.prod.config.d.ts +1 -0
- package/types/packages/utils.d.ts +2 -0
|
@@ -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
|
|
|
@@ -2832,7 +2832,7 @@ eval("eval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony export */
|
|
|
2832
2832
|
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
2833
2833
|
|
|
2834
2834
|
"use strict";
|
|
2835
|
-
eval("eval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */ \\\"default\\\": () => (__WEBPACK_DEFAULT_EXPORT__),\\n/* harmony export */ \\\"FONT_FAMILY\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.FONT_FAMILY),\\n/* harmony export */ \\\"THEME\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.THEME),\\n/* harmony export */ \\\"bumpVersion\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.bumpVersion),\\n/* harmony export */ \\\"defaultLang\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.defaultLang),\\n/* harmony export */ \\\"exportToBlob\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.exportToBlob),\\n/* harmony export */ \\\"exportToCanvas\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.exportToCanvas),\\n/* harmony export */ \\\"exportToSvg\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.exportToSvg),\\n/* harmony export */ \\\"getCommonBoundingBox\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.getCommonBoundingBox),\\n/* harmony export */ \\\"getFreeDrawSvgPath\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.getFreeDrawSvgPath),\\n/* harmony export */ \\\"getMaximumGroups\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.getMaximumGroups),\\n/* harmony export */ \\\"getNonDeletedElements\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.getNonDeletedElements),\\n/* harmony export */ \\\"getSceneVersion\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.getSceneVersion),\\n/* harmony export */ \\\"isInvisiblySmallElement\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.isInvisiblySmallElement),\\n/* harmony export */ \\\"isLinearElement\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.isLinearElement),\\n/* harmony export */ \\\"languages\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.languages),\\n/* harmony export */ \\\"loadFromBlob\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.loadFromBlob),\\n/* harmony export */ \\\"loadLibraryFromBlob\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.loadLibraryFromBlob),\\n/* harmony export */ \\\"mutateElement\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.mutateElement),\\n/* harmony export */ \\\"newElementWith\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.newElementWith),\\n/* harmony export */ \\\"restore\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.restore),\\n/* harmony export */ \\\"restoreAppState\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.restoreAppState),\\n/* harmony export */ \\\"restoreElements\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.restoreElements),\\n/* harmony export */ \\\"serializeAsJSON\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.serializeAsJSON)\\n/* harmony export */ });\\n/* harmony import */ var _index__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./index */ \\\"./index.tsx\\\");\\n/* harmony import */ var _public_fonts_css__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../../public/fonts.css */ \\\"../../../public/fonts.css\\\");\\n/* harmony import */ var _public_fonts_css__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_public_fonts_css__WEBPACK_IMPORTED_MODULE_1__);\\n\\r\\n\\r\\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (_index__WEBPACK_IMPORTED_MODULE_0__[\\\"default\\\"]);\\r\\n\\r\\n//# sourceURL=[module]\\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
2835
|
+
eval("eval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */ \\\"default\\\": () => (__WEBPACK_DEFAULT_EXPORT__),\\n/* harmony export */ \\\"FONT_FAMILY\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.FONT_FAMILY),\\n/* harmony export */ \\\"THEME\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.THEME),\\n/* harmony export */ \\\"bumpVersion\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.bumpVersion),\\n/* harmony export */ \\\"defaultLang\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.defaultLang),\\n/* harmony export */ \\\"determineFocusDistance\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.determineFocusDistance),\\n/* harmony export */ \\\"exportToBlob\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.exportToBlob),\\n/* harmony export */ \\\"exportToCanvas\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.exportToCanvas),\\n/* harmony export */ \\\"exportToSvg\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.exportToSvg),\\n/* harmony export */ \\\"getCommonBoundingBox\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.getCommonBoundingBox),\\n/* harmony export */ \\\"getFreeDrawSvgPath\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.getFreeDrawSvgPath),\\n/* harmony export */ \\\"getMaximumGroups\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.getMaximumGroups),\\n/* harmony export */ \\\"getNonDeletedElements\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.getNonDeletedElements),\\n/* harmony export */ \\\"getSceneVersion\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.getSceneVersion),\\n/* harmony export */ \\\"intersectElementWithLine\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.intersectElementWithLine),\\n/* harmony export */ \\\"isInvisiblySmallElement\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.isInvisiblySmallElement),\\n/* harmony export */ \\\"isLinearElement\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.isLinearElement),\\n/* harmony export */ \\\"languages\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.languages),\\n/* harmony export */ \\\"loadFromBlob\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.loadFromBlob),\\n/* harmony export */ \\\"loadLibraryFromBlob\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.loadLibraryFromBlob),\\n/* harmony export */ \\\"mutateElement\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.mutateElement),\\n/* harmony export */ \\\"newElementWith\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.newElementWith),\\n/* harmony export */ \\\"restore\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.restore),\\n/* harmony export */ \\\"restoreAppState\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.restoreAppState),\\n/* harmony export */ \\\"restoreElements\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.restoreElements),\\n/* harmony export */ \\\"serializeAsJSON\\\": () => (/* reexport safe */ _index__WEBPACK_IMPORTED_MODULE_0__.serializeAsJSON)\\n/* harmony export */ });\\n/* harmony import */ var _index__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./index */ \\\"./index.tsx\\\");\\n/* harmony import */ var _public_fonts_css__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../../public/fonts.css */ \\\"../../../public/fonts.css\\\");\\n/* harmony import */ var _public_fonts_css__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_public_fonts_css__WEBPACK_IMPORTED_MODULE_1__);\\n\\r\\n\\r\\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (_index__WEBPACK_IMPORTED_MODULE_0__[\\\"default\\\"]);\\r\\n\\r\\n//# sourceURL=[module]\\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9lbnRyeS5qcy5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUFpQztBQUNFO0FBQ25DLGlFQUFlLDhDQUFVLEVBQUM7QUFDRiIsInNvdXJjZXMiOlsid2VicGFjazovLy8uL2VudHJ5LmpzPzVhZTUiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEV4Y2FsaWRyYXcgZnJvbSBcIi4vaW5kZXhcIjtcbmltcG9ydCBcIi4uLy4uLy4uL3B1YmxpYy9mb250cy5jc3NcIjtcbmV4cG9ydCBkZWZhdWx0IEV4Y2FsaWRyYXc7XG5leHBvcnQgKiBmcm9tIFwiLi9pbmRleFwiOyJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\\n//# sourceURL=webpack-internal:///./entry.js\\n\");\n\n//# sourceURL=webpack://Excalidraw/./entry.js?");
|
|
2836
2836
|
|
|
2837
2837
|
/***/ }),
|
|
2838
2838
|
|
|
@@ -2843,7 +2843,7 @@ eval("eval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony export */
|
|
|
2843
2843
|
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
2844
2844
|
|
|
2845
2845
|
"use strict";
|
|
2846
|
-
eval("eval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */ \\\"default\\\": () => (__WEBPACK_DEFAULT_EXPORT__),\\n/* harmony export */ \\\"getSceneVersion\\\": () => (/* reexport safe */ _element__WEBPACK_IMPORTED_MODULE_11__.getSceneVersion),\\n/* harmony export */ \\\"isInvisiblySmallElement\\\": () => (/* reexport safe */ _element__WEBPACK_IMPORTED_MODULE_11__.isInvisiblySmallElement),\\n/* harmony export */ \\\"getNonDeletedElements\\\": () => (/* reexport safe */ _element__WEBPACK_IMPORTED_MODULE_11__.getNonDeletedElements),\\n/* harmony export */ \\\"defaultLang\\\": () => (/* reexport safe */ _i18n__WEBPACK_IMPORTED_MODULE_8__.defaultLang),\\n/* harmony export */ \\\"languages\\\": () => (/* reexport safe */ _i18n__WEBPACK_IMPORTED_MODULE_8__.languages),\\n/* harmony export */ \\\"restore\\\": () => (/* reexport safe */ _data_restore__WEBPACK_IMPORTED_MODULE_12__.restore),\\n/* harmony export */ \\\"restoreAppState\\\": () => (/* reexport safe */ _data_restore__WEBPACK_IMPORTED_MODULE_12__.restoreAppState),\\n/* harmony export */ \\\"restoreElements\\\": () => (/* reexport safe */ _data_restore__WEBPACK_IMPORTED_MODULE_12__.restoreElements),\\n/* harmony export */ \\\"exportToCanvas\\\": () => (/* reexport safe */ _packages_utils__WEBPACK_IMPORTED_MODULE_13__.exportToCanvas),\\n/* harmony export */ \\\"exportToBlob\\\": () => (/* reexport safe */ _packages_utils__WEBPACK_IMPORTED_MODULE_13__.exportToBlob),\\n/* harmony export */ \\\"exportToSvg\\\": () => (/* reexport safe */ _packages_utils__WEBPACK_IMPORTED_MODULE_13__.exportToSvg),\\n/* harmony export */ \\\"serializeAsJSON\\\": () => (/* reexport safe */ _packages_utils__WEBPACK_IMPORTED_MODULE_13__.serializeAsJSON),\\n/* harmony export */ \\\"loadLibraryFromBlob\\\": () => (/* reexport safe */ _packages_utils__WEBPACK_IMPORTED_MODULE_13__.loadLibraryFromBlob),\\n/* harmony export */ \\\"loadFromBlob\\\": () => (/* reexport safe */ _packages_utils__WEBPACK_IMPORTED_MODULE_13__.loadFromBlob),\\n/* harmony export */ \\\"getFreeDrawSvgPath\\\": () => (/* reexport safe */ _packages_utils__WEBPACK_IMPORTED_MODULE_13__.getFreeDrawSvgPath),\\n/* harmony export */ \\\"getCommonBoundingBox\\\": () => (/* reexport safe */ _packages_utils__WEBPACK_IMPORTED_MODULE_13__.getCommonBoundingBox),\\n/* harmony export */ \\\"getMaximumGroups\\\": () => (/* reexport safe */ _packages_utils__WEBPACK_IMPORTED_MODULE_13__.getMaximumGroups),\\n/* harmony export */ \\\"isLinearElement\\\": () => (/* reexport safe */ _element_typeChecks__WEBPACK_IMPORTED_MODULE_14__.isLinearElement),\\n/* harmony export */ \\\"FONT_FAMILY\\\": () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_9__.FONT_FAMILY),\\n/* harmony export */ \\\"THEME\\\": () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_9__.THEME),\\n/* harmony export */ \\\"mutateElement\\\": () => (/* reexport safe */ _element_mutateElement__WEBPACK_IMPORTED_MODULE_15__.mutateElement),\\n/* harmony export */ \\\"newElementWith\\\": () => (/* reexport safe */ _element_mutateElement__WEBPACK_IMPORTED_MODULE_15__.newElementWith),\\n/* harmony export */ \\\"bumpVersion\\\": () => (/* reexport safe */ _element_mutateElement__WEBPACK_IMPORTED_MODULE_15__.bumpVersion)\\n/* harmony export */ });\\n/* harmony import */ var _babel_runtime_helpers_objectWithoutProperties__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/objectWithoutProperties */ \\\"./node_modules/@babel/runtime/helpers/objectWithoutProperties.js\\\");\\n/* harmony import */ var _babel_runtime_helpers_objectWithoutProperties__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_objectWithoutProperties__WEBPACK_IMPORTED_MODULE_0__);\\n/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ \\\"./node_modules/@babel/runtime/helpers/defineProperty.js\\\");\\n/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1__);\\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! react */ \\\"react\\\");\\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_2__);\\n/* harmony import */ var _publicPath__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./publicPath */ \\\"./publicPath.js\\\");\\n/* harmony import */ var _components_InitializeApp__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../../components/InitializeApp */ \\\"../../components/InitializeApp.tsx\\\");\\n/* harmony import */ var _components_App__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../../components/App */ \\\"../../components/App.tsx\\\");\\n/* harmony import */ var _css_app_scss__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../../css/app.scss */ \\\"../../css/app.scss\\\");\\n/* harmony import */ var _css_app_scss__WEBPACK_IMPORTED_MODULE_6___default = /*#__PURE__*/__webpack_require__.n(_css_app_scss__WEBPACK_IMPORTED_MODULE_6__);\\n/* harmony import */ var _css_styles_scss__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../../css/styles.scss */ \\\"../../css/styles.scss\\\");\\n/* harmony import */ var _css_styles_scss__WEBPACK_IMPORTED_MODULE_7___default = /*#__PURE__*/__webpack_require__.n(_css_styles_scss__WEBPACK_IMPORTED_MODULE_7__);\\n/* harmony import */ var _i18n__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../../i18n */ \\\"../../i18n.ts\\\");\\n/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ../../constants */ \\\"../../constants.ts\\\");\\n/* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! react/jsx-runtime */ \\\"../../../node_modules/react/jsx-runtime.js\\\");\\n/* harmony import */ var _element__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ../../element */ \\\"../../element/index.ts\\\");\\n/* harmony import */ var _data_restore__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ../../data/restore */ \\\"../../data/restore.ts\\\");\\n/* harmony import */ var _packages_utils__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ../../packages/utils */ \\\"../utils.ts\\\");\\n/* harmony import */ var _element_typeChecks__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(/*! ../../element/typeChecks */ \\\"../../element/typeChecks.ts\\\");\\n/* harmony import */ var _element_mutateElement__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(/*! ../../element/mutateElement */ \\\"../../element/mutateElement.ts\\\");\\n\\r\\n\\r\\nconst _excluded = [\\\"initialData\\\", \\\"UIOptions\\\"], _excluded2 = [\\\"initialData\\\", \\\"UIOptions\\\"];\\r\\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) {\\r\\n var symbols = Object.getOwnPropertySymbols(object);\\r\\n if (enumerableOnly) {\\r\\n symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; });\\r\\n }\\r\\n keys.push.apply(keys, symbols);\\r\\n} return keys; }\\r\\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) {\\r\\n var source = arguments[i] != null ? arguments[i] : {};\\r\\n if (i % 2) {\\r\\n ownKeys(Object(source), true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1___default()(target, key, source[key]); });\\r\\n }\\r\\n else if (Object.getOwnPropertyDescriptors) {\\r\\n Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));\\r\\n }\\r\\n else {\\r\\n ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); });\\r\\n }\\r\\n} return target; }\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\nconst Excalidraw = function (props) {\\r\\n var _a, _b, _c;\\r\\n const { onChange, initialData, excalidrawRef, onCollabButtonClick, isCollaborating, onPointerUpdate, renderTopRightUI, renderFooter, langCode = _i18n__WEBPACK_IMPORTED_MODULE_8__.defaultLang.code, viewModeEnabled, zenModeEnabled, gridModeEnabled, libraryReturnUrl, theme, name, renderCustomStats, onPaste, onDrop, detectScroll = true, handleKeyboardGlobally = false, onLibraryChange, autoFocus = false, onBeforeTextEdit, onBeforeTextSubmit, generateIdForFile, onThemeChange } = props;\\r\\n const canvasActions = (_a = props.UIOptions) === null || _a === void 0 ? void 0 : _a.canvasActions;\\r\\n const UIOptions = {\\r\\n canvasActions: _objectSpread(_objectSpread({}, _constants__WEBPACK_IMPORTED_MODULE_9__.DEFAULT_UI_OPTIONS.canvasActions), canvasActions)\\r\\n };\\r\\n if (canvasActions === null || canvasActions === void 0 ? void 0 : canvasActions.export) {\\r\\n UIOptions.canvasActions.export.saveFileToDisk = (_c = (_b = canvasActions.export) === null || _b === void 0 ? void 0 : _b.saveFileToDisk) !== null && _c !== void 0 ? _c : _constants__WEBPACK_IMPORTED_MODULE_9__.DEFAULT_UI_OPTIONS.canvasActions[\\\"export\\\"].saveFileToDisk;\\r\\n }\\r\\n (0,react__WEBPACK_IMPORTED_MODULE_2__.useEffect)(function () {\\r\\n // Block pinch-zooming on iOS outside of the content area\\r\\n const handleTouchMove = function (event) {\\r\\n // @ts-ignore\\r\\n if (typeof event.scale === \\\"number\\\" && event.scale !== 1) {\\r\\n event.preventDefault();\\r\\n }\\r\\n };\\r\\n document.addEventListener(\\\"touchmove\\\", handleTouchMove, {\\r\\n passive: false\\r\\n });\\r\\n return function () {\\r\\n document.removeEventListener(\\\"touchmove\\\", handleTouchMove);\\r\\n };\\r\\n }, []);\\r\\n return /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_10__.jsx)(_components_InitializeApp__WEBPACK_IMPORTED_MODULE_4__.InitializeApp, {\\r\\n langCode: langCode,\\r\\n children: /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_10__.jsx)(_components_App__WEBPACK_IMPORTED_MODULE_5__[\\\"default\\\"], {\\r\\n onChange: onChange,\\r\\n initialData: initialData,\\r\\n excalidrawRef: excalidrawRef,\\r\\n onCollabButtonClick: onCollabButtonClick,\\r\\n isCollaborating: isCollaborating,\\r\\n onPointerUpdate: onPointerUpdate,\\r\\n renderTopRightUI: renderTopRightUI,\\r\\n renderFooter: renderFooter,\\r\\n langCode: langCode,\\r\\n viewModeEnabled: viewModeEnabled,\\r\\n zenModeEnabled: zenModeEnabled,\\r\\n gridModeEnabled: gridModeEnabled,\\r\\n libraryReturnUrl: libraryReturnUrl,\\r\\n theme: theme,\\r\\n name: name,\\r\\n renderCustomStats: renderCustomStats,\\r\\n UIOptions: UIOptions,\\r\\n onPaste: onPaste,\\r\\n onDrop: onDrop,\\r\\n detectScroll: detectScroll,\\r\\n handleKeyboardGlobally: handleKeyboardGlobally,\\r\\n onLibraryChange: onLibraryChange,\\r\\n autoFocus: autoFocus,\\r\\n onBeforeTextEdit: onBeforeTextEdit,\\r\\n onBeforeTextSubmit: onBeforeTextSubmit,\\r\\n generateIdForFile: generateIdForFile,\\r\\n onThemeChange: onThemeChange\\r\\n })\\r\\n });\\r\\n};\\r\\nconst areEqual = function (prevProps, nextProps) {\\r\\n const { initialData: prevInitialData, UIOptions: prevUIOptions = {} } = prevProps, prev = _babel_runtime_helpers_objectWithoutProperties__WEBPACK_IMPORTED_MODULE_0___default()(prevProps, _excluded);\\r\\n const { initialData: nextInitialData, UIOptions: nextUIOptions = {} } = nextProps, next = _babel_runtime_helpers_objectWithoutProperties__WEBPACK_IMPORTED_MODULE_0___default()(nextProps, _excluded2); // comparing UIOptions\\r\\n const prevUIOptionsKeys = Object.keys(prevUIOptions);\\r\\n const nextUIOptionsKeys = Object.keys(nextUIOptions);\\r\\n if (prevUIOptionsKeys.length !== nextUIOptionsKeys.length) {\\r\\n return false;\\r\\n }\\r\\n const isUIOptionsSame = prevUIOptionsKeys.every(function (key) {\\r\\n if (key === \\\"canvasActions\\\") {\\r\\n const canvasOptionKeys = Object.keys(prevUIOptions.canvasActions);\\r\\n canvasOptionKeys.every(function (key) {\\r\\n var _a, _b, _c, _d;\\r\\n if (key === \\\"export\\\" && ((_a = prevUIOptions === null || prevUIOptions === void 0 ? void 0 : prevUIOptions.canvasActions) === null || _a === void 0 ? void 0 : _a.export) && ((_b = nextUIOptions === null || nextUIOptions === void 0 ? void 0 : nextUIOptions.canvasActions) === null || _b === void 0 ? void 0 : _b.export)) {\\r\\n return prevUIOptions.canvasActions.export.saveFileToDisk === nextUIOptions.canvasActions.export.saveFileToDisk;\\r\\n }\\r\\n return ((_c = prevUIOptions === null || prevUIOptions === void 0 ? void 0 : prevUIOptions.canvasActions) === null || _c === void 0 ? void 0 : _c[key]) === ((_d = nextUIOptions === null || nextUIOptions === void 0 ? void 0 : nextUIOptions.canvasActions) === null || _d === void 0 ? void 0 : _d[key]);\\r\\n });\\r\\n }\\r\\n return true;\\r\\n });\\r\\n const prevKeys = Object.keys(prevProps);\\r\\n const nextKeys = Object.keys(nextProps);\\r\\n return isUIOptionsSame && prevKeys.length === nextKeys.length && prevKeys.every(function (key) {\\r\\n return prev[key] === next[key];\\r\\n });\\r\\n};\\r\\nconst forwardedRefComp = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_2__.forwardRef)(function (props, ref) {\\r\\n return /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_10__.jsx)(Excalidraw, _objectSpread(_objectSpread({}, props), {}, {\\r\\n excalidrawRef: ref\\r\\n }));\\r\\n});\\r\\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (/*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_2___default().memo(forwardedRefComp, areEqual));\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n//# sourceURL=[module]\\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./index.tsx.js","mappings":"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","sources":["webpack:///./index.tsx?ce74"],"sourcesContent":["import _objectWithoutProperties from \"@babel/runtime/helpers/objectWithoutProperties\";\nimport _defineProperty from \"@babel/runtime/helpers/defineProperty\";\nconst _excluded = [\"initialData\", \"UIOptions\"],\n      _excluded2 = [\"initialData\", \"UIOptions\"];\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nimport React, { useEffect, forwardRef } from \"react\";\nimport \"./publicPath\";\nimport { InitializeApp } from \"../../components/InitializeApp\";\nimport App from \"../../components/App\";\nimport \"../../css/app.scss\";\nimport \"../../css/styles.scss\";\nimport { defaultLang } from \"../../i18n\";\nimport { DEFAULT_UI_OPTIONS } from \"../../constants\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\n\nconst Excalidraw = function (props) {\n  const {\n    onChange,\n    initialData,\n    excalidrawRef,\n    onCollabButtonClick,\n    isCollaborating,\n    onPointerUpdate,\n    renderTopRightUI,\n    renderFooter,\n    langCode = defaultLang.code,\n    viewModeEnabled,\n    zenModeEnabled,\n    gridModeEnabled,\n    libraryReturnUrl,\n    theme,\n    name,\n    renderCustomStats,\n    onPaste,\n    onDrop,\n    detectScroll = true,\n    handleKeyboardGlobally = false,\n    onLibraryChange,\n    autoFocus = false,\n    onBeforeTextEdit,\n    onBeforeTextSubmit,\n    generateIdForFile,\n    onThemeChange\n  } = props;\n  const canvasActions = props.UIOptions?.canvasActions;\n  const UIOptions = {\n    canvasActions: _objectSpread(_objectSpread({}, DEFAULT_UI_OPTIONS.canvasActions), canvasActions)\n  };\n\n  if (canvasActions?.export) {\n    UIOptions.canvasActions.export.saveFileToDisk = canvasActions.export?.saveFileToDisk ?? DEFAULT_UI_OPTIONS.canvasActions.export.saveFileToDisk;\n  }\n\n  useEffect(function () {\n    // Block pinch-zooming on iOS outside of the content area\n    const handleTouchMove = function (event) {\n      // @ts-ignore\n      if (typeof event.scale === \"number\" && event.scale !== 1) {\n        event.preventDefault();\n      }\n    };\n\n    document.addEventListener(\"touchmove\", handleTouchMove, {\n      passive: false\n    });\n    return function () {\n      document.removeEventListener(\"touchmove\", handleTouchMove);\n    };\n  }, []);\n  return /*#__PURE__*/_jsx(InitializeApp, {\n    langCode: langCode,\n    children: /*#__PURE__*/_jsx(App, {\n      onChange: onChange,\n      initialData: initialData,\n      excalidrawRef: excalidrawRef,\n      onCollabButtonClick: onCollabButtonClick,\n      isCollaborating: isCollaborating,\n      onPointerUpdate: onPointerUpdate,\n      renderTopRightUI: renderTopRightUI,\n      renderFooter: renderFooter,\n      langCode: langCode,\n      viewModeEnabled: viewModeEnabled,\n      zenModeEnabled: zenModeEnabled,\n      gridModeEnabled: gridModeEnabled,\n      libraryReturnUrl: libraryReturnUrl,\n      theme: theme,\n      name: name,\n      renderCustomStats: renderCustomStats,\n      UIOptions: UIOptions,\n      onPaste: onPaste,\n      onDrop: onDrop,\n      detectScroll: detectScroll,\n      handleKeyboardGlobally: handleKeyboardGlobally,\n      onLibraryChange: onLibraryChange,\n      autoFocus: autoFocus,\n      onBeforeTextEdit: onBeforeTextEdit,\n      onBeforeTextSubmit: onBeforeTextSubmit,\n      generateIdForFile: generateIdForFile,\n      onThemeChange: onThemeChange\n    })\n  });\n};\n\nconst areEqual = function (prevProps, nextProps) {\n  const {\n    initialData: prevInitialData,\n    UIOptions: prevUIOptions = {}\n  } = prevProps,\n        prev = _objectWithoutProperties(prevProps, _excluded);\n\n  const {\n    initialData: nextInitialData,\n    UIOptions: nextUIOptions = {}\n  } = nextProps,\n        next = _objectWithoutProperties(nextProps, _excluded2); // comparing UIOptions\n\n\n  const prevUIOptionsKeys = Object.keys(prevUIOptions);\n  const nextUIOptionsKeys = Object.keys(nextUIOptions);\n\n  if (prevUIOptionsKeys.length !== nextUIOptionsKeys.length) {\n    return false;\n  }\n\n  const isUIOptionsSame = prevUIOptionsKeys.every(function (key) {\n    if (key === \"canvasActions\") {\n      const canvasOptionKeys = Object.keys(prevUIOptions.canvasActions);\n      canvasOptionKeys.every(function (key) {\n        if (key === \"export\" && prevUIOptions?.canvasActions?.export && nextUIOptions?.canvasActions?.export) {\n          return prevUIOptions.canvasActions.export.saveFileToDisk === nextUIOptions.canvasActions.export.saveFileToDisk;\n        }\n\n        return prevUIOptions?.canvasActions?.[key] === nextUIOptions?.canvasActions?.[key];\n      });\n    }\n\n    return true;\n  });\n  const prevKeys = Object.keys(prevProps);\n  const nextKeys = Object.keys(nextProps);\n  return isUIOptionsSame && prevKeys.length === nextKeys.length && prevKeys.every(function (key) {\n    return prev[key] === next[key];\n  });\n};\n\nconst forwardedRefComp = /*#__PURE__*/forwardRef(function (props, ref) {\n  return /*#__PURE__*/_jsx(Excalidraw, _objectSpread(_objectSpread({}, props), {}, {\n    excalidrawRef: ref\n  }));\n});\nexport default /*#__PURE__*/React.memo(forwardedRefComp, areEqual);\nexport { getSceneVersion, isInvisiblySmallElement, getNonDeletedElements } from \"../../element\";\nexport { defaultLang, languages } from \"../../i18n\";\nexport { restore, restoreAppState, restoreElements } from \"../../data/restore\";\nexport { exportToCanvas, exportToBlob, exportToSvg, serializeAsJSON, loadLibraryFromBlob, loadFromBlob, getFreeDrawSvgPath, getCommonBoundingBox, getMaximumGroups } from \"../../packages/utils\";\nexport { isLinearElement } from \"../../element/typeChecks\";\nexport { FONT_FAMILY, THEME } from \"../../constants\";\nexport { mutateElement, newElementWith, bumpVersion } from \"../../element/mutateElement\";"],"names":[],"sourceRoot":""}\\n//# sourceURL=webpack-internal:///./index.tsx\\n\");\n\n//# sourceURL=webpack://Excalidraw/./index.tsx?");
|
|
2846
|
+
eval("eval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */ \\\"default\\\": () => (__WEBPACK_DEFAULT_EXPORT__),\\n/* harmony export */ \\\"getSceneVersion\\\": () => (/* reexport safe */ _element__WEBPACK_IMPORTED_MODULE_11__.getSceneVersion),\\n/* harmony export */ \\\"isInvisiblySmallElement\\\": () => (/* reexport safe */ _element__WEBPACK_IMPORTED_MODULE_11__.isInvisiblySmallElement),\\n/* harmony export */ \\\"getNonDeletedElements\\\": () => (/* reexport safe */ _element__WEBPACK_IMPORTED_MODULE_11__.getNonDeletedElements),\\n/* harmony export */ \\\"defaultLang\\\": () => (/* reexport safe */ _i18n__WEBPACK_IMPORTED_MODULE_8__.defaultLang),\\n/* harmony export */ \\\"languages\\\": () => (/* reexport safe */ _i18n__WEBPACK_IMPORTED_MODULE_8__.languages),\\n/* harmony export */ \\\"restore\\\": () => (/* reexport safe */ _data_restore__WEBPACK_IMPORTED_MODULE_12__.restore),\\n/* harmony export */ \\\"restoreAppState\\\": () => (/* reexport safe */ _data_restore__WEBPACK_IMPORTED_MODULE_12__.restoreAppState),\\n/* harmony export */ \\\"restoreElements\\\": () => (/* reexport safe */ _data_restore__WEBPACK_IMPORTED_MODULE_12__.restoreElements),\\n/* harmony export */ \\\"exportToCanvas\\\": () => (/* reexport safe */ _packages_utils__WEBPACK_IMPORTED_MODULE_13__.exportToCanvas),\\n/* harmony export */ \\\"exportToBlob\\\": () => (/* reexport safe */ _packages_utils__WEBPACK_IMPORTED_MODULE_13__.exportToBlob),\\n/* harmony export */ \\\"exportToSvg\\\": () => (/* reexport safe */ _packages_utils__WEBPACK_IMPORTED_MODULE_13__.exportToSvg),\\n/* harmony export */ \\\"serializeAsJSON\\\": () => (/* reexport safe */ _packages_utils__WEBPACK_IMPORTED_MODULE_13__.serializeAsJSON),\\n/* harmony export */ \\\"loadLibraryFromBlob\\\": () => (/* reexport safe */ _packages_utils__WEBPACK_IMPORTED_MODULE_13__.loadLibraryFromBlob),\\n/* harmony export */ \\\"loadFromBlob\\\": () => (/* reexport safe */ _packages_utils__WEBPACK_IMPORTED_MODULE_13__.loadFromBlob),\\n/* harmony export */ \\\"getFreeDrawSvgPath\\\": () => (/* reexport safe */ _packages_utils__WEBPACK_IMPORTED_MODULE_13__.getFreeDrawSvgPath),\\n/* harmony export */ \\\"getCommonBoundingBox\\\": () => (/* reexport safe */ _packages_utils__WEBPACK_IMPORTED_MODULE_13__.getCommonBoundingBox),\\n/* harmony export */ \\\"getMaximumGroups\\\": () => (/* reexport safe */ _packages_utils__WEBPACK_IMPORTED_MODULE_13__.getMaximumGroups),\\n/* harmony export */ \\\"intersectElementWithLine\\\": () => (/* reexport safe */ _packages_utils__WEBPACK_IMPORTED_MODULE_13__.intersectElementWithLine),\\n/* harmony export */ \\\"determineFocusDistance\\\": () => (/* reexport safe */ _packages_utils__WEBPACK_IMPORTED_MODULE_13__.determineFocusDistance),\\n/* harmony export */ \\\"isLinearElement\\\": () => (/* reexport safe */ _element_typeChecks__WEBPACK_IMPORTED_MODULE_14__.isLinearElement),\\n/* harmony export */ \\\"FONT_FAMILY\\\": () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_9__.FONT_FAMILY),\\n/* harmony export */ \\\"THEME\\\": () => (/* reexport safe */ _constants__WEBPACK_IMPORTED_MODULE_9__.THEME),\\n/* harmony export */ \\\"mutateElement\\\": () => (/* reexport safe */ _element_mutateElement__WEBPACK_IMPORTED_MODULE_15__.mutateElement),\\n/* harmony export */ \\\"newElementWith\\\": () => (/* reexport safe */ _element_mutateElement__WEBPACK_IMPORTED_MODULE_15__.newElementWith),\\n/* harmony export */ \\\"bumpVersion\\\": () => (/* reexport safe */ _element_mutateElement__WEBPACK_IMPORTED_MODULE_15__.bumpVersion)\\n/* harmony export */ });\\n/* harmony import */ var _babel_runtime_helpers_objectWithoutProperties__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/objectWithoutProperties */ \\\"./node_modules/@babel/runtime/helpers/objectWithoutProperties.js\\\");\\n/* harmony import */ var _babel_runtime_helpers_objectWithoutProperties__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_objectWithoutProperties__WEBPACK_IMPORTED_MODULE_0__);\\n/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ \\\"./node_modules/@babel/runtime/helpers/defineProperty.js\\\");\\n/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1__);\\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! react */ \\\"react\\\");\\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_2__);\\n/* harmony import */ var _publicPath__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./publicPath */ \\\"./publicPath.js\\\");\\n/* harmony import */ var _components_InitializeApp__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../../components/InitializeApp */ \\\"../../components/InitializeApp.tsx\\\");\\n/* harmony import */ var _components_App__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../../components/App */ \\\"../../components/App.tsx\\\");\\n/* harmony import */ var _css_app_scss__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../../css/app.scss */ \\\"../../css/app.scss\\\");\\n/* harmony import */ var _css_app_scss__WEBPACK_IMPORTED_MODULE_6___default = /*#__PURE__*/__webpack_require__.n(_css_app_scss__WEBPACK_IMPORTED_MODULE_6__);\\n/* harmony import */ var _css_styles_scss__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../../css/styles.scss */ \\\"../../css/styles.scss\\\");\\n/* harmony import */ var _css_styles_scss__WEBPACK_IMPORTED_MODULE_7___default = /*#__PURE__*/__webpack_require__.n(_css_styles_scss__WEBPACK_IMPORTED_MODULE_7__);\\n/* harmony import */ var _i18n__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../../i18n */ \\\"../../i18n.ts\\\");\\n/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ../../constants */ \\\"../../constants.ts\\\");\\n/* harmony import */ var react_jsx_runtime__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! react/jsx-runtime */ \\\"../../../node_modules/react/jsx-runtime.js\\\");\\n/* harmony import */ var _element__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ../../element */ \\\"../../element/index.ts\\\");\\n/* harmony import */ var _data_restore__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ../../data/restore */ \\\"../../data/restore.ts\\\");\\n/* harmony import */ var _packages_utils__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ../../packages/utils */ \\\"../utils.ts\\\");\\n/* harmony import */ var _element_typeChecks__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(/*! ../../element/typeChecks */ \\\"../../element/typeChecks.ts\\\");\\n/* harmony import */ var _element_mutateElement__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(/*! ../../element/mutateElement */ \\\"../../element/mutateElement.ts\\\");\\n\\r\\n\\r\\nconst _excluded = [\\\"initialData\\\", \\\"UIOptions\\\"], _excluded2 = [\\\"initialData\\\", \\\"UIOptions\\\"];\\r\\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) {\\r\\n var symbols = Object.getOwnPropertySymbols(object);\\r\\n if (enumerableOnly) {\\r\\n symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; });\\r\\n }\\r\\n keys.push.apply(keys, symbols);\\r\\n} return keys; }\\r\\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) {\\r\\n var source = arguments[i] != null ? arguments[i] : {};\\r\\n if (i % 2) {\\r\\n ownKeys(Object(source), true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1___default()(target, key, source[key]); });\\r\\n }\\r\\n else if (Object.getOwnPropertyDescriptors) {\\r\\n Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));\\r\\n }\\r\\n else {\\r\\n ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); });\\r\\n }\\r\\n} return target; }\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\nconst Excalidraw = function (props) {\\r\\n var _a, _b, _c;\\r\\n const { onChange, initialData, excalidrawRef, onCollabButtonClick, isCollaborating, onPointerUpdate, renderTopRightUI, renderFooter, langCode = _i18n__WEBPACK_IMPORTED_MODULE_8__.defaultLang.code, viewModeEnabled, zenModeEnabled, gridModeEnabled, libraryReturnUrl, theme, name, renderCustomStats, onPaste, onDrop, detectScroll = true, handleKeyboardGlobally = false, onLibraryChange, autoFocus = false, onBeforeTextEdit, onBeforeTextSubmit, generateIdForFile, onThemeChange } = props;\\r\\n const canvasActions = (_a = props.UIOptions) === null || _a === void 0 ? void 0 : _a.canvasActions;\\r\\n const UIOptions = {\\r\\n canvasActions: _objectSpread(_objectSpread({}, _constants__WEBPACK_IMPORTED_MODULE_9__.DEFAULT_UI_OPTIONS.canvasActions), canvasActions)\\r\\n };\\r\\n if (canvasActions === null || canvasActions === void 0 ? void 0 : canvasActions.export) {\\r\\n UIOptions.canvasActions.export.saveFileToDisk = (_c = (_b = canvasActions.export) === null || _b === void 0 ? void 0 : _b.saveFileToDisk) !== null && _c !== void 0 ? _c : _constants__WEBPACK_IMPORTED_MODULE_9__.DEFAULT_UI_OPTIONS.canvasActions[\\\"export\\\"].saveFileToDisk;\\r\\n }\\r\\n (0,react__WEBPACK_IMPORTED_MODULE_2__.useEffect)(function () {\\r\\n // Block pinch-zooming on iOS outside of the content area\\r\\n const handleTouchMove = function (event) {\\r\\n // @ts-ignore\\r\\n if (typeof event.scale === \\\"number\\\" && event.scale !== 1) {\\r\\n event.preventDefault();\\r\\n }\\r\\n };\\r\\n document.addEventListener(\\\"touchmove\\\", handleTouchMove, {\\r\\n passive: false\\r\\n });\\r\\n return function () {\\r\\n document.removeEventListener(\\\"touchmove\\\", handleTouchMove);\\r\\n };\\r\\n }, []);\\r\\n return /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_10__.jsx)(_components_InitializeApp__WEBPACK_IMPORTED_MODULE_4__.InitializeApp, {\\r\\n langCode: langCode,\\r\\n children: /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_10__.jsx)(_components_App__WEBPACK_IMPORTED_MODULE_5__[\\\"default\\\"], {\\r\\n onChange: onChange,\\r\\n initialData: initialData,\\r\\n excalidrawRef: excalidrawRef,\\r\\n onCollabButtonClick: onCollabButtonClick,\\r\\n isCollaborating: isCollaborating,\\r\\n onPointerUpdate: onPointerUpdate,\\r\\n renderTopRightUI: renderTopRightUI,\\r\\n renderFooter: renderFooter,\\r\\n langCode: langCode,\\r\\n viewModeEnabled: viewModeEnabled,\\r\\n zenModeEnabled: zenModeEnabled,\\r\\n gridModeEnabled: gridModeEnabled,\\r\\n libraryReturnUrl: libraryReturnUrl,\\r\\n theme: theme,\\r\\n name: name,\\r\\n renderCustomStats: renderCustomStats,\\r\\n UIOptions: UIOptions,\\r\\n onPaste: onPaste,\\r\\n onDrop: onDrop,\\r\\n detectScroll: detectScroll,\\r\\n handleKeyboardGlobally: handleKeyboardGlobally,\\r\\n onLibraryChange: onLibraryChange,\\r\\n autoFocus: autoFocus,\\r\\n onBeforeTextEdit: onBeforeTextEdit,\\r\\n onBeforeTextSubmit: onBeforeTextSubmit,\\r\\n generateIdForFile: generateIdForFile,\\r\\n onThemeChange: onThemeChange\\r\\n })\\r\\n });\\r\\n};\\r\\nconst areEqual = function (prevProps, nextProps) {\\r\\n const { initialData: prevInitialData, UIOptions: prevUIOptions = {} } = prevProps, prev = _babel_runtime_helpers_objectWithoutProperties__WEBPACK_IMPORTED_MODULE_0___default()(prevProps, _excluded);\\r\\n const { initialData: nextInitialData, UIOptions: nextUIOptions = {} } = nextProps, next = _babel_runtime_helpers_objectWithoutProperties__WEBPACK_IMPORTED_MODULE_0___default()(nextProps, _excluded2); // comparing UIOptions\\r\\n const prevUIOptionsKeys = Object.keys(prevUIOptions);\\r\\n const nextUIOptionsKeys = Object.keys(nextUIOptions);\\r\\n if (prevUIOptionsKeys.length !== nextUIOptionsKeys.length) {\\r\\n return false;\\r\\n }\\r\\n const isUIOptionsSame = prevUIOptionsKeys.every(function (key) {\\r\\n if (key === \\\"canvasActions\\\") {\\r\\n const canvasOptionKeys = Object.keys(prevUIOptions.canvasActions);\\r\\n canvasOptionKeys.every(function (key) {\\r\\n var _a, _b, _c, _d;\\r\\n if (key === \\\"export\\\" && ((_a = prevUIOptions === null || prevUIOptions === void 0 ? void 0 : prevUIOptions.canvasActions) === null || _a === void 0 ? void 0 : _a.export) && ((_b = nextUIOptions === null || nextUIOptions === void 0 ? void 0 : nextUIOptions.canvasActions) === null || _b === void 0 ? void 0 : _b.export)) {\\r\\n return prevUIOptions.canvasActions.export.saveFileToDisk === nextUIOptions.canvasActions.export.saveFileToDisk;\\r\\n }\\r\\n return ((_c = prevUIOptions === null || prevUIOptions === void 0 ? void 0 : prevUIOptions.canvasActions) === null || _c === void 0 ? void 0 : _c[key]) === ((_d = nextUIOptions === null || nextUIOptions === void 0 ? void 0 : nextUIOptions.canvasActions) === null || _d === void 0 ? void 0 : _d[key]);\\r\\n });\\r\\n }\\r\\n return true;\\r\\n });\\r\\n const prevKeys = Object.keys(prevProps);\\r\\n const nextKeys = Object.keys(nextProps);\\r\\n return isUIOptionsSame && prevKeys.length === nextKeys.length && prevKeys.every(function (key) {\\r\\n return prev[key] === next[key];\\r\\n });\\r\\n};\\r\\nconst forwardedRefComp = /*#__PURE__*/ (0,react__WEBPACK_IMPORTED_MODULE_2__.forwardRef)(function (props, ref) {\\r\\n return /*#__PURE__*/ (0,react_jsx_runtime__WEBPACK_IMPORTED_MODULE_10__.jsx)(Excalidraw, _objectSpread(_objectSpread({}, props), {}, {\\r\\n excalidrawRef: ref\\r\\n }));\\r\\n});\\r\\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (/*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_2___default().memo(forwardedRefComp, areEqual));\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n//# sourceURL=[module]\\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./index.tsx.js","mappings":"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","sources":["webpack:///./index.tsx?ce74"],"sourcesContent":["import _objectWithoutProperties from \"@babel/runtime/helpers/objectWithoutProperties\";\nimport _defineProperty from \"@babel/runtime/helpers/defineProperty\";\nconst _excluded = [\"initialData\", \"UIOptions\"],\n      _excluded2 = [\"initialData\", \"UIOptions\"];\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nimport React, { useEffect, forwardRef } from \"react\";\nimport \"./publicPath\";\nimport { InitializeApp } from \"../../components/InitializeApp\";\nimport App from \"../../components/App\";\nimport \"../../css/app.scss\";\nimport \"../../css/styles.scss\";\nimport { defaultLang } from \"../../i18n\";\nimport { DEFAULT_UI_OPTIONS } from \"../../constants\";\nimport { jsx as _jsx } from \"react/jsx-runtime\";\n\nconst Excalidraw = function (props) {\n  const {\n    onChange,\n    initialData,\n    excalidrawRef,\n    onCollabButtonClick,\n    isCollaborating,\n    onPointerUpdate,\n    renderTopRightUI,\n    renderFooter,\n    langCode = defaultLang.code,\n    viewModeEnabled,\n    zenModeEnabled,\n    gridModeEnabled,\n    libraryReturnUrl,\n    theme,\n    name,\n    renderCustomStats,\n    onPaste,\n    onDrop,\n    detectScroll = true,\n    handleKeyboardGlobally = false,\n    onLibraryChange,\n    autoFocus = false,\n    onBeforeTextEdit,\n    onBeforeTextSubmit,\n    generateIdForFile,\n    onThemeChange\n  } = props;\n  const canvasActions = props.UIOptions?.canvasActions;\n  const UIOptions = {\n    canvasActions: _objectSpread(_objectSpread({}, DEFAULT_UI_OPTIONS.canvasActions), canvasActions)\n  };\n\n  if (canvasActions?.export) {\n    UIOptions.canvasActions.export.saveFileToDisk = canvasActions.export?.saveFileToDisk ?? DEFAULT_UI_OPTIONS.canvasActions.export.saveFileToDisk;\n  }\n\n  useEffect(function () {\n    // Block pinch-zooming on iOS outside of the content area\n    const handleTouchMove = function (event) {\n      // @ts-ignore\n      if (typeof event.scale === \"number\" && event.scale !== 1) {\n        event.preventDefault();\n      }\n    };\n\n    document.addEventListener(\"touchmove\", handleTouchMove, {\n      passive: false\n    });\n    return function () {\n      document.removeEventListener(\"touchmove\", handleTouchMove);\n    };\n  }, []);\n  return /*#__PURE__*/_jsx(InitializeApp, {\n    langCode: langCode,\n    children: /*#__PURE__*/_jsx(App, {\n      onChange: onChange,\n      initialData: initialData,\n      excalidrawRef: excalidrawRef,\n      onCollabButtonClick: onCollabButtonClick,\n      isCollaborating: isCollaborating,\n      onPointerUpdate: onPointerUpdate,\n      renderTopRightUI: renderTopRightUI,\n      renderFooter: renderFooter,\n      langCode: langCode,\n      viewModeEnabled: viewModeEnabled,\n      zenModeEnabled: zenModeEnabled,\n      gridModeEnabled: gridModeEnabled,\n      libraryReturnUrl: libraryReturnUrl,\n      theme: theme,\n      name: name,\n      renderCustomStats: renderCustomStats,\n      UIOptions: UIOptions,\n      onPaste: onPaste,\n      onDrop: onDrop,\n      detectScroll: detectScroll,\n      handleKeyboardGlobally: handleKeyboardGlobally,\n      onLibraryChange: onLibraryChange,\n      autoFocus: autoFocus,\n      onBeforeTextEdit: onBeforeTextEdit,\n      onBeforeTextSubmit: onBeforeTextSubmit,\n      generateIdForFile: generateIdForFile,\n      onThemeChange: onThemeChange\n    })\n  });\n};\n\nconst areEqual = function (prevProps, nextProps) {\n  const {\n    initialData: prevInitialData,\n    UIOptions: prevUIOptions = {}\n  } = prevProps,\n        prev = _objectWithoutProperties(prevProps, _excluded);\n\n  const {\n    initialData: nextInitialData,\n    UIOptions: nextUIOptions = {}\n  } = nextProps,\n        next = _objectWithoutProperties(nextProps, _excluded2); // comparing UIOptions\n\n\n  const prevUIOptionsKeys = Object.keys(prevUIOptions);\n  const nextUIOptionsKeys = Object.keys(nextUIOptions);\n\n  if (prevUIOptionsKeys.length !== nextUIOptionsKeys.length) {\n    return false;\n  }\n\n  const isUIOptionsSame = prevUIOptionsKeys.every(function (key) {\n    if (key === \"canvasActions\") {\n      const canvasOptionKeys = Object.keys(prevUIOptions.canvasActions);\n      canvasOptionKeys.every(function (key) {\n        if (key === \"export\" && prevUIOptions?.canvasActions?.export && nextUIOptions?.canvasActions?.export) {\n          return prevUIOptions.canvasActions.export.saveFileToDisk === nextUIOptions.canvasActions.export.saveFileToDisk;\n        }\n\n        return prevUIOptions?.canvasActions?.[key] === nextUIOptions?.canvasActions?.[key];\n      });\n    }\n\n    return true;\n  });\n  const prevKeys = Object.keys(prevProps);\n  const nextKeys = Object.keys(nextProps);\n  return isUIOptionsSame && prevKeys.length === nextKeys.length && prevKeys.every(function (key) {\n    return prev[key] === next[key];\n  });\n};\n\nconst forwardedRefComp = /*#__PURE__*/forwardRef(function (props, ref) {\n  return /*#__PURE__*/_jsx(Excalidraw, _objectSpread(_objectSpread({}, props), {}, {\n    excalidrawRef: ref\n  }));\n});\nexport default /*#__PURE__*/React.memo(forwardedRefComp, areEqual);\nexport { getSceneVersion, isInvisiblySmallElement, getNonDeletedElements } from \"../../element\";\nexport { defaultLang, languages } from \"../../i18n\";\nexport { restore, restoreAppState, restoreElements } from \"../../data/restore\";\nexport { exportToCanvas, exportToBlob, exportToSvg, serializeAsJSON, loadLibraryFromBlob, loadFromBlob, getFreeDrawSvgPath, getCommonBoundingBox, getMaximumGroups, intersectElementWithLine, determineFocusDistance } from \"../../packages/utils\";\nexport { isLinearElement } from \"../../element/typeChecks\";\nexport { FONT_FAMILY, THEME } from \"../../constants\";\nexport { mutateElement, newElementWith, bumpVersion } from \"../../element/mutateElement\";"],"names":[],"sourceRoot":""}\\n//# sourceURL=webpack-internal:///./index.tsx\\n\");\n\n//# sourceURL=webpack://Excalidraw/./index.tsx?");
|
|
2847
2847
|
|
|
2848
2848
|
/***/ }),
|
|
2849
2849
|
|
|
@@ -2865,7 +2865,7 @@ eval("eval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony import */
|
|
|
2865
2865
|
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
|
|
2866
2866
|
|
|
2867
2867
|
"use strict";
|
|
2868
|
-
eval("eval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */ \\\"exportToCanvas\\\": () => (/* binding */ exportToCanvas),\\n/* harmony export */ \\\"exportToBlob\\\": () => (/* binding */ exportToBlob),\\n/* harmony export */ \\\"exportToSvg\\\": () => (/* binding */ exportToSvg),\\n/* harmony export */ \\\"serializeAsJSON\\\": () => (/* reexport safe */ _data_json__WEBPACK_IMPORTED_MODULE_7__.serializeAsJSON),\\n/* harmony export */ \\\"loadFromBlob\\\": () => (/* reexport safe */ _data_blob__WEBPACK_IMPORTED_MODULE_8__.loadFromBlob),\\n/* harmony export */ \\\"loadLibraryFromBlob\\\": () => (/* reexport safe */ _data_blob__WEBPACK_IMPORTED_MODULE_8__.loadLibraryFromBlob),\\n/* harmony export */ \\\"getFreeDrawSvgPath\\\": () => (/* reexport safe */ _renderer_renderElement__WEBPACK_IMPORTED_MODULE_9__.getFreeDrawSvgPath),\\n/* harmony export */ \\\"getCommonBoundingBox\\\": () => (/* reexport safe */ _element_bounds__WEBPACK_IMPORTED_MODULE_10__.getCommonBoundingBox),\\n/* harmony export */ \\\"getMaximumGroups\\\": () => (/* reexport safe */ _align__WEBPACK_IMPORTED_MODULE_11__.getMaximumGroups)\\n/* harmony export */ });\\n/* harmony import */ var _babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/asyncToGenerator */ \\\"../../../node_modules/@babel/runtime/helpers/esm/asyncToGenerator.js\\\");\\n/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ \\\"../../../node_modules/@babel/runtime/helpers/esm/defineProperty.js\\\");\\n/* harmony import */ var _scene_export__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../scene/export */ \\\"../../scene/export.ts\\\");\\n/* harmony import */ var _appState__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../appState */ \\\"../../appState.ts\\\");\\n/* harmony import */ var _element__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../element */ \\\"../../element/index.ts\\\");\\n/* harmony import */ var _data_restore__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../data/restore */ \\\"../../data/restore.ts\\\");\\n/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../constants */ \\\"../../constants.ts\\\");\\n/* harmony import */ var _data_json__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../data/json */ \\\"../../data/json.ts\\\");\\n/* harmony import */ var _data_blob__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../data/blob */ \\\"../../data/blob.ts\\\");\\n/* harmony import */ var _renderer_renderElement__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ../renderer/renderElement */ \\\"../../renderer/renderElement.ts\\\");\\n/* harmony import */ var _element_bounds__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ../element/bounds */ \\\"../../element/bounds.ts\\\");\\n/* harmony import */ var _align__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ../align */ \\\"../../align.ts\\\");\\n\\r\\n\\r\\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) {\\r\\n var symbols = Object.getOwnPropertySymbols(object);\\r\\n if (enumerableOnly) {\\r\\n symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; });\\r\\n }\\r\\n keys.push.apply(keys, symbols);\\r\\n} return keys; }\\r\\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) {\\r\\n var source = arguments[i] != null ? arguments[i] : {};\\r\\n if (i % 2) {\\r\\n ownKeys(Object(source), true).forEach(function (key) { (0,_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1__[\\\"default\\\"])(target, key, source[key]); });\\r\\n }\\r\\n else if (Object.getOwnPropertyDescriptors) {\\r\\n Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));\\r\\n }\\r\\n else {\\r\\n ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); });\\r\\n }\\r\\n} return target; }\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\nconst exportToCanvas = function (_ref) {\\r\\n let { elements, appState, files, maxWidthOrHeight, getDimensions } = _ref;\\r\\n const { elements: restoredElements, appState: restoredAppState } = (0,_data_restore__WEBPACK_IMPORTED_MODULE_5__.restore)({\\r\\n elements,\\r\\n appState\\r\\n }, null, null);\\r\\n const { exportBackground, viewBackgroundColor } = restoredAppState;\\r\\n return (0,_scene_export__WEBPACK_IMPORTED_MODULE_2__.exportToCanvas)((0,_element__WEBPACK_IMPORTED_MODULE_4__.getNonDeletedElements)(restoredElements), _objectSpread(_objectSpread({}, restoredAppState), {}, {\\r\\n offsetTop: 0,\\r\\n offsetLeft: 0,\\r\\n width: 0,\\r\\n height: 0\\r\\n }), files || {}, {\\r\\n exportBackground,\\r\\n viewBackgroundColor\\r\\n }, function (width, height) {\\r\\n var _a;\\r\\n const canvas = document.createElement(\\\"canvas\\\");\\r\\n if (maxWidthOrHeight) {\\r\\n if (typeof getDimensions === \\\"function\\\") {\\r\\n console.warn(\\\"`getDimensions()` is ignored when `maxWidthOrHeight` is supplied.\\\");\\r\\n }\\r\\n const max = Math.max(width, height);\\r\\n const scale = maxWidthOrHeight / max;\\r\\n canvas.width = width * scale;\\r\\n canvas.height = height * scale;\\r\\n return {\\r\\n canvas,\\r\\n scale\\r\\n };\\r\\n }\\r\\n const ret = (getDimensions === null || getDimensions === void 0 ? void 0 : getDimensions(width, height)) || {\\r\\n width,\\r\\n height\\r\\n };\\r\\n canvas.width = ret.width;\\r\\n canvas.height = ret.height;\\r\\n return {\\r\\n canvas,\\r\\n scale: (_a = ret.scale) !== null && _a !== void 0 ? _a : 1\\r\\n };\\r\\n });\\r\\n};\\r\\nconst exportToBlob = /*#__PURE__*/ function () {\\r\\n var _ref2 = (0,_babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_0__[\\\"default\\\"])(function* (opts) {\\r\\n var _a;\\r\\n let { mimeType = _constants__WEBPACK_IMPORTED_MODULE_6__.MIME_TYPES.png, quality } = opts;\\r\\n if (mimeType === _constants__WEBPACK_IMPORTED_MODULE_6__.MIME_TYPES.png && typeof quality === \\\"number\\\") {\\r\\n console.warn(`\\\"quality\\\" will be ignored for \\\"${_constants__WEBPACK_IMPORTED_MODULE_6__.MIME_TYPES.png}\\\" mimeType`);\\r\\n } // typo in MIME type (should be \\\"jpeg\\\")\\r\\n if (mimeType === \\\"image/jpg\\\") {\\r\\n mimeType = _constants__WEBPACK_IMPORTED_MODULE_6__.MIME_TYPES.jpg;\\r\\n }\\r\\n if (mimeType === _constants__WEBPACK_IMPORTED_MODULE_6__.MIME_TYPES.jpg && !((_a = opts.appState) === null || _a === void 0 ? void 0 : _a.exportBackground)) {\\r\\n console.warn(`Defaulting \\\"exportBackground\\\" to \\\"true\\\" for \\\"${_constants__WEBPACK_IMPORTED_MODULE_6__.MIME_TYPES.jpg}\\\" mimeType`);\\r\\n opts = _objectSpread(_objectSpread({}, opts), {}, {\\r\\n appState: _objectSpread(_objectSpread({}, opts.appState), {}, {\\r\\n exportBackground: true\\r\\n })\\r\\n });\\r\\n }\\r\\n const canvas = yield exportToCanvas(opts);\\r\\n quality = quality ? quality : /image\\\\/jpe?g/.test(mimeType) ? 0.92 : 0.8;\\r\\n return new Promise(function (resolve) {\\r\\n canvas.toBlob(function (blob) {\\r\\n resolve(blob);\\r\\n }, mimeType, quality);\\r\\n });\\r\\n });\\r\\n return function exportToBlob(_x) {\\r\\n return _ref2.apply(this, arguments);\\r\\n };\\r\\n}();\\r\\nconst exportToSvg = /*#__PURE__*/ function () {\\r\\n var _ref3 = (0,_babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_0__[\\\"default\\\"])(function* (_ref4) {\\r\\n let { elements, appState = (0,_appState__WEBPACK_IMPORTED_MODULE_3__.getDefaultAppState)(), files = {}, exportPadding } = _ref4;\\r\\n const { elements: restoredElements, appState: restoredAppState } = (0,_data_restore__WEBPACK_IMPORTED_MODULE_5__.restore)({\\r\\n elements,\\r\\n appState\\r\\n }, null, null);\\r\\n return (0,_scene_export__WEBPACK_IMPORTED_MODULE_2__.exportToSvg)((0,_element__WEBPACK_IMPORTED_MODULE_4__.getNonDeletedElements)(restoredElements), _objectSpread(_objectSpread({}, restoredAppState), {}, {\\r\\n exportPadding\\r\\n }), files);\\r\\n });\\r\\n return function exportToSvg(_x2) {\\r\\n return _ref3.apply(this, arguments);\\r\\n };\\r\\n}();\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n//# sourceURL=[module]\\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../utils.ts.js","mappings":";;;;;;;;;;;;;;;;;;;;;;;;AAAwE;AACJ;AAEpE,SAAS,OAAO,CAAC,MAAM,EAAE,cAAc,IAAI,IAAI,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,qBAAqB,EAAE;IAAE,IAAI,OAAO,GAAG,MAAM,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;IAAC,IAAI,cAAc,EAAE;QAAE,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC,UAAU,GAAG,IAAI,OAAO,MAAM,CAAC,wBAAwB,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;KAAE;IAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;CAAE,CAAC,OAAO,IAAI,CAAC,CAAC,CAAC;AAEzV,SAAS,aAAa,CAAC,MAAM,IAAI,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;IAAE,IAAI,MAAM,GAAG,SAAS,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IAAC,IAAI,CAAC,GAAG,CAAC,EAAE;QAAE,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,CAAC,OAAO,CAAC,UAAU,GAAG,IAAI,iFAAe,CAAC,MAAM,EAAE,GAAG,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;KAAE;SAAM,IAAI,MAAM,CAAC,yBAAyB,EAAE;QAAE,MAAM,CAAC,gBAAgB,CAAC,MAAM,EAAE,MAAM,CAAC,yBAAyB,CAAC,MAAM,CAAC,CAAC,CAAC;KAAE;SAAM;QAAE,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,GAAG,IAAI,MAAM,CAAC,cAAc,CAAC,MAAM,EAAE,GAAG,EAAE,MAAM,CAAC,wBAAwB,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;KAAE;CAAE,CAAC,OAAO,MAAM,CAAC,CAAC,CAAC;AAErb;AAChD;AACE;AACT;AACA;AACnC,MAAM,cAAc,GAAG,UAAU,IAAI;IAC1C,IAAI,EACF,QAAQ,EACR,QAAQ,EACR,KAAK,EACL,gBAAgB,EAChB,aAAa,EACd,GAAG,IAAI,CAAC;IACT,MAAM,EACJ,QAAQ,EAAE,gBAAgB,EAC1B,QAAQ,EAAE,gBAAgB,EAC3B,GAAG,sDAAO,CAAC;QACV,QAAQ;QACR,QAAQ;KACT,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;IACf,MAAM,EACJ,gBAAgB,EAChB,mBAAmB,EACpB,GAAG,gBAAgB,CAAC;IACrB,OAAO,6DAAe,CAAC,+DAAqB,CAAC,gBAAgB,CAAC,EAAE,aAAa,CAAC,aAAa,CAAC,EAAE,EAAE,gBAAgB,CAAC,EAAE,EAAE,EAAE;QACrH,SAAS,EAAE,CAAC;QACZ,UAAU,EAAE,CAAC;QACb,KAAK,EAAE,CAAC;QACR,MAAM,EAAE,CAAC;KACV,CAAC,EAAE,KAAK,IAAI,EAAE,EAAE;QACf,gBAAgB;QAChB,mBAAmB;KACpB,EAAE,UAAU,KAAK,EAAE,MAAM;;QACxB,MAAM,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;QAEhD,IAAI,gBAAgB,EAAE;YACpB,IAAI,OAAO,aAAa,KAAK,UAAU,EAAE;gBACvC,OAAO,CAAC,IAAI,CAAC,mEAAmE,CAAC,CAAC;aACnF;YAED,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;YACpC,MAAM,KAAK,GAAG,gBAAgB,GAAG,GAAG,CAAC;YACrC,MAAM,CAAC,KAAK,GAAG,KAAK,GAAG,KAAK,CAAC;YAC7B,MAAM,CAAC,MAAM,GAAG,MAAM,GAAG,KAAK,CAAC;YAC/B,OAAO;gBACL,MAAM;gBACN,KAAK;aACN,CAAC;SACH;QAED,MAAM,GAAG,GAAG,cAAa,aAAb,aAAa,uBAAb,aAAa,CAAG,KAAK,EAAE,MAAM,CAAC,KAAI;YAC5C,KAAK;YACL,MAAM;SACP,CAAC;QACF,MAAM,CAAC,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC;QACzB,MAAM,CAAC,MAAM,GAAG,GAAG,CAAC,MAAM,CAAC;QAC3B,OAAO;YACL,MAAM;YACN,KAAK,EAAE,SAAG,CAAC,KAAK,mCAAI,CAAC;SACtB,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC,CAAC;AACK,MAAM,YAAY,GAAG,aAAa;IACvC,IAAI,KAAK,GAAG,mFAAiB,CAAC,QAAQ,CAAC,EAAE,IAAI;;QAC3C,IAAI,EACF,QAAQ,GAAG,sDAAc,EACzB,OAAO,EACR,GAAG,IAAI,CAAC;QAET,IAAI,QAAQ,KAAK,sDAAc,IAAI,OAAO,OAAO,KAAK,QAAQ,EAAE;YAC9D,OAAO,CAAC,IAAI,CAAC,kCAAkC,sDAAc,YAAY,CAAC,CAAC;SAC5E,CAAC,uCAAuC;QAGzC,IAAI,QAAQ,KAAK,WAAW,EAAE;YAC5B,QAAQ,GAAG,sDAAc,CAAC;SAC3B;QAED,IAAI,QAAQ,KAAK,sDAAc,IAAI,CAAC,WAAI,CAAC,QAAQ,0CAAE,gBAAgB,GAAE;YACnE,OAAO,CAAC,IAAI,CAAC,gDAAgD,sDAAc,YAAY,CAAC,CAAC;YACzF,IAAI,GAAG,aAAa,CAAC,aAAa,CAAC,EAAE,EAAE,IAAI,CAAC,EAAE,EAAE,EAAE;gBAChD,QAAQ,EAAE,aAAa,CAAC,aAAa,CAAC,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,EAAE,EAAE,EAAE;oBAC5D,gBAAgB,EAAE,IAAI;iBACvB,CAAC;aACH,CAAC,CAAC;SACJ;QAED,MAAM,MAAM,GAAG,MAAM,cAAc,CAAC,IAAI,CAAC,CAAC;QAC1C,OAAO,GAAG,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC;QACzE,OAAO,IAAI,OAAO,CAAC,UAAU,OAAO;YAClC,MAAM,CAAC,MAAM,CAAC,UAAU,IAAI;gBAC1B,OAAO,CAAC,IAAI,CAAC,CAAC;YAChB,CAAC,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;QACxB,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,OAAO,SAAS,YAAY,CAAC,EAAE;QAC7B,OAAO,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;IACtC,CAAC,CAAC;AACJ,CAAC,EAAE,CAAC;AACG,MAAM,WAAW,GAAG,aAAa;IACtC,IAAI,KAAK,GAAG,mFAAiB,CAAC,QAAQ,CAAC,EAAE,KAAK;QAC5C,IAAI,EACF,QAAQ,EACR,QAAQ,GAAG,6DAAkB,EAAE,EAC/B,KAAK,GAAG,EAAE,EACV,aAAa,EACd,GAAG,KAAK,CAAC;QACV,MAAM,EACJ,QAAQ,EAAE,gBAAgB,EAC1B,QAAQ,EAAE,gBAAgB,EAC3B,GAAG,sDAAO,CAAC;YACV,QAAQ;YACR,QAAQ;SACT,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QACf,OAAO,0DAAY,CAAC,+DAAqB,CAAC,gBAAgB,CAAC,EAAE,aAAa,CAAC,aAAa,CAAC,EAAE,EAAE,gBAAgB,CAAC,EAAE,EAAE,EAAE;YAClH,aAAa;SACd,CAAC,EAAE,KAAK,CAAC,CAAC;IACb,CAAC,CAAC,CAAC;IAEH,OAAO,SAAS,WAAW,CAAC,GAAG;QAC7B,OAAO,KAAK,CAAC,KAAK,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;IACtC,CAAC,CAAC;AACJ,CAAC,EAAE,CAAC;AAC2C;AACkB;AACF;AACN;AACb","sources":["webpack:///../utils.ts?b1b8"],"sourcesContent":["import _asyncToGenerator from \"@babel/runtime/helpers/asyncToGenerator\";\nimport _defineProperty from \"@babel/runtime/helpers/defineProperty\";\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nimport { exportToCanvas as _exportToCanvas, exportToSvg as _exportToSvg } from \"../scene/export\";\nimport { getDefaultAppState } from \"../appState\";\nimport { getNonDeletedElements } from \"../element\";\nimport { restore } from \"../data/restore\";\nimport { MIME_TYPES } from \"../constants\";\nexport const exportToCanvas = function (_ref) {\n  let {\n    elements,\n    appState,\n    files,\n    maxWidthOrHeight,\n    getDimensions\n  } = _ref;\n  const {\n    elements: restoredElements,\n    appState: restoredAppState\n  } = restore({\n    elements,\n    appState\n  }, null, null);\n  const {\n    exportBackground,\n    viewBackgroundColor\n  } = restoredAppState;\n  return _exportToCanvas(getNonDeletedElements(restoredElements), _objectSpread(_objectSpread({}, restoredAppState), {}, {\n    offsetTop: 0,\n    offsetLeft: 0,\n    width: 0,\n    height: 0\n  }), files || {}, {\n    exportBackground,\n    viewBackgroundColor\n  }, function (width, height) {\n    const canvas = document.createElement(\"canvas\");\n\n    if (maxWidthOrHeight) {\n      if (typeof getDimensions === \"function\") {\n        console.warn(\"`getDimensions()` is ignored when `maxWidthOrHeight` is supplied.\");\n      }\n\n      const max = Math.max(width, height);\n      const scale = maxWidthOrHeight / max;\n      canvas.width = width * scale;\n      canvas.height = height * scale;\n      return {\n        canvas,\n        scale\n      };\n    }\n\n    const ret = getDimensions?.(width, height) || {\n      width,\n      height\n    };\n    canvas.width = ret.width;\n    canvas.height = ret.height;\n    return {\n      canvas,\n      scale: ret.scale ?? 1\n    };\n  });\n};\nexport const exportToBlob = /*#__PURE__*/function () {\n  var _ref2 = _asyncToGenerator(function* (opts) {\n    let {\n      mimeType = MIME_TYPES.png,\n      quality\n    } = opts;\n\n    if (mimeType === MIME_TYPES.png && typeof quality === \"number\") {\n      console.warn(`\"quality\" will be ignored for \"${MIME_TYPES.png}\" mimeType`);\n    } // typo in MIME type (should be \"jpeg\")\n\n\n    if (mimeType === \"image/jpg\") {\n      mimeType = MIME_TYPES.jpg;\n    }\n\n    if (mimeType === MIME_TYPES.jpg && !opts.appState?.exportBackground) {\n      console.warn(`Defaulting \"exportBackground\" to \"true\" for \"${MIME_TYPES.jpg}\" mimeType`);\n      opts = _objectSpread(_objectSpread({}, opts), {}, {\n        appState: _objectSpread(_objectSpread({}, opts.appState), {}, {\n          exportBackground: true\n        })\n      });\n    }\n\n    const canvas = yield exportToCanvas(opts);\n    quality = quality ? quality : /image\\/jpe?g/.test(mimeType) ? 0.92 : 0.8;\n    return new Promise(function (resolve) {\n      canvas.toBlob(function (blob) {\n        resolve(blob);\n      }, mimeType, quality);\n    });\n  });\n\n  return function exportToBlob(_x) {\n    return _ref2.apply(this, arguments);\n  };\n}();\nexport const exportToSvg = /*#__PURE__*/function () {\n  var _ref3 = _asyncToGenerator(function* (_ref4) {\n    let {\n      elements,\n      appState = getDefaultAppState(),\n      files = {},\n      exportPadding\n    } = _ref4;\n    const {\n      elements: restoredElements,\n      appState: restoredAppState\n    } = restore({\n      elements,\n      appState\n    }, null, null);\n    return _exportToSvg(getNonDeletedElements(restoredElements), _objectSpread(_objectSpread({}, restoredAppState), {}, {\n      exportPadding\n    }), files);\n  });\n\n  return function exportToSvg(_x2) {\n    return _ref3.apply(this, arguments);\n  };\n}();\nexport { serializeAsJSON } from \"../data/json\";\nexport { loadFromBlob, loadLibraryFromBlob } from \"../data/blob\";\nexport { getFreeDrawSvgPath } from \"../renderer/renderElement\";\nexport { getCommonBoundingBox } from \"../element/bounds\";\nexport { getMaximumGroups } from \"../align\";"],"names":[],"sourceRoot":""}\\n//# sourceURL=webpack-internal:///../utils.ts\\n\");\n\n//# sourceURL=webpack://Excalidraw/../utils.ts?");
|
|
2868
|
+
eval("eval(\"__webpack_require__.r(__webpack_exports__);\\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\\n/* harmony export */ \\\"exportToCanvas\\\": () => (/* binding */ exportToCanvas),\\n/* harmony export */ \\\"exportToBlob\\\": () => (/* binding */ exportToBlob),\\n/* harmony export */ \\\"exportToSvg\\\": () => (/* binding */ exportToSvg),\\n/* harmony export */ \\\"serializeAsJSON\\\": () => (/* reexport safe */ _data_json__WEBPACK_IMPORTED_MODULE_7__.serializeAsJSON),\\n/* harmony export */ \\\"loadFromBlob\\\": () => (/* reexport safe */ _data_blob__WEBPACK_IMPORTED_MODULE_8__.loadFromBlob),\\n/* harmony export */ \\\"loadLibraryFromBlob\\\": () => (/* reexport safe */ _data_blob__WEBPACK_IMPORTED_MODULE_8__.loadLibraryFromBlob),\\n/* harmony export */ \\\"getFreeDrawSvgPath\\\": () => (/* reexport safe */ _renderer_renderElement__WEBPACK_IMPORTED_MODULE_9__.getFreeDrawSvgPath),\\n/* harmony export */ \\\"getCommonBoundingBox\\\": () => (/* reexport safe */ _element_bounds__WEBPACK_IMPORTED_MODULE_10__.getCommonBoundingBox),\\n/* harmony export */ \\\"getMaximumGroups\\\": () => (/* reexport safe */ _align__WEBPACK_IMPORTED_MODULE_11__.getMaximumGroups),\\n/* harmony export */ \\\"intersectElementWithLine\\\": () => (/* reexport safe */ _element_collision__WEBPACK_IMPORTED_MODULE_12__.intersectElementWithLine),\\n/* harmony export */ \\\"determineFocusDistance\\\": () => (/* reexport safe */ _element_collision__WEBPACK_IMPORTED_MODULE_12__.determineFocusDistance)\\n/* harmony export */ });\\n/* harmony import */ var _babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/asyncToGenerator */ \\\"../../../node_modules/@babel/runtime/helpers/esm/asyncToGenerator.js\\\");\\n/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ \\\"../../../node_modules/@babel/runtime/helpers/esm/defineProperty.js\\\");\\n/* harmony import */ var _scene_export__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../scene/export */ \\\"../../scene/export.ts\\\");\\n/* harmony import */ var _appState__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../appState */ \\\"../../appState.ts\\\");\\n/* harmony import */ var _element__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../element */ \\\"../../element/index.ts\\\");\\n/* harmony import */ var _data_restore__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../data/restore */ \\\"../../data/restore.ts\\\");\\n/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../constants */ \\\"../../constants.ts\\\");\\n/* harmony import */ var _data_json__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../data/json */ \\\"../../data/json.ts\\\");\\n/* harmony import */ var _data_blob__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../data/blob */ \\\"../../data/blob.ts\\\");\\n/* harmony import */ var _renderer_renderElement__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ../renderer/renderElement */ \\\"../../renderer/renderElement.ts\\\");\\n/* harmony import */ var _element_bounds__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ../element/bounds */ \\\"../../element/bounds.ts\\\");\\n/* harmony import */ var _align__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ../align */ \\\"../../align.ts\\\");\\n/* harmony import */ var _element_collision__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ../element/collision */ \\\"../../element/collision.ts\\\");\\n\\r\\n\\r\\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) {\\r\\n var symbols = Object.getOwnPropertySymbols(object);\\r\\n if (enumerableOnly) {\\r\\n symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; });\\r\\n }\\r\\n keys.push.apply(keys, symbols);\\r\\n} return keys; }\\r\\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) {\\r\\n var source = arguments[i] != null ? arguments[i] : {};\\r\\n if (i % 2) {\\r\\n ownKeys(Object(source), true).forEach(function (key) { (0,_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1__[\\\"default\\\"])(target, key, source[key]); });\\r\\n }\\r\\n else if (Object.getOwnPropertyDescriptors) {\\r\\n Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));\\r\\n }\\r\\n else {\\r\\n ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); });\\r\\n }\\r\\n} return target; }\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\nconst exportToCanvas = function (_ref) {\\r\\n let { elements, appState, files, maxWidthOrHeight, getDimensions } = _ref;\\r\\n const { elements: restoredElements, appState: restoredAppState } = (0,_data_restore__WEBPACK_IMPORTED_MODULE_5__.restore)({\\r\\n elements,\\r\\n appState\\r\\n }, null, null);\\r\\n const { exportBackground, viewBackgroundColor } = restoredAppState;\\r\\n return (0,_scene_export__WEBPACK_IMPORTED_MODULE_2__.exportToCanvas)((0,_element__WEBPACK_IMPORTED_MODULE_4__.getNonDeletedElements)(restoredElements), _objectSpread(_objectSpread({}, restoredAppState), {}, {\\r\\n offsetTop: 0,\\r\\n offsetLeft: 0,\\r\\n width: 0,\\r\\n height: 0\\r\\n }), files || {}, {\\r\\n exportBackground,\\r\\n viewBackgroundColor\\r\\n }, function (width, height) {\\r\\n var _a;\\r\\n const canvas = document.createElement(\\\"canvas\\\");\\r\\n if (maxWidthOrHeight) {\\r\\n if (typeof getDimensions === \\\"function\\\") {\\r\\n console.warn(\\\"`getDimensions()` is ignored when `maxWidthOrHeight` is supplied.\\\");\\r\\n }\\r\\n const max = Math.max(width, height);\\r\\n const scale = maxWidthOrHeight / max;\\r\\n canvas.width = width * scale;\\r\\n canvas.height = height * scale;\\r\\n return {\\r\\n canvas,\\r\\n scale\\r\\n };\\r\\n }\\r\\n const ret = (getDimensions === null || getDimensions === void 0 ? void 0 : getDimensions(width, height)) || {\\r\\n width,\\r\\n height\\r\\n };\\r\\n canvas.width = ret.width;\\r\\n canvas.height = ret.height;\\r\\n return {\\r\\n canvas,\\r\\n scale: (_a = ret.scale) !== null && _a !== void 0 ? _a : 1\\r\\n };\\r\\n });\\r\\n};\\r\\nconst exportToBlob = /*#__PURE__*/ function () {\\r\\n var _ref2 = (0,_babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_0__[\\\"default\\\"])(function* (opts) {\\r\\n var _a;\\r\\n let { mimeType = _constants__WEBPACK_IMPORTED_MODULE_6__.MIME_TYPES.png, quality } = opts;\\r\\n if (mimeType === _constants__WEBPACK_IMPORTED_MODULE_6__.MIME_TYPES.png && typeof quality === \\\"number\\\") {\\r\\n console.warn(`\\\"quality\\\" will be ignored for \\\"${_constants__WEBPACK_IMPORTED_MODULE_6__.MIME_TYPES.png}\\\" mimeType`);\\r\\n } // typo in MIME type (should be \\\"jpeg\\\")\\r\\n if (mimeType === \\\"image/jpg\\\") {\\r\\n mimeType = _constants__WEBPACK_IMPORTED_MODULE_6__.MIME_TYPES.jpg;\\r\\n }\\r\\n if (mimeType === _constants__WEBPACK_IMPORTED_MODULE_6__.MIME_TYPES.jpg && !((_a = opts.appState) === null || _a === void 0 ? void 0 : _a.exportBackground)) {\\r\\n console.warn(`Defaulting \\\"exportBackground\\\" to \\\"true\\\" for \\\"${_constants__WEBPACK_IMPORTED_MODULE_6__.MIME_TYPES.jpg}\\\" mimeType`);\\r\\n opts = _objectSpread(_objectSpread({}, opts), {}, {\\r\\n appState: _objectSpread(_objectSpread({}, opts.appState), {}, {\\r\\n exportBackground: true\\r\\n })\\r\\n });\\r\\n }\\r\\n const canvas = yield exportToCanvas(opts);\\r\\n quality = quality ? quality : /image\\\\/jpe?g/.test(mimeType) ? 0.92 : 0.8;\\r\\n return new Promise(function (resolve) {\\r\\n canvas.toBlob(function (blob) {\\r\\n resolve(blob);\\r\\n }, mimeType, quality);\\r\\n });\\r\\n });\\r\\n return function exportToBlob(_x) {\\r\\n return _ref2.apply(this, arguments);\\r\\n };\\r\\n}();\\r\\nconst exportToSvg = /*#__PURE__*/ function () {\\r\\n var _ref3 = (0,_babel_runtime_helpers_asyncToGenerator__WEBPACK_IMPORTED_MODULE_0__[\\\"default\\\"])(function* (_ref4) {\\r\\n let { elements, appState = (0,_appState__WEBPACK_IMPORTED_MODULE_3__.getDefaultAppState)(), files = {}, exportPadding } = _ref4;\\r\\n const { elements: restoredElements, appState: restoredAppState } = (0,_data_restore__WEBPACK_IMPORTED_MODULE_5__.restore)({\\r\\n elements,\\r\\n appState\\r\\n }, null, null);\\r\\n return (0,_scene_export__WEBPACK_IMPORTED_MODULE_2__.exportToSvg)((0,_element__WEBPACK_IMPORTED_MODULE_4__.getNonDeletedElements)(restoredElements), _objectSpread(_objectSpread({}, restoredAppState), {}, {\\r\\n exportPadding\\r\\n }), files);\\r\\n });\\r\\n return function exportToSvg(_x2) {\\r\\n return _ref3.apply(this, arguments);\\r\\n };\\r\\n}();\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n\\r\\n//# sourceURL=[module]\\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"../utils.ts.js","mappings":"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","sources":["webpack:///../utils.ts?b1b8"],"sourcesContent":["import _asyncToGenerator from \"@babel/runtime/helpers/asyncToGenerator\";\nimport _defineProperty from \"@babel/runtime/helpers/defineProperty\";\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nimport { exportToCanvas as _exportToCanvas, exportToSvg as _exportToSvg } from \"../scene/export\";\nimport { getDefaultAppState } from \"../appState\";\nimport { getNonDeletedElements } from \"../element\";\nimport { restore } from \"../data/restore\";\nimport { MIME_TYPES } from \"../constants\";\nexport const exportToCanvas = function (_ref) {\n  let {\n    elements,\n    appState,\n    files,\n    maxWidthOrHeight,\n    getDimensions\n  } = _ref;\n  const {\n    elements: restoredElements,\n    appState: restoredAppState\n  } = restore({\n    elements,\n    appState\n  }, null, null);\n  const {\n    exportBackground,\n    viewBackgroundColor\n  } = restoredAppState;\n  return _exportToCanvas(getNonDeletedElements(restoredElements), _objectSpread(_objectSpread({}, restoredAppState), {}, {\n    offsetTop: 0,\n    offsetLeft: 0,\n    width: 0,\n    height: 0\n  }), files || {}, {\n    exportBackground,\n    viewBackgroundColor\n  }, function (width, height) {\n    const canvas = document.createElement(\"canvas\");\n\n    if (maxWidthOrHeight) {\n      if (typeof getDimensions === \"function\") {\n        console.warn(\"`getDimensions()` is ignored when `maxWidthOrHeight` is supplied.\");\n      }\n\n      const max = Math.max(width, height);\n      const scale = maxWidthOrHeight / max;\n      canvas.width = width * scale;\n      canvas.height = height * scale;\n      return {\n        canvas,\n        scale\n      };\n    }\n\n    const ret = getDimensions?.(width, height) || {\n      width,\n      height\n    };\n    canvas.width = ret.width;\n    canvas.height = ret.height;\n    return {\n      canvas,\n      scale: ret.scale ?? 1\n    };\n  });\n};\nexport const exportToBlob = /*#__PURE__*/function () {\n  var _ref2 = _asyncToGenerator(function* (opts) {\n    let {\n      mimeType = MIME_TYPES.png,\n      quality\n    } = opts;\n\n    if (mimeType === MIME_TYPES.png && typeof quality === \"number\") {\n      console.warn(`\"quality\" will be ignored for \"${MIME_TYPES.png}\" mimeType`);\n    } // typo in MIME type (should be \"jpeg\")\n\n\n    if (mimeType === \"image/jpg\") {\n      mimeType = MIME_TYPES.jpg;\n    }\n\n    if (mimeType === MIME_TYPES.jpg && !opts.appState?.exportBackground) {\n      console.warn(`Defaulting \"exportBackground\" to \"true\" for \"${MIME_TYPES.jpg}\" mimeType`);\n      opts = _objectSpread(_objectSpread({}, opts), {}, {\n        appState: _objectSpread(_objectSpread({}, opts.appState), {}, {\n          exportBackground: true\n        })\n      });\n    }\n\n    const canvas = yield exportToCanvas(opts);\n    quality = quality ? quality : /image\\/jpe?g/.test(mimeType) ? 0.92 : 0.8;\n    return new Promise(function (resolve) {\n      canvas.toBlob(function (blob) {\n        resolve(blob);\n      }, mimeType, quality);\n    });\n  });\n\n  return function exportToBlob(_x) {\n    return _ref2.apply(this, arguments);\n  };\n}();\nexport const exportToSvg = /*#__PURE__*/function () {\n  var _ref3 = _asyncToGenerator(function* (_ref4) {\n    let {\n      elements,\n      appState = getDefaultAppState(),\n      files = {},\n      exportPadding\n    } = _ref4;\n    const {\n      elements: restoredElements,\n      appState: restoredAppState\n    } = restore({\n      elements,\n      appState\n    }, null, null);\n    return _exportToSvg(getNonDeletedElements(restoredElements), _objectSpread(_objectSpread({}, restoredAppState), {}, {\n      exportPadding\n    }), files);\n  });\n\n  return function exportToSvg(_x2) {\n    return _ref3.apply(this, arguments);\n  };\n}();\nexport { serializeAsJSON } from \"../data/json\";\nexport { loadFromBlob, loadLibraryFromBlob } from \"../data/blob\";\nexport { getFreeDrawSvgPath } from \"../renderer/renderElement\";\nexport { getCommonBoundingBox } from \"../element/bounds\";\nexport { getMaximumGroups } from \"../align\";\nexport { intersectElementWithLine } from \"../element/collision\";\nexport { determineFocusDistance } from \"../element/collision\";"],"names":[],"sourceRoot":""}\\n//# sourceURL=webpack-internal:///../utils.ts\\n\");\n\n//# sourceURL=webpack://Excalidraw/../utils.ts?");
|
|
2869
2869
|
|
|
2870
2870
|
/***/ }),
|
|
2871
2871
|
|
|
@@ -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-
|
|
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
|
|