apeman-react-sign
Version:
apeman react package for sign components
322 lines (279 loc) • 24 kB
JavaScript
/**
* Form for signup
* @class ApSignupForm
*/
'use strict';
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.ApSigninForm = undefined;
var _assign = require('babel-runtime/core-js/object/assign');
var _assign2 = _interopRequireDefault(_assign);
var _getPrototypeOf = require('babel-runtime/core-js/object/get-prototype-of');
var _getPrototypeOf2 = _interopRequireDefault(_getPrototypeOf);
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
var _createClass2 = require('babel-runtime/helpers/createClass');
var _createClass3 = _interopRequireDefault(_createClass2);
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn');
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2);
var _inherits2 = require('babel-runtime/helpers/inherits');
var _inherits3 = _interopRequireDefault(_inherits2);
var _react = require('react');
var _react2 = _interopRequireDefault(_react);
var _classnames = require('classnames');
var _classnames2 = _interopRequireDefault(_classnames);
var _apemanReactForm = require('apeman-react-form');
var _apemanReactField = require('apeman-react-field');
var _apemanReactButton = require('apeman-react-button');
var _apemanReactText = require('apeman-react-text');
var _apemanReactPassword = require('apeman-react-password');
var _apemanReactCaptcha = require('apeman-react-captcha');
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var noop = function noop(e) {
return console.log(e);
};
/** @lends ApSigninForm */
var ApSigninForm = function (_Component) {
(0, _inherits3.default)(ApSigninForm, _Component);
function ApSigninForm(props) {
(0, _classCallCheck3.default)(this, ApSigninForm);
var _this = (0, _possibleConstructorReturn3.default)(this, (ApSigninForm.__proto__ || (0, _getPrototypeOf2.default)(ApSigninForm)).call(this, props));
var s = _this;
s.state = {};
return _this;
}
(0, _createClass3.default)(ApSigninForm, [{
key: 'render',
value: function render() {
var s = this;
var props = s.props;
var id = props.id,
idOf = props.idOf,
labels = props.labels,
values = props.values,
images = props.images,
actions = props.actions,
placeholders = props.placeholders,
onUpdate = props.onUpdate,
onSubmit = props.onSubmit,
spinning = props.spinning,
errorList = props.errorList,
errorStyle = props.errorStyle,
centered = props.centered,
captchaSpinning = props.captchaSpinning;
return _react2.default.createElement(
_apemanReactForm.ApForm,
{ id: id,
spinning: spinning,
centered: centered,
className: (0, _classnames2.default)('ap-signin-form', props.className),
style: (0, _assign2.default)({}, props.style)
},
_react2.default.createElement(
_apemanReactField.ApFieldSet,
{ plain: true },
errorList,
errorStyle,
_react2.default.createElement(ApSigninForm.KeyField, { idOf: idOf, labels: labels, values: values, onUpdate: onUpdate }),
_react2.default.createElement(ApSigninForm.EmailField, { idOf: idOf, labels: labels, values: values, onUpdate: onUpdate }),
_react2.default.createElement(ApSigninForm.PasswordField, { idOf: idOf, labels: labels, values: values, onUpdate: onUpdate })
),
_react2.default.createElement(
_apemanReactField.ApFieldSet,
{ plain: true },
_react2.default.createElement(ApSigninForm.CaptchaField, {
idOf: idOf,
labels: labels,
values: values,
onUpdate: onUpdate,
placeholders: placeholders,
images: images,
actions: actions,
captchaSpinning: captchaSpinning
})
),
_react2.default.createElement(
_apemanReactField.ApFieldSet,
{ plain: true },
props.children
),
_react2.default.createElement(
_apemanReactField.ApFieldSet,
{ plain: true },
_react2.default.createElement(ApSigninForm.ButtonField, { idOf: idOf, labels: labels, values: values, onSubmit: onSubmit })
)
);
}
}]);
return ApSigninForm;
}(_react.Component);
(0, _assign2.default)(ApSigninForm, {
// --------------------
// Specs
// --------------------
propTypes: {
captchaSpinning: _react.PropTypes.bool
},
defaultProps: {
labels: {
key: 'Username',
email: 'Email',
password: 'Password',
captcha: 'Captcha',
captchaRefresh: 'refresh',
submit: 'Sign Up'
},
placeholders: {
captcha: '(Type numbers above)'
},
images: {
captcha: ''
},
actions: {
captchaRefresh: noop
},
captchaSpinning: false
},
// --------------------
// Sub Component
// --------------------
KeyField: function KeyField(_ref) {
var idOf = _ref.idOf,
labels = _ref.labels,
values = _ref.values,
onUpdate = _ref.onUpdate;
return _react2.default.createElement(
_apemanReactField.ApField,
null,
_react2.default.createElement(
_apemanReactField.ApFieldLabel,
{ htmlFor: idOf('key') },
labels['key']
),
_react2.default.createElement(
_apemanReactField.ApFieldValue,
null,
_react2.default.createElement(_apemanReactText.ApText, { autoFocus: true,
id: idOf('key'),
name: 'key',
value: values['key'],
onChange: function onChange(e) {
return onUpdate({ key: e.target.value });
}
})
)
);
},
EmailField: function EmailField(_ref2) {
var idOf = _ref2.idOf,
labels = _ref2.labels,
values = _ref2.values,
onUpdate = _ref2.onUpdate;
return _react2.default.createElement(
_apemanReactField.ApField,
null,
_react2.default.createElement(
_apemanReactField.ApFieldLabel,
{ htmlFor: idOf('email') },
labels['email']
),
_react2.default.createElement(
_apemanReactField.ApFieldValue,
null,
_react2.default.createElement(_apemanReactText.ApText, { id: idOf('email'),
name: 'email',
value: values['email'],
onChange: function onChange(e) {
return onUpdate({ email: e.target.value });
}
})
)
);
},
PasswordField: function PasswordField(_ref3) {
var idOf = _ref3.idOf,
labels = _ref3.labels,
values = _ref3.values,
onUpdate = _ref3.onUpdate;
return _react2.default.createElement(
_apemanReactField.ApField,
null,
_react2.default.createElement(
_apemanReactField.ApFieldLabel,
{ htmlFor: idOf('password') },
labels['password']
),
_react2.default.createElement(
_apemanReactField.ApFieldValue,
null,
_react2.default.createElement(_apemanReactPassword.ApPassword, { id: idOf('password'),
name: 'password',
value: values['password'],
onChange: function onChange(e) {
return onUpdate({ password: e.target.value });
}
})
)
);
},
CaptchaField: function CaptchaField(_ref4) {
var idOf = _ref4.idOf,
labels = _ref4.labels,
values = _ref4.values,
onUpdate = _ref4.onUpdate,
placeholders = _ref4.placeholders,
images = _ref4.images,
actions = _ref4.actions,
captchaSpinning = _ref4.captchaSpinning;
return _react2.default.createElement(
_apemanReactField.ApField,
null,
_react2.default.createElement(
_apemanReactField.ApFieldLabel,
{ htmlFor: idOf('captcha') },
labels['captcha']
),
_react2.default.createElement(
_apemanReactField.ApFieldValue,
null,
_react2.default.createElement(_apemanReactCaptcha.ApCaptcha, { src: images['captcha'],
spinning: captchaSpinning,
refreshText: labels['captchaRefresh'],
onRefresh: actions['captchaRefresh'] }),
_react2.default.createElement(_apemanReactText.ApText, { id: idOf('captcha'),
name: 'captcha',
value: values['captcha'],
onChange: function onChange(e) {
return onUpdate({ captcha: e.target.value });
},
placeholder: placeholders['captcha']
})
)
);
},
ButtonField: function ButtonField(_ref5) {
var idOf = _ref5.idOf,
labels = _ref5.labels,
values = _ref5.values,
onSubmit = _ref5.onSubmit;
return _react2.default.createElement(
_apemanReactField.ApField,
{ center: true, className: 'ap-signup-form-button-field' },
_react2.default.createElement(
_apemanReactButton.ApButton,
{ id: idOf('submit'),
onTap: function onTap() {
return onSubmit(values);
},
wide: true,
primary: true
},
labels['submit']
)
);
}
});
exports.ApSigninForm = ApSigninForm;
exports.default = (0, _apemanReactForm.withForm)(ApSigninForm);
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["ap_signup_form.jsx"],"names":["noop","e","console","log","ApSigninForm","props","s","state","id","idOf","labels","values","images","actions","placeholders","onUpdate","onSubmit","spinning","errorList","errorStyle","centered","captchaSpinning","className","style","children","propTypes","bool","defaultProps","key","email","password","captcha","captchaRefresh","submit","KeyField","target","value","EmailField","PasswordField","CaptchaField","ButtonField"],"mappings":"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","file":"ap_signup_form.jsx","sourceRoot":"lib","sourcesContent":["/**\n * Form for signup\n * @class ApSignupForm\n */\n\n'use strict'\n\nimport React, { Component, PropTypes as types } from 'react'\nimport classnames from 'classnames'\n\nimport { ApForm, withForm } from 'apeman-react-form'\nimport { ApFieldSet, ApField, ApFieldLabel, ApFieldValue } from 'apeman-react-field'\nimport { ApButton, ApCellButton, ApCellButtonRow, ApIconButton, ApIconButtonRow } from 'apeman-react-button'\nimport { ApText } from 'apeman-react-text'\nimport { ApPassword } from 'apeman-react-password'\nimport { ApCaptcha } from 'apeman-react-captcha'\n\nconst noop = (e) => console.log(e)\n\n/** @lends ApSigninForm */\nclass ApSigninForm extends Component {\n  constructor (props) {\n    super(props)\n    const s = this\n    s.state = {}\n  }\n\n  render () {\n    const s = this\n    let { props } = s\n    let {\n      id,\n      idOf,\n      labels,\n      values,\n      images,\n      actions,\n      placeholders,\n      onUpdate,\n      onSubmit,\n      spinning,\n      errorList,\n      errorStyle,\n      centered,\n      captchaSpinning\n    } = props\n    return (\n      <ApForm id={ id }\n              spinning={ spinning }\n              centered={ centered }\n              className={ classnames('ap-signin-form', props.className)}\n              style={ Object.assign({}, props.style) }\n      >\n        <ApFieldSet plain>\n          { errorList }\n          { errorStyle }\n          <ApSigninForm.KeyField { ...{ idOf, labels, values, onUpdate } }/>\n          <ApSigninForm.EmailField { ...{ idOf, labels, values, onUpdate } }/>\n          <ApSigninForm.PasswordField { ...{ idOf, labels, values, onUpdate } }/>\n        </ApFieldSet>\n        <ApFieldSet plain>\n          <ApSigninForm.CaptchaField { ...{\n            idOf,\n            labels,\n            values,\n            onUpdate,\n            placeholders,\n            images,\n            actions,\n            captchaSpinning\n          } }/>\n        </ApFieldSet>\n        <ApFieldSet plain>\n          { props.children }\n        </ApFieldSet>\n        <ApFieldSet plain>\n          <ApSigninForm.ButtonField { ...{ idOf, labels, values, onSubmit } }/>\n        </ApFieldSet>\n      </ApForm>\n    )\n  }\n}\nObject.assign(ApSigninForm, {\n  // --------------------\n  // Specs\n  // --------------------\n\n  propTypes: {\n    captchaSpinning: types.bool\n  },\n\n  defaultProps: {\n    labels: {\n      key: 'Username',\n      email: 'Email',\n      password: 'Password',\n      captcha: 'Captcha',\n      captchaRefresh: 'refresh',\n      submit: 'Sign Up'\n    },\n    placeholders: {\n      captcha: '(Type numbers above)'\n    },\n    images: {\n      captcha: ''\n    },\n    actions: {\n      captchaRefresh: noop\n    },\n    captchaSpinning: false\n  },\n\n  // --------------------\n  // Sub Component\n  // --------------------\n  KeyField ({ idOf, labels, values, onUpdate }) {\n    return (\n      <ApField>\n        <ApFieldLabel htmlFor={ idOf('key') }>\n          { labels[ 'key' ] }\n        </ApFieldLabel>\n        <ApFieldValue>\n          <ApText autoFocus\n                  id={ idOf('key') }\n                  name={ 'key' }\n                  value={ values[ 'key' ] }\n                  onChange={ (e) => onUpdate({ key: e.target.value }) }\n          />\n        </ApFieldValue>\n      </ApField>\n    )\n  },\n\n  EmailField ({ idOf, labels, values, onUpdate }) {\n    return (\n      <ApField>\n        <ApFieldLabel htmlFor={ idOf('email') }>\n          { labels[ 'email' ] }\n        </ApFieldLabel>\n        <ApFieldValue>\n          <ApText id={ idOf('email') }\n                  name={ 'email' }\n                  value={ values[ 'email' ] }\n                  onChange={ (e) => onUpdate({ email: e.target.value }) }\n          />\n        </ApFieldValue>\n      </ApField>\n    )\n  },\n\n  PasswordField ({ idOf, labels, values, onUpdate }) {\n    return (\n      <ApField>\n        <ApFieldLabel htmlFor={ idOf('password') }>\n          { labels[ 'password' ] }\n        </ApFieldLabel>\n        <ApFieldValue>\n          <ApPassword id={ idOf('password') }\n                      name={ 'password' }\n                      value={ values[ 'password' ] }\n                      onChange={ (e) => onUpdate({ password: e.target.value }) }\n          />\n        </ApFieldValue>\n      </ApField>\n    )\n  },\n\n  CaptchaField ({ idOf, labels, values, onUpdate, placeholders, images, actions, captchaSpinning }) {\n    return (\n      <ApField>\n        <ApFieldLabel htmlFor={ idOf('captcha') }>\n          { labels[ 'captcha' ] }\n        </ApFieldLabel>\n        <ApFieldValue>\n          <ApCaptcha src={ images[ 'captcha' ] }\n                     spinning={ captchaSpinning }\n                     refreshText={ labels[ 'captchaRefresh' ] }\n                     onRefresh={ actions[ 'captchaRefresh' ] }>\n          </ApCaptcha>\n          <ApText id={ idOf('captcha') }\n                  name={ 'captcha' }\n                  value={ values[ 'captcha' ] }\n                  onChange={ (e) => onUpdate({ captcha: e.target.value }) }\n                  placeholder={ placeholders[ 'captcha' ] }\n          />\n        </ApFieldValue>\n      </ApField>\n    )\n  },\n\n  ButtonField ({ idOf, labels, values, onSubmit }) {\n    return (\n      <ApField center className='ap-signup-form-button-field'>\n        <ApButton id={ idOf('submit') }\n                  onTap={ () => onSubmit(values) }\n                  wide\n                  primary\n        >{ labels[ 'submit' ] }</ApButton>\n      </ApField>\n    )\n  }\n})\n\nexport { ApSigninForm }\nexport default withForm(ApSigninForm)\n"]}