UNPKG

@antv/f2

Version:

Charts for mobile visualization.

126 lines 3.3 kB
import { __assign, __rest } from "tslib"; import { jsx } from '@antv/f-engine'; import { isArray } from '@antv/util'; export default (function (props, context) { var originTicks = props.ticks, coord = props.coord, style = props.style, animation = props.animation; var px2hd = context.px2hd; var left = coord.left, top = coord.top, bottom = coord.bottom; var grid = style.grid, tickLine = style.tickLine, line = style.line, labelOffset = style.labelOffset, label = style.label, symbol = style.symbol; var ticks = originTicks.filter(function (d) { return !isNaN(d.value); }); var symbols = isArray(symbol) ? symbol : [symbol]; var _a = tickLine || {}, tickLineLength = _a.length, tickLineStyle = __rest(_a, ["length"]); return jsx("group", null, grid ? ticks.map(function (tick) { var points = tick.points, tickValue = tick.tickValue, gridStyle = tick.gridStyle; var start = points[0]; var end = points[points.length - 1]; return jsx("line", { key: "grid-".concat(tickValue), style: __assign(__assign({ x1: start.x, y1: start.y, x2: end.x, y2: end.y }, grid), gridStyle) }); }) : null, tickLineLength ? ticks.map(function (tick) { var points = tick.points, tickValue = tick.tickValue; var start = points[0]; return jsx("line", { key: "tickLine-".concat(tickValue), style: __assign({ x1: start.x, y1: start.y, x2: start.x - px2hd(tickLineLength), y2: start.y }, tickLineStyle) }); }) : null, symbols[0] ? jsx("marker", { style: __assign(__assign({ x: left, y: top }, symbols[0]), { symbol: symbols[0].type }) }) : null, line ? jsx("line", { style: __assign({ x1: left, y1: top, x2: left, y2: bottom }, line) }) : null, symbols[1] ? jsx("marker", { style: __assign(__assign({ x: left, y: bottom, transform: 'rotate(180deg)', transformOrigin: '50% 50%' }, symbols[1]), { symbol: symbols[1].type }) }) : null, label ? ticks.map(function (tick, _index) { var tickValue = tick.tickValue, points = tick.points, text = tick.text, labelStyle = tick.labelStyle; var start = points[0]; return jsx("text", { key: "text-".concat(tickValue), style: __assign(__assign({ x: start.x - labelOffset, y: start.y, textAlign: 'right', textBaseline: 'middle', text: text }, label), labelStyle), animation: animation || { appear: { easing: 'linear', duration: 300, delay: 0, property: ['fillOpacity'], start: { fillOpacity: 0 }, end: { fillOpacity: 1 } }, update: { easing: 'linear', duration: 450, delay: 0, property: ['x', 'y'] }, leave: { easing: 'linear', duration: 450, delay: 0, property: ['fillOpacity'], start: { fillOpacity: 1 }, end: { fillOpacity: 0 } } } }); }) : null); });