XMLWAN преди 4 години
родител
ревизия
4c0b21fa8f

+ 32 - 0
src/api/drug/drug_stock.js Целия файл

@@ -385,9 +385,41 @@ export function getDrugStockAutomaticReduceConfig() {
385 385
 }
386 386
 
387 387
 
388
+export function getDrugIndetail(params){
389
+  return request({
390
+    url:"/api/drugstock/getdrugindetail",
391
+    method:"Get",
392
+    params:params
393
+  })
394
+}
395
+
396
+
397
+export function getDrugCancelOrder(params){
398
+  
399
+   return request({
400
+     url:"/api/drugstock/getdrugcancelorder",
401
+     method:"get",
402
+     params:params
403
+   })
404
+}
388 405
 
406
+export function getDrugOutDetail(params){
407
+  
408
+  return request({
409
+    url:"/api/drugstock/getdrugoutdetail",
410
+    method:"get",
411
+    params:params
412
+  })
413
+}
389 414
 
415
+export function getDrugCancelDetail(params){
390 416
 
417
+  return request({
418
+    url:"/api/drugstock/getdrugcanceldetail",
419
+    method:"Get",
420
+    params:params
421
+  })
422
+}
391 423
 
392 424
 
393 425
 

+ 6 - 0
src/router/modules/drugs.js Целия файл

@@ -42,6 +42,12 @@ export default {
42 42
         name: 'drugsStockCancel',
43 43
         meta: { title: 'drugsStockCancel', noCache: true }
44 44
     },
45
+    {
46
+      path:'/stock/drugs/stock/detail',
47
+      component:()=>import('@/xt_pages/stock/drugs/drugIndex'),
48
+      name:'drugDetail',
49
+      meta:{title:'明细查询',noCache:true}
50
+    },
45 51
     // {
46 52
     //     path: '/stock/drugs/stock/adjustPrice',
47 53
     //     component: () => import('@/xt_pages/stock/drugs/adjustPrice'),

+ 12 - 0
src/router/modules/stock.js Целия файл

@@ -189,5 +189,17 @@ export default {
189 189
       is_menu: false,
190 190
       meta: { title: 'user_detail', noCache: true }
191 191
     },
192
+
193
+    {
194
+      path: '/stock/drugprint',
195
+      component: () => import('@/xt_pages/stock/drugs/drugPrint'),
196
+      hidden: true,
197
+      is_menu: false,
198
+      name: 'stock_print',
199
+      meta: {
200
+        title: '库存打印',
201
+        noCache: true
202
+      }
203
+    },
192 204
   ]
193 205
 }

+ 2 - 2
src/utils/tools.js Целия файл

@@ -155,7 +155,7 @@ export function uParseTime(time, cFormat) {
155 155
 export function calculateAnticoagulantZL(type, shouji, shichang, weichi) {
156 156
   console.log('类型',type)
157 157
   console.log('首剂', shouji)
158
-  console.log('总量', shichang)
158
+  console.log('时长', shichang)
159 159
   console.log('维持', weichi)
160 160
 
161 161
   var t = 0.5
@@ -172,7 +172,7 @@ export function calculateAnticoagulantZL(type, shouji, shichang, weichi) {
172 172
   if (isNaN(shouji) || isNaN(shichang) || isNaN(weichi)) {
173 173
     return 0
174 174
   }
175
-  // console.log((shouji + (shichang - t) * weichi).toFixed(1))
175
+ console.log((shouji + (shichang - t) * weichi).toFixed(1))
176 176
   return (shouji + (shichang - t) * weichi).toFixed(1)
177 177
 }
178 178
 

+ 3 - 27
src/xt_pages/dialysis/details/dialog/dialysisPrescriptionDialog.vue Целия файл

@@ -3244,15 +3244,7 @@
3244 3244
           this.dialysisPrescription.anticoagulant_zongliang = ''
3245 3245
         }
3246 3246
 
3247
-        // this.dialysisPrescription.anticoagulant_zongliang = calculateAnticoagulantZL(
3248
-        //  1,
3249
-        //   this.dialysisPrescription.anticoagulant_shouji,
3250
-        //  duration,
3251
-        //  this.dialysisPrescription.anticoagulant_weichi
3252
-        // );
3253
-        //  if (isNaN(this.dialysisPrescription.anticoagulant_zongliang)) {
3254
-        //    this.dialysisPrescription.anticoagulant_zongliang = "";
3255
-        //  }
3247
+       
3256 3248
       },
3257 3249
       'dialysisPrescription.anticoagulant_shouji': function() {
3258 3250
         let dialysis_duration_minute = 0
@@ -3284,15 +3276,7 @@
3284 3276
           this.dialysisPrescription.anticoagulant_zongliang = ''
3285 3277
         }
3286 3278
 
3287
-        //  this.dialysisPrescription.anticoagulant_zongliang = calculateAnticoagulantZL(
3288
-        //   1,
3289
-        //    this.dialysisPrescription.anticoagulant_shouji,
3290
-        //    duration,
3291
-        //    this.dialysisPrescription.anticoagulant_weichi
3292
-        //  );
3293
-        // if (isNaN(this.dialysisPrescription.anticoagulant_zongliang)) {
3294
-        //    this.dialysisPrescription.anticoagulant_zongliang = "";
3295
-        // }
3279
+        
3296 3280
       },
3297 3281
       'dialysisPrescription.anticoagulant_weichi': function() {
3298 3282
         let dialysis_duration_minute = 0
@@ -3319,15 +3303,7 @@
3319 3303
           this.dialysisPrescription.anticoagulant_zongliang = ''
3320 3304
         }
3321 3305
 
3322
-        // this.dialysisPrescription.anticoagulant_zongliang = calculateAnticoagulantZL(
3323
-        //   1,
3324
-        //  this.dialysisPrescription.anticoagulant_shouji,
3325
-        //   duration,
3326
-        //   this.dialysisPrescription.anticoagulant_weichi
3327
-        // );
3328
-        // if (isNaN(this.dialysisPrescription.anticoagulant_zongliang)) {
3329
-        //   this.dialysisPrescription.anticoagulant_zongliang = "";
3330
-        // }
3306
+      
3331 3307
       },
3332 3308
       'prescription.id': {
3333 3309
         immediate: true,

+ 0 - 1
src/xt_pages/outpatientCharges/outpatientChargesManagement.vue Целия файл

@@ -711,7 +711,6 @@
711 711
                 'record_time': this.record_date,
712 712
                 'admin_user_id':this.$store.getters.xt_user.user.id
713 713
 
714
-
715 714
               }
716 715
               axios.get('http://127.0.0.1:9532/api/refund/post', {
717 716
                 params: params

+ 24 - 4
src/xt_pages/stock/detail/print.vue Целия файл

@@ -52,7 +52,10 @@
52 52
               <!-- <td style="line-height: 50px">
53 53
                 <span v-if="stock.type && stock.type.type_name.length > 0">{{stock.type.type_name}}</span>
54 54
               </td> -->
55
-              <td style="line-height: 50px">{{calCount(stock)}}</td>
55
+              <td style="line-height: 50px">
56
+                <span v-if="type == 3">{{getStockCount(stock.id)}}</span>
57
+                 <span v-else>{{calCount(stock)}}</span> 
58
+              </td>
56 59
               <td style="line-height:50px" v-if="type == 1 && stock.query_warehousing_info.length > 0">{{stock.query_warehousing_info[0].price}}</td>
57 60
               <td style="line-height:50px" v-if="type == 3 && stock.query_warehouseout_info.length > 0">{{stock.query_warehouseout_info[0].price}}</td>
58 61
               <td style="line-height: 50px" v-if="type == 1 || type == 3">{{calTotal(stock)}}</td>
@@ -111,7 +114,7 @@
111 114
         type: this.$route.query.type,
112 115
         start_time: this.$route.query.start_time,
113 116
         end_time: this.$route.query.end_time,
114
-
117
+        stockTotal:[]
115 118
       }
116 119
     },
117 120
     methods: {
@@ -155,6 +158,9 @@
155 158
         this.loading = true
156 159
         getPrintStockGood(this.queryParams).then(response => {
157 160
           if (response.data.state == 1) {
161
+            var stockTotal = response.data.data.stockTotal
162
+            console.log("stocktOTl",stockTotal)
163
+            this.stockTotal = stockTotal
158 164
             for (let i = 0; i < response.data.data.list.length; i++) {
159 165
               if (this.type == 1) {
160 166
                 if (response.data.data.list[i].query_warehousing_info.length > 0) {
@@ -167,10 +173,12 @@
167 173
                 }
168 174
 
169 175
               } else if (this.type == 3) {
176
+              
170 177
                 if (response.data.data.list[i].query_warehouseout_info.length > 0) {
171 178
                   this.stockDatas.push(response.data.data.list[i])
172 179
                 }
173
-
180
+              
181
+                
174 182
               } else if (this.type == 4) {
175 183
                 if (response.data.data.list[i].query_cancel_stock_info.length > 0) {
176 184
                   this.stockDatas.push(response.data.data.list[i])
@@ -197,6 +205,7 @@
197 205
           }
198 206
         })
199 207
       }, calCount(stock) {
208
+      
200 209
         let total = 0
201 210
         var array = []
202 211
         if (this.type == 1) {
@@ -292,7 +301,18 @@
292 301
           }
293 302
         }
294 303
         return name
295
-      }
304
+      },
305
+
306
+     getStockCount(id){
307
+       
308
+       var count = ""
309
+       for(let i=0;i<this.stockTotal.length;i++){
310
+          if(id == this.stockTotal[i].good_id){
311
+             count = this.stockTotal[i].count
312
+          }
313
+       }
314
+       return count
315
+     }
296 316
     },
297 317
     created() {
298 318
       var xtuser = this.$store.getters.xt_user

+ 2 - 0
src/xt_pages/stock/detail/stockOutDetail.vue Целия файл

@@ -310,6 +310,7 @@ export default {
310 310
           this.$message.error(response.data.msg);
311 311
           return false;
312 312
         } else {
313
+          
313 314
           this.total = response.data.data.total;
314 315
           for (let i = 0; i < response.data.data.list.length; i++) {
315 316
             var obj = response.data.data.list[i];
@@ -351,6 +352,7 @@ export default {
351 352
           return false;
352 353
         } else {
353 354
           this.total = response.data.data.total;
355
+         
354 356
           for (let i = 0; i < response.data.data.list.length; i++) {
355 357
             var obj = response.data.data.list[i];
356 358
             obj["is_total"] = 0;

+ 428 - 0
src/xt_pages/stock/drugs/components/drugCancelDetail.vue Целия файл

@@ -0,0 +1,428 @@
1
+<template>
2
+  <div>
3
+    <!-- <el-button
4
+      style="float: right"
5
+      size="small"
6
+      icon="el-icon-printer"
7
+      @click="PrintAction"
8
+      type="primary"
9
+      >打印
10
+    </el-button> -->
11
+    <div class="cell clearfix">
12
+      <el-input
13
+        size="small"
14
+        style="width: 400px;"
15
+        class="filter-item"
16
+        v-model.trim="searchKey"
17
+        placeholder="单据编码/制单人/规格名称"
18
+      />
19
+      <el-button
20
+        size="small"
21
+        class="filter-item"
22
+        type="primary"
23
+        icon="el-icon-search"
24
+        @click="search"
25
+        >搜索</el-button
26
+      >
27
+    </div>
28
+
29
+    <div class="cell clearfix">
30
+      <label class="title"><span class="name">日期查询</span> : </label>
31
+      <el-date-picker
32
+        size="small"
33
+        v-model="start_time"
34
+        prefix-icon="el-icon-date"
35
+        :editable="false"
36
+        style="width: 196px;"
37
+        type="date"
38
+        placeholder="选择日期时间"
39
+        align="right"
40
+        format="yyyy-MM-dd"
41
+        value-format="yyyy-MM-dd"
42
+        @change="startTimeChange"
43
+      ></el-date-picker>
44
+      <span class="cellLine"> - </span>
45
+      <el-date-picker
46
+        size="small"
47
+        v-model="end_time"
48
+        prefix-icon="el-icon-date"
49
+        :editable="false"
50
+        style="width: 196px;"
51
+        type="date"
52
+        placeholder="选择日期时间"
53
+        align="right"
54
+        format="yyyy-MM-dd"
55
+        value-format="yyyy-MM-dd"
56
+        @change="endTimeChange"
57
+      ></el-date-picker>
58
+    </div>
59
+
60
+    <div class="cell clearfix">
61
+      <label class="title"><span class="name">单据类型</span> : </label>
62
+      <el-select
63
+        size="small"
64
+        v-model="order_type"
65
+        clearable
66
+        placeholder="单据类型"
67
+        @change="changeType"
68
+      >
69
+        <el-option
70
+          v-for="item in orderTypeArr"
71
+          :key="item.value"
72
+          :label="item.label"
73
+          :value="item.value"
74
+        >
75
+        </el-option>
76
+      </el-select>
77
+    </div>
78
+
79
+    <div class="cell clearfix">
80
+      <label class="title"><span class="name">其它</span> : </label>
81
+      <el-select
82
+        size="small"
83
+        v-model="manufacturer_id"
84
+        clearable
85
+        placeholder="厂商"
86
+        @change="changeManufacturer"
87
+      >
88
+        <el-option
89
+          v-for="item in manufacturer"
90
+          :key="item.id"
91
+          :label="item.manufacturer_name"
92
+          :value="item.id"
93
+        >
94
+        </el-option>
95
+      </el-select>
96
+    </div>
97
+
98
+    <el-row :gutter="12" style="margin-top: 10px">
99
+      <el-table
100
+        :data="tableData"
101
+        :class="signAndWeighBoxPatients"
102
+        border
103
+        highlight-current-row
104
+        ref="multipleTable"
105
+        @selection-change="select"
106
+        :row-style="{ color: '#303133' }"
107
+        :header-cell-style="{
108
+          backgroundColor: 'rgb(245, 247, 250)',
109
+          color: '#606266'
110
+        }"
111
+      >
112
+        <el-table-column label="单据编号" align="center" width="200">
113
+          <template slot-scope="scope">
114
+            {{scope.row.order_number}}
115
+          </template>
116
+        </el-table-column>
117
+
118
+        <el-table-column label="药品类型" align="center">
119
+          <template slot-scope="scope">
120
+            <span v-if="scope.row.drug_type == 1">西药</span>
121
+            <span v-if="scope.row.drug_type == 2">草药</span>
122
+            <span v-if="scope.row.drug_type == 3">成药</span>
123
+          </template>
124
+        </el-table-column>
125
+
126
+         <el-table-column label="药品名称" align="center">
127
+          <template slot-scope="scope">
128
+             <span>{{scope.row.drug_name}}</span>
129
+          </template>
130
+        </el-table-column>
131
+
132
+        <el-table-column label="规格型号" align="center">
133
+          <template slot-scope="scope">
134
+            <span>{{scope.row.drug_spec}}</span>
135
+          </template>
136
+        </el-table-column>
137
+
138
+        <el-table-column label="单据类型" align="center">
139
+          <template slot-scope="scope">
140
+            <span v-if="scope.row.type == 1">药品退库单</span>
141
+            <span v-if="scope.row.type == 2">其他</span>
142
+          </template>
143
+        </el-table-column>
144
+
145
+        <el-table-column label="操作时间" align="center">
146
+          <template slot-scope="scope">
147
+            <span>{{getTime(scope.row.ctime)}}</span>
148
+          </template>
149
+        </el-table-column>
150
+        <el-table-column label="制单人" align="center">
151
+          <template slot-scope="scope">
152
+          {{getAdminUser(scope.row.creater)}}
153
+          </template>
154
+        </el-table-column>
155
+
156
+        <el-table-column label="数量" align="center">
157
+          <template slot-scope="scope">
158
+            {{scope.row.count}}
159
+          </template>
160
+        </el-table-column>
161
+      </el-table>
162
+
163
+      <el-pagination
164
+        @size-change="handleSizeChange"
165
+        @current-change="handleCurrentChange"
166
+        :page-sizes="[10, 50, 100]"
167
+        :page-size="10"
168
+        background
169
+        style="margin-top:20px;float: right"
170
+        layout="total, sizes, prev, pager, next, jumper"
171
+        :total="total"
172
+      >
173
+      </el-pagination>
174
+    </el-row>
175
+  </div>
176
+</template>
177
+
178
+<script>
179
+import { uParseTime } from "@/utils/tools";
180
+import { fetchAllAdminUsers} from "@/api/doctor";
181
+import {  GetAllConfig} from "@/api/stock";
182
+import { getDrugCancelDetail } from "@/api/drug/drug_stock";
183
+export default {
184
+  name: "cancelStockDetail",
185
+
186
+  created() {
187
+    var nowDate = new Date();
188
+    var nowYear = nowDate.getFullYear();
189
+    var nowMonth = nowDate.getMonth() + 1;
190
+    var nowDay = nowDate.getDate();
191
+    this.end_time =
192
+      nowYear +
193
+      "-" +
194
+      (nowMonth < 10 ? "0" + nowMonth : nowMonth) +
195
+      "-" +
196
+      (nowDay < 10 ? "0" + nowDay : nowDay);
197
+    nowDate.setMonth(nowDate.getMonth() - 1);
198
+    nowYear = nowDate.getFullYear();
199
+    nowMonth = nowDate.getMonth() + 1;
200
+    nowDay = nowDate.getDate();
201
+    this.start_time =
202
+      nowYear +
203
+      "-" +
204
+      (nowMonth < 10 ? "0" + nowMonth : nowMonth) +
205
+      "-" +
206
+      (nowDay < 10 ? "0" + nowDay : nowDay);
207
+  
208
+    this.GetConfigInfo();
209
+    this.fetchAllAdminUsers();
210
+    this.getlist()
211
+  },
212
+  data() {
213
+    return {
214
+      orderTypeArr: [
215
+        { value: 1, label: "药品退库单" },
216
+        { value: 2, label: "其他入库单" }
217
+      ],
218
+      manufacturer_id: "",
219
+      dealer_id: "",
220
+      order_type: "",
221
+      searchKey: "",
222
+      type: 4,
223
+      page: 1,
224
+      limit: 10,
225
+      checked: false,
226
+      total: 0,
227
+      pageTotal: 0,
228
+      pageSelect: 0,
229
+      adminUserOptions: [],
230
+      multipleSelection: [],
231
+      signAndWeighBoxPatients: "sign-and-weigh-box-patients",
232
+      start_time: "",
233
+      cancelStockDate: [],
234
+      end_time: "",
235
+      goodType: [],
236
+      goodInfo: [],
237
+      manufacturer: [],
238
+      selectedTableData: [],
239
+      dealer: [],
240
+      tableData:[]
241
+    };
242
+  },
243
+  methods: {
244
+    PrintAction: function() {
245
+      this.$router.push({
246
+        path: "/stock/print",
247
+        query: {
248
+          type: 4,
249
+          start_time: this.start_time,
250
+          end_time: this.end_time
251
+        }
252
+      });
253
+    },
254
+    changeType: function(val) {
255
+      this.order_type = val;
256
+      this.getlist()
257
+    },
258
+    changeManufacturer: function(val) {
259
+      this.manufacturer_id = val;
260
+      this.getlist()
261
+    },
262
+    getTypeName: function(row) {
263
+      let name = "";
264
+      const name2 = "";
265
+      if (row.type == 1) {
266
+        name = "药品退库单";
267
+      } else if (row.type == 2) {
268
+        name = "其他退库单";
269
+      }
270
+
271
+      return name;
272
+    },
273
+   
274
+  
275
+    search() {
276
+      this.getlist()
277
+    },
278
+  
279
+   
280
+   
281
+    fetchAllAdminUsers() {
282
+      fetchAllAdminUsers().then(response => {
283
+        console.log(response);
284
+        if (response.data.state == 1) {
285
+          this.adminUserOptions = response.data.data.users;
286
+        }
287
+      });
288
+    },
289
+    handleSelectionChange: function(val) {
290
+      this.multipleSelection = val;
291
+      this.getlist()
292
+    },
293
+    handleSizeChange(val) {
294
+      this.limit = val;
295
+      this.getlist()
296
+    },
297
+    handleCurrentChange(val) {
298
+      this.page = val;
299
+      this.getlist()
300
+    },
301
+    startTimeChange(val) {
302
+      var time = this.getTimestamp(val) - this.getTimestamp(this.end_time);
303
+      if (time > 0) {
304
+        this.$message.error("结束时间不能小于开始时间");
305
+        this.start_time = "";
306
+      } else {
307
+        this.getlist()
308
+      }
309
+    },
310
+    endTimeChange(val) {
311
+      var time = this.getTimestamp(val) - this.getTimestamp(this.start_time);
312
+      if (time < 0) {
313
+        this.$message.error("结束时间不能小于开始时间");
314
+        this.end_time = "";
315
+      } else {
316
+        this.getlist()
317
+      }
318
+    },
319
+    getTimestamp(time) {
320
+      // 把时间日期转成时间戳
321
+      return new Date(time).getTime() / 1000;
322
+    },
323
+    calculate: function(val) {
324
+      return Math.round(parseFloat(val) * 100) / 100;
325
+    },
326
+    GetConfigInfo: function() {
327
+      GetAllConfig().then(response => {
328
+        if (response.data.state == 0) {
329
+          this.$message.error(response.data.msg);
330
+          return false;
331
+        } else {
332
+          this.manufacturer = response.data.data.manufacturer;
333
+          this.dealer = response.data.data.dealer;
334
+          this.goodInfo = response.data.data.goodInfo;
335
+          this.goodType = response.data.data.goodType;
336
+        }
337
+      });
338
+    },
339
+  
340
+  
341
+   
342
+    select(selection) {
343
+     
344
+    },
345
+    getlist(){
346
+       var params = {
347
+        start_time:this.start_time,
348
+        end_time:this.end_time,
349
+        order_type:this.order_type,
350
+        manufacturer_id:this.manufacturer_id,
351
+        keyword:this.searchKey,
352
+        limit:this.limit,
353
+        page:this.page,
354
+       }
355
+      getDrugCancelDetail(params).then(response=>{
356
+         if(response.data.state == 1){
357
+           var order =  response.data.data.order
358
+           console.log("退库详细",order)
359
+           this.tableData = order
360
+           var total = response.data.data.total
361
+           this.total = total
362
+         } 
363
+      })
364
+    },
365
+
366
+     getAdminUser(id){
367
+      var name = ""
368
+      for(let i=0;i<this.adminUserOptions.length;i++){
369
+          if(id == this.adminUserOptions[i].id){
370
+             name = this.adminUserOptions[i].name
371
+          }
372
+      }
373
+      return name
374
+    },
375
+
376
+      getTime: function(val) {
377
+      if (val == 0) {
378
+        return "";
379
+      } else {
380
+        return uParseTime(val, "{y}-{m}-{d}");
381
+      }
382
+    },
383
+  }
384
+};
385
+</script>
386
+
387
+<style rel="stylesheet/css" lang="scss" scoped>
388
+.information {
389
+  border: 1px #dcdfe6 solid;
390
+  padding: 30px 20px 30px 20px;
391
+
392
+  .border {
393
+    border-bottom: 1px #dcdfe6 solid;
394
+    margin: 0px 0 20px 0;
395
+  }
396
+}
397
+
398
+.edit_separater {
399
+  border-top: 1px solid rgb(233, 233, 233);
400
+  margin-top: 15px;
401
+  margin-bottom: 15px;
402
+}
403
+</style>
404
+
405
+<style>
406
+.sign-and-weigh-box .sign-and-weigh-box-patients .cell {
407
+  font-size: 12px;
408
+}
409
+
410
+.sign-and-weigh-box .sign-and-weigh-box-patients .current-row > td {
411
+  background: #6fb5fa;
412
+}
413
+
414
+.count {
415
+  color: #bd2c00;
416
+}
417
+.el-table td,
418
+.el-table th.is-leaf,
419
+.el-table--border,
420
+.el-table--group {
421
+  border-color: #d0d3da;
422
+}
423
+.el-table--border::after,
424
+.el-table--group::after,
425
+.el-table::before {
426
+  background-color: #d0d3da;
427
+}
428
+</style>

+ 463 - 0
src/xt_pages/stock/drugs/components/drugCancelOrder.vue Целия файл

@@ -0,0 +1,463 @@
1
+<template>
2
+  <div>
3
+    <!-- <el-button
4
+      style="float: right"
5
+      size="small"
6
+      icon="el-icon-printer"
7
+      @click="PrintAction"
8
+      type="primary"
9
+      >打印
10
+    </el-button> -->
11
+    <div class="cell clearfix">
12
+      <el-input
13
+        size="small"
14
+        style="width: 400px;"
15
+        class="filter-item"
16
+        v-model="searchKey"
17
+        placeholder="单据编码/制单人/规格名称"
18
+      />
19
+      <el-button
20
+        size="small"
21
+        class="filter-item"
22
+        type="primary"
23
+        icon="el-icon-search"
24
+        @click="search"
25
+        >搜索</el-button
26
+      >
27
+    </div>
28
+
29
+    <div class="cell clearfix">
30
+      <label class="title"><span class="name">日期查询</span> : </label>
31
+      <el-date-picker
32
+        size="small"
33
+        v-model="start_time"
34
+        prefix-icon="el-icon-date"
35
+        :editable="false"
36
+        style="width: 196px;"
37
+        type="date"
38
+        placeholder="选择日期时间"
39
+        align="right"
40
+        format="yyyy-MM-dd"
41
+        value-format="yyyy-MM-dd"
42
+        @change="startTimeChange"
43
+      ></el-date-picker>
44
+      <span class="cellLine"> - </span>
45
+      <el-date-picker
46
+        size="small"
47
+        v-model="end_time"
48
+        prefix-icon="el-icon-date"
49
+        :editable="false"
50
+        style="width: 196px;"
51
+        type="date"
52
+        placeholder="选择日期时间"
53
+        align="right"
54
+        format="yyyy-MM-dd"
55
+        value-format="yyyy-MM-dd"
56
+        @change="endTimeChange"
57
+      ></el-date-picker>
58
+    </div>
59
+
60
+    <div class="cell clearfix">
61
+      <label class="title"><span class="name">单据类型</span> : </label>
62
+      <el-select
63
+        size="small"
64
+        v-model="order_type"
65
+        clearable
66
+        placeholder="单据类型"
67
+        @change="changeType"
68
+      >
69
+        <el-option
70
+          v-for="item in orderTypeArr"
71
+          :key="item.value"
72
+          :label="item.label"
73
+          :value="item.value"
74
+        >
75
+        </el-option>
76
+      </el-select>
77
+    </div>
78
+
79
+    <div class="cell clearfix">
80
+      <label class="title"><span class="name">其它</span> : </label>
81
+      <el-select
82
+        size="small"
83
+        v-model="manufacturer_id"
84
+        clearable
85
+        placeholder="厂商"
86
+        @change="changeManufacturer"
87
+      >
88
+        <el-option
89
+          v-for="item in manufacturer"
90
+          :key="item.id"
91
+          :label="item.manufacturer_name"
92
+          :value="item.id"
93
+        >
94
+        </el-option>
95
+      </el-select>
96
+    </div>
97
+
98
+    <el-row :gutter="12" style="margin-top: 10px">
99
+      <el-table
100
+        :data="tableData"
101
+        :class="signAndWeighBoxPatients"
102
+        border
103
+        highlight-current-row
104
+        ref="multipleTable"
105
+        @selection-change="select"
106
+        :row-style="{ color: '#303133' }"
107
+        :header-cell-style="{
108
+          backgroundColor: 'rgb(245, 247, 250)',
109
+          color: '#606266'
110
+        }"
111
+      >
112
+        <el-table-column label="单据编号" align="center" width="200">
113
+          <template slot-scope="scope">
114
+             {{scope.row.order_number}} 
115
+          </template>
116
+        </el-table-column>
117
+
118
+        
119
+
120
+        <el-table-column label="药品类型" align="center">
121
+          <template slot-scope="scope">
122
+            <span v-if="scope.row.drug_type == 1">西药</span>
123
+            <span v-if="scope.row.drug_type == 2">草药</span>
124
+            <span v-if="scope.row.drug_type == 3">成药</span>
125
+          </template>
126
+        </el-table-column>
127
+
128
+         <el-table-column label="药品名称" align="center">
129
+          <template slot-scope="scope">
130
+            <span>{{scope.row.drug_name}}</span>
131
+          </template>
132
+        </el-table-column>
133
+
134
+        <el-table-column label="规格型号" align="center">
135
+          <template slot-scope="scope">
136
+             <span>{{scope.row.drug_spec}}</span>
137
+          </template>
138
+        </el-table-column>
139
+
140
+        <el-table-column label="单据类型" align="center">
141
+          <template slot-scope="scope">
142
+           <span v-if="scope.row.type == 1">药品退货单</span>
143
+            <span v-if="scope.row.type == 2">其他</span>
144
+          </template>
145
+        </el-table-column>
146
+
147
+        <el-table-column label="操作时间" align="center">
148
+          <template slot-scope="scope">
149
+            <span>{{getTime(scope.row.ctime)}}</span>
150
+          </template>
151
+        </el-table-column>
152
+        <el-table-column label="制单人" align="center">
153
+          <template slot-scope="scope">
154
+             <span>{{getAdminUser(scope.row.creater)}}</span>
155
+          </template>
156
+        </el-table-column>
157
+
158
+        <el-table-column label="数量" align="center">
159
+          <template slot-scope="scope">
160
+             <span>{{scope.row.count}}</span>
161
+          </template>
162
+        </el-table-column>
163
+      </el-table>
164
+
165
+      <el-pagination
166
+        @size-change="handleSizeChange"
167
+        @current-change="handleCurrentChange"
168
+        :page-sizes="[10, 50, 100]"
169
+        :page-size="10"
170
+        background
171
+        style="margin-top:20px;float: right"
172
+        layout="total, sizes, prev, pager, next, jumper"
173
+        :total="total"
174
+      >
175
+      </el-pagination>
176
+    </el-row>
177
+  </div>
178
+</template>
179
+
180
+<script>
181
+import { uParseTime } from "@/utils/tools";
182
+import { fetchAllAdminUsers, fetchAllDoctorAndNurse } from "@/api/doctor";
183
+import { getDrugCancelOrder } from "@/api/drug/drug_stock"
184
+import { GetAllConfig } from "@/api/stock";
185
+export default {
186
+  name: "salesReturnDetail",
187
+
188
+  created() {
189
+    var nowDate = new Date();
190
+    var nowYear = nowDate.getFullYear();
191
+    var nowMonth = nowDate.getMonth() + 1;
192
+    var nowDay = nowDate.getDate();
193
+    this.end_time =
194
+      nowYear +
195
+      "-" +
196
+      (nowMonth < 10 ? "0" + nowMonth : nowMonth) +
197
+      "-" +
198
+      (nowDay < 10 ? "0" + nowDay : nowDay);
199
+    nowDate.setMonth(nowDate.getMonth() - 1);
200
+    nowYear = nowDate.getFullYear();
201
+    nowMonth = nowDate.getMonth() + 1;
202
+    nowDay = nowDate.getDate();
203
+    this.start_time =
204
+      nowYear +
205
+      "-" +
206
+      (nowMonth < 10 ? "0" + nowMonth : nowMonth) +
207
+      "-" +
208
+      (nowDay < 10 ? "0" + nowDay : nowDay);
209
+    this.GetConfigInfo();
210
+    this.fetchAllAdminUsers();
211
+    this.getlist()
212
+  },
213
+  data() {
214
+    return {
215
+      orderTypeArr: [
216
+        { value: 1, label: "药品退货单" },
217
+        { value: 2, label: "其他入库单" }
218
+      ],
219
+      manufacturer_id: "",
220
+      dealer_id: "",
221
+      order_type: "",
222
+      searchKey: "",
223
+      type: 3,
224
+      page: 1,
225
+      limit: 10,
226
+      checked: false,
227
+      total: 0,
228
+      pageTotal: 0,
229
+      pageSelect: 0,
230
+      adminUserOptions: [],
231
+      multipleSelection: [],
232
+      signAndWeighBoxPatients: "sign-and-weigh-box-patients",
233
+      start_time: "",
234
+      cancelStockDate: [],
235
+      end_time: "",
236
+      goodType: [],
237
+      goodInfo: [],
238
+      manufacturer: [],
239
+      selectedTableData: [],
240
+      dealer: [],
241
+      tableData:[]
242
+    };
243
+  },
244
+  methods: {
245
+    changeType: function(val) {
246
+      this.order_type = val;
247
+      this.getlist()
248
+    },
249
+    changeManufacturer: function(val) {
250
+      this.manufacturer_id = val;
251
+      this.getlist()
252
+    },
253
+    getTypeName: function(row) {
254
+      let name = "";
255
+      if (row.type == 1) {
256
+        name = "耗材退货单";
257
+      } else if (row.type == 2) {
258
+        name = "其他退货单";
259
+      }
260
+
261
+      return name;
262
+    },
263
+    typeName: function(good_type_id) {
264
+      let name = "";
265
+      for (let i = 0; i < this.goodType.length; i++) {
266
+        if (this.goodType[i].id == good_type_id) {
267
+          name = this.goodType[i].type_name;
268
+        }
269
+      }
270
+      return name;
271
+    },
272
+    typeNameOne:function(good_id){
273
+      let name = "";
274
+      for (let i = 0; i < this.goodInfo.length; i++) {
275
+        if (this.goodInfo[i].id == good_id) {
276
+          name = this.goodInfo[i].good_name;
277
+        }
278
+      }
279
+      return name
280
+    },
281
+    specificationName: function(good_info_id) {
282
+      let name = "";
283
+      for (let i = 0; i < this.goodInfo.length; i++) {
284
+        if (this.goodInfo[i].id == good_info_id) {
285
+          name = this.goodInfo[i].specification_name;
286
+        }
287
+      }
288
+      return name;
289
+    },
290
+    search(){
291
+      this.getlist()
292
+    },
293
+  
294
+    PrintAction: function() {
295
+    
296
+    },
297
+  
298
+    getXuserName(id) {
299
+      if (id <= 0) {
300
+        return "";
301
+      }
302
+      var name = "";
303
+      if (
304
+        this.adminUserOptions == null ||
305
+        typeof this.adminUserOptions.length === "undefined"
306
+      ) {
307
+        return name;
308
+      }
309
+      var leng = this.adminUserOptions.length;
310
+      if (leng == 0) {
311
+        return name;
312
+      }
313
+      for (let index = 0; index < leng; index++) {
314
+        if (this.adminUserOptions[index].id == id) {
315
+          name = this.adminUserOptions[index].name;
316
+          break;
317
+        }
318
+      }
319
+      return name;
320
+    },
321
+    fetchAllAdminUsers() {
322
+      fetchAllAdminUsers().then(response => {
323
+        if (response.data.state == 1) {
324
+          this.adminUserOptions = response.data.data.users;
325
+        }
326
+      });
327
+    },
328
+    handleSelectionChange: function(val) {
329
+      this.multipleSelection = val;
330
+    },
331
+    handleSizeChange(val) {
332
+      this.limit = val;
333
+      this.getlist()
334
+    },
335
+    handleCurrentChange(val) {
336
+      this.page = val;
337
+      this.getlist()
338
+    },
339
+    startTimeChange(val) {
340
+      var time = this.getTimestamp(val) - this.getTimestamp(this.end_time);
341
+      if (time > 0) {
342
+        this.$message.error("结束时间不能小于开始时间");
343
+        this.start_time = "";
344
+      } else {
345
+        this.getlist() 
346
+      }
347
+    },
348
+    endTimeChange(val) {
349
+      var time = this.getTimestamp(val) - this.getTimestamp(this.start_time);
350
+      if (time < 0) {
351
+        this.$message.error("结束时间不能小于开始时间");
352
+        this.end_time = "";
353
+      } else {
354
+        this.getlist()
355
+      }
356
+    },
357
+    getTimestamp(time) {
358
+      // 把时间日期转成时间戳
359
+      return new Date(time).getTime() / 1000;
360
+    },
361
+    calculate: function(val) {
362
+      return Math.round(parseFloat(val) * 100) / 100;
363
+    },
364
+    GetConfigInfo() {
365
+      GetAllConfig().then(response => {
366
+        if (response.data.state == 0) {
367
+          this.$message.error(response.data.msg);
368
+          return false;
369
+        } else {
370
+          this.manufacturer = response.data.data.manufacturer;
371
+          this.dealer = response.data.data.dealer;
372
+          this.goodInfo = response.data.data.goodInfo;
373
+          this.goodType = response.data.data.goodType;
374
+        }
375
+      });
376
+    },
377
+    select(selection) {
378
+      this.selectedTableData = selection;
379
+    },
380
+
381
+    getlist(){
382
+     const params = {
383
+        start_time:this.start_time,
384
+        end_time:this.end_time,
385
+        order_type:this.order_type,
386
+        manufacturer_id:this.manufacturer_id,
387
+        keyword:this.searchKey,
388
+        limit:this.limit,
389
+        page:this.page,
390
+      }
391
+      getDrugCancelOrder(params).then(response=>{
392
+        if(response.data.state == 1){
393
+          var order = response.data.data.order
394
+          console.log("order",order)
395
+          this.tableData = order
396
+          var total =  response.data.data.total
397
+          this.total = total
398
+        }
399
+      }) 
400
+    },
401
+
402
+   getAdminUser(id){
403
+      var name = ""
404
+      for(let i=0;i<this.adminUserOptions.length;i++){
405
+          if(id == this.adminUserOptions[i].id){
406
+             name = this.adminUserOptions[i].name
407
+          }
408
+      }
409
+      return name
410
+    },
411
+   getTime: function(val) {
412
+      if (val == 0) {
413
+        return "";
414
+      } else {
415
+        return uParseTime(val, "{y}-{m}-{d}");
416
+      }
417
+    },
418
+  }
419
+};
420
+</script>
421
+
422
+<style rel="stylesheet/css" lang="scss" scoped>
423
+.information {
424
+  border: 1px #dcdfe6 solid;
425
+  padding: 30px 20px 30px 20px;
426
+
427
+  .border {
428
+    border-bottom: 1px #dcdfe6 solid;
429
+    margin: 0px 0 20px 0;
430
+  }
431
+}
432
+
433
+.edit_separater {
434
+  border-top: 1px solid rgb(233, 233, 233);
435
+  margin-top: 15px;
436
+  margin-bottom: 15px;
437
+}
438
+</style>
439
+
440
+<style>
441
+.sign-and-weigh-box .sign-and-weigh-box-patients .cell {
442
+  font-size: 12px;
443
+}
444
+
445
+.sign-and-weigh-box .sign-and-weigh-box-patients .current-row > td {
446
+  background: #6fb5fa;
447
+}
448
+
449
+.count {
450
+  color: #bd2c00;
451
+}
452
+.el-table td,
453
+.el-table th.is-leaf,
454
+.el-table--border,
455
+.el-table--group {
456
+  border-color: #d0d3da;
457
+}
458
+.el-table--border::after,
459
+.el-table--group::after,
460
+.el-table::before {
461
+  background-color: #d0d3da;
462
+}
463
+</style>

+ 424 - 0
src/xt_pages/stock/drugs/components/drugInOrder.vue Целия файл

@@ -0,0 +1,424 @@
1
+<template>
2
+  <div>
3
+    <el-button
4
+      style="float: right"
5
+      size="small"
6
+      icon="el-icon-printer"
7
+      @click="PrintAction"
8
+      type="primary"
9
+      >打印
10
+    </el-button>
11
+
12
+    <div class="cell clearfix">
13
+      <el-input
14
+        size="small"
15
+        style="width: 400px;"
16
+        class="filter-item"
17
+        v-model.trim="searchKey"
18
+        placeholder="单据编码/制单人/规格名称"
19
+      />
20
+      <el-button
21
+        size="small"
22
+        class="filter-item"
23
+        type="primary"
24
+        icon="el-icon-search"
25
+        @click="search"
26
+        >搜索</el-button
27
+      >
28
+    </div>
29
+
30
+    <div class="cell clearfix">
31
+      <label class="title"><span class="name">日期查询</span> : </label>
32
+      <el-date-picker
33
+        size="small"
34
+        v-model="start_time"
35
+        prefix-icon="el-icon-date"
36
+        :editable="false"
37
+        style="width: 196px;"
38
+        type="date"
39
+        placeholder="选择日期时间"
40
+        align="right"
41
+        format="yyyy-MM-dd"
42
+        value-format="yyyy-MM-dd"
43
+        @change="startTimeChange"
44
+      ></el-date-picker>
45
+      <span class="cellLine"> - </span>
46
+      <el-date-picker
47
+        size="small"
48
+        v-model="end_time"
49
+        prefix-icon="el-icon-date"
50
+        :editable="false"
51
+        style="width: 196px;"
52
+        type="date"
53
+        placeholder="选择日期时间"
54
+        align="right"
55
+        format="yyyy-MM-dd"
56
+        value-format="yyyy-MM-dd"
57
+        @change="endTimeChange"
58
+      ></el-date-picker>
59
+    </div>
60
+
61
+    <div class="cell clearfix">
62
+      <label class="title"><span class="name">单据类型</span> : </label>
63
+      <el-select
64
+        size="small"
65
+        v-model="order_type"
66
+        clearable
67
+        placeholder="单据类型"
68
+        @change="changeType"
69
+      >
70
+        <el-option
71
+          v-for="item in orderTypeArr"
72
+          :key="item.value"
73
+          :label="item.label"
74
+          :value="item.value"
75
+        >
76
+        </el-option>
77
+      </el-select>
78
+    </div>
79
+
80
+    <div class="cell clearfix">
81
+      <label class="title"><span class="name">其它</span> : </label>
82
+      <el-select
83
+        size="small"
84
+        v-model="manufacturer_id"
85
+        clearable
86
+        placeholder="厂商"
87
+        @change="changeManufacturer"
88
+      >
89
+        <el-option
90
+          v-for="item in manufacturer"
91
+          :key="item.id"
92
+          :label="item.manufacturer_name"
93
+          :value="item.id"
94
+        >
95
+        </el-option>
96
+      </el-select>
97
+    </div>
98
+
99
+    <el-row :gutter="12" style="margin-top: 10px">
100
+      <el-table
101
+        :data="cancelStockDate"
102
+        :class="signAndWeighBoxPatients"
103
+        border
104
+        highlight-current-row
105
+        ref="multipleTable"
106
+        @selection-change="select"
107
+        :row-style="{ color: '#303133' }"
108
+        :header-cell-style="{
109
+          backgroundColor: 'rgb(245, 247, 250)',
110
+          color: '#606266'
111
+        }"
112
+      >
113
+        <el-table-column label="单据编号" align="center" width="200">
114
+          <template slot-scope="scope">
115
+            {{scope.row.warehousing_order}}
116
+          </template>
117
+        </el-table-column>
118
+
119
+        <el-table-column label="药品类型" align="center">
120
+          <template slot-scope="scope">
121
+            <span v-if="scope.row.drug_type == 1">西药</span>
122
+            <span v-if="scope.row.drug_type == 2">草药</span>
123
+            <span v-if="scope.row.drug_type == 3">成药</span>
124
+          </template>
125
+        </el-table-column>
126
+
127
+        <el-table-column label="药品名称" align="center">
128
+          <template slot-scope="scope">
129
+            {{scope.row.drug_name}}
130
+          </template>
131
+        </el-table-column>
132
+
133
+        <el-table-column label="规格型号" align="center">
134
+          <template slot-scope="scope">
135
+           {{scope.row.drug_spec}}
136
+          </template>
137
+        </el-table-column>
138
+
139
+        <el-table-column label="单据类型" align="center">
140
+          <template slot-scope="scope">
141
+            <span v-if="scope.row.type == 1">药品入库单</span>
142
+            <span v-if="scope.row.type == 2">其他</span>
143
+          </template>
144
+        </el-table-column>
145
+
146
+        <el-table-column label="操作时间" align="center">
147
+          <template slot-scope="scope">
148
+            <span>{{getTime(scope.row.ctime)}}</span>
149
+          </template>
150
+        </el-table-column>
151
+        <el-table-column label="制单人" align="center">
152
+          <template slot-scope="scope">
153
+           {{getAdminUser(scope.row.creater)}}
154
+          </template>
155
+        </el-table-column>
156
+        <el-table-column label="进货价" align="center">
157
+          <template slot-scope="scope">
158
+            {{scope.row.price}}
159
+          </template>
160
+        </el-table-column>
161
+        <el-table-column label="数量" align="center">
162
+          <template slot-scope="scope">
163
+            {{scope.row.warehousing_count}}
164
+          </template>
165
+        </el-table-column>
166
+        <el-table-column label="总价" align="center">
167
+          <template slot-scope="scope">
168
+            {{scope.row.total_price}}
169
+          </template>
170
+        </el-table-column>
171
+      </el-table>
172
+
173
+      <el-pagination
174
+        @size-change="handleSizeChange"
175
+        @current-change="handleCurrentChange"
176
+        :page-sizes="[10, 50, 100]"
177
+        :page-size="10"
178
+        background
179
+        style="margin-top:20px;float: right"
180
+        layout="total, sizes, prev, pager, next, jumper"
181
+        :total="total"
182
+      >
183
+      </el-pagination>
184
+    </el-row>
185
+  </div>
186
+</template>
187
+
188
+<script>
189
+import { uParseTime } from "@/utils/tools";
190
+import { fetchAllAdminUsers } from "@/api/doctor";
191
+import { GetAllConfig } from "@/api/stock";
192
+import { getDrugIndetail} from "@/api/drug/drug_stock"
193
+export default {
194
+  name: "stockInDetail",
195
+
196
+  created() {
197
+    var nowDate = new Date();
198
+    var nowYear = nowDate.getFullYear();
199
+    var nowMonth = nowDate.getMonth() + 1;
200
+    var nowDay = nowDate.getDate();
201
+    this.end_time =
202
+      nowYear +
203
+      "-" +
204
+      (nowMonth < 10 ? "0" + nowMonth : nowMonth) +
205
+      "-" +
206
+      (nowDay < 10 ? "0" + nowDay : nowDay);
207
+    nowDate.setMonth(nowDate.getMonth() - 1);
208
+    nowYear = nowDate.getFullYear();
209
+    nowMonth = nowDate.getMonth() + 1;
210
+    nowDay = nowDate.getDate();
211
+    this.start_time =
212
+      nowYear +
213
+      "-" +
214
+      (nowMonth < 10 ? "0" + nowMonth : nowMonth) +
215
+      "-" +
216
+      (nowDay < 10 ? "0" + nowDay : nowDay);
217
+    this.GetConfigInfo()
218
+    this.fetchAllAdminUsers()
219
+    //获取入库单数据
220
+    this.getlist()
221
+  },
222
+  data() {
223
+    return {
224
+      orderTypeArr: [
225
+        { value: 1, label: "药品入库单" },
226
+        { value: 2, label: "其他入库单" }
227
+      ],
228
+      newDate: [{ name: "合计", num: "111111" }],
229
+
230
+      searchKey: "",
231
+      type: 1,
232
+      page: 1,
233
+      limit: 10,
234
+      manufacturer_id: "",
235
+      dealer_id: "",
236
+      order_type: "",
237
+      checked: false,
238
+      total: 0,
239
+      pageTotal: 0,
240
+      pageSelect: 0,
241
+      adminUserOptions: [],
242
+      multipleSelection: [],
243
+      signAndWeighBoxPatients: "sign-and-weigh-box-patients",
244
+      start_time: "",
245
+      cancelStockDate: [],
246
+      end_time: "",
247
+      goodType: [],
248
+      goodInfo: [],
249
+      manufacturer: [],
250
+      selectedTableData: [],
251
+      dealer: []
252
+    };
253
+  },
254
+  methods: {
255
+    changeType: function(val) {
256
+      this.order_type = val;
257
+     
258
+    },
259
+    changeManufacturer: function(val) {
260
+      this.manufacturer_id = val;
261
+      
262
+    },
263
+    changeDealer: function(val) {
264
+      this.dealer_id = val;
265
+     
266
+    },
267
+    search: function() {
268
+      this.getlist()
269
+    },
270
+    getTime: function(val) {
271
+      if (val == 0) {
272
+        return "";
273
+      } else {
274
+        return uParseTime(val, "{y}-{m}-{d}");
275
+      }
276
+    },
277
+    AddNewOrder: function() {
278
+   
279
+    },
280
+  
281
+   
282
+    fetchAllAdminUsers() {
283
+      fetchAllAdminUsers().then(response => {
284
+        console.log(response);
285
+        if (response.data.state == 1) {
286
+          this.adminUserOptions = response.data.data.users;
287
+          console.log("医生护士",this.adminUserOptions)
288
+        }
289
+      });
290
+    },
291
+    handleSelectionChange: function(val) {
292
+      this.multipleSelection = val;
293
+    },
294
+    handleSizeChange(val) {
295
+      this.limit = val;
296
+      this.getlist()
297
+    },
298
+    handleCurrentChange(val) {
299
+      this.page = val;
300
+      this.getlist()
301
+     
302
+    },
303
+    startTimeChange(val) {
304
+      var time = this.getTimestamp(val) - this.getTimestamp(this.end_time);
305
+      if (time > 0) {
306
+        this.$message.error("结束时间不能小于开始时间");
307
+        this.start_time = "";
308
+      } else {
309
+        this.getlist();
310
+      }
311
+    },
312
+    endTimeChange(val) {
313
+      var time = this.getTimestamp(val) - this.getTimestamp(this.start_time);
314
+      if (time < 0) {
315
+        this.$message.error("结束时间不能小于开始时间");
316
+        this.end_time = "";
317
+      } else {
318
+        this.getlist();
319
+      }
320
+    },
321
+    getTimestamp(time) {
322
+      // 把时间日期转成时间戳
323
+      return new Date(time).getTime() / 1000;
324
+    },
325
+    calculate: function(val) {
326
+      return Math.round(parseFloat(val) * 100) / 100;
327
+    },
328
+
329
+     GetConfigInfo(){
330
+      GetAllConfig().then(response => {
331
+        if (response.data.state == 0) {
332
+          this.$message.error(response.data.msg);
333
+          return false;
334
+        } else {
335
+          this.manufacturer = response.data.data.manufacturer;
336
+          this.dealer = response.data.data.dealer;
337
+          this.goodInfo = response.data.data.goodInfo;
338
+          this.goodType = response.data.data.goodType;
339
+        }
340
+      });
341
+    },
342
+
343
+   
344
+    getlist(){
345
+       var params = {
346
+        start_time:this.start_time,
347
+        end_time:this.end_time,
348
+        order_type:this.order_type,
349
+        manufacturer_id:this.manufacturer_id,
350
+        keyword:this.searchKey,
351
+        limit:this.limit,
352
+        page:this.page,
353
+       }
354
+      getDrugIndetail(params).then(response=>{
355
+        if(response.data.state == 1){
356
+          var drugInOrder = response.data.data.detail
357
+          console.log("drug3434444",drugInOrder)
358
+          this.cancelStockDate = drugInOrder
359
+          var total = response.data.data.total
360
+          this.total = total
361
+        }
362
+      })
363
+    },
364
+    PrintAction(){
365
+      this.$router.push("/stock/drugprint?start_time="+this.start_time+"&end_time="+this.end_time+"&order_type="+this.order_type+"&manufacturer_id="+this.manufacturer_id+"&keyword="+this.keyword+"&limit="+this.limit+"&page="+this.page)
366
+    },
367
+    select(){
368
+
369
+    },
370
+    getAdminUser(id){
371
+      var name = ""
372
+      for(let i=0;i<this.adminUserOptions.length;i++){
373
+          if(id == this.adminUserOptions[i].id){
374
+             name = this.adminUserOptions[i].name
375
+          }
376
+      }
377
+      return name
378
+    }
379
+  }
380
+};
381
+</script>
382
+
383
+<style rel="stylesheet/css" lang="scss" scoped>
384
+.information {
385
+  border: 1px #dcdfe6 solid;
386
+  padding: 30px 20px 30px 20px;
387
+
388
+  .border {
389
+    border-bottom: 1px #dcdfe6 solid;
390
+    margin: 0px 0 20px 0;
391
+  }
392
+}
393
+
394
+.edit_separater {
395
+  border-top: 1px solid rgb(233, 233, 233);
396
+  margin-top: 15px;
397
+  margin-bottom: 15px;
398
+}
399
+</style>
400
+
401
+<style>
402
+.sign-and-weigh-box .sign-and-weigh-box-patients .cell {
403
+  font-size: 12px;
404
+}
405
+
406
+.sign-and-weigh-box .sign-and-weigh-box-patients .current-row > td {
407
+  background: #6fb5fa;
408
+}
409
+
410
+.count {
411
+  color: #bd2c00;
412
+}
413
+.el-table td,
414
+.el-table th.is-leaf,
415
+.el-table--border,
416
+.el-table--group {
417
+  border-color: #d0d3da;
418
+}
419
+.el-table--border::after,
420
+.el-table--group::after,
421
+.el-table::before {
422
+  background-color: #d0d3da;
423
+}
424
+</style>

+ 446 - 0
src/xt_pages/stock/drugs/components/drugOutDetail.vue Целия файл

@@ -0,0 +1,446 @@
1
+<template>
2
+  <div>
3
+    <!-- <el-button
4
+      style="float: right"
5
+      size="small"
6
+      icon="el-icon-printer"
7
+      @click="PrintAction"
8
+      type="primary"
9
+      >打印
10
+    </el-button> -->
11
+    <div class="cell clearfix">
12
+      <el-input
13
+        size="small"
14
+        style="width: 400px;"
15
+        class="filter-item"
16
+        v-model.trim="searchKey"
17
+        placeholder="单据编码/制单人/规格名称"
18
+      />
19
+      <el-button
20
+        size="small"
21
+        class="filter-item"
22
+        type="primary"
23
+        icon="el-icon-search"
24
+        @click="search"
25
+        >搜索</el-button
26
+      >
27
+    </div>
28
+
29
+    <div class="cell clearfix">
30
+      <label class="title"><span class="name">日期查询</span> : </label>
31
+      <el-date-picker
32
+        size="small"
33
+        v-model="start_time"
34
+        prefix-icon="el-icon-date"
35
+        :editable="false"
36
+        style="width: 196px;"
37
+        type="date"
38
+        placeholder="选择日期时间"
39
+        align="right"
40
+        format="yyyy-MM-dd"
41
+        value-format="yyyy-MM-dd"
42
+        @change="startTimeChange"
43
+      ></el-date-picker>
44
+      <span class="cellLine"> - </span>
45
+      <el-date-picker
46
+        size="small"
47
+        v-model="end_time"
48
+        prefix-icon="el-icon-date"
49
+        :editable="false"
50
+        style="width: 196px;"
51
+        type="date"
52
+        placeholder="选择日期时间"
53
+        align="right"
54
+        format="yyyy-MM-dd"
55
+        value-format="yyyy-MM-dd"
56
+        @change="endTimeChange"
57
+      ></el-date-picker>
58
+    </div>
59
+
60
+    <div class="cell clearfix">
61
+      <label class="title"><span class="name">单据类型</span> : </label>
62
+      <el-select
63
+        size="small"
64
+        v-model="order_type"
65
+        clearable
66
+        placeholder="单据类型"
67
+        @change="changeType"
68
+      >
69
+        <el-option
70
+          v-for="item in orderTypeArr"
71
+          :key="item.value"
72
+          :label="item.label"
73
+          :value="item.value"
74
+        >
75
+        </el-option>
76
+      </el-select>
77
+    </div>
78
+
79
+    <div class="cell clearfix">
80
+      <label class="title"><span class="name">其它</span> : </label>
81
+      <el-select
82
+        size="small"
83
+        v-model="manufacturer_id"
84
+        clearable
85
+        placeholder="厂商"
86
+        @change="changeManufacturer"
87
+      >
88
+        <el-option
89
+          v-for="item in manufacturer"
90
+          :key="item.id"
91
+          :label="item.manufacturer_name"
92
+          :value="item.id"
93
+        >
94
+        </el-option>
95
+      </el-select>
96
+    </div>
97
+
98
+    <el-row :gutter="12" style="margin-top: 10px">
99
+      <el-table
100
+        :data="tableData"
101
+        :class="signAndWeighBoxPatients"
102
+        border
103
+        highlight-current-row
104
+        ref="multipleTable"
105
+        @selection-change="select"
106
+        :row-style="{ color: '#303133' }"
107
+        :header-cell-style="{
108
+          backgroundColor: 'rgb(245, 247, 250)',
109
+          color: '#606266'
110
+        }"
111
+      >
112
+        <el-table-column label="单据编号" align="center" width="200">
113
+          <template slot-scope="scope">
114
+            {{ scope.row.warehouse_out_order_number }}
115
+          </template>
116
+        </el-table-column>
117
+
118
+        <el-table-column label="药品类型" align="center">
119
+          <template slot-scope="scope">
120
+            <span v-if="scope.row.drug_type == 1">西药</span>
121
+            <span v-if="scope.row.drug_type == 2">草药</span>
122
+            <span v-if="scope.row.drug_type == 3">成药</span>
123
+          </template>
124
+        </el-table-column>
125
+
126
+         <el-table-column label="药品名称" align="center">
127
+          <template slot-scope="scope">
128
+            {{scope.row.drug_name}}
129
+          </template>
130
+        </el-table-column>
131
+
132
+        <el-table-column label="规格型号" align="center">
133
+          <template slot-scope="scope">
134
+           {{scope.row.drug_spec}}
135
+          </template>
136
+        </el-table-column>
137
+
138
+        <el-table-column label="单据类型" align="center">
139
+          <template slot-scope="scope">
140
+            <span v-if="scope.row.type == 1">药品出库单</span>
141
+            <span v-if="scope.row.type == 2">其他</span>
142
+          </template>
143
+        </el-table-column>
144
+
145
+        <el-table-column label="操作时间" align="center">
146
+          <template slot-scope="scope">
147
+           <span>{{getTime(scope.row.ctime)}}</span>
148
+          </template>
149
+        </el-table-column>
150
+        <el-table-column label="制单人" align="center">
151
+          <template slot-scope="scope">
152
+           {{getAdminUser(scope.row.creater)}}
153
+          </template>
154
+        </el-table-column>
155
+        <el-table-column label="出货价" align="center">
156
+          <template slot-scope="scope">
157
+           {{scope.row.price}}
158
+          </template>
159
+        </el-table-column>
160
+        <el-table-column label="数量" align="center">
161
+          <template slot-scope="scope">
162
+            {{scope.row.count}}
163
+          </template>
164
+        </el-table-column>
165
+        <el-table-column label="总价" align="center">
166
+          <template slot-scope="scope">
167
+            {{scope.row.total_price}}
168
+          </template>
169
+        </el-table-column>
170
+      </el-table>
171
+
172
+      <el-pagination
173
+        @size-change="handleSizeChange"
174
+        @current-change="handleCurrentChange"
175
+        :page-sizes="[10, 50, 100]"
176
+        :page-size="10"
177
+        background
178
+        style="margin-top:20px;float: right"
179
+        layout="total, sizes, prev, pager, next, jumper"
180
+        :total="total"
181
+      >
182
+      </el-pagination>
183
+    </el-row>
184
+  </div>
185
+</template>
186
+
187
+<script>
188
+import { uParseTime } from "@/utils/tools";
189
+import { fetchAllAdminUsers } from "@/api/doctor";
190
+import {GetAllConfig } from "@/api/stock";
191
+import {getDrugOutDetail } from "@/api/drug/drug_stock"
192
+export default {
193
+  name: "stockOutDetail",
194
+
195
+  created() {
196
+    var nowDate = new Date();
197
+    var nowYear = nowDate.getFullYear();
198
+    var nowMonth = nowDate.getMonth() + 1;
199
+    var nowDay = nowDate.getDate();
200
+    this.end_time =
201
+      nowYear +
202
+      "-" +
203
+      (nowMonth < 10 ? "0" + nowMonth : nowMonth) +
204
+      "-" +
205
+      (nowDay < 10 ? "0" + nowDay : nowDay);
206
+    nowDate.setMonth(nowDate.getMonth() - 1);
207
+    nowYear = nowDate.getFullYear();
208
+    nowMonth = nowDate.getMonth() + 1;
209
+    nowDay = nowDate.getDate();
210
+    this.start_time =
211
+      nowYear +
212
+      "-" +
213
+      (nowMonth < 10 ? "0" + nowMonth : nowMonth) +
214
+      "-" +
215
+      (nowDay < 10 ? "0" + nowDay : nowDay);
216
+    this.GetConfigInfo();
217
+    this.fetchAllAdminUsers();
218
+    this.getlist()
219
+  },
220
+  data() {
221
+    return {
222
+      orderTypeArr: [
223
+        { value: 1, label: "药品出库单" },
224
+        { value: 2, label: "其他入库单" }
225
+      ],
226
+      manufacturer_id: "",
227
+      dealer_id: "",
228
+      order_type: "",
229
+
230
+      searchKey: "",
231
+      type: 2,
232
+      page: 1,
233
+      limit: 10,
234
+      checked: false,
235
+      total: 0,
236
+      pageTotal: 0,
237
+      pageSelect: 0,
238
+      adminUserOptions: [],
239
+      multipleSelection: [],
240
+      signAndWeighBoxPatients: "sign-and-weigh-box-patients",
241
+      start_time: "",
242
+      cancelStockDate: [],
243
+      end_time: "",
244
+      goodType: [],
245
+      goodInfo: [],
246
+      manufacturer: [],
247
+      selectedTableData: [],
248
+      dealer: [],
249
+      tableData:[]
250
+    };
251
+  },
252
+  methods: {
253
+    changeType: function(val) {
254
+      this.order_type = val;
255
+      this.getlist()
256
+    },
257
+    changeManufacturer: function(val) {
258
+      this.manufacturer_id = val;
259
+      this.getlist()
260
+    },
261
+    getTypeName: function(row) {
262
+      let name = "";
263
+      const name2 = "";
264
+      if (row.type == 1) {
265
+        name = "药品出库单";
266
+      } else if (row.type == 2) {
267
+        name = "其他出库单";
268
+      }
269
+
270
+      return name;
271
+    },
272
+    search: function() {
273
+      this.getlist()
274
+    },
275
+
276
+    getXuserName(id) {
277
+      if (id <= 0) {
278
+        return "";
279
+      }
280
+      var name = "";
281
+      if (
282
+        this.adminUserOptions == null ||
283
+        typeof this.adminUserOptions.length === "undefined"
284
+      ) {
285
+        return name;
286
+      }
287
+      var leng = this.adminUserOptions.length;
288
+      if (leng == 0) {
289
+        return name;
290
+      }
291
+      for (let index = 0; index < leng; index++) {
292
+        if (this.adminUserOptions[index].id == id) {
293
+          name = this.adminUserOptions[index].name;
294
+          break;
295
+        }
296
+      }
297
+      return name;
298
+    },
299
+    fetchAllAdminUsers() {
300
+      fetchAllAdminUsers().then(response => {
301
+        console.log(response);
302
+        if (response.data.state == 1) {
303
+          this.adminUserOptions = response.data.data.users;
304
+        }
305
+      });
306
+    },
307
+    handleSelectionChange: function(val) {
308
+      this.multipleSelection = val;
309
+    },
310
+    handleSizeChange(val) {
311
+      this.limit = val;
312
+      this.getlist()
313
+    },
314
+    handleCurrentChange(val) {
315
+      this.page = val;
316
+      this.getlist()
317
+    },
318
+    startTimeChange(val) {
319
+      var time = this.getTimestamp(val) - this.getTimestamp(this.end_time);
320
+      if (time > 0) {
321
+        this.$message.error("结束时间不能小于开始时间");
322
+        this.start_time = "";
323
+      } else {
324
+         this.getlist()
325
+      }
326
+    },
327
+    endTimeChange(val) {
328
+      var time = this.getTimestamp(val) - this.getTimestamp(this.start_time);
329
+      if (time < 0) {
330
+        this.$message.error("结束时间不能小于开始时间");
331
+        this.end_time = "";
332
+      } else {
333
+        this.getlist()
334
+      }
335
+    },
336
+    getTimestamp(time) {
337
+      // 把时间日期转成时间戳
338
+      return new Date(time).getTime() / 1000;
339
+    },
340
+    calculate: function(val) {
341
+      return Math.round(parseFloat(val) * 100) / 100;
342
+    },
343
+    GetConfigInfo() {
344
+      GetAllConfig().then(response => {
345
+        if (response.data.state == 0) {
346
+          this.$message.error(response.data.msg);
347
+          return false;
348
+        } else {
349
+          this.manufacturer = response.data.data.manufacturer;
350
+          this.dealer = response.data.data.dealer;
351
+          this.goodInfo = response.data.data.goodInfo;
352
+          this.goodType = response.data.data.goodType;
353
+        }
354
+      });
355
+    },
356
+   
357
+    getTime: function(val) {
358
+      if (val == 0) {
359
+        return "";
360
+      } else {
361
+        return uParseTime(val, "{y}-{m}-{d}");
362
+      }
363
+    },
364
+    PrintAction: function() {
365
+      
366
+    },
367
+    getlist(){
368
+      var params = {
369
+         start_time:this.start_time,
370
+         end_time:this.end_time,
371
+         order_type:this.order_type,
372
+         manufacturer_id:this.manufacturer_id,
373
+         keyword:this.searchKey,
374
+         page:this.page,
375
+         limit:this.limit,
376
+      }  
377
+      getDrugOutDetail(params).then(response=>{
378
+        if(response.data.state == 1){
379
+          var order = response.data.data.order
380
+          console.log("出库数据",order)
381
+          this.tableData = order
382
+          var total = response.data.data.total
383
+          this.total = total
384
+        } 
385
+      }) 
386
+    },
387
+
388
+   select(){
389
+       
390
+   },
391
+
392
+    getAdminUser(id){
393
+      var name = ""
394
+      for(let i=0;i<this.adminUserOptions.length;i++){
395
+          if(id == this.adminUserOptions[i].id){
396
+             name = this.adminUserOptions[i].name
397
+          }
398
+      }
399
+      return name
400
+    }
401
+  }
402
+};
403
+</script>
404
+
405
+<style rel="stylesheet/css" lang="scss" scoped>
406
+.information {
407
+  border: 1px #dcdfe6 solid;
408
+  padding: 30px 20px 30px 20px;
409
+
410
+  .border {
411
+    border-bottom: 1px #dcdfe6 solid;
412
+    margin: 0px 0 20px 0;
413
+  }
414
+}
415
+
416
+.edit_separater {
417
+  border-top: 1px solid rgb(233, 233, 233);
418
+  margin-top: 15px;
419
+  margin-bottom: 15px;
420
+}
421
+</style>
422
+
423
+<style>
424
+.sign-and-weigh-box .sign-and-weigh-box-patients .cell {
425
+  font-size: 12px;
426
+}
427
+
428
+.sign-and-weigh-box .sign-and-weigh-box-patients .current-row > td {
429
+  background: #6fb5fa;
430
+}
431
+
432
+.count {
433
+  color: #bd2c00;
434
+}
435
+.el-table td,
436
+.el-table th.is-leaf,
437
+.el-table--border,
438
+.el-table--group {
439
+  border-color: #d0d3da;
440
+}
441
+.el-table--border::after,
442
+.el-table--group::after,
443
+.el-table::before {
444
+  background-color: #d0d3da;
445
+}
446
+</style>

+ 52 - 0
src/xt_pages/stock/drugs/drugIndex.vue Целия файл

@@ -0,0 +1,52 @@
1
+<template>
2
+  <div class="main-contain">
3
+    <div class="position">
4
+      <bread-crumb :crumbs='crumbs'></bread-crumb>
5
+    </div>
6
+    <div class="app-container">
7
+      <div class="service-box">
8
+        <el-tabs v-model="activeName">
9
+          <el-tab-pane label="入库明细" name="first">
10
+            <drug-in-order></drug-in-order>
11
+          </el-tab-pane>
12
+          <el-tab-pane label="退货明细">
13
+            <drug-cancel-order></drug-cancel-order>
14
+          </el-tab-pane>
15
+          <el-tab-pane label="出库明细">
16
+            <drug-out-detail></drug-out-detail>
17
+          </el-tab-pane>
18
+          <el-tab-pane label="退库明细">
19
+            <drug-cancel-detail></drug-cancel-detail>
20
+          </el-tab-pane>
21
+
22
+        </el-tabs>
23
+      </div>
24
+    </div>
25
+  </div>
26
+</template>
27
+<script>
28
+import BreadCrumb from '@/xt_pages/components/bread-crumb'
29
+import DrugInOrder from '@/xt_pages/stock/drugs/components/drugInOrder'
30
+import DrugCancelOrder from '@/xt_pages/stock/drugs/components/drugCancelOrder'
31
+import DrugOutDetail from '@/xt_pages/stock/drugs/components/drugOutDetail'
32
+import DrugCancelDetail from '@/xt_pages/stock/drugs/components/drugCancelDetail'
33
+export default {
34
+  components: {
35
+    BreadCrumb,
36
+    DrugInOrder,
37
+    DrugCancelOrder,
38
+    DrugOutDetail,
39
+    DrugCancelDetail
40
+  },
41
+   data() {
42
+      return {
43
+        crumbs: [
44
+          { path: false, name: '库存管理' },
45
+          { path: '/stock/drugs/stock/detail', name: '出入库明细查询' }
46
+        ],
47
+        activeName: 'first'
48
+
49
+      }
50
+    },
51
+}
52
+</script>

+ 324 - 0
src/xt_pages/stock/drugs/drugPrint.vue Целия файл

@@ -0,0 +1,324 @@
1
+<template>
2
+  <div class="main-contain">
3
+    <div class="position">
4
+      <bread-crumb :crumbs='crumbs'></bread-crumb>
5
+      <el-button :loading="loading" size="small" icon="el-icon-printer" @click="printThisPage" type="primary">打印
6
+      </el-button>
7
+    </div>
8
+    <div class="app-container ">
9
+      <div id="dialysis-print-box">
10
+        <div class="dialysis-print-order">
11
+        <div style="float: right;margin-bottom: 10px;">{{getDateTwo()}}</div>
12
+
13
+          <table class="print-table" border="1">
14
+            <tbody>
15
+            <tr>
16
+              <td style="line-height: 50px" width="50">序号</td>
17
+              <td style="line-height: 50px" width="250">药品名称</td>
18
+              <td style="line-height: 50px" width="250">规格型号</td>
19
+              <td style="line-height: 50px" width="50">单位</td>
20
+              <td style="line-height: 50px" width="80">数量</td>
21
+              <td style="line-height:50px" width="80">单价</td>
22
+              <td style="line-height: 50px" width="">备 注</td>
23
+            </tr>
24
+
25
+            <tr v-for="(item,index) in cancelStockDate" :key="item.id">
26
+              <td style="line-height: 50px">&nbsp;
27
+                {{index+1}}
28
+              </td>
29
+              <td style="line-height: 50px">
30
+                <span>{{item.drug_name}}</span>
31
+              </td>
32
+              <td style="line-height: 50px">
33
+                <span>{{item.drug_spec}}</span>
34
+              </td>
35
+              <td style="line-height: 50px">
36
+                <span>{{item.min_unit}}</span>
37
+              </td>
38
+            
39
+              <td style="line-height: 50px">
40
+                  {{item.warehousing_count}}
41
+              </td>
42
+              <td style="line-height:50px">
43
+                  {{item.price}}
44
+              </td>
45
+              <td style="line-height: 50px">
46
+                 {{item.remark}}
47
+              </td>
48
+            </tr>
49
+            </tbody>
50
+          </table>
51
+          <table class="print-table" border="1" v-if="type == 1 || type == 3">
52
+            <tbody>
53
+            <tr>
54
+              <td width="633" style="line-height: 50px">合计</td>
55
+              <td width="80" style="line-height: 50px">{{calTotalPrice()}}</td>
56
+              <td></td>
57
+            </tr>
58
+
59
+            </tbody>
60
+          </table>
61
+        </div>
62
+
63
+      </div>
64
+
65
+    </div>
66
+  </div>
67
+
68
+</template>
69
+
70
+<script>
71
+  import { getPrintStockGood } from '@/api/stock'
72
+  import { getDataConfig } from '@/utils/data'
73
+  import { jsGetAge, uParseTime } from '@/utils/tools'
74
+  import BreadCrumb from '@/xt_pages/components/bread-crumb'
75
+  import print from 'print-js'
76
+  import { getDrugIndetail} from "@/api/drug/drug_stock"
77
+  export default {
78
+    name: 'dialysisPrintOrder',
79
+    components: {
80
+      BreadCrumb
81
+
82
+    },
83
+    data() {
84
+      return {
85
+        crumbs: [
86
+          { path: false, name: '出入库明细' },
87
+          { path: false, name: '打印单' }
88
+        ],
89
+        loading: false,
90
+        orgname: '',   
91
+        totalPrice: 0,
92
+        stockDatas: [],
93
+        goodUnit: [],
94
+        start_time: this.$route.query.start_time,
95
+        end_time: this.$route.query.end_time,
96
+        order_type:this.$route.query.order_type,
97
+        manufacturer_id:this.$route.query.manufacturer_id,
98
+        keyword:this.$route.query.keyword,
99
+        limit:this.$route.query.limit,
100
+        page:this.$route.query.page,
101
+        cancelStockDate:[],
102
+      }
103
+    },
104
+    methods: {
105
+      getDateTwo(){
106
+        var ptime = Math.round(new Date().getTime() / 1000)
107
+        return "印单日期:"+uParseTime(ptime, '{y}-{m}-{d}')
108
+      },
109
+      getTime(value, temp) {
110
+        if (value == 0) {
111
+          return ''
112
+        }
113
+        if (value != undefined) {
114
+          return uParseTime(value, temp)
115
+        }
116
+        return ''
117
+      },
118
+      printThisPage() {
119
+        var ptime = Math.round(new Date().getTime() / 1000)
120
+        this.print_time = uParseTime(ptime, '{y}-{m}-{d} {h}:{i}')
121
+        const style = '@media print {.dialysis-print-order{width:960px;margin:0 auto}.dialysis-print-order .order-yy-name{margin:auto;text-align:center;font-size:20px;letter-spacing:5px}.dialysis-print-order .order-title{margin:auto;font-weight:600;text-align:center;font-size:22px;padding:10px 20px 20px 20px}.dialysis-print-order .table-box{width:100%;line-height:23px;font-size:14px}.dialysis-print-order .print-table{width:100%;text-align:center;border-collapse:collapse;line-height:25px;font-size:14px}.dialysis-print-order .print-table-no{width:100%;text-align:center;border-collapse:collapse;font-size:14px}.dialysis-print-order .under-line{border-bottom:1px solid #999;width:95%;text-align:center;margin-left:2px}.dialysis-print-order .title-box{text-align:center;font-size:16px;border:1px solid #666}.dialysis-print-order .radio-lebel-box{font-weight:400;cursor:pointer}.dialysis-print-order .radio-no{opacity:0;outline:0;position:absolute;margin:0;width:0;height:0;z-index:-1}.dialysis-print-order .radio-inner{white-space:nowrap;cursor:pointer;outline:0;display:inline-block;line-height:1;position:relative;vertical-align:middle}.dialysis-print-order .radio-fang{display:inline-block;position:relative;border:1px solid #000;box-sizing:border-box;width:14px;height:14px;background-color:#fff;z-index:1;transition:border-color .25s cubic-bezier(.71,-.46,.29,1.46),background-color .25s cubic-bezier(.71,-.46,.29,1.46)}.dialysis-print-order .is-checked-radio::after{content:"√";font-size:15px}}.dialysis-print-order .print-table-no tr td { padding: 8px 5px; line-height: 25px; }.es-img{height: 20px; }.advice-name{text-align: left;}.advice-children{display:flex;} .dialysis-print-order .print-table tr td{padding: 0px 0px;} .print-template-two tr {line-height: 30px;}   .title-box-pro{border: 0 #fff;line-height: 40px;height: 40px;text-align: left;padding-left: 10px !important;}  .text-align-left{text-align: left !important;padding-left:10px !important;font-size: 14px !important;line-height: 25px;}'
122
+        printJS({
123
+          printable: 'dialysis-print-box',
124
+          type: 'html',
125
+          style: style,
126
+          scanStyles: false
127
+        })
128
+      },
129
+   
130
+      getUnit(id){
131
+        var name = ""
132
+        for(let i=0;i<this.goodUnit.length;i++){
133
+          if(this.goodUnit[i].id == id){
134
+            name = this.goodUnit[i].name
135
+          }
136
+        }
137
+        return name
138
+      },
139
+      getlist(){
140
+        var params = {
141
+        start_time:this.start_time,
142
+        end_time:this.end_time,
143
+        order_type:this.order_type,
144
+        manufacturer_id:this.manufacturer_id,
145
+        keyword:this.searchKey,
146
+        limit:this.limit,
147
+        page:this.page,
148
+       }
149
+      getDrugIndetail(params).then(response=>{
150
+        if(response.data.state == 1){
151
+          var drugInOrder = response.data.data.detail
152
+          console.log("drug3434444",drugInOrder)
153
+          this.cancelStockDate = drugInOrder
154
+          var total = response.data.data.total
155
+          this.total = total
156
+        }
157
+      })  
158
+      }
159
+    },
160
+    created() {
161
+      var xtuser = this.$store.getters.xt_user
162
+      this.orgname = xtuser.org.org_name
163
+      this.getlist()
164
+
165
+      
166
+
167
+    }
168
+
169
+  }
170
+</script>
171
+
172
+<style>
173
+  .dialysis-print-order {
174
+    width: 960px;
175
+    margin: 0 auto
176
+  }
177
+
178
+  .dialysis-print-order .order-yy-name {
179
+    margin: auto;
180
+    text-align: center;
181
+    font-size: 20px;
182
+    letter-spacing: 5px;
183
+  }
184
+
185
+  .dialysis-print-order .order-title {
186
+    margin: auto;
187
+    font-weight: 600;
188
+    text-align: center;
189
+    font-size: 22px;
190
+    padding: 10px 20px 20px 20px;
191
+  }
192
+
193
+  .dialysis-print-order .table-box {
194
+
195
+    width: 100%;
196
+    line-height: 23px;
197
+    font-size: 14px;
198
+  }
199
+
200
+  .dialysis-print-order .print-table {
201
+    width: 100%;
202
+    text-align: center;
203
+    border-collapse: collapse;
204
+    line-height: 40px;
205
+    font-size: 14px;
206
+  }
207
+
208
+  .dialysis-print-order .print-table-no {
209
+    width: 100%;
210
+    text-align: center;
211
+    border-collapse: collapse;
212
+    font-size: 14px;
213
+  }
214
+
215
+  .dialysis-print-order .under-line {
216
+    border-bottom: 1px solid #999;
217
+    width: 95%;
218
+    text-align: center;
219
+    margin-left: 2px;
220
+
221
+
222
+  }
223
+
224
+  .dialysis-print-order .title-box {
225
+    text-align: center;
226
+    font-size: 16px;
227
+  }
228
+
229
+  .dialysis-print-order .radio-lebel-box {
230
+    font-weight: 400;
231
+    cursor: pointer;
232
+  }
233
+
234
+  .dialysis-print-order .radio-no {
235
+    opacity: 0;
236
+    outline: none;
237
+    position: absolute;
238
+    margin: 0;
239
+    width: 0;
240
+    height: 0;
241
+    z-index: -1;
242
+  }
243
+
244
+  .dialysis-print-order .radio-inner {
245
+    white-space: nowrap;
246
+    cursor: pointer;
247
+    outline: none;
248
+    display: inline-block;
249
+    line-height: 1;
250
+    position: relative;
251
+    vertical-align: middle;
252
+  }
253
+
254
+  .dialysis-print-order .radio-fang {
255
+    display: inline-block;
256
+    position: relative;
257
+    border: 1px solid #000;
258
+    box-sizing: border-box;
259
+    width: 14px;
260
+    height: 14px;
261
+    background-color: #fff;
262
+    z-index: 1;
263
+    transition: border-color .25s cubic-bezier(.71, -.46, .29, 1.46), background-color .25s cubic-bezier(.71, -.46, .29, 1.46);
264
+  }
265
+
266
+  .dialysis-print-order .is-checked-radio::after {
267
+    content: "√";
268
+    font-size: 15px;
269
+  }
270
+
271
+
272
+  .dialysis-print-order .print-table-no tr td {
273
+    padding: 8px 5px;
274
+    line-height: 25px;
275
+  }
276
+
277
+  .dialysis-print-order .print-table tr td {
278
+    padding: 1px 1px;
279
+    /*line-height: 25px;*/
280
+  }
281
+
282
+  .es-img {
283
+    height: 25px;
284
+  }
285
+
286
+  .advice-name {
287
+    text-align: left;
288
+  }
289
+
290
+  .advice-children {
291
+    display: flex;
292
+  }
293
+
294
+  .title-box-pro {
295
+    border: 0 #fff;
296
+    line-height: 25px;
297
+    height: 25px;
298
+    text-align: left;
299
+    padding-left: 10px !important;
300
+  }
301
+
302
+  .title-box-pro-tr {
303
+    border: 0 #fff;
304
+  }
305
+
306
+  .text-align-left {
307
+    text-align: left !important;
308
+    padding-left: 10px !important;
309
+    font-size: 14px !important;
310
+    line-height: 25px;
311
+  }
312
+
313
+  .print-table-tr-new td {
314
+    line-height: 20px !important;
315
+  }
316
+
317
+  .border-top-solid {
318
+    border: solid 1px #000;
319
+  }
320
+
321
+  .print-template-two tr {
322
+    line-height: 30px;
323
+  }
324
+</style>

+ 22 - 62
src/xt_pages/user/dialysisSolution.vue Целия файл

@@ -199,43 +199,12 @@
199 199
             </el-form-item>
200 200
           </el-col>
201 201
 
202
-          <!-- <el-col   :span="8">
203
-            <el-form-item label="透析器:" prop="dialyzer">
204
-                <el-select v-model="addPlan.dialyzer" placeholder="" >
205
-                  <el-option v-for="item in deviceList"  :label="item.name" :key="item.id" :value="item.id"></el-option>
206
-                </el-select>
207
-            </el-form-item>
208
-          </el-col> -->
209
-          <!-- <el-col   :span="8">
210
-            <el-form-item label="透析器:" prop="hemodialysis_machine">
211
-                <el-select v-model="addPlan.hemodialysis_machine" placeholder="" >
212
-                  <el-option v-for="item in hemodialysis_machines"  :label="item.name" :key="item.id" :value="item.id"></el-option>
213
-                </el-select>
214
-            </el-form-item>
215
-          </el-col> -->
216
-          <!-- <el-col   :span="8">
217
-            <el-form-item label="灌流器:" prop="perfusion_apparatus">
218
-                <el-select v-model="addPlan.perfusion_apparatus" placeholder="" >
219
-                  <el-option v-for="item in perfusion_apparatus"  :label="item.name" :key="item.id" :value="item.id"></el-option>
220
-                </el-select>
221
-            </el-form-item>
222
-          </el-col> -->
223 202
           <el-col :span="8" v-if="isShows('血流量')">
224 203
             <el-form-item label="血流量(ml/min):" prop="blood_flow_volume">
225 204
               <el-input v-model="addPlan.blood_flow_volume"></el-input>
226 205
             </el-form-item>
227 206
           </el-col>
228
-          <!--<el-col :span="8" v-if="isShows('目标超滤量')&&this.$store.getters.xt_user.template_info.template_id == 6">-->
229
-          <!--<el-form-item label="目标超滤量(ml) : ">-->
230
-          <!--<el-input v-model="addPlan.target_ultrafiltration" type="number"></el-input>-->
231
-          <!--</el-form-item>-->
232
-          <!--</el-col>-->
233
-
234
-          <!--<el-col :span="8" v-if="isShows('目标超滤量')&&this.$store.getters.xt_user.template_info.template_id != 6">-->
235
-          <!--<el-form-item label="目标超滤量(L) : ">-->
236
-          <!--<el-input v-model="addPlan.target_ultrafiltration" type="number"></el-input>-->
237
-          <!--</el-form-item>-->
238
-          <!--</el-col>-->
207
+       
239 208
 
240 209
           <el-col :span="8" v-if="isShows('透析液配方')">
241 210
             <el-form-item label="透析液配方:">
@@ -249,23 +218,7 @@
249 218
               </el-select>
250 219
             </el-form-item>
251 220
           </el-col>
252
-          <!-- <el-col  :span="12">
253
-            <el-form-item label="脱水量(L):" prop="dewater">
254
-              <el-input v-model="addPlan.dewater" ></el-input>
255
-            </el-form-item>
256
-          </el-col> -->
257
-          <!-- <el-col  :span="12">
258
-            <el-form-item label="置换液(L):" prop="displace_liqui">
259
-              <el-input v-model="addPlan.displace_liqui" ></el-input>
260
-            </el-form-item>
261
-          </el-col>
262
-          <el-col  :span="12">
263
-            <el-form-item label="置换方式:" prop="replacement_way" >
264
-              <el-select v-model="addPlan.replacement_way"  >
265
-                <el-option v-for="item in replacementWays"  :label="item.name" :key="item.id" :value="item.id"></el-option>
266
-              </el-select>
267
-            </el-form-item>
268
-          </el-col> -->
221
+         
269 222
           <el-col :span="8" v-if="isShows('抗凝剂')">
270 223
             <el-form-item label="抗凝剂:" prop="anticoagulant">
271 224
               <el-select
@@ -852,17 +805,26 @@ export default {
852 805
     }
853 806
   },
854 807
   watch: {
808
+   
809
+   'dialysisTimeShow':function(){
810
+      var val = this.addPlan.dialysis_duration_hour+":"+this.addPlan.dialysis_duration_minute
811
+      var valTime = val.split(':')
812
+      this.addPlan.dialysis_duration = parseFloat(valTime[0]) + parseFloat((valTime[1] / 60).toFixed(2))
813
+      this.addPlan.dialysis_duration_hour = valTime[0]
814
+      this.addPlan.dialysis_duration_minute = valTime[1]
815
+   },
816
+
855 817
     'addPlan.dialysis_duration': function() {
856
-      this.addPlan.anticoagulant_zongliang = calculateAnticoagulantZL(
857
-        1,
818
+    
819
+      this.addPlan.anticoagulant_zongliang = calculateAnticoagulantZL(1,
858 820
         this.addPlan.anticoagulant_shouji,
859 821
         this.addPlan.dialysis_duration,
860 822
         this.addPlan.anticoagulant_weichi
861 823
       )
862 824
     },
863 825
     'addPlan.anticoagulant_shouji': function() {
864
-      this.addPlan.anticoagulant_zongliang = calculateAnticoagulantZL(
865
-        1,
826
+      
827
+      this.addPlan.anticoagulant_zongliang = calculateAnticoagulantZL(1,
866 828
         this.addPlan.anticoagulant_shouji,
867 829
         this.addPlan.dialysis_duration,
868 830
         this.addPlan.anticoagulant_weichi
@@ -877,6 +839,9 @@ export default {
877 839
       )
878 840
     }
879 841
   },
842
+
843
+
844
+  
880 845
   components: {
881 846
     MultiSelectBox,
882 847
     tableTitle,
@@ -916,9 +881,10 @@ export default {
916 881
     },
917 882
 
918 883
     selectnDialysisTime(val) {
884
+     
919 885
       var valTime = val.split(':')
920
-      this.addPlan.dialysis_duration =
921
-        parseFloat(valTime[0]) + parseFloat((valTime[1] / 60).toFixed(2))
886
+      this.addPlan.dialysis_duration = parseFloat(valTime[0]) + parseFloat((valTime[1] / 60).toFixed(2))
887
+      console.log("透析时长",this.addPlan.dialysis_duration)
922 888
       this.addPlan.dialysis_duration_hour = valTime[0]
923 889
       this.addPlan.dialysis_duration_minute = valTime[1]
924 890
     },
@@ -1364,13 +1330,7 @@ export default {
1364 1330
         this.addPlan.dialysate_formulation= ""
1365 1331
       }
1366 1332
       this.addPlan.dialysate_formulation = row.dialysate_formulation
1367
-      this.dialysisTimeShow = new Date(
1368
-        2018,
1369
-        1,
1370
-        1,
1371
-        this.addPlan.dialysis_duration_hour,
1372
-        this.addPlan.dialysis_duration_minute
1373
-      )
1333
+      this.dialysisTimeShow = new Date(2018,1,1,this.addPlan.dialysis_duration_hour,this.addPlan.dialysis_duration_minute)
1374 1334
     },
1375 1335
     isShows(name) {
1376 1336
       var filedList = store.getters.xt_user.fileds

+ 4 - 1
src/xt_pages/user/patients.vue Целия файл

@@ -102,6 +102,7 @@
102 102
           <el-button size="small" type="primary" @click="toRemind">传染病检查提醒</el-button>
103 103
         </el-badge>
104 104
         <upload-excel :on-success='handleSuccess' :before-upload="beforeUpload" v-if="isShow"></upload-excel>
105
+
105 106
         <el-link target="_blank" href="https://kuyi.shengws.com/patient_template.xlsx" :underline="false"
106 107
                  style="margin-left:15px">
107 108
           <el-button
@@ -768,7 +769,6 @@
768 769
     },
769 770
 
770 771
     methods: {
771
-      beforeUpload(){},
772 772
       generateTxt: function(log) {
773 773
         var content = ''
774 774
         var errlog = log.err_logs
@@ -821,6 +821,8 @@
821 821
 
822 822
       },
823 823
       handleSuccess({ results, header }) {
824
+        console.log("999999999")
825
+
824 826
         console.log(results)
825 827
         if (header != undefined && header.length > 0) {
826 828
           var isHasName = header.includes('*姓名')
@@ -1114,6 +1116,7 @@
1114 1116
 
1115 1117
 
1116 1118
               if (tempExportDateOne.length < this.export_date.length){
1119
+
1117 1120
                 this.phoneVisible = true
1118 1121
                 return
1119 1122
               }