1 | /**
|
2 | * Dialog to confirm.
|
3 | * @constructor ApConfirmDialog
|
4 | */
|
5 |
|
6 | ;
|
7 |
|
8 | 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; };
|
9 |
|
10 | var _react = require('react');
|
11 |
|
12 | var _react2 = _interopRequireDefault(_react);
|
13 |
|
14 | var _classnames = require('classnames');
|
15 |
|
16 | var _classnames2 = _interopRequireDefault(_classnames);
|
17 |
|
18 | var _apemanReactTouchable = require('apeman-react-touchable');
|
19 |
|
20 | var _apemanReactCheckbox = require('apeman-react-checkbox');
|
21 |
|
22 | var _apemanReactButton = require('apeman-react-button');
|
23 |
|
24 | var _apemanReactMixins = require('apeman-react-mixins');
|
25 |
|
26 | var _ap_dialog = require('./ap_dialog');
|
27 |
|
28 | var _ap_dialog2 = _interopRequireDefault(_ap_dialog);
|
29 |
|
30 | var _uuid = require('uuid');
|
31 |
|
32 | var _uuid2 = _interopRequireDefault(_uuid);
|
33 |
|
34 | function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
35 |
|
36 | /** lends ApConfirmDialog */
|
37 | var 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 |
|
217 | module.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 |