UNPKG

apeman-react-sign

Version:
334 lines (295 loc) 28.5 kB
/** * Form for signin * @class ApSigninForm */ 'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.ApSigninForm = undefined; var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; 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 _apemanReactCheckbox = require('apeman-react-checkbox'); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return 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 values = props.values; var labels = props.labels; var icons = props.icons; var idOf = props.idOf; var onUpdate = props.onUpdate; var _onSubmit = props.onSubmit; var spinning = props.spinning; var errorList = props.errorList; var errorStyle = props.errorStyle; var actions = props.actions; var centered = props.centered; var rememberEnabled = props.rememberEnabled; return _react2.default.createElement( _apemanReactForm.ApForm, { id: id, centered: centered, spinning: spinning, 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, { values: values, labels: labels, idOf: idOf, onUpdate: onUpdate }), _react2.default.createElement(ApSigninForm.PasswordField, { values: values, labels: labels, idOf: idOf, onUpdate: onUpdate }), _react2.default.createElement(ApSigninForm.RememberField, _extends({ labels: labels, idOf: idOf }, { enabled: rememberEnabled, onToggle: actions.toggleRemember })), _react2.default.createElement(ApSigninForm.ButtonField, _extends({ labels: labels, idOf: idOf }, { onSubmit: function onSubmit() { return _onSubmit(s.props.values); } })) ), _react2.default.createElement(ApSigninForm.MenuFieldSet, { actions: props.menu, labels: labels, idOf: idOf }), _react2.default.createElement(ApSigninForm.ButtonFieldSet, { actions: props.buttons, labels: labels, icons: icons, idOf: idOf }) ); } }]); return ApSigninForm; }(_react.Component); Object.assign(ApSigninForm, { // -------------------- // Specs // -------------------- propTypes: { labels: _react.PropTypes.object, icons: _react.PropTypes.object, menu: _react.PropTypes.objectOf(_react.PropTypes.func), buttons: _react.PropTypes.objectOf(_react.PropTypes.func), rememberEnabled: _react.PropTypes.bool }, defaultProps: { labels: { key: 'Username or Email', password: 'Password', remember: 'Remember Me', submit: 'Sign In', signup: 'Sign Up', recover: 'Forget Password?', twitter: 'Sign in with Twitter', google: 'Sign in with Google', facebook: 'Sign in with Facebook' }, icons: { facebook: 'fa fa-facebook', twitter: 'fa fa-twitter', google: 'fa fa-google' }, actions: { toggleRemember: noop }, menu: null, buttons: null, rememberEnabled: false }, // ------------------ // Sub Components // ------------------ KeyField: function KeyField(_ref) { var values = _ref.values; var labels = _ref.labels; var idOf = _ref.idOf; var onUpdate = _ref.onUpdate; var name = 'key'; return _react2.default.createElement( _apemanReactField.ApField, null, _react2.default.createElement( _apemanReactField.ApFieldLabel, { htmlFor: idOf(name) }, labels[[name]] ), _react2.default.createElement( _apemanReactField.ApFieldValue, null, _react2.default.createElement(_apemanReactText.ApText, { autoFocus: true, id: idOf(name), name: name, value: values[name], onChange: function onChange(e) { return onUpdate(_defineProperty({}, name, e.target.value)); } }) ) ); }, PasswordField: function PasswordField(_ref2) { var values = _ref2.values; var labels = _ref2.labels; var idOf = _ref2.idOf; var onUpdate = _ref2.onUpdate; var name = 'password'; return _react2.default.createElement( _apemanReactField.ApField, null, _react2.default.createElement( _apemanReactField.ApFieldLabel, { htmlFor: idOf(name) }, labels[name] ), _react2.default.createElement( _apemanReactField.ApFieldValue, null, _react2.default.createElement(_apemanReactPassword.ApPassword, { id: idOf(name), value: values[name], name: name, onChange: function onChange(e) { return onUpdate(_defineProperty({}, name, e.target.value)); } }) ) ); }, RememberField: function RememberField(_ref3) { var labels = _ref3.labels; var idOf = _ref3.idOf; var enabled = _ref3.enabled; var onToggle = _ref3.onToggle; var name = 'remember'; return _react2.default.createElement( _apemanReactField.ApField, { className: 'ap-signin-form-sub-field' }, _react2.default.createElement(_apemanReactField.ApFieldLabel, { htmlFor: idOf(name) }), _react2.default.createElement( _apemanReactField.ApFieldValue, null, _react2.default.createElement(_apemanReactCheckbox.ApCheckbox, { id: idOf(name), value: 'YES', checked: enabled, title: labels[name], name: name, onChange: function onChange() { return onToggle(!enabled); } }) ) ); }, ButtonField: function ButtonField(_ref4) { var labels = _ref4.labels; var idOf = _ref4.idOf; var onSubmit = _ref4.onSubmit; var name = 'submit'; return _react2.default.createElement( _apemanReactField.ApField, { center: true, className: 'ap-signin-form-button-field' }, _react2.default.createElement( _apemanReactButton.ApButton, { wide: true, primary: true, onTap: onSubmit, id: idOf(name) }, labels[name] ) ); }, MenuFieldSet: function MenuFieldSet(_ref5) { var actions = _ref5.actions; var labels = _ref5.labels; var idOf = _ref5.idOf; if (!actions) { return null; } return _react2.default.createElement( _apemanReactField.ApFieldSet, { plain: true }, _react2.default.createElement( _apemanReactField.ApField, { center: true, className: 'ap-signin-form-action-field' }, _react2.default.createElement( _apemanReactButton.ApCellButtonRow, { className: 'ap-signin-form-action-button-row' }, Object.keys(actions).map(function (name) { return _react2.default.createElement(_apemanReactButton.ApCellButton, { id: idOf(name), key: name, onTap: function onTap(e) { return actions[name](); }, text: labels[name] }); }) ) ) ); }, ButtonFieldSet: function ButtonFieldSet(_ref6) { var actions = _ref6.actions; var labels = _ref6.labels; var icons = _ref6.icons; var idOf = _ref6.idOf; if (!actions) { return null; } return _react2.default.createElement( _apemanReactField.ApFieldSet, { plain: true }, _react2.default.createElement( _apemanReactField.ApField, { className: 'ap-signin-form-action-field' }, _react2.default.createElement( _apemanReactButton.ApIconButtonRow, { className: 'ap-signin-form-action-button-row' }, Object.keys(actions).map(function (name) { return _react2.default.createElement(_apemanReactButton.ApIconButton, { id: idOf(name), key: name, onTap: function onTap(e) { return actions[name](); }, icon: icons[name], text: labels[name] }); }) ) ) ); } }); exports.ApSigninForm = ApSigninForm; exports.default = (0, _apemanReactForm.withForm)(ApSigninForm); //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["ap_signin_form.jsx"],"names":["noop","e","console","log","ApSigninForm","props","s","state","id","values","labels","icons","idOf","onUpdate","onSubmit","spinning","errorList","errorStyle","actions","centered","rememberEnabled","className","Object","assign","style","toggleRemember","menu","buttons","propTypes","object","objectOf","func","bool","defaultProps","key","password","remember","submit","signup","recover","twitter","google","facebook","KeyField","name","target","value","PasswordField","RememberField","enabled","onToggle","ButtonField","MenuFieldSet","keys","map","ButtonFieldSet"],"mappings":"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","file":"ap_signin_form.jsx","sourceRoot":"lib","sourcesContent":["/**\n * Form for signin\n * @class ApSigninForm\n */\n\n'use strict'\n\nimport React, { Component, PropTypes as types } from 'react'\nimport classnames from 'classnames'\nimport {\n  ApForm, withForm\n} from 'apeman-react-form'\nimport {\n  ApFieldSet, ApField, ApFieldLabel, ApFieldValue\n} from 'apeman-react-field'\nimport {\n  ApButton, ApCellButton, ApCellButtonRow, ApIconButton, ApIconButtonRow\n} from 'apeman-react-button'\nimport { ApText } from 'apeman-react-text'\nimport { ApPassword } from 'apeman-react-password'\nimport { ApCheckbox } from 'apeman-react-checkbox'\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      values,\n      labels,\n      icons,\n      idOf,\n      onUpdate,\n      onSubmit,\n      spinning,\n      errorList,\n      errorStyle,\n      actions,\n      centered,\n      rememberEnabled\n    } = props\n    return (\n      <ApForm id={ id }\n              centered={ centered }\n              spinning={ spinning }\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 { ...{ values, labels, idOf, onUpdate } }/>\n          <ApSigninForm.PasswordField { ...{ values, labels, idOf, onUpdate } }/>\n          <ApSigninForm.RememberField { ...{ labels, idOf } }\n                                      enabled={ rememberEnabled }\n                                      onToggle={ actions.toggleRemember }\n          />\n          <ApSigninForm.ButtonField { ...{ labels, idOf } }\n                                    onSubmit={ () => onSubmit(s.props.values) }/>\n        </ApFieldSet>\n        <ApSigninForm.MenuFieldSet actions={ props.menu }\n                                   labels={ labels }\n                                   idOf={ idOf }\n        />\n        <ApSigninForm.ButtonFieldSet actions={ props.buttons }\n                                     labels={ labels }\n                                     icons={ icons }\n                                     idOf={ idOf }/>\n      </ApForm>\n    )\n  }\n}\n\nObject.assign(ApSigninForm, {\n  // --------------------\n  // Specs\n  // --------------------\n  propTypes: {\n    labels: types.object,\n    icons: types.object,\n    menu: types.objectOf(types.func),\n    buttons: types.objectOf(types.func),\n    rememberEnabled: types.bool\n  },\n\n  defaultProps: {\n    labels: {\n      key: 'Username or Email',\n      password: 'Password',\n      remember: 'Remember Me',\n      submit: 'Sign In',\n      signup: 'Sign Up',\n      recover: 'Forget Password?',\n      twitter: 'Sign in with Twitter',\n      google: 'Sign in with Google',\n      facebook: 'Sign in with Facebook'\n    },\n    icons: {\n      facebook: 'fa fa-facebook',\n      twitter: 'fa fa-twitter',\n      google: 'fa fa-google'\n    },\n    actions: {\n      toggleRemember: noop\n    },\n    menu: null,\n    buttons: null,\n    rememberEnabled: false\n  },\n\n  // ------------------\n  // Sub Components\n  // ------------------\n\n  KeyField ({ values, labels, idOf, onUpdate }) {\n    let name = 'key'\n    return (\n      <ApField>\n        <ApFieldLabel htmlFor={ idOf(name) }>\n          { labels[ [ name ] ] }\n        </ApFieldLabel>\n        <ApFieldValue>\n          <ApText autoFocus\n                  id={ idOf(name) }\n                  name={ name }\n                  value={ values[ name ] }\n                  onChange={ (e) => onUpdate({ [name]: e.target.value }) }\n          />\n        </ApFieldValue>\n      </ApField>\n    )\n  },\n\n  PasswordField ({ values, labels, idOf, onUpdate }) {\n    let name = 'password'\n    return (\n      <ApField>\n        <ApFieldLabel htmlFor={ idOf(name) }>\n          { labels[ name ] }\n        </ApFieldLabel>\n        <ApFieldValue>\n          <ApPassword id={ idOf(name) }\n                      value={ values[ name ] }\n                      name={ name }\n                      onChange={ (e) => onUpdate({ [name]: e.target.value }) }\n          />\n        </ApFieldValue>\n      </ApField>\n    )\n  },\n\n  RememberField ({ labels, idOf, enabled, onToggle }) {\n    let name = 'remember'\n    return (\n      <ApField className='ap-signin-form-sub-field'>\n        <ApFieldLabel htmlFor={ idOf(name) }>\n        </ApFieldLabel>\n        <ApFieldValue>\n          <ApCheckbox id={ idOf(name) }\n                      value='YES'\n                      checked={ enabled }\n                      title={ labels[ name ] }\n                      name={ name }\n                      onChange={ () => onToggle(!enabled) }\n          />\n        </ApFieldValue>\n      </ApField>\n    )\n  },\n\n  ButtonField ({ labels, idOf, onSubmit }) {\n    let name = 'submit'\n    return (\n      <ApField center\n               className='ap-signin-form-button-field'>\n        <ApButton wide\n                  primary\n                  onTap={ onSubmit }\n                  id={ idOf(name) }\n        >{ labels[ name ] }</ApButton>\n      </ApField>\n    )\n  },\n\n  MenuFieldSet ({ actions, labels, idOf }) {\n    if (!actions) {\n      return null\n    }\n    return (\n      <ApFieldSet plain>\n        <ApField center\n                 className='ap-signin-form-action-field'>\n          <ApCellButtonRow className='ap-signin-form-action-button-row'>\n            {\n              Object.keys(actions).map((name) => (\n                <ApCellButton id={ idOf(name) }\n                              key={ name }\n                              onTap={ (e) => actions[ name ]() }\n                              text={ labels[ name ] }/>\n              ))\n            }\n          </ApCellButtonRow>\n        </ApField>\n      </ApFieldSet>\n    )\n  },\n\n  ButtonFieldSet ({ actions, labels, icons, idOf }) {\n    if (!actions) {\n      return null\n    }\n    return (\n      <ApFieldSet plain>\n        <ApField className='ap-signin-form-action-field'>\n          <ApIconButtonRow className='ap-signin-form-action-button-row'>\n            {\n              Object.keys(actions).map((name) => (\n                <ApIconButton id={ idOf(name) }\n                              key={ name }\n                              onTap={ (e) => actions[ name ]() }\n                              icon={ icons[ name ] }\n                              text={ labels[ name ] }/>\n              ))\n            }\n          </ApIconButtonRow>\n        </ApField>\n      </ApFieldSet>\n    )\n  }\n})\n\nexport { ApSigninForm }\nexport default withForm(ApSigninForm)\n"]}