123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391 |
- /*
- * Licensed to the Apache Software Foundation (ASF) under one
- * or more contributor license agreements. See the NOTICE file
- * distributed with this work for additional information
- * regarding copyright ownership. The ASF licenses this file
- * to you under the Apache License, Version 2.0 (the
- * "License"); you may not use this file except in compliance
- * with the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing,
- * software distributed under the License is distributed on an
- * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
- * KIND, either express or implied. See the License for the
- * specific language governing permissions and limitations
- * under the License.
- */
- /**
- * AUTO-GENERATED FILE. DO NOT MODIFY.
- */
- /*
- * Licensed to the Apache Software Foundation (ASF) under one
- * or more contributor license agreements. See the NOTICE file
- * distributed with this work for additional information
- * regarding copyright ownership. The ASF licenses this file
- * to you under the Apache License, Version 2.0 (the
- * "License"); you may not use this file except in compliance
- * with the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing,
- * software distributed under the License is distributed on an
- * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
- * KIND, either express or implied. See the License for the
- * specific language governing permissions and limitations
- * under the License.
- */
- import { __extends } from "tslib";
- import * as zrUtil from 'zrender/lib/core/util.js';
- import Displayable from 'zrender/lib/graphic/Displayable.js';
- import * as modelUtil from '../../util/model.js';
- import * as graphicUtil from '../../util/graphic.js';
- import * as layoutUtil from '../../util/layout.js';
- import { parsePercent } from '../../util/number.js';
- import ComponentView from '../../view/Component.js';
- import { getECData } from '../../util/innerStore.js';
- import { isEC4CompatibleStyle, convertFromEC4CompatibleStyle } from '../../util/styleCompat.js';
- import { applyLeaveTransition, applyUpdateTransition, isTransitionAll, updateLeaveTo } from '../../animation/customGraphicTransition.js';
- import { updateProps } from '../../animation/basicTransition.js';
- import { applyKeyframeAnimation, stopPreviousKeyframeAnimationAndRestore } from '../../animation/customGraphicKeyframeAnimation.js';
- var nonShapeGraphicElements = {
- // Reserved but not supported in graphic component.
- path: null,
- compoundPath: null,
- // Supported in graphic component.
- group: graphicUtil.Group,
- image: graphicUtil.Image,
- text: graphicUtil.Text
- };
- export var inner = modelUtil.makeInner();
- // ------------------------
- // View
- // ------------------------
- var GraphicComponentView = /** @class */function (_super) {
- __extends(GraphicComponentView, _super);
- function GraphicComponentView() {
- var _this = _super !== null && _super.apply(this, arguments) || this;
- _this.type = GraphicComponentView.type;
- return _this;
- }
- GraphicComponentView.prototype.init = function () {
- this._elMap = zrUtil.createHashMap();
- };
- GraphicComponentView.prototype.render = function (graphicModel, ecModel, api) {
- // Having leveraged between use cases and algorithm complexity, a very
- // simple layout mechanism is used:
- // The size(width/height) can be determined by itself or its parent (not
- // implemented yet), but can not by its children. (Top-down travel)
- // The location(x/y) can be determined by the bounding rect of itself
- // (can including its descendants or not) and the size of its parent.
- // (Bottom-up travel)
- // When `chart.clear()` or `chart.setOption({...}, true)` with the same id,
- // view will be reused.
- if (graphicModel !== this._lastGraphicModel) {
- this._clear();
- }
- this._lastGraphicModel = graphicModel;
- this._updateElements(graphicModel);
- this._relocate(graphicModel, api);
- };
- /**
- * Update graphic elements.
- */
- GraphicComponentView.prototype._updateElements = function (graphicModel) {
- var elOptionsToUpdate = graphicModel.useElOptionsToUpdate();
- if (!elOptionsToUpdate) {
- return;
- }
- var elMap = this._elMap;
- var rootGroup = this.group;
- var globalZ = graphicModel.get('z');
- var globalZLevel = graphicModel.get('zlevel');
- // Top-down tranverse to assign graphic settings to each elements.
- zrUtil.each(elOptionsToUpdate, function (elOption) {
- var id = modelUtil.convertOptionIdName(elOption.id, null);
- var elExisting = id != null ? elMap.get(id) : null;
- var parentId = modelUtil.convertOptionIdName(elOption.parentId, null);
- var targetElParent = parentId != null ? elMap.get(parentId) : rootGroup;
- var elType = elOption.type;
- var elOptionStyle = elOption.style;
- if (elType === 'text' && elOptionStyle) {
- // In top/bottom mode, textVerticalAlign should not be used, which cause
- // inaccurately locating.
- if (elOption.hv && elOption.hv[1]) {
- elOptionStyle.textVerticalAlign = elOptionStyle.textBaseline = elOptionStyle.verticalAlign = elOptionStyle.align = null;
- }
- }
- var textContentOption = elOption.textContent;
- var textConfig = elOption.textConfig;
- if (elOptionStyle && isEC4CompatibleStyle(elOptionStyle, elType, !!textConfig, !!textContentOption)) {
- var convertResult = convertFromEC4CompatibleStyle(elOptionStyle, elType, true);
- if (!textConfig && convertResult.textConfig) {
- textConfig = elOption.textConfig = convertResult.textConfig;
- }
- if (!textContentOption && convertResult.textContent) {
- textContentOption = convertResult.textContent;
- }
- }
- // Remove unnecessary props to avoid potential problems.
- var elOptionCleaned = getCleanedElOption(elOption);
- // For simple, do not support parent change, otherwise reorder is needed.
- if (process.env.NODE_ENV !== 'production') {
- elExisting && zrUtil.assert(targetElParent === elExisting.parent, 'Changing parent is not supported.');
- }
- var $action = elOption.$action || 'merge';
- var isMerge = $action === 'merge';
- var isReplace = $action === 'replace';
- if (isMerge) {
- var isInit = !elExisting;
- var el_1 = elExisting;
- if (isInit) {
- el_1 = createEl(id, targetElParent, elOption.type, elMap);
- } else {
- el_1 && (inner(el_1).isNew = false);
- // Stop and restore before update any other attributes.
- stopPreviousKeyframeAnimationAndRestore(el_1);
- }
- if (el_1) {
- applyUpdateTransition(el_1, elOptionCleaned, graphicModel, {
- isInit: isInit
- });
- updateCommonAttrs(el_1, elOption, globalZ, globalZLevel);
- }
- } else if (isReplace) {
- removeEl(elExisting, elOption, elMap, graphicModel);
- var el_2 = createEl(id, targetElParent, elOption.type, elMap);
- if (el_2) {
- applyUpdateTransition(el_2, elOptionCleaned, graphicModel, {
- isInit: true
- });
- updateCommonAttrs(el_2, elOption, globalZ, globalZLevel);
- }
- } else if ($action === 'remove') {
- updateLeaveTo(elExisting, elOption);
- removeEl(elExisting, elOption, elMap, graphicModel);
- }
- var el = elMap.get(id);
- if (el && textContentOption) {
- if (isMerge) {
- var textContentExisting = el.getTextContent();
- textContentExisting ? textContentExisting.attr(textContentOption) : el.setTextContent(new graphicUtil.Text(textContentOption));
- } else if (isReplace) {
- el.setTextContent(new graphicUtil.Text(textContentOption));
- }
- }
- if (el) {
- var clipPathOption = elOption.clipPath;
- if (clipPathOption) {
- var clipPathType = clipPathOption.type;
- var clipPath = void 0;
- var isInit = false;
- if (isMerge) {
- var oldClipPath = el.getClipPath();
- isInit = !oldClipPath || inner(oldClipPath).type !== clipPathType;
- clipPath = isInit ? newEl(clipPathType) : oldClipPath;
- } else if (isReplace) {
- isInit = true;
- clipPath = newEl(clipPathType);
- }
- el.setClipPath(clipPath);
- applyUpdateTransition(clipPath, clipPathOption, graphicModel, {
- isInit: isInit
- });
- applyKeyframeAnimation(clipPath, clipPathOption.keyframeAnimation, graphicModel);
- }
- var elInner = inner(el);
- el.setTextConfig(textConfig);
- elInner.option = elOption;
- setEventData(el, graphicModel, elOption);
- graphicUtil.setTooltipConfig({
- el: el,
- componentModel: graphicModel,
- itemName: el.name,
- itemTooltipOption: elOption.tooltip
- });
- applyKeyframeAnimation(el, elOption.keyframeAnimation, graphicModel);
- }
- });
- };
- /**
- * Locate graphic elements.
- */
- GraphicComponentView.prototype._relocate = function (graphicModel, api) {
- var elOptions = graphicModel.option.elements;
- var rootGroup = this.group;
- var elMap = this._elMap;
- var apiWidth = api.getWidth();
- var apiHeight = api.getHeight();
- var xy = ['x', 'y'];
- // Top-down to calculate percentage width/height of group
- for (var i = 0; i < elOptions.length; i++) {
- var elOption = elOptions[i];
- var id = modelUtil.convertOptionIdName(elOption.id, null);
- var el = id != null ? elMap.get(id) : null;
- if (!el || !el.isGroup) {
- continue;
- }
- var parentEl = el.parent;
- var isParentRoot = parentEl === rootGroup;
- // Like 'position:absolut' in css, default 0.
- var elInner = inner(el);
- var parentElInner = inner(parentEl);
- elInner.width = parsePercent(elInner.option.width, isParentRoot ? apiWidth : parentElInner.width) || 0;
- elInner.height = parsePercent(elInner.option.height, isParentRoot ? apiHeight : parentElInner.height) || 0;
- }
- // Bottom-up tranvese all elements (consider ec resize) to locate elements.
- for (var i = elOptions.length - 1; i >= 0; i--) {
- var elOption = elOptions[i];
- var id = modelUtil.convertOptionIdName(elOption.id, null);
- var el = id != null ? elMap.get(id) : null;
- if (!el) {
- continue;
- }
- var parentEl = el.parent;
- var parentElInner = inner(parentEl);
- var containerInfo = parentEl === rootGroup ? {
- width: apiWidth,
- height: apiHeight
- } : {
- width: parentElInner.width,
- height: parentElInner.height
- };
- // PENDING
- // Currently, when `bounding: 'all'`, the union bounding rect of the group
- // does not include the rect of [0, 0, group.width, group.height], which
- // is probably weird for users. Should we make a break change for it?
- var layoutPos = {};
- var layouted = layoutUtil.positionElement(el, elOption, containerInfo, null, {
- hv: elOption.hv,
- boundingMode: elOption.bounding
- }, layoutPos);
- if (!inner(el).isNew && layouted) {
- var transition = elOption.transition;
- var animatePos = {};
- for (var k = 0; k < xy.length; k++) {
- var key = xy[k];
- var val = layoutPos[key];
- if (transition && (isTransitionAll(transition) || zrUtil.indexOf(transition, key) >= 0)) {
- animatePos[key] = val;
- } else {
- el[key] = val;
- }
- }
- updateProps(el, animatePos, graphicModel, 0);
- } else {
- el.attr(layoutPos);
- }
- }
- };
- /**
- * Clear all elements.
- */
- GraphicComponentView.prototype._clear = function () {
- var _this = this;
- var elMap = this._elMap;
- elMap.each(function (el) {
- removeEl(el, inner(el).option, elMap, _this._lastGraphicModel);
- });
- this._elMap = zrUtil.createHashMap();
- };
- GraphicComponentView.prototype.dispose = function () {
- this._clear();
- };
- GraphicComponentView.type = 'graphic';
- return GraphicComponentView;
- }(ComponentView);
- export { GraphicComponentView };
- function newEl(graphicType) {
- if (process.env.NODE_ENV !== 'production') {
- zrUtil.assert(graphicType, 'graphic type MUST be set');
- }
- var Clz = zrUtil.hasOwn(nonShapeGraphicElements, graphicType)
- // Those graphic elements are not shapes. They should not be
- // overwritten by users, so do them first.
- ? nonShapeGraphicElements[graphicType] : graphicUtil.getShapeClass(graphicType);
- if (process.env.NODE_ENV !== 'production') {
- zrUtil.assert(Clz, "graphic type " + graphicType + " can not be found");
- }
- var el = new Clz({});
- inner(el).type = graphicType;
- return el;
- }
- function createEl(id, targetElParent, graphicType, elMap) {
- var el = newEl(graphicType);
- targetElParent.add(el);
- elMap.set(id, el);
- inner(el).id = id;
- inner(el).isNew = true;
- return el;
- }
- function removeEl(elExisting, elOption, elMap, graphicModel) {
- var existElParent = elExisting && elExisting.parent;
- if (existElParent) {
- elExisting.type === 'group' && elExisting.traverse(function (el) {
- removeEl(el, elOption, elMap, graphicModel);
- });
- applyLeaveTransition(elExisting, elOption, graphicModel);
- elMap.removeKey(inner(elExisting).id);
- }
- }
- function updateCommonAttrs(el, elOption, defaultZ, defaultZlevel) {
- if (!el.isGroup) {
- zrUtil.each([['cursor', Displayable.prototype.cursor],
- // We should not support configure z and zlevel in the element level.
- // But seems we didn't limit it previously. So here still use it to avoid breaking.
- ['zlevel', defaultZlevel || 0], ['z', defaultZ || 0],
- // z2 must not be null/undefined, otherwise sort error may occur.
- ['z2', 0]], function (item) {
- var prop = item[0];
- if (zrUtil.hasOwn(elOption, prop)) {
- el[prop] = zrUtil.retrieve2(elOption[prop], item[1]);
- } else if (el[prop] == null) {
- el[prop] = item[1];
- }
- });
- }
- zrUtil.each(zrUtil.keys(elOption), function (key) {
- // Assign event handlers.
- // PENDING: should enumerate all event names or use pattern matching?
- if (key.indexOf('on') === 0) {
- var val = elOption[key];
- el[key] = zrUtil.isFunction(val) ? val : null;
- }
- });
- if (zrUtil.hasOwn(elOption, 'draggable')) {
- el.draggable = elOption.draggable;
- }
- // Other attributes
- elOption.name != null && (el.name = elOption.name);
- elOption.id != null && (el.id = elOption.id);
- }
- // Remove unnecessary props to avoid potential problems.
- function getCleanedElOption(elOption) {
- elOption = zrUtil.extend({}, elOption);
- zrUtil.each(['id', 'parentId', '$action', 'hv', 'bounding', 'textContent', 'clipPath'].concat(layoutUtil.LOCATION_PARAMS), function (name) {
- delete elOption[name];
- });
- return elOption;
- }
- function setEventData(el, graphicModel, elOption) {
- var eventData = getECData(el).eventData;
- // Simple optimize for large amount of elements that no need event.
- if (!el.silent && !el.ignore && !eventData) {
- eventData = getECData(el).eventData = {
- componentType: 'graphic',
- componentIndex: graphicModel.componentIndex,
- name: el.name
- };
- }
- // `elOption.info` enables user to mount some info on
- // elements and use them in event handlers.
- if (eventData) {
- eventData.info = elOption.info;
- }
- }
|