UNPKG

14.8 kBJavaScriptView Raw
1/**
2 * Toast component
3 * @class ApToast
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 _apemanReactMixinPure = require('apeman-react-mixin-pure');
17
18var _classnames = require('classnames');
19
20var _classnames2 = _interopRequireDefault(_classnames);
21
22var _arrayfilter = require('arrayfilter');
23
24var _arrayfilter2 = _interopRequireDefault(_arrayfilter);
25
26var _ap_toast_item = require('./ap_toast_item');
27
28var _ap_toast_item2 = _interopRequireDefault(_ap_toast_item);
29
30function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
31
32/** @lends ApToast */
33var 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: [_apemanReactMixinPure.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
209exports.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-mixin-pure'\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