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