1 | /**
|
2 | * Dialog component.
|
3 | * @class ApDialog
|
4 | */
|
5 |
|
6 | ;
|
7 |
|
8 | Object.defineProperty(exports, "__esModule", {
|
9 | value: true
|
10 | });
|
11 |
|
12 | var _react = require('react');
|
13 |
|
14 | var _react2 = _interopRequireDefault(_react);
|
15 |
|
16 | var _classnames = require('classnames');
|
17 |
|
18 | var _classnames2 = _interopRequireDefault(_classnames);
|
19 |
|
20 | var _apemanReactTouchable = require('apeman-react-touchable');
|
21 |
|
22 | var _apemanReactIcon = require('apeman-react-icon');
|
23 |
|
24 | var _apemanReactSpinner = require('apeman-react-spinner');
|
25 |
|
26 | var _ap_dialog_header = require('./ap_dialog_header');
|
27 |
|
28 | var _ap_dialog_header2 = _interopRequireDefault(_ap_dialog_header);
|
29 |
|
30 | var _ap_dialog_body = require('./ap_dialog_body');
|
31 |
|
32 | var _ap_dialog_body2 = _interopRequireDefault(_ap_dialog_body);
|
33 |
|
34 | function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
35 |
|
36 | var DEFAULT_CLOSE_ICON = 'fa fa-close';
|
37 |
|
38 | /** @lends ApDialog */
|
39 | var 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 |
|
221 | exports.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 |