echarts 4.4.0 → 4.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.github/ISSUE_TEMPLATE.md +1 -1
- package/.github/workflows/nodejs.yml +31 -0
- package/CONTRIBUTING.md +2 -2
- package/README.md +6 -12
- package/dist/echarts-en.common.js +2354 -1029
- package/dist/echarts-en.common.min.js +1 -1
- package/dist/echarts-en.js +2727 -1138
- package/dist/echarts-en.js.map +1 -1
- package/dist/echarts-en.min.js +1 -1
- package/dist/echarts-en.simple.js +2028 -759
- package/dist/echarts-en.simple.min.js +1 -1
- package/dist/echarts.common.js +2354 -1029
- package/dist/echarts.common.min.js +1 -1
- package/dist/echarts.js +2727 -1138
- package/dist/echarts.js.map +1 -1
- package/dist/echarts.min.js +1 -1
- package/dist/echarts.simple.js +2028 -759
- package/dist/echarts.simple.min.js +1 -1
- package/dist/extension/dataTool.js +9 -0
- package/dist/extension/dataTool.js.map +1 -1
- package/echarts.all.js +1 -1
- package/lib/chart/bar/BarSeries.js +4 -1
- package/lib/chart/bar/BarView.js +20 -6
- package/lib/chart/bar/BaseBarSeries.js +5 -1
- package/lib/chart/candlestick/CandlestickSeries.js +1 -0
- package/lib/chart/candlestick/CandlestickView.js +42 -1
- package/lib/chart/custom.js +1 -0
- package/lib/chart/effectScatter/EffectScatterSeries.js +3 -1
- package/lib/chart/funnel/FunnelSeries.js +15 -5
- package/lib/chart/gauge/GaugeSeries.js +0 -9
- package/lib/chart/graph/GraphSeries.js +11 -4
- package/lib/chart/graph/GraphView.js +28 -8
- package/lib/chart/graph/forceHelper.js +8 -2
- package/lib/chart/graph/forceLayout.js +5 -2
- package/lib/chart/heatmap/HeatmapView.js +4 -4
- package/lib/chart/helper/Symbol.js +8 -0
- package/lib/chart/helper/createListFromArray.js +14 -8
- package/lib/chart/helper/whiskerBoxCommon.js +22 -16
- package/lib/chart/line/LineSeries.js +3 -1
- package/lib/chart/line/LineView.js +8 -2
- package/lib/chart/map/MapSeries.js +8 -1
- package/lib/chart/pie/PieSeries.js +27 -6
- package/lib/chart/pie/PieView.js +1 -1
- package/lib/chart/pie/labelLayout.js +102 -19
- package/lib/chart/pie/pieLayout.js +19 -7
- package/lib/chart/radar/RadarSeries.js +3 -3
- package/lib/chart/sankey/SankeyView.js +28 -9
- package/lib/chart/scatter/ScatterSeries.js +3 -1
- package/lib/chart/themeRiver/ThemeRiverSeries.js +3 -3
- package/lib/chart/tree/TreeSeries.js +15 -1
- package/lib/chart/tree/TreeView.js +4 -2
- package/lib/component/axis/AngleAxisView.js +97 -20
- package/lib/component/axis/AxisBuilder.js +63 -24
- package/lib/component/axis/CartesianAxisView.js +55 -11
- package/lib/component/axis/RadiusAxisView.js +36 -4
- package/lib/component/brush/BrushView.js +6 -0
- package/lib/component/brush/brushAction.js +5 -0
- package/lib/component/dataZoom/DataZoomModel.js +15 -1
- package/lib/component/dataZoom/SliderZoomView.js +4 -10
- package/lib/component/helper/BrushController.js +43 -25
- package/lib/component/legend/LegendModel.js +3 -3
- package/lib/component/legend/LegendView.js +17 -13
- package/lib/component/toolbox/ToolboxView.js +16 -7
- package/lib/component/toolbox/feature/MagicType.js +19 -14
- package/lib/coord/Axis.js +44 -12
- package/lib/coord/axisDefault.js +21 -2
- package/lib/coord/axisTickLabelBuilder.js +9 -1
- package/lib/coord/cartesian/Cartesian2D.js +0 -15
- package/lib/coord/geo/geoJSONLoader.js +1 -1
- package/lib/coord/polar/polarCreator.js +11 -2
- package/lib/coord/radar/Radar.js +3 -1
- package/lib/coord/radar/RadarModel.js +4 -1
- package/lib/data/DataDiffer.js +2 -4
- package/lib/data/DataDimensionInfo.js +157 -0
- package/lib/data/List.js +29 -23
- package/lib/data/Tree.js +2 -1
- package/lib/data/helper/completeDimensions.js +43 -32
- package/lib/data/helper/createDimensions.js +2 -0
- package/lib/data/helper/sourceHelper.js +214 -114
- package/lib/echarts.js +2 -2
- package/lib/layout/barGrid.js +136 -11
- package/lib/layout/barPolar.js +2 -2
- package/lib/model/Global.js +1 -1
- package/lib/model/Series.js +3 -3
- package/lib/model/referHelper.js +40 -12
- package/lib/scale/Interval.js +87 -2
- package/lib/scale/Log.js +9 -2
- package/lib/scale/helper.js +1 -43
- package/lib/theme/dark.js +3 -0
- package/lib/util/graphic.js +1 -2
- package/lib/util/number.js +25 -1
- package/lib/util/shape/sausage.js +93 -0
- package/lib/visual/LegendVisualProvider.js +75 -0
- package/lib/visual/dataColor.js +2 -12
- package/lib/visual/seriesColor.js +15 -7
- package/map/js/china.js +2 -2
- package/map/json/china.json +1 -1
- package/map/json/province/tianjin.json +1 -1
- package/package.json +3 -2
- package/src/chart/bar/BarSeries.js +5 -1
- package/src/chart/bar/BarView.js +24 -8
- package/src/chart/bar/BaseBarSeries.js +5 -1
- package/src/chart/candlestick/CandlestickSeries.js +2 -0
- package/src/chart/candlestick/CandlestickView.js +44 -1
- package/src/chart/custom.js +1 -0
- package/src/chart/effectScatter/EffectScatterSeries.js +1 -1
- package/src/chart/funnel/FunnelSeries.js +11 -4
- package/src/chart/gauge/GaugeSeries.js +0 -6
- package/src/chart/graph/GraphSeries.js +10 -3
- package/src/chart/graph/GraphView.js +26 -8
- package/src/chart/graph/forceHelper.js +7 -3
- package/src/chart/graph/forceLayout.js +6 -3
- package/src/chart/heatmap/HeatmapView.js +4 -4
- package/src/chart/helper/Symbol.js +9 -0
- package/src/chart/helper/createClipPathFromCoordSys.js +5 -1
- package/src/chart/helper/createGraphFromNodeEdge.js +1 -1
- package/src/chart/helper/createListFromArray.js +13 -8
- package/src/chart/helper/whiskerBoxCommon.js +21 -16
- package/src/chart/line/LineSeries.js +1 -1
- package/src/chart/line/LineView.js +6 -1
- package/src/chart/map/MapSeries.js +5 -1
- package/src/chart/pie/PieSeries.js +26 -5
- package/src/chart/pie/PieView.js +1 -1
- package/src/chart/pie/labelLayout.js +114 -22
- package/src/chart/pie/pieLayout.js +20 -7
- package/src/chart/radar/RadarSeries.js +5 -3
- package/src/chart/sankey/SankeyView.js +26 -9
- package/src/chart/scatter/ScatterSeries.js +1 -1
- package/src/chart/themeRiver/ThemeRiverSeries.js +4 -3
- package/src/chart/tree/TreeSeries.js +12 -1
- package/src/chart/tree/TreeView.js +5 -2
- package/src/component/axis/AngleAxisView.js +106 -19
- package/src/component/axis/AxisBuilder.js +78 -33
- package/src/component/axis/CartesianAxisView.js +58 -11
- package/src/component/axis/RadiusAxisView.js +37 -4
- package/src/component/brush/BrushView.js +6 -0
- package/src/component/brush/brushAction.js +6 -1
- package/src/component/dataZoom/DataZoomModel.js +15 -1
- package/src/component/dataZoom/SliderZoomView.js +4 -9
- package/src/component/helper/BrushController.js +50 -28
- package/src/component/legend/LegendModel.js +3 -3
- package/src/component/legend/LegendView.js +18 -12
- package/src/component/toolbox/ToolboxView.js +18 -5
- package/src/component/toolbox/feature/MagicType.js +18 -13
- package/src/coord/Axis.js +48 -13
- package/src/coord/axisDefault.js +25 -1
- package/src/coord/axisTickLabelBuilder.js +10 -0
- package/src/coord/cartesian/Cartesian2D.js +0 -13
- package/src/coord/geo/geoJSONLoader.js +2 -2
- package/src/coord/polar/polarCreator.js +16 -3
- package/src/coord/radar/Radar.js +3 -1
- package/src/coord/radar/RadarModel.js +5 -2
- package/src/data/DataDiffer.js +1 -4
- package/src/data/DataDimensionInfo.js +135 -0
- package/src/data/Graph.js +1 -1
- package/src/data/List.js +33 -20
- package/src/data/Tree.js +3 -1
- package/src/data/helper/completeDimensions.js +49 -30
- package/src/data/helper/createDimensions.js +2 -0
- package/src/data/helper/sourceHelper.js +216 -124
- package/src/echarts.js +2 -2
- package/src/layout/barGrid.js +136 -13
- package/src/layout/barPolar.js +3 -2
- package/src/model/Global.js +1 -1
- package/src/model/Series.js +3 -3
- package/src/model/referHelper.js +34 -11
- package/src/scale/Interval.js +84 -4
- package/src/scale/Log.js +9 -2
- package/src/scale/helper.js +1 -39
- package/src/theme/dark.js +3 -0
- package/src/util/graphic.js +1 -2
- package/src/util/number.js +22 -2
- package/src/util/shape/sausage.js +93 -0
- package/src/visual/LegendVisualProvider.js +55 -0
- package/src/visual/dataColor.js +0 -13
- package/src/visual/seriesColor.js +13 -7
- package/theme/azul.js +163 -0
- package/theme/bee-inspired.js +178 -0
- package/theme/blue.js +178 -0
- package/theme/caravan.js +178 -0
- package/theme/carp.js +163 -0
- package/theme/cool.js +180 -0
- package/theme/dark-blue.js +168 -0
- package/theme/dark-bold.js +168 -0
- package/theme/dark-digerati.js +168 -0
- package/theme/dark-fresh-cut.js +168 -0
- package/theme/dark-mushroom.js +168 -0
- package/theme/dark.js +69 -62
- package/theme/eduardo.js +178 -0
- package/theme/forest.js +163 -0
- package/theme/fresh-cut.js +163 -0
- package/theme/fruit.js +178 -0
- package/theme/gray.js +220 -0
- package/theme/green.js +222 -0
- package/theme/helianthus.js +263 -0
- package/theme/infographic.js +72 -57
- package/theme/inspired.js +163 -0
- package/theme/jazz.js +163 -0
- package/theme/london.js +163 -0
- package/theme/macarons.js +80 -57
- package/theme/macarons2.js +251 -0
- package/theme/mint.js +155 -0
- package/theme/red-velvet.js +163 -0
- package/theme/red.js +225 -0
- package/theme/roma.js +55 -22
- package/theme/royal.js +163 -0
- package/theme/sakura.js +140 -0
- package/theme/shine.js +52 -45
- package/theme/tech-blue.js +180 -0
- package/theme/vintage.js +37 -23
- package/.travis.yml +0 -16
package/src/data/List.js
CHANGED
|
@@ -31,6 +31,7 @@ import DataDiffer from './DataDiffer';
|
|
|
31
31
|
import Source from './Source';
|
|
32
32
|
import {defaultDimValueGetters, DefaultDataProvider} from './helper/dataProvider';
|
|
33
33
|
import {summarizeDimensions} from './helper/dimensionHelper';
|
|
34
|
+
import DataDimensionInfo from './DataDimensionInfo';
|
|
34
35
|
|
|
35
36
|
var isObject = zrUtil.isObject;
|
|
36
37
|
|
|
@@ -102,13 +103,9 @@ function transferProperties(target, source) {
|
|
|
102
103
|
* @constructor
|
|
103
104
|
* @alias module:echarts/data/List
|
|
104
105
|
*
|
|
105
|
-
* @param {Array.<string|Object>} dimensions
|
|
106
|
+
* @param {Array.<string|Object|module:data/DataDimensionInfo>} dimensions
|
|
106
107
|
* For example, ['someDimName', {name: 'someDimName', type: 'someDimType'}, ...].
|
|
107
108
|
* Dimensions should be concrete names like x, y, z, lng, lat, angle, radius
|
|
108
|
-
* Spetial fields: {
|
|
109
|
-
* ordinalMeta: <module:echarts/data/OrdinalMeta>
|
|
110
|
-
* createInvertedIndices: <boolean>
|
|
111
|
-
* }
|
|
112
109
|
* @param {module:echarts/model/Model} hostModel
|
|
113
110
|
*/
|
|
114
111
|
var List = function (dimensions, hostModel) {
|
|
@@ -124,7 +121,10 @@ var List = function (dimensions, hostModel) {
|
|
|
124
121
|
var dimensionInfo = dimensions[i];
|
|
125
122
|
|
|
126
123
|
if (zrUtil.isString(dimensionInfo)) {
|
|
127
|
-
dimensionInfo = {name: dimensionInfo};
|
|
124
|
+
dimensionInfo = new DataDimensionInfo({name: dimensionInfo});
|
|
125
|
+
}
|
|
126
|
+
else if (!(dimensionInfo instanceof DataDimensionInfo)) {
|
|
127
|
+
dimensionInfo = new DataDimensionInfo(dimensionInfo);
|
|
128
128
|
}
|
|
129
129
|
|
|
130
130
|
var dimensionName = dimensionInfo.name;
|
|
@@ -1105,14 +1105,14 @@ listProto.indexOfName = function (name) {
|
|
|
1105
1105
|
* @return {number}
|
|
1106
1106
|
*/
|
|
1107
1107
|
listProto.indexOfRawIndex = function (rawIndex) {
|
|
1108
|
-
if (!this._indices) {
|
|
1109
|
-
return rawIndex;
|
|
1110
|
-
}
|
|
1111
|
-
|
|
1112
1108
|
if (rawIndex >= this._rawCount || rawIndex < 0) {
|
|
1113
1109
|
return -1;
|
|
1114
1110
|
}
|
|
1115
1111
|
|
|
1112
|
+
if (!this._indices) {
|
|
1113
|
+
return rawIndex;
|
|
1114
|
+
}
|
|
1115
|
+
|
|
1116
1116
|
// Indices are ascending
|
|
1117
1117
|
var indices = this._indices;
|
|
1118
1118
|
|
|
@@ -1144,7 +1144,8 @@ listProto.indexOfRawIndex = function (rawIndex) {
|
|
|
1144
1144
|
* @param {string} dim
|
|
1145
1145
|
* @param {number} value
|
|
1146
1146
|
* @param {number} [maxDistance=Infinity]
|
|
1147
|
-
* @return {Array.<number>}
|
|
1147
|
+
* @return {Array.<number>} If and only if multiple indices has
|
|
1148
|
+
* the same value, they are put to the result.
|
|
1148
1149
|
*/
|
|
1149
1150
|
listProto.indicesOfNearest = function (dim, value, maxDistance) {
|
|
1150
1151
|
var storage = this._storage;
|
|
@@ -1159,23 +1160,35 @@ listProto.indicesOfNearest = function (dim, value, maxDistance) {
|
|
|
1159
1160
|
maxDistance = Infinity;
|
|
1160
1161
|
}
|
|
1161
1162
|
|
|
1162
|
-
var minDist =
|
|
1163
|
+
var minDist = Infinity;
|
|
1163
1164
|
var minDiff = -1;
|
|
1165
|
+
var nearestIndicesLen = 0;
|
|
1166
|
+
|
|
1167
|
+
// Check the test case of `test/ut/spec/data/List.js`.
|
|
1164
1168
|
for (var i = 0, len = this.count(); i < len; i++) {
|
|
1165
|
-
var diff = value - this.get(dim, i
|
|
1169
|
+
var diff = value - this.get(dim, i);
|
|
1166
1170
|
var dist = Math.abs(diff);
|
|
1167
|
-
if (
|
|
1168
|
-
//
|
|
1169
|
-
//
|
|
1170
|
-
//
|
|
1171
|
-
|
|
1171
|
+
if (dist <= maxDistance) {
|
|
1172
|
+
// When the `value` is at the middle of `this.get(dim, i)` and `this.get(dim, i+1)`,
|
|
1173
|
+
// we'd better not push both of them to `nearestIndices`, otherwise it is easy to
|
|
1174
|
+
// get more than one item in `nearestIndices` (more specifically, in `tooltip`).
|
|
1175
|
+
// So we chose the one that `diff >= 0` in this csae.
|
|
1176
|
+
// But if `this.get(dim, i)` and `this.get(dim, j)` get the same value, both of them
|
|
1177
|
+
// should be push to `nearestIndices`.
|
|
1178
|
+
if (dist < minDist
|
|
1179
|
+
|| (dist === minDist && diff >= 0 && minDiff < 0)
|
|
1180
|
+
) {
|
|
1172
1181
|
minDist = dist;
|
|
1173
1182
|
minDiff = diff;
|
|
1174
|
-
|
|
1183
|
+
nearestIndicesLen = 0;
|
|
1184
|
+
}
|
|
1185
|
+
if (diff === minDiff) {
|
|
1186
|
+
nearestIndices[nearestIndicesLen++] = i;
|
|
1175
1187
|
}
|
|
1176
|
-
nearestIndices.push(i);
|
|
1177
1188
|
}
|
|
1178
1189
|
}
|
|
1190
|
+
nearestIndices.length = nearestIndicesLen;
|
|
1191
|
+
|
|
1179
1192
|
return nearestIndices;
|
|
1180
1193
|
};
|
|
1181
1194
|
|
package/src/data/Tree.js
CHANGED
|
@@ -472,7 +472,7 @@ Tree.prototype = {
|
|
|
472
472
|
* @param {Array.<Object>} treeOptions.leaves
|
|
473
473
|
* @return module:echarts/data/Tree
|
|
474
474
|
*/
|
|
475
|
-
Tree.createTree = function (dataRoot, hostModel, treeOptions) {
|
|
475
|
+
Tree.createTree = function (dataRoot, hostModel, treeOptions, beforeLink) {
|
|
476
476
|
|
|
477
477
|
var tree = new Tree(hostModel, treeOptions.levels, treeOptions.leaves);
|
|
478
478
|
var listData = [];
|
|
@@ -519,6 +519,8 @@ Tree.createTree = function (dataRoot, hostModel, treeOptions) {
|
|
|
519
519
|
|
|
520
520
|
tree.update();
|
|
521
521
|
|
|
522
|
+
beforeLink && beforeLink(list);
|
|
523
|
+
|
|
522
524
|
return tree;
|
|
523
525
|
};
|
|
524
526
|
|
|
@@ -24,15 +24,20 @@
|
|
|
24
24
|
|
|
25
25
|
import {createHashMap, each, isString, defaults, extend, isObject, clone} from 'zrender/src/core/util';
|
|
26
26
|
import {normalizeToArray} from '../../util/model';
|
|
27
|
-
import {guessOrdinal} from './sourceHelper';
|
|
27
|
+
import {guessOrdinal, BE_ORDINAL} from './sourceHelper';
|
|
28
28
|
import Source from '../Source';
|
|
29
29
|
import {OTHER_DIMENSIONS} from './dimensionHelper';
|
|
30
|
+
import DataDimensionInfo from '../DataDimensionInfo';
|
|
30
31
|
|
|
31
32
|
/**
|
|
32
33
|
* @see {module:echarts/test/ut/spec/data/completeDimensions}
|
|
33
34
|
*
|
|
34
|
-
*
|
|
35
|
-
*
|
|
35
|
+
* This method builds the relationship between:
|
|
36
|
+
* + "what the coord sys or series requires (see `sysDims`)",
|
|
37
|
+
* + "what the user defines (in `encode` and `dimensions`, see `opt.dimsDef` and `opt.encodeDef`)"
|
|
38
|
+
* + "what the data source provids (see `source`)".
|
|
39
|
+
*
|
|
40
|
+
* Some guess strategy will be adapted if user does not define something.
|
|
36
41
|
* If no 'value' dimension specified, the first no-named dimension will be
|
|
37
42
|
* named as 'value'.
|
|
38
43
|
*
|
|
@@ -48,32 +53,20 @@ import {OTHER_DIMENSIONS} from './dimensionHelper';
|
|
|
48
53
|
* @param {Array.<Object|string>} [opt.dimsDef] option.series.dimensions User defined dimensions
|
|
49
54
|
* For example: ['asdf', {name, type}, ...].
|
|
50
55
|
* @param {Object|HashMap} [opt.encodeDef] option.series.encode {x: 2, y: [3, 1], tooltip: [1, 2], label: 3}
|
|
56
|
+
* @param {Function} [opt.encodeDefaulter] Called if no `opt.encodeDef` exists.
|
|
57
|
+
* If not specified, auto find the next available data dim.
|
|
58
|
+
* param source {module:data/Source}
|
|
59
|
+
* param dimCount {number}
|
|
60
|
+
* return {Object} encode Never be `null/undefined`.
|
|
51
61
|
* @param {string} [opt.generateCoord] Generate coord dim with the given name.
|
|
52
|
-
*
|
|
53
|
-
*
|
|
62
|
+
* If not specified, extra dim names will be:
|
|
63
|
+
* 'value', 'value0', 'value1', ...
|
|
54
64
|
* @param {number} [opt.generateCoordCount] By default, the generated dim name is `generateCoord`.
|
|
55
|
-
*
|
|
56
|
-
*
|
|
57
|
-
*
|
|
65
|
+
* If `generateCoordCount` specified, the generated dim names will be:
|
|
66
|
+
* `generateCoord` + 0, `generateCoord` + 1, ...
|
|
67
|
+
* can be Infinity, indicate that use all of the remain columns.
|
|
58
68
|
* @param {number} [opt.dimCount] If not specified, guess by the first data item.
|
|
59
|
-
* @
|
|
60
|
-
* @return {Array.<Object>} [{
|
|
61
|
-
* name: string mandatory,
|
|
62
|
-
* displayName: string, the origin name in dimsDef, see source helper.
|
|
63
|
-
* If displayName given, the tooltip will displayed vertically.
|
|
64
|
-
* coordDim: string mandatory,
|
|
65
|
-
* coordDimIndex: number mandatory,
|
|
66
|
-
* type: string optional,
|
|
67
|
-
* otherDims: { never null/undefined
|
|
68
|
-
* tooltip: number optional,
|
|
69
|
-
* label: number optional,
|
|
70
|
-
* itemName: number optional,
|
|
71
|
-
* seriesName: number optional,
|
|
72
|
-
* },
|
|
73
|
-
* isExtraCoord: boolean true if coord is generated
|
|
74
|
-
* (not specified in encode and not series specified)
|
|
75
|
-
* other props ...
|
|
76
|
-
* }]
|
|
69
|
+
* @return {Array.<module:data/DataDimensionInfo>}
|
|
77
70
|
*/
|
|
78
71
|
function completeDimensions(sysDims, source, opt) {
|
|
79
72
|
if (!Source.isInstance(source)) {
|
|
@@ -83,7 +76,6 @@ function completeDimensions(sysDims, source, opt) {
|
|
|
83
76
|
opt = opt || {};
|
|
84
77
|
sysDims = (sysDims || []).slice();
|
|
85
78
|
var dimsDef = (opt.dimsDef || []).slice();
|
|
86
|
-
var encodeDef = createHashMap(opt.encodeDef);
|
|
87
79
|
var dataDimNameMap = createHashMap();
|
|
88
80
|
var coordDimNameMap = createHashMap();
|
|
89
81
|
// var valueCandidate;
|
|
@@ -97,7 +89,7 @@ function completeDimensions(sysDims, source, opt) {
|
|
|
97
89
|
{}, isObject(dimsDef[i]) ? dimsDef[i] : {name: dimsDef[i]}
|
|
98
90
|
);
|
|
99
91
|
var userDimName = dimDefItem.name;
|
|
100
|
-
var resultItem = result[i] =
|
|
92
|
+
var resultItem = result[i] = new DataDimensionInfo();
|
|
101
93
|
// Name will be applied later for avoiding duplication.
|
|
102
94
|
if (userDimName != null && dataDimNameMap.get(userDimName) == null) {
|
|
103
95
|
// Only if `series.dimensions` is defined in option
|
|
@@ -110,6 +102,12 @@ function completeDimensions(sysDims, source, opt) {
|
|
|
110
102
|
dimDefItem.displayName != null && (resultItem.displayName = dimDefItem.displayName);
|
|
111
103
|
}
|
|
112
104
|
|
|
105
|
+
var encodeDef = opt.encodeDef;
|
|
106
|
+
if (!encodeDef && opt.encodeDefaulter) {
|
|
107
|
+
encodeDef = opt.encodeDefaulter(source, dimCount);
|
|
108
|
+
}
|
|
109
|
+
encodeDef = createHashMap(encodeDef);
|
|
110
|
+
|
|
113
111
|
// Set `coordDim` and `coordDimIndex` by `encodeDef` and normalize `encodeDef`.
|
|
114
112
|
encodeDef.each(function (dataDims, coordDim) {
|
|
115
113
|
dataDims = normalizeToArray(dataDims).slice();
|
|
@@ -211,7 +209,7 @@ function completeDimensions(sysDims, source, opt) {
|
|
|
211
209
|
|
|
212
210
|
// Set dim `name` and other `coordDim` and other props.
|
|
213
211
|
for (var resultDimIdx = 0; resultDimIdx < dimCount; resultDimIdx++) {
|
|
214
|
-
var resultItem = result[resultDimIdx] = result[resultDimIdx] ||
|
|
212
|
+
var resultItem = result[resultDimIdx] = result[resultDimIdx] || new DataDimensionInfo();
|
|
215
213
|
var coordDim = resultItem.coordDim;
|
|
216
214
|
|
|
217
215
|
if (coordDim == null) {
|
|
@@ -230,7 +228,28 @@ function completeDimensions(sysDims, source, opt) {
|
|
|
230
228
|
dataDimNameMap
|
|
231
229
|
));
|
|
232
230
|
|
|
233
|
-
if (resultItem.type == null
|
|
231
|
+
if (resultItem.type == null
|
|
232
|
+
&& (
|
|
233
|
+
guessOrdinal(source, resultDimIdx, resultItem.name) === BE_ORDINAL.Must
|
|
234
|
+
// Consider the case:
|
|
235
|
+
// {
|
|
236
|
+
// dataset: {source: [
|
|
237
|
+
// ['2001', 123],
|
|
238
|
+
// ['2002', 456],
|
|
239
|
+
// ...
|
|
240
|
+
// ['The others', 987],
|
|
241
|
+
// ]},
|
|
242
|
+
// series: {type: 'pie'}
|
|
243
|
+
// }
|
|
244
|
+
// The first colum should better be treated as a "ordinal" although it
|
|
245
|
+
// might not able to be detected as an "ordinal" by `guessOrdinal`.
|
|
246
|
+
|| (resultItem.isExtraCoord
|
|
247
|
+
&& (resultItem.otherDims.itemName != null
|
|
248
|
+
|| resultItem.otherDims.seriesName != null
|
|
249
|
+
)
|
|
250
|
+
)
|
|
251
|
+
)
|
|
252
|
+
) {
|
|
234
253
|
resultItem.type = 'ordinal';
|
|
235
254
|
}
|
|
236
255
|
}
|
|
@@ -32,6 +32,7 @@ import completeDimensions from './completeDimensions';
|
|
|
32
32
|
* @param {string} [opt.generateCoordCount]
|
|
33
33
|
* @param {Array.<string|Object>} [opt.dimensionsDefine=source.dimensionsDefine] Overwrite source define.
|
|
34
34
|
* @param {Object|HashMap} [opt.encodeDefine=source.encodeDefine] Overwrite source define.
|
|
35
|
+
* @param {Function} [opt.encodeDefaulter] Make default encode if user not specified.
|
|
35
36
|
* @return {Array.<Object>} dimensionsInfo
|
|
36
37
|
*/
|
|
37
38
|
export default function (source, opt) {
|
|
@@ -40,6 +41,7 @@ export default function (source, opt) {
|
|
|
40
41
|
dimsDef: opt.dimensionsDefine || source.dimensionsDefine,
|
|
41
42
|
encodeDef: opt.encodeDefine || source.encodeDefine,
|
|
42
43
|
dimCount: opt.dimensionsCount,
|
|
44
|
+
encodeDefaulter: opt.encodeDefaulter,
|
|
43
45
|
generateCoord: opt.generateCoord,
|
|
44
46
|
generateCoordCount: opt.generateCoordCount
|
|
45
47
|
});
|