index.vue 31 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780
  1. <template>
  2. <div class="app-container">
  3. <div class="filter-container">
  4. <el-select v-model="getdataListParm.parammaps.pastureName" style="width: 140px;" placeholder="牧场" class="filter-item" @change="changePastureName">
  5. <el-option v-for="item in findAllPasture" :key="item.id" :label="item.name" :value="item.name" />
  6. </el-select>
  7. <el-select v-model="getdataListParm.parammaps.departName" style="width: 140px;" clearable placeholder="部门" class="filter-item">
  8. <el-option v-for="item in findAllDepart" :key="item.id" :label="item.name" :value="item.name" />
  9. </el-select>
  10. <el-input v-model="getdataListParm.parammaps.formNunber" placeholder="表编号" style="width: 140px;" class="filter-item" />
  11. <el-input v-model="getdataListParm.parammaps.formName" placeholder="表名称" style="width: 140px;" class="filter-item" />
  12. <el-select v-model="getdataListParm.parammaps.formType" clearable placeholder="表类型" class="filter-item">
  13. <el-option v-for="item in getDictByName" :key="item.id" :label="item.value" :value="item.value" />
  14. </el-select>
  15. <el-select v-model="getdataListParm.parammaps.useType" clearable placeholder="表结构" class="filter-item">
  16. <el-option v-for="item in useTypes" :key="item.id" :label="item.name" :value="item.name" />
  17. </el-select>
  18. <el-button v-waves class="filter-item" type="primary" icon="el-icon-search" @click="form_search">搜索</el-button>
  19. <div>
  20. <el-button class="filter-item" style="margin-left: 10px;" type="primary" icon="el-icon-edit" @click="form_add">新增</el-button>
  21. <el-upload style="display: inline-block;" :headers="headers" :data="uploadData" :action="uploadExcelUrl" :show-file-list="false" :before-upload="beforeImportExcel" :on-success="handleImportExcelSuccess">
  22. <el-button v-waves class="filter-item" type="warning" icon="el-icon-upload2">导入</el-button>
  23. </el-upload>
  24. </div>
  25. </div>
  26. <el-table
  27. :key="tableKey"
  28. v-loading="listLoading"
  29. element-loading-text="给我一点时间"
  30. :data="list"
  31. border
  32. fit
  33. highlight-current-row
  34. style="width: 100%;"
  35. :row-style="rowStyle"
  36. :cell-style="cellStyle"
  37. class="elTable"
  38. @sort-change="tableSort1"
  39. :max-height="myHeight"
  40. >
  41. <el-table-column label="序号" align="center" type="index" width="50px">
  42. <template slot-scope="scope">
  43. <span>{{ scope.$index + (pageNum-1) * pageSize + 1 }}</span>
  44. </template>
  45. </el-table-column>
  46. <el-table-column label="牧场" min-width="110px" align="center">
  47. <template slot-scope="scope">
  48. <span>{{ scope.row.pastureName }}</span>
  49. </template>
  50. </el-table-column>
  51. <el-table-column label="部门" min-width="110px" align="center">
  52. <template slot-scope="scope">
  53. <span>{{ scope.row.departName }}</span>
  54. </template>
  55. </el-table-column>
  56. <el-table-column label="表名" min-width="110px" align="center">
  57. <template slot-scope="scope">
  58. <span>{{ scope.row.formName }}</span>
  59. </template>
  60. </el-table-column>
  61. <el-table-column label="表编号" align="center" width="120">
  62. <template slot-scope="scope">
  63. <span>{{ scope.row.formNumber }}</span>
  64. </template>
  65. </el-table-column>
  66. <el-table-column label="表结构" align="center" width="100">
  67. <template slot-scope="scope">
  68. <span>{{ scope.row.useType }}</span>
  69. </template>
  70. </el-table-column>
  71. <el-table-column label="表类型" width="100px" align="center">
  72. <template slot-scope="scope">
  73. <span>{{ scope.row.formType }}</span>
  74. </template>
  75. </el-table-column>
  76. <el-table-column label="具体位置" min-width="110px" align="center">
  77. <template slot-scope="scope">
  78. <span>{{ scope.row.location }}</span>
  79. </template>
  80. </el-table-column>
  81. <el-table-column label="单价" sortable prop="price" min-width="90px" align="center">
  82. <template slot-scope="scope">
  83. <span>{{ scope.row.price }}</span>
  84. </template>
  85. </el-table-column>
  86. <el-table-column label="负责人" min-width="110px" align="center">
  87. <template slot-scope="scope">
  88. <span>{{ scope.row.employeName }}</span>
  89. </template>
  90. </el-table-column>
  91. <el-table-column label="是否统计" min-width="80px" header-align="center" align="center">
  92. <template slot-scope="scope">
  93. <el-switch v-model="scope.row.isInfo" active-color="#13ce66" inactive-color="#ff4949" :active-value="1" :inactive-value="0" @change="handleEnableChange(scope.$index, scope.row)" />
  94. </template>
  95. </el-table-column>
  96. <el-table-column label="操作" align="center" width="250px" class-name="small-padding fixed-width" fixed="right">
  97. <template slot-scope="{row}">
  98. <el-button type="primary" size="mini" @click="form_see(row)">查看</el-button>
  99. <el-button type="success" size="mini" @click="form_edit(row)">编辑</el-button>
  100. <el-button type="danger" size="mini" @click="form_delete(row)">删除</el-button>
  101. </template>
  102. </el-table-column>
  103. </el-table>
  104. <pagination v-show="total>=0" :total="total" :page.sync="getdataListParm.offset" :limit.sync="getdataListParm.pagecount" @pagination="get_table_data" />
  105. <!-- 弹出层新增or修改 -->
  106. <el-dialog :title="textMap[dialogStatus]" :visible.sync="dialogFormVisible" :close-on-click-modal="false" width="80%">
  107. <div class="app-add">
  108. <el-form ref="createTemp" :rules="rules" :model="createTemp" label-position="right" label-width="100px" style="width: 90%;margin:0 auto">
  109. <el-row>
  110. <el-col :span="8">
  111. <el-form-item label="牧场:" prop="pastureId">
  112. <el-select v-model="createTemp.pastureId" placeholder="牧场" class="filter-item" style="width:100%" @change="changePasture">
  113. <el-option v-for="item in findAllPasture" :key="item.id" :label="item.name" :value="item.id" />
  114. </el-select>
  115. </el-form-item>
  116. </el-col>
  117. <el-col :span="8">
  118. <el-form-item label="部门:" prop="departmentId">
  119. <el-select v-model="createTemp.departmentId" placeholder="部门" class="filter-item" style="width:100%" @change="changeDepart">
  120. <el-option v-for="item in createDepartList" :key="item.id" :label="item.name" :value="item.id" />
  121. </el-select>
  122. </el-form-item>
  123. </el-col>
  124. <el-col :span="8">
  125. <el-form-item label="表结构:" prop="useType">
  126. <el-select v-model="createTemp.useType" placeholder="表结构" class="filter-item" style="width:100%" :disabled="dialogStatus==='update'">
  127. <el-option v-for="item in useTypes" :key="item.id" :label="item.name" :value="item.name" />
  128. </el-select>
  129. </el-form-item>
  130. </el-col>
  131. </el-row>
  132. <el-row>
  133. <el-col :span="8">
  134. <el-form-item label="表类型:" prop="formType">
  135. <el-select v-model="createTemp.formType" placeholder="表类型" class="filter-item" style="width:100%" :disabled="dialogStatus==='update'">
  136. <el-option v-for="item in getDictByName" :key="item.id" :label="item.value" :value="item.value" />
  137. </el-select>
  138. </el-form-item>
  139. </el-col>
  140. <el-col :span="8">
  141. <el-form-item label="表名称:" prop="formName">
  142. <el-input ref="formName" v-model="createTemp.formName" />
  143. </el-form-item>
  144. </el-col>
  145. <el-col :span="8">
  146. <el-form-item label="表编号:" prop="formNumber">
  147. <el-input ref="formNumber" v-model="createTemp.formNumber" />
  148. </el-form-item>
  149. </el-col>
  150. </el-row>
  151. <el-row>
  152. <el-col :span="8">
  153. <el-form-item label="单价:" prop="price">
  154. <el-input ref="price" v-model="createTemp.price" />
  155. </el-form-item>
  156. </el-col>
  157. <el-col :span="8">
  158. <el-form-item label="倍率:" prop="Multiple">
  159. <el-input ref="Multiple" v-model="createTemp.Multiple" disabled/>
  160. </el-form-item>
  161. </el-col>
  162. <el-col :span="8">
  163. <el-form-item label="当前值:" prop="startAmount">
  164. <el-input ref="startAmount" v-model="createTemp.startAmount" :disabled="dialogStatus==='update'" />
  165. </el-form-item>
  166. </el-col>
  167. </el-row>
  168. <el-row>
  169. <el-col :span="8">
  170. <el-form-item label="具体位置:" prop="location">
  171. <el-input ref="location" v-model="createTemp.location" />
  172. </el-form-item>
  173. </el-col>
  174. <el-col :span="8">
  175. <el-form-item label="负责人:" prop="employeId">
  176. <el-select v-model="createTemp.employeId" placeholder="负责人" class="filter-item" style="width:100%">
  177. <el-option v-for="item in findAllEmploye" :key="item.id" :label="item.name" :value="item.id" />
  178. </el-select>
  179. </el-form-item>
  180. </el-col>
  181. <el-col :span="8">
  182. <el-form-item label="录入时间:" prop="inputDatetime">
  183. <el-date-picker v-model="createTemp.inputDatetime" type="date" style="width:100%;top:-3px;" format="yyyy-MM-dd" value-format="yyyy-MM-dd" :clearable="false" />
  184. </el-form-item>
  185. </el-col>
  186. </el-row>
  187. <!-- <el-row>
  188. <el-col :span="8">
  189. <el-form-item label="iot编号:" prop="iotNumber">
  190. <el-input ref="iotNumber" v-model="createTemp.iotNumber" type="number" />
  191. </el-form-item>
  192. </el-col>
  193. </el-row> -->
  194. </el-form>
  195. </div>
  196. <div slot="footer" class="dialog-footer">
  197. <el-button v-if="dialogStatus==='create'" ref="createb" type="success" @click="add_dialog_save_again()">确认新增</el-button>
  198. <el-button type="primary" @click="dialogStatus==='create'?add_dialog_save():edit_dialog_save()">确认</el-button>
  199. <el-button @click="dialogFormVisible = false;get_table_data()">关闭</el-button>
  200. </div>
  201. </el-dialog>
  202. <!-- 卡片 -->
  203. <el-dialog :title="textMap[dialogStatus]" :visible.sync="dialogFormVisibleSee" :close-on-click-modal="false" width="80%">
  204. <div class="app-see">
  205. <el-tabs v-model="activeName">
  206. <el-tab-pane label="基本信息" name="first">
  207. <el-form ref="seeTemp" :rules="rules" :model="seeTemp" label-position="right" label-width="100px" style="width: 90%;margin:0 auto">
  208. <el-row>
  209. <el-col :span="8">
  210. <el-form-item label="牧场:" prop="pastureName">
  211. <el-input ref="pastureName" v-model="seeTemp.pastureName" disabled />
  212. </el-form-item>
  213. </el-col>
  214. <el-col :span="8">
  215. <el-form-item label="部门:" prop="departName">
  216. <el-input ref="departName" v-model="seeTemp.departName" disabled />
  217. </el-form-item>
  218. </el-col>
  219. <el-col :span="8">
  220. <el-form-item label="表结构:" prop="useType">
  221. <el-input ref="useType" v-model="seeTemp.useType" disabled />
  222. </el-form-item>
  223. </el-col>
  224. </el-row>
  225. <el-row>
  226. <el-col :span="8">
  227. <el-form-item label="表类型:" prop="formType">
  228. <el-input ref="formType" v-model="seeTemp.formType" disabled />
  229. </el-form-item>
  230. </el-col>
  231. <el-col :span="8">
  232. <el-form-item label="表名称:" prop="formName">
  233. <el-input ref="formName" v-model="seeTemp.formName" disabled />
  234. </el-form-item>
  235. </el-col>
  236. <el-col :span="8">
  237. <el-form-item label="表编号:" prop="formNumber">
  238. <el-input ref="formNumber" v-model="seeTemp.formNumber" disabled />
  239. </el-form-item>
  240. </el-col>
  241. </el-row>
  242. <el-row>
  243. <el-col :span="8">
  244. <el-form-item label="单价:" prop="price">
  245. <el-input ref="price" v-model="seeTemp.price" disabled />
  246. </el-form-item>
  247. </el-col>
  248. <el-col :span="8">
  249. <el-form-item label="倍率:" prop="Multiple">
  250. <el-input ref="Multiple" v-model="seeTemp.Multiple" disabled />
  251. </el-form-item>
  252. </el-col>
  253. <el-col :span="8">
  254. <el-form-item label="当前值:" prop="endAmount">
  255. <el-input ref="endAmount" v-model="seeTemp.endAmount" disabled />
  256. </el-form-item>
  257. </el-col>
  258. </el-row>
  259. <el-row>
  260. <el-col :span="8">
  261. <el-form-item label="具体位置:" prop="location">
  262. <el-input ref="location" v-model="seeTemp.location" disabled />
  263. </el-form-item>
  264. </el-col>
  265. <el-col :span="8">
  266. <el-form-item label="负责人:" prop="employeId">
  267. <el-input ref="employeName" v-model="seeTemp.employeName" disabled />
  268. </el-form-item>
  269. </el-col>
  270. <el-col :span="8">
  271. <el-form-item label="上次录入时间:" prop="endDate">
  272. <el-input ref="endDate" v-model="seeTemp.endDate" disabled />
  273. </el-form-item>
  274. </el-col>
  275. </el-row>
  276. </el-form>
  277. </el-tab-pane>
  278. <el-tab-pane label="用量记录" name="second">
  279. <el-table
  280. :key="tableKey"
  281. v-loading="listLoading"
  282. element-loading-text="给我一点时间"
  283. :data="listSee"
  284. border
  285. fit
  286. highlight-current-row
  287. style="width: 100%;"
  288. :row-style="rowStyle"
  289. :cell-style="cellStyle"
  290. class="elTable"
  291. @sort-change="tableSort2"
  292. >
  293. <el-table-column label="序号" align="center" type="index" width="50px">
  294. <template slot-scope="scope">
  295. <span>{{ scope.$index + (pageNumSee-1) * pageSizeSee + 1 }}</span>
  296. </template>
  297. </el-table-column>
  298. <el-table-column sortable prop="lastAmount" label="上次值" min-width="110px" align="center">
  299. <template slot-scope="scope">
  300. <span>{{ scope.row.lastAmount }}</span>
  301. </template>
  302. </el-table-column>
  303. <el-table-column sortable prop="endAmount" label="本次值" min-width="110px" align="center">
  304. <template slot-scope="scope">
  305. <span>{{ scope.row.endAmount }}</span>
  306. </template>
  307. </el-table-column>
  308. <el-table-column sortable prop="waterConsumption" label="用量" min-width="110px" align="center">
  309. <template slot-scope="scope">
  310. <span>{{ scope.row.waterConsumption }}</span>
  311. </template>
  312. </el-table-column>
  313. <el-table-column sortable prop="price" label="单价" align="center" width="150">
  314. <template slot-scope="scope">
  315. <span>{{ scope.row.price }}</span>
  316. </template>
  317. </el-table-column>
  318. <el-table-column sortable prop="sumPrice" label="总价" align="center" width="150">
  319. <template slot-scope="scope">
  320. <span>{{ scope.row.sumPrice }}</span>
  321. </template>
  322. </el-table-column>
  323. <el-table-column label="记录人" width="150px" align="center">
  324. <template slot-scope="scope">
  325. <span>{{ scope.row.empname }}</span>
  326. </template>
  327. </el-table-column>
  328. <el-table-column label="记录日期" min-width="110px" align="center" sortable prop="date" />
  329. </el-table>
  330. <pagination v-show="total>=0" :total="totalSee" :page.sync="getSeeListParm.offset" :limit.sync="getSeeListParm.pagecount" @pagination="getSeeList" />
  331. </el-tab-pane>
  332. </el-tabs>
  333. </div>
  334. <div slot="footer" class="dialog-footer">
  335. <el-button @click="dialogFormVisibleSee = false">关闭</el-button>
  336. </div>
  337. </el-dialog>
  338. </div>
  339. </template>
  340. <script>
  341. // 引入
  342. import { GetDataByName, GetDataByNames, PostDataByName, failproccess } from '@/api/common'
  343. import waves from '@/directive/waves' // waves directive
  344. import { parseTime, sortChange } from '@/utils/index.js'
  345. // eslint-disable-next-line no-unused-vars
  346. import { validateEMail } from '@/utils/validate.js'
  347. import Pagination from '@/components/Pagination' // secondary package based on el-pagination
  348. import { MessageBox } from 'element-ui'
  349. import { getToken } from '@/utils/auth'
  350. import Cookies from 'js-cookie'
  351. export default {
  352. name: 'Measure',
  353. components: { Pagination },
  354. directives: { waves },
  355. data() {
  356. return {
  357. // 校验规则
  358. // -----------------------------
  359. myHeight:document.documentElement.clientHeight - 85- 200,
  360. rules: {
  361. useType: [{ required: true, message: '必填', trigger: 'blur' }],
  362. formType: [{ required: true, message: '必填', trigger: 'blur' }],
  363. formName: [{ required: true, message: '必填', trigger: 'blur' }],
  364. formNumber: [{ required: true, message: '必填', trigger: 'blur' }]
  365. },
  366. rowStyle: { maxHeight: 50 + 'px', height: 45 + 'px' },
  367. cellStyle: { padding: 0 + 'px' },
  368. findAllPasture: [],
  369. findAllDepart: [],
  370. findAllEmploye: [],
  371. getDictByName: [], createDepartList: [], edit: 0,
  372. useTypes: [{ id: 0, name: '1级表' }, { id: 1, name: '2级表' }, { id: 2, name: '3级表' }],
  373. requestParams: [
  374. { name: 'findAllPasture', offset: 0, pagecount: 0, returntype: 'Map', parammaps: { 'id': Cookies.get('pastureid') }},
  375. { name: 'findAllEmploye', offset: 0, pagecount: 0, parammaps: { 'pastureId': Cookies.get('pastureid') }},
  376. { name: 'getDictByName', offset: 0, pagecount: 0, params: ['表类型'] }
  377. ],
  378. getDepartParam: {
  379. name: 'findAllDepart', offset: 0, pagecount: 0, parammaps: { 'pastureId': Cookies.get('pastureid') }
  380. },
  381. dialogFormVisible: false,
  382. dialogFormVisibleSee: false,
  383. dialogStatus: '',
  384. textMap: {
  385. update: '编辑',
  386. create: '新增',
  387. see: '查看详情'
  388. },
  389. tableKey: 0,
  390. list: null,
  391. total: 0,
  392. listLoading: false,
  393. getdataListParm: {
  394. name: 'getMeasureList',
  395. page: 1,
  396. offset: 1,
  397. pagecount: 10,
  398. returntype: 'Map',
  399. parammaps: {
  400. pastureName: Cookies.get('pasturename'),
  401. departName: '',
  402. formNunber: ''
  403. }
  404. },
  405. createTemp: {
  406. departmentId: this.$store.state.user.departmentid,
  407. departmentName: '',
  408. location: '',
  409. startAmount: '',
  410. formName: '',
  411. formType: '',
  412. useType: '',
  413. price: '',
  414. employeId: this.$store.state.user.employeid,
  415. pastureId: this.$store.state.user.pastureid,
  416. formNumber: '',
  417. inputDatetime: parseTime(new Date(), '{y}-{m}-{d}'),
  418. Multiple: '1',
  419. iotNumber:''
  420. },
  421. requestParam: {},
  422. activeName: 'first',
  423. seeTemp: {},
  424. listSee: [],
  425. totalSee: 0,
  426. getSeeListParm: {
  427. name: 'getAllMeasureTypeList',
  428. page: 1,
  429. offset: 1,
  430. pagecount: 10,
  431. returntype: 'Map',
  432. parammaps: {}
  433. }
  434. }
  435. },
  436. computed: {
  437. // 设置请求头
  438. headers() {
  439. return {
  440. // 设置token
  441. token: getToken()
  442. }
  443. },
  444. uploadData() {
  445. return {
  446. name: 'importMeasureNew',
  447. importParams: '牧场,表名称,表编号,表结构,表类型,部门,位置,最后一次抄表值,单价,管理人,倍率',
  448. sheetname: 'SheetJS'
  449. }
  450. },
  451. // 设置上传地址
  452. uploadExcelUrl() {
  453. // process.env.VUE_APP_BASE_API是服务器的路径,也是axios的基本路径
  454. return process.env.VUE_APP_BASE_API + 'authdata/ImportExcel'
  455. }
  456. },
  457. created() {
  458. this.get_select_list()
  459. this.get_table_data()
  460. },
  461. methods: {
  462. tableSort1(column) {
  463. sortChange(column, this.list)
  464. },
  465. tableSort2(column) {
  466. sortChange(column, this.listSee)
  467. },
  468. get_select_list() {
  469. GetDataByNames(this.requestParams).then(response => {
  470. this.findAllPasture = response.data.findAllPasture.list
  471. this.findAllEmploye = response.data.findAllEmploye.list
  472. this.getDictByName = response.data.getDictByName.list
  473. this.getDepartDownList()
  474. })
  475. },
  476. getDepartDownList() {
  477. GetDataByName(this.getDepartParam).then(response => {
  478. this.findAllDepart = response.data.list
  479. })
  480. },
  481. changePastureName(item) {
  482. this.getDepartParam.parammaps.pastureId = this.findAllPasture.find(obj => obj.name == item).id
  483. this.getdataListParm.parammaps.departName = ''
  484. this.getDepartDownList()
  485. },
  486. getCreateDepartDownList() {
  487. GetDataByName(this.getDepartParam).then(response => {
  488. this.createDepartList = response.data.list
  489. if (this.edit == 1) {
  490. if (this.createDepartList.find(obj => obj.id == Cookies.get('departmentid'))) {
  491. this.createTemp.departmentId = parseInt(Cookies.get('departmentid'))
  492. this.createTemp.departmentName = this.createDepartList.find(obj => obj.id == Cookies.get('departmentid')).name
  493. } else {
  494. this.createTemp.departmentId = response.data.list[0].id
  495. this.createTemp.departmentName = response.data.list[0].name
  496. }
  497. console.log(this.createTemp.departmentName, 'this.createTemp.departmentName')
  498. }
  499. })
  500. },
  501. changePasture(item) {
  502. this.getDepartParam.parammaps.pastureId = item
  503. this.edit = 1
  504. this.getCreateDepartDownList()
  505. },
  506. changeDepart(item) {
  507. this.createTemp.departmentName = this.createDepartList.find(obj => obj.id == item).name
  508. },
  509. get_table_data() {
  510. this.listLoading = true
  511. GetDataByName(this.getdataListParm).then(response => {
  512. if (response.data.list !== null) {
  513. this.list = response.data.list
  514. this.pageNum = response.data.pageNum
  515. this.pageSize = response.data.pageSize
  516. // Just to simulate the time of the request
  517. } else {
  518. this.list = []
  519. }
  520. this.total = response.data.total
  521. setTimeout(() => {
  522. this.listLoading = false
  523. }, 100)
  524. })
  525. },
  526. form_search() {
  527. this.listLoading = true
  528. this.getdataListParm.offset = 1
  529. this.get_table_data()
  530. },
  531. handleEnableChange(index, row) {
  532. this.requestParam.name = 'updateMeasureInfo'
  533. this.requestParam.parammaps['isInfo'] = row.isInfo
  534. this.requestParam.parammaps['id'] = row.id
  535. PostDataByName(this.requestParam).then(() => {
  536. this.$notify({
  537. title: '成功',
  538. message: '变更成功',
  539. type: 'success',
  540. duration: 2000
  541. })
  542. })
  543. },
  544. resetcreateTemp() {
  545. this.createTemp = {
  546. departmentId: parseInt(Cookies.get('departmentid')),
  547. departmentName: '',
  548. location: '',
  549. startAmount: '',
  550. formName: '',
  551. formType: '',
  552. useType: '',
  553. price: '',
  554. employeId: parseInt(Cookies.get('employeid')),
  555. pastureId: parseInt(Cookies.get('pastureid')),
  556. formNumber: '',
  557. inputDatetime: parseTime(new Date(), '{y}-{m}-{d}'),
  558. Multiple: '1',
  559. iotNumber:''
  560. }
  561. },
  562. form_add() {
  563. this.resetcreateTemp()
  564. this.edit = 1
  565. this.getDepartParam.parammaps.pastureId = this.createTemp.pastureId
  566. this.getCreateDepartDownList()
  567. this.dialogStatus = 'create'
  568. this.dialogFormVisible = true
  569. this.$nextTick(() => {
  570. this.$refs['createTemp'].clearValidate()
  571. })
  572. },
  573. add_dialog_save() {
  574. this.$refs['createTemp'].validate(valid => {
  575. if (valid) {
  576. this.requestParam.name = 'insertMeasure'
  577. this.requestParam.parammaps = this.createTemp
  578. if (this.createTemp.price == '') { this.createTemp.price = 0 }
  579. if (this.createTemp.Multiple == '') { this.createTemp.Multiple = 1 }
  580. if (this.createTemp.startAmount == '') { this.createTemp.startAmount = 0 }
  581. PostDataByName(this.requestParam).then(response => {
  582. if (response.msg !== 'fail') {
  583. this.get_table_data()
  584. this.dialogFormVisible = false
  585. this.$notify({
  586. title: '成功',
  587. message: '新增成功',
  588. type: 'success',
  589. duration: 2000
  590. })
  591. } else {
  592. failproccess(response, this.$notify)
  593. }
  594. })
  595. }
  596. })
  597. },
  598. add_dialog_save_again() {
  599. this.$refs['createTemp'].validate(valid => {
  600. if (valid) {
  601. this.requestParam.name = 'insertMeasure'
  602. this.requestParam.parammaps = this.createTemp
  603. if (this.createTemp.price == '') { this.createTemp.price = 0 }
  604. if (this.createTemp.Multiple == '') { this.createTemp.Multiple = 1 }
  605. if (this.createTemp.startAmount == '') { this.createTemp.startAmount = 0 }
  606. PostDataByName(this.requestParam).then(response => {
  607. if (response.msg !== 'fail') {
  608. this.resetcreateTemp()
  609. this.$notify({
  610. title: '成功',
  611. message: '新增成功',
  612. type: 'success',
  613. duration: 2000
  614. })
  615. } else {
  616. failproccess(response, this.$notify)
  617. }
  618. })
  619. }
  620. })
  621. },
  622. form_edit(row) {
  623. this.edit = 0
  624. this.getDepartParam.parammaps.pastureId = row.pastureId
  625. this.getCreateDepartDownList()
  626. this.createTemp = Object.assign({}, row) // copy obj
  627. this.createTemp.departmentId = parseInt(row.departmentId)
  628. this.createTemp.inputDatetime = row.endDate
  629. this.createTemp.startAmount = row.endAmount
  630. this.dialogStatus = 'update'
  631. this.dialogFormVisible = true
  632. this.$nextTick(() => {
  633. this.$refs['createTemp'].clearValidate()
  634. })
  635. },
  636. edit_dialog_save() {
  637. this.$refs['createTemp'].validate(valid => {
  638. if (valid) {
  639. this.requestParam.name = 'updateMeasure'
  640. this.requestParam.parammaps = this.createTemp
  641. PostDataByName(this.requestParam).then(response => {
  642. if (response.msg !== 'fail') {
  643. this.get_table_data()
  644. this.dialogFormVisible = false
  645. this.$notify({
  646. title: '成功',
  647. message: '修改成功',
  648. type: 'success',
  649. duration: 2000
  650. })
  651. } else {
  652. failproccess(response, this.$notify)
  653. }
  654. })
  655. }
  656. })
  657. },
  658. form_delete(row) {
  659. MessageBox.confirm('设备名称:' + row.formName, '确认删除?', {
  660. confirmButtonText: '确认',
  661. cancelButtonText: '取消',
  662. type: 'warning'
  663. })
  664. .then(() => {
  665. this.requestParam.name = 'deleteMeasure'
  666. this.requestParam.parammaps = {}
  667. this.requestParam.parammaps['id'] = row.id
  668. PostDataByName(this.requestParam).then(() => {
  669. this.get_table_data()
  670. this.dialogFormVisible = false
  671. this.$notify({
  672. title: '成功',
  673. message: '删除成功',
  674. type: 'success',
  675. duration: 2000
  676. })
  677. })
  678. })
  679. .catch(() => {
  680. this.$message({
  681. type: 'info',
  682. message: '已取消删除'
  683. })
  684. })
  685. },
  686. form_see(row) {
  687. this.seeTemp = Object.assign({}, row) // copy obj
  688. this.dialogStatus = 'see'
  689. this.dialogFormVisibleSee = true
  690. this.getSeeList()
  691. },
  692. getSeeList() {
  693. this.listLoading = true
  694. this.getSeeListParm.parammaps.id = this.seeTemp.id
  695. GetDataByName(this.getSeeListParm).then(response => {
  696. if (response.data.list !== null) {
  697. this.listSee = response.data.list
  698. this.pageNumSee = response.data.pageNum
  699. this.pageSizeSee = response.data.pageSize
  700. } else {
  701. this.listSee = []
  702. }
  703. this.totalSee = response.data.total
  704. setTimeout(() => {
  705. this.listLoading = false
  706. }, 100)
  707. })
  708. },
  709. beforeImportExcel(file) {
  710. const isLt2M = file.size / 1024 / 1024 < 2
  711. if (!isLt2M) {
  712. this.$message.error('上传文件大小不能超过 2MB!')
  713. }
  714. return isLt2M
  715. },
  716. handleImportExcelSuccess(res, file) {
  717. this.get_table_data()
  718. if (res.msg === 'ok') {
  719. this.$message({
  720. title: '成功',
  721. message: '导入成功:' + res.data.success + '条!',
  722. type: 'success',
  723. duration: 2000
  724. })
  725. if (res.data.err_count > 0) {
  726. this.$notify({
  727. title: '失败',
  728. message: '导入失败:' + res.data.err_count + '条!',
  729. type: 'danger',
  730. duration: 2000
  731. })
  732. import('@/vendor/Export2Excel').then(excel => {
  733. const list1 = res.data.result
  734. const tHeader = [
  735. '牧场', '表名称', '表编号', '表结构', '表类型', '部门', '位置', '最后一次抄表值', '单价', '管理人', '倍率', '错误信息'
  736. ]
  737. const filterVal = [
  738. '牧场', '表名称', '表编号', '表结构', '表类型', '部门', '位置', '最后一次抄表值', '单价', '管理人', '倍率', 'error_msg'
  739. ]
  740. const data1 = this.formatJson(filterVal, list1)
  741. excel.export_json_to_excel({
  742. header: tHeader,
  743. data: data1,
  744. filename: '计量设备管理',
  745. autoWidth: true,
  746. bookType: 'xlsx'
  747. })
  748. })
  749. }
  750. } else {
  751. this.$notify({
  752. title: '失败',
  753. message: '上传失败',
  754. type: 'danger',
  755. duration: 2000
  756. })
  757. }
  758. },
  759. formatJson(filterVal, jsonData) {
  760. return jsonData.map(v =>
  761. filterVal.map(j => {
  762. if (j === 'timestamp') {
  763. return parseTime(v[j])
  764. } else {
  765. return v[j]
  766. }
  767. })
  768. )
  769. }
  770. }
  771. }
  772. </script>