point.data.ts 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273
  1. import { BasicColumn } from '/@/components/Table';
  2. import { FormSchema } from '/@/components/Table';
  3. import { queryDeviceList } from './point.api';
  4. import { defHttp } from '/@/utils/http/axios';
  5. export const columns: BasicColumn[] = [
  6. // {
  7. // title: 'id',
  8. // dataIndex: 'id',
  9. // width: 120,
  10. // ifShow: true,
  11. // },
  12. {
  13. title: '设备类型',
  14. dataIndex: 'devicekind_dictText',
  15. width: 120,
  16. },
  17. {
  18. title: '点表类型',
  19. dataIndex: 'devicetype',
  20. width: 120,
  21. },
  22. {
  23. title: '值名称',
  24. dataIndex: 'valuename',
  25. width: 100,
  26. },
  27. {
  28. title: '值code',
  29. dataIndex: 'valuecode',
  30. width: 100,
  31. },
  32. {
  33. title: '点位地址',
  34. width: 150,
  35. dataIndex: 'plcaddr',
  36. },
  37. {
  38. title: '数据类型',
  39. width: 100,
  40. dataIndex: 'datakind_dictText',
  41. },
  42. // {
  43. // title: '最大值',
  44. // dataIndex: 'fmax',
  45. // width: 100,
  46. // },
  47. // {
  48. // title: '模拟最小值',
  49. // dataIndex: 'testlow',
  50. // width: 100,
  51. // },
  52. // {
  53. // title: '模拟最大值',
  54. // width: 100,
  55. // dataIndex: 'testup',
  56. // },
  57. // {
  58. // title: '小数位数',
  59. // width: 100,
  60. // dataIndex: 'floatnum',
  61. // },
  62. // {
  63. // title: '是否保存',
  64. // dataIndex: 'saveflag_dictText',
  65. // width: 80,
  66. // },
  67. ];
  68. export const searchFormSchema: FormSchema[] = [
  69. {
  70. label: '设备类型',
  71. field: 'devicetype',
  72. component: 'MTreeSelect',
  73. colProps: { span: 6 },
  74. },
  75. ];
  76. export const formSchema: FormSchema[] = [
  77. {
  78. label: '',
  79. field: 'id',
  80. component: 'Input',
  81. show: false,
  82. },
  83. {
  84. label: '设备分类',
  85. field: 'devicekind',
  86. component: 'ApiSelect',
  87. // componentProps: {
  88. // dictCode: 'devicekind',
  89. // placeholder: '请选择设备分类',
  90. // },
  91. componentProps: ({ formModel, formActionType }) => {
  92. return {
  93. // options: provincesOptions,
  94. placeholder: '请选择设备分类',
  95. api: queryDeviceList,
  96. resultField: 'result',
  97. // use name as label
  98. labelField: 'itemText',
  99. // use id as value
  100. valueField: 'itemValue',
  101. onChange: (e: any) => {
  102. // formModel.devicetype = '';
  103. const { updateSchema } = formActionType;
  104. updateSchema({
  105. field: 'devicetype',
  106. component: 'ApiSelect',
  107. componentProps: {
  108. api: (params) => defHttp.get({ url: `/sys/dict/getDictItems/${e + 'kind'}` }, params),
  109. resultField: 'result',
  110. labelField: 'title',
  111. valueField: 'value',
  112. },
  113. });
  114. },
  115. resetFields: () => {},
  116. };
  117. },
  118. },
  119. {
  120. label: '点表类型',
  121. field: 'devicetype',
  122. component: 'ApiSelect',
  123. componentProps: ({ formModel }) => {
  124. return {
  125. defaultValue: formModel['devicetype'],
  126. componentProps: {},
  127. api: (params) => defHttp.get({ url: `/sys/dict/getDictItems/${formModel.devicekind + 'kind'}` }, params),
  128. resultField: 'result',
  129. labelField: 'title',
  130. valueField: 'value',
  131. };
  132. },
  133. },
  134. {
  135. label: '功能码',
  136. field: 'fanctionCode',
  137. component: 'Input',
  138. },
  139. {
  140. label: '值名称',
  141. field: 'valuename',
  142. component: 'Input',
  143. },
  144. {
  145. label: '值code',
  146. field: 'valuecode',
  147. component: 'Input',
  148. },
  149. {
  150. label: '值类型',
  151. field: 'valuetype',
  152. component: 'JDictSelectTag',
  153. componentProps: {
  154. dictCode: 'valuetype',
  155. placeholder: '请选择设备类型',
  156. stringToNumber: true,
  157. },
  158. },
  159. {
  160. label: '指令默认写入值',
  161. field: 'value',
  162. component: 'Input',
  163. },
  164. {
  165. label: '点位地址',
  166. field: 'plcaddr',
  167. component: 'Input',
  168. },
  169. {
  170. label: '数据类型',
  171. field: 'datakind',
  172. component: 'JDictSelectTag',
  173. componentProps: {
  174. dictCode: 'datakind',
  175. placeholder: '请选择数据类型',
  176. stringToNumber: true,
  177. },
  178. },
  179. {
  180. label: '字节数',
  181. field: 'len',
  182. component: 'Input',
  183. },
  184. {
  185. label: '功能码',
  186. field: 'fanctionCode',
  187. component: 'Input',
  188. },
  189. {
  190. label: '数值解析',
  191. field: 'dictset',
  192. component: 'Input',
  193. },
  194. {
  195. label: '最小值',
  196. field: 'fmin',
  197. component: 'InputNumber',
  198. },
  199. {
  200. label: '最大值',
  201. field: 'fmax',
  202. component: 'InputNumber',
  203. },
  204. {
  205. label: '模拟最小值',
  206. field: 'testlow',
  207. component: 'InputNumber',
  208. },
  209. {
  210. label: '模拟最大值',
  211. field: 'testup',
  212. component: 'InputNumber',
  213. },
  214. {
  215. label: '开始指令',
  216. field: 'startcommand ',
  217. component: 'InputTextArea',
  218. },
  219. {
  220. label: '结束指令',
  221. field: 'endcommand',
  222. component: 'InputTextArea',
  223. },
  224. {
  225. label: '控制指令设置模拟数据',
  226. field: 'setTestdata',
  227. component: 'InputTextArea',
  228. },
  229. {
  230. label: '是否保存',
  231. field: 'saveflag',
  232. component: 'JDictSelectTag',
  233. componentProps: {
  234. dictCode: 'booltype',
  235. placeholder: '是否保存',
  236. stringToNumber: true,
  237. },
  238. },
  239. {
  240. label: '是否报警',
  241. field: 'bwarning',
  242. component: 'JDictSelectTag',
  243. componentProps: {
  244. dictCode: 'booltype',
  245. placeholder: '是否报警',
  246. stringToNumber: true,
  247. },
  248. },
  249. {
  250. label: '是否计算平均值',
  251. field: 'avgflag',
  252. component: 'JDictSelectTag',
  253. componentProps: {
  254. dictCode: 'booltype',
  255. placeholder: '是否计算平均值',
  256. stringToNumber: true,
  257. },
  258. },
  259. {
  260. label: '小数位数',
  261. field: 'floatnum',
  262. component: 'InputNumber',
  263. },
  264. {
  265. label: '备注',
  266. field: 'strremark',
  267. component: 'InputTextArea',
  268. },
  269. ];