Bladeren bron

工区开工预付款计量期

ZaiZai 1 jaar geleden
bovenliggende
commit
7c2f02bed2
2 gewijzigde bestanden met toevoegingen van 248 en 8 verwijderingen
  1. 121 0
      src/views/periods/start-work/components/order/dataModal.vue
  2. 127 8
      src/views/periods/start-work/phase.vue

+ 121 - 0
src/views/periods/start-work/components/order/dataModal.vue

@@ -0,0 +1,121 @@
+<template>
+    <hc-dialog is-to-body widths="500px" :show="isShow" title="开工预付款计量单新增" @save="modalSave" @close="modalClose">
+        <el-scrollbar>
+            <hc-card-item>
+                <el-form ref="baseFormRef" :model="baseForm" :rules="baseFormRules" label-position="top" label-width="auto">
+                    <el-form-item label="计量期:">
+                        <el-select v-model="baseForm.key1" block>
+                            <el-option label="第一期" value="1" />
+                            <el-option label="第二期" value="2" />
+                        </el-select>
+                    </el-form-item>
+                    <el-form-item label="业务日期:">
+                        <el-date-picker v-model="baseForm.key2" class="block" format="YYYY-MM-DD" type="date" value-format="YYYY-MM-DD" disabled />
+                    </el-form-item>
+                    <el-form-item label="计量金额:">
+                        <el-input v-model="baseForm.key3" />
+                    </el-form-item>
+                    <el-form-item label="开工预付款总额:">
+                        <el-input v-model="baseForm.key4" />
+                    </el-form-item>
+                    <el-form-item label="申请依据:">
+                        <el-input v-model="baseForm.key5" :autosize="{ minRows: 2, maxRows: 6 }" type="textarea" />
+                    </el-form-item>
+                </el-form>
+            </hc-card-item>
+            <!-- 附件列表 -->
+            <hc-card-item class="mt-3" title="附件列表" extra-text="可上传:图片、Excel、PDF、Word文件">
+                <el-form :model="baseForm" label-position="top">
+                    <el-form-item label="">
+                        <hc-form-upload type="list" :src="baseForm.key11" />
+                    </el-form-item>
+                </el-form>
+            </hc-card-item>
+        </el-scrollbar>
+    </hc-dialog>
+</template>
+
+<script setup>
+import { nextTick, ref, watch } from 'vue'
+
+const props = defineProps({
+    ids: {
+        type: [String, Number],
+        default: '',
+    },
+})
+
+//事件
+const emit = defineEmits(['close'])
+
+//双向绑定
+// eslint-disable-next-line no-undef
+const isShow = defineModel('modelValue', {
+    default: false,
+})
+
+//监听
+watch(() => [
+    props.ids,
+], ([ids]) => {
+    console.log('ids', ids)
+}, { immediate: true })
+
+//监听
+watch(isShow, (val) => {
+    if (val) {
+        detailsModalShow()
+    }
+})
+
+const detailsModalShow = () => {
+    nextTick(() => {
+        window.$split(['#hc_modal_tree', '#hc_modal_form'], {
+            sizes: [30, 70],
+            snapOffset: 0,
+            minSize: [170, 500],
+        })
+    })
+}
+
+//数据格式
+const treeProps = {
+    label: 'name',
+    children: 'children',
+    isLeaf: 'leaf',
+}
+
+//懒加载的数据
+const treeLoadNode = ({ level }, resolve) => {
+    if (level === 0) {
+        return resolve([{ name: 'region' }])
+    }
+    if (level > 3) {
+        return resolve([])
+    }
+    setTimeout(() => {
+        resolve([
+            { name: 'leaf', leaf: true },
+            { name: 'zone' },
+        ])
+    }, 500)
+}
+
+//基础表单
+const baseFormRef = ref(null)
+const baseForm = ref({})
+const baseFormRules = {}
+
+const modalSave = () => {
+    modalClose()
+}
+
+const modalClose = () => {
+    isShow.value = false
+    emit('close')
+}
+</script>
+
+<style scoped lang="scss">
+
+</style>

+ 127 - 8
src/views/periods/start-work/phase.vue

@@ -1,29 +1,148 @@
 <template>
-    <hc-card>
-        <template #header>
-            1
-        </template>
+    <hc-card title="开工预付款计量期">
         <template #extra>
-            <el-button hc-btn type="primary">
-                <HcIcon name="add" />
-                <span>新增</span>
+            <el-button hc-btn type="primary" @click="editModalClick">
+                <HcIcon name="edit" />
+                <span>编辑</span>
             </el-button>
         </template>
-        1111
+        <hc-table :column="tableColumn" :datas="tableData" :loading="tableLoading">
+            <template #action="{ row }">
+                <el-link type="danger">锁定</el-link>
+            </template>
+        </hc-table>
+        <template #action>
+            <hc-pages :pages="searchForm" @change="pageChange" />
+        </template>
+
+        <!-- 编辑修改 -->
+        <hc-dialog is-to-body is-table is-footer-center widths="1200px" :show="editModalShow" title="新增预付款计量期" @save="editModalSave" @close="editModalClose">
+            <hc-card-item>
+                <template #header>
+                    <el-tooltip :visible="editVisible" effect="light" placement="bottom-start">
+                        <template #content>
+                            <div class="text-sm text-red">
+                                1.日期不能为空<br>
+                                2.已经存在数据或者被锁定的计量期不能删除数据
+                            </div>
+                        </template>
+                        <el-button type="danger" @mouseenter="editVisible = true" @mouseleave="editVisible = false">
+                            <HcIcon name="question" />
+                            <span>编辑说明</span>
+                        </el-button>
+                    </el-tooltip>
+                </template>
+                <template #extra>
+                    <el-button type="primary">
+                        <HcIcon name="page-separator" :line="false" />
+                        <span>插入上一行</span>
+                    </el-button>
+                    <el-button type="primary">
+                        <HcIcon name="page-separator" :line="false" />
+                        <span>插入下一行</span>
+                    </el-button>
+                </template>
+                <hc-table :column="tableEditColumn" :datas="tableEditData">
+                    <template #key1="{ row }">
+                        <hc-table-input v-model="row.key1" disabled />
+                    </template>
+                    <template #key2="{ row }">
+                        <hc-table-input v-model="row.key2" disabled />
+                    </template>
+                    <template #key3="{ row }">
+                        <el-select v-model="row.key3" placeholder="选择年份" filterable disabled block>
+                            <el-option v-for="item in yearData" :key="item" :label="item" :value="item" />
+                        </el-select>
+                    </template>
+                    <template #key4="{ row }">
+                        <el-select v-model="row.key4" placeholder="选择月份" filterable disabled block>
+                            <el-option v-for="item in monthData" :key="item" :label="item" :value="item" />
+                        </el-select>
+                    </template>
+                    <template #key5="{ row }">
+                        <el-date-picker v-model="row.key5" class="block" format="YYYY-MM-DD" type="date" value-format="YYYY-MM-DD" disabled />
+                    </template>
+                    <template #action="{ row }">
+                        <el-button plain size="small" type="danger">删除</el-button>
+                    </template>
+                </hc-table>
+            </hc-card-item>
+        </hc-dialog>
     </hc-card>
 </template>
 
 <script setup>
 import { onMounted, ref } from 'vue'
+import { getMonthList, getYearList } from 'js-fast-way'
+import dayjs from 'dayjs'
 
 defineOptions({
     name: 'PeriodsStartWorkPhase',
 })
 
+//获取年月等相关日期数据
+const year = Number(dayjs().format('YYYY')) + 8
+const yearData = getYearList(year, 2010)
+const monthData = getMonthList()
+
 //渲染完成
 onMounted(() => {
 
 })
+
+//搜索表单
+const searchForm = ref({
+    current: 1, size: 10, total: 0,
+})
+
+//分页
+const pageChange = ({ current, size }) => {
+    searchForm.value.current = current
+    searchForm.value.size = size
+}
+
+//表格数据
+const tableLoading = ref(false)
+const tableColumn = ref([
+    { key: 'key1', name: '期号' },
+    { key: 'key2', name: '期名称' },
+    { key: 'key3', name: '年份' },
+    { key: 'key4', name: '月份' },
+    { key: 'key5', name: '报表打印日期' },
+    { key: 'action', name: '操作', width: 80 },
+])
+const tableData = ref([
+    { key1: '1111' },
+])
+
+
+//计量期编辑
+const editVisible = ref(false)
+const editModalShow = ref(false)
+const editModalClick = () => {
+    editModalShow.value = true
+}
+
+//编辑的表格
+const tableEditColumn = [
+    { key: 'key1', name: '期号' },
+    { key: 'key2', name: '期名称' },
+    { key: 'key3', name: '年份' },
+    { key: 'key4', name: '月份' },
+    { key: 'key5', name: '报表打印日期' },
+    { key: 'action', name: '操作', width: 80, align: 'center' },
+]
+const tableEditData = ref([
+    { key1: '11' },
+    { key1: '222' },
+])
+
+const editModalSave = () => {
+    editModalClose()
+}
+const editModalClose = () => {
+    editModalShow.value = false
+}
 </script>
 
 <style scoped lang="scss">