1 | /**
|
2 | * Toast component
|
3 | * @class ApToast
|
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 _apemanReactMixins = require('apeman-react-mixins');
|
17 |
|
18 | var _classnames = require('classnames');
|
19 |
|
20 | var _classnames2 = _interopRequireDefault(_classnames);
|
21 |
|
22 | var _arrayfilter = require('arrayfilter');
|
23 |
|
24 | var _arrayfilter2 = _interopRequireDefault(_arrayfilter);
|
25 |
|
26 | var _ap_toast_item = require('./ap_toast_item');
|
27 |
|
28 | var _ap_toast_item2 = _interopRequireDefault(_ap_toast_item);
|
29 |
|
30 | function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
31 |
|
32 | /** @lends ApToast */
|
33 | var ApToast = _react2.default.createClass({
|
34 | displayName: 'ApToast',
|
35 |
|
36 |
|
37 | // --------------------
|
38 | // Specs
|
39 | // --------------------
|
40 |
|
41 | propTypes: {
|
42 | message: _react.PropTypes.string,
|
43 | duration: _react.PropTypes.number,
|
44 | icon: _react.PropTypes.string,
|
45 | name: _react.PropTypes.string,
|
46 | onDismiss: _react.PropTypes.func
|
47 | },
|
48 |
|
49 | mixins: [_apemanReactMixins.ApPureMixin],
|
50 |
|
51 | statics: {
|
52 | itemJoiner: '____'
|
53 | },
|
54 |
|
55 | getInitialState: function getInitialState() {
|
56 | return {
|
57 | items: ''
|
58 | };
|
59 | },
|
60 | getDefaultProps: function getDefaultProps() {
|
61 | return {
|
62 | message: null,
|
63 | duration: 2000,
|
64 | icon: null,
|
65 | name: null,
|
66 | onDismiss: null
|
67 | };
|
68 | },
|
69 | render: function render() {
|
70 | var s = this;
|
71 | var state = s.state;
|
72 | var props = s.props;
|
73 |
|
74 |
|
75 | var valid = state.items.length;
|
76 | if (!valid) {
|
77 | return null;
|
78 | }
|
79 | return _react2.default.createElement(
|
80 | 'div',
|
81 | { className: (0, _classnames2.default)('ap-toast', props.className, {}),
|
82 | style: Object.assign({}, props.style) },
|
83 | _react2.default.createElement(
|
84 | 'div',
|
85 | { className: 'ap-toast-inner' },
|
86 | s._renderToastItem()
|
87 | )
|
88 | );
|
89 | },
|
90 |
|
91 |
|
92 | // --------------------
|
93 | // Lifecycle
|
94 | // --------------------
|
95 |
|
96 | componentWillMount: function componentWillMount() {
|
97 | var s = this;
|
98 | },
|
99 | componentDidMount: function componentDidMount() {
|
100 | var s = this;
|
101 | var props = s.props;
|
102 |
|
103 | s.startTicking();
|
104 | s.pushToastItem(props.message);
|
105 | },
|
106 | componentWillReceiveProps: function componentWillReceiveProps(nextProps) {
|
107 | var s = this;
|
108 | s.pushToastItem(nextProps.message);
|
109 | },
|
110 | componentWillUnmount: function componentWillUnmount() {
|
111 | var s = this;
|
112 | s.stopTicking();
|
113 | },
|
114 |
|
115 |
|
116 | // ------------------
|
117 | // Custom
|
118 | // ------------------
|
119 |
|
120 | startTicking: function startTicking() {
|
121 | var s = this;
|
122 | clearTimeout(s._tickTimer);
|
123 | s._ticking = true;
|
124 | s.doTick();
|
125 | },
|
126 | stopTicking: function stopTicking() {
|
127 | var s = this;
|
128 | clearTimeout(s._tickTimer);
|
129 | s._ticking = false;
|
130 | },
|
131 | doTick: function doTick() {
|
132 | var s = this;
|
133 | var props = s.props;
|
134 |
|
135 | if (!s._ticking) {
|
136 | return;
|
137 | }
|
138 | s._tickTimer = setTimeout(function () {
|
139 | s.shiftToastItem();
|
140 | s.doTick();
|
141 | }, props.duration);
|
142 | },
|
143 | pushToastItem: function pushToastItem(message) {
|
144 | var s = this;
|
145 | if (!message) {
|
146 | return;
|
147 | }
|
148 | var items = (s.state.items || '').split(ApToast.itemJoiner);
|
149 | var duplicate = items[items.length - 1] === message;
|
150 | if (duplicate) {
|
151 | return;
|
152 | }
|
153 | s.setState({
|
154 | items: items.concat(message).join(ApToast.itemJoiner)
|
155 | });
|
156 | },
|
157 | shiftToastItem: function shiftToastItem() {
|
158 | var s = this;
|
159 | var props = s.props;
|
160 |
|
161 | var items = (s.state.items || '').split(ApToast.itemJoiner);
|
162 | if (!items.length) {
|
163 | s.setState({ items: null });
|
164 | return;
|
165 | }
|
166 | s.dismissToastItem(items[0]);
|
167 | },
|
168 | dismissToastItem: function dismissToastItem(message) {
|
169 | var s = this;
|
170 | var props = s.props;
|
171 |
|
172 | var items = (s.state.items || '').split(ApToast.itemJoiner);
|
173 | s.setState({
|
174 | items: items.filter(function (filtering) {
|
175 | return filtering !== message;
|
176 | }).join(ApToast.itemJoiner)
|
177 | });
|
178 | if (props.onDismiss) {
|
179 | props.onDismiss({ dismissed: message, name: props.name });
|
180 | }
|
181 | },
|
182 | handleToastItemTap: function handleToastItemTap(e) {
|
183 | var s = this;
|
184 | var text = e.target.dataset['text'];
|
185 | s.dismissToastItem(text);
|
186 | },
|
187 |
|
188 |
|
189 | // ------------------
|
190 | // Private
|
191 | // ------------------
|
192 | _ticking: false,
|
193 | _tickTimer: null,
|
194 | _renderToastItem: function _renderToastItem() {
|
195 | var s = this;
|
196 | var state = s.state;
|
197 | var props = s.props;
|
198 |
|
199 | return (state.items || '').split(ApToast.itemJoiner).filter(_arrayfilter2.default.emptyReject()).map(function (text, i) {
|
200 | return _react2.default.createElement(_ap_toast_item2.default, { key: 'toast-' + text + '-' + i,
|
201 | text: text,
|
202 | icon: props.icon,
|
203 | onTap: s.handleToastItemTap
|
204 | });
|
205 | });
|
206 | }
|
207 | });
|
208 |
|
209 | exports.default = ApToast;
|
210 | //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["ap_toast.jsx"],"names":[],"mappings":"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","file":"ap_toast.js","sourceRoot":"/Users/okunishinishi/Projects/apeman-projects/apeman-react-toast/lib","sourcesContent":["/**\n * Toast component\n * @class ApToast\n */\n\n'use strict'\n\nimport React, {PropTypes as types} from 'react'\nimport {ApPureMixin} from 'apeman-react-mixins'\nimport classnames from 'classnames'\nimport arrayfilter from 'arrayfilter'\nimport ApToastItem from './ap_toast_item'\n\n/** @lends ApToast */\nconst ApToast = React.createClass({\n\n  // --------------------\n  // Specs\n  // --------------------\n\n  propTypes: {\n    message: types.string,\n    duration: types.number,\n    icon: types.string,\n    name: types.string,\n    onDismiss: types.func\n  },\n\n  mixins: [\n    ApPureMixin\n  ],\n\n  statics: {\n    itemJoiner: '____'\n  },\n\n  getInitialState () {\n    return {\n      items: ''\n    }\n  },\n\n  getDefaultProps () {\n    return {\n      message: null,\n      duration: 2000,\n      icon: null,\n      name: null,\n      onDismiss: null\n    }\n  },\n\n  render () {\n    const s = this\n    let { state, props } = s\n\n    let valid = state.items.length\n    if (!valid) {\n      return null\n    }\n    return (\n      <div className={ classnames('ap-toast', props.className, {}) }\n           style={ Object.assign({}, props.style) }>\n        <div className=\"ap-toast-inner\">\n          {s._renderToastItem()}\n        </div>\n      </div>\n    )\n  },\n\n  // --------------------\n  // Lifecycle\n  // --------------------\n\n  componentWillMount () {\n    const s = this\n  },\n\n  componentDidMount () {\n    const s = this\n    let { props } = s\n    s.startTicking()\n    s.pushToastItem(props.message)\n  },\n\n  componentWillReceiveProps (nextProps) {\n    const s = this\n    s.pushToastItem(nextProps.message)\n  },\n\n  componentWillUnmount () {\n    const s = this\n    s.stopTicking()\n  },\n\n  // ------------------\n  // Custom\n  // ------------------\n\n  startTicking () {\n    const s = this\n    clearTimeout(s._tickTimer)\n    s._ticking = true\n    s.doTick()\n  },\n\n  stopTicking () {\n    const s = this\n    clearTimeout(s._tickTimer)\n    s._ticking = false\n  },\n\n  doTick () {\n    const s = this\n    let { props } = s\n    if (!s._ticking) {\n      return\n    }\n    s._tickTimer = setTimeout(() => {\n      s.shiftToastItem()\n      s.doTick()\n    }, props.duration)\n  },\n\n  pushToastItem (message) {\n    const s = this\n    if (!message) {\n      return\n    }\n    let items = (s.state.items || '').split(ApToast.itemJoiner)\n    let duplicate = items[ items.length - 1 ] === message\n    if (duplicate) {\n      return\n    }\n    s.setState({\n      items: items.concat(message).join(ApToast.itemJoiner)\n    })\n  },\n\n  shiftToastItem () {\n    const s = this\n    let { props } = s\n    let items = (s.state.items || '').split(ApToast.itemJoiner)\n    if (!items.length) {\n      s.setState({ items: null })\n      return\n    }\n    s.dismissToastItem(items[ 0 ])\n  },\n\n  dismissToastItem (message) {\n    const s = this\n    let { props } = s\n    let items = (s.state.items || '').split(ApToast.itemJoiner)\n    s.setState({\n      items: items.filter((filtering) => filtering !== message)\n        .join(ApToast.itemJoiner)\n    })\n    if (props.onDismiss) {\n      props.onDismiss({ dismissed: message, name: props.name })\n    }\n  },\n\n  handleToastItemTap (e) {\n    const s = this\n    let text = e.target.dataset[ 'text' ]\n    s.dismissToastItem(text)\n  },\n\n  // ------------------\n  // Private\n  // ------------------\n  _ticking: false,\n  _tickTimer: null,\n  _renderToastItem () {\n    const s = this\n    let { state, props } = s\n    return (state.items || '').split(ApToast.itemJoiner)\n      .filter(arrayfilter.emptyReject())\n      .map((text, i) => (\n          <ApToastItem key={`toast-${text}-${i}`}\n                       text={text}\n                       icon={props.icon}\n                       onTap={s.handleToastItemTap}\n          >\n          </ApToastItem>\n        )\n      )\n  }\n})\n\nexport default ApToast\n"]} |
\ | No newline at end of file |