vue2-client 1.18.39 → 1.18.41

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.
Files changed (103) hide show
  1. package/.eslintrc.js +90 -90
  2. package/Components.md +60 -60
  3. package/docs/index.md +30 -30
  4. package/docs//350/257/267/346/261/202/345/267/245/345/205/267/344/275/277/347/224/250/350/257/264/346/230/216.md +353 -0
  5. package/index.js +31 -31
  6. package/jest-transform-stub.js +8 -8
  7. package/jest.setup.js +7 -7
  8. package/package.json +1 -1
  9. package/src/assets/img/querySlotDemo.svg +15 -15
  10. package/src/base-client/components/common/AmapMarker/AmapPointRendering.vue +120 -120
  11. package/src/base-client/components/common/CitySelect/index.js +3 -3
  12. package/src/base-client/components/common/CitySelect/index.md +109 -109
  13. package/src/base-client/components/common/CreateQuery/CreateQuery.vue +669 -669
  14. package/src/base-client/components/common/CreateQuery/index.js +3 -3
  15. package/src/base-client/components/common/CreateQuery/index.md +42 -42
  16. package/src/base-client/components/common/CreateSimpleFormQuery/index.js +3 -3
  17. package/src/base-client/components/common/CreateSimpleFormQuery/index.md +42 -42
  18. package/src/base-client/components/common/FormGroupEdit/index.js +3 -3
  19. package/src/base-client/components/common/FormGroupEdit/index.md +43 -43
  20. package/src/base-client/components/common/FormGroupQuery/FormGroupQuery.vue +166 -166
  21. package/src/base-client/components/common/FormGroupQuery/index.js +3 -3
  22. package/src/base-client/components/common/FormGroupQuery/index.md +43 -43
  23. package/src/base-client/components/common/JSONToTree/jsontotree.vue +271 -271
  24. package/src/base-client/components/common/PersonSetting/PersonSetting.vue +208 -208
  25. package/src/base-client/components/common/PersonSetting/index.js +3 -3
  26. package/src/base-client/components/common/Tree/Tree.vue +149 -149
  27. package/src/base-client/components/common/Tree/index.js +2 -2
  28. package/src/base-client/components/common/Upload/index.js +3 -3
  29. package/src/base-client/components/common/XAddNativeForm/index.md +146 -146
  30. package/src/base-client/components/common/XCard/XCard.vue +64 -64
  31. package/src/base-client/components/common/XDataDrawer/XDataDrawer.vue +180 -180
  32. package/src/base-client/components/common/XDataDrawer/index.js +3 -3
  33. package/src/base-client/components/common/XDataDrawer/index.md +41 -41
  34. package/src/base-client/components/common/XDescriptions/index.js +3 -3
  35. package/src/base-client/components/common/XDescriptions/index.md +322 -322
  36. package/src/base-client/components/common/XForm/index.md +178 -178
  37. package/src/base-client/components/common/XFormTable/demo.vue +2 -4
  38. package/src/base-client/components/common/XReport/print.js +186 -186
  39. package/src/base-client/components/common/XReportGrid/XReportTrGroup.vue +1 -1
  40. package/src/base-client/components/common/XStepView/XStepView.vue +252 -252
  41. package/src/base-client/components/common/XStepView/index.js +3 -3
  42. package/src/base-client/components/common/XStepView/index.md +31 -31
  43. package/src/base-client/components/common/XTable/XTable.vue +1715 -1715
  44. package/src/base-client/components/common/XTable/XTableWrapper.vue +786 -769
  45. package/src/base-client/components/common/XTable/index.md +255 -255
  46. package/src/base-client/components/system/DictionaryDetailsView/DictionaryDetailsView.vue +232 -232
  47. package/src/base-client/plugins/Config.js +19 -19
  48. package/src/base-client/plugins/tabs-page-plugin.js +39 -39
  49. package/src/components/Charts/Bar.vue +62 -62
  50. package/src/components/Charts/ChartCard.vue +134 -134
  51. package/src/components/Charts/Liquid.vue +67 -67
  52. package/src/components/Charts/MiniArea.vue +39 -39
  53. package/src/components/Charts/MiniBar.vue +39 -39
  54. package/src/components/Charts/MiniProgress.vue +75 -75
  55. package/src/components/Charts/MiniSmoothArea.vue +40 -40
  56. package/src/components/Charts/Radar.vue +68 -68
  57. package/src/components/Charts/RankList.vue +77 -77
  58. package/src/components/Charts/TagCloud.vue +113 -113
  59. package/src/components/Charts/TransferBar.vue +64 -64
  60. package/src/components/Charts/Trend.vue +82 -82
  61. package/src/components/Charts/chart.less +12 -12
  62. package/src/components/Charts/smooth.area.less +13 -13
  63. package/src/components/NumberInfo/NumberInfo.vue +54 -54
  64. package/src/components/NumberInfo/index.js +3 -3
  65. package/src/components/NumberInfo/index.less +54 -54
  66. package/src/components/NumberInfo/index.md +43 -43
  67. package/src/components/card/ChartCard.vue +79 -79
  68. package/src/components/chart/Bar.vue +60 -60
  69. package/src/components/chart/MiniArea.vue +67 -67
  70. package/src/components/chart/MiniBar.vue +59 -59
  71. package/src/components/chart/MiniProgress.vue +57 -57
  72. package/src/components/chart/Radar.vue +80 -80
  73. package/src/components/chart/RankingList.vue +60 -60
  74. package/src/components/chart/Trend.vue +79 -79
  75. package/src/components/chart/index.less +9 -9
  76. package/src/components/checkbox/ColorCheckbox.vue +157 -157
  77. package/src/components/input/IInput.vue +66 -66
  78. package/src/components/menu/SideMenu.vue +75 -75
  79. package/src/components/menu/menu.js +273 -273
  80. package/src/components/tool/AStepItem.vue +60 -60
  81. package/src/composables/demo/UseRequestDemo.vue +175 -0
  82. package/src/composables/index.js +6 -0
  83. package/src/composables/useGlobalLoading.js +206 -0
  84. package/src/composables/usePost.js +221 -0
  85. package/src/layouts/CommonLayout.vue +56 -56
  86. package/src/layouts/header/HeaderNotice.vue +177 -177
  87. package/src/lib.js +1 -1
  88. package/src/mock/extend/index.js +84 -84
  89. package/src/mock/goods/index.js +108 -108
  90. package/src/pages/dashboard/workplace/WorkPlace.vue +141 -141
  91. package/src/pages/system/dictionary/index.vue +44 -44
  92. package/src/pages/system/monitor/loginInfor/index.vue +37 -37
  93. package/src/pages/system/monitor/operLog/index.vue +37 -37
  94. package/src/services/api/cas.js +79 -79
  95. package/src/services/api/common.js +11 -11
  96. package/src/services/api/restTools.js +36 -46
  97. package/src/store/modules/setting.js +119 -119
  98. package/src/utils/authority-utils.js +85 -85
  99. package/src/utils/errorCode.js +6 -6
  100. package/src/utils/map-utils.js +47 -47
  101. package/src/utils/request.js +103 -0
  102. package/vue.config.js +9 -4
  103. package//350/277/201/347/247/273/346/227/245/345/277/227.md +15 -15
@@ -1,59 +1,59 @@
1
- <template>
2
- <div class="mini-chart">
3
- <div class="chart-content" :style="{height: 46}">
4
- <v-chart :force-fit="true" :height="height" :data="data" :padding="[36, 5, 18, 5]">
5
- <v-tooltip />
6
- <v-bar position="x*y" />
7
- </v-chart>
8
- </div>
9
- </div>
10
- </template>
11
-
12
- <script>
13
- import { format } from 'date-fns'
14
-
15
- const data = []
16
- const beginDay = new Date().getTime()
17
-
18
- const fakeY = [7, 5, 4, 2, 4, 7, 5, 6, 5, 9, 6, 3, 1, 5, 3, 6, 5]
19
- for (let i = 0; i < fakeY.length; i += 1) {
20
- data.push({
21
- x: format(new Date(beginDay + 1000 * 60 * 60 * 24 * i), 'yyyy-MM-dd'),
22
- y: fakeY[i]
23
- })
24
- }
25
-
26
- const tooltip = [
27
- 'x*y',
28
- (x, y) => ({
29
- name: x,
30
- value: y
31
- })
32
- ]
33
-
34
- const scale = [{
35
- dataKey: 'x',
36
- min: 2
37
- }, {
38
- dataKey: 'y',
39
- title: '时间',
40
- min: 1,
41
- max: 22
42
- }]
43
-
44
- export default {
45
- name: 'MiniBar',
46
- data () {
47
- return {
48
- data,
49
- scale,
50
- tooltip,
51
- height: 100
52
- }
53
- }
54
- }
55
- </script>
56
-
57
- <style lang="less" scoped>
58
- @import "index.less";
59
- </style>
1
+ <template>
2
+ <div class="mini-chart">
3
+ <div class="chart-content" :style="{height: 46}">
4
+ <v-chart :force-fit="true" :height="height" :data="data" :padding="[36, 5, 18, 5]">
5
+ <v-tooltip />
6
+ <v-bar position="x*y" />
7
+ </v-chart>
8
+ </div>
9
+ </div>
10
+ </template>
11
+
12
+ <script>
13
+ import { format } from 'date-fns'
14
+
15
+ const data = []
16
+ const beginDay = new Date().getTime()
17
+
18
+ const fakeY = [7, 5, 4, 2, 4, 7, 5, 6, 5, 9, 6, 3, 1, 5, 3, 6, 5]
19
+ for (let i = 0; i < fakeY.length; i += 1) {
20
+ data.push({
21
+ x: format(new Date(beginDay + 1000 * 60 * 60 * 24 * i), 'yyyy-MM-dd'),
22
+ y: fakeY[i]
23
+ })
24
+ }
25
+
26
+ const tooltip = [
27
+ 'x*y',
28
+ (x, y) => ({
29
+ name: x,
30
+ value: y
31
+ })
32
+ ]
33
+
34
+ const scale = [{
35
+ dataKey: 'x',
36
+ min: 2
37
+ }, {
38
+ dataKey: 'y',
39
+ title: '时间',
40
+ min: 1,
41
+ max: 22
42
+ }]
43
+
44
+ export default {
45
+ name: 'MiniBar',
46
+ data () {
47
+ return {
48
+ data,
49
+ scale,
50
+ tooltip,
51
+ height: 100
52
+ }
53
+ }
54
+ }
55
+ </script>
56
+
57
+ <style lang="less" scoped>
58
+ @import "index.less";
59
+ </style>
@@ -1,57 +1,57 @@
1
- <template>
2
- <div class="mini-progress">
3
- <a-tooltip :title="'目标值:' + target + '%'">
4
- <div class="target" :style="{left: target + '%'}">
5
- <span :style="{backgroundColor: color}" />
6
- <span :style="{backgroundColor: color}" />
7
- </div>
8
- </a-tooltip>
9
- <div class="wrap">
10
- <div class="progress" :style="{backgroundColor: color, width: percent + '%', height: height}" />
11
- </div>
12
- </div>
13
- </template>
14
-
15
- <script>
16
- export default {
17
- name: 'MiniProgress',
18
- // eslint-disable-next-line vue/require-prop-types
19
- props: ['target', 'color', 'percent', 'height']
20
- }
21
- </script>
22
-
23
- <style lang="less" scoped>
24
- .mini-progress {
25
- padding: 5px 0;
26
- position: relative;
27
- width: 100%;
28
- .wrap {
29
- background-color: @layout-bg-color;
30
- position: relative;
31
- }
32
- .progress {
33
- transition: all 0.4s cubic-bezier(0.08, 0.82, 0.17, 1) 0s;
34
- border-radius: 1px 0 0 1px;
35
- background-color: #13C2C2;
36
- width: 0;
37
- height: 100%;
38
- }
39
- .target {
40
- position: absolute;
41
- top: 0;
42
- bottom: 0;
43
- span {
44
- border-radius: 100px;
45
- position: absolute;
46
- top: 0;
47
- left: 0;
48
- height: 4px;
49
- width: 2px;
50
- }
51
- span:last-child {
52
- top: auto;
53
- bottom: 0;
54
- }
55
- }
56
- }
57
- </style>
1
+ <template>
2
+ <div class="mini-progress">
3
+ <a-tooltip :title="'目标值:' + target + '%'">
4
+ <div class="target" :style="{left: target + '%'}">
5
+ <span :style="{backgroundColor: color}" />
6
+ <span :style="{backgroundColor: color}" />
7
+ </div>
8
+ </a-tooltip>
9
+ <div class="wrap">
10
+ <div class="progress" :style="{backgroundColor: color, width: percent + '%', height: height}" />
11
+ </div>
12
+ </div>
13
+ </template>
14
+
15
+ <script>
16
+ export default {
17
+ name: 'MiniProgress',
18
+ // eslint-disable-next-line vue/require-prop-types
19
+ props: ['target', 'color', 'percent', 'height']
20
+ }
21
+ </script>
22
+
23
+ <style lang="less" scoped>
24
+ .mini-progress {
25
+ padding: 5px 0;
26
+ position: relative;
27
+ width: 100%;
28
+ .wrap {
29
+ background-color: @layout-bg-color;
30
+ position: relative;
31
+ }
32
+ .progress {
33
+ transition: all 0.4s cubic-bezier(0.08, 0.82, 0.17, 1) 0s;
34
+ border-radius: 1px 0 0 1px;
35
+ background-color: #13C2C2;
36
+ width: 0;
37
+ height: 100%;
38
+ }
39
+ .target {
40
+ position: absolute;
41
+ top: 0;
42
+ bottom: 0;
43
+ span {
44
+ border-radius: 100px;
45
+ position: absolute;
46
+ top: 0;
47
+ left: 0;
48
+ height: 4px;
49
+ width: 2px;
50
+ }
51
+ span:last-child {
52
+ top: auto;
53
+ bottom: 0;
54
+ }
55
+ }
56
+ }
57
+ </style>
@@ -1,80 +1,80 @@
1
- <template>
2
- <v-chart :forceFit="true" height="400" :data="data" :padding="[20, 20, 95, 20]" :scale="scale">
3
- <v-tooltip />
4
- <v-axis :dataKey="axis1Opts.dataKey" :line="axis1Opts.line" :tickLine="axis1Opts.tickLine" :grid="axis1Opts.grid" />
5
- <v-axis :dataKey="axis2Opts.dataKey" :line="axis2Opts.line" :tickLine="axis2Opts.tickLine" :grid="axis2Opts.grid" />
6
- <v-legend dataKey="user" marker="circle" :offset="30" />
7
- <v-coord type="polar" radius="0.8" />
8
- <v-line position="item*score" color="user" :size="2" />
9
- <v-point position="item*score" color="user" :size="4" shape="circle" />
10
- </v-chart>
11
- </template>
12
-
13
- <script>
14
- const DataSet = require('@antv/data-set')
15
-
16
- const sourceData = [
17
- { item: '引用', a: 70, b: 30, c: 40 },
18
- { item: '口碑', a: 60, b: 70, c: 40 },
19
- { item: '产量', a: 50, b: 60, c: 40 },
20
- { item: '贡献', a: 40, b: 50, c: 40 },
21
- { item: '热度', a: 60, b: 70, c: 40 },
22
- { item: '引用', a: 70, b: 50, c: 40 }
23
- ]
24
-
25
- const dv = new DataSet.View().source(sourceData)
26
- dv.transform({
27
- type: 'fold',
28
- fields: ['a', 'b', 'c'],
29
- key: 'user',
30
- value: 'score'
31
- })
32
-
33
- const scale = [{
34
- dataKey: 'score',
35
- min: 0,
36
- max: 80
37
- }]
38
-
39
- const data = dv.rows
40
-
41
- const axis1Opts = {
42
- dataKey: 'item',
43
- line: null,
44
- tickLine: null,
45
- grid: {
46
- lineStyle: {
47
- lineDash: null
48
- },
49
- hideFirstLine: false
50
- }
51
- }
52
- const axis2Opts = {
53
- dataKey: 'score',
54
- line: null,
55
- tickLine: null,
56
- grid: {
57
- type: 'polygon',
58
- lineStyle: {
59
- lineDash: null
60
- }
61
- }
62
- }
63
-
64
- export default {
65
- name: 'Radar',
66
- data () {
67
- return {
68
- sourceData,
69
- data,
70
- axis1Opts,
71
- axis2Opts,
72
- scale
73
- }
74
- }
75
- }
76
- </script>
77
-
78
- <style scoped>
79
-
80
- </style>
1
+ <template>
2
+ <v-chart :forceFit="true" height="400" :data="data" :padding="[20, 20, 95, 20]" :scale="scale">
3
+ <v-tooltip />
4
+ <v-axis :dataKey="axis1Opts.dataKey" :line="axis1Opts.line" :tickLine="axis1Opts.tickLine" :grid="axis1Opts.grid" />
5
+ <v-axis :dataKey="axis2Opts.dataKey" :line="axis2Opts.line" :tickLine="axis2Opts.tickLine" :grid="axis2Opts.grid" />
6
+ <v-legend dataKey="user" marker="circle" :offset="30" />
7
+ <v-coord type="polar" radius="0.8" />
8
+ <v-line position="item*score" color="user" :size="2" />
9
+ <v-point position="item*score" color="user" :size="4" shape="circle" />
10
+ </v-chart>
11
+ </template>
12
+
13
+ <script>
14
+ const DataSet = require('@antv/data-set')
15
+
16
+ const sourceData = [
17
+ { item: '引用', a: 70, b: 30, c: 40 },
18
+ { item: '口碑', a: 60, b: 70, c: 40 },
19
+ { item: '产量', a: 50, b: 60, c: 40 },
20
+ { item: '贡献', a: 40, b: 50, c: 40 },
21
+ { item: '热度', a: 60, b: 70, c: 40 },
22
+ { item: '引用', a: 70, b: 50, c: 40 }
23
+ ]
24
+
25
+ const dv = new DataSet.View().source(sourceData)
26
+ dv.transform({
27
+ type: 'fold',
28
+ fields: ['a', 'b', 'c'],
29
+ key: 'user',
30
+ value: 'score'
31
+ })
32
+
33
+ const scale = [{
34
+ dataKey: 'score',
35
+ min: 0,
36
+ max: 80
37
+ }]
38
+
39
+ const data = dv.rows
40
+
41
+ const axis1Opts = {
42
+ dataKey: 'item',
43
+ line: null,
44
+ tickLine: null,
45
+ grid: {
46
+ lineStyle: {
47
+ lineDash: null
48
+ },
49
+ hideFirstLine: false
50
+ }
51
+ }
52
+ const axis2Opts = {
53
+ dataKey: 'score',
54
+ line: null,
55
+ tickLine: null,
56
+ grid: {
57
+ type: 'polygon',
58
+ lineStyle: {
59
+ lineDash: null
60
+ }
61
+ }
62
+ }
63
+
64
+ export default {
65
+ name: 'Radar',
66
+ data () {
67
+ return {
68
+ sourceData,
69
+ data,
70
+ axis1Opts,
71
+ axis2Opts,
72
+ scale
73
+ }
74
+ }
75
+ }
76
+ </script>
77
+
78
+ <style scoped>
79
+
80
+ </style>
@@ -1,60 +1,60 @@
1
- <template>
2
- <div class="rank">
3
- <h4 class="title">{{ title }}</h4>
4
- <ul class="list">
5
- <li :key="index" v-for="(item, index) in list">
6
- <span :class="index < 3 ? 'active' : null">{{ index + 1 }}</span>
7
- <span >{{ item.name }}</span>
8
- <span >{{ item.total }}</span>
9
- </li>
10
- </ul>
11
- </div>
12
- </template>
13
-
14
- <script>
15
- export default {
16
- name: 'RankingList',
17
- // eslint-disable-next-line vue/require-prop-types
18
- props: ['title', 'list']
19
- }
20
- </script>
21
-
22
- <style lang="less" scoped>
23
- .rank{
24
- padding: 0 32px 32px 72px;
25
- .title{
26
- }
27
- .list{
28
- margin: 25px 0 0;
29
- padding: 0;
30
- list-style: none;
31
- li {
32
- margin-top: 16px;
33
- span {
34
- color: @text-color-second;
35
- font-size: 14px;
36
- line-height: 22px;
37
- }
38
- span:first-child {
39
- background-color: @layout-bg-color;
40
- border-radius: 20px;
41
- display: inline-block;
42
- font-size: 12px;
43
- font-weight: 600;
44
- margin-right: 24px;
45
- height: 20px;
46
- line-height: 20px;
47
- width: 20px;
48
- text-align: center;
49
- }
50
- span.active {
51
- background-color: #314659 !important;
52
- color: @text-color-inverse !important;
53
- }
54
- span:last-child {
55
- float: right;
56
- }
57
- }
58
- }
59
- }
60
- </style>
1
+ <template>
2
+ <div class="rank">
3
+ <h4 class="title">{{ title }}</h4>
4
+ <ul class="list">
5
+ <li :key="index" v-for="(item, index) in list">
6
+ <span :class="index < 3 ? 'active' : null">{{ index + 1 }}</span>
7
+ <span >{{ item.name }}</span>
8
+ <span >{{ item.total }}</span>
9
+ </li>
10
+ </ul>
11
+ </div>
12
+ </template>
13
+
14
+ <script>
15
+ export default {
16
+ name: 'RankingList',
17
+ // eslint-disable-next-line vue/require-prop-types
18
+ props: ['title', 'list']
19
+ }
20
+ </script>
21
+
22
+ <style lang="less" scoped>
23
+ .rank{
24
+ padding: 0 32px 32px 72px;
25
+ .title{
26
+ }
27
+ .list{
28
+ margin: 25px 0 0;
29
+ padding: 0;
30
+ list-style: none;
31
+ li {
32
+ margin-top: 16px;
33
+ span {
34
+ color: @text-color-second;
35
+ font-size: 14px;
36
+ line-height: 22px;
37
+ }
38
+ span:first-child {
39
+ background-color: @layout-bg-color;
40
+ border-radius: 20px;
41
+ display: inline-block;
42
+ font-size: 12px;
43
+ font-weight: 600;
44
+ margin-right: 24px;
45
+ height: 20px;
46
+ line-height: 20px;
47
+ width: 20px;
48
+ text-align: center;
49
+ }
50
+ span.active {
51
+ background-color: #314659 !important;
52
+ color: @text-color-inverse !important;
53
+ }
54
+ span:last-child {
55
+ float: right;
56
+ }
57
+ }
58
+ }
59
+ }
60
+ </style>
@@ -1,79 +1,79 @@
1
- <template>
2
- <div class="chart-trend">
3
- {{ term }}
4
- <span>{{ rate }}%</span>
5
- <span :class="['chart-trend-icon', trend]" style=""><a-icon :type="'caret-' + trend" /></span>
6
- </div>
7
- </template>
8
-
9
- <script>
10
- export default {
11
- name: 'Trend',
12
- props: {
13
- term: {
14
- type: String,
15
- required: true
16
- },
17
- target: {
18
- type: Number,
19
- required: false,
20
- default: 0
21
- },
22
- value: {
23
- type: Number,
24
- required: false,
25
- default: 0
26
- },
27
- isIncrease: {
28
- type: Boolean,
29
- required: false,
30
- default: null
31
- },
32
- percent: {
33
- type: Number,
34
- required: false,
35
- default: null
36
- },
37
- scale: {
38
- type: Number,
39
- required: false,
40
- default: 2
41
- }
42
- },
43
- data () {
44
- return {
45
- trend: this.isIncrease ? 'up' : 'down',
46
- rate: this.percent
47
- }
48
- },
49
- created () {
50
- this.trend = this.caulateTrend()
51
- this.rate = this.caulateRate()
52
- },
53
- methods: {
54
- caulateRate () {
55
- return (this.percent === null ? Math.abs(this.value - this.target) * 100 / this.target : this.percent).toFixed(this.scale)
56
- },
57
- caulateTrend () {
58
- const isIncrease = this.isIncrease === null ? this.value >= this.target : this.isIncrease
59
- return isIncrease ? 'up' : 'down'
60
- }
61
- }
62
- }
63
- </script>
64
-
65
- <style lang="less" scoped>
66
- .chart-trend{
67
- display: inline-block;
68
- font-size: 14px;
69
- .chart-trend-icon{
70
- font-size: 12px;
71
- &.up{
72
- color: @red-6;
73
- }
74
- &.down{
75
- color: @green-6;
76
- }
77
- }
78
- }
79
- </style>
1
+ <template>
2
+ <div class="chart-trend">
3
+ {{ term }}
4
+ <span>{{ rate }}%</span>
5
+ <span :class="['chart-trend-icon', trend]" style=""><a-icon :type="'caret-' + trend" /></span>
6
+ </div>
7
+ </template>
8
+
9
+ <script>
10
+ export default {
11
+ name: 'Trend',
12
+ props: {
13
+ term: {
14
+ type: String,
15
+ required: true
16
+ },
17
+ target: {
18
+ type: Number,
19
+ required: false,
20
+ default: 0
21
+ },
22
+ value: {
23
+ type: Number,
24
+ required: false,
25
+ default: 0
26
+ },
27
+ isIncrease: {
28
+ type: Boolean,
29
+ required: false,
30
+ default: null
31
+ },
32
+ percent: {
33
+ type: Number,
34
+ required: false,
35
+ default: null
36
+ },
37
+ scale: {
38
+ type: Number,
39
+ required: false,
40
+ default: 2
41
+ }
42
+ },
43
+ data () {
44
+ return {
45
+ trend: this.isIncrease ? 'up' : 'down',
46
+ rate: this.percent
47
+ }
48
+ },
49
+ created () {
50
+ this.trend = this.caulateTrend()
51
+ this.rate = this.caulateRate()
52
+ },
53
+ methods: {
54
+ caulateRate () {
55
+ return (this.percent === null ? Math.abs(this.value - this.target) * 100 / this.target : this.percent).toFixed(this.scale)
56
+ },
57
+ caulateTrend () {
58
+ const isIncrease = this.isIncrease === null ? this.value >= this.target : this.isIncrease
59
+ return isIncrease ? 'up' : 'down'
60
+ }
61
+ }
62
+ }
63
+ </script>
64
+
65
+ <style lang="less" scoped>
66
+ .chart-trend{
67
+ display: inline-block;
68
+ font-size: 14px;
69
+ .chart-trend-icon{
70
+ font-size: 12px;
71
+ &.up{
72
+ color: @red-6;
73
+ }
74
+ &.down{
75
+ color: @green-6;
76
+ }
77
+ }
78
+ }
79
+ </style>