Files
aida_front/src/component/Detail/DesignDetailEnd.vue

716 lines
22 KiB
Vue
Raw Normal View History

2023-08-23 17:50:09 +08:00
<template>
<div class="detail_modal_body_result">
2024-06-17 09:39:01 +08:00
<div v-show="type_ == 1" class="result_apparel_print">
2023-08-23 17:50:09 +08:00
<div class="upload_title result_apparel" v-show="type_ == 1">
<i class="color_edit fi fi-bs-comments"></i>
2023-10-30 17:26:36 +08:00
<span>{{ $t('DesignDetailEnd.NewApparel') }}</span>
2023-08-23 17:50:09 +08:00
</div>
2024-06-17 09:39:01 +08:00
2023-08-23 17:50:09 +08:00
<div class="result_apparel_print_img">
2023-12-22 17:33:53 +08:00
<img v-show="type_==1" class="result_appare_img" :src="sketchImg?.path?sketchImg?.path:current?.path" :title="current?.type">
2024-06-17 09:39:01 +08:00
<!-- <div v-show="type_==2" class="result_print_img" @click="setPrint" :title="current?.type">
2024-05-27 17:57:37 +08:00
<img v-for="item in current?.layersObject" :src="item.imageUrl" alt="">
2024-06-17 09:39:01 +08:00
</div> -->
2023-09-12 10:11:27 +08:00
2023-08-23 17:50:09 +08:00
</div>
</div>
2024-06-17 09:39:01 +08:00
<div v-show="type_ == 2" class="result_apparel_elements">
<div class="upload_title result_apparel">
<i class="color_edit fi fi-bs-comments"></i>
<span>{{ $t('DesignDetailEnd.NewPrint') }}</span>
</div>
<div class="modal_img">
<div class="modal_img_item" v-for="item,index in exhibitionList.print" :key="item" >
<!-- <div class="modal_img_item" v-for="item,index in current.printObject.prints" :key="item" > -->
<img v-lazy="item.path" alt="">
<sketchCategory :disignTypeList="designTypeList" :generateList="exhibitionList.print" :item="item" :isSpread="true" :isSetSketchCategory="true"></sketchCategory>
2024-07-08 09:42:21 +08:00
<!-- <div
2024-06-17 09:39:01 +08:00
class="delete_file_block"
@click="deleteSelectptints(item,index)"
>
<span class="icon iconfont icon-shanchu"></span>
2024-07-08 09:42:21 +08:00
</div> -->
2024-06-17 09:39:01 +08:00
</div>
<div class="modal_img_item" v-for="item,index in printsList" :key="item" >
<img v-lazy="item.path" alt="">
<sketchCategory :disignTypeList="designTypeList" :generateList="printsList" :item="item" :isSpread="true" :isSetSketchCategory="true"></sketchCategory>
<div
class="delete_file_block"
@click="deleteptints(item,index)"
>
<span class="icon iconfont icon-shanchu"></span>
</div>
</div>
</div>
</div>
2023-08-23 17:50:09 +08:00
<div v-show="type_ == 3">
<div class="result_color upload_title">
<i class="color_edit fi fi-bs-comments"></i>
2023-10-30 17:26:36 +08:00
<span>{{ $t('DesignDetailEnd.NewColor') }}</span>
2023-08-23 17:50:09 +08:00
</div>
<div class="modal_img">
<div class="modal_img_item" v-for="color,index in colorList" :key="color" >
2023-09-12 10:11:27 +08:00
<div :title="color?.name?color?.name:''" @click="selectColorItem(index,color)" @dblclick="setSelectColorItem(color)" :class="['upload_color',selectIndex === index ? 'select_upload_color' : '',]" :style="{background:`rgba(${color?.r},${color?.g},${color?.b},${color?.a})`}">
2024-05-16 09:41:16 +08:00
<div v-if="!color?.gradient" class="color_content" :style="{'background-color':`rgba(${color.rgba?.r},${color.rgba?.g},${color.rgba?.b},${color.rgba?.a})`}">
2023-08-23 17:50:09 +08:00
</div>
2024-05-16 09:41:16 +08:00
<div class="color_content" v-else :style="{height:'100%','background-image':color?.gradient?`linear-gradient(${color?.gradient.angle}deg,${setGradient(color?.gradient)}`:'none'}"></div>
<div v-if="!color?.gradient" class="color_content_body">
2023-09-12 10:11:27 +08:00
<div class="color_des">{{color.tcx}}</div>
<div class="color_des">{{ color.name }}</div>
2023-08-23 17:50:09 +08:00
</div>
</div>
</div>
</div>
</div>
2024-06-17 09:39:01 +08:00
<div v-show="type_ == 4" class="result_apparel_elements">
<div class="upload_title result_apparel">
<i class="color_edit fi fi-bs-comments"></i>
<span>New Elements</span>
</div>
<div class="modal_img">
<!-- <div class="modal_img_item" v-for="item,index in current.trims.prints" :key="item" > -->
<div class="modal_img_item" v-for="item,index in exhibitionList.elements" :key="item" >
<img v-lazy="item.path" alt="">
<div
class="delete_file_block"
@click="deleteSelectElements(item,index)"
>
<span class="icon iconfont icon-shanchu"></span>
</div>
</div>
<div class="modal_img_item" v-for="item,index in elementsList" :key="item" >
<img v-lazy="item.url" alt="">
<div
class="delete_file_block"
@click="deleteElements(item,index)"
>
<span class="icon iconfont icon-shanchu"></span>
</div>
</div>
</div>
</div>
2024-05-27 17:57:37 +08:00
<div v-show="type_ == 1 || type_ == 3" @click.stop="setPreview" class="subitOkPreviewBtn" :class="[ !sketchImg?.id?!current?.id?'active':'':'' ]">{{ $t('DesignDetailEnd.preview') }}</div>
2024-06-20 10:36:45 +08:00
<div v-if="type_ == 2 && (current?.printObject?.prints?.length != 0 || printsList.length != 0 || exhibitionList.print.length != 0)" @click.stop="setPrint" class="subitOkPreviewBtn Guide_1_23">{{ $t('DesignDetailEnd.Layout') }}</div>
2024-06-17 09:39:01 +08:00
<!-- <div v-else-if="type_ == 2 && designItemDetail?.clothes?.[currentIndex]?.printObject?.prints?.[0]?.path != null && current?.printObject?.prints?.[0]?.path == null" @click.stop="setPreview" class="subitOkPreviewBtn">{{ $t('DesignDetailEnd.preview') }}</div> -->
2024-06-20 10:36:45 +08:00
<div v-if="type_ == 4 && (elementsList.length != 0 || exhibitionList.elements.length != 0)" @click.stop="setElemets" class="subitOkPreviewBtn">{{ $t('DesignDetailEnd.Layout') }}</div>
2023-12-01 17:13:22 +08:00
<DesignPrintOperation v-if="!moible" ref="DesignPrintOperation"></DesignPrintOperation>
<DesignPrintOperationMobile v-else ref="DesignPrintOperationMobile"></DesignPrintOperationMobile>
2024-06-17 09:39:01 +08:00
<DesignElementsOperation v-if="!moible" ref="DesignElementsOperation"></DesignElementsOperation>
<DesignPrintMobile v-else ref="DesignPrintMobile"></DesignPrintMobile>
2023-11-02 11:00:38 +08:00
</div>
<div class="mark_loading" v-show="loadingShow">
<a-spin size="large" />
2023-08-23 17:50:09 +08:00
</div>
</template>
<script>
2023-11-28 16:21:00 +08:00
import { defineComponent,computed,ref, nextTick,h ,inject} from 'vue'
2023-08-23 17:50:09 +08:00
import Draggable from 'vuedraggable'
import { Https } from "@/tool/https";
import { useStore } from "vuex";
import { Sketch} from '@ans1998/vue3-color'
2023-09-12 10:11:27 +08:00
import DesignPrintOperation from './DesignPrintOperation.vue';
2023-11-27 16:25:32 +08:00
import DesignPrintOperationMobile from './DesignPrintOperationMobile.vue';
2024-06-17 09:39:01 +08:00
import DesignElementsOperation from './DesignElements.vue';
import DesignPrintMobile from './DesignElementsMobile.vue';
2023-09-12 10:11:27 +08:00
import { message,Upload} from 'ant-design-vue';
2023-11-28 16:21:00 +08:00
import { openGuide,driverObj__ } from "@/tool/guide";
2024-05-16 09:41:16 +08:00
import {isMoible,setGradual} from '@/tool/util'
2023-10-30 17:26:36 +08:00
import { useI18n } from 'vue-i18n';
2024-06-17 09:39:01 +08:00
import sketchCategory from "@/component/HomePage/sketchCategory.vue";
2023-08-23 17:50:09 +08:00
export default defineComponent({
props: ["msg"],
components:{
2024-06-17 09:39:01 +08:00
Draggable,Sketch,DesignPrintOperation,DesignPrintOperationMobile,
DesignElementsOperation,DesignPrintMobile,sketchCategory
2023-08-23 17:50:09 +08:00
},
setup(prop) {
const store = useStore();
let type_ = ref(0);
2023-09-12 10:11:27 +08:00
let current = inject('current')//父组件传过来的数据
let setRevocation = inject('setRevocation')//父组件传过来的数据
2023-09-25 10:09:00 +08:00
let sketchImg = ref({})
2023-11-28 16:21:00 +08:00
let driver__ = inject('driver__')//父组件传过来的数据
2023-12-01 17:13:22 +08:00
let moible = inject('moible')//父组件传过来的数据
2023-12-20 17:03:42 +08:00
let designItemDetail = inject('designItemDetail')//父组件传过来的数据
let currentIndex = inject('currentIndex')//父组件传过来的数据
2024-06-17 09:39:01 +08:00
let designTypeList = inject('designTypeList')//父组件传过来的数据
2023-12-20 17:03:42 +08:00
let previewShow = ref(false)
2023-08-23 17:50:09 +08:00
//印花
2023-09-12 10:11:27 +08:00
2023-08-23 17:50:09 +08:00
//颜色
2023-12-20 17:03:42 +08:00
// let colorList = ref([{}])
2024-05-16 09:41:16 +08:00
// let colorList = ref([{},{},{},{},{},{},{},{},{}])
let colorList = inject('colorList')//父组件传过来的数据
let selectIndex = inject('selectIndex')//父组件传过来的数据
2023-09-12 10:11:27 +08:00
//加载中
let loadingShow = ref(false)
2023-10-30 17:26:36 +08:00
2024-06-17 09:39:01 +08:00
let exhibitionList = inject('exhibitionList')
2023-10-30 17:26:36 +08:00
let {t} = useI18n()
2024-06-17 09:39:01 +08:00
let printsList = ref([])
let elementsList = ref([
])
2023-08-23 17:50:09 +08:00
return{
2023-09-12 10:11:27 +08:00
store,
current,
setRevocation,
2023-09-25 10:09:00 +08:00
sketchImg,
2023-11-28 16:21:00 +08:00
driver__,
2023-12-01 17:13:22 +08:00
moible,
2023-12-20 17:03:42 +08:00
designItemDetail,
currentIndex,
2024-06-17 09:39:01 +08:00
designTypeList,
2023-12-20 17:03:42 +08:00
previewShow,
2023-08-23 17:50:09 +08:00
type_,
colorList,
2024-05-16 09:41:16 +08:00
selectIndex,
2023-09-12 10:11:27 +08:00
loadingShow,
2024-06-17 09:39:01 +08:00
exhibitionList,
2023-10-30 17:26:36 +08:00
t,
2024-06-17 09:39:01 +08:00
printsList,
elementsList,
2023-08-23 17:50:09 +08:00
}
},
data(){
return{
//颜色
getRGBA:{},
selectColor:{},
}
},
2024-05-16 09:41:16 +08:00
computed:{
setGradient(){
return (gradient)=>{
let gradientStr = ''
gradient.gradientList.sort((a, b) => {
let aArr = a.left.split('%')[0]
let bArr = b.left.split('%')[0]
return aArr - bArr;
});
gradient.gradientList.forEach((item,index)=>{
let str = ','
if(gradient.gradientList.length == index+1)str = ''
gradientStr += `rgba(${item.rgba.r},${item.rgba.g},${item.rgba.b},${item.rgba.a}) ${item.left}${str}`
})
return `${gradientStr}`
}
}
},
2024-06-17 09:39:01 +08:00
watch: {
'exhibitionList.print':{
handler(newVal,oldVal){
this.printsList = this.printsList.filter(objA => {
return !newVal.some(objB => objB.minIOPath === objA.minIOPath);
});
this.setExhibitionType('print')
}
},
'exhibitionList.elements':{
handler(newVal,oldVal){
this.elementsList = this.elementsList.filter(objA => {
return !newVal.some(objB => objB.minIOPath === objA.minIOPath);
});
this.setExhibitionType('elements')
}
}
},
2023-08-23 17:50:09 +08:00
methods:{
2024-06-17 09:39:01 +08:00
2023-08-23 17:50:09 +08:00
//点击判断
init(num){
2023-09-25 10:09:00 +08:00
// this.current = JSON.parse(JSON.stringify(this.currentItem))
2023-08-23 17:50:09 +08:00
this.type_ = num
this.colorList[this.selectIndex] = this.$parent.selectColor
2024-06-17 09:39:01 +08:00
if(num == 2){
this.setExhibitionType('print')
}else if(num == 4){
this.setExhibitionType('elements')
}
},
clearModal(){
this.elementsList = []
this.printsList = []
2023-08-23 17:50:09 +08:00
},
2023-09-12 10:11:27 +08:00
//模型
2023-09-25 10:09:00 +08:00
setSketchImg(v){
this.sketchImg.id_ = v.id
2023-12-22 17:33:53 +08:00
this.sketchImg.id = v.id
2023-09-25 10:09:00 +08:00
this.sketchImg.path = v.url
2023-10-11 17:34:14 +08:00
this.sketchImg.minIOPath = v.minIOPath
2023-12-12 11:53:02 +08:00
this.sketchImg.type = v.level2Type
this.sketchImg.designType = v.designType
2023-09-25 10:09:00 +08:00
},
2023-08-23 17:50:09 +08:00
//印花
2024-06-17 09:39:01 +08:00
setExhibitionType(str){
this.exhibitionList[str].forEach((item,index)=>{
if(!item.categoryValue){
this.designTypeList.forEach((typeItem)=>{
if(item.level2Type == typeItem.value){
2024-06-24 09:47:59 +08:00
item.categoryValue = typeItem.value
item.category = typeItem.name
2024-06-17 09:39:01 +08:00
}
})
}
})
2023-08-23 17:50:09 +08:00
},
2024-06-17 09:39:01 +08:00
2023-09-12 10:11:27 +08:00
setPrint(){
2024-06-17 09:39:01 +08:00
// if(this.current?.printObject?.prints?.[0]?.path){
2023-11-27 16:25:32 +08:00
let DesignPrintOperation = isMoible() ? this.$refs.DesignPrintOperationMobile : this.$refs.DesignPrintOperation
2023-09-12 10:11:27 +08:00
DesignPrintOperation.init()
2023-11-28 16:21:00 +08:00
if(this.driver__.driver){
nextTick().then(()=>{
driverObj__.moveNext();
})
}
2024-06-17 09:39:01 +08:00
// }else{
// message.info(this.t('DesignDetailEnd.jsContent1'));
// }
2023-09-12 10:11:27 +08:00
},
deleteFile(){
this.current.printObject = {}
},
2023-08-23 17:50:09 +08:00
//颜色
selectColorItem(index,color){
2023-09-12 10:11:27 +08:00
this.selectIndex = index
2024-05-16 09:41:16 +08:00
// if(this.$parent.selectColor?.rgba?.r == color?.rgba?.r && this.$parent.selectColor.rgba.g == color?.rgba?.g && this.$parent.selectColor.rgba.b == color?.rgba?.b){
// return
// }
2023-08-23 17:50:09 +08:00
if(color.rgba?.r){
2024-05-16 09:41:16 +08:00
this.$parent.selectColor = color
2023-08-23 17:50:09 +08:00
}else{
2024-05-16 09:41:16 +08:00
this.$parent.selectColor.isClick = {}
2023-08-23 17:50:09 +08:00
}
2023-12-20 17:03:42 +08:00
//判断是否对一个颜色重复点击
2024-05-16 09:41:16 +08:00
// this.$parent.selectColor.tcxColor = ''
// this.$parent.selectColor.pantongName = ''
2023-08-23 17:50:09 +08:00
},
2023-09-12 10:11:27 +08:00
setSelectColorItem(color){
let designItemDetail = this.store.state.DesignDetailModule.designItemDetail
2023-12-20 17:03:42 +08:00
let string = `${color.rgba.r},${color.rgba.g},${color.rgba.b}`
2023-09-12 10:11:27 +08:00
this.current.color = string
designItemDetail.clothes.forEach((element,index) => {
if(element.id == this.current.id){
designItemDetail.clothes[index] = this.current
}
});
},
2023-12-22 10:57:12 +08:00
hasDuplicateId(arr) {
const set = new Set();
for (let i = 0; i < arr.length; i++) {
const id = arr[i].id;
if (set.has(id)) {
return true;
}
set.add(id);
}
return false;
},
soleId(arr,index){
let randomNum = Math.floor(100 + Math.random() * 900);
2024-03-12 09:42:08 +08:00
// if(this.sketchImg.id_){
if(this.sketchImg.id){
if(this.sketchImg.id == this.sketchImg.id_){
arr[index].id = Number(this.sketchImg.id_+(randomNum+""))
arr[index].changed = true
2024-03-12 09:42:08 +08:00
if(this.hasDuplicateId(arr)){
this.sketchImg.id_ = this.sketchImg.id
this.soleId(arr,index)
}
}else{
arr[index].id = this.sketchImg.id_
}
2023-12-22 10:57:12 +08:00
}else{
2024-03-12 09:42:08 +08:00
arr[index].id = this.current.id
2023-12-22 10:57:12 +08:00
}
2024-03-12 09:42:08 +08:00
// arr[index].id = this.sketchImg.id_? this.sketchImg.id_:this.current.id
return arr
2023-12-22 10:57:12 +08:00
},
2024-06-17 09:39:01 +08:00
deleteptints(item,index){
this.printsList.splice(index,1)
},
deleteSelectptints(item,index){
this.exhibitionList.print.splice(index,1)
},
deleteElements(item,index){
this.elementsList.splice(index,1)
},
deleteSelectElements(item,index){
this.exhibitionList.elements.splice(index,1)
},
setElemets(){
if(this.current.trims.prints && this.current.trims.prints.length == 0 && this.elementsList.length == 0)return message.info('请选择至少一张element')
let DesignElementsOperation = isMoible() ? this.$refs.DesignPrintMobile : this.$refs.DesignElementsOperation
DesignElementsOperation.init()
},
2023-09-12 10:11:27 +08:00
//提交
setPreview(){
let designItemDetail = JSON.parse(JSON.stringify(this.store.state.DesignDetailModule.designItemDetail))
let index
2023-10-11 17:34:14 +08:00
let data = JSON.parse(JSON.stringify(this.store.state.DesignDetailModule.designPreviewData))
2023-12-13 16:09:17 +08:00
// let bor = false
let zIndex = 10
2023-09-12 10:11:27 +08:00
designItemDetail.clothes.forEach((v,ind)=>{
if(v.id == this.current.id){
index = ind
2023-12-13 16:09:17 +08:00
// bor = true
}
if(v.priority){
if(zIndex < v.priority){
zIndex = v.priority
}
2023-09-12 10:11:27 +08:00
}
})
2024-05-27 17:57:37 +08:00
index = index? index:0
2023-12-13 16:09:17 +08:00
if(!this.current.id){
2024-05-27 17:57:37 +08:00
if(index){
data.designSingleItemDTOList[index].priority = zIndex+=1
}
2023-12-13 16:09:17 +08:00
}
if(this.type_ == 1){
2023-10-13 17:06:44 +08:00
if(data.designSingleItemDTOList[index].path != this.sketchImg.minIOPath && this.sketchImg.id_){
data.designSingleItemDTOList[index].offset = [0,0]
2024-05-27 17:57:37 +08:00
data.designSingleItemDTOList[index].scale = [1,1]
2023-10-13 17:06:44 +08:00
}
2023-12-22 10:57:12 +08:00
data.designSingleItemDTOList = this.soleId(data.designSingleItemDTOList,index)
this.sketchImg.id_ = data.designSingleItemDTOList[index].id
2023-10-11 17:34:14 +08:00
data.designSingleItemDTOList[index].path =this.sketchImg.minIOPath? this.sketchImg.minIOPath: this.current.minIOPath
2023-12-12 11:53:02 +08:00
data.designSingleItemDTOList[index].type =this.sketchImg.type? this.sketchImg.type: this.current.type
2023-12-13 16:09:17 +08:00
}else if(this.type_ == 2){
2023-10-11 17:34:14 +08:00
data.designSingleItemDTOList[index].printObject.prints = []
2023-12-13 16:09:17 +08:00
}else if(this.type_ == 3){
2024-05-16 09:41:16 +08:00
if(this.colorList[this.selectIndex]?.rgba?.r == undefined){
2023-12-20 17:03:42 +08:00
message.info(this.t('DesignDetailEnd.jsContent2'))
return
}
2024-05-16 09:41:16 +08:00
let color = `${this.colorList[this.selectIndex].rgba.r} ${this.colorList[this.selectIndex].rgba.g} ${this.colorList[this.selectIndex].rgba.b}`
2023-10-11 17:34:14 +08:00
data.designSingleItemDTOList[index].color = color
2024-06-17 09:39:01 +08:00
}else if(this.type_ == 4){
data.designSingleItemDTOList[index].trims = this.current.trims
2023-09-12 10:11:27 +08:00
}
2024-05-16 09:41:16 +08:00
if(this.colorList[this.selectIndex].gradient){
let gradient = this.colorList[this.selectIndex].gradient
gradient.colorImg = setGradual(gradient,320,700)
data.designSingleItemDTOList[index].gradient = gradient
}else{
delete data.designSingleItemDTOList[index].gradient
}
data.designSingleItemDTOList[index].designType = this.sketchImg.designType?this.sketchImg.designType:this.current.designType
2023-09-25 10:09:00 +08:00
data.timeZone = Intl.DateTimeFormat().resolvedOptions().timeZone
2023-09-12 10:11:27 +08:00
this.loadingShow = true
Https.axiosPost(Https.httpUrls.designSingle, data).then(
(rv) => {
let bor = false
2023-12-12 11:53:02 +08:00
rv.clothes.forEach((item)=>{
if(item.type != 'body'){
if(item.id == designItemDetail.clothes[index].id || item.id == this.sketchImg.id_){
designItemDetail.clothes[index].color = item.color
2024-05-16 09:41:16 +08:00
if(item.gradient){
designItemDetail.clothes[index].gradient = item.gradient
}else{
delete designItemDetail.clothes[index].gradient
}
designItemDetail.clothes[index].designType = item.designType
2024-06-17 09:39:01 +08:00
designItemDetail.clothes[index].trims = item.trims
designItemDetail.clothes[index].layersObject = item.layersObject
designItemDetail.clothes[index].minIOPath = item.minIOPath
designItemDetail.clothes[index].path = item.path
designItemDetail.clothes[index].id = item.id
designItemDetail.clothes[index].changed = item.changed?item.changed:false
designItemDetail.clothes[index].type = item.type
designItemDetail.clothes[index].printObject = item.printObject
bor = true
}else{
}
2023-12-15 11:10:32 +08:00
if(!this.current.id ){
designItemDetail.clothes[index].priority = zIndex
}
2023-12-12 11:53:02 +08:00
}
})
2023-10-11 17:34:14 +08:00
designItemDetail.currentFullBodyView = rv.currentFullBodyView
2023-10-13 17:06:44 +08:00
designItemDetail.ifSubmit = true
2023-10-11 17:34:14 +08:00
designItemDetail.clothes.forEach((item,index)=>{
let a
if(item.layersObject[0].imageCategory.indexOf("back") == -1){
a = item.layersObject[0]
item.layersObject[0] = item.layersObject[1]
item.layersObject[1] = a
}
2023-12-12 11:53:02 +08:00
item.layersObject[0].id = designItemDetail.clothes[index].layersObject[0].id
item.layersObject[1].id = designItemDetail.clothes[index].layersObject[1].id
2023-10-11 17:34:14 +08:00
})
2023-09-12 10:11:27 +08:00
this.loadingShow = false
2023-09-25 10:09:00 +08:00
this.store.commit("setDesignItemDetail", designItemDetail);
2023-10-11 17:34:14 +08:00
this.store.commit("setDesignPreviewData", data);
this.setRevocation(designItemDetail,data)
2023-09-12 10:11:27 +08:00
}
).catch(res=>{
this.loadingShow = false
});
}
2023-08-23 17:50:09 +08:00
}
})
</script>
<style lang="less" scoped>
.detail_modal_body_result{
width: 26%;
2023-09-12 10:11:27 +08:00
position: relative;
2023-08-23 17:50:09 +08:00
i{
2023-11-27 16:25:32 +08:00
font-size: var(--aida-fsize1-8);
display: flex;
align-items: center;
2023-08-23 17:50:09 +08:00
}
2023-09-12 10:11:27 +08:00
2023-08-23 17:50:09 +08:00
.upload_title{
display: flex;
margin-bottom: calc(1rem*1.2);
margin-top: calc(1rem*1.2);
2023-08-23 17:50:09 +08:00
&.upload_title:nth-child(1){
margin-top: 0;
}
span{
margin-left: calc(1rem*1.2);
2023-11-27 16:25:32 +08:00
font-size: var(--aida-fsize1-8);
2023-08-23 17:50:09 +08:00
color: #000000;
}
}
//模型和印花
.result_apparel_print{
height: 100%;
display: flex;
flex-direction: column;
.result_apparel_print_img{
2023-09-12 10:11:27 +08:00
position: relative;
2023-08-23 17:50:09 +08:00
flex: 1;
2023-09-25 10:09:00 +08:00
text-align: center;
2023-08-23 17:50:09 +08:00
img{
2023-09-25 10:09:00 +08:00
max-width: 100%;
max-height: 100%;
2023-09-12 10:11:27 +08:00
width: auto;
2023-09-25 10:09:00 +08:00
height: auto;
max-height: calc(35rem*1.2);
margin-top: calc(2rem*1.2);
2023-10-11 17:34:14 +08:00
width: 100%;
object-fit: contain;
2023-08-23 17:50:09 +08:00
}
.result_print_img{
2023-09-12 10:11:27 +08:00
transform: scale(.85);
2023-09-25 10:09:00 +08:00
transform-origin: center top;
2023-09-12 10:11:27 +08:00
cursor: pointer;
img:nth-child(1){
position: absolute;
}
2023-08-23 17:50:09 +08:00
}
}
}
//印花
.result_print{
display: flex;
justify-content: space-between;
height: calc(14rem*1.2);
2023-10-20 17:21:45 +08:00
>div{
display: flex;
flex-direction: column;
.print_left,.print_right{
display: flex;
flex: 1;
align-items: center;
2023-11-03 11:16:42 +08:00
align-items: flex-start;
2023-10-20 17:21:45 +08:00
}
}
2023-08-23 17:50:09 +08:00
.print_left{
2023-09-12 10:11:27 +08:00
position: relative;
2023-08-23 17:50:09 +08:00
img{
2023-09-12 10:11:27 +08:00
width: auto;
height: calc(8rem*1.2);
2023-08-23 17:50:09 +08:00
margin: auto;
2023-09-12 10:11:27 +08:00
display: block;
2023-08-23 17:50:09 +08:00
}
2023-09-12 10:11:27 +08:00
.delete_file_block{
display: none;
width: calc(3.2rem*1.2);
height: calc(3.2rem*1.2);
2023-09-12 10:11:27 +08:00
background: rgba(0,0,0,0.6);
border-radius: calc(0.4rem*1.2);
2023-09-12 10:11:27 +08:00
position: absolute;
top: calc(0.9rem*1.2);
right: calc(0.9rem*1.2);
2023-09-12 10:11:27 +08:00
text-align: center;
line-height: calc(3.2rem*1.2);
2023-09-12 10:11:27 +08:00
left: auto;
.icon-shanchu{
font-size: calc(1.6rem*1.2);
2023-09-12 10:11:27 +08:00
color: #fff;
}
}
&:hover .delete_file_block{
display: block;
}
2023-08-23 17:50:09 +08:00
}
.print_right{
2023-10-20 17:21:45 +08:00
2023-08-23 17:50:09 +08:00
.habit_Overal_Single {
display: flex;
align-items: center;
justify-content: center;
// margin: 2rem*1.2) 0;
2023-08-23 17:50:09 +08:00
transform: scale(.8);
// margin: 3rem*1.2) 0;
2023-08-23 17:50:09 +08:00
.habit_Overal_Single_text {
font-weight: 600;
color: rgba(0, 0, 0, 0.5);
&.active {
color: rgba(0, 0, 0, 0.7);
// font-weight: 900;
transform: scale(1.2);
}
}
:deep(.ant-switch) {
margin: 0 calc(1rem*1.2);
2023-08-23 17:50:09 +08:00
background-color: #efefef;
}
:deep(.ant-switch-checked) {
background-color: #000;
}
}
.habit_System_Designer {
margin-top: calc(4rem*1.2);
2023-08-23 17:50:09 +08:00
transform: scale(.8);
:deep(.ant-slider-track),
:deep(.ant-slider-rail) {
height: calc(.6rem*1.2);
2023-08-23 17:50:09 +08:00
background-color: #e1e1e1;
border-radius: calc(0.5rem*1.2);
2023-08-23 17:50:09 +08:00
}
:deep(.ant-slider .ant-slider-handle:not(.ant-tooltip-open)),
:deep(.ant-slider-handle) {
background-color: #2d2e76 !important;
border: none !important;
}
:deep(.ant-slider-handle:hover) {
box-shadow: 0 0 0 5px rgba(45, 46, 118, 0.2);
}
}
}
}
//颜色
.modal_img{
width: 100%;
overflow-x: hidden;
display: flex;
flex-wrap: wrap;
padding-left: calc(2rem*1.2);
2024-06-17 09:39:01 +08:00
align-content: flex-start;
2023-08-23 17:50:09 +08:00
&.modal_img::-webkit-scrollbar {
display: none;
}
.modal_img_item{
margin: 0 calc(1rem*1.2) calc(1rem*1.2) 0;
2023-08-23 17:50:09 +08:00
position: relative;
2023-12-20 17:03:42 +08:00
// cursor: pointer;
border: calc(0.1rem*1.2) solid #DCDCEC;
2023-12-20 17:03:42 +08:00
//放8个
height: calc(8.5rem*1.2);
width: calc(7rem*1.2);
// height: 32rem*1.2);
// width: 25rem*1.2);
2023-10-20 17:21:45 +08:00
overflow: hidden;
@media screen and (max-width: 1440px) {
&.modal_img_item {
line-height: 1.2;
}
}
2023-09-12 10:11:27 +08:00
box-sizing: border-box;
2023-08-23 17:50:09 +08:00
.color_content{
2023-09-12 10:11:27 +08:00
width: 100%;
2023-12-20 17:03:42 +08:00
//放8个
height: calc(4rem*1.2);
// height: 25rem*1.2);
2023-08-23 17:50:09 +08:00
}
.color_content_body{
.color_des{
// font-size: 1.8rem*1.2);
2023-08-23 17:50:09 +08:00
font-weight: 600;
2023-09-12 10:11:27 +08:00
white-space: nowrap;
width: 100%;
overflow: hidden;
text-overflow:ellipsis;
2023-08-23 17:50:09 +08:00
}
}
.select_upload_color{
border: calc(0.1rem*1.2) solid #343579;
2023-08-23 17:50:09 +08:00
}
.upload_color{
width: 100%;
height: 100%;
}
}
2023-09-12 10:11:27 +08:00
}
2024-06-17 09:39:01 +08:00
//elements
.result_apparel_elements{
height: 85%;
// height: 100%;
.modal_img{
height: calc(100%);
overflow-y: auto;
}
.modal_img_item{
display: flex;
justify-content: center;
align-items: center;
position: relative;
height: auto;
border: none;
img{
width: 100%;
object-fit: cover;
}
.delete_file_block{
display: none;
width: calc(3.2rem*1.2);
height: calc(3.2rem*1.2);
background: rgba(0,0,0,0.6);
border-radius: calc(0.4rem*1.2);
position: absolute;
top: calc(0.9rem*1.2);
right: calc(0.9rem*1.2);
text-align: center;
line-height: calc(3.2rem*1.2);
left: auto;
cursor: pointer;
.icon-shanchu{
font-size: calc(1.6rem*1.2);
color: #fff;
}
}
&:hover .delete_file_block{
display: block;
}
}
}
2023-09-12 10:11:27 +08:00
.subitOkPreviewBtn{
bottom: calc(4rem*1.2);
2023-09-12 10:11:27 +08:00
position: absolute;
&.active{
opacity: .5;
pointer-events:none;
}
2023-08-23 17:50:09 +08:00
}
}
</style>