UNPKG

apeman-react-sign

Version:
302 lines (266 loc) 24.3 kB
/** * Form for signup * @class ApSignupForm */ 'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.ApSigninForm = undefined; var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); 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 }; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } var noop = function noop(e) { return console.log(e); }; /** @lends ApSigninForm */ var ApSigninForm = function (_Component) { _inherits(ApSigninForm, _Component); function ApSigninForm(props) { _classCallCheck(this, ApSigninForm); var _this = _possibleConstructorReturn(this, (ApSigninForm.__proto__ || Object.getPrototypeOf(ApSigninForm)).call(this, props)); var s = _this; s.state = {}; return _this; } _createClass(ApSigninForm, [{ key: 'render', value: function render() { var s = this; var props = s.props; var id = props.id; var idOf = props.idOf; var labels = props.labels; var values = props.values; var images = props.images; var actions = props.actions; var placeholders = props.placeholders; var onUpdate = props.onUpdate; var onSubmit = props.onSubmit; var spinning = props.spinning; var errorList = props.errorList; var errorStyle = props.errorStyle; var centered = props.centered; var 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: Object.assign({}, 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 }, _react2.default.createElement(ApSigninForm.ButtonField, { idOf: idOf, labels: labels, values: values, onSubmit: onSubmit }) ) ); } }]); return ApSigninForm; }(_react.Component); Object.assign(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; var labels = _ref.labels; var values = _ref.values; var 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; var labels = _ref2.labels; var values = _ref2.values; var 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; var labels = _ref3.labels; var values = _ref3.values; var 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; var labels = _ref4.labels; var values = _ref4.values; var onUpdate = _ref4.onUpdate; var placeholders = _ref4.placeholders; var images = _ref4.images; var actions = _ref4.actions; var 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; var labels = _ref5.labels; var values = _ref5.values; var 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","Object","assign","style","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          <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"]}