You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
130 lines
3.5 KiB
130 lines
3.5 KiB
<template>
|
|
<div class="p-l-xs d-flex flex-col dep-list">
|
|
<!-- 卖 -->
|
|
<div class="d-flex justify-between fn-xs m-b-xs">
|
|
<span>{{$t('exchange.d2')}} <view>(USDT)</view></span>
|
|
<span>{{$t('exchange.c5')}}<view>(BTC)</view></span>
|
|
</div>
|
|
<div class=" overflow-scroll rotatebox" v-if="symbol!='GITP/USDT'">
|
|
<div class="rotateZ">
|
|
<div
|
|
class="d-flex justify-between h-24 align-center row"
|
|
v-for="(item,idx) in showSellList"
|
|
:key="idx"
|
|
@click="$emit('price',item.price)"
|
|
>
|
|
<span style="color: #87354E;" v-if="item.price>100">{{omitTo(item.price,2)}}</span>
|
|
<span style="color: #87354E;" v-if="item.price>1&&item.price<100">{{omitTo(item.price,4)}}</span>
|
|
<span style="color: #87354E;" v-if="item.price<1">{{omitTo(item.price,6)}}</span>
|
|
<span class="p-r-xs" style="color: white;">{{omitTo(item.amount,2)}}</span>
|
|
<!-- <div
|
|
class="proagess h-max bg-sell-transparent"
|
|
:style="{width:getValue(item.amount)+'%'}"
|
|
>
|
|
</div> -->
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="border-t border-b p-y-xs">
|
|
<slot />
|
|
</div>
|
|
<div class=" overflow-scroll">
|
|
<div
|
|
class="d-flex justify-between h-24 align-center row"
|
|
v-for="(item,idx) in showBuyList"
|
|
:key="idx"
|
|
@click="$emit('price',item.price)"
|
|
>
|
|
<span style="color: #23643F;" v-if="item.price>100">{{omitTo(item.price,2)}}</span>
|
|
<span style="color: #23643F;" v-if="item.price>1&&item.price<100">{{omitTo(item.price,4)}}</span>
|
|
<span style="color: #23643F;" v-if="item.price<1">{{omitTo(item.price,6)}}</span>
|
|
<span class="p-r-xs" style="color: white;">{{omitTo(item.amount,2)}}</span>
|
|
<!-- <div class="proagess h-max bg-buy-transparent" :style="{width:getValue(item.amount)+'%'}"></div> -->
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</template>
|
|
<script>
|
|
import date from "@/utils/class/date";
|
|
import math from "@/utils/class/math";
|
|
export default {
|
|
name: "buy-and-sell",
|
|
props: {
|
|
buyList: {
|
|
default:()=> [],
|
|
required: true,
|
|
type: Array,
|
|
},
|
|
sellList: {
|
|
default: ()=>[],
|
|
required: true,
|
|
type: Array,
|
|
},
|
|
max:{
|
|
default:undefined,
|
|
type:Number,
|
|
required:false
|
|
},
|
|
contract:{
|
|
default:undefined,
|
|
type:Number,
|
|
required:false
|
|
},
|
|
symbol: {
|
|
default: undefined,
|
|
type: String,
|
|
required: false,
|
|
},
|
|
},
|
|
components: {},
|
|
computed: {
|
|
showBuyList(){
|
|
if(this.max){
|
|
return this.buyList.splice(0,this.max)
|
|
}
|
|
return this.buyList
|
|
},
|
|
showSellList(){
|
|
if(this.max&&this.contract==1){
|
|
return this.sellList.splice(this.sellList.length-this.max,this.max)
|
|
}
|
|
if(this.max&&this.contract==0){
|
|
return this.sellList.splice(0,this.max)
|
|
}
|
|
return this.sellList
|
|
}
|
|
},
|
|
mounted() {
|
|
},
|
|
methods: {
|
|
parseTime: date.parseTime,
|
|
omitTo: math.omitTo,
|
|
// 计算深度
|
|
getValue(amount) {
|
|
const arr = this.showBuyList.concat(this.showSellList).map((item) => item.amount);
|
|
let max = Math.max(...arr);
|
|
return math.division(amount, max, 2) * 100;
|
|
},
|
|
},
|
|
};
|
|
</script>
|
|
<style lang="scss" scoped>
|
|
.dep-list {
|
|
max-height: 456px;
|
|
.row {
|
|
position: relative;
|
|
.proagess {
|
|
position: absolute;
|
|
right: 0;
|
|
top: 0;
|
|
transition: width 0.3s;
|
|
}
|
|
}
|
|
}
|
|
.rotatebox {
|
|
transform: rotateZ(-180deg);
|
|
.rotateZ {
|
|
transform: rotateZ(180deg);
|
|
}
|
|
}
|
|
</style>
|