UNPKG

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