index.vue 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387
  1. <!--入库记录-->
  2. <template>
  3. <div class="app-container warehousingRecord">
  4. <advanced-search :searchData="searchData"></advanced-search>
  5. <div class="warehousingRecord-min">
  6. <el-table border :data="tableList" @selection-change="handleSelectionChange" ref="multipleTable" :row-key="getRowKeys">
  7. <el-table-column type="selection" width="50" align="center" :reserve-selection="true"/>
  8. <el-table-column label="入库时间" align="center" prop="joinTime" width="183"/>
  9. <el-table-column label="化学品编号" align="center" prop="joinNum" width="130"/>
  10. <el-table-column label="化学品名" align="center" prop="chemicalName" width="180"/>
  11. <el-table-column label="CAS号" align="center" prop="casNum" width="140"/>
  12. <el-table-column label="分类" align="center" prop="classifyName" width="181"/>
  13. <el-table-column label="属性" align="center" prop="classifyAttribute" width="220" show-overflow-tooltip/>
  14. <el-table-column label="形态" align="center" prop="chemicalShape" width="120"/>
  15. <el-table-column label="容量规格" align="center" prop="chemicalAmountUnit" width="121"/>
  16. <el-table-column label="容器规格" align="center" prop="tareUnit" width="121"/>
  17. <el-table-column label="标签类型" align="center" prop="labelType" width="121"/>
  18. <el-table-column label="标签编号" align="center" prop="tagCode" width="130"/>
  19. <el-table-column label="化学品柜" align="center" prop="cabinetName" width="200" show-overflow-tooltip/>
  20. <el-table-column label="位置" align="center" prop="posi" width="280" show-overflow-tooltip/>
  21. <el-table-column label="称重方式" align="center" prop="joinType" width="121"/>
  22. <!--<el-table-column label="入库量" align="center" prop="usages" width="120"/>-->
  23. <el-table-column label="库存净重" align="center" prop="usages" width="120"/>
  24. <!--<el-table-column label="操作人" align="center" prop="operator" width="220" show-overflow-tooltip/>-->
  25. <el-table-column label="双人验证" align="center" prop="verify" width="220" show-overflow-tooltip>
  26. <template slot-scope="scope">
  27. {{scope.row.verify?scope.row.verify:'无'}}
  28. </template>
  29. </el-table-column>
  30. <el-table-column label="操作" align="center" prop="operator" width="190">
  31. <template slot-scope="scope">
  32. <div class="button-box" style="display: flex">
  33. <p class="table-min-button"
  34. style="margin:0!important;"
  35. @click="lockVideo(1,scope.row)"
  36. >操作视频</p>
  37. <p class="table-min-button"
  38. style="margin:0!important;"
  39. @click="lockVideo(2,scope.row)"
  40. >开关锁视频</p>
  41. </div>
  42. </template>
  43. </el-table-column>
  44. </el-table>
  45. <div style="display: flex;height:32px;margin-top:15px;">
  46. <!--<p style="flex:4;"></p>-->
  47. <p style="text-align: left;margin:0;line-height:32px;margin-right:20px;font-size:14px;color:#999;">
  48. <i class="el-icon-warning" style="color:#0183FA;"></i>
  49. 已选择 {{selectedNum}} 项
  50. </p>
  51. <div style="flex:5;">
  52. <pagination :page-sizes="[20, 30, 40, 50]"
  53. v-show="total>0"
  54. :total="total"
  55. style="margin:0;"
  56. :page.sync="queryParams.pageNum"
  57. :limit.sync="queryParams.pageSize"
  58. @pagination="getList"
  59. />
  60. </div>
  61. </div>
  62. </div>
  63. <el-dialog :title="videoTitle" :visible.sync="videoType" v-if="videoType"
  64. width="840px" append-to-body id="operationRecord-dialog-box">
  65. <video style="width:800px;height:450px;" controls="" autoplay="" name="media" :poster="videoCover">
  66. <source :src="videoData.url" type="video/mp4">
  67. </video>
  68. </el-dialog>
  69. </div>
  70. </template>
  71. <script>
  72. import { classifyList,getNoauthList } from "@/api/medicUniversity-3_1/index";
  73. import { getListJoin } from "@/api/studentApi/chemicalManagement/index";
  74. import { listDepartments } from "@/api/system/dept";
  75. import advancedSearch from "@/components/ZDcomponents/advancedSearch.vue"
  76. export default {
  77. name: "warehousingRecord",
  78. components: {
  79. advancedSearch
  80. },
  81. data() {
  82. return {
  83. videoCover:window.location.href.split('://')[0]+'://' + process.env.VUE_APP_BASE_API + localStorage.getItem('videoCover'),
  84. searchData:{
  85. searchList:[//搜索数组
  86. {
  87. name:"关键字",//描述名称
  88. key:"searchValue",//键名 用于返回数据
  89. value:"",//内容 用于组件内绑定数据
  90. placeholder:"化学品名/别名/CAS号/编号/实验室",//输入提示
  91. level:"1",//1.普通搜索 2.高级搜索 普通搜索默认会在高级搜索时显示
  92. type:"1",//类型 1.input 2.select 3.TimePicker
  93. universal:'20',//通用参数 input时为最大长度 //TimePicker时可不传
  94. labelWidth:'68px',//label-width宽度 可传可不传 不传时为默认宽度
  95. width:'260',//el-form-item 长度 可传可不传 不传时input/select默认180长度 TimePicker默认240长度
  96. },
  97. {
  98. name:"化学品分类",//描述名称
  99. key:"chemicalClassify",//键名 用于返回数据
  100. value:"",//内容 用于组件内绑定数据
  101. placeholder:"请选择化学品分类",//输入提示
  102. level:"2",//1.普通搜索 2.高级搜索 普通搜索默认会在高级搜索时显示
  103. type:"2",//类型 1.input 2.select 3.TimePicker
  104. universal:[],
  105. width:'175',//el-form-item 长度 可传可不传 不传时input/select默认180长度 TimePicker默认240长度
  106. },
  107. {
  108. name:"属性",//描述名称
  109. key:"classifyAttribute",//键名 用于返回数据
  110. value:"",//内容 用于组件内绑定数据
  111. placeholder:"请选择属性",//输入提示
  112. level:"2",//1.普通搜索 2.高级搜索 普通搜索默认会在高级搜索时显示
  113. type:"2",//类型 1.input 2.select 3.TimePicker
  114. universal:[ //通用参数 select时为列表数据 //TimePicker时可不传
  115. {label:"RFID",value:"1"},{label:"二维码",value:"2"}
  116. ],
  117. width:'175',//el-form-item 长度 可传可不传 不传时input/select默认180长度 TimePicker默认240长度
  118. },
  119. {
  120. name:"学院",//描述名称
  121. key:"deptId",//键名 用于返回数据
  122. value:"",//内容 用于组件内绑定数据
  123. placeholder:"请选择学院",//输入提示
  124. level:"2",//1.普通搜索 2.高级搜索 普通搜索默认会在高级搜索时显示
  125. type:"2",//类型 1.input 2.select 3.TimePicker
  126. universal:[],
  127. width:'175',//el-form-item 长度 可传可不传 不传时input/select默认180长度 TimePicker默认240长度
  128. },
  129. {
  130. name:"化学品柜",//描述名称
  131. key:"cabinetId",//键名 用于返回数据
  132. value:"",//内容 用于组件内绑定数据
  133. placeholder:"请选择化学品柜",//输入提示
  134. level:"1",//1.普通搜索 2.高级搜索 普通搜索默认会在高级搜索时显示
  135. type:"2",//类型 1.input 2.select 3.TimePicker
  136. universal:[],
  137. width:'175',//el-form-item 长度 可传可不传 不传时input/select默认180长度 TimePicker默认240长度
  138. },
  139. {
  140. name:"标签类型",//描述名称
  141. key:"labelType",//键名 用于返回数据
  142. value:"",//内容 用于组件内绑定数据
  143. placeholder:"请选择标签类型",//输入提示
  144. level:"2",//1.普通搜索 2.高级搜索 普通搜索默认会在高级搜索时显示
  145. type:"2",//类型 1.input 2.select 3.TimePicker
  146. universal:[ //通用参数 select时为列表数据 //TimePicker时可不传
  147. {label:"RFID",value:"1"},{label:"二维码",value:"2"}
  148. ],
  149. width:'175',//el-form-item 长度 可传可不传 不传时input/select默认180长度 TimePicker默认240长度
  150. },
  151. {
  152. name:"入库时间",//描述名称
  153. key:"timeOne",//键名 用于返回数据
  154. value:"",//内容 用于组件内绑定数据
  155. placeholder:"请选择入库时间",//输入提示
  156. level:"1",//1.普通搜索 2.高级搜索 普通搜索默认会在高级搜索时显示
  157. type:"3",//类型 1.input 2.select 3.TimePicker
  158. width:'260',//el-form-item 长度 可传可不传 不传时input/select默认180长度 TimePicker默认240长度
  159. },
  160. ],
  161. },
  162. // 搜索实际发送数据
  163. queryParams:{
  164. pageNum:1,
  165. pageSize:20,
  166. },
  167. //数据数量
  168. total:0,
  169. //数据数组
  170. tableList:[],
  171. //表格扩展选择器---需要在@selection-change绑定的方法内监控selection数组长度
  172. selectedNum:0,
  173. // 选中数组
  174. ids: [],
  175. // 非单个禁用
  176. single: true,
  177. // 非多个禁用
  178. multiple: true,
  179. //视频操作
  180. videoType:false,
  181. videoData:{},
  182. videoTitle:"",
  183. };
  184. },
  185. created() {
  186. },
  187. mounted(){
  188. this.classifyList();
  189. this.listDepartments();
  190. this.getNoauthList();
  191. this.getHxpClassifyattribute();
  192. this.getList();
  193. },
  194. methods: {
  195. //视频按钮
  196. lockVideo(type,row){
  197. if(type == 1){
  198. if(!row.joinVideo){
  199. this.msgError('操作视频异常无法观看');
  200. return
  201. }
  202. let obj = {
  203. url:window.location.href.split('://')[0]+'://' + process.env.VUE_APP_BASE_API + "/admin/" + row.joinVideo
  204. }
  205. this.$set(this,'videoTitle','操作视频');
  206. this.$set(this,'videoData',obj);
  207. this.videoType = true;
  208. }else if(type == 2){
  209. if(!row.closeLockVideo){
  210. this.msgError('开关锁视频异常无法观看');
  211. return
  212. }
  213. let obj = {
  214. url:window.location.href.split('://')[0]+'://' + process.env.VUE_APP_BASE_API + "/admin/" + row.closeLockVideo
  215. }
  216. this.$set(this,'videoTitle','开关锁视频');
  217. this.$set(this,'videoData',obj);
  218. this.videoType = true;
  219. }
  220. },
  221. //获取属性列表
  222. getHxpClassifyattribute(){
  223. this.getDicts("hxp_classifyattribute").then(response => {
  224. let list = [];
  225. for(let i=0;i<response.data.length;i++){
  226. let obj ={
  227. value:response.data[i].dictValue,
  228. label:response.data[i].dictLabel,
  229. }
  230. list.push(obj);
  231. }
  232. this.$set(this.searchData.searchList[2],'universal',list);
  233. })
  234. },
  235. //获取化学品柜列表
  236. getNoauthList(){
  237. getNoauthList().then(response => {
  238. let list = [];
  239. for(let i=0;i<response.rows.length;i++){
  240. let obj ={
  241. value:response.rows[i].id,
  242. label:response.rows[i].cabinetName,
  243. }
  244. list.push(obj);
  245. }
  246. this.$set(this.searchData.searchList[4],'universal',list);
  247. });
  248. },
  249. //获取学院列表
  250. listDepartments(){
  251. listDepartments().then(response => {
  252. let list = [];
  253. for(let i=0;i<response.data.length;i++){
  254. let obj ={
  255. value:response.data[i].deptId,
  256. label:response.data[i].deptName,
  257. }
  258. list.push(obj);
  259. }
  260. this.$set(this.searchData.searchList[3],'universal',list);
  261. });
  262. },
  263. //获取化学品分类列表
  264. classifyList(){
  265. classifyList().then(response => {
  266. let list = [];
  267. for(let i=0;i<response.rows.length;i++){
  268. let obj ={
  269. value:response.rows[i].id,
  270. label:response.rows[i].classifyName,
  271. }
  272. list.push(obj);
  273. }
  274. this.$set(this.searchData.searchList[1],'universal',list);
  275. });
  276. },
  277. getList(){
  278. getListJoin(this.queryParams).then(response => {
  279. this.total = response.total;
  280. this.tableList = response.rows;
  281. });
  282. },
  283. //父组件必要此方法用于接收参数
  284. searchClick(type,data){
  285. let self = this;
  286. if(type == 1){ //type 1.查询
  287. this.queryParams = JSON.parse(JSON.stringify(data));
  288. if(data.timeOne){
  289. this.queryParams.joinTimeBegin = data.timeOne[0];
  290. this.queryParams.joinTimeEnd = data.timeOne[1];
  291. delete this.queryParams.timeOne
  292. }else{
  293. delete this.queryParams.timeOne
  294. }
  295. this.queryParams.pageNum = 1;
  296. this.queryParams.pageSize = 20;
  297. this.getList();
  298. }else if(type == 2){ //type 1.重置
  299. this.queryParams = {
  300. pageNum : 1,
  301. pageSize:20,
  302. };
  303. this.getList();
  304. }else if(type == 'export'){ //type 其他 自定义按钮
  305. let currentDate = this.getCurrentTime()
  306. if(data == 1){
  307. //导出全部
  308. self.$confirm(`确认导出全部数据?`, "提示", {
  309. confirmButtonText: "确定",
  310. cancelButtonText: "取消",
  311. type: "warning"
  312. }).then(async () => {
  313. self.download('/chemical/hxpStock/exportJoin/', {...self.queryParams}, '入库记录-'+currentDate+'.xlsx')
  314. }).catch(() => {})
  315. }else if(data == 2){
  316. //导出选中
  317. if(self.ids.length>0) {
  318. self.$confirm(`确认导出选中数据?`, "提示", {
  319. confirmButtonText: "确定",
  320. cancelButtonText: "取消",
  321. type: "warning"
  322. }).then(async () => {
  323. let ids = self.ids.join(',');
  324. let obj = {
  325. ids :ids
  326. }
  327. self.download(`/chemical/hxpStock/exportJoin/`,obj, '入库记录-'+currentDate+'.xlsx')
  328. }).catch(() => {})
  329. }else {
  330. this.msgError('请选择要导出的数据')
  331. }
  332. }
  333. }
  334. },
  335. /** 当前时间 */
  336. getCurrentTime () {
  337. const yy = new Date().getFullYear()
  338. const mm = new Date().getMonth() + 1
  339. const dd = new Date().getDate()
  340. const hh = new Date().getHours()
  341. const mf = new Date().getMinutes() < 10 ? '0' + new Date().getMinutes() : new Date().getMinutes()
  342. const ss = new Date().getSeconds() < 10 ? '0' + new Date().getSeconds() : new Date().getSeconds()
  343. return yy + '-' + mm + '-' + dd
  344. },
  345. // 多选框选中数据
  346. handleSelectionChange(selection) {
  347. this.selectedNum = selection.length;
  348. this.ids = selection.map(item => item.id);
  349. this.single = selection.length != 1;
  350. this.multiple = !selection.length;
  351. },
  352. /*===记录勾选数据===
  353. 需要再el-table 添加 :row-key="getRowKeys"
  354. 需要在selection 添加 :reserve-selection="true"
  355. */
  356. getRowKeys(row) {
  357. return row.id
  358. },
  359. }
  360. }
  361. </script>
  362. <style scoped lang="scss">
  363. .warehousingRecord{
  364. flex:1;
  365. display: flex;
  366. flex-direction: column;
  367. overflow: hidden!important;
  368. padding-top:20px!important;
  369. p{
  370. margin:0;
  371. padding:0;
  372. }
  373. .warehousingRecord-min{
  374. flex:1;
  375. display: flex;
  376. flex-direction: column;
  377. overflow: hidden!important;
  378. padding:0 20px 20px!important;
  379. }
  380. }
  381. </style>