point.data.ts 6.2 KB

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