| | |
| | | <template>
|
| | | <view>
|
| | | <workOrderInfo :orederMessage="info" />
|
| | | <div class="bg_list">
|
| | | <view class="content">
|
| | | <workOrderInfo :orederMessage="info" /> |
| | | <view class="bg_cate"> |
| | | <view @click="clickIten(index)" :class="typeView == index ? 'bg_cate_item active' : 'bg_cate_item'" |
| | | v-for="(item, index) in cate" :key="index">{{ item.name }}</view> |
| | | </view>
|
| | | <div v-if="typeView==0" class="bg_list">
|
| | | <div class="bg_list_item">
|
| | | <div class="bg_list_item_top">
|
| | | <div class="bg_list_item_top_left">
|
| | |
| | | </div>
|
| | |
|
| | | <template v-if="feedingData && feedingData.length > 0">
|
| | | <view>
|
| | | <view v-for="(item, index) in feedingData" :key="index">
|
| | | <div class="bg_list_item_h">
|
| | | <view class="plr30">
|
| | | <view >
|
| | | <div v-for="(item, index) in feedingData" :key="index" class="bg_list_item_h">
|
| | | <div class="bg_list_item_num">
|
| | | <div class="bg_list_item_num_item">
|
| | | <div class="bg_list_item_num_item_wl">
|
| | |
| | | <div class="bg_list_item_num_item_sr">
|
| | | <view class="cY">
|
| | | <view class="mr10">{{ item.num }}</view> |
| | | <span v-if="info.umodel">{{ info.umodel.name }}</span>
|
| | | <span>{{ item.unitName }}</span>
|
| | | </view>
|
| | |
|
| | | </div>
|
| | |
| | | </div>
|
| | | </div>
|
| | | <div class="bg_list_item_h">
|
| | | <div class="bg_list_item_num">
|
| | | <div class="bg_list_item_num plr30">
|
| | | <div class="bg_list_item_num_item">
|
| | | <span>良品数{{ info.umodel ? `(${info.umodel.name})` : '' }}</span>
|
| | | <div class="bg_list_item_num_item_sr">
|
| | |
| | | </div>
|
| | | </div>
|
| | | <div class="bg_list_item_h">
|
| | | <div class="bg_list_item_num">
|
| | | <div class="bg_list_item_num plr30">
|
| | | <div class="bg_list_item_num_item">
|
| | | <span>不良数{{ info.umodel ? `(${info.umodel.name})` : '' }}</span>
|
| | | <div class="bg_list_item_num_item_sr">
|
| | |
| | | <div class="bg_list_item_top"> |
| | | <div class="bg_list_item_top_left"> |
| | | <div class="bg_list_item_top_left_x bg_m"></div> |
| | | <span>生产点检</span> |
| | | <span>工资绩效</span> |
| | | </div> |
| | | </div> |
| | | <div class="bg_list_item_h mb40 "> |
| | | <div class="bg_list_item_num plr30" style="display: block;"> |
| | | <div class="bX ptb15"> |
| | | <div class="f30 c2">预计工资</div> |
| | | <div class="f28" style="color:#4275FC">{{ (performance.salary / 10 / 10).toFixed(2) }}元</div> |
| | | </div> |
| | | <div class="f24 c6"> |
| | | {{ performance.salaryType == 0 ? '计件' : '计时' }} | |
| | | {{ (performance.salaryPrice / 10 / 10).toFixed(2) }}元/{{ performance.salaryType == |
| | | 0 ? '件' : '时' }} | |
| | | {{ complianceRate }}% |
| | | </div> |
| | | </div> |
| | | |
| | | <!-- <div class="bg_list_item_num"> |
| | | <div class="bg_list_item_num_item"> |
| | | <span>计件方式</span> |
| | | <div class="bg_list_item_num_item_list"> |
| | | {{ performance.salaryType == 0 ? '计件' : '计时' }} |
| | | </div> |
| | | </div> |
| | | </div> --> |
| | | <!-- <div class="bg_list_item_num"> |
| | | <div class="bg_list_item_num_item"> |
| | | <span>工资单价</span> |
| | | <div class="bg_list_item_num_item_sr"> |
| | | <span class="color1">{{ (performance.salaryPrice / 10 / 10).toFixed(2) }}元/{{ performance.salaryType == |
| | | 0 ? '件' : '时' }}</span> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | |
| | | <div class="bg_list_item_num"> |
| | | <div class="bg_list_item_num_item"> |
| | | <span>达标率</span> |
| | | <div class="bg_list_item_num_item_sr"> |
| | | <span class="color1">{{ complianceRate }}%</span> |
| | | </div> |
| | | </div> |
| | | </div> --> |
| | | </div> |
| | | </div> |
| | | </div>
|
| | | <div v-else class="bg_list"> |
| | | <!-- <div class="bg_list_item"> |
| | | <div class="bg_list_item_top"> |
| | | <div class="bg_list_item_top_left"> |
| | | <div class="bg_list_item_top_left_x bg_m"></div> |
| | | <span>生产点检</span> |
| | | </div> |
| | | </div> --> |
| | | <template v-if="djData && djData.length > 0"> |
| | | <div class="details_dj"> |
| | | |
| | | <div class="details_dj_list"> |
| | | <scroll-view scroll-y="true" refresher-enabled="true" @scrolltolower="getLists"> |
| | | <view v-for="(item, index) in djData" :key="index"> |
| | | <div class="details_dj_list_item"> |
| | | <span>{{ item.attrName }}:{{ item.val }}</span> |
| | | <span>{{ item.userName }} {{ item.createTime }}</span> |
| | | </div> |
| | | </view> |
| | | </scroll-view> |
| | | <view v-for="(item, index) in djData" :key="index"> |
| | | <div class="details_dj_list_item"> |
| | | <span>{{ item.attrName }}:{{ item.val }}</span> |
| | | <span>{{ item.userName }} {{ item.createTime }}</span> |
| | | </div> |
| | | </view> |
| | | <!-- <scroll-view scroll-y="true" refresher-enabled="true" @scrolltolower="getLists"> |
| | | |
| | | </scroll-view> --> |
| | | </div> |
| | | </div> |
| | | </template> |
| | |
| | | </div> |
| | | </template> |
| | | </div> |
| | | <div class="bg_list_item"> |
| | | <div class="bg_list_item_top"> |
| | | <div class="bg_list_item_top_left"> |
| | | <div class="bg_list_item_top_left_x bg_m"></div> |
| | | <span>工资绩效</span> |
| | | </div> |
| | | </div> |
| | | <div class="bg_list_item_h"> |
| | | <div class="bg_list_item_num"> |
| | | <div class="bg_list_item_num_item"> |
| | | <span>计件方式</span> |
| | | <div class="bg_list_item_num_item_list"> |
| | | {{ performance.salaryType == 0 ? '计件' : '计时' }} |
| | | </div> |
| | | </div> |
| | | </div> |
| | | <div class="bg_list_item_num"> |
| | | <div class="bg_list_item_num_item"> |
| | | <span>工资单价</span> |
| | | <div class="bg_list_item_num_item_sr"> |
| | | <span class="color1">{{ (performance.salaryPrice / 10 / 10).toFixed(2) }}元/{{ performance.salaryType == |
| | | 0 ? '件' : '时' }}</span> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | <div class="bg_list_item_num"> |
| | | <div class="bg_list_item_num_item"> |
| | | <span>预计工资</span> |
| | | <div class="bg_list_item_num_item_sr"> |
| | | <span class="color1">{{ (performance.salary / 10 / 10).toFixed(2) }}元</span> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | <div class="bg_list_item_num"> |
| | | <div class="bg_list_item_num_item"> |
| | | <span>达标率</span> |
| | | <div class="bg_list_item_num_item_sr"> |
| | | <span class="color1">{{ complianceRate }}%</span> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div>
|
| | | </div> |
| | |
|
| | | </view>
|
| | | </template>
|
| | |
| | | workOrderInfo
|
| | | },
|
| | | data() {
|
| | | return {
|
| | | return { |
| | | cate: [{ |
| | | name: '生产' |
| | | }, |
| | | { |
| | | name: '点检' |
| | | } |
| | | ],
|
| | | workorderId: '',
|
| | | form: {
|
| | | time: '',
|
| | |
| | | complianceRate() {
|
| | | if (!this.performance) return 0; |
| | | if (!this.performance.duration) return 0; |
| | | if (!this.performance.salaryNum || this.performance.salaryTimes) return 0 |
| | |
|
| | | if (!this.performance.qualifiedNum && !this.performance.unqualifiedNum) return 0;
|
| | | if (this.performance.salaryUnqualified == 1) { // 是否计入不良品
|
| | | let a = ((Number(this.performance.qualifiedNum) + Number(this.performance.unqualifiedNum)) / (this.performance
|
| | | .duration / 3600)).toFixed(2)
|
| | | let b = (this.performance.salaryNum / (this.performance.salaryTimes / 3600)).toFixed(2)
|
| | | let b = (this.performance.salaryNum / (this.performance.salaryTimes / 3600)).toFixed(2) |
| | | debugger
|
| | | return ((Number(a) / Number(b)) * 100).toFixed(2)
|
| | | // let total = (Number(from.qualified) + Number(from.undesirable)) / ((from.duration * 60 * 60) * infoBox.value.num / )
|
| | | // return total * infoBox.value.salary;
|
| | | } else { |
| | | let a = (this.performance.qualifiedNum / (this.performance.duration / 3600)).toFixed(2)
|
| | | // let b = (this.arrType[this.form.index].num / (this.arrType[this.form.index].times / 3600)).toFixed(2) |
| | | let b = (this.performance.salaryNum / (this.performance.salaryTimes / 3600)).toFixed(2)
|
| | | let b = (this.performance.salaryNum / (this.performance.salaryTimes / 3600)).toFixed(2) |
| | | debugger
|
| | | return ((Number(a) / Number(b)) * 100).toFixed(2)
|
| | | }
|
| | | }
|
| | |
| | | getWorkorderRecordListStandard({
|
| | | workorderId: this.workorderId
|
| | | }).then(res => { |
| | | console.log(res.data[0]); |
| | | debugger
|
| | | // console.log(res.data[0]); |
| | | if (res.data.length > 0) { |
| | | this.produceFrom.qualified = res.data[0].qualifiedNum |
| | | this.produceFrom.undesirable = res.data[0].unqualifiedNum |
| | |
| | | }
|
| | | </script>
|
| | |
|
| | | <style lang="scss" scoped>
|
| | | <style lang="scss" scoped> |
| | | .content { |
| | | height: 100vh; |
| | | background-color: #f7f7f7; |
| | | }
|
| | | .bg_cate {
|
| | | width: 100%;
|
| | | height: 88rpx;
|
| | | background: #FFFFFF;
|
| | | display: flex;
|
| | | align-items: center;
|
| | |
|
| | | border-top: 20rpx solid #f7f7f7;
|
| | | .active {
|
| | | box-sizing: border-box;
|
| | | color: #305ED5 !important;
|
| | |
| | | // margin-bottom: 40rpx;
|
| | | // border-bottom: 40rpx #f7f7f7 solid;
|
| | |
|
| | | .kong {
|
| | | text-align: center;
|
| | | padding: 30rpx 0;
|
| | | background: #ffffff;
|
| | | font-size: 25rpx;
|
| | |
|
| | | span {
|
| | | color: #474747;
|
| | | }
|
| | | }
|
| | | |
| | |
|
| | | .bg_list_item_top {
|
| | | display: flex;
|
| | |
| | |
|
| | | .bg_list_item_h {
|
| | | width: 100%;
|
| | | padding: 0 30rpx;
|
| | | box-sizing: border-box;
|
| | | background: white;
|
| | |
|
| | | border-bottom: 1rpx solid #E5E5E5; |
| | | padding: 15rpx 0; |
| | | &:last-child { |
| | | border: none !important; |
| | | }
|
| | | .bg_list_item_num {
|
| | | width: 100%;
|
| | | min-height: 98rpx;
|
| | | background: white;
|
| | | background: white; |
| | | box-sizing: border-box;
|
| | | display: flex;
|
| | | justify-content: center;
|
| | | align-items: center;
|
| | | border-bottom: 1rpx solid #E5E5E5;
|
| | |
|
| | | &:last-child {
|
| | | border: none !important;
|
| | | }
|
| | |
|
| | | .kong {
|
| | | text-align: center;
|
| | | font-size: 25rpx;
|
| | |
| | | display: flex;
|
| | | align-items: center;
|
| | | // height: 118rpx;
|
| | | padding: 15rpx 0;
|
| | | // padding: 15rpx 0;
|
| | | box-sizing: border-box;
|
| | | justify-content: space-between;
|
| | | border-bottom: 1rpx solid #E5E5E5;
|
| | | // border-bottom: 3rpx solid #111;
|
| | |
|
| | | &:last-child {
|
| | | border: none;
|
| | |
| | | }
|
| | | }
|
| | | }
|
| | | } |
| | | .kong { |
| | | text-align: center; |
| | | padding: 30rpx 0; |
| | | // background: #ffffff; |
| | | font-size: 25rpx; |
| | | |
| | | span { |
| | | color: #474747; |
| | | } |
| | | }
|
| | | </style> |