|   | 
| /* | 
| * 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 * as graphic from '../../util/graphic.js'; | 
| import { toggleHoverEmphasis, SPECIAL_STATES, DISPLAY_STATES } from '../../util/states.js'; | 
| import { createTextStyle } from '../../label/labelStyle.js'; | 
| import { getECData } from '../../util/innerStore.js'; | 
| import { getSectorCornerRadius } from '../helper/sectorHelper.js'; | 
| import { createOrUpdatePatternFromDecal } from '../../util/decal.js'; | 
| import { saveOldStyle } from '../../animation/basicTransition.js'; | 
| import { normalizeRadian } from 'zrender/lib/contain/util.js'; | 
| import { isRadianAroundZero } from '../../util/number.js'; | 
| var DEFAULT_SECTOR_Z = 2; | 
| var DEFAULT_TEXT_Z = 4; | 
| /** | 
|  * Sunburstce of Sunburst including Sector, Label, LabelLine | 
|  */ | 
| var SunburstPiece = /** @class */function (_super) { | 
|   __extends(SunburstPiece, _super); | 
|   function SunburstPiece(node, seriesModel, ecModel, api) { | 
|     var _this = _super.call(this) || this; | 
|     _this.z2 = DEFAULT_SECTOR_Z; | 
|     _this.textConfig = { | 
|       inside: true | 
|     }; | 
|     getECData(_this).seriesIndex = seriesModel.seriesIndex; | 
|     var text = new graphic.Text({ | 
|       z2: DEFAULT_TEXT_Z, | 
|       silent: node.getModel().get(['label', 'silent']) | 
|     }); | 
|     _this.setTextContent(text); | 
|     _this.updateData(true, node, seriesModel, ecModel, api); | 
|     return _this; | 
|   } | 
|   SunburstPiece.prototype.updateData = function (firstCreate, node, | 
|   // state: 'emphasis' | 'normal' | 'highlight' | 'downplay', | 
|   seriesModel, ecModel, api) { | 
|     this.node = node; | 
|     node.piece = this; | 
|     seriesModel = seriesModel || this._seriesModel; | 
|     ecModel = ecModel || this._ecModel; | 
|     var sector = this; | 
|     getECData(sector).dataIndex = node.dataIndex; | 
|     var itemModel = node.getModel(); | 
|     var emphasisModel = itemModel.getModel('emphasis'); | 
|     var layout = node.getLayout(); | 
|     var sectorShape = zrUtil.extend({}, layout); | 
|     sectorShape.label = null; | 
|     var normalStyle = node.getVisual('style'); | 
|     normalStyle.lineJoin = 'bevel'; | 
|     var decal = node.getVisual('decal'); | 
|     if (decal) { | 
|       normalStyle.decal = createOrUpdatePatternFromDecal(decal, api); | 
|     } | 
|     var cornerRadius = getSectorCornerRadius(itemModel.getModel('itemStyle'), sectorShape, true); | 
|     zrUtil.extend(sectorShape, cornerRadius); | 
|     zrUtil.each(SPECIAL_STATES, function (stateName) { | 
|       var state = sector.ensureState(stateName); | 
|       var itemStyleModel = itemModel.getModel([stateName, 'itemStyle']); | 
|       state.style = itemStyleModel.getItemStyle(); | 
|       // border radius | 
|       var cornerRadius = getSectorCornerRadius(itemStyleModel, sectorShape); | 
|       if (cornerRadius) { | 
|         state.shape = cornerRadius; | 
|       } | 
|     }); | 
|     if (firstCreate) { | 
|       sector.setShape(sectorShape); | 
|       sector.shape.r = layout.r0; | 
|       graphic.initProps(sector, { | 
|         shape: { | 
|           r: layout.r | 
|         } | 
|       }, seriesModel, node.dataIndex); | 
|     } else { | 
|       // Disable animation for gradient since no interpolation method | 
|       // is supported for gradient | 
|       graphic.updateProps(sector, { | 
|         shape: sectorShape | 
|       }, seriesModel); | 
|       saveOldStyle(sector); | 
|     } | 
|     sector.useStyle(normalStyle); | 
|     this._updateLabel(seriesModel); | 
|     var cursorStyle = itemModel.getShallow('cursor'); | 
|     cursorStyle && sector.attr('cursor', cursorStyle); | 
|     this._seriesModel = seriesModel || this._seriesModel; | 
|     this._ecModel = ecModel || this._ecModel; | 
|     var focus = emphasisModel.get('focus'); | 
|     var focusOrIndices = focus === 'relative' ? zrUtil.concatArray(node.getAncestorsIndices(), node.getDescendantIndices()) : focus === 'ancestor' ? node.getAncestorsIndices() : focus === 'descendant' ? node.getDescendantIndices() : focus; | 
|     toggleHoverEmphasis(this, focusOrIndices, emphasisModel.get('blurScope'), emphasisModel.get('disabled')); | 
|   }; | 
|   SunburstPiece.prototype._updateLabel = function (seriesModel) { | 
|     var _this = this; | 
|     var itemModel = this.node.getModel(); | 
|     var normalLabelModel = itemModel.getModel('label'); | 
|     var layout = this.node.getLayout(); | 
|     var angle = layout.endAngle - layout.startAngle; | 
|     var midAngle = (layout.startAngle + layout.endAngle) / 2; | 
|     var dx = Math.cos(midAngle); | 
|     var dy = Math.sin(midAngle); | 
|     var sector = this; | 
|     var label = sector.getTextContent(); | 
|     var dataIndex = this.node.dataIndex; | 
|     var labelMinAngle = normalLabelModel.get('minAngle') / 180 * Math.PI; | 
|     var isNormalShown = normalLabelModel.get('show') && !(labelMinAngle != null && Math.abs(angle) < labelMinAngle); | 
|     label.ignore = !isNormalShown; | 
|     // TODO use setLabelStyle | 
|     zrUtil.each(DISPLAY_STATES, function (stateName) { | 
|       var labelStateModel = stateName === 'normal' ? itemModel.getModel('label') : itemModel.getModel([stateName, 'label']); | 
|       var isNormal = stateName === 'normal'; | 
|       var state = isNormal ? label : label.ensureState(stateName); | 
|       var text = seriesModel.getFormattedLabel(dataIndex, stateName); | 
|       if (isNormal) { | 
|         text = text || _this.node.name; | 
|       } | 
|       state.style = createTextStyle(labelStateModel, {}, null, stateName !== 'normal', true); | 
|       if (text) { | 
|         state.style.text = text; | 
|       } | 
|       // Not displaying text when angle is too small | 
|       var isShown = labelStateModel.get('show'); | 
|       if (isShown != null && !isNormal) { | 
|         state.ignore = !isShown; | 
|       } | 
|       var labelPosition = getLabelAttr(labelStateModel, 'position'); | 
|       var sectorState = isNormal ? sector : sector.states[stateName]; | 
|       var labelColor = sectorState.style.fill; | 
|       sectorState.textConfig = { | 
|         outsideFill: labelStateModel.get('color') === 'inherit' ? labelColor : null, | 
|         inside: labelPosition !== 'outside' | 
|       }; | 
|       var r; | 
|       var labelPadding = getLabelAttr(labelStateModel, 'distance') || 0; | 
|       var textAlign = getLabelAttr(labelStateModel, 'align'); | 
|       var rotateType = getLabelAttr(labelStateModel, 'rotate'); | 
|       var flipStartAngle = Math.PI * 0.5; | 
|       var flipEndAngle = Math.PI * 1.5; | 
|       var midAngleNormal = normalizeRadian(rotateType === 'tangential' ? Math.PI / 2 - midAngle : midAngle); | 
|       // For text that is up-side down, rotate 180 degrees to make sure | 
|       // it's readable | 
|       var needsFlip = midAngleNormal > flipStartAngle && !isRadianAroundZero(midAngleNormal - flipStartAngle) && midAngleNormal < flipEndAngle; | 
|       if (labelPosition === 'outside') { | 
|         r = layout.r + labelPadding; | 
|         textAlign = needsFlip ? 'right' : 'left'; | 
|       } else { | 
|         if (!textAlign || textAlign === 'center') { | 
|           // Put label in the center if it's a circle | 
|           if (angle === 2 * Math.PI && layout.r0 === 0) { | 
|             r = 0; | 
|           } else { | 
|             r = (layout.r + layout.r0) / 2; | 
|           } | 
|           textAlign = 'center'; | 
|         } else if (textAlign === 'left') { | 
|           r = layout.r0 + labelPadding; | 
|           textAlign = needsFlip ? 'right' : 'left'; | 
|         } else if (textAlign === 'right') { | 
|           r = layout.r - labelPadding; | 
|           textAlign = needsFlip ? 'left' : 'right'; | 
|         } | 
|       } | 
|       state.style.align = textAlign; | 
|       state.style.verticalAlign = getLabelAttr(labelStateModel, 'verticalAlign') || 'middle'; | 
|       state.x = r * dx + layout.cx; | 
|       state.y = r * dy + layout.cy; | 
|       var rotate = 0; | 
|       if (rotateType === 'radial') { | 
|         rotate = normalizeRadian(-midAngle) + (needsFlip ? Math.PI : 0); | 
|       } else if (rotateType === 'tangential') { | 
|         rotate = normalizeRadian(Math.PI / 2 - midAngle) + (needsFlip ? Math.PI : 0); | 
|       } else if (zrUtil.isNumber(rotateType)) { | 
|         rotate = rotateType * Math.PI / 180; | 
|       } | 
|       state.rotation = normalizeRadian(rotate); | 
|     }); | 
|     function getLabelAttr(model, name) { | 
|       var stateAttr = model.get(name); | 
|       if (stateAttr == null) { | 
|         return normalLabelModel.get(name); | 
|       } | 
|       return stateAttr; | 
|     } | 
|     label.dirtyStyle(); | 
|   }; | 
|   return SunburstPiece; | 
| }(graphic.Sector); | 
| export default SunburstPiece; |