Commit 87937939 by lingyu0918

提交静态页面

parent 988eca60
Showing with 4242 additions and 17 deletions
File mode changed
<template>
</template>
<script>
</script>
<style>
</style>
\ No newline at end of file
<template>
<view class="head-tabs flex items-center ft30 pl32 pr32">
<view class="tabs-item" :class="active == 1 ? 'active' : ''" @click="handleTbs(1)">
病情概要
<view class="btm-slide" v-if="active == 1"></view>
</view>
<view class="tabs-item" :class="active == 2 ? 'active' : ''" @click="handleTbs(2)">
聊天室
<view class="btm-slide" v-if="active == 2"></view>
</view>
<view class="tabs-item" :class="active == 3 ? 'active' : ''" @click="handleTbs(3)">
报告查询
<view class="btm-slide" v-if="active == 3"></view>
</view>
<view class="tabs-item" :class="active == 4 ? 'active' : ''" @click="handleTbs(4)">
全息视图
<view class="btm-slide" v-if="active == 4"></view>
</view>
</view>
</template>
<script>
export default {
props:{
active:{
type:Number,
default:()=>{
return 1
}
}
},
data() {
return {};
},
methods: {
handleTbs(val) {
// this.active = val;
this.$emit('handleTabs', val);
}
}
};
</script>
<style lang="scss" scoped>
.head-tabs {
width: 100%;
height: 90rpx;
background-color: #fff;
border-bottom: 2rpx solid #F5F6F7;
.tabs-item {
position: relative;
height: 90rpx;
display: flex;
flex-direction: column;
justify-content: center;
color: #666;
margin-right: 44rpx;
.btm-slide {
position: absolute;
bottom: 2rpx;
left: 50%;
transform: translateX(-50%);
width: 40rpx;
height: 6rpx;
background: linear-gradient(270deg, #77abff 0%, #035ceb 100%);
border-radius: 4rpx;
}
}
}
.active {
color: #000000 !important;
font-weight: 700;
}
</style>
<template>
<view class="">
<!-- 滑动 -->
<view class="slide-conts flex items-start" id="slide-cont">
<!-- 左侧内容 -->
<view class="slide-left-cont">
<scroll-view scroll-y="true" class="scroll-Y " :style="{ height: height + 'px' }">
<view
class="slide-left-cont-item ft24 lht34 flex column items-center content-center"
:class="slideIdx == index ? 'slide-left-active' : ''"
v-for="(item, index) in dateTimeList"
:key="index"
@click="clickMenu(index)"
>
<view class="">{{ item.title }}</view>
</view>
</scroll-view>
</view>
<!-- 右侧内容 -->
<view class="slide-right-cont">
<scroll-view scroll-y="true" class="scroll-Y " :style="{ height: height + 'px' }">
<!-- 患者关注列表 -->
<patient-name-item v-for="i in 10"></patient-name-item>
</scroll-view>
</view>
</view>
</view>
</template>
<script>
import patientNameItem from '@/pages/components/patient-name-item.vue';
export default {
components: {
patientNameItem
},
props: {
top: {
type: Number,
default: () => {
return 0;
}
}
},
data() {
return {
height: 0,
dateTimeList: [
{
title: '默认分组'
},
{
title: '分组名称'
}
],
slideIdx: 0
};
},
created() {
this.$nextTick(() => {
if (!this.top) {
return false;
}
const query = uni.createSelectorQuery();
query
.select('#add-btn')
.boundingClientRect(data => {
uni.getSystemInfo({
success: res => {
this.height = res.windowHeight - (this.top + data.height);
}
});
})
.exec();
});
},
methods: {
clickMenu(val) {
this.slideIdx = val;
}
}
};
</script>
<style>
page {
background: #fff;
}
</style>
<style lang="scss" scoped>
.slide-conts {
width: 100%;
height: 100%;
.slide-left-cont {
width: 240rpx;
height: 100%;
.slide-left-cont-item {
position: relative;
width: 240rpx;
height: 132rpx;
background: #f5f6f7;
color: #656975;
}
}
.slide-right-cont {
padding: 0 30rpx;
width: 100%;
height: 100%;
}
}
.slide-left-active {
background: #ffffff !important;
color: #004ac2 !important;
}
</style>
<template>
<view class="patient-card flex items-start ">
<view class="patient-img"></view>
<view class="" style="flex: 1;">
<view class="pl20 flex items-center content-between">
<view class="">
<view class="patient-name flex items-center">
<text class="font500 color333 ft32 lht28">李小明</text>
<text class="info-tag color-tag ml18">开药</text>
</view>
<text class="info-tag" style="margin-top: 4rpx;">女|20岁</text>
</view>
<view class="keep">
</view>
</view>
<view class="pl20 inquiry-time ft24 pt24 lht24" style="color: #A8AAB0;">问诊时间:2022-04-24 下午17</view>
</view>
</view>
</template>
<script></script>
<style lang="scss" scoped>
.patient-card {
background-color: #fff;
padding: 32rpx 28rpx;
height: 192rpx;
border-bottom: 2rpx solid #F5F6F7;
.patient-img {
flex-shrink: 0;
width: 80rpx;
height: 80rpx;
border-radius: 50%;
background: #eee;
image {
width: 100%;
height: 100%;
}
}
.info-tag {
background: #eff4fb;
padding: 4rpx 8rpx;
border-radius: 2rpx;
color: #1c62d5;
font-size: 20rpx;
}
.keep{
width: 30rpx;
height: 30rpx;
background: #eee;
overflow: hidden;
image{
width: 100%;
height: 100%;
}
}
}
.color-tag{
background: linear-gradient(135deg, #05DDBD 0%, #32DFC2 100%) !important;
color: #fff !important;
border-radius: 4rpx !important;
}
</style>
<template>
<view class="flex items-center content-between" style="height: 96rpx;">
<view class="flex items-center">
<view class="paitent-img"></view>
<view class="paitent-name ft32 font700 color333 pl16">李小明</view>
</view>
<view class="paitent-info ft28" style="color: #656975;">女 | 20岁</view>
</view>
</template>
<script>
export default {
props: {
info: {
type: Object,
default: () => {
return {};
}
}
},
data() {
return {};
}
};
</script>
<style lang="scss" scoped>
.paitent-img {
background: #eee;
width: 60rpx;
height: 60rpx;
border-radius: 50%;
overflow: hidden;
}
.tags {
background: #eff4fb;
padding: 10rpx 14rpx;
font-size: 28rpx;
color: #1c62d5;
border-radius: 4rpx;
}
</style>
<template>
<view class="patient-list flex items-center content-between">
<view class="flex items-center ">
<view class="patient-img"></view>
<view class="patient-name pl12 ft28 lht28 color333">李小明</view>
<text class="patient-tag">女|20岁</text>
</view>
<view class="keep-icon"></view>
</view>
</template>
<script></script>
<style lang="scss" scoped>
.patient-list {
// padding: 0 28rpx;
border-bottom: 2rpx solid #F5F6F7;
height: 124rpx;
.patient-img {
width: 64rpx;
height: 64rpx;
border-radius: 50%;
overflow: hidden;
background-color: #eee;
}
.patient-name {
padding-right: 8rpx;
}
.patient-tag {
padding: 4rpx 8rpx;
background: #eff4fb;
color: #1c62d5;
font-size: 20rpx;
border-radius: 2rpx;
}
.keep-icon {
width: 32rpx;
height: 32rpx;
background-color: #eee;
}
}
</style>
<template>
<view class="drug-cont">
<view class="durg-card mb20">
<view class="flex items-center content-between">
<view class="flex items-center ">
<view class="paitent-img mr16"></view>
<view class="paitent-name pr16 ft32 font700 color333">李小明</view>
<view class="paitent-info ft24" style="color: #656975;">男 | 20岁</view>
</view>
<view class="date-time ft24" style="color: #CBCBCB;">2021-01-01 10:00:00</view>
</view>
<view class="paitent-type pt20 flex ft26 lht28">
<view class="" style="color: #656975;">
患者类型:
</view>
<view class="color333">
自费患者
</view>
</view>
<view class="paitent-describe pt14 mb30 flex ft26">
<view class="" style="color: #656975;">
病情描述:
</view>
<view class="color333">
</view>
</view>
<text class="durg-tags">
申请处方药品
</text>
<view class="pb36" style="border-bottom:2rpx solid #F5F6F7">
<view class="durg-name ft26 lht28 pt16" style="color: #656975;">
[甲]维胺酯胶囊 23mg*24粒×4盒
</view>
<view class="durg-name ft26 lht28 pt16" style="color: #656975;">
[甲]维胺酯胶囊 23mg*24粒×4盒
</view>
</view>
<view class="btm-btn flex content-end items-center">
<view class="btn-dtl ft24 colorfff flex content-center items-center">
查看详情
</view>
</view>
</view>
</view>
</template>
<script>
export default {
data() {
return {};
}
};
</script>
<style lang="scss" scoped>
.drug-cont{
padding: 20rpx 25rpx;
.durg-card {
padding: 40rpx 30rpx 0 30rpx;
background: #fff;
border-radius: 8rpx;
.paitent-img {
width: 40rpx;
height: 40rpx;
background: #eee;
border-radius: 50%;
overflow: hidden;
image {
width: 100%;
height: 100%;
}
}
.durg-tags{
background: #EFF4FB;
padding: 6rpx 8rpx;
border-radius: 8rpx;
font-size: 24rpx;
color: #1C62D5;
}
}
.btm-btn{
background: #ffffff;
height: 90rpx;
.btn-dtl{
width: 156rpx;
height: 52rpx;
background: linear-gradient(135deg, #0B57D2 0%, #77A5FF 100%);
box-shadow: 0px 4rpx 10rpx 0rpx rgba(20, 101, 232, 0.23);
border-radius: 26rpx;
}
}
}
</style>
<template>
<view class="">
</view>
</template>
<script>
</script>
<style>
</style>
\ No newline at end of file
<template>
<view class="">
<view class="head-tbs flex items-center">
<text class="tabs-item ft30 ft26 color666 mr20 " :class="active == 1 ? 'active' : ''" @click="handleTbs(1)">检查报告</text>
<text class="tabs-item ft30 ft26 color666 mr20 " :class="active == 2 ? 'active' : ''" @click="handleTbs(2)">体验报告</text>
<text class="tabs-item ft30 ft26 color666 mr20" :class="active == 3 ? 'active' : ''" @click="handleTbs(3)">体检报告</text>
</view>
</view>
</template>
<script>
export default {
props:{
active:{
type:Number,
default:()=>{
return 1
}
}
},
data() {
return {};
},
methods: {
handleTbs(val) {
this.active = val;
this.$emit('handleTags', val);
}
}
};
</script>
<style lang="scss" scoped>
.head-tbs {
padding: 0 30rpx;
background: #fff;
height: 88rpx;
border-top: 2rpx solid #f5f6f7;
.tabs-item {
padding: 6rpx 16rpx;
border-radius: 26rpx;
}
.active {
background-color: #eff4fb;
color: #004ac2;
}
}
</style>
let QRCode = {};
(function () {
/**
* 获取单个字符的utf8编码
* unicode BMP平面约65535个字符
* @param {num} code
* return {array}
*/
function unicodeFormat8(code) {
// 1 byte
var c0, c1, c2;
if (code < 128) {
return [code];
// 2 bytes
} else if (code < 2048) {
c0 = 192 + (code >> 6);
c1 = 128 + (code & 63);
return [c0, c1];
// 3 bytes
} else {
c0 = 224 + (code >> 12);
c1 = 128 + (code >> 6 & 63);
c2 = 128 + (code & 63);
return [c0, c1, c2];
}
}
/**
* 获取字符串的utf8编码字节串
* @param {string} string
* @return {array}
*/
function getUTF8Bytes(string) {
var utf8codes = [];
for (var i = 0; i < string.length; i++) {
var code = string.charCodeAt(i);
var utf8 = unicodeFormat8(code);
for (var j = 0; j < utf8.length; j++) {
utf8codes.push(utf8[j]);
}
}
return utf8codes;
}
/**
* 二维码算法实现
* @param {string} data 要编码的信息字符串
* @param {num} errorCorrectLevel 纠错等级
*/
function QRCodeAlg(data, errorCorrectLevel) {
this.typeNumber = -1; //版本
this.errorCorrectLevel = errorCorrectLevel;
this.modules = null; //二维矩阵,存放最终结果
this.moduleCount = 0; //矩阵大小
this.dataCache = null; //数据缓存
this.rsBlocks = null; //版本数据信息
this.totalDataCount = -1; //可使用的数据量
this.data = data;
this.utf8bytes = getUTF8Bytes(data);
this.make();
}
QRCodeAlg.prototype = {
constructor: QRCodeAlg,
/**
* 获取二维码矩阵大小
* @return {num} 矩阵大小
*/
getModuleCount: function () {
return this.moduleCount;
},
/**
* 编码
*/
make: function () {
this.getRightType();
this.dataCache = this.createData();
this.createQrcode();
},
/**
* 设置二位矩阵功能图形
* @param {bool} test 表示是否在寻找最好掩膜阶段
* @param {num} maskPattern 掩膜的版本
*/
makeImpl: function (maskPattern) {
this.moduleCount = this.typeNumber * 4 + 17;
this.modules = new Array(this.moduleCount);
for (var row = 0; row < this.moduleCount; row++) {
this.modules[row] = new Array(this.moduleCount);
}
this.setupPositionProbePattern(0, 0);
this.setupPositionProbePattern(this.moduleCount - 7, 0);
this.setupPositionProbePattern(0, this.moduleCount - 7);
this.setupPositionAdjustPattern();
this.setupTimingPattern();
this.setupTypeInfo(true, maskPattern);
if (this.typeNumber >= 7) {
this.setupTypeNumber(true);
}
this.mapData(this.dataCache, maskPattern);
},
/**
* 设置二维码的位置探测图形
* @param {num} row 探测图形的中心横坐标
* @param {num} col 探测图形的中心纵坐标
*/
setupPositionProbePattern: function (row, col) {
for (var r = -1; r <= 7; r++) {
if (row + r <= -1 || this.moduleCount <= row + r) continue;
for (var c = -1; c <= 7; c++) {
if (col + c <= -1 || this.moduleCount <= col + c) continue;
if ((0 <= r && r <= 6 && (c == 0 || c == 6)) || (0 <= c && c <= 6 && (r == 0 || r == 6)) || (2 <= r && r <= 4 && 2 <= c && c <= 4)) {
this.modules[row + r][col + c] = true;
} else {
this.modules[row + r][col + c] = false;
}
}
}
},
/**
* 创建二维码
* @return {[type]} [description]
*/
createQrcode: function () {
var minLostPoint = 0;
var pattern = 0;
var bestModules = null;
for (var i = 0; i < 8; i++) {
this.makeImpl(i);
var lostPoint = QRUtil.getLostPoint(this);
if (i == 0 || minLostPoint > lostPoint) {
minLostPoint = lostPoint;
pattern = i;
bestModules = this.modules;
}
}
this.modules = bestModules;
this.setupTypeInfo(false, pattern);
if (this.typeNumber >= 7) {
this.setupTypeNumber(false);
}
},
/**
* 设置定位图形
* @return {[type]} [description]
*/
setupTimingPattern: function () {
for (var r = 8; r < this.moduleCount - 8; r++) {
if (this.modules[r][6] != null) {
continue;
}
this.modules[r][6] = (r % 2 == 0);
if (this.modules[6][r] != null) {
continue;
}
this.modules[6][r] = (r % 2 == 0);
}
},
/**
* 设置矫正图形
* @return {[type]} [description]
*/
setupPositionAdjustPattern: function () {
var pos = QRUtil.getPatternPosition(this.typeNumber);
for (var i = 0; i < pos.length; i++) {
for (var j = 0; j < pos.length; j++) {
var row = pos[i];
var col = pos[j];
if (this.modules[row][col] != null) {
continue;
}
for (var r = -2; r <= 2; r++) {
for (var c = -2; c <= 2; c++) {
if (r == -2 || r == 2 || c == -2 || c == 2 || (r == 0 && c == 0)) {
this.modules[row + r][col + c] = true;
} else {
this.modules[row + r][col + c] = false;
}
}
}
}
}
},
/**
* 设置版本信息(7以上版本才有)
* @param {bool} test 是否处于判断最佳掩膜阶段
* @return {[type]} [description]
*/
setupTypeNumber: function (test) {
var bits = QRUtil.getBCHTypeNumber(this.typeNumber);
for (var i = 0; i < 18; i++) {
var mod = (!test && ((bits >> i) & 1) == 1);
this.modules[Math.floor(i / 3)][i % 3 + this.moduleCount - 8 - 3] = mod;
this.modules[i % 3 + this.moduleCount - 8 - 3][Math.floor(i / 3)] = mod;
}
},
/**
* 设置格式信息(纠错等级和掩膜版本)
* @param {bool} test
* @param {num} maskPattern 掩膜版本
* @return {}
*/
setupTypeInfo: function (test, maskPattern) {
var data = (QRErrorCorrectLevel[this.errorCorrectLevel] << 3) | maskPattern;
var bits = QRUtil.getBCHTypeInfo(data);
// vertical
for (var i = 0; i < 15; i++) {
var mod = (!test && ((bits >> i) & 1) == 1);
if (i < 6) {
this.modules[i][8] = mod;
} else if (i < 8) {
this.modules[i + 1][8] = mod;
} else {
this.modules[this.moduleCount - 15 + i][8] = mod;
}
// horizontal
var mod = (!test && ((bits >> i) & 1) == 1);
if (i < 8) {
this.modules[8][this.moduleCount - i - 1] = mod;
} else if (i < 9) {
this.modules[8][15 - i - 1 + 1] = mod;
} else {
this.modules[8][15 - i - 1] = mod;
}
}
// fixed module
this.modules[this.moduleCount - 8][8] = (!test);
},
/**
* 数据编码
* @return {[type]} [description]
*/
createData: function () {
var buffer = new QRBitBuffer();
var lengthBits = this.typeNumber > 9 ? 16 : 8;
buffer.put(4, 4); //添加模式
buffer.put(this.utf8bytes.length, lengthBits);
for (var i = 0, l = this.utf8bytes.length; i < l; i++) {
buffer.put(this.utf8bytes[i], 8);
}
if (buffer.length + 4 <= this.totalDataCount * 8) {
buffer.put(0, 4);
}
// padding
while (buffer.length % 8 != 0) {
buffer.putBit(false);
}
// padding
while (true) {
if (buffer.length >= this.totalDataCount * 8) {
break;
}
buffer.put(QRCodeAlg.PAD0, 8);
if (buffer.length >= this.totalDataCount * 8) {
break;
}
buffer.put(QRCodeAlg.PAD1, 8);
}
return this.createBytes(buffer);
},
/**
* 纠错码编码
* @param {buffer} buffer 数据编码
* @return {[type]}
*/
createBytes: function (buffer) {
var offset = 0;
var maxDcCount = 0;
var maxEcCount = 0;
var length = this.rsBlock.length / 3;
var rsBlocks = new Array();
for (var i = 0; i < length; i++) {
var count = this.rsBlock[i * 3 + 0];
var totalCount = this.rsBlock[i * 3 + 1];
var dataCount = this.rsBlock[i * 3 + 2];
for (var j = 0; j < count; j++) {
rsBlocks.push([dataCount, totalCount]);
}
}
var dcdata = new Array(rsBlocks.length);
var ecdata = new Array(rsBlocks.length);
for (var r = 0; r < rsBlocks.length; r++) {
var dcCount = rsBlocks[r][0];
var ecCount = rsBlocks[r][1] - dcCount;
maxDcCount = Math.max(maxDcCount, dcCount);
maxEcCount = Math.max(maxEcCount, ecCount);
dcdata[r] = new Array(dcCount);
for (var i = 0; i < dcdata[r].length; i++) {
dcdata[r][i] = 0xff & buffer.buffer[i + offset];
}
offset += dcCount;
var rsPoly = QRUtil.getErrorCorrectPolynomial(ecCount);
var rawPoly = new QRPolynomial(dcdata[r], rsPoly.getLength() - 1);
var modPoly = rawPoly.mod(rsPoly);
ecdata[r] = new Array(rsPoly.getLength() - 1);
for (var i = 0; i < ecdata[r].length; i++) {
var modIndex = i + modPoly.getLength() - ecdata[r].length;
ecdata[r][i] = (modIndex >= 0) ? modPoly.get(modIndex) : 0;
}
}
var data = new Array(this.totalDataCount);
var index = 0;
for (var i = 0; i < maxDcCount; i++) {
for (var r = 0; r < rsBlocks.length; r++) {
if (i < dcdata[r].length) {
data[index++] = dcdata[r][i];
}
}
}
for (var i = 0; i < maxEcCount; i++) {
for (var r = 0; r < rsBlocks.length; r++) {
if (i < ecdata[r].length) {
data[index++] = ecdata[r][i];
}
}
}
return data;
},
/**
* 布置模块,构建最终信息
* @param {} data
* @param {} maskPattern
* @return {}
*/
mapData: function (data, maskPattern) {
var inc = -1;
var row = this.moduleCount - 1;
var bitIndex = 7;
var byteIndex = 0;
for (var col = this.moduleCount - 1; col > 0; col -= 2) {
if (col == 6) col--;
while (true) {
for (var c = 0; c < 2; c++) {
if (this.modules[row][col - c] == null) {
var dark = false;
if (byteIndex < data.length) {
dark = (((data[byteIndex] >>> bitIndex) & 1) == 1);
}
var mask = QRUtil.getMask(maskPattern, row, col - c);
if (mask) {
dark = !dark;
}
this.modules[row][col - c] = dark;
bitIndex--;
if (bitIndex == -1) {
byteIndex++;
bitIndex = 7;
}
}
}
row += inc;
if (row < 0 || this.moduleCount <= row) {
row -= inc;
inc = -inc;
break;
}
}
}
}
};
/**
* 填充字段
*/
QRCodeAlg.PAD0 = 0xEC;
QRCodeAlg.PAD1 = 0x11;
//---------------------------------------------------------------------
// 纠错等级对应的编码
//---------------------------------------------------------------------
var QRErrorCorrectLevel = [1, 0, 3, 2];
//---------------------------------------------------------------------
// 掩膜版本
//---------------------------------------------------------------------
var QRMaskPattern = {
PATTERN000: 0,
PATTERN001: 1,
PATTERN010: 2,
PATTERN011: 3,
PATTERN100: 4,
PATTERN101: 5,
PATTERN110: 6,
PATTERN111: 7
};
//---------------------------------------------------------------------
// 工具类
//---------------------------------------------------------------------
var QRUtil = {
/*
每个版本矫正图形的位置
*/
PATTERN_POSITION_TABLE: [
[],
[6, 18],
[6, 22],
[6, 26],
[6, 30],
[6, 34],
[6, 22, 38],
[6, 24, 42],
[6, 26, 46],
[6, 28, 50],
[6, 30, 54],
[6, 32, 58],
[6, 34, 62],
[6, 26, 46, 66],
[6, 26, 48, 70],
[6, 26, 50, 74],
[6, 30, 54, 78],
[6, 30, 56, 82],
[6, 30, 58, 86],
[6, 34, 62, 90],
[6, 28, 50, 72, 94],
[6, 26, 50, 74, 98],
[6, 30, 54, 78, 102],
[6, 28, 54, 80, 106],
[6, 32, 58, 84, 110],
[6, 30, 58, 86, 114],
[6, 34, 62, 90, 118],
[6, 26, 50, 74, 98, 122],
[6, 30, 54, 78, 102, 126],
[6, 26, 52, 78, 104, 130],
[6, 30, 56, 82, 108, 134],
[6, 34, 60, 86, 112, 138],
[6, 30, 58, 86, 114, 142],
[6, 34, 62, 90, 118, 146],
[6, 30, 54, 78, 102, 126, 150],
[6, 24, 50, 76, 102, 128, 154],
[6, 28, 54, 80, 106, 132, 158],
[6, 32, 58, 84, 110, 136, 162],
[6, 26, 54, 82, 110, 138, 166],
[6, 30, 58, 86, 114, 142, 170]
],
G15: (1 << 10) | (1 << 8) | (1 << 5) | (1 << 4) | (1 << 2) | (1 << 1) | (1 << 0),
G18: (1 << 12) | (1 << 11) | (1 << 10) | (1 << 9) | (1 << 8) | (1 << 5) | (1 << 2) | (1 << 0),
G15_MASK: (1 << 14) | (1 << 12) | (1 << 10) | (1 << 4) | (1 << 1),
/*
BCH编码格式信息
*/
getBCHTypeInfo: function (data) {
var d = data << 10;
while (QRUtil.getBCHDigit(d) - QRUtil.getBCHDigit(QRUtil.G15) >= 0) {
d ^= (QRUtil.G15 << (QRUtil.getBCHDigit(d) - QRUtil.getBCHDigit(QRUtil.G15)));
}
return ((data << 10) | d) ^ QRUtil.G15_MASK;
},
/*
BCH编码版本信息
*/
getBCHTypeNumber: function (data) {
var d = data << 12;
while (QRUtil.getBCHDigit(d) - QRUtil.getBCHDigit(QRUtil.G18) >= 0) {
d ^= (QRUtil.G18 << (QRUtil.getBCHDigit(d) - QRUtil.getBCHDigit(QRUtil.G18)));
}
return (data << 12) | d;
},
/*
获取BCH位信息
*/
getBCHDigit: function (data) {
var digit = 0;
while (data != 0) {
digit++;
data >>>= 1;
}
return digit;
},
/*
获取版本对应的矫正图形位置
*/
getPatternPosition: function (typeNumber) {
return QRUtil.PATTERN_POSITION_TABLE[typeNumber - 1];
},
/*
掩膜算法
*/
getMask: function (maskPattern, i, j) {
switch (maskPattern) {
case QRMaskPattern.PATTERN000:
return (i + j) % 2 == 0;
case QRMaskPattern.PATTERN001:
return i % 2 == 0;
case QRMaskPattern.PATTERN010:
return j % 3 == 0;
case QRMaskPattern.PATTERN011:
return (i + j) % 3 == 0;
case QRMaskPattern.PATTERN100:
return (Math.floor(i / 2) + Math.floor(j / 3)) % 2 == 0;
case QRMaskPattern.PATTERN101:
return (i * j) % 2 + (i * j) % 3 == 0;
case QRMaskPattern.PATTERN110:
return ((i * j) % 2 + (i * j) % 3) % 2 == 0;
case QRMaskPattern.PATTERN111:
return ((i * j) % 3 + (i + j) % 2) % 2 == 0;
default:
throw new Error("bad maskPattern:" + maskPattern);
}
},
/*
获取RS的纠错多项式
*/
getErrorCorrectPolynomial: function (errorCorrectLength) {
var a = new QRPolynomial([1], 0);
for (var i = 0; i < errorCorrectLength; i++) {
a = a.multiply(new QRPolynomial([1, QRMath.gexp(i)], 0));
}
return a;
},
/*
获取评价
*/
getLostPoint: function (qrCode) {
var moduleCount = qrCode.getModuleCount(),
lostPoint = 0,
darkCount = 0;
for (var row = 0; row < moduleCount; row++) {
var sameCount = 0;
var head = qrCode.modules[row][0];
for (var col = 0; col < moduleCount; col++) {
var current = qrCode.modules[row][col];
//level 3 评价
if (col < moduleCount - 6) {
if (current && !qrCode.modules[row][col + 1] && qrCode.modules[row][col + 2] && qrCode.modules[row][col + 3] && qrCode.modules[row][col + 4] && !qrCode.modules[row][col + 5] && qrCode.modules[row][col + 6]) {
if (col < moduleCount - 10) {
if (qrCode.modules[row][col + 7] && qrCode.modules[row][col + 8] && qrCode.modules[row][col + 9] && qrCode.modules[row][col + 10]) {
lostPoint += 40;
}
} else if (col > 3) {
if (qrCode.modules[row][col - 1] && qrCode.modules[row][col - 2] && qrCode.modules[row][col - 3] && qrCode.modules[row][col - 4]) {
lostPoint += 40;
}
}
}
}
//level 2 评价
if ((row < moduleCount - 1) && (col < moduleCount - 1)) {
var count = 0;
if (current) count++;
if (qrCode.modules[row + 1][col]) count++;
if (qrCode.modules[row][col + 1]) count++;
if (qrCode.modules[row + 1][col + 1]) count++;
if (count == 0 || count == 4) {
lostPoint += 3;
}
}
//level 1 评价
if (head ^ current) {
sameCount++;
} else {
head = current;
if (sameCount >= 5) {
lostPoint += (3 + sameCount - 5);
}
sameCount = 1;
}
//level 4 评价
if (current) {
darkCount++;
}
}
}
for (var col = 0; col < moduleCount; col++) {
var sameCount = 0;
var head = qrCode.modules[0][col];
for (var row = 0; row < moduleCount; row++) {
var current = qrCode.modules[row][col];
//level 3 评价
if (row < moduleCount - 6) {
if (current && !qrCode.modules[row + 1][col] && qrCode.modules[row + 2][col] && qrCode.modules[row + 3][col] && qrCode.modules[row + 4][col] && !qrCode.modules[row + 5][col] && qrCode.modules[row + 6][col]) {
if (row < moduleCount - 10) {
if (qrCode.modules[row + 7][col] && qrCode.modules[row + 8][col] && qrCode.modules[row + 9][col] && qrCode.modules[row + 10][col]) {
lostPoint += 40;
}
} else if (row > 3) {
if (qrCode.modules[row - 1][col] && qrCode.modules[row - 2][col] && qrCode.modules[row - 3][col] && qrCode.modules[row - 4][col]) {
lostPoint += 40;
}
}
}
}
//level 1 评价
if (head ^ current) {
sameCount++;
} else {
head = current;
if (sameCount >= 5) {
lostPoint += (3 + sameCount - 5);
}
sameCount = 1;
}
}
}
// LEVEL4
var ratio = Math.abs(100 * darkCount / moduleCount / moduleCount - 50) / 5;
lostPoint += ratio * 10;
return lostPoint;
}
};
//---------------------------------------------------------------------
// QRMath使用的数学工具
//---------------------------------------------------------------------
var QRMath = {
/*
将n转化为a^m
*/
glog: function (n) {
if (n < 1) {
throw new Error("glog(" + n + ")");
}
return QRMath.LOG_TABLE[n];
},
/*
将a^m转化为n
*/
gexp: function (n) {
while (n < 0) {
n += 255;
}
while (n >= 256) {
n -= 255;
}
return QRMath.EXP_TABLE[n];
},
EXP_TABLE: new Array(256),
LOG_TABLE: new Array(256)
};
for (var i = 0; i < 8; i++) {
QRMath.EXP_TABLE[i] = 1 << i;
}
for (var i = 8; i < 256; i++) {
QRMath.EXP_TABLE[i] = QRMath.EXP_TABLE[i - 4] ^ QRMath.EXP_TABLE[i - 5] ^ QRMath.EXP_TABLE[i - 6] ^ QRMath.EXP_TABLE[i - 8];
}
for (var i = 0; i < 255; i++) {
QRMath.LOG_TABLE[QRMath.EXP_TABLE[i]] = i;
}
//---------------------------------------------------------------------
// QRPolynomial 多项式
//---------------------------------------------------------------------
/**
* 多项式类
* @param {Array} num 系数
* @param {num} shift a^shift
*/
function QRPolynomial(num, shift) {
if (num.length == undefined) {
throw new Error(num.length + "/" + shift);
}
var offset = 0;
while (offset < num.length && num[offset] == 0) {
offset++;
}
this.num = new Array(num.length - offset + shift);
for (var i = 0; i < num.length - offset; i++) {
this.num[i] = num[i + offset];
}
}
QRPolynomial.prototype = {
get: function (index) {
return this.num[index];
},
getLength: function () {
return this.num.length;
},
/**
* 多项式乘法
* @param {QRPolynomial} e 被乘多项式
* @return {[type]} [description]
*/
multiply: function (e) {
var num = new Array(this.getLength() + e.getLength() - 1);
for (var i = 0; i < this.getLength(); i++) {
for (var j = 0; j < e.getLength(); j++) {
num[i + j] ^= QRMath.gexp(QRMath.glog(this.get(i)) + QRMath.glog(e.get(j)));
}
}
return new QRPolynomial(num, 0);
},
/**
* 多项式模运算
* @param {QRPolynomial} e 模多项式
* @return {}
*/
mod: function (e) {
var tl = this.getLength(),
el = e.getLength();
if (tl - el < 0) {
return this;
}
var num = new Array(tl);
for (var i = 0; i < tl; i++) {
num[i] = this.get(i);
}
while (num.length >= el) {
var ratio = QRMath.glog(num[0]) - QRMath.glog(e.get(0));
for (var i = 0; i < e.getLength(); i++) {
num[i] ^= QRMath.gexp(QRMath.glog(e.get(i)) + ratio);
}
while (num[0] == 0) {
num.shift();
}
}
return new QRPolynomial(num, 0);
}
};
//---------------------------------------------------------------------
// RS_BLOCK_TABLE
//---------------------------------------------------------------------
/*
二维码各个版本信息[块数, 每块中的数据块数, 每块中的信息块数]
*/
var RS_BLOCK_TABLE = [
// L
// M
// Q
// H
// 1
[1, 26, 19],
[1, 26, 16],
[1, 26, 13],
[1, 26, 9],
// 2
[1, 44, 34],
[1, 44, 28],
[1, 44, 22],
[1, 44, 16],
// 3
[1, 70, 55],
[1, 70, 44],
[2, 35, 17],
[2, 35, 13],
// 4
[1, 100, 80],
[2, 50, 32],
[2, 50, 24],
[4, 25, 9],
// 5
[1, 134, 108],
[2, 67, 43],
[2, 33, 15, 2, 34, 16],
[2, 33, 11, 2, 34, 12],
// 6
[2, 86, 68],
[4, 43, 27],
[4, 43, 19],
[4, 43, 15],
// 7
[2, 98, 78],
[4, 49, 31],
[2, 32, 14, 4, 33, 15],
[4, 39, 13, 1, 40, 14],
// 8
[2, 121, 97],
[2, 60, 38, 2, 61, 39],
[4, 40, 18, 2, 41, 19],
[4, 40, 14, 2, 41, 15],
// 9
[2, 146, 116],
[3, 58, 36, 2, 59, 37],
[4, 36, 16, 4, 37, 17],
[4, 36, 12, 4, 37, 13],
// 10
[2, 86, 68, 2, 87, 69],
[4, 69, 43, 1, 70, 44],
[6, 43, 19, 2, 44, 20],
[6, 43, 15, 2, 44, 16],
// 11
[4, 101, 81],
[1, 80, 50, 4, 81, 51],
[4, 50, 22, 4, 51, 23],
[3, 36, 12, 8, 37, 13],
// 12
[2, 116, 92, 2, 117, 93],
[6, 58, 36, 2, 59, 37],
[4, 46, 20, 6, 47, 21],
[7, 42, 14, 4, 43, 15],
// 13
[4, 133, 107],
[8, 59, 37, 1, 60, 38],
[8, 44, 20, 4, 45, 21],
[12, 33, 11, 4, 34, 12],
// 14
[3, 145, 115, 1, 146, 116],
[4, 64, 40, 5, 65, 41],
[11, 36, 16, 5, 37, 17],
[11, 36, 12, 5, 37, 13],
// 15
[5, 109, 87, 1, 110, 88],
[5, 65, 41, 5, 66, 42],
[5, 54, 24, 7, 55, 25],
[11, 36, 12],
// 16
[5, 122, 98, 1, 123, 99],
[7, 73, 45, 3, 74, 46],
[15, 43, 19, 2, 44, 20],
[3, 45, 15, 13, 46, 16],
// 17
[1, 135, 107, 5, 136, 108],
[10, 74, 46, 1, 75, 47],
[1, 50, 22, 15, 51, 23],
[2, 42, 14, 17, 43, 15],
// 18
[5, 150, 120, 1, 151, 121],
[9, 69, 43, 4, 70, 44],
[17, 50, 22, 1, 51, 23],
[2, 42, 14, 19, 43, 15],
// 19
[3, 141, 113, 4, 142, 114],
[3, 70, 44, 11, 71, 45],
[17, 47, 21, 4, 48, 22],
[9, 39, 13, 16, 40, 14],
// 20
[3, 135, 107, 5, 136, 108],
[3, 67, 41, 13, 68, 42],
[15, 54, 24, 5, 55, 25],
[15, 43, 15, 10, 44, 16],
// 21
[4, 144, 116, 4, 145, 117],
[17, 68, 42],
[17, 50, 22, 6, 51, 23],
[19, 46, 16, 6, 47, 17],
// 22
[2, 139, 111, 7, 140, 112],
[17, 74, 46],
[7, 54, 24, 16, 55, 25],
[34, 37, 13],
// 23
[4, 151, 121, 5, 152, 122],
[4, 75, 47, 14, 76, 48],
[11, 54, 24, 14, 55, 25],
[16, 45, 15, 14, 46, 16],
// 24
[6, 147, 117, 4, 148, 118],
[6, 73, 45, 14, 74, 46],
[11, 54, 24, 16, 55, 25],
[30, 46, 16, 2, 47, 17],
// 25
[8, 132, 106, 4, 133, 107],
[8, 75, 47, 13, 76, 48],
[7, 54, 24, 22, 55, 25],
[22, 45, 15, 13, 46, 16],
// 26
[10, 142, 114, 2, 143, 115],
[19, 74, 46, 4, 75, 47],
[28, 50, 22, 6, 51, 23],
[33, 46, 16, 4, 47, 17],
// 27
[8, 152, 122, 4, 153, 123],
[22, 73, 45, 3, 74, 46],
[8, 53, 23, 26, 54, 24],
[12, 45, 15, 28, 46, 16],
// 28
[3, 147, 117, 10, 148, 118],
[3, 73, 45, 23, 74, 46],
[4, 54, 24, 31, 55, 25],
[11, 45, 15, 31, 46, 16],
// 29
[7, 146, 116, 7, 147, 117],
[21, 73, 45, 7, 74, 46],
[1, 53, 23, 37, 54, 24],
[19, 45, 15, 26, 46, 16],
// 30
[5, 145, 115, 10, 146, 116],
[19, 75, 47, 10, 76, 48],
[15, 54, 24, 25, 55, 25],
[23, 45, 15, 25, 46, 16],
// 31
[13, 145, 115, 3, 146, 116],
[2, 74, 46, 29, 75, 47],
[42, 54, 24, 1, 55, 25],
[23, 45, 15, 28, 46, 16],
// 32
[17, 145, 115],
[10, 74, 46, 23, 75, 47],
[10, 54, 24, 35, 55, 25],
[19, 45, 15, 35, 46, 16],
// 33
[17, 145, 115, 1, 146, 116],
[14, 74, 46, 21, 75, 47],
[29, 54, 24, 19, 55, 25],
[11, 45, 15, 46, 46, 16],
// 34
[13, 145, 115, 6, 146, 116],
[14, 74, 46, 23, 75, 47],
[44, 54, 24, 7, 55, 25],
[59, 46, 16, 1, 47, 17],
// 35
[12, 151, 121, 7, 152, 122],
[12, 75, 47, 26, 76, 48],
[39, 54, 24, 14, 55, 25],
[22, 45, 15, 41, 46, 16],
// 36
[6, 151, 121, 14, 152, 122],
[6, 75, 47, 34, 76, 48],
[46, 54, 24, 10, 55, 25],
[2, 45, 15, 64, 46, 16],
// 37
[17, 152, 122, 4, 153, 123],
[29, 74, 46, 14, 75, 47],
[49, 54, 24, 10, 55, 25],
[24, 45, 15, 46, 46, 16],
// 38
[4, 152, 122, 18, 153, 123],
[13, 74, 46, 32, 75, 47],
[48, 54, 24, 14, 55, 25],
[42, 45, 15, 32, 46, 16],
// 39
[20, 147, 117, 4, 148, 118],
[40, 75, 47, 7, 76, 48],
[43, 54, 24, 22, 55, 25],
[10, 45, 15, 67, 46, 16],
// 40
[19, 148, 118, 6, 149, 119],
[18, 75, 47, 31, 76, 48],
[34, 54, 24, 34, 55, 25],
[20, 45, 15, 61, 46, 16]
];
/**
* 根据数据获取对应版本
* @return {[type]} [description]
*/
QRCodeAlg.prototype.getRightType = function () {
for (var typeNumber = 1; typeNumber < 41; typeNumber++) {
var rsBlock = RS_BLOCK_TABLE[(typeNumber - 1) * 4 + this.errorCorrectLevel];
if (rsBlock == undefined) {
throw new Error("bad rs block @ typeNumber:" + typeNumber + "/errorCorrectLevel:" + this.errorCorrectLevel);
}
var length = rsBlock.length / 3;
var totalDataCount = 0;
for (var i = 0; i < length; i++) {
var count = rsBlock[i * 3 + 0];
var dataCount = rsBlock[i * 3 + 2];
totalDataCount += dataCount * count;
}
var lengthBytes = typeNumber > 9 ? 2 : 1;
if (this.utf8bytes.length + lengthBytes < totalDataCount || typeNumber == 40) {
this.typeNumber = typeNumber;
this.rsBlock = rsBlock;
this.totalDataCount = totalDataCount;
break;
}
}
};
//---------------------------------------------------------------------
// QRBitBuffer
//---------------------------------------------------------------------
function QRBitBuffer() {
this.buffer = new Array();
this.length = 0;
}
QRBitBuffer.prototype = {
get: function (index) {
var bufIndex = Math.floor(index / 8);
return ((this.buffer[bufIndex] >>> (7 - index % 8)) & 1);
},
put: function (num, length) {
for (var i = 0; i < length; i++) {
this.putBit(((num >>> (length - i - 1)) & 1));
}
},
putBit: function (bit) {
var bufIndex = Math.floor(this.length / 8);
if (this.buffer.length <= bufIndex) {
this.buffer.push(0);
}
if (bit) {
this.buffer[bufIndex] |= (0x80 >>> (this.length % 8));
}
this.length++;
}
};
// xzedit
let qrcodeAlgObjCache = [];
/**
* 二维码构造函数,主要用于绘制
* @param {参数列表} opt 传递参数
* @return {}
*/
QRCode = function (opt) {
//设置默认参数
this.options = {
text: '',
size: 256,
correctLevel: 3,
background: '#ffffff',
foreground: '#000000',
pdground: '#000000',
image: '',
imageSize: 30,
canvasId: opt.canvasId,
context: opt.context,
usingComponents: opt.usingComponents,
showLoading: opt.showLoading,
loadingText: opt.loadingText,
};
if (typeof opt === 'string') { // 只编码ASCII字符串
opt = {
text: opt
};
}
if (opt) {
for (var i in opt) {
this.options[i] = opt[i];
}
}
//使用QRCodeAlg创建二维码结构
var qrCodeAlg = null;
for (var i = 0, l = qrcodeAlgObjCache.length; i < l; i++) {
if (qrcodeAlgObjCache[i].text == this.options.text && qrcodeAlgObjCache[i].text.correctLevel == this.options.correctLevel) {
qrCodeAlg = qrcodeAlgObjCache[i].obj;
break;
}
}
if (i == l) {
qrCodeAlg = new QRCodeAlg(this.options.text, this.options.correctLevel);
qrcodeAlgObjCache.push({
text: this.options.text,
correctLevel: this.options.correctLevel,
obj: qrCodeAlg
});
}
/**
* 计算矩阵点的前景色
* @param {Obj} config
* @param {Number} config.row 点x坐标
* @param {Number} config.col 点y坐标
* @param {Number} config.count 矩阵大小
* @param {Number} config.options 组件的options
* @return {String}
*/
let getForeGround = function (config) {
var options = config.options;
if (options.pdground && (
(config.row > 1 && config.row < 5 && config.col > 1 && config.col < 5) ||
(config.row > (config.count - 6) && config.row < (config.count - 2) && config.col > 1 && config.col < 5) ||
(config.row > 1 && config.row < 5 && config.col > (config.count - 6) && config.col < (config.count - 2))
)) {
return options.pdground;
}
return options.foreground;
}
// 创建canvas
let createCanvas = function (options) {
if(options.showLoading){
uni.showLoading({
title: options.loadingText,
mask: true
});
}
var ctx = uni.createCanvasContext(options.canvasId, options.context);
var count = qrCodeAlg.getModuleCount();
var ratioSize = options.size;
var ratioImgSize = options.imageSize;
//计算每个点的长宽
var tileW = (ratioSize / count).toPrecision(4);
var tileH = (ratioSize / count).toPrecision(4);
//绘制
for (var row = 0; row < count; row++) {
for (var col = 0; col < count; col++) {
var w = (Math.ceil((col + 1) * tileW) - Math.floor(col * tileW));
var h = (Math.ceil((row + 1) * tileW) - Math.floor(row * tileW));
var foreground = getForeGround({
row: row,
col: col,
count: count,
options: options
});
ctx.setFillStyle(qrCodeAlg.modules[row][col] ? foreground : options.background);
ctx.fillRect(Math.round(col * tileW), Math.round(row * tileH), w, h);
}
}
if (options.image) {
var x = Number(((ratioSize - ratioImgSize) / 2).toFixed(2));
var y = Number(((ratioSize - ratioImgSize) / 2).toFixed(2));
drawRoundedRect(ctx, x, y, ratioImgSize, ratioImgSize, 2, 6, true, true)
ctx.drawImage(options.image, x, y, ratioImgSize, ratioImgSize);
// 画圆角矩形
function drawRoundedRect(ctxi, x, y, width, height, r, lineWidth, fill, stroke) {
ctxi.setLineWidth(lineWidth);
ctxi.setFillStyle(options.background);
ctxi.setStrokeStyle(options.background);
ctxi.beginPath(); // draw top and top right corner
ctxi.moveTo(x + r, y);
ctxi.arcTo(x + width, y, x + width, y + r, r); // draw right side and bottom right corner
ctxi.arcTo(x + width, y + height, x + width - r, y + height, r); // draw bottom and bottom left corner
ctxi.arcTo(x, y + height, x, y + height - r, r); // draw left and top left corner
ctxi.arcTo(x, y, x + r, y, r);
ctxi.closePath();
if (fill) {
ctxi.fill();
}
if (stroke) {
ctxi.stroke();
}
}
}
setTimeout(() => {
ctx.draw(true, () => {
// 保存到临时区域
setTimeout(() => {
uni.canvasToTempFilePath({
width: options.width,
height: options.height,
destWidth: options.width,
destHeight: options.height,
canvasId: options.canvasId,
quality: Number(1),
success: function (res) {
if (options.cbResult) {
// 由于官方还没有统一此接口的输出字段,所以先判定下 支付宝为 res.apFilePath
if (!empty(res.tempFilePath)) {
options.cbResult(res.tempFilePath)
} else if (!empty(res.apFilePath)) {
options.cbResult(res.apFilePath)
} else {
options.cbResult(res.tempFilePath)
}
}
},
fail: function (res) {
if (options.cbResult) {
options.cbResult(res)
}
},
complete: function () {
uni.hideLoading();
},
}, options.context);
}, options.text.length + 100);
});
}, options.usingComponents ? 0 : 150);
}
createCanvas(this.options);
// 空判定
let empty = function (v) {
let tp = typeof v,
rt = false;
if (tp == "number" && String(v) == "") {
rt = true
} else if (tp == "undefined") {
rt = true
} else if (tp == "object") {
if (JSON.stringify(v) == "{}" || JSON.stringify(v) == "[]" || v == null) rt = true
} else if (tp == "string") {
if (v == "" || v == "undefined" || v == "null" || v == "{}" || v == "[]") rt = true
} else if (tp == "function") {
rt = false
}
return rt
}
};
QRCode.prototype.clear = function (fn) {
var ctx = uni.createCanvasContext(this.options.canvasId, this.options.context)
ctx.clearRect(0, 0, this.options.size, this.options.size)
ctx.draw(false, () => {
if (fn) {
fn()
}
})
};
})()
export default QRCode
\ No newline at end of file
<template xlang="wxml" minapp="mpvue">
<view class="tki-qrcode">
<canvas class="tki-qrcode-canvas" :canvas-id="cid" :style="{width:cpSize+'px',height:cpSize+'px'}" />
<image v-show="show" :src="result" :style="{width:cpSize+'px',height:cpSize+'px'}" />
</view>
</template>
<script>
import QRCode from "./qrcode.js"
let qrcode
export default {
name: "tki-qrcode",
props: {
cid: {
type: String,
default: 'tki-qrcode-canvas'
},
size: {
type: Number,
default: 200
},
unit: {
type: String,
default: 'upx'
},
show: {
type: Boolean,
default: true
},
val: {
type: String,
default: ''
},
background: {
type: String,
default: '#ffffff'
},
foreground: {
type: String,
default: '#000000'
},
pdground: {
type: String,
default: '#000000'
},
icon: {
type: String,
default: ''
},
iconSize: {
type: Number,
default: 40
},
lv: {
type: Number,
default: 3
},
onval: {
type: Boolean,
default: false
},
loadMake: {
type: Boolean,
default: false
},
usingComponents: {
type: Boolean,
default: true
},
showLoading: {
type: Boolean,
default: true
},
loadingText: {
type: String,
default: '二维码生成中'
},
},
data() {
return {
result: '',
}
},
methods: {
_makeCode() {
let that = this
if (!this._empty(this.val)) {
qrcode = new QRCode({
context: that, // 上下文环境
canvasId:that.cid, // canvas-id
usingComponents: that.usingComponents, // 是否是自定义组件
showLoading: that.showLoading, // 是否显示loading
loadingText: that.loadingText, // loading文字
text: that.val, // 生成内容
size: that.cpSize, // 二维码大小
background: that.background, // 背景色
foreground: that.foreground, // 前景色
pdground: that.pdground, // 定位角点颜色
correctLevel: that.lv, // 容错级别
image: that.icon, // 二维码图标
imageSize: that.iconSize,// 二维码图标大小
cbResult: function (res) { // 生成二维码的回调
that._result(res)
},
});
} else {
uni.showToast({
title: '二维码内容不能为空',
icon: 'none',
duration: 2000
});
}
},
_clearCode() {
this._result('')
qrcode.clear()
},
_saveCode() {
let that = this;
if (this.result != "") {
uni.saveImageToPhotosAlbum({
filePath: that.result,
success: function () {
uni.showToast({
title: '二维码保存成功',
icon: 'success',
duration: 2000
});
}
});
}
},
_result(res) {
this.result = res;
this.$emit('result', res)
},
_empty(v) {
let tp = typeof v,
rt = false;
if (tp == "number" && String(v) == "") {
rt = true
} else if (tp == "undefined") {
rt = true
} else if (tp == "object") {
if (JSON.stringify(v) == "{}" || JSON.stringify(v) == "[]" || v == null) rt = true
} else if (tp == "string") {
if (v == "" || v == "undefined" || v == "null" || v == "{}" || v == "[]") rt = true
} else if (tp == "function") {
rt = false
}
return rt
}
},
watch: {
size: function (n, o) {
if (n != o && !this._empty(n)) {
this.cSize = n
if (!this._empty(this.val)) {
setTimeout(() => {
this._makeCode()
}, 100);
}
}
},
val: function (n, o) {
if (this.onval) {
if (n != o && !this._empty(n)) {
setTimeout(() => {
this._makeCode()
}, 0);
}
}
}
},
computed: {
cpSize() {
if(this.unit == "upx"){
return uni.upx2px(this.size)
}else{
return this.size
}
}
},
mounted: function () {
if (this.loadMake) {
if (!this._empty(this.val)) {
setTimeout(() => {
this._makeCode()
}, 0);
}
}
},
}
</script>
<style>
.tki-qrcode {
position: relative;
}
.tki-qrcode-canvas {
position: fixed;
top: -99999upx;
left: -99999upx;
z-index: -99999;
}
</style>
<template>
<view class="">
<!-- tabs -->
<view class=" cont flex items-center content-between">
<view class="tabs-cut flex items-center">
<text class="tabs-cut-item ft26 lht24 color666 mr10" :class="active == 1 ? 'active' : ''" @click="handleTbs(1)">门诊</text>
<text class="tabs-cut-item ft26 lht24 color666" :class="active == 2 ? 'active' : ''" @click="handleTbs(2)">网络</text>
</view>
<view class="hospital-cut flex pr24">
<view class="hospital-item ft24 lht28 flex items-center content-center" :class="hospitalType == 1 ? 'active-btn-cor' : ''" @click="handleTbsHospt(1)">
弘爱门诊
</view>
<view class="hospital-item ft24 lht28 flex items-center content-center" :class="hospitalType == 2 ? 'active-btn-cor' : ''" @click="handleTbsHospt(2)">
弘爱门诊
</view>
</view>
</view>
<!-- 滑动 -->
<view class="slide-conts flex items-start" id="slide-cont">
<!-- 左侧内容 -->
<view class="slide-left-cont">
<scroll-view scroll-y="true" class="scroll-Y " :style="{ height: height + 'px' }">
<view
class="slide-left-cont-item ft24 lht34 flex column items-center content-center"
:class="slideIdx == index ? 'slide-left-active' : ''"
v-for="(item, index) in dateTimeList"
:key="index"
@click="clickMenu(index)"
>
<view class="">{{ item.time }}</view>
<view class="">{{ item.title }}</view>
<view class="left-tags">门诊</view>
<!-- <view class="left-tags active-left-tags">
住院
</view> -->
</view>
</scroll-view>
</view>
<!-- 右侧内容 -->
<view class="slide-right-cont">
<scroll-view scroll-y="true" class="scroll-Y " :style="{ height: height + 'px' }">
<!-- 患者--门诊 -->
<template>
<view class="btm-border ">
<view class="flex items-center content-between ">
<view class="ft28 lht32" style="color: #004AC2;">2019-04-22 16:21:18</view>
<text class="tags">开药</text>
</view>
<view class="ft24 lht24 color333 pt14 ">泌尿外科 | 刘传霞</view>
</view>
<view class="btm-border flex items-center content-between">
<view class="flex items-center">
<image class="img mr12" src="../../../static/image/info4.png" mode=""></image>
<view class="ft28 lht32" style="color: #004AC2;">咨询记录</view>
</view>
<text class="tags check-tags">开药</text>
</view>
<view class="btm-border">
<view class="flex items-center">
<image class="img mr12" src="../../../static/image/info4.png" mode=""></image>
<view class="ft28 lht32" style="color: #004AC2;">患病时长</view>
</view>
<view class="ft24 lht24 color333 pt14">泌尿外科 | 刘传霞</view>
</view>
<view class="btm-border">
<view class="flex items-center">
<image class="img mr12" src="../../../static/image/info4.png" mode=""></image>
<view class="ft28 lht32" style="color: #004AC2;">病情描述</view>
</view>
<view class="ft24 lht34 color333 pt14">糖尿病时长期存在的高血糖,导致各种组织,特别是眼、的肾、心脏、血管</view>
</view>
<view class="btm-border">
<view class="flex items-center">
<image class="img mr12" src="../../../static/image/info4.png" mode=""></image>
<view class="ft28 lht32" style="color: #004AC2;">病情描述</view>
</view>
<view class="img-list pt16 flex"><view class="img-item mr16" v-for="i in 3"></view></view>
</view>
<view class="btm-border">
<view class="flex items-center">
<image class="img mr12" src="../../../static/image/info4.png" mode=""></image>
<view class="ft28 lht32" style="color: #004AC2;">咨询小结</view>
</view>
<view class="ft24 lht34 color333 pt14">糖尿病时长期存在的高血糖,导致各种组织,特别是眼、的肾、心脏、血管</view>
</view>
<view class="btm-border">
<view class="flex items-center">
<image class="img mr12" src="../../../static/image/info4.png" mode=""></image>
<view class="ft28 lht32" style="color: #004AC2;">处方</view>
</view>
<view class="">
<view class="ft24 lht34 color333 pt14">[甲]达喜铝碳酸镁片</view>
<view class="color999 lht28" style="font-size: 20rpx;">1.0004次/日</view>
</view>
<view class="">
<view class="ft24 lht34 color333 pt14">[甲]达喜铝碳酸镁片</view>
<view class="color999 lht28" style="font-size: 20rpx;">1.0004次/日</view>
</view>
</view>
</template>
<!-- 患者--住院 -->
<template>
<view class="btm-border">
<view class="flex items-center">
<image class="img mr12" src="../../../static/image/info4.png" mode=""></image>
<view class="ft28 lht32" style="color: #004AC2;">住院信息</view>
</view>
<view class="ft24 lht24 color333 pt14">泌尿外科 | 刘传霞</view>
</view>
<!-- 入园时间 -->
<view class="btm-border">
<view class="flex items-center">
<image class="img mr12" src="../../../static/image/info4.png" mode=""></image>
<view class="ft28 lht32" style="color: #004AC2;">入院日期</view>
</view>
<view class="ft24 lht24 color333 pt14">2020-01-01 10:00:00</view>
</view>
<!-- 入园时间 -->
<view class="btm-border">
<view class="flex items-center">
<image class="img mr12" src="../../../static/image/info4.png" mode=""></image>
<view class="ft28 lht32" style="color: #004AC2;">管床医师</view>
</view>
<view class="ft24 lht24 color333 pt14">李白</view>
</view>
</template>
<!-- 首页--个人主页--全息视图 -->
<template>
<!-- 医生 -->
<view class="btm-border">
<view class="flex items-center">
<image class="img mr12" src="../../../static/image/info4.png" mode=""></image>
<view class="ft28 lht32" style="color: #004AC2;">医生</view>
</view>
<view class="ft24 lht24 color333 pt14">消化内科门诊 刘传霞医生</view>
</view>
<!-- 诊断 -->
<view class="btm-border">
<view class="flex items-center">
<image class="img mr12" src="../../../static/image/info4.png" mode=""></image>
<view class="ft28 lht32" style="color: #004AC2;">诊断</view>
</view>
<view class="ft24 lht24 color333 pt14">健康查体</view>
</view>
<!-- 主诉 -->
<view class="btm-border">
<view class="flex items-center">
<image class="img mr12" src="../../../static/image/info4.png" mode=""></image>
<view class="ft28 lht32" style="color: #004AC2;">主诉</view>
</view>
<view class="ft24 lht24 color333 pt14">双眼干,伴头痛4天</view>
</view>
<!-- 查体 -->
<view class="btm-border">
<view class="flex items-center">
<image class="img mr12" src="../../../static/image/info4.png" mode=""></image>
<view class="ft28 lht32" style="color: #004AC2;">查体</view>
</view>
<view class="ft24 lht34 color333 pt14">T 36.8℃ R次/分 P次/分 BP</view>
</view>
<!-- 处方 -->
<view class="btm-border">
<view class="flex items-center">
<image class="img mr12" src="../../../static/image/info4.png" mode=""></image>
<view class="ft28 lht32" style="color: #004AC2;">处方</view>
</view>
<view class="">
<view class="ft24 lht34 color333 pt14">[甲]达喜铝碳酸镁片</view>
<view class="color999 lht28" style="font-size: 20rpx;">1.0004次/日</view>
</view>
<view class="">
<view class="ft24 lht34 color333 pt14">[甲]达喜铝碳酸镁片</view>
<view class="color999 lht28" style="font-size: 20rpx;">1.0004次/日</view>
</view>
</view>
<!-- 费用 -->
<view class="btm-border">
<view class="flex items-center">
<image class="img mr12" src="../../../static/image/info4.png" mode=""></image>
<view class="ft28 lht32" style="color: #004AC2;">费用</view>
</view>
<view class="flex items-center content-between">
<view class="ft24 lht34 color333 pt14">西药费</view>
<view class="ft24 lht34 color333 pt14" style="color: #EF2B2D;">¥100.00</view>
</view>
<view class="flex items-center content-between">
<view class="ft24 lht34 color333 pt14">西药费</view>
<view class="ft24 lht34 color333 pt14" style="color: #EF2B2D;">¥100.00</view>
</view>
<view class="flex items-center content-between">
<view class="ft24 lht34 color333 pt14">西药费</view>
<view class="ft24 lht34 color333 pt14" style="color: #EF2B2D;">¥100.00</view>
</view>
<view class="flex items-center content-between">
<view class="ft24 lht34 color333 pt14">西药费</view>
<view class="ft24 lht34 color333 pt14" style="color: #EF2B2D;">¥100.00</view>
</view>
</view>
</template>
</scroll-view>
</view>
</view>
</view>
</template>
<script>
export default {
props: {
top: {
type: Number,
default: () => {
return 0;
}
}
},
data() {
return {
slideIdx: 0, //左侧菜单默认选中第一个
active: 1,
hospitalType: 1,
height: 0,
dateTimeList: [
{
time: '2020-03-20',
title: '消化内科'
},
{
time: '2020-03-20',
title: '消化内科'
},
{
time: '2020-03-20',
title: '消化内科'
},
{
time: '2020-03-20',
title: '消化内科'
},
{
time: '2020-03-20',
title: '消化内科'
},
{
time: '2020-03-20',
title: '消化内科'
}
]
};
},
created() {
uni.getSystemInfo({
success: res => {
console.log(res);
this.height = res.windowHeight - this.top;
}
});
},
methods: {
// 切换门和网络
handleTbs(val) {
this.active = val;
},
// 切换医院
handleTbsHospt(val) {
this.hospitalType = val;
},
//点击选中左侧菜单
clickMenu(val) {
this.slideIdx = val;
}
}
};
</script>
<style>
page {
background: #fff !important;
}
</style>
<style lang="scss" scoped>
.cont {
background-color: #ffffff;
.tabs-cut {
height: 90rpx;
padding: 0 32rpx;
.tabs-cut-item {
padding: 12rpx 34rpx;
border-radius: 27rpx;
}
}
.hospital-cut {
width: 304rpx;
height: 60rpx;
.hospital-item {
width: 152rpx;
height: 60rpx;
border: 2rpx solid #004ac2;
color: #004ac2;
}
.hospital-item:first-child {
border-radius: 30rpx 0 0 30rpx;
}
.hospital-item:last-child {
border-radius: 0 30rpx 30rpx 0;
}
}
.active {
background-color: #eff4fb !important;
color: #004ac2 !important;
}
.active-btn-cor {
background: #004ac2 !important;
color: #ffffff !important;
}
}
.slide-conts {
width: 100%;
height: 100%;
.slide-left-cont {
width: 240rpx;
height: 100%;
.slide-left-cont-item {
position: relative;
width: 240rpx;
height: 132rpx;
background: #f5f6f7;
color: #656975;
.left-tags {
position: absolute;
left: 0;
top: 0;
background: #004ac2;
padding: 4rpx 8rpx;
border-bottom-right-radius: 4rpx;
color: #ffffff;
font-size: 24rpx;
transform: scale(0.7);
}
.active-left-tags {
background-color: #ef2b2d !important;
}
}
}
.slide-right-cont {
padding: 0 30rpx;
width: 100%;
height: 100%;
}
}
.tags {
background: linear-gradient(135deg, #05ddbd 0%, #32dfc2 100%);
padding: 2rpx 6rpx;
border-radius: 4rpx;
font-size: 20rpx;
color: #ffffff;
}
.btm-border {
padding: 30rpx 0;
border-bottom: 2rpx solid #f5f6f7 !important;
}
.img {
width: 32rpx;
height: 32rpx;
}
.check-tags {
border: 2rpx solid #004ac2 !important;
background: #ffffff !important;
color: #004ac2;
}
.img-list {
.img-item {
width: 120rpx;
height: 120rpx;
border-radius: 4rpx;
background: #eee;
}
}
.slide-left-active {
background: #ffffff !important;
color: #004ac2 !important;
}
</style>
<template>
<view class="">
<view class="list flex items-center content-between">
<view class="flex items-center">
<view class="list-img">
<image style="width: 100%;height: 100%;" src="../../../static/image/info1.png" mode=""></image>
</view>
<view class="pl20">
<view class="title color333 lht28 ft28 font500">
超声
</view>
<view class="ft24 color999 lht24 pt12">
妇科卵巢检测
</view>
</view>
</view>
<view class="ft24 color999">
2020-01-01 10:00:00
</view>
</view>
</view>
</template>
<script>
</script>
<style lang="scss" scoped>
.list{
background: #fff;
padding: 0 28rpx;
width: 100%;
height: 132rpx;
border-bottom: 2rpx solid #F5F6F7;
.list-img{
width: 44rpx;
height: 44rpx;
border-radius: 50%;
overflow: hidden;
image{
width: 100%;
height: 100%;
}
}
}
</style>
\ No newline at end of file
<template>
<view class="">
<report-tabs @handleTags="handleTags" :active="active"></report-tabs>
<!-- 检查报告组件 -->
<view class="pt16"><physical-list></physical-list></view>
</view>
</template>
<script>
import reportTabs from '@/pages/components/report-tabs.vue';
import physicalList from './physical-list.vue';
export default {
components: {
reportTabs,
physicalList
},
data() {
return {
active: 1,//选中的标签值
};
},
methods: {
handleTags(val) {
this.active = val;
}
}
};
</script>
<style>
page {
background-color: #f5f6f7;
}
</style>
<style lang="scss" scoped></style>
<template>
<view class="paitent-cont">
<view class="pt22">
<head-info :info="info"></head-info>
</view>
<view class="mt36"><text class="tags">病人主诉</text></view>
<view class="ft26 lht28 pt30 flex items-center">
<view class="" style="color: #656975; width: 130rpx;">身高体重:</view>
<view class="color333 pl12">123cm65kg</view>
</view>
<view class="ft26 lht28 pt26 flex items-center">
<view class="" style="color: #656975;width: 130rpx;">是否怀孕:</view>
<view class="color333 pl12"></view>
</view>
<view class="ft26 lht28 pt26 flex items-center">
<view class="" style="color: #656975;">患病时长:</view>
<view class="color333 pl12">一年以上</view>
</view>
<view class="ft26 lht28 pt26 flex items-start">
<view class="" style="color: #656975;width: 130rpx; flex-shrink: 0;">病情描述:</view>
<view class="color333 pl12">糖尿病时长期存在的高血糖,导致各种组织,特别是眼、的肾、心脏、血管、神经的慢性损害、功能障碍。</view>
</view>
<view class="ft26 lht28 pt26 flex items-center">
<view class="" style="color: #656975;width: 130rpx;">病史:</view>
<view class="color333 pl12"></view>
</view>
<view class="ft26 lht28 pt26 flex items-center">
<view class="" style="color: #656975;width: 130rpx;">过敏史:</view>
<view class="color333 pl12"></view>
</view>
<view class="ft26 lht28 pt26 flex items-center">
<view class="" style="color: #656975;width: 130rpx;">相关图片:</view>
<view class="color333 pl12"></view>
</view>
<view class="mb32" style="padding-top: 56rpx;"><text class="tags">历史处方药品</text></view>
<view class="ft26 lht28 pb40" v-for="i in 2" :key="i">
<view class="drug-title color333">[甲]维胺酯胶囊 23mg*24粒×4盒备份 2</view>
<view class="drug-explain pt16" style="color: #656975;">用法:口服,3次/日</view>
</view>
<view class="btm-btn flex content-between">
<!-- <view class="order-btn" @click="submitOrder">接单</view> -->
<view class="left-btn flex content-center items-center" @click="show = true">拒绝开方</view>
<view class="right-btn flex content-center items-center">开处方</view>
</view>
<u-popup :show="show" mode="center" @close="close" @open="open" closeable>
<view class="modal-card">
<view class="head-title font700 ft28 flex content-center pb24 pt30">请说明拒绝原因</view>
<view class="" @click="isSelect = true">
<u-input type="text" v-model="value" style="height:64rpx" disabled disabledColor="#F5F6F7">
<template slot="suffix">
<image style="width: 16rpx; height: 12rpx;" src="/static/image/arrow-down333.png" mode=""></image>
</template>
</u-input>
</view>
<view class="cont-card mt24">
<u--textarea v-model="content" style="background: #F5F6F7;" height="390rpx" border="none" maxlength="500" placeholder="请输入原因…"></u--textarea>
</view>
<view class="btm-opt flex">
<view class="cancel flex items-center content-center color666" style="flex: 1;" @click="close()">取消</view>
<view class="submit flex items-center content-center" style="color: #003893;flex:1" @click="close()">确定</view>
</view>
</view>
</u-popup>
<u-action-sheet :actions="selectList" :closeOnClickAction="true" :title="title" :show="isSelect" @close="isSelect=false" @select="select"></u-action-sheet>
</view>
</template>
<script>
import headInfo from '@/pages/components/patient-head-info.vue'
export default {
components:{
headInfo
},
data() {
return {
show: false,
title: '请说明拒绝原因',
content: '',
value: '其他',
selectList: [
{
name: '选项一'
},
{
name: '选项二禁用'
},
{
name: '开启load加载' //开启后文字不显示
}
],
isSelect: false,//拒绝下拉框状态
info:{}
};
},
methods: {
submitOrder() {
uni.showModal({
content: '是否确认订单?',
success: res => {
if (res.confirm) {
}
}
});
},
// 选中拒绝的下拉框
select(val){
this.value=val.name
this.isSelect=false
},
open() {},
close() {
this.show = false;
}
}
};
</script>
<style lang="scss" scoped>
.paitent-cont {
padding: 0 24rpx;
background-color: #fff;
.btm-btn {
position: absolute;
bottom: 0;
left: 0;
background: #fff;
width: 100%;
height: 130rpx;
box-shadow: 0px -4px 12px 0px rgba(0, 0, 0, 0.08);
padding: 32rpx 24rpx 0 24rpx;
.order-btn {
display: flex;
justify-content: center;
align-items: center;
width: 100%;
height: 84rpx;
background: linear-gradient(135deg, #0b57d2 0%, #77a5ff 100%);
border-radius: 8rpx;
color: #fff;
}
.left-btn,
.right-btn {
width: 336rpx;
height: 84rpx;
border-radius: 8px;
}
.left-btn {
background: #ffffff;
border-radius: 8rpx;
border: 2rpx solid #f1f1f1;
color: #333333;
font-size: 32rpx;
}
.right-btn {
background: linear-gradient(135deg, #0b57d2 0%, #77a5ff 100%);
border-radius: 8rpx;
font-weight: 500;
color: #ffffff;
font-size: 32rpx;
}
}
}
.modal-card {
width: 590rpx;
height: 720rpx;
background: #ffffff;
padding: 0 30rpx;
border-radius: 8rpx;
overflow: hidden;
}
.cont-card {
width: 100%;
height: 390rpx;
}
.btm-opt {
position: absolute;
background: #fff;
left: 0;
bottom: 0;
width: 100%;
height: 88rpx;
border-top: 2rpx solid #f1f1f1;
.cancel {
}
}
.tags {
background: #eff4fb;
padding: 10rpx 14rpx;
font-size: 28rpx;
color: #1c62d5;
border-radius: 4rpx;
}
</style>
<template>
<view class="">
<u-navbar title="药品查询" :placeholder="true" @leftClick="onNavbarLeftClick"></u-navbar>
<view class="head">
<text class="doctor-title">
弘爱互联网+药房
<view class="btm-slide"></view>
</text>
</view>
<!-- 搜索输入框 -->
<view class="pl24 pr24 pt20">
<view class="search-content flex">
<view class="pl20 pr20" style="line-height: 68rpx;"><img style="width: 28rpx;height: 28rpx;" src="/static/image/search.png" alt="" /></view>
<u--input :fontSize="'24rpx'" placeholder="请输入药品名称" border="none" v-model="value"></u--input>
</view>
</view>
<!-- 药品列表 -->
<drug-list></drug-list>
</view>
</template>
<script>
import drugList from './components/drug-list.vue';
export default {
components:{
drugList
},
data() {
return {
value: ''
};
}
};
</script>
<style lang="scss" scoped>
.head {
height: 90rpx;
border-bottom: 2rpx solid #f5f6f7;
.doctor-title {
position: relative;
padding: 20rpx 34rpx 28rpx 34rpx;
font-weight: 500;
line-height: 42rpx;
font-size: 30rpx;
color: #000000;
}
.btm-slide {
position: absolute;
bottom: -10rpx;
left: 50%;
transform: translateX(-50%);
width: 40rpx;
height: 6rpx;
background: linear-gradient(270deg, #77abff 0%, #035ceb 100%);
border-radius: 4rpx;
}
}
.search-content {
background: #f5f6f7;
width: 100%;
height: 68rpx;
border-radius: 6rpx;
}
</style>
<template>
<view class="">
<u-navbar title="处方" :placeholder="true" @leftClick="onNavbarLeftClick"></u-navbar>
<view class="head flex items-center">
<text class="drug-tag ft28">
RP
</text>
</view>
<view class="specification-list flex items-center">
<view class="flex column" style="flex: 1;">
<view class="durg-title color333 ft30 lht30">
维生素C片 *2瓶
</view>
<view class="ft24 lht24 color999 pt16">
用法用量:口服,立即,每次1片
</view>
</view>
<view class="state-img">
</view>
</view>
</view>
</template>
<script>
</script>
<style>
page {
background-color: #f5f6f7;
}
</style>
<style lang="scss" scoped>
.head{
background: #fff;
height: 88rpx;
padding: 0 30rpx;
.drug-tag{
background: #EFF4FB;
padding: 10rpx 30rpx;
border-radius: 4rpx;
color: #1C62D5;
font-weight: 500;
}
}
.specification-list{
padding: 36rpx 28rpx;
border-top: 2rpx solid #F5F6F7;
background: #fff;
.state-img{
flex-shrink: 0;
width: 120rpx;
height: 66rpx;
background: #eee;
overflow: hidden;
}
}
</style>
\ No newline at end of file
<template>
<view class="">
<u-navbar title="急速配药" :placeholder="true" @leftClick="onNavbarLeftClick"></u-navbar>
<view class=""><rapid-drug-list></rapid-drug-list></view>
</view>
</template>
<script>
import rapidDrugList from '@/pages/components/rapid-drug-list.vue';
export default {
components: {
rapidDrugList
},
data() {
return {};
}
};
</script>
<style>
page {
background-color: #f5f6f7;
}
</style>
<style lang="scss" scoped>
</style>
<template>
<view class="">
<u-navbar title="急速配药" :placeholder="true" @leftClick="onNavbarLeftClick"></u-navbar>
<consult-tabs @handleTabs="handleTabs" :active="active"></consult-tabs>
<!-- 病情概要 -->
<template v-if="active == 1">
<state-otline></state-otline>
</template>
<!-- 报告查询 -->
<template v-if="active == 3">
<report-search></report-search>
</template>
<!-- 全息视图 -->
<template v-if="active == 4">
<view class="" id="slide-cont"><holographic-view :top="top"></holographic-view></view>
</template>
</view>
</template>
<script>
import consultTabs from '@/pages/components/consult-tabs.vue';
import stateOtline from './components/state-otline.vue'; //病情概要
import reportSearch from './components/report-search.vue'; //病情概要
import holographicView from './components/holographic-view.vue'; //病情概要
export default {
components: {
consultTabs,
stateOtline,
reportSearch,
holographicView
},
data() {
return {
active: 4,
top: 0
};
},
onLoad() {
if (this.active == 4) {
this.$nextTick(() => {
wx.createSelectorQuery()
.select('#slide-cont')
.boundingClientRect(res => {
this.top = res.top;
})
.exec();
});
}
},
methods:{
handleTabs(val){
this.active=val;
}
}
};
</script>
<style>
page {
background-color: #f5f6f7;
}
</style>
<style lang="scss" scoped>
</style>
...@@ -143,8 +143,9 @@ export default { ...@@ -143,8 +143,9 @@ export default {
openId: this.openId, openId: this.openId,
unionId: this.unionId unionId: this.unionId
}); });
console.log(request)
if (request.code == 0) { if (request.code == 0) {
status = 0; this.switchTab(request)
} }
} else { } else {
const request = await loginByMobile({ const request = await loginByMobile({
...@@ -155,24 +156,9 @@ export default { ...@@ -155,24 +156,9 @@ export default {
unionId: this.unionId unionId: this.unionId
}); });
if (request.code == 0) { if (request.code == 0) {
status = 0; this.switchTab(request)
} }
} }
if (status == 0) {
uni.setStorageSync('accessToken', request.data.accessToken);
uni.setStorageSync('refreshToken', request.data.refreshToken);
uni.setStorageSync('userInfo', request.data.doctorAdmin);
uni.showToast({
title: '登录成功',
mask: true,
duration: 1500
});
setTimeout(() => {
uni.switchTab({
url: '/pages/tabbar/doctor-home'
});
}, 800);
}
}) })
.catch(errors => { .catch(errors => {
// uni.$u.toast('校验失败'); // uni.$u.toast('校验失败');
...@@ -222,6 +208,21 @@ export default { ...@@ -222,6 +208,21 @@ export default {
uni.$u.toast('倒计时结束后再发送'); uni.$u.toast('倒计时结束后再发送');
} }
}, },
switchTab(request){
uni.setStorageSync('accessToken', request.data.accessToken);
uni.setStorageSync('refreshToken', request.data.refreshToken);
uni.setStorageSync('userInfo', request.data.doctorAdmin);
uni.showToast({
title: '登录成功',
mask: true,
duration: 1500
});
setTimeout(() => {
uni.switchTab({
url: '/pages/tabbar/doctor-home'
});
}, 800);
},
end() { end() {
uni.$u.toast('倒计时结束'); uni.$u.toast('倒计时结束');
}, },
......
<template>
<view class="">
<u-navbar :title="title" :placeholder="true" @leftClick="onNavbarLeftClick"></u-navbar>
<view class="cont">
<!-- -->
<view class="card mb18">
<report-head-title :title="'就诊人信息'" :icon="iconList[0]"></report-head-title>
<view class="patient-info">
<view class="flex items-center pb28">
<view class="label-color ft28 lht28 pr24">姓名:</view>
<view class="value-color ft28 lht28">李小明</view>
</view>
<view class="flex items-center pb28">
<view class="label-color ft28 lht28 pr24">性别:</view>
<view class="value-color ft28 lht28"></view>
</view>
<view class="flex items-center pb28">
<view class="label-color ft28 lht28 pr24">年龄:</view>
<view class="value-color ft28 lht28">20岁</view>
</view>
<view class="flex items-center pb28">
<view class="label-color ft28 lht28 pr24">卡号:</view>
<view class="value-color ft28 lht28">DF1234</view>
</view>
</view>
</view>
<!-- 检验信息 -->
<view class="card">
<report-head-title :title="'检验信息'" :icon="iconList[1]"></report-head-title>
<view class="patient-info">
<view class="flex items-center pb28">
<view class="label-color ft28 lht28 pr24">医院名称:</view>
<view class="value-color ft28 lht28">厦门弘爱医院</view>
</view>
<view class="flex items-center pb28">
<view class="label-color ft28 lht28 pr24">申请科室:</view>
<view class="value-color ft28 lht28">妇科门诊</view>
</view>
<view class="flex items-center pb28">
<view class="label-color ft28 lht28 pr24">检查日期:</view>
<view class="value-color ft28 lht28">2021-08-11岁</view>
</view>
<view class="flex items-center pb28">
<view class="label-color ft28 lht28 pr24">检查类型:</view>
<view class="value-color ft28 lht28">分子</view>
</view>
<view class="flex items-center pb28">
<view class="label-color ft28 lht28 pr24">检验医生:</view>
<view class="value-color ft28 lht28">李白</view>
</view>
<view class="flex items-center pb28">
<view class="label-color ft28 lht28 pr24">审核医生:</view>
<view class="value-color ft28 lht28">李白</view>
</view>
<view class="flex items-center pb28">
<view class="label-color ft28 lht28 pr24">审核时间:</view>
<view class="value-color ft28 lht28">2021-08-11</view>
</view>
</view>
</view>
<!-- 检验结果 -->
<view class="card">
<report-head-title :title="'检验信息'" :icon="iconList[2]"></report-head-title>
<view class="tabs flex">
<view class="tabs-item color333 font500 flex content-center items-center">检验项目</view>
<view class="tabs-item color333 font500 flex content-center items-center">结果</view>
<view class="tabs-item color333 font500 flex content-center items-center">参考值/单位</view>
</view>
<view class="result-list">
<view class="pl20 pt22 pr20 pb40 flex items-center content-between" v-for="i in 3" :key="i">
<view class="result-list-item flex content-center ft24 lht34">新型冠状病毒核酸(2019-</view>
<view class="result-list-item ft24 flex content-center lht34">阴性</view>
<view class="result-list-item ft24 flex content-center lht34">阴性</view>
</view>
</view>
</view>
<view class=""><button class="btn-all-report">查看报告</button></view>
<view class="btm-tips color999 ft24 lht34 flex content-center">
注:报告仅供参考, :表示偏高, :表示
</view>
</view>
</view>
</template>
<script>
import reportHeadTitle from '@/pages/patient/components/report-head-title.vue';
export default {
components: {
reportHeadTitle
},
data() {
return {
title: '李小明的彩超报告',
iconList: ['/static/image/icon2.png', '/static/image/icon3.png', '/static/image/icon4.png']
};
}
};
</script>
<style>
page {
background-color: #f5f6f7;
}
</style>
<style lang="scss" scoped>
.cont {
padding: 20rpx 26rpx;
.head-info {
background: #fff;
height: 96rpx;
padding: 0 20rpx;
border-bottom: 2rpx solid #f5f6f7;
border-radius: 8rpx 8rpx 0 0;
}
.patient-info {
background: #fff;
padding: 26rpx 28rpx 40rpx 28rpx;
border-radius: 0 0 8rpx 8rpx;
}
.tabs {
height: 80rpx;
border-bottom: 2rpx solid #f5f6f7;
.tabs-item {
flex: 1;
}
}
.result-list {
.result-list-item {
width: 194rpx;
height: 100%;
color: #656975;
}
}
.btn-all-report {
background: linear-gradient(135deg, #0b57d2 0%, #77a5ff 100%);
width: 702rpx;
height: 84rpx;
margin-top: 40rpx;
border-radius: 8rpx;
font-weight: 500;
color: #ffffff;
font-size: 32rpx;
}
.btm-tips{
padding-top: 60rpx;
}
}
.label-color {
color: #656975;
}
.value-color {
color: #333333;
}
</style>
<template>
<view class="">
<!-- 头部用户信息 -->
<view class="bgfff pl24 pr24"><head-info :info="info"></head-info></view>
<view class="">
<view class="paitent-cont ml26 mr26 mt20">
<view class=" head ft32 color333 font500 pl28 flex items-center">病人主诉</view>
<view class="ft26 lht28 pt30 flex items-center">
<view class="" style="color: #656975; width: 130rpx;">身高体重:</view>
<view class="color333 pl12">123cm65kg</view>
</view>
<view class="ft26 lht28 pt26 flex items-center">
<view class="" style="color: #656975;width: 130rpx;">是否怀孕:</view>
<view class="color333 pl12"></view>
</view>
<view class="ft26 lht28 pt26 flex items-center">
<view class="" style="color: #656975;">患病时长:</view>
<view class="color333 pl12">一年以上</view>
</view>
<view class="ft26 lht28 pt26 flex items-start">
<view class="" style="color: #656975;width: 130rpx; flex-shrink: 0;">病情描述:</view>
<view class="color333 pl12">糖尿病时长期存在的高血糖,导致各种组织,特别是眼、的肾、心脏、血管、神经的慢性损害、功能障碍。</view>
</view>
<view class="ft26 lht28 pt26 flex items-center">
<view class="" style="color: #656975;width: 130rpx;">病史:</view>
<view class="color333 pl12"></view>
</view>
<view class="ft26 lht28 pt26 flex items-center">
<view class="" style="color: #656975;width: 130rpx;">过敏史:</view>
<view class="color333 pl12"></view>
</view>
<view class="ft26 lht28 pt26 flex items-center">
<view class="" style="color: #656975;width: 130rpx;">相关图片:</view>
<view class="img-list color333 pl12 flex"><view class="img-item mr16" v-for="i in 2"></view></view>
</view>
<view class="mb32" style="padding-top: 48rpx;"><text class="tags">历史处方药品</text></view>
<view class="ft26 lht28 pb40" v-for="i in 2" :key="i">
<view class="drug-title color333">[甲]维胺酯胶囊 23mg*24粒×4盒备份 2</view>
<view class="drug-explain pt16" style="color: #656975;">用法:口服,3次/日</view>
</view>
</view>
<view class="paitent-cont ml26 mr26 mt20">
<view class=" head ft32 color333 font500 pl28 flex items-center">订单详情</view>
<view class="ft26 lht28 pt26 flex items-center">
<view class="" style="color: #656975;width: 130rpx;">业务类型:</view>
<view class="color333 pl12">图文</view>
</view>
<view class="ft26 lht28 pt26 flex items-center">
<view class="" style="color: #656975;width: 130rpx;">患者类型:</view>
<view class="color333 pl12">自费</view>
</view>
<view class="ft26 lht28 pt26 flex items-center">
<view class="" style="color: #656975;width: 130rpx;">订单号码:</view>
<view class="color333 pl12">6271467932614762916</view>
</view>
<view class="ft26 lht28 pt26 flex items-center">
<view class="" style="color: #656975;width: 130rpx;">下单时间:</view>
<view class="color333 pl12">2021-01-01 10:00:00</view>
</view>
<view class="ft26 lht28 pt26 pb40 flex items-center">
<view class="" style="color: #656975;width: 130rpx;">支付费用:</view>
<view class="color333 pl12" style="color: #EF2B2D;">¥1.00</view>
</view>
</view>
<view class="mt48">
<view class="btm-tips flex items-center content-center">本次问诊未开始,需接诊之后开始计时</view>
<view class="btm-btn flex content-between ">
<view class="left-btn flex content-center items-center" @click="selectShow = true">退诊并退款</view>
<view class="right-btn flex content-center items-center">接诊</view>
</view>
</view>
</view>
<!-- 选择退诊理由 -->
<u-popup :show="selectShow" round="12" mode="bottom" @close="selectclose" @open="selectOpen" closeable>
<view class="select-title ft32 font500 pl24 flex items-center">请填写或选择取消理由</view>
<view class="select-cont pl24 pr24">
<view class="select-item ft28 flex items-center" v-for="(item, index) in selectList" :key="index" @click="handleSelect(item)">
<image class="mr10" style="width: 30rpx; height: 32rpx;" :src="item.image" mode="" v-if="item.image"></image>
{{ item.title }}
</view>
</view>
</u-popup>
<!-- 退诊 -->
<u-popup :show="show" mode="center" @close="close" @open="open" closeable>
<view class="modal-card" style="height: 672rpx;">
<view class="head-title font700 ft28 flex content-center pb24 pt44">请说明拒绝原因</view>
<view class="cont-card mt24"><u--textarea v-model="content" placeholderClass="placeholderClass" height="390rpx" border="none" maxlength="50" placeholder="请输入原因…"></u--textarea></view>
<view class="radio-reason flex items-center pt20">
<image style="width: 28rpx; height: 28rpx;" src="/static/image/radio1.png" mode="" v-if="reasonSte" @click="reasonSte = false"></image>
<image style="width: 28rpx; height: 28rpx;" src="/static/image/radio2.png" mode="" v-else @click="reasonSte = true"></image>
<view class="pl8 ft24 lht24 color333 ft32" style="color: #004AC2;">保存为退诊理由</view>
</view>
<view class="btm-opt flex">
<view class="cancel flex items-center content-center color666" style="flex: 1;" @click="close()">取消</view>
<view class="submit flex items-center content-center" style="color: #003893;flex:1" @click="close()">确定</view>
</view>
</view>
</u-popup>
</view>
</template>
<script>
import headInfo from '@/pages/components/patient-head-info.vue';
export default {
components: {
headInfo
},
data() {
return {
selectShow: true,
show: false,
title: '请说明拒绝原因',
content: '',
value: '其他',
reasonSte: true, //保存为确诊理由状态
selectList: [
{
name: '选项一'
},
{
name: '选项二禁用'
},
{
name: '开启load加载' //开启后文字不显示
}
],
isSelect: false, //拒绝下拉框状态
info: {},
selectList: [
{
title: '手动填写拒绝理由',
image: '/static/image/edit.png'
},
{
title: '不属于我的诊疗范围',
image: ''
},
{
title: '很抱歉,暂无时间处理',
image: ''
},
{
title: '没空没空没空没空',
image: ''
}
]
};
},
methods: {
submitOrder() {
uni.showModal({
content: '是否确认订单?',
success: res => {
if (res.confirm) {
}
}
});
},
// 选中拒绝的下拉框
select(val) {
this.value = val.name;
this.isSelect = false;
},
// 选择拒绝的理由项
handleSelect(val){
this.selectclose();
if(val.image){
this.open()
}
},
open() {
this.show = true;
},
close() {
this.show = false;
},
selectOpen() {},
selectclose() {
this.selectShow = false;
}
}
};
</script>
<style>
page {
background-color: #f5f6f7;
}
</style>
<style lang="scss" scoped>
.placeholderClass{
background: #eee;
}
.paitent-cont {
padding: 0 24rpx;
background-color: #fff;
.head {
height: 96rpx;
border-bottom: 2rpx solid #f5f6f7;
}
.img-item {
width: 120rpx;
height: 120rpx;
border-radius: 4rpx;
overflow: hidden;
background: #eee;
image {
width: 100%;
height: 100%;
}
}
}
.modal-card {
width: 590rpx;
height: 720rpx;
// background: #ffffff;
padding: 0 30rpx;
border-radius: 8rpx;
overflow: hidden;
}
.btm-opt {
position: absolute;
background: #fff;
left: 0;
bottom: 0;
width: 100%;
height: 88rpx;
border-top: 2rpx solid #f1f1f1;
.cancel {
}
}
.tags {
background: #eff4fb;
padding: 10rpx 14rpx;
font-size: 28rpx;
color: #1c62d5;
border-radius: 4rpx;
}
.btm-tips {
background: #e5ecf8;
height: 56rpx;
color: #004ac2;
font-size: 24rpx;
}
.btm-btn {
// position: absolute;
// bottom: 0;
// left: 0;
background: #fff;
width: 100%;
height: 130rpx;
box-shadow: 0px -4px 12px 0px rgba(0, 0, 0, 0.08);
padding: 32rpx 24rpx 0 24rpx;
.order-btn {
display: flex;
justify-content: center;
align-items: center;
width: 100%;
height: 84rpx;
background: linear-gradient(135deg, #0b57d2 0%, #77a5ff 100%);
border-radius: 8rpx;
color: #fff;
}
.left-btn,
.right-btn {
width: 336rpx;
height: 84rpx;
border-radius: 8px;
}
.left-btn {
background: #ffffff;
border-radius: 8rpx;
border: 2rpx solid #f1f1f1;
color: #333333;
font-size: 32rpx;
}
.right-btn {
background: linear-gradient(135deg, #0b57d2 0%, #77a5ff 100%);
border-radius: 8rpx;
font-weight: 500;
color: #ffffff;
font-size: 32rpx;
}
}
.select-title {
height: 96rpx;
border-bottom: 2rpx solid #f5f6f7;
}
.select-cont {
.select-item {
height: 88rpx;
color: #4e4f50;
border-bottom: 2rpx solid #f5f6f7;
}
}
</style>
<template>
<view class="">
<view class="head-info flex items-center flex content-between">
<view class="flex">
<image style="width: 44rpx; height: 44rpx;" :src="icon" mode=""></image>
<view class="head-title color333 ft32 font500 pl16">
{{title}}
</view>
</view>
<view class="arrow-right">
<image style="width: 26rpx;height: 14rpx;" src="/static/image/arrow-down.png" mode=""></image>
</view>
</view>
</view>
</template>
<script>
export default{
props:{
title:{
type:String,
default:()=>{
return ''
}
},
icon:{
type:String,
default:()=>{
return ''
}
}
},
data(){
return{
}
}
}
</script>
<style lang="scss" scoped>
.head-info{
background: #fff;
height: 96rpx;
padding: 0 20rpx;
border-bottom: 2rpx solid #F5F6F7;
border-radius: 8rpx 8rpx 0 0;
}
.patient-info{
background: #fff;
padding: 26rpx 28rpx 40rpx 28rpx;
}
</style>
\ No newline at end of file
<template>
<view class="report-list flex items-center content-between">
<view class="flex items-center">
<image class="report-img" src="/static/image/info3.png" mode=""></image>
<view class="report-title color333 ft28 font500 pl12">
B超
</view>
</view>
<view class="create-time ft26 color999">
2020-01-01 10:00:00
</view>
</view>
</template>
<script>
</script>
<style lang="scss" scoped>
.report-list{
background: #fff;
padding: 0 30rpx;
height: 96rpx;
border-bottom: 2rpx solid #F5F6F7;
.report-img{
width: 44rpx;
height: 44rpx;
}
}
</style>
\ No newline at end of file
<template>
<view class="">
<u-navbar title="咨询记录" :placeholder="true" leftIconColor="#fff"></u-navbar>
<view class="patient-list mt16">
<view class="patient-item flex items-center content-between" v-for="i in 3">
<view class="flex items-center">
<view class="patient-img"></view>
<view class="pl20">
<view class="flex">
<view class="patient-name color333 font500 ft32 lht28">李小明</view>
<text class="patient-tag ml12">女|20岁</text>
</view>
<view class="date-time ft24 pt16 lht24">2022-04-24 17:48:00</view>
</view>
</view>
<view class="flex column">
<text class="tags ky ">开药</text>
<text class="tags dpj mt16">待评价</text>
</view>
</view>
</view>
</view>
</template>
<script>
</script>
<style>
page {
background-color: #f5f6f7;
}
</style>
<style lang="scss" scoped>
.patient-list {
background: #fff;
.patient-item {
padding: 0 28rpx;
height: 148rpx;
border-bottom: 2rpx solid #F5F6F7;
.patient-img {
width: 80rpx;
height: 80rpx;
border-radius: 50%;
background: #eee;
}
.patient-tag {
background: #eff4fb;
font-size: 20rpx;
padding: 4rpx 8rpx;
color: #1c62d5;
border-radius: 2rpx;
}
.date-time{
color: #A8AAB0;
}
.tags{
padding: 2rpx 6rpx;
border-radius: 4rpx;
font-size: 20rpx
}
}
}
.ky{
background: linear-gradient(135deg, #05DDBD 0%, #32DFC2 100%);
color: #fff;
}
.dpj{
border: 2rpx solid #004AC2;
color: #004AC2;
}
</style>
<template>
<view class="">
<view class="">
</view>
</view>
</template>
<script>
export default{
data(){
return{
}
},
methods:{
}
}
</script>
<style>
</style>
\ No newline at end of file
<template>
<view class="">
<u-navbar title="分组管理" :placeholder="true" leftIconColor="#fff"></u-navbar>
<view class="head-cont"><view class="add-btn flex items-center content-center" @click="open">+添加分组</view></view>
<view class="cont-list mt20">
<view class="cont-list-item pl24 flex items-center color333 ft30">默认关注</view>
<view class="cont-list-item pl24 flex items-center color333 ft30" style="border:0;">分组名称名称</view>
</view>
<!-- 新增弹框 -->
<u-popup :show="addShow" :closeOnClickOverlay="true" closeable :round="8" mode="center" @close="close" @open="open">
<view class="modal">
<view class=" flex content-center"><view class="moddal-title color333 ft28 lht44 font500 pt44 pb24">添加分组</view></view>
<u--input type="text" value="" border="none" :customStyle="{background:'#F5F6F7','height':'88rpx','padding':'0 20rpx'}" fontSize="28rpx" :placeholderStyle="{'color':'#999'}" placeholder="请输入分组名称" />
<view class="btm-btn flex mt32">
<view class="cancel flex content-center items-center" @click="close">
取消
</view>
<view class="submit flex content-center items-center" @click="handleAdd">
确定
</view>
</view>
</view>
</u-popup>
</view>
</template>
<script>
export default {
data() {
return {
addShow: false
};
},
methods: {
handleAdd(){
this.close();
},
open() {
this.addShow=true;
},
close() {
this.addShow = false;
// console.log('close');
}
}
};
</script>
<style>
page {
background-color: #f5f6f7;
}
</style>
<style lang="scss" scoped>
.head-cont {
background: #fff;
padding: 20rpx 24rpx;
.add-btn {
background: linear-gradient(135deg, #0b57d2 0%, #77a5ff 100%);
width: 702rpx;
height: 84rpx;
padding: 0 24rpx;
border-radius: 8rpx;
font-size: 32rpx;
font-weight: 500;
color: #fff;
}
}
.cont-list {
background: #fff;
.cont-list-item {
height: 96rpx;
border-bottom: 2rpx solid #f5f6f7;
}
}
.modal {
width: 590rpx;
height: 322rpx;
padding: 0 24rpx;
.btm-btn{
display: flex;
height: 88rpx;
border-top: 2rpx solid #F1F1F1;
}
.cancel{
flex: 1;
}
.submit{
flex: 1;
color: #003893;
}
}
/deep/.u-safe-bottom{
display: none;
}
</style>
<template>
<view class="">
<u-navbar title="患者基本信息" :placeholder="true" @leftClick="onNavbarLeftClick"></u-navbar>
<view class="pl24 pr24">
<view class="info-list flex items-center">
<view class="info-title">姓名</view>
<view class="info-name">李小明</view>
</view>
<view class="info-list flex items-center">
<view class="info-title">性别</view>
<view class="info-name"></view>
</view>
<view class="info-list flex items-center">
<view class="info-title">年龄</view>
<view class="info-name">20岁</view>
</view>
</view>
<view class="slide"></view>
<view class="pl24 pr24">
<view class="info-list flex items-center">
<view class="info-title">身份证号</view>
<view class="info-name">34567787896789</view>
</view>
<view class="info-list flex items-center">
<view class="info-title">就诊卡类型</view>
<view class="info-name">34567787896789</view>
</view>
<view class="info-list flex items-center">
<view class="info-title">就诊卡号</view>
<view class="info-name">193929_DF4944606</view>
</view>
</view>
<view class="btm-btn">
<view class="submit-btn flex content-center items-center">
确定开方
</view>
</view>
</view>
</template>
<script>
export default {
data() {
return {};
}
};
</script>
<style></style>
<style lang="scss" scoped>
.info-list {
background: #fff;
padding: 36rpx 0 32rpx 0;
font-size: 28rpx;
line-height: 32rpx;
border-bottom: 2rpx solid #f6f6f6;
.info-title {
width: 192rpx;
color: #666666;
}
.info.name {
color: #666666;
}
}
.slide {
background: #f5f6f7;
width: 100%;
height: 16rpx;
}
.btm-btn{
position: absolute;
bottom: 0;
left: 0;
background: #fff;
width: 100%;
height: 132rpx;
padding: 32rpx 24rpx 0 24rpx;
box-shadow: 0rpx -4rpx 12rpx 0rpx rgba(0, 0, 0, 0.08);
.submit-btn{
background: linear-gradient(135deg, #0B57D2 0%, #77A5FF 100%);
width: 702rpx;
height: 84rpx;
border-radius: 8rpx;
font-size: 32rpx;
font-weight: 500;
color: #FFFFFF;
}
}
</style>
<template>
<view class="">
<u-navbar :title="title" :placeholder="true" @leftClick="onNavbarLeftClick"></u-navbar>
<!-- 头部tab项 -->
<view class=""><consult-tbs :active="active" @handleTabs="handleTabs"></consult-tbs></view>
<!-- 病情概要 -->
<view class=" " v-if="active==1">
<outline></outline>
</view>
</view>
</template>
<script>
import consultTbs from '@/pages/components/consult-tabs.vue'; //头部tab项
import outline from '../patient/components/outline.vue';
export default {
components: {
consultTbs,
outline
},
data() {
return {
title: '李小名',
active: 1
};
},
methods: {
handleTabs(val) {
this.active = val;
}
}
};
</script>
<style></style>
<template>
<view class="cont">
<view class="head-cont">
<u-navbar :placeholder="true" leftIconColor="#fff" bgColor="rgba(0,0,0,0.0)"></u-navbar>
<view class="patient-info flex content-between ">
<view class="flex items-center content-between" style="height: 92rpx;width: 100%;">
<view class="flex pt20">
<view class="patient-img"></view>
<view class=" flex column content-start pl24">
<view class="flex items-start pb18">
<view class="patient-name colorfff font700 ft36 lht36">李白</view>
<text class="patient-idcard">女|20岁</text>
</view>
<view class=" pt8 ft24 colorfff lht24" style="opacity: 0.8;">身份证号:3502***6063</view>
</view>
</view>
<view class="keep ft24 mt6 flex content-center items-center" v-if="keepSte">
<text class="pr6 font500">已关注</text>
<u-icon size="12" color="#004AC2" name="checkmark"></u-icon>
</view>
<view class="keep ft24 flex content-center items-center" v-else><text class="pr6 font500">未关注</text></view>
</view>
</view>
</view>
<view class="info-card">
<view class="patient-card">
<view class="menu-card flex items-center">
<view class="menu-item flex column items-center content-center" style="flex: 1;">
<view class="menu-icon"><image src="/static/image/menu2.png" mode=""></image></view>
<view class="menu-title ft24 color333 lht34 pt4">俱乐部</view>
</view>
<view class="menu-item flex column items-center content-center" style="flex: 1;">
<view class="menu-icon"><image src="/static/image/menu1.png" mode=""></image></view>
<view class="menu-title ft24 color333 lht34 pt4">报告查询</view>
</view>
<view class="menu-item flex column items-center content-center" style="flex: 1;">
<view class="menu-icon"><image src="/static/image/menu3.png" mode=""></image></view>
<view class="menu-title ft24 color333 lht34 pt4">咨询记录</view>
</view>
</view>
</view>
<!-- -->
<view class="card-list">
<view class="card-list-item flex items-center content-between">
<view class="flex items-center">
<image style="width: 44rpx;height: 44rpx;" src="/static/image/info4.png" mode=""></image>
<view class="ft30 color333 pl12">发消息</view>
</view>
<image style="width: 12rpx; height: 20rpx;" src="/static/image/patient-info1.png" mode=""></image>
</view>
<view class="card-list-item flex items-center content-between">
<view class="flex items-center">
<image style="width: 44rpx;height: 44rpx;" src="/static/image/patient-info2.png" mode=""></image>
<view class="ft30 color333 pl12">关注</view>
</view>
<u-switch v-model="keepSte" @change="change" activeColor="#004AC2"></u-switch>
</view>
<view class="card-list-item flex items-center content-between">
<view class="flex items-center">
<image style="width: 44rpx;height: 44rpx;" src="/static/image/patient-info3.png" mode=""></image>
<view class="ft30 color333 pl12">分组</view>
</view>
<view class="color999 ft28">
<text class="pr20">未分组</text>
<image style="width: 12rpx; height: 20rpx;" src="/static/image/arrow-right.png" mode=""></image>
</view>
</view>
</view>
</view>
</view>
</template>
<script>
export default {
data() {
return {
navHeight: this.navHeight, //导航栏高度
navTop: this.navTop, //胶囊距离顶部的高度
keepSte: true
};
},
methods: {
change() {}
}
};
</script>
<style>
page {
background-color: #f5f6f7;
}
</style>
<style lang="scss" scoped>
.head-cont {
width: 100%;
background-image: url('');
background-repeat: no-repeat;
background-size: 100%;
padding: 0 24rpx;
.patient-info {
height: 240rpx;
.patient-img {
width: 92rpx;
height: 92rpx;
background: #eee;
border-radius: 50%;
overflow: hidden;
}
.patient-idcard {
background: rgba(255, 255, 255, 0.14);
padding: 4rpx 8rpx;
color: #fff;
font-size: 20rpx;
}
.keep {
width: 142rpx;
height: 48rpx;
background: #ffffff;
border-radius: 24rpx;
border: 2rpx solid #004ac2;
color: #004ac2;
font-weight: 500;
}
}
}
.info-card {
position: relative;
top: -98rpx;
padding: 0 24rpx;
.patient-card {
.menu-card {
width: 100%;
height: 194rpx;
background: #fff;
border-radius: 8rpx;
.menu-icon {
width: 88rpx;
height: 88rpx;
image {
width: 100%;
height: 100%;
}
}
}
}
.card-list {
margin-top: 20rpx;
padding: 0 24rpx;
background: #fff;
border-radius: 8rpx;
.card-list-item {
height: 96rpx;
border-bottom: 2rpx solid #f5f6f7;
}
}
}
</style>
<template>
<view class="">
<u-navbar :title="title" :placeholder="true"></u-navbar>
<view class="cont">
<view class="card">
<report-head-title :title="'就诊人信息'" :icon="iconList[0]"></report-head-title>
<view class="patient-info">
<view class="flex items-center pb28">
<view class="label-color ft28 lht28 pr24">姓名:</view>
<view class="value-color ft28 lht28">李小明</view>
</view>
<view class="flex items-center pb28">
<view class="label-color ft28 lht28 pr24">性别:</view>
<view class="value-color ft28 lht28"></view>
</view>
<view class="flex items-center pb28">
<view class="label-color ft28 lht28 pr24">年龄:</view>
<view class="value-color ft28 lht28">20岁</view>
</view>
<view class="flex items-center pb28">
<view class="label-color ft28 lht28 pr24">卡号:</view>
<view class="value-color ft28 lht28">DF1234</view>
</view>
</view>
</view>
<!-- 检验信息 -->
<view class="card mt16">
<report-head-title :title="'检验信息'" :icon="iconList[1]"></report-head-title>
<view class="patient-info">
<view class="flex items-center pb28">
<view class="label-color ft28 lht28 pr24">医院名称:</view>
<view class="value-color ft28 lht28">厦门弘爱医院</view>
</view>
<view class="flex items-center pb28">
<view class="label-color ft28 lht28 pr24">申请科室:</view>
<view class="value-color ft28 lht28">妇科门诊</view>
</view>
<view class="flex items-center pb28">
<view class="label-color ft28 lht28 pr24">检查日期:</view>
<view class="value-color ft28 lht28">2021-08-11岁</view>
</view>
<view class="flex items-center pb28">
<view class="label-color ft28 lht28 pr24">检查类型:</view>
<view class="value-color ft28 lht28">分子</view>
</view>
<view class="flex items-center pb28">
<view class="label-color ft28 lht28 pr24">检验医生:</view>
<view class="value-color ft28 lht28">李白</view>
</view>
<view class="flex items-center pb28">
<view class="label-color ft28 lht28 pr24">审核医生:</view>
<view class="value-color ft28 lht28">李白</view>
</view>
<view class="flex items-center pb28">
<view class="label-color ft28 lht28 pr24">审核时间:</view>
<view class="value-color ft28 lht28">2021-08-11</view>
</view>
</view>
</view>
<!-- 检查所见 -->
<view class="card mt16">
<report-head-title :title="'检查所见'" :icon="iconList[1]"></report-head-title>
<view class="patient-info ft28 color333 lht40">
糖尿病时长期存在的高血糖,导致各种组织,特别是眼、的肾、心脏、血管、神经的慢性损害、功能障碍
</view>
</view>
<!-- 检查结论 -->
<view class="card mt16">
<report-head-title :title="'检查结论'" :icon="iconList[1]"></report-head-title>
<view class="patient-info ft28 color333 lht40">
糖尿病时长期存在的高血糖,导致各种组织,特别是眼、的肾、心脏、血管、神经的慢性损害、功能障碍
</view>
</view>
</view>
</view>
</template>
<script>
import reportHeadTitle from '@/pages/patient/components/report-head-title.vue';
export default {
components: {
reportHeadTitle
},
data() {
return {
title: '李小霞的彩超报告',
iconList: ['/static/image/icon2.png', '/static/image/icon3.png', '/static/image/icon4.png'],
};
},
methods: {}
};
</script>
<style>
page {
background-color: #f5f6f7;
}
</style>
<style lang="scss" scoped>
.cont {
padding: 20rpx 26rpx;
.patient-info {
background: #fff;
padding: 26rpx 28rpx 40rpx 28rpx;
border-radius: 0 0 8rpx 8rpx;
}
.patient-cont{
}
}
.label-color {
color: #656975;
}
.value-color {
color: #333333;
}
</style>
<template>
<view class="">
<u-navbar title="报告查询" :placeholder="true"></u-navbar>
<view class="head-patient flex items-center">
<view class="head-patient-img"></view>
<view class="patient-name color333 ft32 font500 pl20 pr12">李小明</view>
<text class="patient-tag">女|20岁</text>
</view>
<view class="head-tbs flex items-center mb16">
<text class="tabs-item ft30 ft26 color666 mr20 " :class="active == 1 ? 'active' : ''" @click="handleTbs(1)">检查报告</text>
<text class="tabs-item ft30 ft26 color666 mr20 " :class="active == 2 ? 'active' : ''" @click="handleTbs(2)">体验报告</text>
<text class="tabs-item ft30 ft26 color666 mr20" :class="active == 3 ? 'active' : ''" @click="handleTbs(3)">体检报告</text>
</view>
<template>
<report-item></report-item>
</template>
</view>
</template>
<script>
import reportItem from '@/pages/patient/components/report-item.vue';
export default {
components:{
reportItem
},
data() {
return {
active: 1
};
},
methods: {
handleTbs(val) {
this.active = val;
}
}
};
</script>
<style>
page{
background: #F5F6F7;
}
</style>
<style lang="scss" scoped>
.head-patient {
background-color: #fff;
height: 90rpx;
padding: 0 30rpx;
border-bottom: 2rpx solid #f5f6f7;
.head-patient-img {
width: 60rpx;
height: 60rpx;
background: #eee;
border-radius: 50%;
overflow: hidden;
image {
width: 100%;
height: 100%;
}
}
.patient-tag {
background-color: #eff4fb;
padding: 4rpx 8rpx;
background: #eff4fb;
border-radius: 2rpx;
color: #1c62d5;
font-size: 20rpx;
}
}
.head-tbs {
padding: 0 30rpx;
background: #fff;
height: 88rpx;
border-top: 2rpx solid #f5f6f7;
.tabs-item {
padding: 6rpx 16rpx;
border-radius: 26rpx;
}
.active {
background-color: #eff4fb;
color: #004ac2;
}
}
</style>
<template>
<view class="">
<!-- 头部内容 -->
<view class="custom_head" :style="{ height: navHeight + 'px' }">
<view class="flex items-center" :style="{ 'padding-top': navTop + 'px' }">
<view class="head-logo"></view>
<view class="">
<view class="head-title pl20 ft34 colorfff pr28">建发健康平台</view>
<view class="head-title pl20 ft34 colorfff pr28">建发健康平台</view>
</view>
</view>
</view>
</view>
</template>
<script>
export default{
data(){
return{
navHeight: this.navHeight, //导航栏高度
navTop: this.navTop, //胶囊距离顶部的高度
}
}
}
</script>
<style lang="scss" scoped>
.custom_head {
padding: 0 30rpx;
width: 750rpx;
background: #004bb9;
color: #fff;
position: fixed;
top: 0;
z-index: 999;
.head-logo {
width: 62rpx;
height: 62rpx;
background: #fff;
border-radius: 50%;
overflow: hidden;
}
}
</style>
<template>
</template>
<script>
</script>
<style>
</style>
\ No newline at end of file
<template>
<view class="">
<view class="custom_head" :style="{ height: navHeight + 'px' }">
<view class="flex items-center" :style="{ 'padding-top': navTop + 'px' }">
<view class="head-tabs pl8 flex">
<view class="head-tabs-item color666 ft30 font500" :class="activeSte == 1 ? 'active-color' : ''" @click.stop="handleTbs(1)">
网络
<view class="btm-slide" v-if="activeSte == 1"></view>
</view>
<view class="head-tabs-item color666 ft30 font500" style="margin-left: 54rpx;" :class="activeSte == 2 ? 'active-color' : ''" @click.stop="handleTbs(2)">
关注
<view class="btm-slide" v-if="activeSte == 2"></view>
</view>
</view>
</view>
</view>
<!-- 日期 -->
<view class="head-time flex items-center" :style="{ 'margin-top': navHeight + 'px' }" v-if="activeSte == 1">
<view class="head-time-btn ft26 flex content-center items-center" @click="showTime = true">
<view class="">2022-04-16</view>
<view class="pl10 pr10">-</view>
<view class="">2022-04-16</view>
<image class="ml10" style="width: 16rpx;height: 16rpx;" src="/static/image/tabbar/arrow-down.png" mode=""></image>
</view>
</view>
<!-- 患者列表 -->
<view class="" v-if="activeSte == 1">
<patient-item></patient-item>
</view>
<view class="" :style="{ 'margin-top': navHeight + 'px' }">
<view class="head pt20 pb20"><view id="add-btn" class="add-btn ml24 flex items-center content-center ">分组管理</view></view>
<view class="" id="slide-cont" v-if="activeSte == 2"><my-attention :top="navHeight"></my-attention></view>
</view>
<!-- 日期 -->
<u-calendar :show="showTime" :closeOnClickOverlay="true" :mode="mode" @close="closeTime" @confirm="confirm"></u-calendar>
</view>
</template>
<script>
import patientItem from '@/pages/components/patient-Item.vue'; //我的患者
import myAttention from '@/pages/components/myAttention.vue'; //我的关注
export default {
components: {
patientItem,
myAttention
},
data() {
return {
activeSte: 2,
navHeight: this.navHeight, //导航栏高度
navTop: this.navTop, //胶囊距离顶部的高度
showTime: false,
mode: 'range',
top: 0
};
},
onLoad() {
if (this.activeSte == 2) {
this.$nextTick(() => {
wx.createSelectorQuery()
.select('#slide-cont')
.boundingClientRect(res => {
this.top = res.top;
})
.exec();
});
}
},
methods: {
handleTbs(val) {
this.activeSte = val;
},
// 选中的日期范围
confirm(val) {
console.log(val);
this.closeTime();
},
// 关闭日期
closeTime() {
this.showTime = false;
}
}
};
</script>
<style>
page {
background-color: #f5f6f7;
}
</style>
<style lang="scss" scoped>
.add-btn {
width: 702rpx;
height: 84rpx;
background: linear-gradient(135deg, #0b57d2 0%, #77a5ff 100%);
border-radius: 8rpx;
color: #ffffff;
font-size: 32rpx;
}
.custom_head {
padding: 0 30rpx;
width: 750rpx;
background: #fff;
color: #fff;
position: fixed;
top: 0;
z-index: 999;
.head-tabs {
height: 100%;
background: #fff;
.head-tabs-item {
position: relative;
.btm-slide {
position: absolute;
bottom: -24rpx;
left: 50%;
transform: translateX(-50%);
width: 40rpx;
height: 6rpx;
background: linear-gradient(270deg, #77abff 0%, #035ceb 100%);
border-radius: 4rpx;
}
}
}
}
.head-time {
padding: 0 24rpx;
width: 100%;
height: 90rpx;
background: #fff;
.head-time-btn {
width: 400rpx;
height: 44rpx;
background: #eff4fb;
border-radius: 28rpx;
color: #004ac2;
}
}
.active-color {
color: #000000;
}
.tags {
background: linear-gradient(135deg, #05ddbd 0%, #32dfc2 100%);
padding: 2rpx 6rpx;
border-radius: 4rpx;
font-size: 20rpx;
color: #ffffff;
}
.btm-border {
padding: 30rpx 0;
border-bottom: 2rpx solid #f5f6f7 !important;
}
.img {
width: 32rpx;
height: 32rpx;
}
.check-tags {
border: 2rpx solid #004ac2 !important;
background: #ffffff !important;
color: #004ac2;
}
.img-list {
.img-item {
width: 120rpx;
height: 120rpx;
border-radius: 4rpx;
background: #eee;
}
}
.slide-left-active {
background: #ffffff !important;
color: #004ac2 !important;
}
</style>
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or sign in to comment