apeman-react-sign
Version:
apeman react package for sign components
358 lines (308 loc) • 27.9 kB
JavaScript
/**
* 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"]}