UNPKG

apeman-react-sign

Version:
358 lines (308 loc) 27.9 kB
/** * Form for signin * @class ApSigninForm */ 'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.ApSigninForm = undefined; var _keys = require('babel-runtime/core-js/object/keys'); var _keys2 = _interopRequireDefault(_keys); var _defineProperty2 = require('babel-runtime/helpers/defineProperty'); var _defineProperty3 = _interopRequireDefault(_defineProperty2); var _extends2 = require('babel-runtime/helpers/extends'); var _extends3 = _interopRequireDefault(_extends2); 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 _apemanReactCheckbox = require('apeman-react-checkbox'); 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, values = props.values, labels = props.labels, icons = props.icons, idOf = props.idOf, onUpdate = props.onUpdate, _onSubmit = props.onSubmit, spinning = props.spinning, errorList = props.errorList, errorStyle = props.errorStyle, actions = props.actions, centered = props.centered, 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: (0, _assign2.default)({}, 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, (0, _extends3.default)({ labels: labels, idOf: idOf }, { enabled: rememberEnabled, onToggle: actions.toggleRemember })), props.children, _react2.default.createElement(ApSigninForm.ButtonField, (0, _extends3.default)({ 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); (0, _assign2.default)(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, labels = _ref.labels, idOf = _ref.idOf, 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((0, _defineProperty3.default)({}, name, e.target.value)); } }) ) ); }, PasswordField: function PasswordField(_ref2) { var values = _ref2.values, labels = _ref2.labels, idOf = _ref2.idOf, 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((0, _defineProperty3.default)({}, name, e.target.value)); } }) ) ); }, RememberField: function RememberField(_ref3) { var labels = _ref3.labels, idOf = _ref3.idOf, enabled = _ref3.enabled, 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, idOf = _ref4.idOf, 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, labels = _ref5.labels, 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' }, (0, _keys2.default)(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, labels = _ref6.labels, icons = _ref6.icons, 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' }, (0, _keys2.default)(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","style","toggleRemember","children","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","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          { props.children }\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"]}