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