From 31be70633511dd1839eb042bf90687ce62db9e01 Mon Sep 17 00:00:00 2001 From: Yue JIN <40021217+kingyue737@users.noreply.github.com> Date: Tue, 9 Jan 2024 10:39:40 +0800 Subject: [PATCH] fix: avoid access document or window in server side (#4101) --- packages/x6-common/src/dom/matrix.ts | 4 ++- packages/x6-common/src/dom/prefix.ts | 2 +- packages/x6-common/src/dom/selection.ts | 2 ++ packages/x6-common/src/dom/text.ts | 3 +- packages/x6-common/src/polyfill/index.ts | 44 +++++++++++++----------- packages/x6/src/util/index.ts | 3 +- 6 files changed, 31 insertions(+), 27 deletions(-) diff --git a/packages/x6-common/src/dom/matrix.ts b/packages/x6-common/src/dom/matrix.ts index d174332027a..c9922a9d7a3 100644 --- a/packages/x6-common/src/dom/matrix.ts +++ b/packages/x6-common/src/dom/matrix.ts @@ -1,7 +1,6 @@ import { PointLike } from '../types' import { createSvgElement } from './elem' -const svgDocument = createSvgElement('svg') as SVGSVGElement const transformRegex = /(\w+)\(([^,)]+),?([^)]+)?\)/gi const transformSeparatorRegex = /[ ,]+/ const transformationListRegex = /^(\w+)\((.*)\)/ @@ -36,6 +35,7 @@ export interface Scale { * @see https://developer.mozilla.org/en/docs/Web/API/SVGPoint */ export function createSVGPoint(x: number, y: number) { + const svgDocument = createSvgElement('svg') as SVGSVGElement const p = svgDocument.createSVGPoint() p.x = x p.y = y @@ -58,6 +58,7 @@ export function createSVGPoint(x: number, y: number) { * @see https://developer.mozilla.org/en/docs/Web/API/SVGMatrix */ export function createSVGMatrix(matrix?: DOMMatrix | MatrixLike | null) { + const svgDocument = createSvgElement('svg') as SVGSVGElement const mat = svgDocument.createSVGMatrix() if (matrix != null) { const source = matrix as any @@ -75,6 +76,7 @@ export function createSVGMatrix(matrix?: DOMMatrix | MatrixLike | null) { * @see https://developer.mozilla.org/en/docs/Web/API/SVGTransform */ export function createSVGTransform(matrix?: DOMMatrix | MatrixLike) { + const svgDocument = createSvgElement('svg') as SVGSVGElement if (matrix != null) { if (!(matrix instanceof DOMMatrix)) { matrix = createSVGMatrix(matrix) // eslint-disable-line diff --git a/packages/x6-common/src/dom/prefix.ts b/packages/x6-common/src/dom/prefix.ts index 9c46c64292c..d2f7a367e9d 100644 --- a/packages/x6-common/src/dom/prefix.ts +++ b/packages/x6-common/src/dom/prefix.ts @@ -5,7 +5,7 @@ function camelize(str: string) { const memoized: { [key: string]: string | null } = {} const prefixes = ['webkit', 'ms', 'moz', 'o'] -const testStyle = document ? document.createElement('div').style : {} +const testStyle = typeof document !== 'undefined' ? document.createElement('div').style : {} function getWithPrefix(name: string) { for (let i = 0; i < prefixes.length; i += 1) { diff --git a/packages/x6-common/src/dom/selection.ts b/packages/x6-common/src/dom/selection.ts index 0c75608cdde..e6f72c42971 100644 --- a/packages/x6-common/src/dom/selection.ts +++ b/packages/x6-common/src/dom/selection.ts @@ -1,4 +1,6 @@ export const clearSelection = (function () { + if (typeof document == 'undefined') + return function () {} const doc = document as any if (doc.selection) { return function () { diff --git a/packages/x6-common/src/dom/text.ts b/packages/x6-common/src/dom/text.ts index 7f0514bb3aa..5c61a9e5d7a 100644 --- a/packages/x6-common/src/dom/text.ts +++ b/packages/x6-common/src/dom/text.ts @@ -7,8 +7,6 @@ import { attr } from './attr' import { Vector } from '../vector' import { createSvgElement, empty } from './elem' -const canvasContext = document.createElement('canvas').getContext('2d')! - function createTextPathNode( attrs: { d?: string; 'xlink:href'?: string }, elem: SVGElement, @@ -374,6 +372,7 @@ export function text( } export function measureText(text: string, styles: any = {}) { + const canvasContext = document.createElement('canvas').getContext('2d')! if (!text) { return { width: 0 } } diff --git a/packages/x6-common/src/polyfill/index.ts b/packages/x6-common/src/polyfill/index.ts index 80c7a090bfc..41f757ced5f 100644 --- a/packages/x6-common/src/polyfill/index.ts +++ b/packages/x6-common/src/polyfill/index.ts @@ -10,27 +10,29 @@ if ( // compatible with ParentNode.append() before chrome 54 // https://github.com/jserz/js_piece/blob/master/DOM/ParentNode/append()/append().md -;(function (arr) { - arr.forEach((item) => { - if (Object.prototype.hasOwnProperty.call(item, 'append')) { - return - } - Object.defineProperty(item, 'append', { - configurable: true, - enumerable: true, - writable: true, - value(...args: any[]) { - const docFrag = document.createDocumentFragment() +if (typeof window !== 'undefined') { + ;(function (arr) { + arr.forEach((item) => { + if (Object.prototype.hasOwnProperty.call(item, 'append')) { + return + } + Object.defineProperty(item, 'append', { + configurable: true, + enumerable: true, + writable: true, + value(...args: any[]) { + const docFrag = document.createDocumentFragment() - args.forEach((arg: any) => { - const isNode = arg instanceof Node - docFrag.appendChild( - isNode ? arg : document.createTextNode(String(arg)), - ) - }) + args.forEach((arg: any) => { + const isNode = arg instanceof Node + docFrag.appendChild( + isNode ? arg : document.createTextNode(String(arg)), + ) + }) - this.appendChild(docFrag) - }, + this.appendChild(docFrag) + }, + }) }) - }) -})([Element.prototype, Document.prototype, DocumentFragment.prototype]) + })([Element.prototype, Document.prototype, DocumentFragment.prototype]) +} \ No newline at end of file diff --git a/packages/x6/src/util/index.ts b/packages/x6/src/util/index.ts index f2ba40164c6..bade8cea8c1 100644 --- a/packages/x6/src/util/index.ts +++ b/packages/x6/src/util/index.ts @@ -10,8 +10,6 @@ import { Dom, PointData, PointLike } from '@antv/x6-common' import { normalize } from '../registry/marker/util' export namespace Util { - const svgDocument = Dom.createSvgElement('svg') as SVGSVGElement - export const normalizeMarker = normalize /** * Transforms point by an SVG transformation represented by `matrix`. @@ -47,6 +45,7 @@ export namespace Util { rect: Rectangle.RectangleLike, matrix: DOMMatrix, ) { + const svgDocument = Dom.createSvgElement('svg') as SVGSVGElement const p = svgDocument.createSVGPoint() p.x = rect.x