UNPKG

@antv/x6

Version:

JavaScript diagramming library that uses SVG and HTML for rendering

136 lines 4.42 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.GridManager = void 0; const tslib_1 = require("tslib"); const common_1 = require("../common"); const registry_1 = require("../registry"); const base_1 = require("./base"); class GridManager extends base_1.Base { get elem() { return this.view.grid; } get grid() { return this.options.grid; } init() { this.startListening(); this.draw(this.grid); } startListening() { this.graph.on('scale', this.update, this); this.graph.on('translate', this.update, this); } stopListening() { this.graph.off('scale', this.update, this); this.graph.off('translate', this.update, this); } setVisible(visible) { if (this.grid.visible !== visible) { this.grid.visible = visible; this.update(); } } getGridSize() { return this.grid.size; } setGridSize(size) { this.grid.size = Math.max(size, 1); this.update(); } show() { this.setVisible(true); this.update(); } hide() { this.setVisible(false); this.update(); } clear() { this.elem.style.backgroundImage = ''; } draw(options) { this.clear(); this.instance = null; Object.assign(this.grid, options); this.patterns = this.resolveGrid(options); this.update(); } update(options = {}) { const gridSize = this.grid.size; if (gridSize <= 1 || !this.grid.visible) { return this.clear(); } const ctm = this.graph.matrix(); const grid = this.getInstance(); const items = Array.isArray(options) ? options : [options]; this.patterns.forEach((settings, index) => { const id = `pattern_${index}`; const sx = ctm.a || 1; const sy = ctm.d || 1; const { update, markup } = settings, others = tslib_1.__rest(settings, ["update", "markup"]); const options = Object.assign(Object.assign(Object.assign({}, others), items[index]), { sx, sy, ox: ctm.e || 0, oy: ctm.f || 0, width: gridSize * sx, height: gridSize * sy }); if (!grid.has(id)) { grid.add(id, common_1.Vector.create('pattern', { id, patternUnits: 'userSpaceOnUse' }, common_1.Vector.createVectors(markup)).node); } const patternElem = grid.get(id); if (typeof update === 'function') { update(patternElem.childNodes[0], options); } let x = options.ox % options.width; if (x < 0) { x += options.width; } let y = options.oy % options.height; if (y < 0) { y += options.height; } common_1.Dom.attr(patternElem, { x, y, width: options.width, height: options.height, }); }); const base64 = new XMLSerializer().serializeToString(grid.root); const url = `url(data:image/svg+xml;base64,${btoa(base64)})`; this.elem.style.backgroundImage = url; } getInstance() { if (!this.instance) { this.instance = new registry_1.Grid(); } return this.instance; } resolveGrid(options) { if (!options) { return []; } const type = options.type; if (type == null) { return [ Object.assign(Object.assign({}, registry_1.gridPresets.dot), options.args), ]; } const items = registry_1.gridRegistry.get(type); if (items) { let args = options.args || []; if (!Array.isArray(args)) { args = [args]; } return Array.isArray(items) ? items.map((item, index) => (Object.assign(Object.assign({}, item), args[index]))) : [Object.assign(Object.assign({}, items), args[0])]; } return registry_1.gridRegistry.onNotFound(type); } dispose() { this.stopListening(); this.clear(); } } exports.GridManager = GridManager; tslib_1.__decorate([ (0, common_1.disposable)() ], GridManager.prototype, "dispose", null); //# sourceMappingURL=grid.js.map