index.vue 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331
  1. <!-- 气瓶类型 -->
  2. <template>
  3. <div class="app-container cylinderSetting">
  4. <div class="page-container cylinderSettingPage">
  5. <div class="page-form-title-box">
  6. <el-form :model="queryParams" class="form-box" ref="queryForm"
  7. :inline="true" style="width:100%;">
  8. <el-form-item label="关键字" prop="searchValue" label-width="60px">
  9. <el-input
  10. maxLength="30"
  11. v-model="queryParams.searchValue"
  12. placeholder="气体名称"
  13. clearable
  14. style="width: 240px"
  15. />
  16. </el-form-item>
  17. <p class="page-inquire-common-style-button" @click="handleQuery">查询</p>
  18. <p class="page-reset-common-style-button" @click="resetQuery">重置</p>
  19. <p class="page-add-common-style-button"
  20. style="float: right;"
  21. @click="tableButton(1)"
  22. >新增</p>
  23. </el-form>
  24. </div>
  25. <div class="page-content-box">
  26. <el-table class="table-box" v-loading="loading" border :data="dataList">
  27. <el-table-column label="气体名称" prop="gasName" show-overflow-tooltip/>
  28. <el-table-column label="级别" prop="level" width="300" show-overflow-tooltip>
  29. <template slot-scope="scope">
  30. {{forData(1,scope.row.level)}}
  31. </template>
  32. </el-table-column>
  33. <el-table-column label="规格" prop="size" width="150" show-overflow-tooltip>
  34. <template slot-scope="scope">
  35. {{forData(2,scope.row.size)}}
  36. </template>
  37. </el-table-column>
  38. <el-table-column label="成分" prop="gasComposition" width="300" show-overflow-tooltip/>
  39. <el-table-column label="编辑时间" prop="updateTime" width="249" show-overflow-tooltip>
  40. <template slot-scope="scope">
  41. <span>{{ parseTime(scope.row.updateTime,'{y}-{m}-{d} {h}:{i}') }}</span>
  42. </template>
  43. </el-table-column>
  44. <el-table-column label="操作" width="180" show-overflow-tooltip v-if="tableButtonType">
  45. <template slot-scope="scope">
  46. <div class="table-button-box">
  47. <p class="table-button-null"></p>
  48. <p class="table-button-p"
  49. @click="tableButton(2,scope.row)"
  50. >编辑</p>
  51. <p class="table-button-p"
  52. @click="tableButton(3,scope.row)"
  53. >删除</p>
  54. <p class="table-button-null"></p>
  55. </div>
  56. </template>
  57. </el-table-column>
  58. </el-table>
  59. <pagination :page-sizes="[20, 30, 40, 50]"
  60. v-show="total>0"
  61. :total="total"
  62. :page.sync="queryParams.pageNum"
  63. :limit.sync="queryParams.pageSize"
  64. @pagination="getList"
  65. />
  66. </div>
  67. </div>
  68. <el-dialog class="cylinderSetting-dialog-box"
  69. :title="dialogTitle" :visible.sync="dialogType" v-if="dialogType"
  70. :close-on-click-modal="false" width="500px" append-to-body>
  71. <el-form ref="dialogForm" :model="dialogForm" :rules="rules" label-width="120px">
  72. <el-form-item label="名称:" prop="gasName">
  73. <el-input
  74. maxLength="10"
  75. v-model="dialogForm.gasName"
  76. placeholder="请输入名称"
  77. style="width: 280px"
  78. />
  79. </el-form-item>
  80. <el-form-item label="级别:" prop="level">
  81. <el-select v-model="dialogForm.level"
  82. placeholder="请选择" style="width: 280px">
  83. <el-option
  84. v-for="dict in gasBottleLevel"
  85. :key="dict.dictValue"
  86. :label="dict.dictLabel"
  87. :value="dict.dictValue"
  88. />
  89. </el-select>
  90. </el-form-item>
  91. <el-form-item label="规格:" prop="size">
  92. <el-select v-model="dialogForm.size"
  93. placeholder="请选择" style="width: 280px">
  94. <el-option
  95. v-for="dict in gasBottleSpecification"
  96. :key="dict.dictValue"
  97. :label="dict.dictLabel"
  98. :value="dict.dictValue"
  99. />
  100. </el-select>
  101. </el-form-item>
  102. <el-form-item label="气体成分:" prop="gasComposition">
  103. <el-input
  104. maxLength="20"
  105. v-model="dialogForm.gasComposition"
  106. placeholder="请输入名称"
  107. style="width: 280px"
  108. />
  109. </el-form-item>
  110. </el-form>
  111. <div slot="footer" class="dialog-footer">
  112. <p class="dialog-footer-null-p"></p>
  113. <el-button @click="cancel">取 消</el-button>
  114. <el-button type="primary" @click="submit">确 定</el-button>
  115. <p class="dialog-footer-null-p"></p>
  116. </div>
  117. </el-dialog>
  118. </div>
  119. </template>
  120. <script>
  121. import vueQr from 'vue-qr'
  122. import { getLodop } from "@/utils/LodopFuncs";
  123. import { airbottleBottleTypeList,airbottleBottleTypeAdd,
  124. airbottleBottleTypeUpdate,airbottleBottleTypeFindById,
  125. airbottleBottleTypeDelete} from "@/api/gasBottleManage/index";
  126. //import { getDicts } from "@/api/commonality/noPermission";
  127. //import { systemUserSelect } from "@/api/commonality/permission";
  128. //import { getInfo } from "@/api/basicsModules/index";
  129. //import addPage from "./addPage.vue";
  130. export default {
  131. name: 'index',
  132. components: {
  133. vueQr
  134. },
  135. data () {
  136. return {
  137. tableButtonType:this.hasPermiDom(['demo:demo:detail','demo:demo:edit','demo:demo:del',]),
  138. //页面遮罩
  139. loading:false,
  140. //气瓶级别
  141. gasBottleLevel:[],
  142. gasBottleSpecification:[],
  143. //查询条件
  144. queryParams:{
  145. pageNum:1,
  146. pageSize:20,
  147. searchValue:"",
  148. collegeId :null,
  149. },
  150. //时间数据
  151. dateRange:[],
  152. //列表数据
  153. dataList:[],
  154. //数据数量
  155. total:0,
  156. //弹窗开关
  157. dialogType:false,
  158. dialogTitle:"",
  159. dialogForm:{},
  160. //校验
  161. rules:{
  162. gasName:[
  163. { required: true, message: '请输入名称', trigger: 'blur' },
  164. { required: true, message: "请输入名称", validator: this.spaceJudgment, trigger: "blur" }
  165. ],
  166. level:[
  167. { required: true, message: '请选择级别', trigger: 'blur' },
  168. ],
  169. size:[
  170. { required: true, message: '请选择规格', trigger: 'blur' },
  171. ],
  172. // gasComposition:[
  173. // { required: true, message: '请输入气体成分', trigger: 'blur' },
  174. // { required: true, message: "请输入气体成分", validator: this.spaceJudgment, trigger: "blur" }
  175. // ],
  176. },
  177. }
  178. },
  179. created () {
  180. },
  181. mounted () {
  182. this.getList();
  183. this.getDicts("gasBottleLevel").then((response) => {
  184. this.$set(this,'gasBottleLevel',response.data);
  185. });
  186. this.getDicts("gasBottleSpecification").then((response) => {
  187. this.$set(this,'gasBottleSpecification',response.data);
  188. });
  189. },
  190. methods: {
  191. //弹窗相关
  192. cancel(){
  193. this.$set(this,'dialogType',false);
  194. },
  195. submit(){
  196. this.$refs["dialogForm"].validate(valid => {
  197. if (valid) {
  198. if(this.dialogForm.id){
  199. //编辑
  200. airbottleBottleTypeUpdate(this.dialogForm).then(response => {
  201. this.$set(this,'dialogType',false);
  202. this.msgSuccess(response.msg)
  203. this.getList();
  204. });
  205. } else {
  206. //新增
  207. airbottleBottleTypeAdd(this.dialogForm).then(response => {
  208. this.$set(this,'dialogType',false);
  209. this.msgSuccess(response.msg)
  210. this.getList();
  211. });
  212. }
  213. }
  214. })
  215. },
  216. //查询按钮
  217. handleQuery(){
  218. this.$set(this.queryParams,'pageNum',1);
  219. this.getList();
  220. },
  221. //重置按钮
  222. resetQuery(){
  223. this.$set(this,'dateRange',[])
  224. this.$set(this,'queryParams',{
  225. pageNum:1,
  226. pageSize:20,
  227. searchValue:"",
  228. collegeId :null,
  229. });
  230. this.getList();
  231. },
  232. //获取数据列表
  233. getList(){
  234. this.$set(this,'loading',true);
  235. let obj = JSON.parse(JSON.stringify(this.queryParams))
  236. airbottleBottleTypeList(obj).then(response => {
  237. this.$set(this,'loading',false);
  238. this.$set(this,'dataList',response.data.records);
  239. this.$set(this,'total',response.data.total);
  240. });
  241. },
  242. //操作按钮
  243. tableButton(type,row){
  244. let self = this;
  245. if(type == 1){
  246. //新增
  247. this.$set(this,'dialogTitle','新增');
  248. this.$set(this,'dialogForm',{
  249. gasName:"",
  250. level:"",
  251. size:"",
  252. gasComposition:"",
  253. });
  254. this.$set(this,'dialogType',true);
  255. }else if(type == 2){
  256. //编辑
  257. this.$set(this,'dialogTitle','编辑');
  258. this.$set(this,'dialogForm',{
  259. id:row.id,
  260. gasName:row.gasName,
  261. level:row.level+'',
  262. size:row.size+'',
  263. gasComposition:row.gasComposition,
  264. });
  265. this.$set(this,'dialogType',true);
  266. }else if(type == 3){
  267. //删除
  268. this.$confirm('是否确认删除?', "警告", {
  269. confirmButtonText: "确定",
  270. cancelButtonText: "取消",
  271. type: "warning"
  272. }).then(function() {
  273. }).then(() => {
  274. airbottleBottleTypeDelete({id:row.id}).then(response => {
  275. self.msgSuccess(response.msg)
  276. self.getList();
  277. });
  278. }).catch(() => {});
  279. }
  280. },
  281. forData(type,id){
  282. let self = this;
  283. let num = 0;
  284. if(type == 1){
  285. for(let i=0;i<self.gasBottleLevel.length;i++){
  286. if(id == self.gasBottleLevel[i].dictValue){
  287. num++
  288. return self.gasBottleLevel[i].dictLabel
  289. }
  290. }
  291. }else if (type){
  292. for(let i=0;i<self.gasBottleSpecification.length;i++){
  293. if(id == self.gasBottleSpecification[i].dictValue){
  294. num++
  295. return self.gasBottleSpecification[i].dictLabel
  296. }
  297. }
  298. }
  299. if(num == 0){
  300. return '其他'
  301. }
  302. },
  303. },
  304. }
  305. </script>
  306. <style scoped lang="scss">
  307. .cylinderSetting{
  308. display: flex;
  309. flex-direction: column;
  310. .cylinderSettingPage{
  311. }
  312. }
  313. </style>
  314. <style lang="scss">
  315. .cylinderSetting-dialog-box{
  316. .text-p{
  317. line-height:40px;
  318. font-size:16px;
  319. text-align: center;
  320. }
  321. .dialog-footer{
  322. display: flex;
  323. .dialog-footer-null-p{
  324. flex:1;
  325. }
  326. }
  327. }
  328. </style>