@tarojs/components-react 3.6.0-canary.9 → 3.6.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/components/ad/loader.js +4 -0
- package/dist/components/ad/loader.js.map +1 -0
- package/dist/components/ad-custom/loader.js +4 -0
- package/dist/components/ad-custom/loader.js.map +1 -0
- package/dist/components/animation-video/loader.js +4 -0
- package/dist/components/animation-video/loader.js.map +1 -0
- package/dist/components/animation-view/loader.js +4 -0
- package/dist/components/animation-view/loader.js.map +1 -0
- package/dist/components/ar-camera/loader.js +4 -0
- package/dist/components/ar-camera/loader.js.map +1 -0
- package/dist/components/audio/loader.js +4 -0
- package/dist/components/audio/loader.js.map +1 -0
- package/dist/components/aweme-data/loader.js +4 -0
- package/dist/components/aweme-data/loader.js.map +1 -0
- package/dist/components/button/loader.js +4 -0
- package/dist/components/button/loader.js.map +1 -0
- package/dist/components/camera/loader.js +4 -0
- package/dist/components/camera/loader.js.map +1 -0
- package/dist/components/canvas/loader.js +4 -0
- package/dist/components/canvas/loader.js.map +1 -0
- package/dist/components/checkbox/loader.js +6 -0
- package/dist/components/checkbox/loader.js.map +1 -0
- package/dist/components/comment/loader.js +6 -0
- package/dist/components/comment/loader.js.map +1 -0
- package/dist/components/contact-button/loader.js +4 -0
- package/dist/components/contact-button/loader.js.map +1 -0
- package/dist/components/cover-image/loader.js +4 -0
- package/dist/components/cover-image/loader.js.map +1 -0
- package/dist/components/cover-view/loader.js +4 -0
- package/dist/components/cover-view/loader.js.map +1 -0
- package/dist/components/editor/loader.js +4 -0
- package/dist/components/editor/loader.js.map +1 -0
- package/dist/components/follow-swan/loader.js +4 -0
- package/dist/components/follow-swan/loader.js.map +1 -0
- package/dist/components/form/loader.js +4 -0
- package/dist/components/form/loader.js.map +1 -0
- package/dist/components/functional-page-navigator/loader.js +4 -0
- package/dist/components/functional-page-navigator/loader.js.map +1 -0
- package/dist/components/icon/loader.js +4 -0
- package/dist/components/icon/loader.js.map +1 -0
- package/dist/{image → components/image}/index.js +24 -18
- package/dist/components/image/index.js.map +1 -0
- package/dist/components/inline-payment-panel/loader.js +4 -0
- package/dist/components/inline-payment-panel/loader.js.map +1 -0
- package/dist/components/input/loader.js +4 -0
- package/dist/components/input/loader.js.map +1 -0
- package/dist/components/keyboard-accessory/loader.js +4 -0
- package/dist/components/keyboard-accessory/loader.js.map +1 -0
- package/dist/components/label/loader.js +4 -0
- package/dist/components/label/loader.js.map +1 -0
- package/dist/components/lifestyle/loader.js +4 -0
- package/dist/components/lifestyle/loader.js.map +1 -0
- package/dist/components/like/loader.js +4 -0
- package/dist/components/like/loader.js.map +1 -0
- package/dist/components/live-player/loader.js +4 -0
- package/dist/components/live-player/loader.js.map +1 -0
- package/dist/components/live-pusher/loader.js +4 -0
- package/dist/components/live-pusher/loader.js.map +1 -0
- package/dist/components/login/loader.js +4 -0
- package/dist/components/login/loader.js.map +1 -0
- package/dist/components/lottie/loader.js +4 -0
- package/dist/components/lottie/loader.js.map +1 -0
- package/dist/components/map/loader.js +4 -0
- package/dist/components/map/loader.js.map +1 -0
- package/dist/components/match-media/loader.js +4 -0
- package/dist/components/match-media/loader.js.map +1 -0
- package/dist/components/movable-area/loader.js +6 -0
- package/dist/components/movable-area/loader.js.map +1 -0
- package/dist/components/navigation-bar/loader.js +4 -0
- package/dist/components/navigation-bar/loader.js.map +1 -0
- package/dist/components/navigator/loader.js +4 -0
- package/dist/components/navigator/loader.js.map +1 -0
- package/dist/components/official-account/loader.js +4 -0
- package/dist/components/official-account/loader.js.map +1 -0
- package/dist/components/open-data/loader.js +4 -0
- package/dist/components/open-data/loader.js.map +1 -0
- package/dist/components/page-container/loader.js +4 -0
- package/dist/components/page-container/loader.js.map +1 -0
- package/dist/components/page-meta/loader.js +4 -0
- package/dist/components/page-meta/loader.js.map +1 -0
- package/dist/components/picker/loader.js +6 -0
- package/dist/components/picker/loader.js.map +1 -0
- package/dist/components/picker-view/loader.js +6 -0
- package/dist/components/picker-view/loader.js.map +1 -0
- package/dist/components/progress/loader.js +4 -0
- package/dist/components/progress/loader.js.map +1 -0
- package/dist/{pull-down-refresh → components/pull-down-refresh}/index.js +85 -29
- package/dist/components/pull-down-refresh/index.js.map +1 -0
- package/dist/components/radio/loader.js +6 -0
- package/dist/components/radio/loader.js.map +1 -0
- package/dist/components/rich-text/loader.js +4 -0
- package/dist/components/rich-text/loader.js.map +1 -0
- package/dist/components/root-portal/loader.js +4 -0
- package/dist/components/root-portal/loader.js.map +1 -0
- package/dist/components/rtc-room/loader.js +6 -0
- package/dist/components/rtc-room/loader.js.map +1 -0
- package/dist/{scroll-view → components/scroll-view}/index.js +66 -34
- package/dist/components/scroll-view/index.js.map +1 -0
- package/dist/components/share-element/loader.js +4 -0
- package/dist/components/share-element/loader.js.map +1 -0
- package/dist/components/slider/loader.js +4 -0
- package/dist/components/slider/loader.js.map +1 -0
- package/dist/components/slot/loader.js +6 -0
- package/dist/components/slot/loader.js.map +1 -0
- package/dist/components/swiper/index.js +359 -0
- package/dist/components/swiper/index.js.map +1 -0
- package/dist/components/switch/loader.js +4 -0
- package/dist/components/switch/loader.js.map +1 -0
- package/dist/components/tabbar/loader.js +6 -0
- package/dist/components/tabbar/loader.js.map +1 -0
- package/dist/components/tabs/loader.js +4 -0
- package/dist/components/tabs/loader.js.map +1 -0
- package/dist/{text → components/text}/index.js +13 -11
- package/dist/components/text/index.js.map +1 -0
- package/dist/components/textarea/loader.js +4 -0
- package/dist/components/textarea/loader.js.map +1 -0
- package/dist/components/video/loader.js +8 -0
- package/dist/components/video/loader.js.map +1 -0
- package/dist/{view → components/view}/index.js +32 -17
- package/dist/components/view/index.js.map +1 -0
- package/dist/components/voip-room/loader.js +4 -0
- package/dist/components/voip-room/loader.js.map +1 -0
- package/dist/components/web-view/loader.js +4 -0
- package/dist/components/web-view/loader.js.map +1 -0
- package/dist/index.js +63 -75
- package/dist/index.js.map +1 -1
- package/dist/{index2.js → utils/index.js} +5 -2
- package/dist/utils/index.js.map +1 -0
- package/package.json +7 -4
- package/types/global.d.ts +5 -0
- package/dist/image/index.js.map +0 -1
- package/dist/index2.js.map +0 -1
- package/dist/pull-down-refresh/index.js.map +0 -1
- package/dist/scroll-view/index.js.map +0 -1
- package/dist/swiper/index.js +0 -9209
- package/dist/swiper/index.js.map +0 -1
- package/dist/text/index.js.map +0 -1
- package/dist/tslib.es6.js +0 -15
- package/dist/tslib.es6.js.map +0 -1
- package/dist/view/index.js.map +0 -1
- package/dist/weui.js +0 -5
- package/dist/weui.js.map +0 -1
- package/index.js +0 -6
|
@@ -2,50 +2,58 @@ import _classCallCheck from '@babel/runtime/helpers/classCallCheck';
|
|
|
2
2
|
import _createClass from '@babel/runtime/helpers/createClass';
|
|
3
3
|
import _inherits from '@babel/runtime/helpers/inherits';
|
|
4
4
|
import _createSuper from '@babel/runtime/helpers/createSuper';
|
|
5
|
-
import '
|
|
6
|
-
import
|
|
5
|
+
import 'weui';
|
|
6
|
+
import classNames from 'classnames';
|
|
7
7
|
import React from 'react';
|
|
8
|
-
import {
|
|
9
|
-
import '@babel/runtime/helpers/typeof';
|
|
10
|
-
|
|
11
|
-
var css_248z = ".taro-scroll {\n -webkit-overflow-scrolling: auto;\n}\n\n.taro-scroll::-webkit-scrollbar {\n display: none;\n}\n\n.taro-scroll-view {\n overflow: hidden;\n}\n\n.taro-scroll-view__scroll-x {\n overflow-x: scroll;\n overflow-y: hidden;\n}\n\n.taro-scroll-view__scroll-y {\n overflow-x: hidden;\n overflow-y: scroll;\n}\n";
|
|
12
|
-
styleInject(css_248z,{"insertAt":"top"});
|
|
8
|
+
import { throttle } from '../../utils/index.js';
|
|
13
9
|
|
|
14
10
|
function easeOutScroll() {
|
|
15
11
|
var from = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;
|
|
16
12
|
var to = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
|
|
17
13
|
var callback = arguments.length > 2 ? arguments[2] : undefined;
|
|
14
|
+
|
|
18
15
|
if (from === to || typeof from !== 'number') {
|
|
19
16
|
return;
|
|
20
17
|
}
|
|
18
|
+
|
|
21
19
|
var change = to - from;
|
|
22
20
|
var dur = 500;
|
|
23
21
|
var sTime = +new Date();
|
|
22
|
+
|
|
24
23
|
function linear(t, b, c, d) {
|
|
25
24
|
return c * t / d + b;
|
|
26
25
|
}
|
|
26
|
+
|
|
27
27
|
var isLarger = to >= from;
|
|
28
|
+
|
|
28
29
|
function step() {
|
|
29
30
|
from = linear(+new Date() - sTime, from, change, dur);
|
|
31
|
+
|
|
30
32
|
if (isLarger && from >= to || !isLarger && to >= from) {
|
|
31
33
|
callback(to);
|
|
32
34
|
return;
|
|
33
35
|
}
|
|
36
|
+
|
|
34
37
|
callback(from);
|
|
35
38
|
requestAnimationFrame(step);
|
|
36
39
|
}
|
|
40
|
+
|
|
37
41
|
step();
|
|
38
42
|
}
|
|
43
|
+
|
|
39
44
|
function scrollIntoView(id) {
|
|
40
45
|
var _a;
|
|
46
|
+
|
|
41
47
|
(_a = document.querySelector("#".concat(id))) === null || _a === void 0 ? void 0 : _a.scrollIntoView({
|
|
42
48
|
behavior: 'smooth',
|
|
43
49
|
block: 'center',
|
|
44
50
|
inline: 'start'
|
|
45
51
|
});
|
|
46
52
|
}
|
|
53
|
+
|
|
47
54
|
function scrollVertical(top, isAnimation) {
|
|
48
55
|
var _this = this;
|
|
56
|
+
|
|
49
57
|
if (isAnimation) {
|
|
50
58
|
easeOutScroll(this._scrollTop, top, function (pos) {
|
|
51
59
|
if (_this.container) _this.container.scrollTop = pos;
|
|
@@ -53,10 +61,13 @@ function scrollVertical(top, isAnimation) {
|
|
|
53
61
|
} else {
|
|
54
62
|
if (this.container) this.container.scrollTop = top;
|
|
55
63
|
}
|
|
64
|
+
|
|
56
65
|
this._scrollTop = top;
|
|
57
66
|
}
|
|
67
|
+
|
|
58
68
|
function scrollHorizontal(left, isAnimation) {
|
|
59
69
|
var _this2 = this;
|
|
70
|
+
|
|
60
71
|
if (isAnimation) {
|
|
61
72
|
easeOutScroll(this._scrollLeft, left, function (pos) {
|
|
62
73
|
if (_this2.container) _this2.container.scrollLeft = pos;
|
|
@@ -64,23 +75,32 @@ function scrollHorizontal(left, isAnimation) {
|
|
|
64
75
|
} else {
|
|
65
76
|
if (this.container) this.container.scrollLeft = left;
|
|
66
77
|
}
|
|
78
|
+
|
|
67
79
|
this._scrollLeft = left;
|
|
68
80
|
}
|
|
81
|
+
|
|
69
82
|
var ScrollView = /*#__PURE__*/function (_React$Component) {
|
|
70
83
|
_inherits(ScrollView, _React$Component);
|
|
84
|
+
|
|
71
85
|
var _super = _createSuper(ScrollView);
|
|
86
|
+
|
|
72
87
|
function ScrollView() {
|
|
73
88
|
var _this3;
|
|
89
|
+
|
|
74
90
|
_classCallCheck(this, ScrollView);
|
|
91
|
+
|
|
75
92
|
_this3 = _super.apply(this, arguments);
|
|
76
93
|
_this3._scrollTop = null;
|
|
77
94
|
_this3._scrollLeft = null;
|
|
78
95
|
_this3.container = null;
|
|
96
|
+
|
|
79
97
|
_this3.onTouchMove = function (e) {
|
|
80
98
|
e.stopPropagation();
|
|
81
99
|
};
|
|
100
|
+
|
|
82
101
|
return _this3;
|
|
83
102
|
}
|
|
103
|
+
|
|
84
104
|
_createClass(ScrollView, [{
|
|
85
105
|
key: "componentDidMount",
|
|
86
106
|
value: function componentDidMount() {
|
|
@@ -95,7 +115,9 @@ var ScrollView = /*#__PURE__*/function (_React$Component) {
|
|
|
95
115
|
key: "handleScroll",
|
|
96
116
|
value: function handleScroll(props) {
|
|
97
117
|
var _this4 = this;
|
|
118
|
+
|
|
98
119
|
var isInit = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
|
|
120
|
+
|
|
99
121
|
// scrollIntoView
|
|
100
122
|
if (props.scrollIntoView && typeof props.scrollIntoView === 'string' && document && document.querySelector && document.querySelector("#".concat(props.scrollIntoView))) {
|
|
101
123
|
if (isInit) {
|
|
@@ -106,8 +128,8 @@ var ScrollView = /*#__PURE__*/function (_React$Component) {
|
|
|
106
128
|
scrollIntoView(props.scrollIntoView);
|
|
107
129
|
}
|
|
108
130
|
} else {
|
|
109
|
-
var isAnimation =
|
|
110
|
-
|
|
131
|
+
var isAnimation = !!props.scrollWithAnimation; // Y 轴滚动
|
|
132
|
+
|
|
111
133
|
if (props.scrollY && typeof props.scrollTop === 'number' && props.scrollTop !== this._scrollTop) {
|
|
112
134
|
if (isInit) {
|
|
113
135
|
setTimeout(function () {
|
|
@@ -116,8 +138,9 @@ var ScrollView = /*#__PURE__*/function (_React$Component) {
|
|
|
116
138
|
} else {
|
|
117
139
|
scrollVertical.bind(this)(props.scrollTop, isAnimation);
|
|
118
140
|
}
|
|
119
|
-
}
|
|
120
|
-
|
|
141
|
+
} // X 轴滚动
|
|
142
|
+
|
|
143
|
+
|
|
121
144
|
if (props.scrollX && typeof props.scrollLeft === 'number' && props.scrollLeft !== this._scrollLeft) {
|
|
122
145
|
if (isInit) {
|
|
123
146
|
setTimeout(function () {
|
|
@@ -133,50 +156,56 @@ var ScrollView = /*#__PURE__*/function (_React$Component) {
|
|
|
133
156
|
key: "render",
|
|
134
157
|
value: function render() {
|
|
135
158
|
var _this5 = this;
|
|
159
|
+
|
|
136
160
|
var _this$props = this.props,
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
161
|
+
className = _this$props.className,
|
|
162
|
+
_this$props$style = _this$props.style,
|
|
163
|
+
style = _this$props$style === void 0 ? {} : _this$props$style,
|
|
164
|
+
onScroll = _this$props.onScroll,
|
|
165
|
+
onScrollToUpper = _this$props.onScrollToUpper,
|
|
166
|
+
onScrollToLower = _this$props.onScrollToLower,
|
|
167
|
+
onTouchMove = _this$props.onTouchMove,
|
|
168
|
+
scrollX = _this$props.scrollX,
|
|
169
|
+
scrollY = _this$props.scrollY;
|
|
146
170
|
var _this$props2 = this.props,
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
171
|
+
_this$props2$upperThr = _this$props2.upperThreshold,
|
|
172
|
+
upperThreshold = _this$props2$upperThr === void 0 ? 50 : _this$props2$upperThr,
|
|
173
|
+
_this$props2$lowerThr = _this$props2.lowerThreshold,
|
|
174
|
+
lowerThreshold = _this$props2$lowerThr === void 0 ? 50 : _this$props2$lowerThr;
|
|
151
175
|
var cls = classNames('taro-scroll', {
|
|
152
176
|
'taro-scroll-view__scroll-x': scrollX,
|
|
153
177
|
'taro-scroll-view__scroll-y': scrollY
|
|
154
178
|
}, className);
|
|
155
179
|
upperThreshold = Number(upperThreshold);
|
|
156
180
|
lowerThreshold = Number(lowerThreshold);
|
|
181
|
+
|
|
157
182
|
var upperAndLower = function upperAndLower(e) {
|
|
158
183
|
if (!_this5.container) return;
|
|
159
184
|
var _this5$container = _this5.container,
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
185
|
+
offsetWidth = _this5$container.offsetWidth,
|
|
186
|
+
offsetHeight = _this5$container.offsetHeight,
|
|
187
|
+
scrollLeft = _this5$container.scrollLeft,
|
|
188
|
+
scrollTop = _this5$container.scrollTop,
|
|
189
|
+
scrollHeight = _this5$container.scrollHeight,
|
|
190
|
+
scrollWidth = _this5$container.scrollWidth;
|
|
191
|
+
|
|
166
192
|
if (onScrollToLower && (_this5.props.scrollY && offsetHeight + scrollTop + lowerThreshold >= scrollHeight || _this5.props.scrollX && offsetWidth + scrollLeft + lowerThreshold >= scrollWidth)) {
|
|
167
193
|
onScrollToLower(e);
|
|
168
194
|
}
|
|
195
|
+
|
|
169
196
|
if (onScrollToUpper && (_this5.props.scrollY && scrollTop <= upperThreshold || _this5.props.scrollX && scrollLeft <= upperThreshold)) {
|
|
170
197
|
onScrollToUpper(e);
|
|
171
198
|
}
|
|
172
199
|
};
|
|
200
|
+
|
|
173
201
|
var upperAndLowerThrottle = throttle(upperAndLower, 200);
|
|
202
|
+
|
|
174
203
|
var _onScroll = function _onScroll(e) {
|
|
175
204
|
var _this5$container2 = _this5.container,
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
205
|
+
scrollLeft = _this5$container2.scrollLeft,
|
|
206
|
+
scrollTop = _this5$container2.scrollTop,
|
|
207
|
+
scrollHeight = _this5$container2.scrollHeight,
|
|
208
|
+
scrollWidth = _this5$container2.scrollWidth;
|
|
180
209
|
_this5._scrollLeft = scrollLeft;
|
|
181
210
|
_this5._scrollTop = scrollTop;
|
|
182
211
|
Object.defineProperty(e, 'detail', {
|
|
@@ -192,9 +221,11 @@ var ScrollView = /*#__PURE__*/function (_React$Component) {
|
|
|
192
221
|
upperAndLowerThrottle(e);
|
|
193
222
|
onScroll && onScroll(e);
|
|
194
223
|
};
|
|
224
|
+
|
|
195
225
|
var _onTouchMove = function _onTouchMove(e) {
|
|
196
226
|
onTouchMove ? onTouchMove(e) : _this5.onTouchMove(e);
|
|
197
227
|
};
|
|
228
|
+
|
|
198
229
|
return React.createElement("div", {
|
|
199
230
|
ref: function ref(container) {
|
|
200
231
|
_this5.container = container;
|
|
@@ -206,6 +237,7 @@ var ScrollView = /*#__PURE__*/function (_React$Component) {
|
|
|
206
237
|
}, this.props.children);
|
|
207
238
|
}
|
|
208
239
|
}]);
|
|
240
|
+
|
|
209
241
|
return ScrollView;
|
|
210
242
|
}(React.Component);
|
|
211
243
|
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../src/components/scroll-view/index.tsx"],"sourcesContent":["import 'weui'\nimport './style/index.css'\n\nimport classNames from 'classnames'\nimport React from 'react'\n\nimport { throttle } from '../../utils'\n\nfunction easeOutScroll (from = 0, to = 0, callback) {\n if (from === to || typeof from !== 'number') {\n return\n }\n const change = to - from\n const dur = 500\n const sTime = +new Date()\n function linear (t, b, c, d) {\n return (c * t) / d + b\n }\n const isLarger = to >= from\n\n function step () {\n from = linear(+new Date() - sTime, from, change, dur)\n if ((isLarger && from >= to) || (!isLarger && to >= from)) {\n callback(to)\n return\n }\n callback(from)\n requestAnimationFrame(step)\n }\n step()\n}\n\nfunction scrollIntoView (id) {\n document.querySelector(`#${id}`)?.scrollIntoView({\n behavior: 'smooth',\n block: 'center',\n inline: 'start'\n })\n}\n\nfunction scrollVertical (top, isAnimation) {\n if (isAnimation) {\n easeOutScroll(this._scrollTop, top, pos => {\n if (this.container) this.container.scrollTop = pos\n })\n } else {\n if (this.container) this.container.scrollTop = top\n }\n this._scrollTop = top\n}\n\nfunction scrollHorizontal (left, isAnimation) {\n if (isAnimation) {\n easeOutScroll(this._scrollLeft, left, pos => {\n if (this.container) this.container.scrollLeft = pos\n })\n } else {\n if (this.container) this.container.scrollLeft = left\n }\n this._scrollLeft = left\n}\n\ninterface IProps extends React.HTMLAttributes<HTMLDivElement> {\n scrollX: boolean\n scrollY: boolean\n upperThreshold: number\n lowerThreshold: number\n scrollTop: number\n scrollLeft: number\n scrollIntoView?: string\n scrollWithAnimation: boolean\n enableBackToTop?: boolean\n onScrollToUpper: (e: React.SyntheticEvent<HTMLDivElement, Event>) => void\n onScrollToLower: (e: React.SyntheticEvent<HTMLDivElement, Event>) => void\n onScroll: (e: React.SyntheticEvent<HTMLDivElement, Event>) => void\n onTouchMove: (e: React.SyntheticEvent<HTMLDivElement, Event>) => void\n}\n\nclass ScrollView extends React.Component<IProps> {\n _scrollTop: any = null\n _scrollLeft: any = null\n container: any = null\n\n onTouchMove = e => {\n e.stopPropagation()\n }\n\n componentDidMount () {\n this.handleScroll(this.props, true)\n }\n\n UNSAFE_componentWillReceiveProps (nextProps) {\n this.handleScroll(nextProps)\n }\n\n handleScroll (props, isInit = false) {\n // scrollIntoView\n if (\n props.scrollIntoView &&\n typeof props.scrollIntoView === 'string' &&\n document &&\n document.querySelector &&\n document.querySelector(`#${props.scrollIntoView}`)\n ) {\n if (isInit) {\n setTimeout(() => scrollIntoView(props.scrollIntoView), 500)\n } else {\n scrollIntoView(props.scrollIntoView)\n }\n } else {\n const isAnimation = !!props.scrollWithAnimation\n // Y 轴滚动\n if (props.scrollY && typeof props.scrollTop === 'number' && props.scrollTop !== this._scrollTop) {\n if (isInit) {\n setTimeout(() => scrollVertical.bind(this)(props.scrollTop, isAnimation), 10)\n } else {\n scrollVertical.bind(this)(props.scrollTop, isAnimation)\n }\n }\n // X 轴滚动\n if (props.scrollX && typeof props.scrollLeft === 'number' && props.scrollLeft !== this._scrollLeft) {\n if (isInit) {\n setTimeout(() => scrollHorizontal.bind(this)(props.scrollLeft, isAnimation), 10)\n } else {\n scrollHorizontal.bind(this)(props.scrollLeft, isAnimation)\n }\n }\n }\n }\n\n render () {\n const {\n className,\n style = {},\n onScroll,\n onScrollToUpper,\n onScrollToLower,\n onTouchMove,\n scrollX,\n scrollY\n } = this.props\n let { upperThreshold = 50, lowerThreshold = 50 } = this.props\n const cls = classNames(\n 'taro-scroll',\n {\n 'taro-scroll-view__scroll-x': scrollX,\n 'taro-scroll-view__scroll-y': scrollY\n },\n className\n )\n upperThreshold = Number(upperThreshold)\n lowerThreshold = Number(lowerThreshold)\n const upperAndLower = e => {\n if (!this.container) return\n const { offsetWidth, offsetHeight, scrollLeft, scrollTop, scrollHeight, scrollWidth } = this.container\n if (\n onScrollToLower &&\n ((this.props.scrollY && offsetHeight + scrollTop + lowerThreshold >= scrollHeight) ||\n (this.props.scrollX && offsetWidth + scrollLeft + lowerThreshold >= scrollWidth))\n ) {\n onScrollToLower(e)\n }\n if (\n onScrollToUpper &&\n ((this.props.scrollY && scrollTop <= upperThreshold) || (this.props.scrollX && scrollLeft <= upperThreshold))\n ) {\n onScrollToUpper(e)\n }\n }\n const upperAndLowerThrottle = throttle(upperAndLower, 200)\n const _onScroll = e => {\n const { scrollLeft, scrollTop, scrollHeight, scrollWidth } = this.container\n this._scrollLeft = scrollLeft\n this._scrollTop = scrollTop\n Object.defineProperty(e, 'detail', {\n enumerable: true,\n writable: true,\n value: {\n scrollLeft,\n scrollTop,\n scrollHeight,\n scrollWidth\n }\n })\n upperAndLowerThrottle(e)\n onScroll && onScroll(e)\n }\n const _onTouchMove = e => {\n onTouchMove ? onTouchMove(e) : this.onTouchMove(e)\n }\n return (\n <div\n ref={container => {\n this.container = container\n }}\n style={style}\n className={cls}\n onScroll={_onScroll}\n onTouchMove={_onTouchMove}\n >\n {this.props.children}\n </div>\n )\n }\n}\n\nexport default ScrollView\n"],"names":["easeOutScroll","from","to","callback","change","dur","sTime","Date","linear","t","b","c","d","isLarger","step","requestAnimationFrame","scrollIntoView","id","_a","document","querySelector","behavior","block","inline","scrollVertical","top","isAnimation","_scrollTop","pos","container","scrollTop","scrollHorizontal","left","_scrollLeft","scrollLeft","ScrollView","onTouchMove","e","stopPropagation","handleScroll","props","nextProps","isInit","setTimeout","scrollWithAnimation","scrollY","bind","scrollX","className","style","onScroll","onScrollToUpper","onScrollToLower","upperThreshold","lowerThreshold","cls","classNames","Number","upperAndLower","offsetWidth","offsetHeight","scrollHeight","scrollWidth","upperAndLowerThrottle","throttle","_onScroll","Object","defineProperty","enumerable","writable","value","_onTouchMove","React","createElement","ref","children","Component"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"loader.js","sources":["../../../src/components/share-element/loader.ts"],"sourcesContent":["import { defineCustomElement } from '@tarojs/components/dist/components/taro-share-element-core'\n\ndefineCustomElement()\n"],"names":["defineCustomElement"],"mappings":";;AAEAA,mBAAmB,EAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"loader.js","sources":["../../../src/components/slider/loader.ts"],"sourcesContent":["import { defineCustomElement } from '@tarojs/components/dist/components/taro-slider-core'\n\ndefineCustomElement()\n"],"names":["defineCustomElement"],"mappings":";;AAEAA,mBAAmB,EAAA"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { defineCustomElement } from '@tarojs/components/dist/components/taro-native-slot-core';
|
|
2
|
+
import { defineCustomElement as defineCustomElement$1 } from '@tarojs/components/dist/components/taro-slot-core';
|
|
3
|
+
|
|
4
|
+
defineCustomElement();
|
|
5
|
+
defineCustomElement$1();
|
|
6
|
+
//# sourceMappingURL=loader.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"loader.js","sources":["../../../src/components/slot/loader.ts"],"sourcesContent":["import { defineCustomElement as defineCustomElementTaroNativeSlotCore } from '@tarojs/components/dist/components/taro-native-slot-core'\nimport { defineCustomElement as defineCustomElementTaroSlotCore } from '@tarojs/components/dist/components/taro-slot-core'\n\ndefineCustomElementTaroNativeSlotCore()\ndefineCustomElementTaroSlotCore()\n"],"names":["defineCustomElementTaroNativeSlotCore","defineCustomElementTaroSlotCore"],"mappings":";;;AAGAA,mBAAqC,EAAA,CAAA;AACrCC,qBAA+B,EAAA"}
|
|
@@ -0,0 +1,359 @@
|
|
|
1
|
+
import _typeof from '@babel/runtime/helpers/typeof';
|
|
2
|
+
import _classCallCheck from '@babel/runtime/helpers/classCallCheck';
|
|
3
|
+
import _createClass from '@babel/runtime/helpers/createClass';
|
|
4
|
+
import _inherits from '@babel/runtime/helpers/inherits';
|
|
5
|
+
import _createSuper from '@babel/runtime/helpers/createSuper';
|
|
6
|
+
import { __rest } from 'tslib';
|
|
7
|
+
import 'swiper/swiper-bundle.min.css';
|
|
8
|
+
import 'weui';
|
|
9
|
+
import classNames from 'classnames';
|
|
10
|
+
import React from 'react';
|
|
11
|
+
import Swipers from 'swiper/swiper-bundle.esm.js';
|
|
12
|
+
import { debounce } from '../../utils/index.js';
|
|
13
|
+
|
|
14
|
+
var INSTANCE_ID = 0;
|
|
15
|
+
|
|
16
|
+
var createEvent = function createEvent(type) {
|
|
17
|
+
var e;
|
|
18
|
+
|
|
19
|
+
try {
|
|
20
|
+
e = new TouchEvent(type);
|
|
21
|
+
} catch (err) {
|
|
22
|
+
e = document.createEvent('Event');
|
|
23
|
+
e.initEvent(type, true, true);
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
return e;
|
|
27
|
+
};
|
|
28
|
+
|
|
29
|
+
var SwiperItem = /*#__PURE__*/function (_React$Component) {
|
|
30
|
+
_inherits(SwiperItem, _React$Component);
|
|
31
|
+
|
|
32
|
+
var _super = _createSuper(SwiperItem);
|
|
33
|
+
|
|
34
|
+
function SwiperItem() {
|
|
35
|
+
_classCallCheck(this, SwiperItem);
|
|
36
|
+
|
|
37
|
+
return _super.apply(this, arguments);
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
_createClass(SwiperItem, [{
|
|
41
|
+
key: "render",
|
|
42
|
+
value: function render() {
|
|
43
|
+
var _a = this.props,
|
|
44
|
+
className = _a.className,
|
|
45
|
+
style = _a.style,
|
|
46
|
+
itemId = _a.itemId,
|
|
47
|
+
children = _a.children,
|
|
48
|
+
restProps = __rest(_a, ["className", "style", "itemId", "children"]);
|
|
49
|
+
|
|
50
|
+
var cls = classNames('swiper-slide', className);
|
|
51
|
+
return React.createElement("div", Object.assign({
|
|
52
|
+
className: cls,
|
|
53
|
+
style: style,
|
|
54
|
+
"item-id": itemId
|
|
55
|
+
}, restProps), children);
|
|
56
|
+
}
|
|
57
|
+
}]);
|
|
58
|
+
|
|
59
|
+
return SwiperItem;
|
|
60
|
+
}(React.Component);
|
|
61
|
+
|
|
62
|
+
var Swiper = /*#__PURE__*/function (_React$Component2) {
|
|
63
|
+
_inherits(Swiper, _React$Component2);
|
|
64
|
+
|
|
65
|
+
var _super2 = _createSuper(Swiper);
|
|
66
|
+
|
|
67
|
+
function Swiper() {
|
|
68
|
+
var _this;
|
|
69
|
+
|
|
70
|
+
_classCallCheck(this, Swiper);
|
|
71
|
+
|
|
72
|
+
_this = _super2.apply(this, arguments);
|
|
73
|
+
_this._id = 1 + INSTANCE_ID++;
|
|
74
|
+
_this._$current = 0;
|
|
75
|
+
_this._$width = 0;
|
|
76
|
+
_this._$height = 0;
|
|
77
|
+
|
|
78
|
+
_this.handleSwiperLoopListen = function () {
|
|
79
|
+
var _a, _b, _c, _d;
|
|
80
|
+
|
|
81
|
+
(_b = (_a = _this.observerFirst) === null || _a === void 0 ? void 0 : _a.disconnect) === null || _b === void 0 ? void 0 : _b.call(_a);
|
|
82
|
+
(_d = (_c = _this.observerLast) === null || _c === void 0 ? void 0 : _c.disconnect) === null || _d === void 0 ? void 0 : _d.call(_c);
|
|
83
|
+
_this.observerFirst = new MutationObserver(_this.handleSwiperLoop);
|
|
84
|
+
_this.observerLast = new MutationObserver(_this.handleSwiperLoop);
|
|
85
|
+
var wrapper = _this.mySwiper.$wrapperEl[0];
|
|
86
|
+
var list = wrapper.querySelectorAll('taro-swiper-item-core:not(.swiper-slide-duplicate)');
|
|
87
|
+
|
|
88
|
+
if (list.length >= 1) {
|
|
89
|
+
_this.observerFirst.observe(list[0], {
|
|
90
|
+
characterData: true
|
|
91
|
+
});
|
|
92
|
+
} else if (list.length >= 2) {
|
|
93
|
+
_this.observerLast.observe(list[list.length - 1], {
|
|
94
|
+
characterData: true
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
};
|
|
98
|
+
|
|
99
|
+
_this.handleSwiperLoop = debounce(function () {
|
|
100
|
+
if (_this.mySwiper && _this.mySwiper.$wrapperEl && _this.props.circular) {
|
|
101
|
+
// @ts-ignore
|
|
102
|
+
_this.mySwiper.loopDestroy(); // @ts-ignore
|
|
103
|
+
|
|
104
|
+
|
|
105
|
+
_this.mySwiper.loopCreate();
|
|
106
|
+
}
|
|
107
|
+
}, 500);
|
|
108
|
+
return _this;
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
_createClass(Swiper, [{
|
|
112
|
+
key: "componentDidMount",
|
|
113
|
+
value: function componentDidMount() {
|
|
114
|
+
var _this2 = this;
|
|
115
|
+
|
|
116
|
+
var _this$props = this.props,
|
|
117
|
+
_this$props$autoplay = _this$props.autoplay,
|
|
118
|
+
autoplay = _this$props$autoplay === void 0 ? false : _this$props$autoplay,
|
|
119
|
+
_this$props$circular = _this$props.circular,
|
|
120
|
+
circular = _this$props$circular === void 0 ? true : _this$props$circular,
|
|
121
|
+
_this$props$current = _this$props.current,
|
|
122
|
+
current = _this$props$current === void 0 ? 0 : _this$props$current,
|
|
123
|
+
_this$props$displayMu = _this$props.displayMultipleItems,
|
|
124
|
+
displayMultipleItems = _this$props$displayMu === void 0 ? 1 : _this$props$displayMu,
|
|
125
|
+
_this$props$duration = _this$props.duration,
|
|
126
|
+
duration = _this$props$duration === void 0 ? 500 : _this$props$duration,
|
|
127
|
+
_this$props$interval = _this$props.interval,
|
|
128
|
+
interval = _this$props$interval === void 0 ? 5000 : _this$props$interval,
|
|
129
|
+
spaceBetween = _this$props.spaceBetween,
|
|
130
|
+
vertical = _this$props.vertical; // eslint-disable-next-line @typescript-eslint/no-this-alias
|
|
131
|
+
|
|
132
|
+
var that = this;
|
|
133
|
+
var opt = {
|
|
134
|
+
// 指示器
|
|
135
|
+
pagination: {
|
|
136
|
+
el: ".taro-swiper-".concat(this._id, " > .swiper-container > .swiper-pagination")
|
|
137
|
+
},
|
|
138
|
+
direction: vertical ? 'vertical' : 'horizontal',
|
|
139
|
+
loop: circular,
|
|
140
|
+
slidesPerView: parseFloat(String(displayMultipleItems)),
|
|
141
|
+
initialSlide: parseInt(String(current), 10),
|
|
142
|
+
speed: parseInt(String(duration), 10),
|
|
143
|
+
observer: true,
|
|
144
|
+
observeParents: true,
|
|
145
|
+
on: {
|
|
146
|
+
slideChange: function slideChange() {
|
|
147
|
+
var e = createEvent('touchend');
|
|
148
|
+
|
|
149
|
+
try {
|
|
150
|
+
Object.defineProperty(e, 'detail', {
|
|
151
|
+
enumerable: true,
|
|
152
|
+
value: {
|
|
153
|
+
current: this.realIndex
|
|
154
|
+
}
|
|
155
|
+
});
|
|
156
|
+
} catch (err) {} // eslint-disable-line no-empty
|
|
157
|
+
|
|
158
|
+
|
|
159
|
+
that._$current = this.realIndex;
|
|
160
|
+
that.handleOnChange(e);
|
|
161
|
+
},
|
|
162
|
+
transitionEnd: function transitionEnd() {
|
|
163
|
+
var e = createEvent('touchend');
|
|
164
|
+
|
|
165
|
+
try {
|
|
166
|
+
Object.defineProperty(e, 'detail', {
|
|
167
|
+
enumerable: true,
|
|
168
|
+
value: {
|
|
169
|
+
current: this.mySwiper.realIndex
|
|
170
|
+
}
|
|
171
|
+
});
|
|
172
|
+
|
|
173
|
+
if (this.mySwiper.isBeginning) {
|
|
174
|
+
this.mySwiper.slideToLoop(this.props.children.length - 1, 0);
|
|
175
|
+
} else if (this.mySwiper.isEnd) {
|
|
176
|
+
this.mySwiper.slideToLoop(0, 0);
|
|
177
|
+
}
|
|
178
|
+
} catch (err) {} // eslint-disable-line no-empty
|
|
179
|
+
|
|
180
|
+
|
|
181
|
+
that.handleOnAnimationFinish(e);
|
|
182
|
+
},
|
|
183
|
+
observerUpdate: function observerUpdate(_swiper, e) {
|
|
184
|
+
var target = e.target;
|
|
185
|
+
var className = target && typeof target.className === 'string' ? target.className : '';
|
|
186
|
+
|
|
187
|
+
if (className.includes('taro_page') && target.style.display !== 'none') {
|
|
188
|
+
if (that.props.autoplay && target.contains(_swiper.$el[0])) {
|
|
189
|
+
if (that.props.circular) {
|
|
190
|
+
_swiper.slideToLoop(this.realIndex, 0); // 更新下标
|
|
191
|
+
|
|
192
|
+
} else {
|
|
193
|
+
_swiper.slideTo(this.realIndex);
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
}; // 自动播放
|
|
200
|
+
|
|
201
|
+
if (autoplay) {
|
|
202
|
+
opt.autoplay = {
|
|
203
|
+
delay: parseInt(String(interval), 10),
|
|
204
|
+
disableOnInteraction: false
|
|
205
|
+
};
|
|
206
|
+
} // 两端距离
|
|
207
|
+
|
|
208
|
+
|
|
209
|
+
if (spaceBetween) {
|
|
210
|
+
opt.spaceBetween = spaceBetween;
|
|
211
|
+
}
|
|
212
|
+
|
|
213
|
+
this.mySwiper = new Swipers(this.$el, opt);
|
|
214
|
+
setTimeout(function () {
|
|
215
|
+
_this2.mySwiper.update();
|
|
216
|
+
}, 500);
|
|
217
|
+
if (!this.mySwiper || !this.props.circular) return;
|
|
218
|
+
var wrapper = this.mySwiper.$wrapperEl[0];
|
|
219
|
+
this.observer = new MutationObserver(this.handleSwiperLoopListen);
|
|
220
|
+
this.observer.observe(wrapper, {
|
|
221
|
+
childList: true
|
|
222
|
+
});
|
|
223
|
+
}
|
|
224
|
+
}, {
|
|
225
|
+
key: "UNSAFE_componentWillReceiveProps",
|
|
226
|
+
value: function UNSAFE_componentWillReceiveProps(nextProps) {
|
|
227
|
+
if (this.mySwiper) {
|
|
228
|
+
var nextCurrent = typeof nextProps.current === 'number' ? nextProps.current : this._$current || 0;
|
|
229
|
+
this.handleSwiperLoop(); // 是否衔接滚动模式
|
|
230
|
+
|
|
231
|
+
if (nextProps.circular) {
|
|
232
|
+
if (!this.mySwiper.isBeginning && !this.mySwiper.isEnd) {
|
|
233
|
+
this.mySwiper.slideToLoop(parseInt(nextCurrent, 10)); // 更新下标
|
|
234
|
+
}
|
|
235
|
+
} else {
|
|
236
|
+
this.mySwiper.slideTo(parseInt(nextCurrent, 10) + 1); // 更新下标
|
|
237
|
+
}
|
|
238
|
+
|
|
239
|
+
var autoplay = this.mySwiper.autoplay; // 判断是否需要停止或开始自动轮播
|
|
240
|
+
|
|
241
|
+
if (autoplay.running !== nextProps.autoplay) {
|
|
242
|
+
if (nextProps.autoplay) {
|
|
243
|
+
if (_typeof(this.mySwiper.params.autoplay) === 'object') {
|
|
244
|
+
this.mySwiper.params.autoplay.disableOnInteraction = false;
|
|
245
|
+
this.mySwiper.params.autoplay.delay = parseInt(String(this.props.interval) || '3000', 10);
|
|
246
|
+
}
|
|
247
|
+
|
|
248
|
+
autoplay.start();
|
|
249
|
+
} else {
|
|
250
|
+
autoplay.stop();
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
|
|
254
|
+
this.mySwiper.update(); // 更新子元素
|
|
255
|
+
}
|
|
256
|
+
}
|
|
257
|
+
}, {
|
|
258
|
+
key: "componentDidUpdate",
|
|
259
|
+
value: function componentDidUpdate(preProps) {
|
|
260
|
+
if (preProps.children.length === 0 && this.props.children.length > 0) {
|
|
261
|
+
this.mySwiper.loopDestroy();
|
|
262
|
+
this.mySwiper.loopCreate();
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
if (!this.mySwiper) return;
|
|
266
|
+
|
|
267
|
+
if (this.props.autoplay) {
|
|
268
|
+
if (this._$width !== this.mySwiper.width || this._$height !== this.mySwiper.height) {
|
|
269
|
+
this.mySwiper.autoplay.start();
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
|
|
273
|
+
this._$width = this.mySwiper.width;
|
|
274
|
+
this._$height = this.mySwiper.height;
|
|
275
|
+
}
|
|
276
|
+
}, {
|
|
277
|
+
key: "componentWillUnmount",
|
|
278
|
+
value: function componentWillUnmount() {
|
|
279
|
+
var _a, _b, _c, _d, _e, _f;
|
|
280
|
+
|
|
281
|
+
this.$el = null;
|
|
282
|
+
if (this.mySwiper) this.mySwiper.destroy();
|
|
283
|
+
(_b = (_a = this.observer) === null || _a === void 0 ? void 0 : _a.disconnect) === null || _b === void 0 ? void 0 : _b.call(_a);
|
|
284
|
+
(_d = (_c = this.observerFirst) === null || _c === void 0 ? void 0 : _c.disconnect) === null || _d === void 0 ? void 0 : _d.call(_c);
|
|
285
|
+
(_f = (_e = this.observerLast) === null || _e === void 0 ? void 0 : _e.disconnect) === null || _f === void 0 ? void 0 : _f.call(_e);
|
|
286
|
+
}
|
|
287
|
+
}, {
|
|
288
|
+
key: "handleOnChange",
|
|
289
|
+
value: function handleOnChange(e) {
|
|
290
|
+
var func = this.props.onChange;
|
|
291
|
+
typeof func === 'function' && func(e);
|
|
292
|
+
}
|
|
293
|
+
}, {
|
|
294
|
+
key: "handleOnAnimationFinish",
|
|
295
|
+
value: function handleOnAnimationFinish(e) {
|
|
296
|
+
var func = this.props.onAnimationFinish;
|
|
297
|
+
typeof func === 'function' && func(e);
|
|
298
|
+
}
|
|
299
|
+
}, {
|
|
300
|
+
key: "parsePX",
|
|
301
|
+
value: function parsePX() {
|
|
302
|
+
var s = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : '0px';
|
|
303
|
+
return parseFloat(s.replace(/r*px/i, ''));
|
|
304
|
+
}
|
|
305
|
+
}, {
|
|
306
|
+
key: "render",
|
|
307
|
+
value: function render() {
|
|
308
|
+
var _this3 = this;
|
|
309
|
+
|
|
310
|
+
var _this$props2 = this.props,
|
|
311
|
+
className = _this$props2.className,
|
|
312
|
+
style = _this$props2.style,
|
|
313
|
+
vertical = _this$props2.vertical,
|
|
314
|
+
previousMargin = _this$props2.previousMargin,
|
|
315
|
+
nextMargin = _this$props2.nextMargin,
|
|
316
|
+
indicatorColor = _this$props2.indicatorColor,
|
|
317
|
+
indicatorActiveColor = _this$props2.indicatorActiveColor;
|
|
318
|
+
var defaultIndicatorColor = indicatorColor || 'rgba(0, 0, 0, .3)';
|
|
319
|
+
var defaultIndicatorActiveColor = indicatorActiveColor || '#000';
|
|
320
|
+
var cls = classNames("taro-swiper-".concat(this._id), className);
|
|
321
|
+
var sty = Object.assign({
|
|
322
|
+
paddingTop: vertical ? this.parsePX(previousMargin) : 0,
|
|
323
|
+
paddingRight: vertical ? 0 : this.parsePX(nextMargin),
|
|
324
|
+
paddingBottom: vertical ? this.parsePX(nextMargin) : 0,
|
|
325
|
+
paddingLeft: vertical ? 0 : this.parsePX(previousMargin),
|
|
326
|
+
overflow: 'hidden'
|
|
327
|
+
}, style);
|
|
328
|
+
var paginationCls = classNames('swiper-pagination', {
|
|
329
|
+
'swiper-pagination-hidden': !this.props.indicatorDots,
|
|
330
|
+
'swiper-pagination-bullets': this.props.indicatorDots
|
|
331
|
+
});
|
|
332
|
+
return React.createElement("div", {
|
|
333
|
+
className: "swiper-container-wrapper ".concat(cls),
|
|
334
|
+
style: sty
|
|
335
|
+
}, React.createElement("div", {
|
|
336
|
+
className: 'swiper-container',
|
|
337
|
+
style: {
|
|
338
|
+
overflow: 'visible'
|
|
339
|
+
},
|
|
340
|
+
ref: function ref(el) {
|
|
341
|
+
_this3.$el = el;
|
|
342
|
+
}
|
|
343
|
+
}, React.createElement("div", {
|
|
344
|
+
dangerouslySetInnerHTML: {
|
|
345
|
+
__html: "<style type='text/css'>\n .taro-swiper-".concat(this._id, " > .swiper-container > .swiper-pagination > .swiper-pagination-bullet { background: ").concat(defaultIndicatorColor, " }\n .taro-swiper-").concat(this._id, " > .swiper-container > .swiper-pagination > .swiper-pagination-bullet-active { background: ").concat(defaultIndicatorActiveColor, " }\n </style>")
|
|
346
|
+
}
|
|
347
|
+
}), React.createElement("div", {
|
|
348
|
+
className: 'swiper-wrapper'
|
|
349
|
+
}, this.props.children), React.createElement("div", {
|
|
350
|
+
className: paginationCls
|
|
351
|
+
})));
|
|
352
|
+
}
|
|
353
|
+
}]);
|
|
354
|
+
|
|
355
|
+
return Swiper;
|
|
356
|
+
}(React.Component);
|
|
357
|
+
|
|
358
|
+
export { Swiper, SwiperItem };
|
|
359
|
+
//# sourceMappingURL=index.js.map
|