123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813 |
- <template>
- <scroll-view :scroll-y="!models.disjunctor" @scroll="scrollList" :scroll-top="scroll_t" class="my_list">
- <view class="my_list_top">
- <view class="my_list_topL" @click="act()">
- 筛选
- <text class="cubeic-pulldown icon_transport transport-paixujiantouxia" v-if="!actType"></text>
- <text class="cubeic-pullup icon_transport transport-paixujiantoushang" v-if="actType"></text>
- </view>
- <view class="my_list_topC">
- <input type="text" placeholder="请输入关键字" v-model="listData.workOrder.keyWord" />
- </view>
- <view class="my_list_topR" @click="search(listData)"> 搜索 </view>
- </view>
- <view class="my_list_tops" id="actType" :animation="animationData" v-if="actType">
- <view class="tops">
- <view>类型筛选</view>
- <view class="tops_cont">
- <view v-for="(data, i) of typeData" :key="i" :class="{ ac: checkedSear[data.id] }"
- @click="sxTab(data.associationTypes, data.id)" :id="data.id">
- {{ data.name }}
- </view>
- </view>
- </view>
- <view class="tops">
- <view>工单筛选</view>
- <view class="tops_cont1">
- <view :class="{ gdType: listData.workOrder.abnormityType == 0 }" @click="gdTab(0)">
- 正常工单
- </view>
- <view :class="{ gdType: listData.workOrder.abnormityType == 1 }" @click="gdTab(1)">
- 异常工单
- </view>
- </view>
- </view>
- <view class="foot_btn2">
- <view class="btn1" :class="{ btnType: btnType == 1 }" @click="ok(listData)">
- 确定
- </view>
- <view class="btn2" @click="Reset()"> 重置 </view>
- </view>
- </view>
- <view class="item" @click="item()">
- <view class="page_items" v-if="workData && workData.length > 0">
- <view class="page_item" v-for="(infoDATA, i) of workData" :key="i" @click="detailIt(infoDATA)">
- <view class="page_item_top">
- <view class="page_item_top_L">
- <text class="L_text">单号:{{ infoDATA.gdcode }}</text>
- <view class="page_item_cont_start emergency1" v-if="infoDATA.emergencyType.value == 1">
- <text>
- <text
- class="cubeic-star icon_transport transport-shiwujiaoxing"></text>{{ infoDATA.emergencyType.name }}</text>
- </view>
- <view class="page_item_cont_start emergency" v-if="infoDATA.emergencyType.value == 2">
- <text>
- <text
- class="cubeic-star icon_transport transport-shiwujiaoxing"></text>{{ infoDATA.emergencyType.name }}</text>
- </view>
- <view class="page_item_cont_start emergencys" v-if="infoDATA.emergencyType.value == 3">
- <text>
- <text
- class="cubeic-star icon_transport transport-shiwujiaoxing"></text>{{ infoDATA.emergencyType.name }}</text>
- </view>
- </view>
- <view class="page_item_top_L">
- <text class="L_iocn" v-if="infoDATA.taskType.associationType.value == 'specimen'">标本<template v-if="infoDATA.goodsRemark">-{{infoDATA.goodsRemark}}</template></text>
- <text class="L_iocn" v-if="infoDATA.taskType.associationType.value == 'specimenPlan'">标本<template v-if="infoDATA.goodsRemark">-{{infoDATA.goodsRemark}}</template></text>
- <text class="L_iocn" v-if="infoDATA.taskType.associationType.value == 'drugsBag'">药品<template v-if="infoDATA.goodsRemark">-{{infoDATA.goodsRemark}}</template></text>
- <text class="L_iocn" v-if="infoDATA.taskType.associationType.value == 'jPBag'">静配<template v-if="infoDATA.goodsRemark">-{{infoDATA.goodsRemark}}</template></text>
- <text class="L_iocn" v-if="infoDATA.taskType.associationType.value == 'inspect'">陪检<template v-if="infoDATA.goodsRemark">-{{infoDATA.goodsRemark}}</template></text>
- <text class="L_iocn" v-if="
- infoDATA.taskType.associationType.value == 'patientTransport'
- ">转运<template v-if="infoDATA.goodsRemark">-{{infoDATA.goodsRemark}}</template></text>
- <text class="L_iocn" v-if="infoDATA.taskType.associationType.value == 'other'">其他<template v-if="infoDATA.goodsRemark">-{{infoDATA.goodsRemark}}</template></text>
- </view>
- <view class="page_item_top_R">
- <view class="num" v-if="infoDATA.gdState.value != 6">
- {{infoDATA.grade?(infoDATA.grade.gradeTotal>=0?'+'+infoDATA.grade.gradeTotal:'-'+infoDATA.grade.gradeTotal):''}}
- </view>
- <view class="num" v-if="infoDATA.gdState.value == 6">
- 未评价
- </view>
- </view>
- <view class="L"> </view>
- <view class="R"> </view>
- </view>
- <view class="page_item_cont">
- <view class="page_item_cont_T">
- <view class="page_item_cont_title">
- <text> <text class="starting">起</text> 点科室</text>
- <text class="text_big"> {{ infoDATA.startDept.dept }}</text>
- </view>
- </view>
- <view class="line"> </view>
- <view class="page_item_cont_B">
- <view class="page_item_cont_title" v-for="(dept, i) of infoDATA.middleDept" :key="i">
- <view v-if="infoDATA.taskType.associationType.value == 'inspect'">
- <text> <text class="End">检</text> 查科室</text>
- <text class="text_big"> {{ dept.dept }}</text>
- <view></view>
- </view>
- </view>
- <view class="page_item_cont_title" v-for="(dept, i) of infoDATA.endDepts" :key="i">
- <view v-if="infoDATA.taskType.associationType.value != 'inspect'">
- <text> <text class="End">终</text> 点科室</text>
- <text class="text_big"> {{ dept.dept }}</text>
- </view>
- </view>
- </view>
- </view>
- <view class="page_item_foot">
- <view class="page_item_foot_text">
- <text class="text1">完成时间</text>
- <text class="text1">{{ infoDATA.completeTime || '' }}</text>
- </view>
- <view class="page_item_foot_text" @click.stop="goToDetail(infoDATA)" v-if="infoDATA.taskType.associationType.value==='specimen' || infoDATA.taskType.associationType.value==='specimenPlan'">
- <text class="text1">{{infoDATA.taskType.associationType.value==='specimen' ? '扫描接收数量' : '扫描送达数量'}}</text>
- <text class="text1 b">{{ infoDATA.actualReceiveNum || 0 }}</text>
- </view>
- </view>
- </view>
- </view>
- </view>
- <!-- 弹窗 -->
- <showIntegralModel :disjunctor="models.disjunctor" :operate="models.operate" :timestamp="models.timestamp"
- :orderId="models.orderId" @know="know()"></showIntegralModel>
- <!-- 未评价弹窗提示 -->
- <showModel :title="models6.title" :icon="models6.icon" :disjunctor="models6.disjunctor" :content="models6.content"
- @know="know6" :operate="models6.operate"></showModel>
- </scroll-view>
- </template>
- <script>
- import {
- get,
- post,
- webHandle
- } from "../../http/http.js";
- import showIntegralModel from "../../components/showIntegralModel/showIntegralModel.vue";
- import showModel from "../../components/showModel/showModel.vue";
- export default {
- data() {
- return {
- // 弹窗model
- models6: {
- disjunctor: false,
- },
- //滚动距离
- scroll_t: 0,
- scroll_t_old: 0,
- // 弹窗model
- models: {
- disjunctor: false,
- },
- animationData: {}, //动画
- actType: false,
- btnType: 1,
- checkedSear: {}, //筛选多选box
- types: "",
- typeData: [],
- listData: {
- idx: 0,
- sum: 20,
- workOrder: {
- abnormityType: "0",
- associationTypes: [],
- keyWord: "",
- },
- },
- workData: [],
- };
- },
- components: {
- showIntegralModel,
- showModel,
- },
- methods: {
- goToDetail(order){
- console.log(order)
- let data = {
- uuid: order.id,
- }
- uni.navigateTo({
- url: `../scannedDepartmentSpecimens/scannedDepartmentSpecimens?infoDATA=${encodeURIComponent(JSON.stringify(data))}`,
- });
- },
- //滚动距离
- scrollList(e) {
- this.scroll_t_old = e.detail.scrollTop;
- },
- // 知道了
- know() {
- this.scroll_t = this.scroll_t_old;
- this.models.disjunctor = false;
- },
- //未评价弹窗知道了
- know6() {
- this.models6.disjunctor = false;
- },
- //积分详情
- detailIt(infoDATA) {
- if (infoDATA.gdState.value == 6) {
- this.models6 = {
- disjunctor: true,
- content: "暂未评价,无法查看积分详情",
- icon: "warn",
- operate: {
- know: "知道了"
- },
- };
- return;
- }
- this.models.disjunctor = true;
- this.models.orderId = infoDATA.id;
- this.models.timestamp = Date.now();
- },
- item() {
- this.actType = false;
- this.animation.opacity(0).step();
- this.animationData = this.animation.export();
- },
- // 确定
- ok(data) {
- this.getData(data);
- this.actType = false;
- this.animation.opacity(0).step();
- this.animationData = this.animation.export();
- },
- // 搜索
- search(data) {
- this.getData(data);
- this.actType = false;
- this.animation.opacity(0).step();
- this.animationData = this.animation.export();
- },
- // 重置
- Reset() {
- for (var k in this.checkedSear) {
- this.checkedSear[k] = false;
- }
- this.listData.workOrder.associationType = [];
- this.listData.workOrder.abnormityType = "0";
- this.listData.workOrder.keyWord = "";
- this.getData(this.listData);
- },
- // 筛选
- act() {
- if (this.actType) {
- //当前状态时展开
- this.animation.opacity(0).step();
- this.animationData = this.animation.export();
- } else {
- //seimin
- this.animation.opacity(1).step();
- this.animationData = this.animation.export();
- }
- this.actType = !this.actType;
- },
- // 类型筛选
- sxTab(type, id) {
- this.$set(this.checkedSear, id, !this.checkedSear[id]);
- let checkedArr = [];
- for (var k in this.checkedSear) {
- if (this.checkedSear[k]) {
- checkedArr.push(k);
- }
- }
- this.listData.workOrder.associationTypes = checkedArr;
- },
- gdTab(type) {
- this.listData.workOrder.abnormityType = type;
- },
- getType() {
- let data = {
- type: "list",
- key: "association_types",
- };
- post("/common/common/getDictionary", data).then((res) => {
- for (var i = 0; i < res.length; i++) {
- let list = {
- name: "",
- associationTypes: "",
- id: "",
- };
- list.name = res[i].name;
- list.associationTypes = res[i].value;
- list.id = res[i].id;
- this.typeData.push(list);
- let id = res[i].id;
- this.$set(this.checkedSear, id, false);
- }
- });
- },
- getData(data) {
- uni.showLoading({
- title: '加载中',
- mask: true
- });
- post("/api/getOrdersByDate/" + this.types, data).then((res) => {
- uni.hideLoading();
- if (res.status == 200) {
- res.data.data.forEach(v=>{
- if(v.completeTime){
- v.completeTime = v.completeTime.slice(5,16)
- }
- })
- this.workData = res.data.data;
- } else {
- uni.showToast({
- icon: "none",
- title: "请求失败!",
- });
- }
- });
- },
- },
- onLoad(options) {
- console.log(options)
- this.types = options.type;
- this.getType();
- this.getData(this.listData);
- // 创建动画
- this.animation = uni.createAnimation({
- duration: 500,
- timingFunction: "ease",
- });
- // #ifdef APP-PLUS
- webHandle("no", "app");
- // #endif
- // #ifdef H5
- webHandle("no", "wx");
- // #endif
- },
- onUnload() {
- // 页面关闭后清空数据
- this.animationData = {};
- },
- };
- </script>
- <style lang="less">
- .my_list {
- height: 100vh;
- .my_list_top {
- height: 90rpx;
- background: #fff;
- line-height: 90rpx;
- border-bottom: 2rpx solid rgb(142, 157, 158);
- position: fixed;
- top: 0;
- width: 100%;
- z-index: 999;
- display: flex;
- align-items: center;
- justify-content: space-between;
- .my_list_topL {
- float: left;
- width: 22%;
- height: 100%;
- font-size: 32rpx;
- text-align: center;
- display: flex;
- justify-content: center;
- align-items: center;
- text {
- font-size: 34rpx;
- }
- }
- .my_list_topC {
- float: left;
- width: 55%;
- input {
- height: 60rpx;
- border: 2rpx solid rgb(142, 157, 158);
- border-radius: 40rpx;
- width: 100%;
- padding-left: 10rpx;
- padding-right: 10rpx;
- }
- }
- .my_list_topR {
- float: right;
- width: 22%;
- height: 100%;
- font-size: 32rpx;
- text-align: center;
- }
- }
- .my_list_tops {
- background: #fff;
- position: fixed;
- padding-top: 20rpx;
- z-index: 999;
- top: 92rpx;
- width: 100%;
- opacity: 0;
- .tops {
- height: 100%;
- text-align: left;
- padding-left: 30rpx;
- font-size: 32rpx;
- .tops_cont {
- height: 100%;
- margin-top: 10rpx;
- overflow: hidden;
- display: flex;
- flex-wrap: wrap;
- justify-content: space-between;
- view {
- width: 32%;
- height: 70rpx;
- line-height: 70rpx;
- // float: left;
- text-align: center;
- // margin-right: 2%;
- color: rgb(142, 157, 158);
- background: rgb(249, 250, 251);
- border-radius: 8rpx;
- margin-bottom: 2%;
- }
- .ac {
- color: #fff !important;
- background-image: linear-gradient(to right,
- #72c172,
- #3bb197) !important;
- }
- .ac1 {
- display: inline-block;
- }
- }
- .tops_cont1 {
- height: 100rpx;
- margin-top: 10rpx;
- overflow: hidden;
- view {
- width: 45%;
- color: rgb(142, 157, 158);
- height: 70rpx;
- line-height: 70rpx;
- float: left;
- text-align: center;
- margin-right: 2%;
- background: rgb(249, 250, 251);
- border-radius: 8rpx;
- }
- }
- .tops_cont2 {
- height: 90rpx;
- line-height: 90rpx;
- }
- .lxType {
- color: #fff !important;
- background-image: linear-gradient(to right,
- #72c172,
- #3bb197) !important;
- }
- .gdType {
- color: #fff !important;
- background-image: linear-gradient(to right,
- #72c172,
- #3bb197) !important;
- }
- }
- .foot_btn2 {
- position: absolute;
- width: 100%;
- line-height: 90rpx;
- height: 90rpx;
- border-top: 2rpx solid #e5e9ed;
- border-bottom: 2rpx solid #e5e9ed;
- background: #f9fafb;
- text-align: center;
- view {
- height: 90rpx;
- width: 49%;
- color: rgb(153, 153, 153);
- font-size: 32rpx;
- }
- .btn1 {
- float: left;
- }
- .btn2 {
- float: right;
- border-left: 2rpx solid #e5e9ed;
- }
- }
- .btnType {
- color: rgb(102, 102, 102) !important;
- }
- }
- .item {
- padding: 0 20rpx;
- margin-top: 120rpx;
- .page_items {
- margin-bottom: 110rpx;
- .page_item {
- margin-top: 16rpx;
- min-height: 356rpx;
- background: #fff;
- border-radius: 8rpx;
- overflow: hidden;
- padding: 0 16rpx;
- border: 2rpx solid #e5e9ed;
- .L {
- width: 40rpx;
- height: 40rpx;
- border-radius: 50%;
- background: #f9fafb; // background: blue;
- position: relative;
- left: -50rpx;
- top: 66rpx;
- }
- .R {
- width: 40rpx;
- height: 40rpx;
- border-radius: 50%;
- background: #f9fafb;
- position: relative;
- float: right;
- right: -50rpx;
- top: 26rpx;
- }
- .starting {
- width: 50rpx;
- height: 50rpx;
- color: #fff;
- background: #49b856;
- display: inline-block;
- border-radius: 50%;
- text-align: center;
- line-height: 46rpx;
- font-size: 32rpx;
- margin-right: 6rpx;
- }
- .End {
- width: 50rpx;
- height: 50rpx;
- color: #fff;
- background: #39b199;
- display: inline-block;
- border-radius: 50%;
- text-align: center;
- line-height: 46rpx;
- font-size: 32rpx;
- margin-right: 6rpx;
- }
- .page_item_top {
- height: 86rpx;
- border-bottom: 2rpx dashed #e5e9ed;
- .page_item_top_L {
- height: 100%;
- float: left;
- line-height: 88rpx;
- .ac {
- width: 32rpx;
- height: 32rpx;
- border: 2rpx solid #ccc;
- display: inline-block;
- position: relative;
- top: 6rpx;
- display: none;
- text {
- width: 24rpx;
- height: 24rpx;
- background: #39b199;
- display: block;
- margin: 0 auto;
- margin-top: 4rpx;
- }
- }
- .ac1 {
- width: 32rpx;
- height: 32rpx;
- border: 2rpx solid #ccc;
- display: inline-block;
- position: relative;
- top: 6rpx;
- }
- .emergencys {
- background: #ff3b53 !important;
- width: 124rpx !important;
- }
- .emergency {
- background: #ff3b53 !important;
- }
- .emergency1 {
- background: #49b856 !important;
- }
- .page_item_cont_start {
- text-align: center;
- height: 44rpx;
- width: 104rpx;
- line-height: 44rpx;
- border-radius: 8rpx;
- background: #49b856;
- color: #fff;
- display: inline-block;
- font-size: 28rpx;
- margin-left: 16rpx;
- }
- .L_time {
- color: #6cc076;
- font-size: 32rpx;
- }
- .L_text {
- font-size: 32rpx;
- display: inline-block;
- font-weight: 700;
- }
- .L_iocn {
- display: inline-block;
- height: 52rpx;
- color: rgb(7, 134, 60);
- font-size: 28rpx;
- font-weight: 700;
- margin-left: 20rpx;
- }
- }
- .page_item_top_R {
- height: 60rpx;
- float: right;
- padding-top: 20rpx;
- font-size: 32rpx;
- position: absolute;
- right: 50rpx;
- line-height: 48rpx;
- .num {
- color: rgb(7, 134, 60);
- }
- .num1 {
- color: #ff3b53 !important;
- }
- }
- }
- .page_item_cont {
- min-height: 180rpx;
- padding: 0 16rpx;
- text-align: left;
- position: relative;
- .text_big {
- font-size: 32rpx;
- position: absolute;
- right: 16rpx;
- font-weight: 700;
- margin-top: 10rpx;
- }
- .text_big2 {
- font-size: 32rpx;
- position: absolute;
- right: 16rpx;
- font-weight: 700;
- }
- .line {
- height: 20rpx;
- width: 2rpx;
- border-left: 2rpx solid #e5e9ed;
- position: absolute;
- top: 82rpx;
- left: 40rpx;
- }
- .lines {
- height: 40%;
- width: 2rpx;
- border-left: 2rpx solid #e5e9ed;
- position: absolute;
- top: 23%;
- left: 36rpx;
- }
- .page_item_cont_T {
- padding-top: 28rpx;
- font-size: 28rpx;
- .page_item_cont_title {
- height: 100%;
- font-size: 32rpx;
- }
- }
- .page_item_cont_B {
- padding-top: 28rpx;
- margin-bottom: 28rpx;
- .page_item_cont_title {
- height: 60rpx;
- font-size: 32rpx;
- }
- .page_item_cont_title1 {
- height: 60rpx;
- line-height: 60rpx;
- font-size: 32rpx;
- padding-left: 64rpx;
- }
- }
- }
- .page_item_foot {
- border-top: 2rpx dashed #e5e9ed;
- padding: 28rpx 16rpx;
- text-align: left;
- display: flex;
- justify-content: space-between;
- align-items: center;
- .page_item_foot_text {
- height: 48rpx;
- font-size: 32rpx;
- line-height: 48rpx;
- margin-bottom: 20rpx;
- .text1 {
- color: rgb(102, 102, 102);
- &.b{
- font-weight: bolder;
- }
- }
- .text2 {
- float: right;
- font-weight: 700;
- }
- }
- }
- #infos {
- display: none;
- }
- .page_item_infos {
- padding-bottom: 20rpx;
- border-bottom: 2rpx dashed #e5e9ed;
- .page_item_info2 {
- text-align: left;
- line-height: 60rpx;
- font-size: 32rpx;
- padding-left: 16rpx;
- .page_item_foot_text {
- height: 48rpx;
- font-size: 32rpx;
- line-height: 48rpx;
- margin-bottom: 20rpx;
- .text1 {
- color: rgb(102, 102, 102);
- &.b{
- font-weight: bolder;
- }
- }
- .text2 {
- float: right;
- font-weight: 700;
- }
- }
- }
- }
- }
- }
- }
- }
- </style>
|