@plait/core 0.0.53 → 0.0.56

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.
@@ -16,11 +16,20 @@ export const inverse = (op) => {
16
16
  if (Path.equals(newPath, path)) {
17
17
  return op;
18
18
  }
19
- if (Path.isSibling(path, newPath)) {
20
- const inversePath = Path.transform(path, op);
21
- return { ...op, path: inversePath, newPath: path };
22
- }
23
- return { ...op, path: newPath, newPath: path };
19
+ // when operation path is [0,0] -> [0,2], should exec Path.transform to get [0,1] -> [0,0]
20
+ // shoud not return [0,2] -> [0,0] #WIK-8981
21
+ // if (Path.isSibling(path, newPath)) {
22
+ // return { ...op, path: newPath, newPath: path };
23
+ // }
24
+ // If the move does not happen within a single parent it is possible
25
+ // for the move to impact the true path to the location where the node
26
+ // was removed from and where it was inserted. We have to adjust for this
27
+ // and find the original path. We can accomplish this (only in non-sibling)
28
+ // moves by looking at the impact of the move operation on the node
29
+ // after the original move path.
30
+ const inversePath = Path.transform(path, op);
31
+ const inverseNewPath = Path.transform(Path.next(path), op);
32
+ return { ...op, path: inversePath, newPath: inverseNewPath };
24
33
  }
25
34
  case 'set_node': {
26
35
  const { properties, newProperties } = op;
@@ -72,4 +81,4 @@ export const PlaitOperation = {
72
81
  isSetViewportOperation,
73
82
  inverse
74
83
  };
75
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3BlcmF0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvcGxhaXQvc3JjL2ludGVyZmFjZXMvb3BlcmF0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxRQUFRLENBQUM7QUFzRDlCLE1BQU0sQ0FBQyxNQUFNLHNCQUFzQixHQUFHLENBQUMsS0FBVSxFQUFpQyxFQUFFO0lBQ2hGLE9BQU8sS0FBSyxDQUFDLElBQUksS0FBSyxjQUFjLENBQUM7QUFDekMsQ0FBQyxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFHLENBQUMsRUFBa0IsRUFBa0IsRUFBRTtJQUMxRCxRQUFRLEVBQUUsQ0FBQyxJQUFJLEVBQUU7UUFDYixLQUFLLGFBQWEsQ0FBQyxDQUFDO1lBQ2hCLE9BQU8sRUFBRSxHQUFHLEVBQUUsRUFBRSxJQUFJLEVBQUUsYUFBYSxFQUFFLENBQUM7U0FDekM7UUFFRCxLQUFLLGFBQWEsQ0FBQyxDQUFDO1lBQ2hCLE9BQU8sRUFBRSxHQUFHLEVBQUUsRUFBRSxJQUFJLEVBQUUsYUFBYSxFQUFFLENBQUM7U0FDekM7UUFFRCxLQUFLLFdBQVcsQ0FBQyxDQUFDO1lBQ2QsTUFBTSxFQUFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsR0FBRyxFQUFFLENBQUM7WUFFN0IsNERBQTREO1lBQzVELElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLEVBQUUsSUFBSSxDQUFDLEVBQUU7Z0JBQzVCLE9BQU8sRUFBRSxDQUFDO2FBQ2I7WUFFRCxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxFQUFFLE9BQU8sQ0FBQyxFQUFFO2dCQUMvQixNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksRUFBRSxFQUFFLENBQUUsQ0FBQztnQkFDOUMsT0FBTyxFQUFFLEdBQUcsRUFBRSxFQUFFLElBQUksRUFBRSxXQUFXLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBRSxDQUFDO2FBQ3REO1lBRUQsT0FBTyxFQUFFLEdBQUcsRUFBRSxFQUFFLElBQUksRUFBRSxPQUFPLEVBQUUsT0FBTyxFQUFFLElBQUksRUFBRSxDQUFDO1NBQ2xEO1FBRUQsS0FBSyxVQUFVLENBQUMsQ0FBQztZQUNiLE1BQU0sRUFBRSxVQUFVLEVBQUUsYUFBYSxFQUFFLEdBQUcsRUFBRSxDQUFDO1lBQ3pDLE9BQU8sRUFBRSxHQUFHLEVBQUUsRUFBRSxVQUFVLEVBQUUsYUFBYSxFQUFFLGFBQWEsRUFBRSxVQUFVLEVBQUUsQ0FBQztTQUMxRTtRQUVELEtBQUssZUFBZSxDQUFDLENBQUM7WUFDbEIsTUFBTSxFQUFFLFVBQVUsRUFBRSxhQUFhLEVBQUUsR0FBRyxFQUFFLENBQUM7WUFFekMsSUFBSSxVQUFVLElBQUksSUFBSSxFQUFFO2dCQUNwQixPQUFPO29CQUNILEdBQUcsRUFBRTtvQkFDTCxVQUFVLEVBQUUsYUFBYTtvQkFDekIsYUFBYSxFQUFFLElBQUk7aUJBQ3RCLENBQUM7YUFDTDtpQkFBTSxJQUFJLGFBQWEsSUFBSSxJQUFJLEVBQUU7Z0JBQzlCLE9BQU87b0JBQ0gsR0FBRyxFQUFFO29CQUNMLFVBQVUsRUFBRSxJQUFJO29CQUNoQixhQUFhLEVBQUUsVUFBVTtpQkFDNUIsQ0FBQzthQUNMO2lCQUFNO2dCQUNILE9BQU8sRUFBRSxHQUFHLEVBQUUsRUFBRSxVQUFVLEVBQUUsYUFBYSxFQUFFLGFBQWEsRUFBRSxVQUFVLEVBQUUsQ0FBQzthQUMxRTtTQUNKO1FBRUQsS0FBSyxjQUFjLENBQUMsQ0FBQztZQUNqQixNQUFNLEVBQUUsVUFBVSxFQUFFLGFBQWEsRUFBRSxHQUFHLEVBQUUsQ0FBQztZQUN6QyxJQUFJLFVBQVUsSUFBSSxJQUFJLEVBQUU7Z0JBQ3BCLE9BQU87b0JBQ0gsR0FBRyxFQUFFO29CQUNMLFVBQVUsRUFBRSxhQUFhO29CQUN6QixhQUFhLEVBQUUsYUFBYTtpQkFDL0IsQ0FBQzthQUNMO2lCQUFNLElBQUksYUFBYSxJQUFJLElBQUksRUFBRTtnQkFDOUIsT0FBTztvQkFDSCxHQUFHLEVBQUU7b0JBQ0wsVUFBVSxFQUFFLFVBQVU7b0JBQ3RCLGFBQWEsRUFBRSxVQUFVO2lCQUM1QixDQUFDO2FBQ0w7aUJBQU07Z0JBQ0gsT0FBTyxFQUFFLEdBQUcsRUFBRSxFQUFFLFVBQVUsRUFBRSxhQUFhLEVBQUUsYUFBYSxFQUFFLFVBQVUsRUFBRSxDQUFDO2FBQzFFO1NBQ0o7S0FDSjtBQUNMLENBQUMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGNBQWMsR0FBNEI7SUFDbkQsc0JBQXNCO0lBQ3RCLE9BQU87Q0FDVixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGxhaXROb2RlIH0gZnJvbSAnLi9ub2RlJztcbmltcG9ydCB7IFBhdGggfSBmcm9tICcuL3BhdGgnO1xuaW1wb3J0IHsgU2VsZWN0aW9uIH0gZnJvbSAnLi9zZWxlY3Rpb24nO1xuaW1wb3J0IHsgVmlld3BvcnQgfSBmcm9tICcuL3ZpZXdwb3J0JztcblxuZXhwb3J0IHR5cGUgSW5zZXJ0Tm9kZU9wZXJhdGlvbiA9IHtcbiAgICB0eXBlOiAnaW5zZXJ0X25vZGUnO1xuICAgIHBhdGg6IFBhdGg7XG4gICAgbm9kZTogUGxhaXROb2RlO1xufTtcblxuZXhwb3J0IHR5cGUgUmVtb3ZlTm9kZU9wZXJhdGlvbiA9IHtcbiAgICB0eXBlOiAncmVtb3ZlX25vZGUnO1xuICAgIHBhdGg6IFBhdGg7XG4gICAgbm9kZTogUGxhaXROb2RlO1xufTtcblxuZXhwb3J0IHR5cGUgTW92ZU5vZGVPcGVyYXRpb24gPSB7XG4gICAgdHlwZTogJ21vdmVfbm9kZSc7XG4gICAgcGF0aDogUGF0aDtcbiAgICBuZXdQYXRoOiBQYXRoO1xufTtcblxuZXhwb3J0IHR5cGUgU2V0Vmlld3BvcnRPcGVyYXRpb24gPSB7XG4gICAgdHlwZTogJ3NldF92aWV3cG9ydCc7XG4gICAgcHJvcGVydGllczogUGFydGlhbDxWaWV3cG9ydD47XG4gICAgbmV3UHJvcGVydGllczogUGFydGlhbDxWaWV3cG9ydD47XG59O1xuXG5leHBvcnQgdHlwZSBTZXRTZWxlY3Rpb25PcGVyYXRpb24gPSB7XG4gICAgdHlwZTogJ3NldF9zZWxlY3Rpb24nO1xuICAgIHByb3BlcnRpZXM6IFNlbGVjdGlvbiB8IG51bGw7XG4gICAgbmV3UHJvcGVydGllczogU2VsZWN0aW9uIHwgbnVsbDtcbn07XG5cbmV4cG9ydCB0eXBlIFNldE5vZGVPcGVyYXRpb24gPSB7XG4gICAgdHlwZTogJ3NldF9ub2RlJztcbiAgICBwYXRoOiBQYXRoO1xuICAgIHByb3BlcnRpZXM6IFBhcnRpYWw8UGxhaXROb2RlPjtcbiAgICBuZXdQcm9wZXJ0aWVzOiBQYXJ0aWFsPFBsYWl0Tm9kZT47XG59O1xuXG5leHBvcnQgdHlwZSBQbGFpdE9wZXJhdGlvbiA9XG4gICAgfCBJbnNlcnROb2RlT3BlcmF0aW9uXG4gICAgfCBTZXRWaWV3cG9ydE9wZXJhdGlvblxuICAgIHwgU2V0U2VsZWN0aW9uT3BlcmF0aW9uXG4gICAgfCBTZXROb2RlT3BlcmF0aW9uXG4gICAgfCBSZW1vdmVOb2RlT3BlcmF0aW9uXG4gICAgfCBNb3ZlTm9kZU9wZXJhdGlvbjtcblxuZXhwb3J0IGludGVyZmFjZSBQbGFpdE9wZXJhdGlvbkludGVyZmFjZSB7XG4gICAgaW52ZXJzZTogKG9wOiBQbGFpdE9wZXJhdGlvbikgPT4gUGxhaXRPcGVyYXRpb247XG4gICAgaXNTZXRWaWV3cG9ydE9wZXJhdGlvbjogKHZhbHVlOiBhbnkpID0+IGJvb2xlYW47XG59XG5cbmV4cG9ydCBjb25zdCBpc1NldFZpZXdwb3J0T3BlcmF0aW9uID0gKHZhbHVlOiBhbnkpOiB2YWx1ZSBpcyBTZXRWaWV3cG9ydE9wZXJhdGlvbiA9PiB7XG4gICAgcmV0dXJuIHZhbHVlLnR5cGUgPT09ICdzZXRfdmlld3BvcnQnO1xufTtcblxuZXhwb3J0IGNvbnN0IGludmVyc2UgPSAob3A6IFBsYWl0T3BlcmF0aW9uKTogUGxhaXRPcGVyYXRpb24gPT4ge1xuICAgIHN3aXRjaCAob3AudHlwZSkge1xuICAgICAgICBjYXNlICdpbnNlcnRfbm9kZSc6IHtcbiAgICAgICAgICAgIHJldHVybiB7IC4uLm9wLCB0eXBlOiAncmVtb3ZlX25vZGUnIH07XG4gICAgICAgIH1cblxuICAgICAgICBjYXNlICdyZW1vdmVfbm9kZSc6IHtcbiAgICAgICAgICAgIHJldHVybiB7IC4uLm9wLCB0eXBlOiAnaW5zZXJ0X25vZGUnIH07XG4gICAgICAgIH1cblxuICAgICAgICBjYXNlICdtb3ZlX25vZGUnOiB7XG4gICAgICAgICAgICBjb25zdCB7IG5ld1BhdGgsIHBhdGggfSA9IG9wO1xuXG4gICAgICAgICAgICAvLyBQRVJGOiBpbiB0aGlzIGNhc2UgdGhlIG1vdmUgb3BlcmF0aW9uIGlzIGEgbm8tb3AgYW55d2F5cy5cbiAgICAgICAgICAgIGlmIChQYXRoLmVxdWFscyhuZXdQYXRoLCBwYXRoKSkge1xuICAgICAgICAgICAgICAgIHJldHVybiBvcDtcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgaWYgKFBhdGguaXNTaWJsaW5nKHBhdGgsIG5ld1BhdGgpKSB7XG4gICAgICAgICAgICAgICAgY29uc3QgaW52ZXJzZVBhdGggPSBQYXRoLnRyYW5zZm9ybShwYXRoLCBvcCkhO1xuICAgICAgICAgICAgICAgIHJldHVybiB7IC4uLm9wLCBwYXRoOiBpbnZlcnNlUGF0aCwgbmV3UGF0aDogcGF0aCB9O1xuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICByZXR1cm4geyAuLi5vcCwgcGF0aDogbmV3UGF0aCwgbmV3UGF0aDogcGF0aCB9O1xuICAgICAgICB9XG5cbiAgICAgICAgY2FzZSAnc2V0X25vZGUnOiB7XG4gICAgICAgICAgICBjb25zdCB7IHByb3BlcnRpZXMsIG5ld1Byb3BlcnRpZXMgfSA9IG9wO1xuICAgICAgICAgICAgcmV0dXJuIHsgLi4ub3AsIHByb3BlcnRpZXM6IG5ld1Byb3BlcnRpZXMsIG5ld1Byb3BlcnRpZXM6IHByb3BlcnRpZXMgfTtcbiAgICAgICAgfVxuXG4gICAgICAgIGNhc2UgJ3NldF9zZWxlY3Rpb24nOiB7XG4gICAgICAgICAgICBjb25zdCB7IHByb3BlcnRpZXMsIG5ld1Byb3BlcnRpZXMgfSA9IG9wO1xuXG4gICAgICAgICAgICBpZiAocHJvcGVydGllcyA9PSBudWxsKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgICAgICAgICAgLi4ub3AsXG4gICAgICAgICAgICAgICAgICAgIHByb3BlcnRpZXM6IG5ld1Byb3BlcnRpZXMsXG4gICAgICAgICAgICAgICAgICAgIG5ld1Byb3BlcnRpZXM6IG51bGxcbiAgICAgICAgICAgICAgICB9O1xuICAgICAgICAgICAgfSBlbHNlIGlmIChuZXdQcm9wZXJ0aWVzID09IG51bGwpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgICAgICAgICAuLi5vcCxcbiAgICAgICAgICAgICAgICAgICAgcHJvcGVydGllczogbnVsbCxcbiAgICAgICAgICAgICAgICAgICAgbmV3UHJvcGVydGllczogcHJvcGVydGllc1xuICAgICAgICAgICAgICAgIH07XG4gICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgIHJldHVybiB7IC4uLm9wLCBwcm9wZXJ0aWVzOiBuZXdQcm9wZXJ0aWVzLCBuZXdQcm9wZXJ0aWVzOiBwcm9wZXJ0aWVzIH07XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cblxuICAgICAgICBjYXNlICdzZXRfdmlld3BvcnQnOiB7XG4gICAgICAgICAgICBjb25zdCB7IHByb3BlcnRpZXMsIG5ld1Byb3BlcnRpZXMgfSA9IG9wO1xuICAgICAgICAgICAgaWYgKHByb3BlcnRpZXMgPT0gbnVsbCkge1xuICAgICAgICAgICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICAgICAgICAgIC4uLm9wLFxuICAgICAgICAgICAgICAgICAgICBwcm9wZXJ0aWVzOiBuZXdQcm9wZXJ0aWVzLFxuICAgICAgICAgICAgICAgICAgICBuZXdQcm9wZXJ0aWVzOiBuZXdQcm9wZXJ0aWVzXG4gICAgICAgICAgICAgICAgfTtcbiAgICAgICAgICAgIH0gZWxzZSBpZiAobmV3UHJvcGVydGllcyA9PSBudWxsKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgICAgICAgICAgLi4ub3AsXG4gICAgICAgICAgICAgICAgICAgIHByb3BlcnRpZXM6IHByb3BlcnRpZXMsXG4gICAgICAgICAgICAgICAgICAgIG5ld1Byb3BlcnRpZXM6IHByb3BlcnRpZXNcbiAgICAgICAgICAgICAgICB9O1xuICAgICAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgICAgICByZXR1cm4geyAuLi5vcCwgcHJvcGVydGllczogbmV3UHJvcGVydGllcywgbmV3UHJvcGVydGllczogcHJvcGVydGllcyB9O1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgfVxufTtcblxuZXhwb3J0IGNvbnN0IFBsYWl0T3BlcmF0aW9uOiBQbGFpdE9wZXJhdGlvbkludGVyZmFjZSA9IHtcbiAgICBpc1NldFZpZXdwb3J0T3BlcmF0aW9uLFxuICAgIGludmVyc2Vcbn07XG4iXX0=
84
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"operation.js","sourceRoot":"","sources":["../../../../packages/plait/src/interfaces/operation.ts"],"names":[],"mappings":"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","sourcesContent":["import { PlaitNode } from './node';\nimport { Path } from './path';\nimport { Selection } from './selection';\nimport { Viewport } from './viewport';\n\nexport type InsertNodeOperation = {\n    type: 'insert_node';\n    path: Path;\n    node: PlaitNode;\n};\n\nexport type RemoveNodeOperation = {\n    type: 'remove_node';\n    path: Path;\n    node: PlaitNode;\n};\n\nexport type MoveNodeOperation = {\n    type: 'move_node';\n    path: Path;\n    newPath: Path;\n};\n\nexport type SetViewportOperation = {\n    type: 'set_viewport';\n    properties: Partial<Viewport>;\n    newProperties: Partial<Viewport>;\n};\n\nexport type SetSelectionOperation = {\n    type: 'set_selection';\n    properties: Selection | null;\n    newProperties: Selection | null;\n};\n\nexport type SetNodeOperation = {\n    type: 'set_node';\n    path: Path;\n    properties: Partial<PlaitNode>;\n    newProperties: Partial<PlaitNode>;\n};\n\nexport type PlaitOperation =\n    | InsertNodeOperation\n    | SetViewportOperation\n    | SetSelectionOperation\n    | SetNodeOperation\n    | RemoveNodeOperation\n    | MoveNodeOperation;\n\nexport interface PlaitOperationInterface {\n    inverse: (op: PlaitOperation) => PlaitOperation;\n    isSetViewportOperation: (value: any) => boolean;\n}\n\nexport const isSetViewportOperation = (value: any): value is SetViewportOperation => {\n    return value.type === 'set_viewport';\n};\n\nexport const inverse = (op: PlaitOperation): PlaitOperation => {\n    switch (op.type) {\n        case 'insert_node': {\n            return { ...op, type: 'remove_node' };\n        }\n\n        case 'remove_node': {\n            return { ...op, type: 'insert_node' };\n        }\n\n        case 'move_node': {\n            const { newPath, path } = op;\n\n            // PERF: in this case the move operation is a no-op anyways.\n            if (Path.equals(newPath, path)) {\n                return op;\n            }\n\n            // when operation path is [0,0] -> [0,2], should exec Path.transform to get [0,1] -> [0,0]\n            // shoud not return [0,2] -> [0,0] #WIK-8981\n            // if (Path.isSibling(path, newPath)) {\n            //     return { ...op, path: newPath, newPath: path };\n            // }\n\n            // If the move does not happen within a single parent it is possible\n            // for the move to impact the true path to the location where the node\n            // was removed from and where it was inserted. We have to adjust for this\n            // and find the original path. We can accomplish this (only in non-sibling)\n            // moves by looking at the impact of the move operation on the node\n            // after the original move path.\n            const inversePath = Path.transform(path, op)!;\n            const inverseNewPath = Path.transform(Path.next(path), op)!;\n            return { ...op, path: inversePath, newPath: inverseNewPath };\n        }\n\n        case 'set_node': {\n            const { properties, newProperties } = op;\n            return { ...op, properties: newProperties, newProperties: properties };\n        }\n\n        case 'set_selection': {\n            const { properties, newProperties } = op;\n\n            if (properties == null) {\n                return {\n                    ...op,\n                    properties: newProperties,\n                    newProperties: null\n                };\n            } else if (newProperties == null) {\n                return {\n                    ...op,\n                    properties: null,\n                    newProperties: properties\n                };\n            } else {\n                return { ...op, properties: newProperties, newProperties: properties };\n            }\n        }\n\n        case 'set_viewport': {\n            const { properties, newProperties } = op;\n            if (properties == null) {\n                return {\n                    ...op,\n                    properties: newProperties,\n                    newProperties: newProperties\n                };\n            } else if (newProperties == null) {\n                return {\n                    ...op,\n                    properties: properties,\n                    newProperties: properties\n                };\n            } else {\n                return { ...op, properties: newProperties, newProperties: properties };\n            }\n        }\n    }\n};\n\nexport const PlaitOperation: PlaitOperationInterface = {\n    isSetViewportOperation,\n    inverse\n};\n"]}
@@ -132,8 +132,8 @@ export const Path = {
132
132
  break;
133
133
  }
134
134
  }
135
- return null;
135
+ return p;
136
136
  });
137
137
  }
138
138
  };
139
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"path.js","sourceRoot":"","sources":["../../../../packages/plait/src/interfaces/path.ts"],"names":[],"mappings":"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","sourcesContent":["import produce from 'immer';\nimport { PlaitOperation } from './operation';\n\nexport type Path = number[];\n\nexport const Path = {\n    parent(path: Path): Path {\n        if (path.length === 0) {\n            throw new Error(`Cannot get the parent path of the root path [${path}].`);\n        }\n\n        return path.slice(0, -1);\n    },\n    next(path: Path): Path {\n        if (path.length === 0) {\n            throw new Error(`Cannot get the next path of a root path [${path}], because it has no next index.`);\n        }\n        const last = path[path.length - 1];\n        return path.slice(0, -1).concat(last + 1);\n    },\n    /**\n     * Check if a path is an ancestor of another.\n     */\n\n    isAncestor(path: Path, another: Path): boolean {\n        return path.length < another.length && Path.compare(path, another) === 0;\n    },\n    /**\n     * Compare a path to another, returning an integer indicating whether the path\n     * was before, at, or after the other.\n     *\n     * Note: Two paths of unequal length can still receive a `0` result if one is\n     * directly above or below the other. If you want exact matching, use\n     * [[Path.equals]] instead.\n     */\n    compare(path: Path, another: Path): -1 | 0 | 1 {\n        const min = Math.min(path.length, another.length);\n\n        for (let i = 0; i < min; i++) {\n            if (path[i] < another[i]) return -1;\n            if (path[i] > another[i]) return 1;\n        }\n\n        return 0;\n    },\n\n    /**\n     * Check if a path is exactly equal to another.\n     */\n\n    equals(path: Path, another: Path): boolean {\n        return path.length === another.length && path.every((n, i) => n === another[i]);\n    },\n    /**\n     * Check if a path ends before one of the indexes in another.\n     */\n\n    endsBefore(path: Path, another: Path): boolean {\n        const i = path.length - 1;\n        const as = path.slice(0, i);\n        const bs = another.slice(0, i);\n        const av = path[i];\n        const bv = another[i];\n        return Path.equals(as, bs) && av < bv;\n    },\n    /**\n     * Check if a path is a sibling of another.\n     */\n    isSibling(path: Path, another: Path): boolean {\n        if (path.length !== another.length) {\n            return false;\n        }\n\n        const as = path.slice(0, -1);\n        const bs = another.slice(0, -1);\n        const al = path[path.length - 1];\n        const bl = another[another.length - 1];\n        return al !== bl && Path.equals(as, bs);\n    },\n    transform(path: Path | null, operation: PlaitOperation): Path | null {\n        return produce(path, p => {\n            // PERF: Exit early if the operation is guaranteed not to have an effect.\n            if (!path || path?.length === 0) {\n                return;\n            }\n\n            if (p === null) {\n                return null;\n            }\n\n            switch (operation.type) {\n                case 'insert_node': {\n                    const { path: op } = operation;\n\n                    if (Path.equals(op, p) || Path.endsBefore(op, p) || Path.isAncestor(op, p)) {\n                        p[op.length - 1] += 1;\n                    }\n\n                    break;\n                }\n\n                case 'remove_node': {\n                    const { path: op } = operation;\n\n                    if (Path.equals(op, p) || Path.isAncestor(op, p)) {\n                        return null;\n                    } else if (Path.endsBefore(op, p)) {\n                        p[op.length - 1] -= 1;\n                    }\n\n                    break;\n                }\n\n                case 'move_node': {\n                    const { path: op, newPath: onp } = operation;\n\n                    // If the old and new path are the same, it's a no-op.\n                    if (Path.equals(op, onp)) {\n                        return;\n                    }\n\n                    if (Path.isAncestor(op, p) || Path.equals(op, p)) {\n                        const copy = onp.slice();\n                        // op.length <= onp.length is different for slate\n                        // resolve drag from [0, 0] to [0, 3] issue\n                        if (Path.endsBefore(op, onp) && op.length <= onp.length) {\n                            copy[op.length - 1] -= 1;\n                        }\n\n                        return copy.concat(p.slice(op.length));\n                    } else if (Path.isSibling(op, onp) && (Path.isAncestor(onp, p) || Path.equals(onp, p))) {\n                        if (Path.endsBefore(op, p)) {\n                            p[op.length - 1] -= 1;\n                        } else {\n                            p[op.length - 1] += 1;\n                        }\n                    } else if (Path.endsBefore(onp, p) || Path.equals(onp, p) || Path.isAncestor(onp, p)) {\n                        if (Path.endsBefore(op, p)) {\n                            p[op.length - 1] -= 1;\n                        }\n\n                        p[onp.length - 1] += 1;\n                    } else if (Path.endsBefore(op, p)) {\n                        if (Path.equals(onp, p)) {\n                            p[onp.length - 1] += 1;\n                        }\n\n                        p[op.length - 1] -= 1;\n                    }\n\n                    break;\n                }\n            }\n            return null;\n        });\n    }\n};\n"]}
139
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"path.js","sourceRoot":"","sources":["../../../../packages/plait/src/interfaces/path.ts"],"names":[],"mappings":"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","sourcesContent":["import produce from 'immer';\nimport { PlaitOperation } from './operation';\n\nexport type Path = number[];\n\nexport const Path = {\n    parent(path: Path): Path {\n        if (path.length === 0) {\n            throw new Error(`Cannot get the parent path of the root path [${path}].`);\n        }\n\n        return path.slice(0, -1);\n    },\n    next(path: Path): Path {\n        if (path.length === 0) {\n            throw new Error(`Cannot get the next path of a root path [${path}], because it has no next index.`);\n        }\n        const last = path[path.length - 1];\n        return path.slice(0, -1).concat(last + 1);\n    },\n    /**\n     * Check if a path is an ancestor of another.\n     */\n\n    isAncestor(path: Path, another: Path): boolean {\n        return path.length < another.length && Path.compare(path, another) === 0;\n    },\n    /**\n     * Compare a path to another, returning an integer indicating whether the path\n     * was before, at, or after the other.\n     *\n     * Note: Two paths of unequal length can still receive a `0` result if one is\n     * directly above or below the other. If you want exact matching, use\n     * [[Path.equals]] instead.\n     */\n    compare(path: Path, another: Path): -1 | 0 | 1 {\n        const min = Math.min(path.length, another.length);\n\n        for (let i = 0; i < min; i++) {\n            if (path[i] < another[i]) return -1;\n            if (path[i] > another[i]) return 1;\n        }\n\n        return 0;\n    },\n\n    /**\n     * Check if a path is exactly equal to another.\n     */\n\n    equals(path: Path, another: Path): boolean {\n        return path.length === another.length && path.every((n, i) => n === another[i]);\n    },\n    /**\n     * Check if a path ends before one of the indexes in another.\n     */\n\n    endsBefore(path: Path, another: Path): boolean {\n        const i = path.length - 1;\n        const as = path.slice(0, i);\n        const bs = another.slice(0, i);\n        const av = path[i];\n        const bv = another[i];\n        return Path.equals(as, bs) && av < bv;\n    },\n    /**\n     * Check if a path is a sibling of another.\n     */\n    isSibling(path: Path, another: Path): boolean {\n        if (path.length !== another.length) {\n            return false;\n        }\n\n        const as = path.slice(0, -1);\n        const bs = another.slice(0, -1);\n        const al = path[path.length - 1];\n        const bl = another[another.length - 1];\n        return al !== bl && Path.equals(as, bs);\n    },\n    transform(path: Path | null, operation: PlaitOperation): Path | null {\n        return produce(path, p => {\n            // PERF: Exit early if the operation is guaranteed not to have an effect.\n            if (!path || path?.length === 0) {\n                return;\n            }\n\n            if (p === null) {\n                return null;\n            }\n\n            switch (operation.type) {\n                case 'insert_node': {\n                    const { path: op } = operation;\n\n                    if (Path.equals(op, p) || Path.endsBefore(op, p) || Path.isAncestor(op, p)) {\n                        p[op.length - 1] += 1;\n                    }\n\n                    break;\n                }\n\n                case 'remove_node': {\n                    const { path: op } = operation;\n\n                    if (Path.equals(op, p) || Path.isAncestor(op, p)) {\n                        return null;\n                    } else if (Path.endsBefore(op, p)) {\n                        p[op.length - 1] -= 1;\n                    }\n\n                    break;\n                }\n\n                case 'move_node': {\n                    const { path: op, newPath: onp } = operation;\n\n                    // If the old and new path are the same, it's a no-op.\n                    if (Path.equals(op, onp)) {\n                        return;\n                    }\n\n                    if (Path.isAncestor(op, p) || Path.equals(op, p)) {\n                        const copy = onp.slice();\n                        // op.length <= onp.length is different for slate\n                        // resolve drag from [0, 0] to [0, 3] issue\n                        if (Path.endsBefore(op, onp) && op.length <= onp.length) {\n                            copy[op.length - 1] -= 1;\n                        }\n\n                        return copy.concat(p.slice(op.length));\n                    } else if (Path.isSibling(op, onp) && (Path.isAncestor(onp, p) || Path.equals(onp, p))) {\n                        if (Path.endsBefore(op, p)) {\n                            p[op.length - 1] -= 1;\n                        } else {\n                            p[op.length - 1] += 1;\n                        }\n                    } else if (Path.endsBefore(onp, p) || Path.equals(onp, p) || Path.isAncestor(onp, p)) {\n                        if (Path.endsBefore(op, p)) {\n                            p[op.length - 1] -= 1;\n                        }\n\n                        p[onp.length - 1] += 1;\n                    } else if (Path.endsBefore(op, p)) {\n                        if (Path.equals(onp, p)) {\n                            p[onp.length - 1] += 1;\n                        }\n\n                        p[op.length - 1] -= 1;\n                    }\n\n                    break;\n                }\n            }\n            return p;\n        });\n    }\n};\n"]}
@@ -1,10 +1,7 @@
1
1
  import { isNullOrUndefined } from '../utils/helper';
2
2
  export const Viewport = {
3
3
  isViewport: (value) => {
4
- return (!isNullOrUndefined(value.offsetXRatio) &&
5
- !isNullOrUndefined(value.offsetYRatio) &&
6
- !isNullOrUndefined(value.zoom) &&
7
- !isNullOrUndefined(value.viewBackgroundColor));
4
+ return !isNullOrUndefined(value.zoom) && !isNullOrUndefined(value.viewBackgroundColor) && !isNullOrUndefined(value.canvasPoint);
8
5
  }
9
6
  };
10
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlld3BvcnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9wbGFpdC9zcmMvaW50ZXJmYWNlcy92aWV3cG9ydC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQWlCcEQsTUFBTSxDQUFDLE1BQU0sUUFBUSxHQUFzQjtJQUN2QyxVQUFVLEVBQUUsQ0FBQyxLQUFVLEVBQXFCLEVBQUU7UUFDMUMsT0FBTyxDQUNILENBQUMsaUJBQWlCLENBQUMsS0FBSyxDQUFDLFlBQVksQ0FBQztZQUN0QyxDQUFDLGlCQUFpQixDQUFDLEtBQUssQ0FBQyxZQUFZLENBQUM7WUFDdEMsQ0FBQyxpQkFBaUIsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDO1lBQzlCLENBQUMsaUJBQWlCLENBQUMsS0FBSyxDQUFDLG1CQUFtQixDQUFDLENBQ2hELENBQUM7SUFDTixDQUFDO0NBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGlzTnVsbE9yVW5kZWZpbmVkIH0gZnJvbSAnLi4vdXRpbHMvaGVscGVyJztcbmltcG9ydCB7IEV4dGVuZGVkVHlwZSB9IGZyb20gJy4vY3VzdG9tLXR5cGVzJztcblxuZXhwb3J0IGludGVyZmFjZSBCYXNlVmlld3BvcnQge1xuICAgIFtrZXk6IHN0cmluZ106IGFueTtcbiAgICBvZmZzZXRYUmF0aW86IG51bWJlcjtcbiAgICBvZmZzZXRZUmF0aW86IG51bWJlcjtcbiAgICB6b29tOiBudW1iZXI7XG4gICAgdmlld0JhY2tncm91bmRDb2xvcjogc3RyaW5nO1xufVxuXG5leHBvcnQgdHlwZSBWaWV3cG9ydCA9IEV4dGVuZGVkVHlwZTwnVmlld3BvcnQnLCBCYXNlVmlld3BvcnQ+O1xuXG5leHBvcnQgaW50ZXJmYWNlIFZpZXdwb3J0SW50ZXJmYWNlIHtcbiAgICBpc1ZpZXdwb3J0OiAodmFsdWU6IGFueSkgPT4gdmFsdWUgaXMgVmlld3BvcnQ7XG59XG5cbmV4cG9ydCBjb25zdCBWaWV3cG9ydDogVmlld3BvcnRJbnRlcmZhY2UgPSB7XG4gICAgaXNWaWV3cG9ydDogKHZhbHVlOiBhbnkpOiB2YWx1ZSBpcyBWaWV3cG9ydCA9PiB7XG4gICAgICAgIHJldHVybiAoXG4gICAgICAgICAgICAhaXNOdWxsT3JVbmRlZmluZWQodmFsdWUub2Zmc2V0WFJhdGlvKSAmJlxuICAgICAgICAgICAgIWlzTnVsbE9yVW5kZWZpbmVkKHZhbHVlLm9mZnNldFlSYXRpbykgJiZcbiAgICAgICAgICAgICFpc051bGxPclVuZGVmaW5lZCh2YWx1ZS56b29tKSAmJlxuICAgICAgICAgICAgIWlzTnVsbE9yVW5kZWZpbmVkKHZhbHVlLnZpZXdCYWNrZ3JvdW5kQ29sb3IpXG4gICAgICAgICk7XG4gICAgfVxufTtcbiJdfQ==
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmlld3BvcnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wYWNrYWdlcy9wbGFpdC9zcmMvaW50ZXJmYWNlcy92aWV3cG9ydC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQWdCcEQsTUFBTSxDQUFDLE1BQU0sUUFBUSxHQUFzQjtJQUN2QyxVQUFVLEVBQUUsQ0FBQyxLQUFVLEVBQXFCLEVBQUU7UUFDMUMsT0FBTyxDQUFDLGlCQUFpQixDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGlCQUFpQixDQUFDLEtBQUssQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQ3BJLENBQUM7Q0FDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgaXNOdWxsT3JVbmRlZmluZWQgfSBmcm9tICcuLi91dGlscy9oZWxwZXInO1xuaW1wb3J0IHsgRXh0ZW5kZWRUeXBlIH0gZnJvbSAnLi9jdXN0b20tdHlwZXMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEJhc2VWaWV3cG9ydCB7XG4gICAgW2tleTogc3RyaW5nXTogYW55O1xuICAgIHpvb206IG51bWJlcjtcbiAgICB2aWV3QmFja2dyb3VuZENvbG9yOiBzdHJpbmc7XG4gICAgY2FudmFzUG9pbnQ6IG51bWJlcltdO1xufVxuXG5leHBvcnQgdHlwZSBWaWV3cG9ydCA9IEV4dGVuZGVkVHlwZTwnVmlld3BvcnQnLCBCYXNlVmlld3BvcnQ+O1xuXG5leHBvcnQgaW50ZXJmYWNlIFZpZXdwb3J0SW50ZXJmYWNlIHtcbiAgICBpc1ZpZXdwb3J0OiAodmFsdWU6IGFueSkgPT4gdmFsdWUgaXMgVmlld3BvcnQ7XG59XG5cbmV4cG9ydCBjb25zdCBWaWV3cG9ydDogVmlld3BvcnRJbnRlcmZhY2UgPSB7XG4gICAgaXNWaWV3cG9ydDogKHZhbHVlOiBhbnkpOiB2YWx1ZSBpcyBWaWV3cG9ydCA9PiB7XG4gICAgICAgIHJldHVybiAhaXNOdWxsT3JVbmRlZmluZWQodmFsdWUuem9vbSkgJiYgIWlzTnVsbE9yVW5kZWZpbmVkKHZhbHVlLnZpZXdCYWNrZ3JvdW5kQ29sb3IpICYmICFpc051bGxPclVuZGVmaW5lZCh2YWx1ZS5jYW52YXNQb2ludCk7XG4gICAgfVxufTtcbiJdfQ==
@@ -5,10 +5,9 @@ export function createBoard(host, children, options) {
5
5
  const board = {
6
6
  host,
7
7
  viewport: {
8
- offsetXRatio: 0.5,
9
- offsetYRatio: 0.5,
10
8
  zoom: 1,
11
- viewBackgroundColor: '#000'
9
+ viewBackgroundColor: '#000',
10
+ canvasPoint: []
12
11
  },
13
12
  children,
14
13
  operations: [],
@@ -53,4 +52,4 @@ export function createBoard(host, children, options) {
53
52
  };
54
53
  return board;
55
54
  }
56
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLWJvYXJkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvcGxhaXQvc3JjL3BsdWdpbnMvY3JlYXRlLWJvYXJkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBSXhELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBRTlDLE1BQU0sVUFBVSxXQUFXLENBQUMsSUFBZ0IsRUFBRSxRQUF3QixFQUFFLE9BQTBCO0lBQzlGLE1BQU0sS0FBSyxHQUFlO1FBQ3RCLElBQUk7UUFDSixRQUFRLEVBQUU7WUFDTixZQUFZLEVBQUUsR0FBRztZQUNqQixZQUFZLEVBQUUsR0FBRztZQUNqQixJQUFJLEVBQUUsQ0FBQztZQUNQLG1CQUFtQixFQUFFLE1BQU07U0FDOUI7UUFDRCxRQUFRO1FBQ1IsVUFBVSxFQUFFLEVBQUU7UUFDZCxPQUFPLEVBQUU7WUFDTCxLQUFLLEVBQUUsRUFBRTtZQUNULEtBQUssRUFBRSxFQUFFO1NBQ1o7UUFDRCxTQUFTLEVBQUUsSUFBSTtRQUNmLE1BQU0sRUFBRSxnQkFBZ0IsQ0FBQyxNQUFNO1FBQy9CLE9BQU8sRUFBRSxPQUFPLElBQUk7WUFDaEIsUUFBUSxFQUFFLEtBQUs7WUFDZixlQUFlLEVBQUUsS0FBSztZQUN0QixhQUFhLEVBQUUsS0FBSztTQUN2QjtRQUNELElBQUksRUFBRSxHQUFHLEVBQUUsR0FBRSxDQUFDO1FBQ2QsSUFBSSxFQUFFLEdBQUcsRUFBRSxHQUFFLENBQUM7UUFDZCxLQUFLLEVBQUUsQ0FBQyxTQUF5QixFQUFFLEVBQUU7WUFDakMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7WUFFakMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxLQUFLLEVBQUUsU0FBUyxDQUFDLENBQUM7WUFFdkMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLEVBQUU7Z0JBQ3RCLFFBQVEsQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxDQUFDO2dCQUUxQixPQUFPLENBQUMsT0FBTyxFQUFFLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRTtvQkFDeEIsUUFBUSxDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLENBQUM7b0JBQzNCLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztvQkFDakIsS0FBSyxDQUFDLFVBQVUsR0FBRyxFQUFFLENBQUM7Z0JBQzFCLENBQUMsQ0FBQyxDQUFDO2FBQ047UUFDTCxDQUFDO1FBQ0QsUUFBUSxFQUFFLEdBQUcsRUFBRSxHQUFFLENBQUM7UUFDbEIsU0FBUyxFQUFFLENBQUMsS0FBaUIsRUFBRSxFQUFFLEdBQUUsQ0FBQztRQUNwQyxhQUFhLEVBQUUsQ0FBQyxLQUFpQixFQUFFLEVBQUUsR0FBRSxDQUFDO1FBQ3hDLFNBQVMsRUFBRSxDQUFDLEtBQWlCLEVBQUUsRUFBRSxHQUFFLENBQUM7UUFDcEMsT0FBTyxFQUFFLENBQUMsS0FBb0IsRUFBRSxFQUFFLEdBQUUsQ0FBQztRQUNyQyxLQUFLLEVBQUUsQ0FBQyxLQUFvQixFQUFFLEVBQUUsR0FBRSxDQUFDO1FBQ25DLFFBQVEsRUFBRSxDQUFDLEtBQWlCLEVBQUUsRUFBRSxHQUFFLENBQUM7UUFDbkMsV0FBVyxFQUFFLENBQUMsSUFBeUIsRUFBRSxFQUFFLEdBQUUsQ0FBQztRQUM5QyxjQUFjLEVBQUUsQ0FBQyxJQUF5QixFQUFFLEVBQUUsR0FBRSxDQUFDO1FBQ2pELGNBQWMsRUFBRSxDQUFDLElBQXlCLEVBQUUsRUFBRSxHQUFFLENBQUM7UUFDakQsV0FBVyxFQUFFLENBQUMsT0FBNEIsRUFBRSxFQUFFLENBQUMsRUFBRTtRQUNqRCxhQUFhLEVBQUUsQ0FBQyxPQUE0QixFQUFFLE9BQXNCLEVBQUUsRUFBRSxDQUFDLEVBQUU7UUFDM0UsY0FBYyxFQUFFLEdBQUcsRUFBRSxHQUFFLENBQUM7S0FDM0IsQ0FBQztJQUNGLE9BQU8sS0FBSyxDQUFDO0FBQ2pCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTaW1wbGVDaGFuZ2VzIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBQbGFpdEJvYXJkLCBQbGFpdEJvYXJkT3B0aW9ucyB9IGZyb20gJy4uL2ludGVyZmFjZXMvYm9hcmQnO1xuaW1wb3J0IHsgQmFzZUN1cnNvclN0YXR1cyB9IGZyb20gJy4uL2ludGVyZmFjZXMvY3Vyc29yJztcbmltcG9ydCB7IFBsYWl0RWxlbWVudCB9IGZyb20gJy4uL2ludGVyZmFjZXMvZWxlbWVudCc7XG5pbXBvcnQgeyBQbGFpdEVsZW1lbnRDb250ZXh0IH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9lbGVtZW50LWNvbnRleHQnO1xuaW1wb3J0IHsgUGxhaXRPcGVyYXRpb24gfSBmcm9tICcuLi9pbnRlcmZhY2VzL29wZXJhdGlvbic7XG5pbXBvcnQgeyBUcmFuc2Zvcm1zIH0gZnJvbSAnLi4vdHJhbnNmb3Jtcyc7XG5pbXBvcnQgeyBGTFVTSElORyB9IGZyb20gJy4uL3V0aWxzL3dlYWstbWFwcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVCb2FyZChob3N0OiBTVkdFbGVtZW50LCBjaGlsZHJlbjogUGxhaXRFbGVtZW50W10sIG9wdGlvbnM6IFBsYWl0Qm9hcmRPcHRpb25zKTogUGxhaXRCb2FyZCB7XG4gICAgY29uc3QgYm9hcmQ6IFBsYWl0Qm9hcmQgPSB7XG4gICAgICAgIGhvc3QsXG4gICAgICAgIHZpZXdwb3J0OiB7XG4gICAgICAgICAgICBvZmZzZXRYUmF0aW86IDAuNSxcbiAgICAgICAgICAgIG9mZnNldFlSYXRpbzogMC41LFxuICAgICAgICAgICAgem9vbTogMSxcbiAgICAgICAgICAgIHZpZXdCYWNrZ3JvdW5kQ29sb3I6ICcjMDAwJ1xuICAgICAgICB9LFxuICAgICAgICBjaGlsZHJlbixcbiAgICAgICAgb3BlcmF0aW9uczogW10sXG4gICAgICAgIGhpc3Rvcnk6IHtcbiAgICAgICAgICAgIHJlZG9zOiBbXSxcbiAgICAgICAgICAgIHVuZG9zOiBbXVxuICAgICAgICB9LFxuICAgICAgICBzZWxlY3Rpb246IG51bGwsXG4gICAgICAgIGN1cnNvcjogQmFzZUN1cnNvclN0YXR1cy5zZWxlY3QsXG4gICAgICAgIG9wdGlvbnM6IG9wdGlvbnMgfHwge1xuICAgICAgICAgICAgcmVhZG9ubHk6IGZhbHNlLFxuICAgICAgICAgICAgYWxsb3dDbGVhckJvYXJkOiBmYWxzZSxcbiAgICAgICAgICAgIGhpZGVTY3JvbGxiYXI6IGZhbHNlXG4gICAgICAgIH0sXG4gICAgICAgIHVuZG86ICgpID0+IHt9LFxuICAgICAgICByZWRvOiAoKSA9PiB7fSxcbiAgICAgICAgYXBwbHk6IChvcGVyYXRpb246IFBsYWl0T3BlcmF0aW9uKSA9PiB7XG4gICAgICAgICAgICBib2FyZC5vcGVyYXRpb25zLnB1c2gob3BlcmF0aW9uKTtcblxuICAgICAgICAgICAgVHJhbnNmb3Jtcy50cmFuc2Zvcm0oYm9hcmQsIG9wZXJhdGlvbik7XG5cbiAgICAgICAgICAgIGlmICghRkxVU0hJTkcuZ2V0KGJvYXJkKSkge1xuICAgICAgICAgICAgICAgIEZMVVNISU5HLnNldChib2FyZCwgdHJ1ZSk7XG5cbiAgICAgICAgICAgICAgICBQcm9taXNlLnJlc29sdmUoKS50aGVuKCgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgRkxVU0hJTkcuc2V0KGJvYXJkLCBmYWxzZSk7XG4gICAgICAgICAgICAgICAgICAgIGJvYXJkLm9uQ2hhbmdlKCk7XG4gICAgICAgICAgICAgICAgICAgIGJvYXJkLm9wZXJhdGlvbnMgPSBbXTtcbiAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSxcbiAgICAgICAgb25DaGFuZ2U6ICgpID0+IHt9LFxuICAgICAgICBtb3VzZWRvd246IChldmVudDogTW91c2VFdmVudCkgPT4ge30sXG4gICAgICAgIGdsb2JhbE1vdXNldXA6IChldmVudDogTW91c2VFdmVudCkgPT4ge30sXG4gICAgICAgIG1vdXNlbW92ZTogKGV2ZW50OiBNb3VzZUV2ZW50KSA9PiB7fSxcbiAgICAgICAga2V5ZG93bjogKGV2ZW50OiBLZXlib2FyZEV2ZW50KSA9PiB7fSxcbiAgICAgICAga2V5dXA6IChldmVudDogS2V5Ym9hcmRFdmVudCkgPT4ge30sXG4gICAgICAgIGRibGNsaWNrOiAoZXZlbnQ6IE1vdXNlRXZlbnQpID0+IHt9LFxuICAgICAgICBzZXRGcmFnbWVudDogKGRhdGE6IERhdGFUcmFuc2ZlciB8IG51bGwpID0+IHt9LFxuICAgICAgICBpbnNlcnRGcmFnbWVudDogKGRhdGE6IERhdGFUcmFuc2ZlciB8IG51bGwpID0+IHt9LFxuICAgICAgICBkZWxldGVGcmFnbWVudDogKGRhdGE6IERhdGFUcmFuc2ZlciB8IG51bGwpID0+IHt9LFxuICAgICAgICBkcmF3RWxlbWVudDogKGNvbnRleHQ6IFBsYWl0RWxlbWVudENvbnRleHQpID0+IFtdLFxuICAgICAgICByZWRyYXdFbGVtZW50OiAoY29udGV4dDogUGxhaXRFbGVtZW50Q29udGV4dCwgY2hhbmdlczogU2ltcGxlQ2hhbmdlcykgPT4gW10sXG4gICAgICAgIGRlc3Ryb3lFbGVtZW50OiAoKSA9PiB7fVxuICAgIH07XG4gICAgcmV0dXJuIGJvYXJkO1xufVxuIl19
55
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3JlYXRlLWJvYXJkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcGFja2FnZXMvcGxhaXQvc3JjL3BsdWdpbnMvY3JlYXRlLWJvYXJkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBSXhELE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBRTlDLE1BQU0sVUFBVSxXQUFXLENBQUMsSUFBZ0IsRUFBRSxRQUF3QixFQUFFLE9BQTBCO0lBQzlGLE1BQU0sS0FBSyxHQUFlO1FBQ3RCLElBQUk7UUFDSixRQUFRLEVBQUU7WUFDTixJQUFJLEVBQUUsQ0FBQztZQUNQLG1CQUFtQixFQUFFLE1BQU07WUFDM0IsV0FBVyxFQUFFLEVBQUU7U0FDbEI7UUFDRCxRQUFRO1FBQ1IsVUFBVSxFQUFFLEVBQUU7UUFDZCxPQUFPLEVBQUU7WUFDTCxLQUFLLEVBQUUsRUFBRTtZQUNULEtBQUssRUFBRSxFQUFFO1NBQ1o7UUFDRCxTQUFTLEVBQUUsSUFBSTtRQUNmLE1BQU0sRUFBRSxnQkFBZ0IsQ0FBQyxNQUFNO1FBQy9CLE9BQU8sRUFBRSxPQUFPLElBQUk7WUFDaEIsUUFBUSxFQUFFLEtBQUs7WUFDZixlQUFlLEVBQUUsS0FBSztZQUN0QixhQUFhLEVBQUUsS0FBSztTQUN2QjtRQUNELElBQUksRUFBRSxHQUFHLEVBQUUsR0FBRSxDQUFDO1FBQ2QsSUFBSSxFQUFFLEdBQUcsRUFBRSxHQUFFLENBQUM7UUFDZCxLQUFLLEVBQUUsQ0FBQyxTQUF5QixFQUFFLEVBQUU7WUFDakMsS0FBSyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7WUFFakMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxLQUFLLEVBQUUsU0FBUyxDQUFDLENBQUM7WUFFdkMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLEVBQUU7Z0JBQ3RCLFFBQVEsQ0FBQyxHQUFHLENBQUMsS0FBSyxFQUFFLElBQUksQ0FBQyxDQUFDO2dCQUUxQixPQUFPLENBQUMsT0FBTyxFQUFFLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRTtvQkFDeEIsUUFBUSxDQUFDLEdBQUcsQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLENBQUM7b0JBQzNCLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztvQkFDakIsS0FBSyxDQUFDLFVBQVUsR0FBRyxFQUFFLENBQUM7Z0JBQzFCLENBQUMsQ0FBQyxDQUFDO2FBQ047UUFDTCxDQUFDO1FBQ0QsUUFBUSxFQUFFLEdBQUcsRUFBRSxHQUFFLENBQUM7UUFDbEIsU0FBUyxFQUFFLENBQUMsS0FBaUIsRUFBRSxFQUFFLEdBQUUsQ0FBQztRQUNwQyxhQUFhLEVBQUUsQ0FBQyxLQUFpQixFQUFFLEVBQUUsR0FBRSxDQUFDO1FBQ3hDLFNBQVMsRUFBRSxDQUFDLEtBQWlCLEVBQUUsRUFBRSxHQUFFLENBQUM7UUFDcEMsT0FBTyxFQUFFLENBQUMsS0FBb0IsRUFBRSxFQUFFLEdBQUUsQ0FBQztRQUNyQyxLQUFLLEVBQUUsQ0FBQyxLQUFvQixFQUFFLEVBQUUsR0FBRSxDQUFDO1FBQ25DLFFBQVEsRUFBRSxDQUFDLEtBQWlCLEVBQUUsRUFBRSxHQUFFLENBQUM7UUFDbkMsV0FBVyxFQUFFLENBQUMsSUFBeUIsRUFBRSxFQUFFLEdBQUUsQ0FBQztRQUM5QyxjQUFjLEVBQUUsQ0FBQyxJQUF5QixFQUFFLEVBQUUsR0FBRSxDQUFDO1FBQ2pELGNBQWMsRUFBRSxDQUFDLElBQXlCLEVBQUUsRUFBRSxHQUFFLENBQUM7UUFDakQsV0FBVyxFQUFFLENBQUMsT0FBNEIsRUFBRSxFQUFFLENBQUMsRUFBRTtRQUNqRCxhQUFhLEVBQUUsQ0FBQyxPQUE0QixFQUFFLE9BQXNCLEVBQUUsRUFBRSxDQUFDLEVBQUU7UUFDM0UsY0FBYyxFQUFFLEdBQUcsRUFBRSxHQUFFLENBQUM7S0FDM0IsQ0FBQztJQUNGLE9BQU8sS0FBSyxDQUFDO0FBQ2pCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTaW1wbGVDaGFuZ2VzIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBQbGFpdEJvYXJkLCBQbGFpdEJvYXJkT3B0aW9ucyB9IGZyb20gJy4uL2ludGVyZmFjZXMvYm9hcmQnO1xuaW1wb3J0IHsgQmFzZUN1cnNvclN0YXR1cyB9IGZyb20gJy4uL2ludGVyZmFjZXMvY3Vyc29yJztcbmltcG9ydCB7IFBsYWl0RWxlbWVudCB9IGZyb20gJy4uL2ludGVyZmFjZXMvZWxlbWVudCc7XG5pbXBvcnQgeyBQbGFpdEVsZW1lbnRDb250ZXh0IH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9lbGVtZW50LWNvbnRleHQnO1xuaW1wb3J0IHsgUGxhaXRPcGVyYXRpb24gfSBmcm9tICcuLi9pbnRlcmZhY2VzL29wZXJhdGlvbic7XG5pbXBvcnQgeyBUcmFuc2Zvcm1zIH0gZnJvbSAnLi4vdHJhbnNmb3Jtcyc7XG5pbXBvcnQgeyBGTFVTSElORyB9IGZyb20gJy4uL3V0aWxzL3dlYWstbWFwcyc7XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVCb2FyZChob3N0OiBTVkdFbGVtZW50LCBjaGlsZHJlbjogUGxhaXRFbGVtZW50W10sIG9wdGlvbnM6IFBsYWl0Qm9hcmRPcHRpb25zKTogUGxhaXRCb2FyZCB7XG4gICAgY29uc3QgYm9hcmQ6IFBsYWl0Qm9hcmQgPSB7XG4gICAgICAgIGhvc3QsXG4gICAgICAgIHZpZXdwb3J0OiB7XG4gICAgICAgICAgICB6b29tOiAxLFxuICAgICAgICAgICAgdmlld0JhY2tncm91bmRDb2xvcjogJyMwMDAnLFxuICAgICAgICAgICAgY2FudmFzUG9pbnQ6IFtdXG4gICAgICAgIH0sXG4gICAgICAgIGNoaWxkcmVuLFxuICAgICAgICBvcGVyYXRpb25zOiBbXSxcbiAgICAgICAgaGlzdG9yeToge1xuICAgICAgICAgICAgcmVkb3M6IFtdLFxuICAgICAgICAgICAgdW5kb3M6IFtdXG4gICAgICAgIH0sXG4gICAgICAgIHNlbGVjdGlvbjogbnVsbCxcbiAgICAgICAgY3Vyc29yOiBCYXNlQ3Vyc29yU3RhdHVzLnNlbGVjdCxcbiAgICAgICAgb3B0aW9uczogb3B0aW9ucyB8fCB7XG4gICAgICAgICAgICByZWFkb25seTogZmFsc2UsXG4gICAgICAgICAgICBhbGxvd0NsZWFyQm9hcmQ6IGZhbHNlLFxuICAgICAgICAgICAgaGlkZVNjcm9sbGJhcjogZmFsc2VcbiAgICAgICAgfSxcbiAgICAgICAgdW5kbzogKCkgPT4ge30sXG4gICAgICAgIHJlZG86ICgpID0+IHt9LFxuICAgICAgICBhcHBseTogKG9wZXJhdGlvbjogUGxhaXRPcGVyYXRpb24pID0+IHtcbiAgICAgICAgICAgIGJvYXJkLm9wZXJhdGlvbnMucHVzaChvcGVyYXRpb24pO1xuXG4gICAgICAgICAgICBUcmFuc2Zvcm1zLnRyYW5zZm9ybShib2FyZCwgb3BlcmF0aW9uKTtcblxuICAgICAgICAgICAgaWYgKCFGTFVTSElORy5nZXQoYm9hcmQpKSB7XG4gICAgICAgICAgICAgICAgRkxVU0hJTkcuc2V0KGJvYXJkLCB0cnVlKTtcblxuICAgICAgICAgICAgICAgIFByb21pc2UucmVzb2x2ZSgpLnRoZW4oKCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICBGTFVTSElORy5zZXQoYm9hcmQsIGZhbHNlKTtcbiAgICAgICAgICAgICAgICAgICAgYm9hcmQub25DaGFuZ2UoKTtcbiAgICAgICAgICAgICAgICAgICAgYm9hcmQub3BlcmF0aW9ucyA9IFtdO1xuICAgICAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgfVxuICAgICAgICB9LFxuICAgICAgICBvbkNoYW5nZTogKCkgPT4ge30sXG4gICAgICAgIG1vdXNlZG93bjogKGV2ZW50OiBNb3VzZUV2ZW50KSA9PiB7fSxcbiAgICAgICAgZ2xvYmFsTW91c2V1cDogKGV2ZW50OiBNb3VzZUV2ZW50KSA9PiB7fSxcbiAgICAgICAgbW91c2Vtb3ZlOiAoZXZlbnQ6IE1vdXNlRXZlbnQpID0+IHt9LFxuICAgICAgICBrZXlkb3duOiAoZXZlbnQ6IEtleWJvYXJkRXZlbnQpID0+IHt9LFxuICAgICAgICBrZXl1cDogKGV2ZW50OiBLZXlib2FyZEV2ZW50KSA9PiB7fSxcbiAgICAgICAgZGJsY2xpY2s6IChldmVudDogTW91c2VFdmVudCkgPT4ge30sXG4gICAgICAgIHNldEZyYWdtZW50OiAoZGF0YTogRGF0YVRyYW5zZmVyIHwgbnVsbCkgPT4ge30sXG4gICAgICAgIGluc2VydEZyYWdtZW50OiAoZGF0YTogRGF0YVRyYW5zZmVyIHwgbnVsbCkgPT4ge30sXG4gICAgICAgIGRlbGV0ZUZyYWdtZW50OiAoZGF0YTogRGF0YVRyYW5zZmVyIHwgbnVsbCkgPT4ge30sXG4gICAgICAgIGRyYXdFbGVtZW50OiAoY29udGV4dDogUGxhaXRFbGVtZW50Q29udGV4dCkgPT4gW10sXG4gICAgICAgIHJlZHJhd0VsZW1lbnQ6IChjb250ZXh0OiBQbGFpdEVsZW1lbnRDb250ZXh0LCBjaGFuZ2VzOiBTaW1wbGVDaGFuZ2VzKSA9PiBbXSxcbiAgICAgICAgZGVzdHJveUVsZW1lbnQ6ICgpID0+IHt9XG4gICAgfTtcbiAgICByZXR1cm4gYm9hcmQ7XG59XG4iXX0=
@@ -17,35 +17,80 @@ export function invert(oldMatrix, newMatrix) {
17
17
  : null;
18
18
  }
19
19
  export function transformMat3(e, t, n) {
20
- const r = t[0];
21
- const a = t[1];
22
- const i = t[2];
23
- return (e[0] = r * n[0] + a * n[3] + i * n[6]), (e[1] = r * n[1] + a * n[4] + i * n[7]), (e[2] = r * n[2] + a * n[5] + i * n[8]), e;
20
+ e = [t[0] * n[0] + t[1] * n[3] + t[2] * n[6], t[0] * n[1] + t[1] * n[4] + t[2] * n[7], t[0] * n[2] + t[1] * n[5] + t[2] * n[8]];
21
+ return e;
22
+ }
23
+ export function convertPoint(arr) {
24
+ return Array.isArray(arr)
25
+ ? {
26
+ x: arr[0],
27
+ y: arr[1]
28
+ }
29
+ : arr;
30
+ }
31
+ export function invertClient(board, point, matrix) {
32
+ const convert = convertPoint(point);
33
+ const clientBox = getViewportClientBox(board);
34
+ const newPoint = [convert.x - clientBox.x, convert.y - clientBox.y, 1];
35
+ const invertMatrix = invert([], matrix);
36
+ const newMatrix = transformMat3([], [newPoint[0], newPoint[1], 1], invertMatrix);
37
+ return [newMatrix[0], newMatrix[1]];
38
+ }
39
+ export function invertViewport(point, matrix) {
40
+ const newPoint = convertPoint(point);
41
+ const invertMatrix = invert([], matrix);
42
+ return transformMat3([], [newPoint.x, newPoint.y, 1], invertMatrix);
43
+ }
44
+ export function convertViewport(point, matrix) {
45
+ const newPoint = convertPoint(point);
46
+ return transformMat3([], [newPoint.x, newPoint.y, 1], matrix);
47
+ }
48
+ export function getViewportCanvasBox(board, matrix) {
49
+ const clientBox = getViewportClientBox(board);
50
+ const client = invertClient(board, [clientBox.minX, clientBox.minY], matrix);
51
+ const newClient = invertClient(board, [clientBox.maxX, clientBox.maxY], matrix);
52
+ return {
53
+ minX: client[0],
54
+ minY: client[1],
55
+ maxX: newClient[0],
56
+ maxY: newClient[1],
57
+ x: client[0],
58
+ y: client[1],
59
+ width: newClient[0] - client[0],
60
+ height: newClient[1] - client[1]
61
+ };
24
62
  }
25
63
  export function getViewportClientBox(board) {
26
- const hideScrollbar = board.options.hideScrollbar;
27
- const scrollBarWidth = hideScrollbar ? SCROLL_BAR_WIDTH : 0;
28
64
  const container = board.host?.parentElement;
29
65
  const containerRect = container?.getBoundingClientRect();
30
- const width = containerRect.width - scrollBarWidth;
31
- const height = containerRect.height - scrollBarWidth;
32
66
  const x = containerRect.x || containerRect.left;
33
67
  const y = containerRect.y || containerRect.top;
68
+ const width = containerRect.width - SCROLL_BAR_WIDTH;
69
+ const height = containerRect.height - SCROLL_BAR_WIDTH;
34
70
  return {
35
- width,
36
- height,
71
+ minX: x,
72
+ minY: y,
73
+ maxX: x + width,
74
+ maxY: y + height,
37
75
  x,
38
- y
76
+ y,
77
+ width,
78
+ height
39
79
  };
40
80
  }
41
- export function calculateBBox(board) {
42
- const viewportBox = getViewportClientBox(board);
81
+ export function getGraphicsBBox(board) {
82
+ const rootGroup = board.host.firstChild;
83
+ const rootGroupBox = rootGroup.getBBox();
84
+ return rootGroupBox;
85
+ }
86
+ export function calculateBBox(board, zoom) {
87
+ const boardComponent = PLAIT_BOARD_TO_COMPONENT.get(board);
88
+ // const clientBox = getViewportClientBox(board);
43
89
  const rootGroup = board.host.firstChild;
44
- const zoom = board.viewport.zoom;
45
90
  const rootGroupBox = rootGroup.getBBox();
46
91
  let box = {};
47
- const containerWidth = viewportBox.width / zoom;
48
- const containerHeight = viewportBox.height / zoom;
92
+ const containerWidth = boardComponent.width / zoom;
93
+ const containerHeight = boardComponent.height / zoom;
49
94
  if (rootGroupBox.width < containerWidth) {
50
95
  const offsetX = rootGroupBox.x + rootGroupBox.width / 2;
51
96
  const containerX = containerWidth / 2;
@@ -69,38 +114,4 @@ export function calculateBBox(board) {
69
114
  // 在新的缩放比容器宽高下的内容盒子位置
70
115
  return box;
71
116
  }
72
- export function getViewBox(board) {
73
- const viewportBox = getViewportClientBox(board);
74
- const rootGroupBBox = calculateBBox(board);
75
- const padding = [viewportBox.height / 2, viewportBox.width / 2];
76
- const zoom = board.viewport.zoom;
77
- const minX = rootGroupBBox.left - padding[1] / zoom;
78
- const minY = rootGroupBBox.top - padding[0] / zoom;
79
- const viewportWidth = (rootGroupBBox.right - rootGroupBBox.left) * zoom + 2 * padding[1];
80
- const viewportHeight = (rootGroupBBox.bottom - rootGroupBBox.top) * zoom + 2 * padding[0];
81
- const width = viewportWidth / zoom;
82
- const height = viewportHeight / zoom;
83
- return { minX, minY, width, height, viewportWidth, viewportHeight };
84
- }
85
- export function isOutExtent(board, node, gap) {
86
- const result = { x: 0, y: 0 };
87
- if (!node)
88
- return result;
89
- const boardComponent = PLAIT_BOARD_TO_COMPONENT.get(board);
90
- const scrollBarWidth = board.options.hideScrollbar ? SCROLL_BAR_WIDTH : 0;
91
- const canvasRect = boardComponent.contentContainer.nativeElement.getBoundingClientRect();
92
- if (node.left < canvasRect.left + gap) {
93
- result.x = canvasRect.left - node.left - gap;
94
- }
95
- else if (node.right > canvasRect.right - scrollBarWidth - gap) {
96
- result.x = canvasRect.right - scrollBarWidth - gap - node.right - node.width;
97
- }
98
- if (node.top < canvasRect.top + gap) {
99
- result.y = canvasRect.top - node.top - gap;
100
- }
101
- else if (node.bottom > canvasRect.bottom - scrollBarWidth - gap) {
102
- result.y = canvasRect.bottom - scrollBarWidth - gap - node.bottom - node.height;
103
- }
104
- return result;
105
- }
106
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"matrix.js","sourceRoot":"","sources":["../../../../packages/plait/src/utils/matrix.ts"],"names":[],"mappings":"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","sourcesContent":["import { SCROLL_BAR_WIDTH } from '../constants';\nimport { PlaitBoard } from '../interfaces';\nimport { ViewBox } from './board';\nimport { PLAIT_BOARD_TO_COMPONENT } from './weak-maps';\n\nexport function invert(oldMatrix: number[], newMatrix: number[]) {\n    let n = newMatrix[0],\n        r = newMatrix[1],\n        a = newMatrix[2],\n        i = newMatrix[3],\n        o = newMatrix[4],\n        c = newMatrix[5],\n        l = newMatrix[6],\n        s = newMatrix[7],\n        u = newMatrix[8],\n        d = u * o - c * s,\n        h = -u * i + c * l,\n        f = s * i - o * l,\n        p = n * d + r * h + a * f;\n\n    return p\n        ? ((p = 1 / p),\n          (oldMatrix[0] = d * p),\n          (oldMatrix[1] = (-u * r + a * s) * p),\n          (oldMatrix[2] = (c * r - a * o) * p),\n          (oldMatrix[3] = h * p),\n          (oldMatrix[4] = (u * n - a * l) * p),\n          (oldMatrix[5] = (-c * n + a * i) * p),\n          (oldMatrix[6] = f * p),\n          (oldMatrix[7] = (-s * n + r * l) * p),\n          (oldMatrix[8] = (o * n - r * i) * p),\n          oldMatrix)\n        : null;\n}\n\nexport function transformMat3(e: number[], t: number[], n: number[]) {\n    const r = t[0];\n    const a = t[1];\n    const i = t[2];\n\n    return (e[0] = r * n[0] + a * n[3] + i * n[6]), (e[1] = r * n[1] + a * n[4] + i * n[7]), (e[2] = r * n[2] + a * n[5] + i * n[8]), e;\n}\n\nexport function getViewportClientBox(board: PlaitBoard) {\n    const hideScrollbar = board.options.hideScrollbar;\n    const scrollBarWidth = hideScrollbar ? SCROLL_BAR_WIDTH : 0;\n    const container = board.host?.parentElement as HTMLElement;\n    const containerRect = container?.getBoundingClientRect();\n    const width = containerRect.width - scrollBarWidth;\n    const height = containerRect.height - scrollBarWidth;\n    const x = containerRect.x || containerRect.left;\n    const y = containerRect.y || containerRect.top;\n\n    return {\n        width,\n        height,\n        x,\n        y\n    };\n}\n\nexport function calculateBBox(board: PlaitBoard) {\n    const viewportBox = getViewportClientBox(board);\n    const rootGroup = board.host.firstChild;\n    const zoom = board.viewport.zoom;\n    const rootGroupBox = (rootGroup as SVGGraphicsElement).getBBox();\n\n    let box = {} as any;\n    const containerWidth = viewportBox.width / zoom;\n    const containerHeight = viewportBox.height / zoom;\n\n    if (rootGroupBox.width < containerWidth) {\n        const offsetX = rootGroupBox.x + rootGroupBox.width / 2;\n        const containerX = containerWidth / 2;\n        box.left = offsetX - containerX;\n        box.right = offsetX + containerX;\n    } else {\n        box.left = rootGroupBox.x;\n        box.right = rootGroupBox.x + rootGroupBox.width;\n    }\n\n    if (rootGroupBox.height < containerHeight) {\n        const offsetY = rootGroupBox.y + rootGroupBox.height / 2;\n        const containerY = containerHeight / 2;\n        box.top = offsetY - containerY;\n        box.bottom = offsetY + containerY;\n    } else {\n        box.top = rootGroupBox.y;\n        box.bottom = rootGroupBox.y + rootGroupBox.height;\n    }\n\n    // 在新的缩放比容器宽高下的内容盒子位置\n    return box;\n}\n\nexport function getViewBox(board: PlaitBoard): ViewBox {\n    const viewportBox = getViewportClientBox(board);\n    const rootGroupBBox = calculateBBox(board);\n    const padding = [viewportBox.height / 2, viewportBox.width / 2];\n    const zoom = board.viewport.zoom;\n    const minX = rootGroupBBox.left - padding[1] / zoom;\n    const minY = rootGroupBBox.top - padding[0] / zoom;\n    const viewportWidth = (rootGroupBBox.right - rootGroupBBox.left) * zoom + 2 * padding[1];\n    const viewportHeight = (rootGroupBBox.bottom - rootGroupBBox.top) * zoom + 2 * padding[0];\n    const width = viewportWidth / zoom;\n    const height = viewportHeight / zoom;\n\n    return { minX, minY, width, height, viewportWidth, viewportHeight };\n}\n\nexport function isOutExtent(board: PlaitBoard, node: DOMRect, gap: number): { x: number; y: number } {\n    const result = { x: 0, y: 0 };\n\n    if (!node) return result;\n\n    const boardComponent = PLAIT_BOARD_TO_COMPONENT.get(board);\n    const scrollBarWidth = board.options.hideScrollbar ? SCROLL_BAR_WIDTH : 0;\n    const canvasRect = boardComponent!.contentContainer.nativeElement.getBoundingClientRect();\n\n    if (node.left < canvasRect.left + gap) {\n        result.x = canvasRect.left - node.left - gap;\n    } else if (node.right > canvasRect.right - scrollBarWidth - gap) {\n        result.x = canvasRect.right - scrollBarWidth - gap - node.right - node.width;\n    }\n\n    if (node.top < canvasRect.top + gap) {\n        result.y = canvasRect.top - node.top - gap;\n    } else if (node.bottom > canvasRect.bottom - scrollBarWidth - gap) {\n        result.y = canvasRect.bottom - scrollBarWidth - gap - node.bottom - node.height;\n    }\n    return result;\n}\n"]}
117
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"matrix.js","sourceRoot":"","sources":["../../../../packages/plait/src/utils/matrix.ts"],"names":[],"mappings":"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","sourcesContent":["import { SCROLL_BAR_WIDTH } from '../constants';\nimport { PlaitBoard } from '../interfaces';\nimport { PLAIT_BOARD_TO_COMPONENT } from './weak-maps';\n\nexport function invert(oldMatrix: number[], newMatrix: number[]) {\n    let n = newMatrix[0],\n        r = newMatrix[1],\n        a = newMatrix[2],\n        i = newMatrix[3],\n        o = newMatrix[4],\n        c = newMatrix[5],\n        l = newMatrix[6],\n        s = newMatrix[7],\n        u = newMatrix[8],\n        d = u * o - c * s,\n        h = -u * i + c * l,\n        f = s * i - o * l,\n        p = n * d + r * h + a * f;\n\n    return p\n        ? ((p = 1 / p),\n          (oldMatrix[0] = d * p),\n          (oldMatrix[1] = (-u * r + a * s) * p),\n          (oldMatrix[2] = (c * r - a * o) * p),\n          (oldMatrix[3] = h * p),\n          (oldMatrix[4] = (u * n - a * l) * p),\n          (oldMatrix[5] = (-c * n + a * i) * p),\n          (oldMatrix[6] = f * p),\n          (oldMatrix[7] = (-s * n + r * l) * p),\n          (oldMatrix[8] = (o * n - r * i) * p),\n          oldMatrix)\n        : null;\n}\n\nexport function transformMat3(e: number[], t: number[], n: number[]) {\n    e = [t[0] * n[0] + t[1] * n[3] + t[2] * n[6], t[0] * n[1] + t[1] * n[4] + t[2] * n[7], t[0] * n[2] + t[1] * n[5] + t[2] * n[8]];\n    return e;\n}\n\nexport function convertPoint(arr: number[]) {\n    return Array.isArray(arr)\n        ? {\n              x: arr[0],\n              y: arr[1]\n          }\n        : arr;\n}\n\nexport function invertClient(board: PlaitBoard, point: number[], matrix: number[]) {\n    const convert = convertPoint(point);\n    const clientBox = getViewportClientBox(board);\n    const newPoint = [convert.x - clientBox.x, convert.y - clientBox.y, 1];\n    const invertMatrix = invert([], matrix);\n    const newMatrix = transformMat3([], [newPoint[0], newPoint[1], 1], invertMatrix as []);\n\n    return [newMatrix[0], newMatrix[1]];\n}\n\nexport function invertViewport(point: number[], matrix: number[]) {\n    const newPoint = convertPoint(point);\n    const invertMatrix = invert([], matrix);\n    return transformMat3([], [newPoint.x, newPoint.y, 1], invertMatrix as []);\n}\n\nexport function convertViewport(point: number[], matrix: number[]) {\n    const newPoint = convertPoint(point);\n    return transformMat3([], [newPoint.x, newPoint.y, 1], matrix);\n}\n\nexport function getViewportCanvasBox(board: PlaitBoard, matrix: number[]) {\n    const clientBox = getViewportClientBox(board);\n    const client = invertClient(board, [clientBox.minX, clientBox.minY], matrix);\n    const newClient = invertClient(board, [clientBox.maxX, clientBox.maxY], matrix);\n\n    return {\n        minX: client[0],\n        minY: client[1],\n        maxX: newClient[0],\n        maxY: newClient[1],\n        x: client[0],\n        y: client[1],\n        width: newClient[0] - client[0],\n        height: newClient[1] - client[1]\n    };\n}\n\nexport function getViewportClientBox(board: PlaitBoard) {\n    const container = board.host?.parentElement as HTMLElement;\n    const containerRect = container?.getBoundingClientRect();\n    const x = containerRect.x || containerRect.left;\n    const y = containerRect.y || containerRect.top;\n    const width = containerRect.width - SCROLL_BAR_WIDTH;\n    const height = containerRect.height - SCROLL_BAR_WIDTH;\n\n    return {\n        minX: x,\n        minY: y,\n        maxX: x + width,\n        maxY: y + height,\n        x,\n        y,\n        width,\n        height\n    };\n}\n\nexport function getGraphicsBBox(board: PlaitBoard) {\n    const rootGroup = board.host.firstChild;\n    const rootGroupBox = (rootGroup as SVGGraphicsElement).getBBox();\n    return rootGroupBox;\n}\n\nexport function calculateBBox(board: PlaitBoard, zoom: number) {\n    const boardComponent = PLAIT_BOARD_TO_COMPONENT.get(board);\n    // const clientBox = getViewportClientBox(board);\n    const rootGroup = board.host.firstChild;\n    const rootGroupBox = (rootGroup as SVGGraphicsElement).getBBox();\n\n    let box = {} as any;\n    const containerWidth = boardComponent!.width / zoom;\n    const containerHeight = boardComponent!.height / zoom;\n\n    if (rootGroupBox.width < containerWidth) {\n        const offsetX = rootGroupBox.x + rootGroupBox.width / 2;\n        const containerX = containerWidth / 2;\n        box.left = offsetX - containerX;\n        box.right = offsetX + containerX;\n    } else {\n        box.left = rootGroupBox.x;\n        box.right = rootGroupBox.x + rootGroupBox.width;\n    }\n\n    if (rootGroupBox.height < containerHeight) {\n        const offsetY = rootGroupBox.y + rootGroupBox.height / 2;\n        const containerY = containerHeight / 2;\n        box.top = offsetY - containerY;\n        box.bottom = offsetY + containerY;\n    } else {\n        box.top = rootGroupBox.y;\n        box.bottom = rootGroupBox.y + rootGroupBox.height;\n    }\n\n    // 在新的缩放比容器宽高下的内容盒子位置\n    return box;\n}\n"]}