Skip to content
Snippets Groups Projects
OfferPage.vue 6.26 KiB
Newer Older
  • Learn to ignore specific revisions
  • fz2907's avatar
    fz2907 committed
    <template>
    
      <el-row :gutter="20">
        <el-col :span="4"><div class="grid-content ep-bg-purple" /></el-col>
        <el-col :span="12">
          <el-card style="width: 100%">
            <template #header>
              <div class="card-header">
                <span>Your Offer Information</span>
              </div>
            </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="5">
    
                  <el-input v-model="ruleForm.zipCode" placeholder="24061.." />
    
                </el-col>
              </el-form-item>
    
              <el-form-item label="Space Type" prop="spaceType">
    
                  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 label="Space Available for Offering?">
                <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="7">
    
                  <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="7">
    
                  <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="4">
    
                  <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="16"
    
                  ><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>
          </el-card>
        </el-col>
        <el-col :span="4">
          <el-card style="width: 100%"
            ><template #header>
              <div class="card-header">
                <span>Match Request</span>
              </div>
            </template>
          </el-card></el-col
        >
        <el-col :span="4"></el-col>
      </el-row>
    
    fz2907's avatar
    fz2907 committed
    </template>
    
    
    <script lang="ts">
    
    fz2907's avatar
    fz2907 committed
    import { reactive, ref } from "vue";
    import type { FormInstance, FormRules } from "element-plus";
    import { OfferFormModel } from "@/models/OfferFormModel";
    
    import { defineComponent } from "vue";
    
    import * as OfferPageService from "@/services/OfferPageService";
    
    fz2907's avatar
    fz2907 committed
    const rules = reactive<FormRules>({
    
      spaceLocateCity: [
    
    fz2907's avatar
    fz2907 committed
        {
          required: true,
    
    fz2907's avatar
    fz2907 committed
          message: "Please give your space location",
          trigger: "blur",
    
    fz2907's avatar
    fz2907 committed
        { min: 0, max: 20, message: "Length should be 0 to 20", trigger: "blur" },
    
      zipCode: [
    
    fz2907's avatar
    fz2907 committed
        {
          required: true,
    
    fz2907's avatar
    fz2907 committed
          message: "Please give your zip code of your space",
          trigger: "blur",
    
      spaceType: [
    
    fz2907's avatar
    fz2907 committed
        {
          required: true,
    
    fz2907's avatar
    fz2907 committed
          message: "Please select your space type",
    
    fz2907's avatar
    fz2907 committed
          trigger: "change",
        },
      ],
    });
    
    
    const currentUserId = -1;
    const ruleFormRef = ref<FormInstance>();
    const formSize = ref("default");
    
    export default defineComponent({
      data() {
        return {
          ruleForm: new OfferFormModel(),
          rules,
          ruleFormRef,
          //ruleForm: OfferPageService.getUserOfferInfoFromServer(currentUserId),
        };
      },
      methods: {
        async submitForm(formEl: FormInstance | undefined) {
          if (!formEl) return;
          await formEl.validate((valid, fields) => {
            if (valid) {
              console.log("submitted!", fields);
            } else {
              console.log("error submit!", fields);
            }
          });
        },
        resetForm(formEl: FormInstance | undefined) {
          if (!formEl) return;
          formEl.resetFields();
        },
      },
    });
    
    fz2907's avatar
    fz2907 committed
    </script>