UNPKG

16.2 kBJavaScriptView Raw
1/**
2 * Dialog component.
3 * @class ApDialog
4 */
5
6'use strict';
7
8Object.defineProperty(exports, "__esModule", {
9 value: true
10});
11
12var _react = require('react');
13
14var _react2 = _interopRequireDefault(_react);
15
16var _classnames = require('classnames');
17
18var _classnames2 = _interopRequireDefault(_classnames);
19
20var _apemanReactTouchable = require('apeman-react-touchable');
21
22var _apemanReactIcon = require('apeman-react-icon');
23
24var _apemanReactSpinner = require('apeman-react-spinner');
25
26var _ap_dialog_header = require('./ap_dialog_header');
27
28var _ap_dialog_header2 = _interopRequireDefault(_ap_dialog_header);
29
30var _ap_dialog_body = require('./ap_dialog_body');
31
32var _ap_dialog_body2 = _interopRequireDefault(_ap_dialog_body);
33
34function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
35
36var DEFAULT_CLOSE_ICON = 'fa fa-close';
37
38/** @lends ApDialog */
39var ApDialog = _react2.default.createClass({
40 displayName: 'ApDialog',
41
42
43 // --------------------
44 // Specs
45 // --------------------
46
47 propTypes: {
48 present: _react.PropTypes.bool.isRequired,
49 onClose: _react.PropTypes.func,
50 spinning: _react.PropTypes.bool,
51 spinner: _react.PropTypes.string,
52 title: _react.PropTypes.string,
53 closeIcon: _react.PropTypes.string
54 },
55
56 mixins: [],
57
58 statics: {
59 DEFAULT_CLOSE_ICON: DEFAULT_CLOSE_ICON
60 },
61
62 getInitialState: function getInitialState() {
63 return {};
64 },
65 getDefaultProps: function getDefaultProps() {
66 return {
67 present: false,
68 onClose: null,
69 spinning: false,
70 spinner: _apemanReactSpinner.ApSpinner.DEFAULT_THEME,
71 title: null,
72 closeIcon: DEFAULT_CLOSE_ICON
73 };
74 },
75 render: function render() {
76 var s = this;
77 var props = s.props;
78
79 if (!props.present) {
80 return null;
81 }
82 return _react2.default.createElement(
83 'div',
84 { className: (0, _classnames2.default)('ap-dialog', props.className, {
85 'ap-dialog-present': props.present
86 }),
87 style: Object.assign({}, props.style) },
88 _react2.default.createElement(_apemanReactSpinner.ApSpinner, { theme: props.spinner,
89 className: 'ap-dialog-spinner',
90 enabled: props.spinning }),
91 _react2.default.createElement(
92 'div',
93 { className: 'ap-dialog-inner' },
94 s._renderBack(),
95 _react2.default.createElement(
96 'div',
97 { className: 'ap-dialog-content' },
98 _react2.default.createElement(
99 _ap_dialog_header2.default,
100 null,
101 s._renderTitle(),
102 s._renderCloseButton()
103 ),
104 _react2.default.createElement(
105 _ap_dialog_body2.default,
106 null,
107 props.children
108 )
109 )
110 )
111 );
112 },
113
114
115 // --------------------
116 // Lifecycle
117 // --------------------
118
119 componentWillMount: function componentWillMount() {
120 var s = this;
121 },
122 componentDidMount: function componentDidMount() {
123 var s = this;
124 var props = s.props;
125
126 s.toggleDocumentScroll(props.present);
127 },
128 componentWillReceiveProps: function componentWillReceiveProps(nextProps) {
129 var s = this;
130
131 s.toggleDocumentScroll(nextProps.present);
132 },
133 shouldComponentUpdate: function shouldComponentUpdate(nextProps, nextState) {
134 var s = this;
135 return true;
136 },
137 componentWillUpdate: function componentWillUpdate(nextProps, nextState) {
138 var s = this;
139 },
140 componentDidUpdate: function componentDidUpdate(prevProps, prevState) {
141 var s = this;
142 },
143 componentWillUnmount: function componentWillUnmount() {
144 var s = this;
145 s.toggleDocumentScroll(false);
146 },
147
148
149 // ------------------
150 // Helper
151 // ------------------
152
153 handleClose: function handleClose(e) {
154 var s = this;
155 var props = s.props;
156
157 if (props.onClose) {
158 props.onClose(e);
159 }
160 },
161 toggleDocumentScroll: function toggleDocumentScroll(enabled) {
162 var s = this;
163
164 var body = document.body;
165 if (enabled) {
166 body.classList.add('ap-dialog-fix');
167 } else {
168 body.classList.remove('ap-dialog-fix');
169 }
170 },
171
172
173 // ------------------
174 // Private
175 // ------------------
176
177 _renderBack: function _renderBack() {
178 var s = this;
179 var props = s.props;
180
181 return _react2.default.createElement(
182 'div',
183 { className: 'ap-dialog-back' },
184 _react2.default.createElement(
185 _apemanReactTouchable.ApTouchable,
186 { onTap: s.handleClose },
187 _react2.default.createElement('div', { className: 'ap-dialog-back-inner' })
188 )
189 );
190 },
191 _renderCloseButton: function _renderCloseButton() {
192 var s = this;
193 var props = s.props;
194
195 return _react2.default.createElement(
196 'a',
197 { className: 'ap-dialog-close-button' },
198 _react2.default.createElement(
199 _apemanReactTouchable.ApTouchable,
200 { onTap: s.handleClose },
201 _react2.default.createElement(
202 'span',
203 null,
204 _react2.default.createElement(_apemanReactIcon.ApIcon, { className: (0, _classnames2.default)('ap-dialog-close-button-icon', props.closeIcon) })
205 )
206 )
207 );
208 },
209 _renderTitle: function _renderTitle() {
210 var s = this;
211 var props = s.props;
212
213 return _react2.default.createElement(
214 'h3',
215 { className: 'ap-dialog-title' },
216 props.title
217 );
218 }
219});
220
221exports.default = ApDialog;
222//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["ap_dialog.jsx"],"names":[],"mappings":"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","file":"ap_dialog.js","sourceRoot":"/Users/okunishinishi/Projects/apeman-projects/apeman-react-dialog/lib","sourcesContent":["/**\n * Dialog component.\n * @class ApDialog\n */\n\n'use strict'\n\n\nimport React, {PropTypes as types} from 'react'\nimport classnames from 'classnames'\n\nimport {ApTouchable} from 'apeman-react-touchable'\nimport {ApIcon} from 'apeman-react-icon'\nimport {ApSpinner} from 'apeman-react-spinner'\nimport ApDialogHeader from './ap_dialog_header'\nimport ApDialogBody from './ap_dialog_body'\n\n\nconst DEFAULT_CLOSE_ICON = 'fa fa-close'\n\n/** @lends ApDialog */\nlet ApDialog = React.createClass({\n\n    // --------------------\n    // Specs\n    // --------------------\n\n    propTypes: {\n        present: types.bool.isRequired,\n        onClose: types.func,\n        spinning: types.bool,\n        spinner: types.string,\n        title: types.string,\n        closeIcon: types.string\n    },\n\n    mixins: [],\n\n    statics: {\n        DEFAULT_CLOSE_ICON\n    },\n\n    getInitialState () {\n        return {}\n    },\n\n    getDefaultProps () {\n        return {\n            present: false,\n            onClose: null,\n            spinning: false,\n            spinner: ApSpinner.DEFAULT_THEME,\n            title: null,\n            closeIcon: DEFAULT_CLOSE_ICON\n        }\n    },\n\n    render () {\n        const s = this,\n            {props} = s\n        if (!props.present) {\n            return null;\n        }\n        return (\n            <div className={ classnames('ap-dialog', props.className, {\n                'ap-dialog-present':props.present\n            }) }\n                 style={ Object.assign({}, props.style) }>\n                <ApSpinner theme={ props.spinner }\n                           className=\"ap-dialog-spinner\"\n                           enabled={ props.spinning }/>\n                <div className=\"ap-dialog-inner\">\n                    { s._renderBack() }\n                    <div className=\"ap-dialog-content\">\n                        <ApDialogHeader>\n                            { s._renderTitle() }\n                            { s._renderCloseButton() }\n                        </ApDialogHeader>\n                        <ApDialogBody>\n                            { props.children }\n                        </ApDialogBody>\n                    </div>\n                </div>\n            </div>\n        )\n    },\n\n\n    // --------------------\n    // Lifecycle\n    // --------------------\n\n    componentWillMount () {\n        const s = this\n\n    },\n\n    componentDidMount () {\n        const s = this,\n            {props} = s\n        s.toggleDocumentScroll(props.present)\n    },\n\n    componentWillReceiveProps (nextProps) {\n        const s = this\n\n        s.toggleDocumentScroll(nextProps.present)\n    },\n\n    shouldComponentUpdate(nextProps, nextState) {\n        const s = this\n        return true\n    },\n\n    componentWillUpdate(nextProps, nextState) {\n        const s = this\n    },\n\n    componentDidUpdate(prevProps, prevState) {\n        const s = this\n    },\n\n    componentWillUnmount () {\n        const s = this\n        s.toggleDocumentScroll(false)\n    },\n\n    // ------------------\n    // Helper\n    // ------------------\n\n    handleClose(e) {\n        const s = this,\n            {props} = s\n        if (props.onClose) {\n            props.onClose(e)\n        }\n    },\n\n    toggleDocumentScroll(enabled) {\n        const s = this\n\n        let body = document.body;\n        if (enabled) {\n            body.classList.add('ap-dialog-fix')\n        } else {\n            body.classList.remove('ap-dialog-fix')\n        }\n\n    },\n\n    // ------------------\n    // Private\n    // ------------------\n\n    _renderBack() {\n        const s = this,\n            {props} = s\n        return (\n            <div className=\"ap-dialog-back\">\n                <ApTouchable onTap={ s.handleClose }>\n                    <div className=\"ap-dialog-back-inner\"></div>\n                </ApTouchable>\n            </div>\n        )\n    },\n\n    _renderCloseButton() {\n        const s = this,\n            {props} = s\n        return (\n            <a className=\"ap-dialog-close-button\">\n                <ApTouchable onTap={ s.handleClose }>\n                <span>\n                    <ApIcon className={ classnames('ap-dialog-close-button-icon', props.closeIcon) }/>\n                </span>\n                </ApTouchable>\n            </a>\n        )\n    },\n\n    _renderTitle() {\n        const s = this,\n            {props} = s\n        return (\n            <h3 className=\"ap-dialog-title\">{ props.title }</h3>\n        )\n    }\n})\n\nexport default ApDialog;"]}
\No newline at end of file