You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
636 lines
22 KiB
Vue
636 lines
22 KiB
Vue
<template>
|
|
<div class="p-2">
|
|
<el-card shadow="never">
|
|
<el-form label-width="120px" label-position="right" :inline="true" :model="queryForm" class="demo-form-inline">
|
|
<el-form-item label="调拨单号">
|
|
<el-input v-model="queryForm.allocateOrderCode" placeholder="输入调拨单号" clearable/>
|
|
</el-form-item>
|
|
<el-form-item>
|
|
<el-button :loading="parentTableLoad" type="primary" @click="query">查询</el-button>
|
|
<el-button @click="reset">重置</el-button>
|
|
</el-form-item>
|
|
</el-form>
|
|
</el-card>
|
|
|
|
<el-card style="margin-top: 8px" shadow="never">
|
|
<template #header>
|
|
<el-row :gutter="10" class="mb8">
|
|
<el-col :span="1.5">
|
|
<el-button type="primary" plain icon="Plus" @click="parentTableAdd">新增</el-button>
|
|
</el-col>
|
|
<el-col :span="1.5">
|
|
<el-button type="success" plain icon="Edit" :disabled="ids.length !== 1" @click="parentTableUpdate()">修改
|
|
</el-button>
|
|
</el-col>
|
|
<el-col :span="1.5">
|
|
<el-button type="danger" plain icon="Delete" :disabled="ids.length < 1" @click="parentTableDelete()">删除
|
|
</el-button>
|
|
</el-col>
|
|
<!-- <el-col :span="1.5">-->
|
|
<!-- <el-button type="warning" plain icon="Download" @click="handleExport">导出</el-button>-->
|
|
<!-- </el-col>-->
|
|
<right-toolbar v-model:showSearch="showSearch" :columns="columns" :search="true"
|
|
@queryTable="getParentTable"></right-toolbar>
|
|
</el-row>
|
|
</template>
|
|
<el-table v-loading="parentTableLoad" :data="parentTableData" style="width: 100%" highlight-current-row
|
|
@current-change="parentTableCellClick"
|
|
@selection-change="selectionChange" ref="parentTableRef">
|
|
<el-table-column type="selection" width="55"/>
|
|
<el-table-column label="表主键" align="center" prop="aoId" v-if="false"/>
|
|
<el-table-column label="调拨单号" align="center" prop="allocateOrderCode"/>
|
|
<el-table-column label="物料大类" align="center" prop="materialCategories">
|
|
<template #default="scope">
|
|
<dict-tag :options="material_mategories" :value="scope.row.materialCategories"/>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column label="出库仓库ID" align="center" prop="planWarehouseCode"/>
|
|
<el-table-column label="工单状态" align="center" prop="orderStatus">
|
|
<template #default="scope">
|
|
<dict-tag :options="wms_allocate_status" :value="scope.row.orderStatus"/>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column label="入库仓库ID" align="center" prop="targetWarehouseCode"/>
|
|
<el-table-column label="审核人" align="center" prop="auditBy"/>
|
|
<el-table-column label="审核时间" align="center" prop="auditTime" width="180">
|
|
<template #default="scope">
|
|
<span>{{ parseTime(scope.row.auditTime, '{y}-{m}-{d} {h}:{i}:{s}') }}</span>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column label="审核状态" align="center" prop="auditStatus">
|
|
<template #default="scope">
|
|
<dict-tag :options="approve_status" :value="scope.row.auditStatus"/>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column label="审核意见" align="center" prop="auditComments"/>
|
|
<el-table-column label="是否创建出库单" align="center" prop="createOut">
|
|
<template #default="scope">
|
|
<dict-tag :options="wms_allocate_create" :value="scope.row.createOut"/>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column label="出库单号" align="center" prop="outCode"/>
|
|
<el-table-column label="是否创建入库单" align="center" prop="createIn">
|
|
<template #default="scope">
|
|
<dict-tag :options="wms_allocate_create" :value="scope.row.createIn"/>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column label="入库单号" align="center" prop="inCode"/>
|
|
<el-table-column label="入库方式" align="center" prop="inMethod">
|
|
<template #default="scope">
|
|
<dict-tag :options="wms_allocate_way" :value="scope.row.inMethod"/>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column label="操作" fixed="right" width="200">
|
|
<template #default="scope">
|
|
<!-- <el-button size="small" @click.stop="viewDetails(scope.row)">-->
|
|
<!-- 查看-->
|
|
<!-- </el-button>-->
|
|
<el-button size="small" @click.stop="parentTableUpdate(scope.row)">
|
|
修改
|
|
</el-button>
|
|
<el-button
|
|
size="small"
|
|
type="danger"
|
|
@click.stop="parentTableDelete(scope.row)"
|
|
>
|
|
删除
|
|
</el-button>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table>
|
|
<pagination v-show="parentTableTotal > 0" :total="parentTableTotal" v-model:page="queryForm.pageNum"
|
|
v-model:limit="queryForm.pageSize" @pagination="getParentTable"/>
|
|
</el-card>
|
|
|
|
<el-card style="margin-top: 8px" shadow="never">
|
|
<el-table :data="childrenTableData" style="width: 100%" v-loading="childrenTableLoad">
|
|
<el-table-column label="调拨子表主键" align="center" prop="aoDId" v-if="false"/>
|
|
<el-table-column label="调拨单号" align="center" prop="allocateCode"/>
|
|
<el-table-column label="物料id" align="center" prop="materialId"/>
|
|
<el-table-column label="调拨数量" align="center" prop="allocateOrderQty"/>
|
|
<el-table-column label="erp同步状态" align="center" prop="erpSynchronousStatus"/>
|
|
<el-table-column label="erp同步数量" align="center" prop="erpSynchronousQty"/>
|
|
<el-table-column label="操作" fixed="right" width="200">
|
|
<template #default="scope">
|
|
<!-- <el-button size="small" @click="childrenTableUpdate( scope.row)">-->
|
|
<!-- 修改-->
|
|
<!-- </el-button>-->
|
|
<el-button
|
|
size="small"
|
|
type="danger"
|
|
@click="childrenTableUDelete(scope.row)"
|
|
>
|
|
删除
|
|
</el-button>
|
|
</template>
|
|
</el-table-column>
|
|
</el-table>
|
|
</el-card>
|
|
|
|
<el-dialog v-model="dialogVisible" :title="dialogTitle" width="100%" fullscreen>
|
|
<el-card shadow="never">
|
|
<el-form :model="dialogForm" :inline="true" label-width="120px" :disabled="isView">
|
|
<el-form-item label="物料大类" prop="materialCategories">
|
|
|
|
<el-select
|
|
v-model="dialogForm.materialCategories"
|
|
placeholder="选择物料大类"
|
|
@change="setMaterialList"
|
|
>
|
|
<el-option
|
|
v-for="i in mes_material_categories"
|
|
:label="i.label"
|
|
:value="i.value"
|
|
:key="i.value"
|
|
/>
|
|
</el-select>
|
|
</el-form-item>
|
|
<el-form-item label="出库仓库" prop="planWarehouseId">
|
|
<el-select v-model="dialogForm.planWarehouseId" placeholder="请选择所属仓库">
|
|
<el-option
|
|
v-for="item in baseStoreList"
|
|
:key="item.warehouseId"
|
|
:label="item.warehouseName"
|
|
:value="item.warehouseId"
|
|
></el-option>
|
|
</el-select>
|
|
</el-form-item>
|
|
<el-form-item label="入库仓库" prop="targetWarehouseId">
|
|
<el-select v-model="dialogForm.targetWarehouseId" placeholder="请选择所属仓库">
|
|
<el-option
|
|
v-for="item in baseStoreList"
|
|
:key="item.warehouseId"
|
|
:label="item.warehouseName"
|
|
:value="item.warehouseId"
|
|
></el-option>
|
|
</el-select>
|
|
</el-form-item>
|
|
<el-form-item label="审核人" prop="auditBy">
|
|
<el-select v-model="dialogForm.auditBy" placeholder="请选择审核人">
|
|
<el-option
|
|
v-for="item in userList"
|
|
:key="item.userId"
|
|
:label="item.userName"
|
|
:value="item.userName"
|
|
/>
|
|
</el-select>
|
|
</el-form-item>
|
|
</el-form>
|
|
</el-card>
|
|
<el-card style="margin-top: 8px" shadow="never">
|
|
<el-row :gutter="10" class="mb8">
|
|
<el-col :span="1.5">
|
|
<el-button type="primary" plain icon="Plus" @click="addDialogTableCell">新增</el-button>
|
|
</el-col>
|
|
</el-row>
|
|
<el-table :data="dialogtable" style="width: 100%">
|
|
<el-table-column label="字段1" prop="date" v-if="false">
|
|
<template #default="scope">
|
|
<el-select
|
|
v-model="scope.row.date"
|
|
placeholder="Select"
|
|
>
|
|
<el-option
|
|
v-for="i in mes_material_categories"
|
|
:label="i.materialName"
|
|
:value="i.materialId"
|
|
:key="i.materialId"
|
|
/>
|
|
</el-select>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column label="物料名称" prop="materialId">
|
|
<template #default="scope">
|
|
<el-select
|
|
v-model="scope.row.materialId"
|
|
placeholder="选择物料"
|
|
style="width: 240px"
|
|
>
|
|
<el-option
|
|
v-for="i in materialList"
|
|
:label="i.materialName"
|
|
:value="i.materialId"
|
|
:key="i.materialId"
|
|
/>
|
|
</el-select>
|
|
</template>
|
|
</el-table-column>
|
|
<el-table-column label="调拨数量" prop="allocateOrderQty">
|
|
<template #default="scope">
|
|
<el-input v-model="scope.row.allocateOrderQty" style="width: 240px" placeholder="输入调拨数量"/>
|
|
</template>
|
|
</el-table-column>
|
|
<!-- <el-table-column label="erp同步状态" prop="erpSynchronousStatus">-->
|
|
<!-- <template #default="scope">-->
|
|
<!-- <el-select-->
|
|
<!-- v-model="scope.row.erpSynchronousStatus"-->
|
|
<!-- placeholder="选择erp同步状态"-->
|
|
<!-- >-->
|
|
<!-- <el-option-->
|
|
<!-- label="1"-->
|
|
<!-- value="1"-->
|
|
<!-- />-->
|
|
<!-- <el-option-->
|
|
<!-- label="2"-->
|
|
<!-- value="2"-->
|
|
<!-- />-->
|
|
<!-- </el-select>-->
|
|
<!-- </template>-->
|
|
<!-- </el-table-column>-->
|
|
</el-table>
|
|
</el-card>
|
|
<template #footer>
|
|
<div class="dialog-footer">
|
|
<el-button @click="dialogVisible = false">关闭</el-button>
|
|
<el-button type="primary" @click="dialogSubmit">
|
|
确定
|
|
</el-button>
|
|
</div>
|
|
</template>
|
|
</el-dialog>
|
|
|
|
<el-dialog v-model="parentTableInfoVisible" title="修改父表格" width="40%">
|
|
<el-form :model="parentTableInfoForm" label-width="120px">
|
|
<el-form-item label="id" prop="planWarehouseId"v-if="false">
|
|
<el-input v-model="parentTableInfoForm.aoid"></el-input>
|
|
</el-form-item>
|
|
<el-form-item label="物料大类" prop="materialCategories">
|
|
<el-select
|
|
v-model="parentTableInfoForm.materialCategories"
|
|
placeholder="选择物料大类"
|
|
@change="setMaterialList"
|
|
>
|
|
<el-option
|
|
v-for="i in mes_material_categories"
|
|
:label="i.label"
|
|
:value="i.value"
|
|
:key="i.value"
|
|
/>
|
|
</el-select>
|
|
</el-form-item>
|
|
<el-form-item label="出库仓库" prop="planWarehouseId">
|
|
<el-select v-model="parentTableInfoForm.planWarehouseId" placeholder="请选择所属仓库">
|
|
<el-option
|
|
v-for="item in baseStoreList"
|
|
:key="item.warehouseId"
|
|
:label="item.warehouseName"
|
|
:value="item.warehouseId"
|
|
></el-option>
|
|
</el-select>
|
|
</el-form-item>
|
|
<el-form-item label="入库仓库" prop="targetWarehouseId">
|
|
<el-select v-model="parentTableInfoForm.targetWarehouseId" placeholder="请选择所属仓库">
|
|
<el-option
|
|
v-for="item in baseStoreList"
|
|
:key="item.warehouseId"
|
|
:label="item.warehouseName"
|
|
:value="item.warehouseId"
|
|
></el-option>
|
|
</el-select>
|
|
</el-form-item>
|
|
<el-form-item label="审核人" prop="auditBy">
|
|
<el-select v-model="parentTableInfoForm.auditBy" placeholder="请选择审核人">
|
|
<el-option
|
|
v-for="item in userList"
|
|
:key="item.userId"
|
|
:label="item.userName"
|
|
:value="item.userName"
|
|
/>
|
|
</el-select>
|
|
</el-form-item>
|
|
</el-form>
|
|
<template #footer>
|
|
<div class="dialog-footer">
|
|
<el-button @click="parentTableInfoVisible = false">关闭</el-button>
|
|
<el-button type="primary" @click="parentTableInfoSubmit">
|
|
确定
|
|
</el-button>
|
|
</div>
|
|
</template>
|
|
</el-dialog>
|
|
|
|
<el-dialog v-model="childrenTableInfoVisible" title="修改子表格" width="40%">
|
|
<el-form :model="childrenTableInfoForm" label-width="120px">
|
|
<el-form-item label="物料大类" prop="materialCategories">
|
|
<el-select
|
|
v-model="childrenTableInfoForm.materialCategories"
|
|
placeholder="选择物料大类"
|
|
@change="setMaterialList"
|
|
>
|
|
<el-option
|
|
v-for="i in mes_material_categories"
|
|
:label="i.label"
|
|
:value="i.value"
|
|
:key="i.value"
|
|
/>
|
|
</el-select>
|
|
</el-form-item>
|
|
<el-form-item label="出库仓库" prop="planWarehouseId">
|
|
<el-select v-model="childrenTableInfoForm.planWarehouseId" placeholder="请选择所属仓库">
|
|
<el-option
|
|
v-for="item in baseStoreList"
|
|
:key="item.warehouseId"
|
|
:label="item.warehouseName"
|
|
:value="item.warehouseId"
|
|
></el-option>
|
|
</el-select>
|
|
</el-form-item>
|
|
<el-form-item label="入库仓库" prop="targetWarehouseId">
|
|
<el-select v-model="childrenTableInfoForm.targetWarehouseId" placeholder="请选择所属仓库">
|
|
<el-option
|
|
v-for="item in baseStoreList"
|
|
:key="item.warehouseId"
|
|
:label="item.warehouseName"
|
|
:value="item.warehouseId"
|
|
></el-option>
|
|
</el-select>
|
|
</el-form-item>
|
|
<el-form-item label="审核人" prop="auditBy">
|
|
<el-select v-model="childrenTableInfoForm.auditBy" placeholder="请选择审核人">
|
|
<el-option
|
|
v-for="item in userList"
|
|
:key="item.userId"
|
|
:label="item.userName"
|
|
:value="item.userName"
|
|
/>
|
|
</el-select>
|
|
</el-form-item>
|
|
</el-form>
|
|
<template #footer>
|
|
<div class="dialog-footer">
|
|
<el-button @click="childrenTableInfoVisible = false">关闭</el-button>
|
|
<el-button type="primary" @click="childrenTableInfoSubmit">
|
|
确定
|
|
</el-button>
|
|
</div>
|
|
</template>
|
|
</el-dialog>
|
|
</div>
|
|
</template>
|
|
|
|
<script setup name="Linkage" lang="ts">
|
|
import {
|
|
allocateOrderDetailList,
|
|
allocateOrderlList,
|
|
allocateOrder,
|
|
viewAllocateOrder,
|
|
addAllocateOrder,
|
|
addAllocateOrderDetail,
|
|
getMaterialList, viewAllocateOrderDetail, delAllocateOrderDetail, allocateOrderUpdate
|
|
} from '@/api/wms/linkage'
|
|
|
|
import {reactive} from 'vue'
|
|
import {ElMessage, ElMessageBox} from 'element-plus'
|
|
import {getBaseWarehouseList} from "@/api/wms/baseWarehouse";
|
|
import {UserVO} from "@/api/system/user/types";
|
|
import {listUser} from "@/api/system/user";
|
|
|
|
const {proxy} = getCurrentInstance() as ComponentInternalInstance;
|
|
const {
|
|
approve_status,
|
|
material_mategories,
|
|
mes_material_categories,
|
|
wms_allocate_status,
|
|
wms_allocate_create,
|
|
wms_allocate_way
|
|
} = toRefs<any>(proxy?.useDict('approve_status', 'material_mategories', 'mes_material_categories', 'wms_allocate_status', 'wms_allocate_create', 'wms_allocate_way'));
|
|
|
|
|
|
interface User {
|
|
date: string
|
|
name: string
|
|
address: string
|
|
}
|
|
|
|
const parentTableTotal = ref(0)
|
|
const dialogVisible = ref(false)
|
|
const parentTableInfoVisible = ref(false)
|
|
const childrenTableInfoSubmit = ref(false)
|
|
const dialogTitle = ref('添加')
|
|
const dialogForm = ref({})
|
|
const parentTableInfoForm = ref({})
|
|
const childrenTableInfoForm = ref({})
|
|
|
|
const queryForm = ref({
|
|
allocateCode: '',
|
|
pageNum: 1,
|
|
pageSize: 10
|
|
})
|
|
const parentTableRef = ref()
|
|
const parentTableData = ref([])
|
|
const ids = ref([])
|
|
const childrenTableData = ref([])
|
|
const dialogtable = ref([])
|
|
const baseStoreList = ref([]);
|
|
const userList = ref([]);
|
|
const materialList = ref([]);
|
|
const parentTableLoad = ref(false)
|
|
const childrenTableLoad = ref(false)
|
|
const isView = ref(false)
|
|
const partntTableSelectCell = ref({})
|
|
|
|
// 获取仓库
|
|
getBaseWarehouseList().then(e => {
|
|
baseStoreList.value = e.data
|
|
})
|
|
listUser().then(e => {
|
|
userList.value = e.rows;
|
|
})
|
|
|
|
// 获取父表格数据
|
|
const getParentTable = async () => {
|
|
parentTableLoad.value = true
|
|
await allocateOrderlList(queryForm.value).then(async (e) => {
|
|
parentTableLoad.value = false
|
|
parentTableData.value = e.rows
|
|
parentTableTotal.value = e.total
|
|
if (e.rows.length > 0) {
|
|
parentTableRef.value.setCurrentRow(e.rows[0])
|
|
await getChildrenTable({allocateCode: e.rows[0].allocateOrderCode})
|
|
} else {
|
|
childrenTableData.value = []
|
|
}
|
|
})
|
|
}
|
|
|
|
// 获取子表格数据
|
|
const getChildrenTable = async (form) => {
|
|
childrenTableLoad.value = true
|
|
await allocateOrderDetailList(form).then(e => {
|
|
childrenTableLoad.value = false
|
|
childrenTableData.value = e.rows
|
|
parentTableTotal.value = e.total
|
|
})
|
|
}
|
|
|
|
getParentTable()
|
|
|
|
// 查询
|
|
const query = async () => {
|
|
ids.value = []
|
|
parentTableRef.value?.clearSelection()
|
|
await getParentTable()
|
|
}
|
|
const reset = () => {
|
|
queryForm.value = {
|
|
allocateOrderCode: ''
|
|
}
|
|
}
|
|
|
|
// 父表格行点击
|
|
const parentTableCellClick = async (e) => {
|
|
partntTableSelectCell.value = e
|
|
await getChildrenTable({allocateCode: e.allocateOrderCode})
|
|
}
|
|
|
|
// 表格多选
|
|
const selectionChange = (e) => {
|
|
ids.value = e.map(v => v.aoId)
|
|
}
|
|
// 查看
|
|
const viewDetails = (e) => {
|
|
isView.value = true
|
|
dialogVisible.value = true
|
|
viewAllocateOrder(e.aoId).then(v => {
|
|
dialogForm.value = v.data
|
|
})
|
|
}
|
|
|
|
// 父表格新增
|
|
const parentTableAdd = () => {
|
|
dialogVisible.value = true
|
|
dialogForm.value = {}
|
|
dialogtable.value = []
|
|
}
|
|
// 父表格修改
|
|
const parentTableUpdate = async (e) => {
|
|
let id = ref(null)
|
|
if (e) {
|
|
id.value = e.aoId
|
|
} else {
|
|
id.value = ids.value?.[0]
|
|
}
|
|
if (!id.value) return
|
|
parentTableInfoForm.value = (await viewAllocateOrder(id.value)).data
|
|
parentTableInfoVisible.value = true
|
|
}
|
|
// 父表格删除
|
|
const parentTableDelete = async (e) => {
|
|
const delList = ref([])
|
|
if (e) {
|
|
delList.value = [e.aoId]
|
|
} else {
|
|
delList.value = ids.value
|
|
}
|
|
ElMessageBox.confirm(
|
|
'确定要删除这些数据吗?',
|
|
'Warning',
|
|
{
|
|
confirmButtonText: '确定',
|
|
cancelButtonText: '取消',
|
|
type: 'warning',
|
|
}
|
|
)
|
|
.then(async () => {
|
|
await allocateOrder(delList.value.toString()).then(e => {
|
|
ElMessage({
|
|
type: 'success',
|
|
message: '删除完成',
|
|
})
|
|
getParentTable()
|
|
})
|
|
})
|
|
.catch(() => {
|
|
ElMessage({
|
|
type: 'info',
|
|
message: '取消',
|
|
})
|
|
})
|
|
|
|
}
|
|
|
|
// 获取物料列表
|
|
const setMaterialList = (materialCategories) => {
|
|
getMaterialList({materialCategories}).then(e => {
|
|
materialList.value = e.data
|
|
})
|
|
}
|
|
|
|
// 添加子表格行
|
|
const addDialogTableCell = () => {
|
|
dialogtable.value.push({})
|
|
}
|
|
|
|
// 新增提交
|
|
const dialogSubmit = () => {
|
|
|
|
addAllocateOrder(dialogForm.value).then(e => {
|
|
addAllocateOrderDetail(dialogtable.value.map(item => {
|
|
return {...item, allocateCode: e.msg,}
|
|
}
|
|
)
|
|
).then(v => {
|
|
dialogVisible.value = false
|
|
getParentTable()
|
|
})
|
|
|
|
})
|
|
}
|
|
|
|
const parentTableInfoSubmit = () =>{
|
|
allocateOrderUpdate(parentTableInfoForm.value).then(e=>{
|
|
ElMessage({
|
|
type: 'success',
|
|
message: '修改完成',
|
|
})
|
|
parentTableInfoVisible.value = false
|
|
getParentTable()
|
|
})
|
|
}
|
|
|
|
// 子表格修改
|
|
const childrenTableUpdate = async (e) => {
|
|
childrenTableInfoForm.value = (await viewAllocateOrderDetail(e.aoDId)).data
|
|
childrenTableInfoVisible.value = true
|
|
}
|
|
|
|
|
|
// 子表格删除
|
|
const childrenTableUDelete = (e) => {
|
|
|
|
ElMessageBox.confirm(
|
|
'确定要删除这些数据吗?',
|
|
'Warning',
|
|
{
|
|
confirmButtonText: '确定',
|
|
cancelButtonText: '取消',
|
|
type: 'warning',
|
|
}
|
|
)
|
|
.then(async () => {
|
|
await delAllocateOrderDetail(e.aoDId).then(async (e) => {
|
|
ElMessage({
|
|
type: 'success',
|
|
message: '删除完成',
|
|
})
|
|
await getChildrenTable({allocateCode: partntTableSelectCell.value.allocateOrderCode})
|
|
})
|
|
})
|
|
.catch(() => {
|
|
ElMessage({
|
|
type: 'info',
|
|
message: '取消',
|
|
})
|
|
})
|
|
}
|
|
</script>
|
|
<style>
|
|
.demo-form-inline .el-input {
|
|
--el-input-width: 220px;
|
|
}
|
|
|
|
.demo-form-inline .el-select {
|
|
--el-select-width: 220px;
|
|
}
|
|
</style>
|