123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596 |
- <template>
- <div class="main-contain">
-
- <el-dialog
- title="提示"
- :visible.sync="exportVisible"
- width="40%"
- >
-
- <div>
- 您提交的患者名单已上传成功,系统正在执行导入,请稍候点击当前页面右上角“下载日志”查看导入结果
- </div>
-
- <span slot="footer" class="dialog-footer">
- <el-button @click="exportVisible = false">取 消</el-button>
- <el-button type="primary" @click="exportVisible = false">确 定</el-button>
- </span>
- </el-dialog>
-
- <el-dialog
- title="提示"
- :visible.sync="dialogVisible"
- width="40%"
- >
- <span>您提交的文档不是系统标准导入模板,请检查您的文档或重新 <a href="https://kuyi.shengws.com/patient_template.xlsx" style="color: blue" download="template">下载导入模板</a></span>
- <span slot="footer" class="dialog-footer">
- <el-button @click="dialogVisible = false">取 消</el-button>
- <el-button type="primary" @click="dialogVisible = false">确 定</el-button>
- </span>
- </el-dialog>
-
- <el-dialog
- title="提示"
- :visible.sync="dialysisVisible"
- width="40%"
- >
- <span>您提交的文档中存在不同病人存在相同的透析号,请检查修改后在提交 </span>
- <span slot="footer" class="dialog-footer">
- <el-button @click="dialysisVisible = false">取 消</el-button>
- <el-button type="primary" @click="dialysisVisible = false">确 定</el-button>
- </span>
- </el-dialog>
-
-
- <el-dialog
- title="提示"
- :visible.sync="phoneVisible"
- width="40%"
- >
- <span>您提交的文档中存在不同病人存在相同的手机号,请检查修改后在提交 </span>
- <span slot="footer" class="dialog-footer">
- <el-button @click="phoneVisible = false">取 消</el-button>
- <el-button type="primary" @click="phoneVisible = false">确 定</el-button>
- </span>
- </el-dialog>
-
-
- <el-dialog
- title="提示"
- :visible.sync="idCardNoVisible"
- width="40%"
- >
- <span>您提交的文档中存在不同病人存在相同的身份证,请检查修改后在提交 </span>
- <span slot="footer" class="dialog-footer">
- <el-button @click="idCardNoVisible = false">取 消</el-button>
- <el-button type="primary" @click="idCardNoVisible = false">确 定</el-button>
- </span>
- </el-dialog>
-
-
- <el-dialog
- title="提示"
- :visible.sync="exportLogVisible"
- width="40%"
- >
-
- <div v-for="(item,index) in logs" :key="index">
- <span> {{ item.export_time | parseTime('{y}-{m}-{d} {h}:{i}:{s}')}}</span>
- <br/>
- <br/>
- <span>{{getContent(item)}}</span>
- <span >点击</span>
- <span style="color:blue" @click="generateTxt(item)">查看详情</span>
- <br/>
- <br/>
- </div>
-
- <span slot="footer" class="dialog-footer">
- <el-button @click="exportLogVisible = false">取 消</el-button>
- <el-button type="primary" @click="exportLogVisible = false">确 定</el-button>
- </span>
- </el-dialog>
-
-
- <div class="position">
- <bread-crumb :crumbs="crumbs"></bread-crumb>
-
-
-
- <div style="display:flex;align-items:center">
- <upload-excel :on-success='handleSuccess' :before-upload="beforeUpload" v-if="isShow"></upload-excel>
- <el-link target="_blank" href="https://kuyi.shengws.com/patient_template.xlsx" :underline="false"
- style="margin-left:15px">
- <el-button
- class="filter-item"
- type="primary"
- size="small"
- >下载模版
- </el-button>
- </el-link>
-
-
- <el-button
- style="margin-left:10px;"
- @click="generateLog()"
- class="filter-item"
- type="primary"
- size="small"
- >下载日志
- </el-button>
-
- <el-button
- :disabled="$store.getters.xt_user.subscibe.state == 3 ? true : false"
- @click="$router.push({ path: '/patients/create' })"
- class="filter-item"
- type="primary"
- icon="el-icon-circle-plus-outline"
- size="small"
- >新增
- </el-button>
- </div>
-
-
- </div>
- <div class="app-container">
- <div class="cell clearfix">
- <!-- <label class="title"><span class="name">病人搜索</span> : </label> -->
- <el-input
- style="width: 400px;"
- v-model.trim="searchKey"
- class="filter-item"
- placeholder="病人姓名/透析号"
- size="small"
- @keyup.enter.native='search'
- />
- <el-button
- class="filter-item"
- type="primary"
- icon="el-icon-search"
- @click="search"
- size="small"
- >搜索
- </el-button
- >
- </div>
-
- <div class="cell clearfix">
- <label class="title"><span class="name">日期查询</span> : </label>
- <el-date-picker
- size="small"
- clearable
- v-model="listQuery.start_time"
- prefix-icon="el-icon-date"
- @change="changeTimeOne"
- :editable="false"
- style="width: 196px;"
- type="date"
- placeholder="选择日期时间"
- align="right"
- format="yyyy-MM-dd"
- value-format="yyyy-MM-dd"
- >
- </el-date-picker>
- <span class="cellLine"> - </span>
- <el-date-picker
- size="small"
- clearable
- v-model="listQuery.end_time"
- prefix-icon="el-icon-date"
- @change="changeTime"
- :editable="false"
- style="width: 196px;"
- type="date"
- placeholder="选择日期时间"
- align="right"
- format="yyyy-MM-dd"
- value-format="yyyy-MM-dd"
- >
- </el-date-picker>
- </div>
- <div class="cell clearfix">
- <label class="title"><span class="name">排班班次</span> : </label>
- <div class="time ">
- <ul class="">
- <li
- :class="item.value == schedulType ? 'active' : ''"
- @click="selectSchedulType(item.value)"
- v-for="item in schedulArr"
- :key="item.value"
- >
- {{ item.label }}
- </li>
- </ul>
- </div>
- </div>
- <div class="cell clearfix">
- <label class="title"><span class="name">状态</span> : </label>
- <div class="time ">
- <ul class="">
- <li
- :class="item.value == systemType ? 'active' : ''"
- @click="selectSystemType(item.value)"
- v-for="item in systemArr"
- :key="item.value"
- >
- {{ item.label }}
- </li>
- </ul>
- </div>
- </div>
- <div class="cell clearfix">
- <label class="title"><span class="name">转归情况</span> : </label>
- <div class="time ">
- <ul class="">
- <li
- :class="item.lapseto == lapsetoType ? 'active' : ''"
- @click="selectLapseTo(item.lapseto)"
- v-for="item in lapsetoArr"
- :key="item.value"
- >
- {{ item.label }}
- </li>
- </ul>
- </div>
- </div>
- <div class="cell clearfix">
- <label class="title"><span class="name">病人来源</span> : </label>
- <div class="time ">
- <ul class="">
- <li
- :class="item.source == sourceType ? 'active' : ''"
- @click="selectSource(item.source)"
- v-for="item in sourceArr"
- :key="item.value"
- >
- {{ item.label }}
- </li>
- </ul>
- </div>
- </div>
- <div class="cell clearfix">
- <label class="title"><span class="name">其它查询</span> : </label>
- <el-select
- v-model="listQuery.contagion"
- size="small"
- clearable
- placeholder="传染病"
- @change="changeOtherSearch"
- >
- <el-option
- v-for="item in contagionList"
- :key="item.id"
- :label="item.name"
- :value="item.id"
- >
- </el-option>
- </el-select>
- <el-select
- style="margin-left: 10px;"
- v-model="listQuery.reimbursement_way"
- size="small"
- clearable
- placeholder="付费方式"
- @change="changeOtherSearch"
- >
- <el-option
- v-for="item in reimbursement_ways"
- :key="item.id"
- :label="item.name"
- :value="item.id"
- >
- </el-option>
- </el-select>
- <el-select
- v-model="listQuery.isscheduling"
- collapse-tags
- style="margin-left: 10px;"
- clearable
- placeholder="排班情况"
- size="small"
- @change="changeOtherSearch"
- >
- <el-option
- v-for="item in scheduling"
- :key="item.value"
- :label="item.label"
- :value="item.value"
- >
- </el-option>
- </el-select>
- <el-select
- v-model="listQuery.isprescription"
- collapse-tags
- style="margin-left:10px;"
- clearable
- placeholder="透析处方"
- size="small"
- @change="changeOtherSearch"
- >
- <el-option
- v-for="item in prescription"
- :key="item.value"
- :label="item.label"
- :value="item.value"
- >
- </el-option>
- </el-select>
- </div>
-
- <el-table
- ref="multipleTable"
- :row-style="{ color: '#303133' }"
- :header-cell-style="{
- backgroundColor: 'rgb(245, 247, 250)',
- color: '#606266'
- }"
- :data="tableData"
- border
- fit
- highlight-current-row
- style="width: 100%;margin-top: 10px;"
- @selection-change="handleSelectionChange"
- >
- <el-table-column
- align="center"
- label="全选"
- width="60px"
- type="selection"
- ></el-table-column>
- <el-table-column
- type="index"
- label="序号"
- width="60px"
- align="center"
- ></el-table-column>
- <el-table-column
- label="透析号"
- min-width="80"
- property="dialysis_no"
- align="center"
- style="color:red"
- ></el-table-column>
- <el-table-column
- label="住院号"
- min-width="80"
- property="admission_number"
- align="center"
- >
- </el-table-column>
- <el-table-column
- property="name"
- label="姓名"
- min-width="80"
- align="center"
- >
- <template slot-scope="scope">
- <router-link
- :to="'/patients/patient/' + scope.row.id"
- style="color:#409eff;width:100%;display:block;"
- >{{ scope.row.name }}
- </router-link
- >
- </template>
- </el-table-column>
- <el-table-column label="性别" min-width="80" align="center">
- <template slot-scope="scope">
- <span v-if="scope.row.gender == 1">男</span>
- <span v-else-if="scope.row.gender == 2">女</span>
- <span v-else>未知</span>
- </template>
- </el-table-column>
- <el-table-column label="来源" min-width="80" align="center">
- <template slot-scope="scope">
- <span v-if="scope.row.source == 1">门诊</span>
- <span v-else-if="scope.row.source == 2">住院</span>
- <span v-else>未知</span>
- </template>
- </el-table-column>
- <el-table-column label="透析次数" min-width="94" align="center">
- <template slot-scope="scope">
- <span>{{ getCount(scope.row) }}</span>
- </template>
- </el-table-column>
- <!-- <el-table-column min-width="150" label="二维码" align="center">
- <template slot-scope="scope" type="text">
- <a style="color:#409eff" v-if="scope.row.binding_state==1" @click="openWechatBindDialog">已绑定</a>
- <a style="color:#409eff" v-else @click="openWechatBindDialog">生成</a>
- </template>
- </el-table-column> -->
- <el-table-column label="日期" min-width="144" align="center">
- <template slot-scope="scope">
- <span>{{ scope.row.created_time | parseTime('{y}-{m}-{d}') }}</span>
- </template>
- </el-table-column>
- <el-table-column label="转归" align="center">
- <template slot-scope="scope">
- <span>{{ LapsetoInfo(scope.row) }}</span>
- </template>
- </el-table-column>
- <el-table-column label="转出原因" align="center">
- <template slot-scope="scope">
- <span>{{scope.row.out_reason}}</span>
- </template>
- </el-table-column>
- <el-table-column label="操作" align="center" min-width="140">
- <template slot-scope="scope">
- <el-tooltip
- class="item"
- effect="dark"
- content="转归"
- placement="top"
- >
- <el-button
- type="primary"
- icon="el-icon-edit"
- size="small"
- @click="OpenSetLapseto(scope.row, scope.$index)"
- ></el-button>
- </el-tooltip>
- <el-tooltip
- class="item"
- effect="dark"
- content="预览"
- placement="top"
- >
- <el-button
- type="danger"
- icon="el-icon-tickets"
- size="small"
- @click="
- OpenView(scope.row.name, scope.row.dialysis_no, scope.row.id)
- "
- ></el-button>
- </el-tooltip>
- </template>
- </el-table-column>
- </el-table>
- <!-- <pagi-nation title="分页"></pagi-nation> -->
-
- <el-pagination
- @size-change="handleSizeChange"
- @current-change="handleCurrentChange"
- :current-page="listQuery.pate"
- :page-sizes="[10, 20, 50, 100]"
- :page-size="10"
- background
- style="margin-top:20px;"
- align="right"
- layout="total, sizes, prev, pager, next, jumper"
- :total="total"
- >
- </el-pagination>
-
- <el-dialog
- title="微信绑定"
- :visible.sync="bindWechatDialog"
- width="30%"
- center
- >
- <img :src="wechatbindimg" width="100%" alt="" v-if="wechatbindimg"/>
- <i class="el-icon-loading" v-else></i>
- <span slot="footer" class="dialog-footer">
- <el-button type="primary" @click="bindWechatDialog = false"
- >关闭</el-button
- >
- </span>
- </el-dialog>
- <el-dialog title="转归" :visible.sync="LapsetoDialogVisible">
- <el-form
- :model="lapsetoForm"
- :rules="lapsetoRules"
- ref="lapsetoForm"
- label-width="140px"
- >
- <!-- <el-form-item label="治疗状态(转归):" prop="lapseto_type" required>
- <el-radio-group v-model="lapsetoForm.lapseto_type">
- <el-radio
- v-for="item in lapsetoOptions"
- :key="item.value"
- :label="item.value"
- :value="item.value"
- >{{ item.label }}
- </el-radio
- >
- </el-radio-group>
- </el-form-item> -->
- <el-form-item label="治疗状态(转归):" prop="lapseto_type" required>
- <el-radio v-model="lapsetoForm.lapseto_type" :label="lapsetoForm.lapseto_type">{{lapeseto}}</el-radio>
- </el-form-item>
- <el-form-item label="转归时间 :" prop="lapseto_time" required>
- <el-date-picker
- v-model="lapsetoForm.lapseto_time"
- type="datetime"
- format="yyyy-MM-dd HH:mm:ss"
- value-format="yyyy-MM-dd HH:mm:ss"
- placeholder="选择日期时间"
- default-time="12:00:00"
- >
- </el-date-picker>
- </el-form-item>
- <el-form-item label="转出原因:" v-if="lapsetoForm.lapseto_type == 1">
- <el-input v-model="lapsetoForm.out_reason"></el-input>
- </el-form-item>
- </el-form>
- <div slot="footer" class="dialog-footer">
- <el-button @click="LapsetoDialogVisible = false">取 消</el-button>
- <el-button type="primary" @click="EditLapseto()">保 存</el-button>
- </div>
- </el-dialog>
-
- <el-dialog
- title="签到卡"
- :visible.sync="centerDialogVisible"
- :close-on-click-modal="false"
- @opened="ShowQRCode()"
- width="30%"
- center
- >
- <div align="center" style="margin-bottom:6px;font-size:20px">
- <!-- 姓名:<el-input v-model="name" size="small" style="width:200px"></el-input><br> -->
- 姓名:<span>{{ this.name }}</span>
- </div>
- <div align="center" style="margin-bottom:10px;font-size:20px">
- <!-- 透析号:<el-input v-model="dialysis_no" size="small" style="width:200px"></el-input><br> -->
- 透析号:<span>{{ this.dialysis_no }}</span>
- </div>
- <div id="qrcode" align="center"></div>
- <span slot="footer" class="dialog-footer">
- <!-- <el-button type="primary" @click="download()">下载</el-button> -->
- <el-button type="primary" @click="print()">打印</el-button>
- </span>
- </el-dialog>
- <div hidden="hidden">
- <div id="print-card-info">
- <div
- class="order_title"
- align="center"
- style="margin-bottom:20px;font-size:35px"
- >
- 签到卡
- </div>
- <div align="center" style="margin-bottom:4px;font-size:25px">
- 姓名:<span> {{ this.name }}</span
- ><br/>
- </div>
- <div align="center" style="margin-bottom:20px;font-size:25px">
- 透析号:<span> {{ this.dialysis_no }}</span>
- </div>
- <div>
- <div id="code" align="center"></div>
- </div>
- </div>
- </div>
- </div>
- </div>
- </template>
-
- <script>
- import { code, EditLapseto, fetchList, getMaxDialysisNo, OpenView, postExportPatients } from '@/api/patient'
- import { generateLog } from '@/api/config'
-
- import QRCode from 'qrcodejs2'
- import Vue from 'vue'
- import { Base64 } from 'js-base64'
- import { uParseTime } from '@/utils/tools'
- import { log } from 'util'
- import BreadCrumb from '@/xt_pages/components/bread-crumb'
- import UploadExcel from '@/xt_pages/components/UploadExcel'
-
- export default {
- name: 'Patient',
- components: {
- UploadExcel,
- BreadCrumb
- },
- data() {
- return {
- logs: [],
- downloadUrl: 'https://kuyi.shengws.com/patient_template.xltx',
- crumbs: [
- { path: false, name: '病人管理' },
- { path: '/patients/patients', name: '病人管理' }
- ],
- lapsetoRules: {
- lapseto_type: [{ required: true, message: '请选择治疗状态' }],
- lapseto_time: [{ required: true, message: '请选择转归时间' }]
- },
- currentIndex: -1,
- LapsetoDialogVisible: false,
- centerDialogVisible: false,
- checkAll: false,
- isIndeterminate: true,
- dialogVisible: false,
- exportLogVisible: false,
- exportVisible:false,
- phoneVisible:false,
- idCardNoVisible:false,
- wechatbindimg: '',
- isShow:true,
- active: true,
- schedulType: 0,
- lapsetoForm: {
- lapseto_type: 0,
- lapseto_time: '',
- patient_id: 0,
- out_reason:''
- },
- schedulArr: [
- { value: 0, label: '全部' },
- { value: 1, label: '上午' },
- { value: 2, label: '下午' },
- { value: 3, label: '晚上' }
- ],
- lapsetoOptions: [
- { value: 1, label: '留治' },
- { value: 2, label: '转出' }
- ],
- systemType: 0,
- systemArr: [
- { value: 0, label: '全部' },
- { value: 1, label: '已绑定' },
- { value: 2, label: '未绑定' }
- ],
- sourceType: 0,
- sourceID: 0,
- lapsetoType: 0,
- sourceArr: [
- { value: 0, label: '全部', source: 0, lapseto: 0 },
- // { value: 1, label: "转出", source: 0, lapseto: 2 },
- // { value: 2, label: "留治", source: 0, lapseto: 1 },
- { value: 3, label: '门诊', source: 1, lapseto: 1 },
- { value: 4, label: '住院', source: 2, lapseto: 1 }
- ],
- lapsetoArr: [
- { value: 0, label: '全部', source: 0, lapseto: 0 },
- { value: 1, label: '转出', source: 0, lapseto: 2 },
- { value: 2, label: '留治', source: 0, lapseto: 1 }
- // { value: 3, label: "门诊", source: 1, lapseto: 1 },
- // { value: 4, label: "住院", source: 2, lapseto: 1 }
- ],
- scheduling: [
- {
- value: 1,
- label: '已排班'
- },
- {
- value: 2,
- label: '未排班'
- }
- ],
- prescription: [
- {
- value: 1,
- label: '有处方'
- },
- {
- value: 2,
- label: '无处方'
- }
- ],
- tableData: null,
- searchKey: '',
- // value2: '',
- total: 0,
- pageTotal: 0,
- dialysisVisible:false,
- pageSelect: 0,
- max_dialysis_no: '',
- listQuery: {
- page: 1,
- limit: 10,
- schedul_type: 0,
- binding_state: 0,
- lapseto: 0,
- source: 0,
- start_time: '',
- end_time: '',
- keywords: '',
- contagion: '',
- reimbursement_way: '',
- isscheduling: '',
- isprescription: ''
- },
- multipleSelection: [],
- bindWechatDialog: false,
- contagionList: [],
- reimbursement_ways: [],
- patient: null,
- id: '',
- name: '',
- dialysis_no: '',
- patientPrint: {},
- patient_id: '',
- gender: '',
- idcardno: '',
- phone: '',
- healthcareno: '',
- startTime: '',
- export_date: [],
- lapeseto:"",
- }
- },
- created() {
- this.getList()
- this.contagionList = this.$store.getters.contagions
- this.reimbursement_ways = this.$store.getters.reimbursement_ways
-
- const keyword = this.$route.query && this.$route.query.keyword
- if (typeof keyword === 'string' && keyword.length > 0) {
- this.listQuery.keywords = keyword
- this.searchKey = keyword
- }
- },
-
- methods: {
- generateTxt: function(log) {
- var content = ''
- var errlog = log.err_logs
- content = this.getContent(log)
- for (let i = 0; i < errlog.length; i++) {
- if (content.length == 0) {
- content = errlog[i].err_msg
- } else {
- content = content + '\n' + errlog[i].err_msg
- }
- }
-
- var url = new Blob(['\ufeff' + content], { type: 'text/txt,charset=UTF-8' })
- if (typeof url === 'object' && url instanceof Blob) {
- url = URL.createObjectURL(url) // 创建blob地址
- }
- const aLink = document.createElement('a')
- aLink.href = url
- aLink.download = this.timestampToTime(log.export_time) + '患者导入日志' + '.txt'
- aLink.click()
-
- },
- getContent(log) {
- return '您导入的文档共' + log.total_num + '条患者数据' + ',' + '已成功导入' + log.success_num + '条,导入失败' + log.fail_num + '条,'
- },
- timestampToTime(timestamp) {
- var date = new Date(timestamp * 1000)//时间戳为10位需*1000,时间戳为13位的话不需乘1000
- var Y = date.getFullYear() + '年'
- var M = (date.getMonth() + 1 < 10 ? '0' + (date.getMonth() + 1) : date.getMonth() + 1) + '月'
- var D = (date.getDate() < 10 ? '0' + (date.getDate()) : date.getDate()) + '日 '
- var h = (date.getHours() < 10 ? '0' + (date.getHours()) : date.getHours()) + '时'
- var m = (date.getMinutes() < 10 ? '0' + (date.getMinutes()) : date.getMinutes()) + '分'
- var s = (date.getSeconds() < 10 ? '0' + (date.getSeconds()) : date.getSeconds()) + '秒'
- return Y + M + D + h + m + s
- },
- generateLog() {
- let params = {
- 'log_type': 1
- }
- generateLog(params).then(
- response => {
- if (response.data.state === 1) {
- this.logs = response.data.data.logs
- this.exportLogVisible = true
- } else {
- this.$message.error(response.data.msg)
- }
- }
- )
-
- },
- handleSuccess({ results, header }) {
- console.log(results)
- if (header != undefined && header.length > 0) {
- var isHasName = header.includes('*姓名')
- var isHasGender = header.includes('*性别')
- var isHasPhone = header.includes('*手机号')
- var isHasIdCard = header.includes('*身份证号')
- var isHasDate = header.includes('*首次肾脏治疗时间')
- var isHasSource = header.includes('*患者来源')
- var isHasLapseto = header.includes('*治疗状态')
- var isHasInfectious = header.includes('*传染病')
- var isHasDiagnose = header.includes('诊断')
- var isHasDialysisNo = header.includes('透析号')
-
- var isHasDryWeight = header.includes('干体重(kg)')
- var isHasHeight = header.includes('身高(cm)')
- var isHasHomeAddress = header.includes('家庭住址')
-
- if (!(isHasName && isHasGender && isHasPhone && isHasIdCard && isHasDate && isHasSource && isHasLapseto && isHasInfectious && isHasDiagnose && isHasDialysisNo && isHasDryWeight && isHasHeight && isHasHomeAddress)) {
- this.dialogVisible = true
- return
- }
- } else {
- this.dialogVisible = true
- return
- }
- getMaxDialysisNo().then(
- response => {
- if (response.data.state === 1) {
- this.max_dialysis_no = response.data.data.dialysis_no
- if (this.max_dialysis_no == 0) {
- this.max_dialysis_no = 1
- } else {
- this.max_dialysis_no++
- }
-
-
- this.export_date = []
- for (let i = 1; i < results.length; i++) {
- let obj = {}
- for (var key in results[i]) {
- if (results[i]['*姓名'] === undefined) {
- obj['name'] = ''
- } else {
- if (key == '*姓名') {
- obj['name'] = results[i][key].replace(/\s/g,"")
-
- }
- }
-
- if (results[i]['*性别'] === undefined) {
- obj['gender'] = '0'
- } else {
- if (key == '*性别') {
- if (results[i][key] == '男') {
- obj['gender'] = '1'
- } else if (results[i][key] == '女') {
- obj['gender'] = '2'
- } else {
- obj['gender'] = '0'
- }
- }
- }
-
- if (results[i]['*手机号'] === undefined) {
- obj['phone'] = ''
- } else {
- if (key == '*手机号') {
- obj['phone'] = results[i][key].replace(/\s/g,"")
- }
- }
-
- if (results[i]['*身份证号'] === undefined) {
- obj['id_card_no'] = ''
-
- } else {
- if (key == '*身份证号') {
- obj['id_card_no'] = results[i][key].replace(/\s/g,"")
- }
- }
-
- if (results[i]['*首次肾脏治疗时间'] === undefined) {
- obj['first_treatment_date'] = ''
-
- } else {
- if (key == '*首次肾脏治疗时间') {
- var month = parseInt(results[i][key].replace(/\s/g,"").split('/')[0])
- var day = parseInt(results[i][key].replace(/\s/g,"").split('/')[1])
- var year = parseInt(results[i][key].replace(/\s/g,"").split('/')[2])
- if (year < 10) {
- year = '0' + year
- }
-
- if (day < 10) {
- day = '0' + day
- }
- if (month < 10) {
- month = '0' + month
- }
- obj['first_treatment_date'] = '20' + year.toString() + '/' + month.toString() + '/' + day.toString()
- }
- }
-
- if (results[i]['*患者来源'] === undefined) {
- obj['source'] = '3'
-
- } else {
- if (key == '*患者来源') {
- if (results[i][key] == '门诊') {
- obj['source'] = '1'
- } else if (results[i][key] == '住院') {
- obj['source'] = '2'
- } else {
- obj['source'] = '0'
- }
- }
- }
-
- if (results[i]['*治疗状态'] === undefined) {
- obj['lapseto'] = '3'
-
- } else {
- if (key == '*治疗状态') {
- if (results[i][key] == '留治') {
- obj['lapseto'] = '1'
- } else if (results[i][key] == '转归') {
- obj['lapseto'] = '2'
- } else {
- obj['lapseto'] = '0'
- }
- }
- }
-
- if (results[i]['*传染病'] === undefined) {
- let contagions = []
- obj['is_infectious'] = '3'
- obj['contagions'] = contagions
-
- } else {
- if (key == '*传染病') {
- if (results[i][key] == '无') {
- let contagions = []
- obj['is_infectious'] = '1'
- obj['contagions'] = contagions
-
- } else if (results[i][key] == '乙肝') {
- let contagions = []
- contagions.push(2)
- obj['is_infectious'] = '2'
- obj['contagions'] = contagions
- } else if (results[i][key] == '丙肝') {
- let contagions = []
- contagions.push(3)
- obj['is_infectious'] = '2'
- obj['contagions'] = contagions
-
- } else if (results[i][key] == '艾滋病') {
- let contagions = []
- contagions.push(4)
- obj['is_infectious'] = '2'
- obj['contagions'] = contagions
-
- } else if (results[i][key] == '肺结核') {
- let contagions = []
- contagions.push(5)
- obj['is_infectious'] = '2'
- obj['contagions'] = contagions
-
- } else if (results[i][key] == '梅毒') {
- let contagions = []
- contagions.push(6)
- obj['is_infectious'] = '2'
- obj['contagions'] = contagions
- } else {
- let contagions = []
- obj['is_infectious'] = '0'
- obj['contagions'] = contagions
- }
- }
- }
-
- if (results[i]['诊断'] === undefined) {
- obj['diagnose'] = ''
- } else {
- if (key == '诊断') {
- obj['diagnose'] = results[i][key]
- }
- }
- // console.log(obj)
-
- if (results[i]['透析号'] === undefined) {
- obj['dialysis_no'] = ''
- } else {
- if (key == '透析号') {
- obj['dialysis_no'] = results[i][key].replace(/\s/g,"")
- }
- }
-
- // console.log(obj)
-
- if (results[i]['干体重(kg)'] === undefined) {
- obj['dry_weight'] = ''
- } else {
- if (key == '干体重(kg)') {
- obj['dry_weight'] = results[i][key].replace(/\s/g,"")
- }
- }
-
- // console.log(obj)
-
- if (results[i]['身高(cm)'] === undefined) {
- obj['height'] = ''
- } else {
- if (key == '身高(cm)') {
- obj['height'] = results[i][key].replace(/\s/g,"")
- }
- }
-
- // console.log(obj)
-
- if (results[i]['家庭住址'] === undefined) {
- obj['home_address'] = ''
- } else {
- if (key == '家庭住址') {
- obj['home_address'] = results[i][key]
- }
- }
- }
-
- this.export_date.push(obj)
- }
-
- let index = 0
-
- for (let i = 0; i < this.export_date.length; i++) {
- if (this.export_date[i].dialysis_no == '') {
- let new_dialysis_no = this.max_dialysis_no + index
- // console.log(new_dialysis_no)
- index++
- let no = new_dialysis_no.toString()
- // console.log(no)
- let rep = 3 - no.length
- // console.log(rep)
- let tempNo = ""
- if (rep == 1){
- tempNo = "0"
- }
-
- if (rep == 2){
- tempNo = "00"
- }
-
-
- // console.log(tempNo)
- if (rep > 0) {
- no = tempNo + no
- }
- this.export_date[i].dialysis_no = no
- }
- }
-
-
- // console.log(this.export_date)
-
- var tempExportDate = this.export_date
- var tempExportDateOne = this.export_date
- var tempExportDateTwo = this.export_date
-
-
-
- const obj2 = {}
- tempExportDate = tempExportDate.reduce((cur, next) => {
- obj2[next.dialysis_no] ? '' : obj2[next.dialysis_no] = true && cur.push(next)
- return cur
- }, []) // 设置cur默认类型为数组,并且初始值为空的数组
-
-
-
- if (tempExportDate.length < this.export_date.length){
- this.dialysisVisible = true
- return
- }
-
-
-
- const obj3 = {}
- tempExportDateOne = tempExportDateOne.reduce((cur, next) => {
- obj3[next.phone] ? '' : obj3[next.phone] = true && cur.push(next)
- return cur
- }, []) // 设置cur默认类型为数组,并且初始值为空的数组
-
-
-
- if (tempExportDateOne.length < this.export_date.length){
- this.phoneVisible = true
- return
- }
-
-
-
-
- const obj4 = {}
- tempExportDateTwo = tempExportDateTwo.reduce((cur, next) => {
- obj4[next.id_card_no] ? '' : obj4[next.id_card_no] = true && cur.push(next)
- return cur
- }, []) // 设置cur默认类型为数组,并且初始值为空的数组
-
- if (tempExportDateTwo.length < this.export_date.length){
- this.idCardNoVisible = true
- return
- }
-
- // this.exportVisible = true
- this.$alert('您提交的患者名单已上传成功,系统正在执行导入,请稍候点击当前页面右上角“下载日志”查看导入结果', '上传成功', {
- confirmButtonText: '确定',
- callback: action => {
-
- }
- });
- this.isShow = false
- let params = {
- 'patients': this.export_date
- }
- postExportPatients(params).then(
- response => {
- if (response.data.state === 1) {
-
- this.getList()
- this.isShow = true
-
- } else {
- this.isShow = true
-
- this.$message.error(response.data.msg)
- }
- }
- )
-
- }
- }
- )
-
- },
- getCount(row) {
-
- return row.total_dialysis + row.user_sys_before_count
- },
- EditLapseto() {
- if (this.lapsetoForm.lapseto_time == '') {
- this.$message.error('请选择时间')
- return
- }
- if(this.lapeseto == "留治"){
- this.lapsetoForm.lapseto_type = 1
- }
- if(this.lapeseto == "转出"){
- this.lapsetoForm.lapseto_type = 2
- }
- EditLapseto(this.lapsetoForm.patient_id, this.lapsetoForm).then(
- response => {
- if (response.data.state === 1) {
- this.$notify({
- title: '成功',
- message: '转归设置完成',
- type: 'success',
- duration: 2000
- })
- this.tableData[this.currentIndex].lapseto = this.lapsetoForm.lapseto_type
- this.tableData[this.currentIndex].out_reason = this.lapsetoForm.out_reason
- this.currentIndex = -1
- this.LapsetoDialogVisible = false
- } else {
- this.$message.error(response.data.msg)
- }
- }
- )
- },
- OpenSetLapseto(row, index) {
- if(row.lapseto == 1){
- this.lapeseto = "转出"
- }
- if(row.lapseto == 2){
- this.lapeseto = "留治"
- }
- this.patient = row
- this.currentIndex = index
- this.lapsetoForm.lapseto_time = ''
- this.lapsetoForm.lapseto_type = row.lapseto
- this.lapsetoForm.patient_id = row.id
- this.lapsetoForm.out_reason = row.out_reason
- this.LapsetoDialogVisible = true
- },
- LapsetoInfo(row) {
- if (
- typeof row.lapseto === 'undefined' ||
- (row.lapseto !== 1 && row.lapseto !== 2)
- ) {
- return '未设置'
- } else if (row.lapseto === 1) {
- return '留治'
- } else {
- return '转出'
- }
- },
- openWechatBindDialog() {
- this.bindWechatDialog = true
- },
- handleCheckAllChange(val) {
- // console.log(val)
- // console.log(this.checkAll)
- // console.log(this.isIndeterminate)
- },
- handleSelectionChange(val) {
- this.multipleSelection = val
- this.pageSelect = this.multipleSelection.length
- },
-
- handleCheckedCitiesChange(value) {
- const checkedCount = value.length
- this.checkAll = checkedCount === this.cities.length
- this.isIndeterminate =
- checkedCount > 0 && checkedCount < this.cities.length
- },
- handleSizeChange(val) {
- this.listQuery.limit = val
- this.getList()
- },
- handleCurrentChange(val) {
- this.listQuery.page = val
- this.getList()
- },
- changeCategoryId(categoryId) {
- this.categoryId = categoryId
- },
- selectSchedulType(scheduleType) {
- // alert(scheduleType);/
- this.schedulType = scheduleType
- this.listQuery.schedul_type = scheduleType
- this.getList()
- },
- selectSystemType(systemType) {
- this.systemType = systemType
- this.listQuery.binding_state = systemType
- this.getList()
- },
- selectLapseTo(lapseto) {
- this.lapsetoType = lapseto
- this.listQuery.lapseto = lapseto
- this.getList()
- },
- selectSource(source) {
- this.sourceType = source
- this.listQuery.source = source
- this.getList()
- },
- changeTimeOne(val) {
- var time = this.getTimestamp(val) - this.end_time
- if (time > 0) {
- this.$message.error('结束时间不能小于开始时间')
- this.listQuery.start_time = ''
- } else {
- this.getList()
- this.startTime = this.getTimestamp(val)
- }
- },
- changeTime(val) {
- var time = this.getTimestamp(val) - this.startTime
- if (time < 0) {
- this.$message.error('结束时间不能小于开始时间')
- this.listQuery.end_time = ''
- } else {
- this.getList()
- this.end_time = this.getTimestamp(val)
- }
- },
- getTimestamp(time) {
- // 把时间日期转成时间戳
- return new Date(time).getTime() / 1000
- },
- search() {
- this.listQuery.keywords = this.searchKey
- this.getList()
- },
- changeOtherSearch() {
- this.getList()
- },
- getList() {
- fetchList(this.listQuery).then(response => {
- if (response.data.state === 0) {
- this.$message.error(response.data.msg)
- return false
- } else {
- this.tableData = response.data.data.patients
- console.log('病人是', this.tableData)
- this.pageTotal = this.tableData.length
- this.total = response.data.data.total
- }
- })
- },
-
- OpenView(name, number, id) {
- this.name = name
- this.dialysis_no = number
- this.centerDialogVisible = true
- OpenView(id).then(response => {
- if (response.data.state === 0) {
- this.$message.error(response.data.msg)
- return false
- } else {
- var patient = response.data.data.patient
- console.log('二维码病人信息', patient)
- this.id = patient.id
- this.name = patient.name
- this.gender = patient.gender
- this.idcardno = patient.id_card_no
- this.phone = patient.phone
- this.healthcareno = patient.health_care_no
- }
- })
- },
- ShowQRCode() {
- document.getElementById('qrcode').innerHTML = ''
- this.qrcode = this.$QRCode()
- },
- download() {
- alert('aaaa')
- },
- print() {
- var ptime = Math.round(new Date().getTime() / 1000)
- this.print_time = uParseTime(ptime, '{y}年{m}月{d}日')
- const style =
- '@media print { .print_main_content { background-color: white; width:960px; margin:0 auto; padding: 0 0 20px 0; } .print_main_content .order_title { text-align: center; font-size: 23px; line-height: 50px; font-weight: 500; } .print_main_content table { width: 100%; border: 1px solid; border-collapse: collapse; padding: 2px; } .print_main_content table tbody tr td { border: 1px solid; text-align: center; padding: 10px 8px; } .td_proj_title { font-size: 18px; line-height: 25px; font-weight: 500; } .td_proj_content { font-size: 18px; line-height: 25px; } .td_align_left { text-align: left; } .print_footnote_panel { font-size: 17px; line-height: 40px; } .print_footnote_panel .proj { display: inline-block; width: 49%; } .print_footnote_panel .proj .proj_title { font-weight: 500;} }'
- setTimeout(() => {
- printJS({
- printable: 'print-card-info',
- type: 'html',
- style: style,
- scanStyles: false
- })
- }, 1)
-
- var id = this.id
- var name = this.name
- var gender = this.gender
- if (gender === 1) {
- gender = '男'
- }
- if (gender === 2) {
- gender = '女'
- }
- var idcardno = this.idcardno
- var phone = this.phone
- var healthcareno = this.healthcareno
- var dialysisno = this.dialysis_no
-
- // Base64位加密
- // var aid = this.Base64.encode(id);
- // var aname = this.Base64.encode(name);
- // var agender = this.Base64.encode(gender);
- // var aidcardno = this.Base64.encode(idcardno);
- // var aphone = this.Base64.encode(phone);
- // var ahealthcareno = this.Base64.encode(healthcareno);
- // var adialysisno = this.Base64.encode(dialysisno);
- // 调用生成二维码的方法
- this.$options.methods.qrcode(
- id,
- name,
- gender,
- idcardno,
- phone,
- healthcareno,
- dialysisno
- )
- },
- qrcode(id, name, gender, idcardno, phone, healthcareno, dialysisno) {
- document.getElementById('code').innerHTML = ''
- const qrcode = new QRCode('code', {
- width: 200,
- height: 200,
- text:
- 'user_id:' +
- id +
- ',' +
- 'name:' +
- name +
- ',' +
- 'dialysis_no:' +
- dialysisno +
- ',' +
- 'gender:' +
- gender +
- ',' +
- 'idcard_no:' +
- idcardno +
- ',' +
- 'phone:' +
- phone +
- ',' +
- 'healthcare_no:' +
- healthcareno
- })
- }
- // components:{
- // pagiNation
- // }
- }
- }
- Vue.prototype.$QRCode = function() {
- var name = this.name
- var dialysis_no = this.dialysis_no
- var id = this.id
- var gender = this.gender
- if (gender === 1) {
- gender = '男'
- }
- if (gender === 2) {
- gender = '女'
- }
- var idcardno = this.idcardno
- var phone = this.phone
- var healthcareno = this.healthcareno
-
- // BASE64加密
- // var eid = this.Base64.encode(id)
- // var ename = this.Base64.encode(name)
- // var egender = this.Base64.encode(gender)
- // var eidcardno = this.Base64.encode(idcardno)
- // var ephone = this.Base64.encode(phone)
- // var ehealthcareno = this.Base64.encode(healthcareno)
- // var edialysisno = this.Base64.encode(dialysis_no)
- var eid = id
- var ename = name
- var egender = gender
- var eidcardno = idcardno
- var ephone = phone
- var ehealthcareno = healthcareno
- var edialysisno = dialysis_no
- console.log(
- 'user_id' + eid,
- 'name:' + ename,
- 'gender:' + egender,
- 'idcard_no:' + eidcardno,
- 'phone:' + ephone,
- 'healthcare_no:' + ehealthcareno,
- 'edialysis_no:' + edialysisno
- )
- const salting = 'admin-authority'
- new QRCode('qrcode', {
- width: 150, // 设置宽度
- height: 150, // 设置高度
- text:
- 'user_id:' +
- eid +
- ',' +
- 'name:' +
- ename +
- ',' +
- 'dialysis_no:' +
- edialysisno +
- ',' +
- 'gender:' +
- egender +
- ',' +
- 'idcard_no:' +
- eidcardno +
- ',' +
- 'phone:' +
- ephone +
- ',' +
- 'healthcare_no:' +
- ehealthcareno
- })
- }
- </script>
-
- <style rel="stylesheet/scss" lang="scss">
- .app-container {
- /*margin: 20 px;*/
- font-size: 15px;
-
- .filter-container {
- padding-bottom: 5px;
- }
-
- .search-component {
- width: 500px;
-
- .searchBox {
- width: 300px;
- height: 36px;
- line-height: 36px;
- padding-left: 15px;
- border: 1px #dcdfe6 solid;
- border-right: none;
- outline: none;
- float: left;
- border-radius: 6px 0 0 6px;
- font-size: 14px;
- color: #333;
- background: #fff;
- box-shadow: 3px 3px 4px rgba(135, 135, 135, 0.05);
- }
-
- .searchBtn {
- background-color: #409eff;
- color: #fff;
- font-size: 15px;
- text-align: center;
- height: 36px;
- line-height: 36px;
- float: left;
- outline: none;
- width: 70px;
- border: none;
- border-radius: 0 6px 6px 0;
- font-family: "Microsoft Yahei";
- cursor: pointer;
- }
-
- }
- .amount {
- font-weight: normal;
- padding: 10px 0 0 0;
- color: #606266;
- font-size: 14px;
-
- span {
- color: #ef2525;
- font-family: "Arial";
- padding: 0 2px;
- }
-
- }
-
- .print_main_content {
- background-color: white;
- width: 960px;
- margin: 0 auto;
- padding: 0 0 20px 0;
- }
-
- .print_main_content .order_title {
- text-align: center;
- font-size: 23px;
- line-height: 50px;
- font-weight: 500px;
- }
-
- .print_main_content table {
- width: 100%;
- border: 1px solid;
- border-collapse: collapse;
- padding: 2px;
- }
-
- .print_main_content table tbody tr td {
- border: 1px solid;
- text-align: center;
- /* font-size: 17px; */
- padding: 10px 8px;
- }
-
- .td_proj_title {
- font-size: 18px;
- line-height: 25px;
- font-weight: 500;
- }
-
- .td_proj_content {
- font-size: 18px;
- line-height: 25px;
- }
-
- .td_align_left {
- text-align: left;
- }
-
- .print_footnote_panel {
- font-size: 17px;
- line-height: 40px;
- }
-
- .print_footnote_panel .proj {
- display: inline-block;
- width: 49%;
- }
-
- .print_footnote_panel .proj .proj_title {
- font-weight: 500;
- }
-
- }
- .el-table td,
- .el-table th.is-leaf,
- .el-table--border,
- .el-table--group {
- border-color: #d0d3da;
- }
-
- .el-table--border::after,
- .el-table--group::after,
- .el-table::before {
- background-color: #d0d3da;
- }
-
- .el-select--small {
- width: 196px;
- }
-
- .el-checkbox__inner::after {
- height: 10px;
- left: 7px;
- }
-
- .el-checkbox__inner {
- width: 20px;
- height: 20px;
- }
- </style>
|