Skip to content
Snippets Groups Projects
OfferPage.vue 5.43 KiB
Newer Older
  • Learn to ignore specific revisions
  • fz2907's avatar
    fz2907 committed
    <template>
      <el-form
        ref="ruleFormRef"
        :model="ruleForm"
        :rules="rules"
        label-width="180px"
        :label-position="'right'"
        class="demo-ruleForm"
        :size="formSize"
        status-icon
      >
        <el-form-item label="Located City" prop="_spaceLocateCity">
          <el-col :span="8">
            <el-input v-model="ruleForm._spaceLocateCity" />
          </el-col>
        </el-form-item>
        <el-form-item label="Zip Code" prop="_zipCode">
          <el-col :span="2">
            <el-input v-model="ruleForm._zipCode" />
          </el-col>
        </el-form-item>
        <el-form-item label="Space Type" prop="_spaceType">
          <el-select
            v-model="ruleForm._spaceType"
            placeholder="Please select your Space Type"
          >
            <el-option label="Apartment (No Roommates)" value="apt-single" />
            <el-option
              label="Apartment (Shared with Roommates)"
              value="apt-share"
            />
            <el-option label="Townhouse (No Roommates)" value="th-single" />
            <el-option label="Townhouse (Shared with Roommates)" value="th-share" />
            <el-option
              label="Single Family House (No Roommates)"
              value="sfh-single"
            />
            <el-option
              label="Single Family House (Shared with Roommates)"
              value="sfh-share"
            />
            <el-option label="Other" value="other" />
          </el-select>
        </el-form-item>
        <el-form-item
          label="Other Type"
          v-if="ruleForm._spaceType === 'other'"
          :required="ruleForm._spaceType === 'other'"
        >
          <el-col :span="8">
            <el-input v-model="ruleForm._otherSpaceType" />
          </el-col>
        </el-form-item>
        <el-form-item>
          <el-col :span="2">
            <el-form-item label="Space Available for Offering?"></el-form-item>
          </el-col>
          <el-col :span="3"> </el-col>
          <el-col :span="2">
            <el-form-item prop="_offering">
              <el-switch v-model="ruleForm._offering" />
            </el-form-item>
          </el-col>
        </el-form-item>
        <el-form-item></el-form-item>
        <el-form-item
          label="Time Window"
          v-if="ruleForm._offering"
          :required="ruleForm._offering"
        >
          <el-col :span="6">
            <el-form-item prop="_availableTimeStart">
              <el-date-picker
                v-model="ruleForm._availableTimeStart"
                type="date"
                label="Pick a date"
                placeholder="Pick a date"
                style="width: 100%"
              />
            </el-form-item>
          </el-col>
          <el-col class="text-center" :span="2">
            <span class="text-gray-500"> To </span>
          </el-col>
          <el-col :span="6">
            <el-form-item prop="_availableTimeEnd">
              <el-date-picker
                v-model="ruleForm._availableTimeEnd"
                label="Pick a time"
                placeholder="Pick a time"
                style="width: 100%"
              />
            </el-form-item>
          </el-col>
        </el-form-item>
        <el-form-item
          label="Max Number of People"
          :required="ruleForm._offering"
          v-if="ruleForm._offering"
          prop="_maxNumberOfPeople"
        >
          <el-col :span="2">
            <el-input v-model="ruleForm._maxNumberOfPeople" />
          </el-col>
        </el-form-item>
        <el-form-item></el-form-item>
    
        <el-form-item label="Space Details:" prop="_spaceDetails">
          <el-col :span="10"
            ><el-input v-model="ruleForm._spaceDetails" type="textarea"
          /></el-col>
        </el-form-item>
        <el-form-item>
          <el-button type="primary" @click="submitForm(ruleFormRef)"
            >Create</el-button
          >
          <el-button @click="resetForm(ruleFormRef)">Reset</el-button>
        </el-form-item>
      </el-form>
    </template>
    
    <script lang="ts" setup>
    import { reactive, ref } from "vue";
    import type { FormInstance, FormRules } from "element-plus";
    import { OfferFormModel } from "@/models/OfferFormModel";
    
    const formSize = ref("default");
    const ruleFormRef = ref<FormInstance>();
    const ruleForm = reactive(new OfferFormModel());
    
    const rules = reactive<FormRules>({
      _spaceLocateCity: [
        { required: true, message: "Please input Activity name", trigger: "blur" },
        { min: 3, max: 5, message: "Length should be 3 to 5", trigger: "blur" },
      ],
      region: [
        {
          required: true,
          message: "Please select Activity zone",
          trigger: "change",
        },
      ],
      count: [
        {
          required: true,
          message: "Please select Activity count",
          trigger: "change",
        },
      ],
      date1: [
        {
          type: "date",
          required: true,
          message: "Please pick a date",
          trigger: "change",
        },
      ],
      date2: [
        {
          type: "date",
          required: true,
          message: "Please pick a time",
          trigger: "change",
        },
      ],
      type: [
        {
          type: "array",
          required: true,
          message: "Please select at least one activity type",
          trigger: "change",
        },
      ],
      resource: [
        {
          required: true,
          message: "Please select activity resource",
          trigger: "change",
        },
      ],
      desc: [
        { required: true, message: "Please input activity form", trigger: "blur" },
      ],
    });
    
    const submitForm = async (formEl: FormInstance | undefined) => {
      if (!formEl) return;
      await formEl.validate((valid, fields) => {
        if (valid) {
          console.log("submit!");
        } else {
          console.log("error submit!", fields);
        }
      });
    };
    
    const resetForm = (formEl: FormInstance | undefined) => {
      if (!formEl) return;
      formEl.resetFields();
    };
    
    const options = Array.from({ length: 10000 }).map((_, idx) => ({
      value: `${idx + 1}`,
      label: `${idx + 1}`,
    }));
    </script>