point.data.ts 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282
  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. label: '值类型',
  77. field: 'valuetype',
  78. component: 'JDictSelectTag',
  79. componentProps: {
  80. dictCode: 'valuetype',
  81. placeholder: '请选择设备类型',
  82. stringToNumber: true,
  83. },
  84. },
  85. {
  86. label: '值名称',
  87. field: 'valuename',
  88. component: 'Input',
  89. colProps: { span: 6 },
  90. },
  91. {
  92. label: '值code',
  93. field: 'valuecode',
  94. component: 'Input',
  95. colProps: { span: 6 },
  96. },
  97. ];
  98. export const formSchema: FormSchema[] = [
  99. {
  100. label: '',
  101. field: 'id',
  102. component: 'Input',
  103. show: false,
  104. },
  105. {
  106. label: '设备分类',
  107. field: 'devicekind',
  108. component: 'ApiSelect',
  109. // componentProps: {
  110. // dictCode: 'devicekind',
  111. // placeholder: '请选择设备分类',
  112. // },
  113. componentProps: ({ formModel, formActionType }) => {
  114. return {
  115. // options: provincesOptions,
  116. placeholder: '请选择设备分类',
  117. api: queryDeviceList,
  118. resultField: 'result',
  119. // use name as label
  120. labelField: 'itemText',
  121. // use id as value
  122. valueField: 'itemValue',
  123. onChange: (e: any) => {
  124. formModel.devicetype = '';
  125. const { updateSchema } = formActionType;
  126. updateSchema({
  127. field: 'devicetype',
  128. componentProps: {
  129. api: (params) => defHttp.get({ url: `/sys/dict/getDictItems/${e + 'kind'}` }, params),
  130. resultField: 'result',
  131. labelField: 'title',
  132. valueField: 'value',
  133. },
  134. });
  135. },
  136. };
  137. },
  138. },
  139. {
  140. label: '点表类型',
  141. field: 'devicetype',
  142. component: 'ApiSelect',
  143. componentProps: ({ formModel, formActionType }) => {
  144. return {
  145. componentProps: {},
  146. api: (params) => defHttp.get({ url: `/sys/dict/getDictItems/${formModel.devicekind + 'kind'}` }, params),
  147. resultField: 'result',
  148. labelField: 'title',
  149. valueField: 'value',
  150. };
  151. },
  152. },
  153. {
  154. label: '功能码',
  155. field: 'fanctionCode',
  156. component: 'Input',
  157. },
  158. {
  159. label: '值名称',
  160. field: 'valuename',
  161. component: 'Input',
  162. },
  163. {
  164. label: '值code',
  165. field: 'valuecode',
  166. component: 'Input',
  167. },
  168. {
  169. label: '值类型',
  170. field: 'valuetype',
  171. component: 'JDictSelectTag',
  172. componentProps: {
  173. dictCode: 'valuetype',
  174. placeholder: '请选择设备类型',
  175. stringToNumber: true,
  176. },
  177. },
  178. {
  179. label: '指令默认写入值',
  180. field: 'value',
  181. component: 'Input',
  182. },
  183. {
  184. label: '点位地址',
  185. field: 'plcaddr',
  186. component: 'Input',
  187. },
  188. {
  189. label: '数据类型',
  190. field: 'datakind',
  191. component: 'JDictSelectTag',
  192. componentProps: {
  193. dictCode: 'datakind',
  194. placeholder: '请选择数据类型',
  195. stringToNumber: true,
  196. },
  197. },
  198. {
  199. label: '字节数',
  200. field: 'len',
  201. component: 'Input',
  202. },
  203. {
  204. label: '最小值',
  205. field: 'fmin',
  206. component: 'InputNumber',
  207. },
  208. {
  209. label: '最大值',
  210. field: 'fmax',
  211. component: 'InputNumber',
  212. },
  213. {
  214. label: '模拟最小值',
  215. field: 'testlow',
  216. component: 'InputNumber',
  217. },
  218. {
  219. label: '模拟最大值',
  220. field: 'testup',
  221. component: 'InputNumber',
  222. },
  223. {
  224. label: '开始指令',
  225. field: 'startcommand ',
  226. component: 'InputTextArea',
  227. },
  228. {
  229. label: '结束指令',
  230. field: 'endcommand',
  231. component: 'InputTextArea',
  232. },
  233. {
  234. label: '控制指令设置模拟数据',
  235. field: 'setTestdata',
  236. component: 'InputTextArea',
  237. },
  238. {
  239. label: '是否保存',
  240. field: 'saveflag',
  241. component: 'JDictSelectTag',
  242. componentProps: {
  243. dictCode: 'booltype',
  244. placeholder: '是否保存',
  245. stringToNumber: true,
  246. },
  247. },
  248. {
  249. label: '是否报警',
  250. field: 'bwarning',
  251. component: 'JDictSelectTag',
  252. componentProps: {
  253. dictCode: 'booltype',
  254. placeholder: '是否报警',
  255. stringToNumber: true,
  256. },
  257. },
  258. {
  259. label: '是否计算平均值',
  260. field: 'avgflag',
  261. component: 'JDictSelectTag',
  262. componentProps: {
  263. dictCode: 'booltype',
  264. placeholder: '是否计算平均值',
  265. stringToNumber: true,
  266. },
  267. },
  268. {
  269. label: '小数位数',
  270. field: 'floatnum',
  271. component: 'InputNumber',
  272. },
  273. {
  274. label: '备注',
  275. field: 'strremark',
  276. component: 'InputTextArea',
  277. },
  278. ];