DeviceProfileStep1.vue 2.08 KB
<template>
  <div class="step1">
    <div class="step1-form">
      <BasicForm @register="register" />
    </div>
  </div>
</template>
<script lang="ts">
  import { defineComponent, watch, onMounted } from 'vue';
  import { BasicForm, useForm } from '/@/components/Form';
  import { step1Schemas } from './data';
  import { Select, Input, Divider } from 'ant-design-vue';

  export default defineComponent({
    components: {
      BasicForm,
      [Select.name]: Select,
      [Input.name]: Input,
      [Input.Group.name]: Input.Group,
      [Divider.name]: Divider,
    },
    emits: ['next', 'resetFunc'],
    props: {
      echoStep1: Object,
    },
    setup(props, { emit }) {
      const [register, { validate, setFieldsValue, resetFields }] = useForm({
        labelWidth: 100,
        schemas: step1Schemas,
        actionColOptions: {
          span: 14,
        },
        showResetButton: false,
        submitButtonOptions: {
          text: '下一步',
        },
        submitFunc: customSubmitFunc,
        // resetFunc: customResetFunc,
      });
      onMounted(() => {
        setFieldsValue({ ...props.echoStep1 });
      });

      watch(
        () => props.echoStep1,
        (newV) => {
          setFieldsValue({ ...newV });
        }
      );
      async function customSubmitFunc() {
        try {
          const values = await validate();
          emit('next', values);
        } catch (error) {}
      }

      const customResetFunc = async () => {
        await resetFields();
        // try {
        //   emit('resetFunc', resetValue);
        // } catch (error) {}
      };

      return { register, customResetFunc };
    },
  });
</script>
<style lang="less" scoped>
  .step1 {
    &-form {
      width: 500px;
      margin: 0 auto;
    }

    h3 {
      margin: 0 0 12px;
      font-size: 16px;
      line-height: 32px;
      color: @text-color;
    }

    h4 {
      margin: 0 0 4px;
      font-size: 14px;
      line-height: 22px;
      color: @text-color;
    }

    p {
      color: @text-color;
    }
  }

  .pay-select {
    width: 20%;
  }

  .pay-input {
    width: 70%;
  }
</style>