UNPKG

15.3 kBJavaScriptView Raw
1/**
2 * Dialog to confirm.
3 * @constructor ApConfirmDialog
4 */
5
6'use strict';
7
8var _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; };
9
10var _react = require('react');
11
12var _react2 = _interopRequireDefault(_react);
13
14var _classnames = require('classnames');
15
16var _classnames2 = _interopRequireDefault(_classnames);
17
18var _apemanReactTouchable = require('apeman-react-touchable');
19
20var _apemanReactCheckbox = require('apeman-react-checkbox');
21
22var _apemanReactButton = require('apeman-react-button');
23
24var _apemanReactMixins = require('apeman-react-mixins');
25
26var _ap_dialog = require('./ap_dialog');
27
28var _ap_dialog2 = _interopRequireDefault(_ap_dialog);
29
30var _uuid = require('uuid');
31
32var _uuid2 = _interopRequireDefault(_uuid);
33
34function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
35
36/** lends ApConfirmDialog */
37var ApConfirmDialog = _react2.default.createClass({
38 displayName: 'ApConfirmDialog',
39
40 // --------------------
41 // Specs
42 // --------------------
43
44 propTypes: {
45 present: _react.PropTypes.bool.isRequired,
46 /** Handler for submit event */
47 onSubmit: _react.PropTypes.func,
48 /** Handler for cancel event */
49 onCancel: _react.PropTypes.func,
50 /** Dialog title */
51 title: _react.PropTypes.string,
52 /** Dialog message */
53 message: _react.PropTypes.string,
54 /** Id of checkbox */
55 checkboxId: _react.PropTypes.string,
56 /** Name of checkbox */
57 checkboxName: _react.PropTypes.string,
58 /** Label text of checkbox */
59 checkboxText: _react.PropTypes.string,
60 /** Errot text when not checked */
61 errorText: _react.PropTypes.string,
62 /** Submit button text */
63 submitText: _react.PropTypes.string
64 },
65
66 mixins: [_apemanReactMixins.ApPureMixin],
67
68 statics: {},
69
70 getInitialState: function getInitialState() {
71 return {
72 checked: false,
73 errored: false
74 };
75 },
76 getDefaultProps: function getDefaultProps() {
77 var id = _uuid2.default.v4().replace(/\-/g, '');
78 return {
79 onSubmit: null,
80 onCancel: null,
81 checkboxId: 'ap-confirm-dialog-checkbox-' + id,
82 checkboxName: 'ap-confirm-check-' + id,
83 checkboxText: null,
84 submitText: 'submit',
85 errorText: 'Needs check before submit.',
86 message: 'Once destroyed, there is no going back. Please be certain.'
87 };
88 },
89 render: function render() {
90 var s = this;
91 var state = s.state;
92 var props = s.props;
93
94 if (!props.present) {
95 return null;
96 }
97 return _react2.default.createElement(
98 _ap_dialog2.default,
99 _extends({ className: (0, _classnames2.default)('ap-confirm-dialog', props.className),
100 style: Object.assign({}, props.style),
101 onClose: s.handleCancel
102 }, props),
103 _react2.default.createElement(
104 'p',
105 { className: 'ap-confirm-dialog-message' },
106 props.message
107 ),
108 _react2.default.createElement(
109 'div',
110 null,
111 props.children
112 ),
113 _react2.default.createElement(
114 'div',
115 { className: 'ap-confirm-dialog-control' },
116 s._renderError(state.errored),
117 s._renderCheckbox(state.checked),
118 s._renderSubmitButton(state.checked)
119 )
120 );
121 },
122 toggleCheckbox: function toggleCheckbox() {
123 var s = this;
124 var state = s.state;
125 s.setState({
126 checked: !state.checked,
127 errored: false
128 });
129 },
130 handleSubmit: function handleSubmit(e) {
131 var s = this;
132 var state = s.state;
133 var props = s.props;
134
135 if (!state.checked) {
136 s.setState({
137 errored: true
138 });
139 return;
140 }
141 s.setState({
142 errored: false
143 });
144 if (props.onSubmit) {
145 props.onSubmit(e);
146 }
147 },
148 handleCancel: function handleCancel(e) {
149 var s = this;
150 var props = s.props;
151
152 s.setState({ errored: false });
153 if (props.onCancel) {
154 props.onCancel(e);
155 }
156 },
157
158 // ------------------
159 // Private
160 // ------------------
161 _renderError: function _renderError(errored) {
162 var s = this;
163 var props = s.props;
164
165 if (!errored) {
166 return null;
167 }
168 return _react2.default.createElement(
169 'div',
170 { className: 'ap-confirm-dialog-err' },
171 _react2.default.createElement(
172 'span',
173 null,
174 props.errorText
175 )
176 );
177 },
178 _renderCheckbox: function _renderCheckbox(checked) {
179 var s = this;
180 var props = s.props;
181
182 return _react2.default.createElement(
183 'div',
184 null,
185 _react2.default.createElement(_apemanReactCheckbox.ApCheckbox, { className: 'ap-confirm-dialog-checkbox',
186 checked: checked,
187 name: props.checkboxName,
188 id: props.checkboxId,
189 title: props.checkboxText,
190 onChange: s.toggleCheckbox,
191 value: 'YES'
192
193 })
194 );
195 },
196 _renderSubmitButton: function _renderSubmitButton(checked) {
197 var s = this;
198 var props = s.props;
199
200 return _react2.default.createElement(
201 _apemanReactButton.ApButton,
202 { onTap: s.handleSubmit,
203 disabled: false,
204 primary: true,
205 className: (0, _classnames2.default)('ap-confirm-dialog-button', {
206 'ap-confirm-dialog-button-disabled': !checked
207 }) },
208 _react2.default.createElement(
209 'span',
210 { className: 'ap-confirm-dialog-button-text' },
211 props.submitText
212 )
213 );
214 }
215});
216
217module.exports = ApConfirmDialog;
218//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["ap_confirm_dialog.jsx"],"names":[],"mappings":"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","file":"ap_confirm_dialog.js","sourceRoot":"/Users/okunishinishi/Projects/apeman-projects/apeman-react-dialog/lib","sourcesContent":["/**\n * Dialog to confirm.\n * @constructor ApConfirmDialog\n */\n\n'use strict'\n\nimport React, {PropTypes as types} from 'react'\nimport classnames from 'classnames'\n\nimport {ApTouchable} from 'apeman-react-touchable'\nimport {ApCheckbox} from 'apeman-react-checkbox'\nimport {ApButton} from 'apeman-react-button'\nimport {ApPureMixin} from 'apeman-react-mixins'\nimport ApDialog from './ap_dialog'\nimport uuid from 'uuid'\n\n/** lends ApConfirmDialog */\nconst ApConfirmDialog = React.createClass({\n\n  // --------------------\n  // Specs\n  // --------------------\n\n  propTypes: {\n    present: types.bool.isRequired,\n    /** Handler for submit event */\n    onSubmit: types.func,\n    /** Handler for cancel event */\n    onCancel: types.func,\n    /** Dialog title */\n    title: types.string,\n    /** Dialog message */\n    message: types.string,\n    /** Id of checkbox */\n    checkboxId: types.string,\n    /** Name of checkbox */\n    checkboxName: types.string,\n    /** Label text of checkbox */\n    checkboxText: types.string,\n    /** Errot text when not checked */\n    errorText: types.string,\n    /** Submit button text */\n    submitText: types.string\n  },\n\n  mixins: [\n    ApPureMixin\n  ],\n\n  statics: {},\n\n  getInitialState () {\n    return {\n      checked: false,\n      errored: false\n    }\n  },\n\n  getDefaultProps () {\n    let id = uuid.v4().replace(/\\-/g, '')\n    return {\n      onSubmit: null,\n      onCancel: null,\n      checkboxId: `ap-confirm-dialog-checkbox-${id}`,\n      checkboxName: `ap-confirm-check-${id}`,\n      checkboxText: null,\n      submitText: 'submit',\n      errorText: 'Needs check before submit.',\n      message: 'Once destroyed, there is no going back. Please be certain.'\n    }\n  },\n\n  render () {\n    const s = this\n    let { state, props } = s\n    if (!props.present) {\n      return null\n    }\n    return (\n      <ApDialog className={ classnames('ap-confirm-dialog', props.className) }\n                style={ Object.assign({}, props.style) }\n                onClose={ s.handleCancel }\n        { ...props }\n      >\n        <p className=\"ap-confirm-dialog-message\">\n          { props.message }\n        </p>\n        <div>{ props.children }</div>\n        <div className=\"ap-confirm-dialog-control\">\n          { s._renderError(state.errored) }\n          { s._renderCheckbox(state.checked) }\n          { s._renderSubmitButton(state.checked) }\n        </div>\n      </ApDialog>\n    )\n  },\n\n  toggleCheckbox() {\n    const s = this\n    let state = s.state\n    s.setState({\n      checked: !state.checked,\n      errored: false\n    })\n  },\n\n  handleSubmit(e) {\n    const s = this\n    let { state, props } = s\n    if (!state.checked) {\n      s.setState({\n        errored: true\n      })\n      return\n    }\n    s.setState({\n      errored: false\n    })\n    if (props.onSubmit) {\n      props.onSubmit(e)\n    }\n  },\n\n  handleCancel(e) {\n    const s = this,\n      { props } = s\n    s.setState({ errored: false })\n    if (props.onCancel) {\n      props.onCancel(e)\n    }\n  },\n\n  // ------------------\n  // Private\n  // ------------------\n  _renderError(errored) {\n    const s = this\n    let { props } = s\n    if (!errored) {\n      return null\n    }\n    return (\n      <div className=\"ap-confirm-dialog-err\">\n        <span>{ props.errorText }</span>\n      </div>\n    )\n  },\n  _renderCheckbox (checked) {\n    const s = this\n    let { props } = s\n    return (\n      <div>\n        <ApCheckbox className=\"ap-confirm-dialog-checkbox\"\n                    checked={ checked }\n                    name={ props.checkboxName }\n                    id={ props.checkboxId }\n                    title={ props.checkboxText }\n                    onChange={ s.toggleCheckbox }\n                    value=\"YES\"\n\n        />\n      </div>\n    )\n  },\n  _renderSubmitButton (checked) {\n    const s = this\n    let { props } = s\n    return (\n      <ApButton onTap={ s.handleSubmit }\n                disabled={ false }\n                primary={ true }\n                className={ classnames('ap-confirm-dialog-button', {\n                            'ap-confirm-dialog-button-disabled': !checked\n                      }) }>\n        <span className=\"ap-confirm-dialog-button-text\">{ props.submitText }</span>\n      </ApButton>\n    )\n  }\n\n})\n\nmodule.exports = ApConfirmDialog\n"]}
\No newline at end of file