UNPKG

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