vue2-client 1.4.2 → 1.4.3

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 (99) hide show
  1. package/.env +15 -15
  2. package/.eslintrc.js +82 -82
  3. package/index.js +30 -30
  4. package/package.json +78 -78
  5. package/src/base-client/components/common/AddressSearchCombobox/AddressSearchCombobox.vue +225 -225
  6. package/src/base-client/components/common/AmapMarker/AmapPointRendering.vue +113 -113
  7. package/src/base-client/components/common/CitySelect/CitySelect.vue +244 -244
  8. package/src/base-client/components/common/CitySelect/index.js +3 -3
  9. package/src/base-client/components/common/CitySelect/index.md +109 -109
  10. package/src/base-client/components/common/CreateQuery/CreateQuery.vue +589 -543
  11. package/src/base-client/components/common/CreateQuery/CreateQueryItem.vue +777 -777
  12. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQuery.vue +310 -310
  13. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQueryItem.vue +553 -553
  14. package/src/base-client/components/common/FormGroupQuery/FormGroupQuery.vue +165 -165
  15. package/src/base-client/components/common/JSONToTree/jsontotree.vue +275 -275
  16. package/src/base-client/components/common/PersonSetting/PersonSetting.vue +210 -210
  17. package/src/base-client/components/common/PersonSetting/index.js +3 -3
  18. package/src/base-client/components/common/Upload/index.js +3 -3
  19. package/src/base-client/components/common/XAddForm/XAddForm.vue +354 -354
  20. package/src/base-client/components/common/XAddNativeForm/XAddNativeForm.vue +327 -327
  21. package/src/base-client/components/common/XCard/XCard.vue +64 -64
  22. package/src/base-client/components/common/XForm/XForm.vue +274 -274
  23. package/src/base-client/components/common/XForm/XFormItem.vue +389 -389
  24. package/src/base-client/components/common/XFormTable/index.md +96 -96
  25. package/src/base-client/components/common/XTable/XTable.vue +259 -259
  26. package/src/base-client/components/system/QueryParamsDetailsView/QueryParamsDetailsView.vue +281 -281
  27. package/src/base-client/components/ticket/TicketDetailsView/TicketDetailsView.vue +807 -807
  28. package/src/base-client/components/ticket/TicketDetailsView/index.md +29 -29
  29. package/src/base-client/components/ticket/TicketDetailsView/part/TicketDetailsFlow.vue +260 -260
  30. package/src/base-client/components/ticket/TicketSubmitSuccessView/TicketSubmitSuccessView.vue +532 -532
  31. package/src/base-client/components/ticket/TicketSubmitSuccessView/index.md +29 -29
  32. package/src/base-client/plugins/AppData.js +69 -69
  33. package/src/base-client/plugins/GetLoginInfoService.js +179 -179
  34. package/src/base-client/plugins/PagedList.js +177 -177
  35. package/src/base-client/plugins/compatible/LoginServiceOA.js +20 -20
  36. package/src/base-client/plugins/i18n-extend.js +32 -32
  37. package/src/components/Ellipsis/index.md +38 -38
  38. package/src/components/NumberInfo/index.md +43 -43
  39. package/src/components/STable/README.md +341 -341
  40. package/src/components/STable/index.js +318 -318
  41. package/src/components/Trend/index.md +45 -45
  42. package/src/components/checkbox/ColorCheckbox.vue +157 -157
  43. package/src/components/checkbox/ImgCheckbox.vue +163 -163
  44. package/src/components/exception/ExceptionPage.vue +70 -70
  45. package/src/components/form/FormRow.vue +52 -52
  46. package/src/components/index.js +36 -36
  47. package/src/components/menu/SideMenu.vue +62 -62
  48. package/src/components/menu/menu.js +273 -273
  49. package/src/components/setting/Setting.vue +235 -235
  50. package/src/components/table/StandardTable.vue +141 -141
  51. package/src/components/table/advance/ActionColumns.vue +158 -158
  52. package/src/components/table/advance/SearchArea.vue +355 -355
  53. package/src/components/tool/AStepItem.vue +60 -60
  54. package/src/components/tool/AvatarList.vue +68 -68
  55. package/src/components/tool/Drawer.vue +142 -142
  56. package/src/components/tool/TagSelect.vue +83 -83
  57. package/src/components/transition/PageToggleTransition.vue +97 -97
  58. package/src/config/CreateQueryConfig.js +307 -307
  59. package/src/config/replacer/resolve.config.js +67 -67
  60. package/src/layouts/AdminLayout.vue +174 -174
  61. package/src/layouts/header/AdminHeader.vue +104 -104
  62. package/src/layouts/header/HeaderNotice.vue +167 -167
  63. package/src/layouts/header/HeaderSearch.vue +67 -67
  64. package/src/layouts/header/InstitutionDetail.vue +181 -181
  65. package/src/layouts/tabs/TabsHead.vue +190 -190
  66. package/src/layouts/tabs/TabsView.vue +379 -379
  67. package/src/mock/goods/index.js +108 -108
  68. package/src/pages/CreateQueryPage.vue +65 -65
  69. package/src/pages/report/ReportTable.js +124 -124
  70. package/src/pages/report/ReportTableHome.vue +28 -28
  71. package/src/pages/resourceManage/orgListManage.vue +98 -98
  72. package/src/pages/system/dictionary/index.vue +43 -43
  73. package/src/pages/system/file/index.vue +317 -317
  74. package/src/pages/system/queryParams/index.vue +43 -43
  75. package/src/router/async/config.async.js +27 -27
  76. package/src/router/async/router.map.js +2 -0
  77. package/src/router/index.js +27 -27
  78. package/src/services/api/DictionaryDetailsViewApi.js +6 -6
  79. package/src/services/api/LogDetailsViewApi.js +10 -10
  80. package/src/services/api/QueryParamsDetailsViewApi.js +6 -6
  81. package/src/services/api/TicketDetailsViewApi.js +34 -34
  82. package/src/services/api/commonTempTable.js +10 -10
  83. package/src/services/api/index.js +17 -17
  84. package/src/services/api/manage.js +8 -8
  85. package/src/services/api/restTools.js +24 -24
  86. package/src/store/mutation-types.js +2 -2
  87. package/src/theme/default/nprogress.less +76 -76
  88. package/src/theme/default/style.less +47 -47
  89. package/src/utils/colors.js +103 -103
  90. package/src/utils/excel/Blob.js +180 -180
  91. package/src/utils/excel/Export2Excel.js +141 -141
  92. package/src/utils/formatter.js +68 -68
  93. package/src/utils/i18n.js +80 -80
  94. package/src/utils/request.js +225 -225
  95. package/src/utils/routerUtil.js +364 -364
  96. package/src/utils/theme-color-replacer-extend.js +91 -91
  97. package/src/utils/themeUtil.js +100 -100
  98. package/src/utils/util.js +230 -230
  99. package/vue.config.js +2 -2
@@ -1,108 +1,108 @@
1
- import Mock from 'mockjs'
2
- import '@vue2-client/mock/extend'
3
- import { parseUrlParams } from '@vue2-client/utils/request'
4
-
5
- const current = new Date().getTime()
6
-
7
- const goodsList = Mock.mock({
8
- 'list|100': [{
9
- 'id|+1': 0,
10
- 'name': '@GOODS',
11
- 'orderId': `${current}-@integer(1,100)`,
12
- 'status|1-4': 1,
13
- 'send': '@BOOLEAN',
14
- 'sendTime': '@DATETIME',
15
- 'orderDate': '@DATE',
16
- 'auditTime': '@TIME'
17
- }]
18
- })
19
-
20
- Mock.mock(RegExp(`${process.env.VUE_APP_API_BASE_URL}/goods` + '.*'), 'get', ({ url }) => {
21
- const params = parseUrlParams(decodeURI(url))
22
- let { page, pageSize } = params
23
- // eslint-disable-next-line no-eval
24
- page = eval(page) - 1 || 0
25
- // eslint-disable-next-line no-eval
26
- pageSize = eval(pageSize) || 10
27
- delete params.page
28
- delete params.pageSize
29
- let result = goodsList.list.filter(item => {
30
- for (const [key, value] of Object.entries(params)) {
31
- if (item[key] !== value) {
32
- return false
33
- }
34
- }
35
- return true
36
- })
37
- const total = result.length
38
- if ((page) * pageSize > total) {
39
- result = []
40
- } else {
41
- result = result.slice(page * pageSize, (page + 1) * pageSize)
42
- }
43
- return {
44
- code: 0,
45
- message: 'success',
46
- data: {
47
- page: page + 1,
48
- pageSize,
49
- total,
50
- list: result
51
- }
52
- }
53
- })
54
-
55
- const columnsConfig = [
56
- {
57
- title: '商品名称',
58
- dataIndex: 'name',
59
- searchAble: true
60
- },
61
- {
62
- title: '订单号',
63
- dataIndex: 'orderId'
64
- },
65
- {
66
- searchAble: true,
67
- dataIndex: 'status',
68
- dataType: 'select',
69
- slots: { title: 'statusTitle' },
70
- scopedSlots: { customRender: 'status' },
71
- search: {
72
- selectOptions: [
73
- { title: '已下单', value: 1 },
74
- { title: '已付款', value: 2 },
75
- { title: '已审核', value: 3 }
76
- // {title: '已发货', value: 4}
77
- ]
78
- }
79
- },
80
- {
81
- title: '发货',
82
- searchAble: true,
83
- dataIndex: 'send',
84
- dataType: 'boolean',
85
- scopedSlots: { customRender: 'send' }
86
- },
87
- {
88
- title: '发货时间',
89
- dataIndex: 'sendTime',
90
- dataType: 'datetime'
91
- },
92
- {
93
- title: '下单日期',
94
- searchAble: true,
95
- dataIndex: 'orderDate',
96
- dataType: 'date',
97
- visible: false
98
- },
99
- {
100
- title: '审核时间',
101
- dataIndex: 'auditTime',
102
- dataType: 'time'
103
- }
104
- ]
105
-
106
- Mock.mock(`${process.env.VUE_APP_API_BASE_URL}/columns`, 'get', () => {
107
- return columnsConfig
108
- })
1
+ import Mock from 'mockjs'
2
+ import '@vue2-client/mock/extend'
3
+ import { parseUrlParams } from '@vue2-client/utils/request'
4
+
5
+ const current = new Date().getTime()
6
+
7
+ const goodsList = Mock.mock({
8
+ 'list|100': [{
9
+ 'id|+1': 0,
10
+ 'name': '@GOODS',
11
+ 'orderId': `${current}-@integer(1,100)`,
12
+ 'status|1-4': 1,
13
+ 'send': '@BOOLEAN',
14
+ 'sendTime': '@DATETIME',
15
+ 'orderDate': '@DATE',
16
+ 'auditTime': '@TIME'
17
+ }]
18
+ })
19
+
20
+ Mock.mock(RegExp(`${process.env.VUE_APP_API_BASE_URL}/goods` + '.*'), 'get', ({ url }) => {
21
+ const params = parseUrlParams(decodeURI(url))
22
+ let { page, pageSize } = params
23
+ // eslint-disable-next-line no-eval
24
+ page = eval(page) - 1 || 0
25
+ // eslint-disable-next-line no-eval
26
+ pageSize = eval(pageSize) || 10
27
+ delete params.page
28
+ delete params.pageSize
29
+ let result = goodsList.list.filter(item => {
30
+ for (const [key, value] of Object.entries(params)) {
31
+ if (item[key] !== value) {
32
+ return false
33
+ }
34
+ }
35
+ return true
36
+ })
37
+ const total = result.length
38
+ if ((page) * pageSize > total) {
39
+ result = []
40
+ } else {
41
+ result = result.slice(page * pageSize, (page + 1) * pageSize)
42
+ }
43
+ return {
44
+ code: 0,
45
+ message: 'success',
46
+ data: {
47
+ page: page + 1,
48
+ pageSize,
49
+ total,
50
+ list: result
51
+ }
52
+ }
53
+ })
54
+
55
+ const columnsConfig = [
56
+ {
57
+ title: '商品名称',
58
+ dataIndex: 'name',
59
+ searchAble: true
60
+ },
61
+ {
62
+ title: '订单号',
63
+ dataIndex: 'orderId'
64
+ },
65
+ {
66
+ searchAble: true,
67
+ dataIndex: 'status',
68
+ dataType: 'select',
69
+ slots: { title: 'statusTitle' },
70
+ scopedSlots: { customRender: 'status' },
71
+ search: {
72
+ selectOptions: [
73
+ { title: '已下单', value: 1 },
74
+ { title: '已付款', value: 2 },
75
+ { title: '已审核', value: 3 }
76
+ // {title: '已发货', value: 4}
77
+ ]
78
+ }
79
+ },
80
+ {
81
+ title: '发货',
82
+ searchAble: true,
83
+ dataIndex: 'send',
84
+ dataType: 'boolean',
85
+ scopedSlots: { customRender: 'send' }
86
+ },
87
+ {
88
+ title: '发货时间',
89
+ dataIndex: 'sendTime',
90
+ dataType: 'datetime'
91
+ },
92
+ {
93
+ title: '下单日期',
94
+ searchAble: true,
95
+ dataIndex: 'orderDate',
96
+ dataType: 'date',
97
+ visible: false
98
+ },
99
+ {
100
+ title: '审核时间',
101
+ dataIndex: 'auditTime',
102
+ dataType: 'time'
103
+ }
104
+ ]
105
+
106
+ Mock.mock(`${process.env.VUE_APP_API_BASE_URL}/columns`, 'get', () => {
107
+ return columnsConfig
108
+ })
@@ -1,65 +1,65 @@
1
- <template>
2
- <div>
3
- <create-query
4
- :visible.sync="visible"
5
- @saveQueryParams="saveQueryParams"
6
- />
7
- <create-simple-form-query
8
- :visible.sync="createSimpleFormVisible"
9
- @saveSimpleFormQueryParams="saveSimpleFormQueryParams"
10
- />
11
- <a-button style="margin-top: 10px;margin-left: 10px;" type="primary" @click="showDrawer">打开完整查询配置生成工具</a-button>
12
- <a-button style="margin-top: 10px;margin-left: 10px;" type="primary" @click="showSimpleFormQueryParamsDrawer">打开基础表单配置生成工具</a-button>
13
- <!-- <webmeter-analysis-view/>-->
14
- </div>
15
- </template>
16
-
17
- <script>
18
- import { post } from '@vue2-client/services/api/restTools'
19
- import CreateQuery from '@vue2-client/base-client/components/common/CreateQuery'
20
- import CreateSimpleFormQuery from '@vue2-client/base-client/components/common/CreateSimpleFormQuery'
21
-
22
- export default {
23
- name: 'CreateQueryPage',
24
- components: {
25
- CreateQuery,
26
- CreateSimpleFormQuery
27
- },
28
- data () {
29
- return {
30
- visible: false,
31
- createSimpleFormVisible: false
32
- }
33
- },
34
- methods: {
35
- showDrawer () {
36
- this.visible = true
37
- },
38
- showSimpleFormQueryParamsDrawer () {
39
- this.createSimpleFormVisible = true
40
- },
41
- // 存储查询配置信息
42
- saveQueryParams (source) {
43
- return post('/api/af-system/logic/addOrEditQueryParams', {
44
- source: source
45
- }).then(res => {
46
- this.$message.success('保存查询配置成功')
47
- }, err => {
48
- console.error(err)
49
- })
50
- },
51
- // 存储基础表单配置信息
52
- saveSimpleFormQueryParams (source) {
53
- return post('/api/af-system/logic/addOrEditSimpleFormQueryParams', {
54
- source: source
55
- }).then(res => {
56
- this.$message.success('保存基础表单配置成功')
57
- }, err => {
58
- console.error(err)
59
- })
60
- }
61
- }
62
- }
63
- </script>
64
- <style lang="less" scoped>
65
- </style>
1
+ <template>
2
+ <div>
3
+ <create-query
4
+ :visible.sync="visible"
5
+ @saveQueryParams="saveQueryParams"
6
+ />
7
+ <create-simple-form-query
8
+ :visible.sync="createSimpleFormVisible"
9
+ @saveSimpleFormQueryParams="saveSimpleFormQueryParams"
10
+ />
11
+ <a-button style="margin-top: 10px;margin-left: 10px;" type="primary" @click="showDrawer">打开完整查询配置生成工具</a-button>
12
+ <a-button style="margin-top: 10px;margin-left: 10px;" type="primary" @click="showSimpleFormQueryParamsDrawer">打开基础表单配置生成工具</a-button>
13
+ <!-- <webmeter-analysis-view/>-->
14
+ </div>
15
+ </template>
16
+
17
+ <script>
18
+ import { post } from '@vue2-client/services/api/restTools'
19
+ import CreateQuery from '@vue2-client/base-client/components/common/CreateQuery'
20
+ import CreateSimpleFormQuery from '@vue2-client/base-client/components/common/CreateSimpleFormQuery'
21
+
22
+ export default {
23
+ name: 'CreateQueryPage',
24
+ components: {
25
+ CreateQuery,
26
+ CreateSimpleFormQuery
27
+ },
28
+ data () {
29
+ return {
30
+ visible: false,
31
+ createSimpleFormVisible: false
32
+ }
33
+ },
34
+ methods: {
35
+ showDrawer () {
36
+ this.visible = true
37
+ },
38
+ showSimpleFormQueryParamsDrawer () {
39
+ this.createSimpleFormVisible = true
40
+ },
41
+ // 存储查询配置信息
42
+ saveQueryParams (source) {
43
+ return post('/api/af-system/logic/addOrEditQueryParams', {
44
+ source: source
45
+ }).then(res => {
46
+ this.$message.success('保存查询配置成功')
47
+ }, err => {
48
+ console.error(err)
49
+ })
50
+ },
51
+ // 存储基础表单配置信息
52
+ saveSimpleFormQueryParams (source) {
53
+ return post('/api/af-system/logic/addOrEditSimpleFormQueryParams', {
54
+ source: source
55
+ }).then(res => {
56
+ this.$message.success('保存基础表单配置成功')
57
+ }, err => {
58
+ console.error(err)
59
+ })
60
+ }
61
+ }
62
+ }
63
+ </script>
64
+ <style lang="less" scoped>
65
+ </style>
@@ -1,124 +1,124 @@
1
- export default {
2
- name: 'ReportTable',
3
- functional: true,
4
- render (h, content) {
5
- if (!content.props.tableData) {
6
- console.log('没有报表数据')
7
- return
8
- }
9
- console.log('content=>', content)
10
- const html = reportCompute(h, content.props.tableData)
11
- console.log('html=>', html)
12
- // 报表整体高度和宽度
13
- const reportClass = `h-${html.h} w-${html.w}`
14
- return (
15
- <div id='ReportTableHome'>
16
- <div id='reportTable' class={reportClass}>
17
- {html.el}
18
- </div>
19
- </div>
20
- )
21
- }
22
- }
23
- /**
24
- * class类生成
25
- * @param w 宽
26
- * @param h 高
27
- * @param l left
28
- * @param t top
29
- * @returns {string}
30
- */
31
- function generClass ({ w = 1, h = 1, l, t }) {
32
- return `w-${w} h-${h} l-${l} t-${t}`
33
- }
34
- /**
35
- * 判断是否是个Number数据
36
- * @param value
37
- * @returns {boolean}
38
- */
39
- function typeNumber (value) {
40
- return Object.prototype.toString.call(value) === '[object Number]'
41
- }
42
- /**
43
- * 判断是否是个object数据
44
- * @param value
45
- * @returns {boolean}
46
- */
47
- function typeObject (value) {
48
- return Object.prototype.toString.call(value) === '[object Object]'
49
- }
50
- /**
51
- * 判断是否是个Array数据
52
- * @param value
53
- * @returns {boolean}
54
- */
55
- function typeArray (value) {
56
- return Object.prototype.toString.call(value) === '[object Array]'
57
- }
58
- /**
59
- * 一行数据转换html函数
60
- * @param h vue的h
61
- * @param row 一行json数据
62
- * @param left 起始left距离
63
- * @param top 起始top距离
64
- * @returns {{el: Array, h: number}}
65
- */
66
- function rowCompute (h, row, left, top) {
67
- if (typeObject(row)) {
68
- const el = []
69
- const keys = Object.keys(row).filter((res) => res !== 'span')
70
- let heigth = 0
71
- for (const key of keys.values()) {
72
- const value = row[key]['value'] ? row[key]['value'] : row[key]
73
- const style = { l: left, t: top + heigth }
74
- style.w = row[key]['span'] ? row[key]['span'] : 1
75
- const nextL = left + style.w
76
- const nextT = top + heigth
77
- const divObject = rowCompute(h, value, nextL, nextT)
78
- el.push(divObject.el)
79
- style.h = divObject.h ? divObject.h : 1
80
- heigth += style.h
81
- const attrs = { class: generClass(style) + ' title' }
82
- const div = <div {...attrs}>{key === 'value' ? value : key}</div>
83
- el.push(div)
84
- }
85
- return { h: heigth, el: el }
86
- } else if (typeArray(row)) {
87
- const el = []
88
- for (const [i, value] of row.entries()) {
89
- const style = { l: (left + i), t: top, w: 1, h: 1 }
90
- const extraClass = typeNumber(value) ? 'bold' : 'title'
91
- const attrs = { class: generClass(style) + ` ${extraClass}` }
92
- const div = <div {...attrs}>{value}</div>
93
- el.push(div)
94
- }
95
- return { h: 1, el: el }
96
- }
97
- }
98
- /**
99
- * 完整报表数据转换html函数
100
- * @param h vue的h
101
- * @param jsonArr json数组
102
- * @returns {{el: Array, h: number}}
103
- */
104
- function reportCompute (h, jsonArr) {
105
- const html = []
106
- let heigth = 0
107
- let width = 0
108
- for (const [index, row] of jsonArr.entries()) {
109
- const rowHtml = rowCompute(h, row, 0, index)
110
- // 取第一行的宽度作为整个报表的宽度
111
- if (index === 0) {
112
- const reg = /w-\d\s/
113
- for (const vNode of rowHtml.el) {
114
- if (!vNode.data || !vNode.data.class) continue
115
- const c = vNode.data.class
116
- const w = c.match(reg)[0].split('-')[1]
117
- width += (w - 0)
118
- }
119
- }
120
- heigth += rowHtml.h
121
- html.push(rowHtml.el)
122
- }
123
- return { el: html, h: heigth, w: width }
124
- }
1
+ export default {
2
+ name: 'ReportTable',
3
+ functional: true,
4
+ render (h, content) {
5
+ if (!content.props.tableData) {
6
+ console.log('没有报表数据')
7
+ return
8
+ }
9
+ console.log('content=>', content)
10
+ const html = reportCompute(h, content.props.tableData)
11
+ console.log('html=>', html)
12
+ // 报表整体高度和宽度
13
+ const reportClass = `h-${html.h} w-${html.w}`
14
+ return (
15
+ <div id='ReportTableHome'>
16
+ <div id='reportTable' class={reportClass}>
17
+ {html.el}
18
+ </div>
19
+ </div>
20
+ )
21
+ }
22
+ }
23
+ /**
24
+ * class类生成
25
+ * @param w 宽
26
+ * @param h 高
27
+ * @param l left
28
+ * @param t top
29
+ * @returns {string}
30
+ */
31
+ function generClass ({ w = 1, h = 1, l, t }) {
32
+ return `w-${w} h-${h} l-${l} t-${t}`
33
+ }
34
+ /**
35
+ * 判断是否是个Number数据
36
+ * @param value
37
+ * @returns {boolean}
38
+ */
39
+ function typeNumber (value) {
40
+ return Object.prototype.toString.call(value) === '[object Number]'
41
+ }
42
+ /**
43
+ * 判断是否是个object数据
44
+ * @param value
45
+ * @returns {boolean}
46
+ */
47
+ function typeObject (value) {
48
+ return Object.prototype.toString.call(value) === '[object Object]'
49
+ }
50
+ /**
51
+ * 判断是否是个Array数据
52
+ * @param value
53
+ * @returns {boolean}
54
+ */
55
+ function typeArray (value) {
56
+ return Object.prototype.toString.call(value) === '[object Array]'
57
+ }
58
+ /**
59
+ * 一行数据转换html函数
60
+ * @param h vue的h
61
+ * @param row 一行json数据
62
+ * @param left 起始left距离
63
+ * @param top 起始top距离
64
+ * @returns {{el: Array, h: number}}
65
+ */
66
+ function rowCompute (h, row, left, top) {
67
+ if (typeObject(row)) {
68
+ const el = []
69
+ const keys = Object.keys(row).filter((res) => res !== 'span')
70
+ let heigth = 0
71
+ for (const key of keys.values()) {
72
+ const value = row[key]['value'] ? row[key]['value'] : row[key]
73
+ const style = { l: left, t: top + heigth }
74
+ style.w = row[key]['span'] ? row[key]['span'] : 1
75
+ const nextL = left + style.w
76
+ const nextT = top + heigth
77
+ const divObject = rowCompute(h, value, nextL, nextT)
78
+ el.push(divObject.el)
79
+ style.h = divObject.h ? divObject.h : 1
80
+ heigth += style.h
81
+ const attrs = { class: generClass(style) + ' title' }
82
+ const div = <div {...attrs}>{key === 'value' ? value : key}</div>
83
+ el.push(div)
84
+ }
85
+ return { h: heigth, el: el }
86
+ } else if (typeArray(row)) {
87
+ const el = []
88
+ for (const [i, value] of row.entries()) {
89
+ const style = { l: (left + i), t: top, w: 1, h: 1 }
90
+ const extraClass = typeNumber(value) ? 'bold' : 'title'
91
+ const attrs = { class: generClass(style) + ` ${extraClass}` }
92
+ const div = <div {...attrs}>{value}</div>
93
+ el.push(div)
94
+ }
95
+ return { h: 1, el: el }
96
+ }
97
+ }
98
+ /**
99
+ * 完整报表数据转换html函数
100
+ * @param h vue的h
101
+ * @param jsonArr json数组
102
+ * @returns {{el: Array, h: number}}
103
+ */
104
+ function reportCompute (h, jsonArr) {
105
+ const html = []
106
+ let heigth = 0
107
+ let width = 0
108
+ for (const [index, row] of jsonArr.entries()) {
109
+ const rowHtml = rowCompute(h, row, 0, index)
110
+ // 取第一行的宽度作为整个报表的宽度
111
+ if (index === 0) {
112
+ const reg = /w-\d\s/
113
+ for (const vNode of rowHtml.el) {
114
+ if (!vNode.data || !vNode.data.class) continue
115
+ const c = vNode.data.class
116
+ const w = c.match(reg)[0].split('-')[1]
117
+ width += (w - 0)
118
+ }
119
+ }
120
+ heigth += rowHtml.h
121
+ html.push(rowHtml.el)
122
+ }
123
+ return { el: html, h: heigth, w: width }
124
+ }
@@ -1,28 +1,28 @@
1
- <template>
2
- <report-table :tableData="tableData"></report-table>
3
- </template>
4
-
5
- <script>
6
- import { post } from '@vue2-client/services/api'
7
- import ReportTable from '@vue2-client/pages/report/ReportTable'
8
- export default {
9
- name: 'ReportTableHome',
10
- components: { ReportTable },
11
- data () {
12
- return {
13
- tableData: null
14
- }
15
- },
16
- created () {
17
- },
18
- mounted () {
19
- this.getData()
20
- },
21
- methods: {
22
- async getData () {
23
- this.tableData = await post('/api/af-system/logic/reportTest', {})
24
- console.log('数据=>', JSON.stringify(this.tableData))
25
- }
26
- }
27
- }
28
- </script>
1
+ <template>
2
+ <report-table :tableData="tableData"></report-table>
3
+ </template>
4
+
5
+ <script>
6
+ import { post } from '@vue2-client/services/api'
7
+ import ReportTable from '@vue2-client/pages/report/ReportTable'
8
+ export default {
9
+ name: 'ReportTableHome',
10
+ components: { ReportTable },
11
+ data () {
12
+ return {
13
+ tableData: null
14
+ }
15
+ },
16
+ created () {
17
+ },
18
+ mounted () {
19
+ this.getData()
20
+ },
21
+ methods: {
22
+ async getData () {
23
+ this.tableData = await post('/api/af-system/logic/reportTest', {})
24
+ console.log('数据=>', JSON.stringify(this.tableData))
25
+ }
26
+ }
27
+ }
28
+ </script>