naive-ui/demo/documentation/components/modal/zhCN/drawer-debug.demo.md
07akioni 8c10ccdef5 refactor: upgrade to vue3, make it work first
there are quite a lot of things to finish
1. Vue.prototype
2. $scopedSlots
3. functional
4. i18n
5. virtual scroll
...
2020-09-08 22:04:45 +08:00

8.2 KiB

Drawer Debug

<n-button @click="modalActive = !modalActive">Toggle</n-button>
<n-modal
  title="Dark Modal Debug"
  preset="card"
  v-model="modalActive"
  :overlay-style="{ marginTop: '24px', marginBottom: '24px', width: '800px' }"
>
  <n-button @click="drawerActive = !drawerActive">Open Drawer</n-button>
  <n-drawer v-model="drawerActive" width="600">
    <n-radio-group v-model="size" name="top-size" style="margin-bottom: 12px;">
      <n-radio-button value="small"></n-radio-button>
      <n-radio-button value="medium" ></n-radio-button>
      <n-radio-button value="large"></n-radio-button>
    </n-radio-group>
    <n-form
      :model="model"
      :rules="rules"
      :size="size"
      ref="form"
      label-placement="top"
    >
      <n-row :gutter="24">
        <n-form-item-col :span="12" label="Input" path="inputValue">
          <n-input placeholder="Input" v-model="model.inputValue" />
        </n-form-item-col>
        <n-form-item-col :span="12" label="Textarea" path="textareaValue">
          <n-input placeholder="Textarea" v-model="model.textareaValue" type="textarea"
            :autosize="{
              minRows: 3,
              maxRows: 5
            }"
          />
        </n-form-item-col>
      </n-row>
      <n-row :gutter="24">
        <n-form-item-col :span="12" label="Select" path="selectValue">
          <n-select placeholder="Select" :options="generalOptions" v-model="model.selectValue"/>
        </n-form-item-col>
        <n-form-item-col :span="12" label="Multiple Select" path="multipleSelectValue">
          <n-select placeholder="Select" :options="generalOptions" v-model="model.multipleSelectValue" multiple/>
        </n-form-item-col>
      </n-row>
      <n-row :gutter="24">
        <n-form-item-col :span="12" label="Datetime" path="datetimeValue">
          <n-date-picker type="datetime" v-model="model.datetimeValue"/>
        </n-form-item-col>
        <n-form-item-col :span="12" label="Switch" path="switchValue">
          <n-switch v-model="model.switchValue" />
        </n-form-item-col>
      </n-row>
      <n-row :gutter="24">
        <n-form-item-col :span="12" label="Checkbox Group" path="checkboxGroupValue">
          <n-checkbox-group v-model="model.checkboxGroupValue">
            <n-checkbox value="Option 1">Option 1</n-checkbox>
            <n-checkbox value="Option 2">Option 2</n-checkbox>
            <n-checkbox value="Option 3">Option 3</n-checkbox>
          </n-checkbox-group>
        </n-form-item-col>
        <n-form-item-col :span="12" label="Radio Group" path="radioGroupValue">
          <n-radio-group v-model="model.radioGroupValue" name="radiogroup1">
            <n-radio value="Radio 1">Radio 1</n-radio>
            <n-radio value="Radio 2">Radio 2</n-radio>
            <n-radio value="Radio 3">Radio 3</n-radio>
          </n-radio-group>
        </n-form-item-col>
      </n-row>
      <n-row :gutter="24">
        <n-form-item-col :span="12" label="Radio Button Group" path="radioGroupValue">
          <n-radio-group v-model="model.radioGroupValue" name="radiogroup2">
            <n-radio-button value="Radio 1">Radio 1</n-radio-button>
            <n-radio-button value="Radio 2">Radio 2</n-radio-button>
            <n-radio-button value="Radio 3">Radio 3</n-radio-button>
          </n-radio-group>
        </n-form-item-col>
        <n-form-item-col :span="12" label="Input Number" path="inputNumberValue">
          <n-input-number v-model="model.inputNumberValue"/>
        </n-form-item-col>
      </n-row>
      <n-row :gutter="24">
        <n-form-item-col :span="12" label="Time Picker" path="timePickerValue">
          <n-time-picker v-model="model.timePickerValue" />
        </n-form-item-col>
        <n-form-item-col :span="12" label="Slider" path="sliderValue">
          <n-slider v-model="model.sliderValue" :step="5"/>
        </n-form-item-col>
      </n-row>
      <n-row :gutter="24">
        <n-form-item-col :span="14" label="Transfer" path="transferValue">
          <n-transfer
            style="width: 100%;"
            v-model="model.transferValue"
            :options="generalOptions"
          />
        </n-form-item-col>
        <n-form-item-col :span="5" label="Nested Path" path="nestedValue.path1">
          <n-cascader placeholder="Nested Path 1" v-model="model.nestedValue.path1" :options="cascaderOptions"/>
        </n-form-item-col>
        <n-form-item-col :span="5" path="nestedValue.path2">
          <n-select placeholder="Nested Path 2" :options="generalOptions" v-model="model.nestedValue.path2"/>
        </n-form-item-col>
      </n-row>
      <n-row>
        <n-col :span="24">
          <div style="display: flex; justify-content: flex-end;">
            <n-button @click="handleValidateButtonClick" round type="primary">验证</n-button>
          </div>
        </n-col>
      </n-row>
    </n-form>
  </n-drawer>
</n-modal>
export default {
  data () {
    return {
      drawerActive: false,
      modalActive: false,
      size: 'medium',
      model: {
        inputValue: null,
        textareaValue: null,
        selectValue: null,
        multipleSelectValue: null,
        datetimeValue: null,
        nestedValue: {
          path1: null,
          path2: null
        },
        switchValue: false,
        checkboxGroupValue: null,
        radioGroupValue: null,
        radioButtonGroupValue: null,
        inputNumberValue: null,
        timePickerValue: null,
        sliderValue: 0,
        transferValue: null
      },
      generalOptions: [
        'groode',
        'veli good',
        'emazing',
        'lidiculous'
      ].map(v => ({
        label: v,
        value: v
      })),
      cascaderOptions: [
        {
          label: 'groode',
          value: 'groode',
          children: [
            {
              label: 'veli good',
              value: 'veli good'
            }
          ]
        }
      ],
      rules: {
        inputValue: {
          required: true,
          trigger: ['blur', 'input'],
          message: '请输入 inputValue'
        },
        textareaValue: {
          required: true,
          trigger: ['blur', 'input'],
          message: '请输入 textareaValue'
        },
        selectValue: {
          required: true,
          trigger: ['blur', 'change'],
          message: '请选择 selectValue'
        },
        multipleSelectValue: {
          type: 'array',
          required: true,
          trigger: ['blur', 'change'],
          message: '请选择 multipleSelectValue'
        },
        datetimeValue: {
          type: 'number',
          required: true,
          trigger: ['blur', 'change'],
          message: '请输入 datetimeValue'
        },
        nestedValue: {
          path1: {
            required: true,
            trigger: ['blur', 'input'],
            message: '请输入 nestedValue.path1'
          },
          path2: {
            required: true,
            trigger: ['blur', 'change'],
            message: '请输入 nestedValue.path2'
          }
        },
        checkboxGroupValue: {
          type: 'array',
          required: true,
          trigger: 'change',
          message: '请选择 checkboxGroupValue'
        },
        radioGroupValue: {
          required: true,
          trigger: 'change',
          message: '请选择 radioGroupValue'
        },
        radioButtonGroupValue: {
          required: true,
          trigger: 'change',
          message: '请选择 radioButtonGroupValue'
        },
        inputNumberValue: {
          type: 'number',
          required: true,
          trigger: ['blur', 'change'],
          message: '请输入 inputNumberValue'
        },
        timePickerValue: {
          type: 'number',
          required: true,
          trigger: ['blur', 'change'],
          message: '请输入 timePickerValue'
        },
        sliderValue: 0,
        transferValue: {
          type: 'array',
          required: true,
          trigger: 'change',
          message: '请输入 transferValue'
        }
      }
    }
  },
  methods: {
    handleValidateButtonClick (e) {
      e.preventDefault()
      this.$refs.form.validate(errors => {
        if (!errors) {
          this.$NMessage.success('验证成功')
        } else {
          console.log(errors)
          this.$NMessage.error('验证失败')
        }
      })
    }
  }
}