vue2-client 1.4.9 → 1.4.11

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 (89) hide show
  1. package/CHANGELOG.md +362 -355
  2. package/index.js +30 -30
  3. package/package.json +78 -78
  4. package/src/base-client/components/common/AddressSearchCombobox/AddressSearchCombobox.vue +225 -225
  5. package/src/base-client/components/common/CreateQuery/CreateQueryItem.vue +777 -777
  6. package/src/base-client/components/common/CreateSimpleFormQuery/CreateSimpleFormQueryItem.vue +553 -553
  7. package/src/base-client/components/common/FormGroupQuery/FormGroupQuery.vue +165 -165
  8. package/src/base-client/components/common/JSONToTree/jsontotree.vue +275 -275
  9. package/src/base-client/components/common/XAddForm/XAddForm.vue +354 -354
  10. package/src/base-client/components/common/XAddNativeForm/XAddNativeForm.vue +327 -327
  11. package/src/base-client/components/common/XCard/XCard.vue +64 -64
  12. package/src/base-client/components/common/XForm/XForm.vue +274 -274
  13. package/src/base-client/components/common/XForm/XFormItem.vue +389 -389
  14. package/src/base-client/components/common/XFormTable/XFormTable.vue +548 -547
  15. package/src/base-client/components/common/XFormTable/index.md +96 -96
  16. package/src/base-client/components/common/XTable/XTable.vue +262 -262
  17. package/src/base-client/components/system/QueryParamsDetailsView/QueryParamsDetailsView.vue +281 -281
  18. package/src/base-client/components/ticket/TicketDetailsView/TicketDetailsView.vue +807 -807
  19. package/src/base-client/components/ticket/TicketDetailsView/index.md +29 -29
  20. package/src/base-client/components/ticket/TicketDetailsView/part/TicketDetailsFlow.vue +260 -260
  21. package/src/base-client/components/ticket/TicketSubmitSuccessView/TicketSubmitSuccessView.vue +532 -532
  22. package/src/base-client/components/ticket/TicketSubmitSuccessView/index.md +29 -29
  23. package/src/base-client/plugins/AppData.js +69 -69
  24. package/src/base-client/plugins/GetLoginInfoService.js +179 -179
  25. package/src/base-client/plugins/PagedList.js +177 -177
  26. package/src/base-client/plugins/compatible/LoginServiceOA.js +20 -20
  27. package/src/base-client/plugins/i18n-extend.js +32 -32
  28. package/src/components/Ellipsis/index.md +38 -38
  29. package/src/components/NumberInfo/index.md +43 -43
  30. package/src/components/STable/README.md +341 -341
  31. package/src/components/STable/index.js +318 -318
  32. package/src/components/Trend/index.md +45 -45
  33. package/src/components/checkbox/ColorCheckbox.vue +157 -157
  34. package/src/components/checkbox/ImgCheckbox.vue +163 -163
  35. package/src/components/exception/ExceptionPage.vue +70 -70
  36. package/src/components/form/FormRow.vue +52 -52
  37. package/src/components/index.js +36 -36
  38. package/src/components/menu/SideMenu.vue +62 -62
  39. package/src/components/menu/menu.js +273 -273
  40. package/src/components/setting/Setting.vue +235 -235
  41. package/src/components/table/StandardTable.vue +141 -141
  42. package/src/components/table/advance/ActionColumns.vue +158 -158
  43. package/src/components/table/advance/SearchArea.vue +355 -355
  44. package/src/components/tool/AStepItem.vue +60 -60
  45. package/src/components/tool/AvatarList.vue +68 -68
  46. package/src/components/tool/Drawer.vue +142 -142
  47. package/src/components/tool/TagSelect.vue +83 -83
  48. package/src/components/transition/PageToggleTransition.vue +97 -97
  49. package/src/config/replacer/resolve.config.js +67 -67
  50. package/src/layouts/AdminLayout.vue +174 -174
  51. package/src/layouts/header/AdminHeader.vue +104 -104
  52. package/src/layouts/header/HeaderNotice.vue +167 -167
  53. package/src/layouts/header/HeaderSearch.vue +67 -67
  54. package/src/layouts/header/InstitutionDetail.vue +181 -181
  55. package/src/layouts/tabs/TabsHead.vue +190 -190
  56. package/src/layouts/tabs/TabsView.vue +379 -379
  57. package/src/mock/goods/index.js +108 -108
  58. package/src/pages/CreateQueryPage.vue +65 -65
  59. package/src/pages/report/ReportTable.js +124 -124
  60. package/src/pages/report/ReportTableHome.vue +28 -28
  61. package/src/pages/resourceManage/orgListManage.vue +98 -98
  62. package/src/pages/system/dictionary/index.vue +43 -43
  63. package/src/pages/system/file/index.vue +317 -317
  64. package/src/pages/system/queryParams/index.vue +43 -43
  65. package/src/pages/system/ticket/index.vue +2 -2
  66. package/src/router/async/config.async.js +27 -27
  67. package/src/router/async/router.map.js +56 -56
  68. package/src/router/index.js +27 -27
  69. package/src/services/api/DictionaryDetailsViewApi.js +6 -6
  70. package/src/services/api/LogDetailsViewApi.js +10 -10
  71. package/src/services/api/QueryParamsDetailsViewApi.js +6 -6
  72. package/src/services/api/TicketDetailsViewApi.js +34 -34
  73. package/src/services/api/commonTempTable.js +10 -10
  74. package/src/services/api/index.js +17 -17
  75. package/src/services/api/manage.js +8 -8
  76. package/src/store/mutation-types.js +2 -2
  77. package/src/theme/default/nprogress.less +76 -76
  78. package/src/theme/default/style.less +47 -47
  79. package/src/utils/colors.js +103 -103
  80. package/src/utils/excel/Blob.js +180 -180
  81. package/src/utils/excel/Export2Excel.js +141 -141
  82. package/src/utils/formatter.js +68 -68
  83. package/src/utils/i18n.js +80 -80
  84. package/src/utils/request.js +225 -225
  85. package/src/utils/routerUtil.js +364 -364
  86. package/src/utils/theme-color-replacer-extend.js +91 -91
  87. package/src/utils/themeUtil.js +100 -100
  88. package/src/utils/util.js +230 -230
  89. package/vue.config.js +99 -99
@@ -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>