dynamic.js 4.13 KB
'use strict';

Object.defineProperty(exports, "__esModule", {
  value: true
});

var _babelHelperVueJsxMergeProps = require('babel-helper-vue-jsx-merge-props');

var _babelHelperVueJsxMergeProps2 = _interopRequireDefault(_babelHelperVueJsxMergeProps);

var _extends2 = require('babel-runtime/helpers/extends');

var _extends3 = _interopRequireDefault(_extends2);

var _index = require('../index');

var _styles = require('./styles');

function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; }

/* eslint react/no-multi-comp:0, no-console:0 */

var Email = {
  props: {
    form: Object,
    hidden: Boolean
  },
  render: function render() {
    var h = arguments[0];
    var hidden = this.hidden,
        form = this.form;
    var getFieldProps = form.getFieldProps,
        getFieldError = form.getFieldError,
        isFieldValidating = form.isFieldValidating;

    var errors = getFieldError('email');
    var style = (0, _extends3['default'])({}, _styles.regionStyle, {
      display: hidden ? 'none' : ''
    });
    return h(
      'div',
      { style: style },
      [h('div', ['email:', h('input', getFieldProps('email', {
        rules: [{
          required: true
        }, {
          type: 'email',
          message: '错误的 email 格式'
        }],
        hidden: hidden
      }))]), errors ? h(
        'div',
        { style: _styles.errorStyle },
        [errors.join(',')]
      ) : null, isFieldValidating('email') ? h(
        'div',
        { style: _styles.errorStyle },
        ['validating']
      ) : null]
    );
  }
};

var User = {
  props: {
    form: Object
  },
  render: function render() {
    var h = arguments[0];
    var _form = this.form,
        getFieldProps = _form.getFieldProps,
        getFieldError = _form.getFieldError,
        isFieldValidating = _form.isFieldValidating;

    var errors = getFieldError('user');
    return h(
      'div',
      { style: _styles.regionStyle },
      [h('div', ['user:', h('input', getFieldProps('user', {
        initialValue: 'x',
        rules: [{
          required: true
        }]
      }))]), errors ? h(
        'div',
        { style: _styles.errorStyle },
        [errors.join(',')]
      ) : null, isFieldValidating('user') ? h(
        'div',
        { style: _styles.errorStyle },
        ['validating']
      ) : null]
    );
  }
};

var Form = {
  props: {
    form: Object
  },
  methods: {
    onSubmit: function onSubmit(e) {
      e.preventDefault();
      this.form.validateFields(function (error, values) {
        if (!error) {
          console.log('ok', values);
        } else {
          console.log('error', error, values);
        }
      });
    }
  },

  render: function render() {
    var h = arguments[0];
    var form = this.form;
    var getFieldProps = form.getFieldProps,
        getFieldValue = form.getFieldValue;

    return h(
      'div',
      { style: { margin: 20 } },
      [h('h2', ['overview']), h(
        'form',
        {
          on: {
            'submit': this.onSubmit
          }
        },
        [h(
          'div',
          { style: _styles.regionStyle },
          [h('div', [h('label', ['remove/add user:', h('input', (0, _babelHelperVueJsxMergeProps2['default'])([{
            attrs: {
              type: 'checkbox'
            }
          }, getFieldProps('remove_user', {
            // initialValue:true,
            valuePropName: 'checked'
          })]))])])]
        ), getFieldValue('remove_user') ? null : h(User, {
          attrs: { form: form }
        }), h(
          'div',
          { style: _styles.regionStyle },
          [h('div', [h('label', ['hide/show email:', h('input', (0, _babelHelperVueJsxMergeProps2['default'])([{
            attrs: {
              type: 'checkbox'
            }
          }, getFieldProps('hide_email', {
            // initialValue:true,
            valuePropName: 'checked'
          })]))])])]
        ), h(Email, {
          attrs: { form: form, hidden: !!getFieldValue('hide_email') }
        }), h(
          'div',
          { style: _styles.regionStyle },
          [h('button', ['submit'])]
        )]
      )]
    );
  }
};

exports['default'] = (0, _index.createForm)()(Form);