@conecli/cone-render 0.8.15-taroUpdate.3 → 0.8.15-taroUpdate.5

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.
@@ -0,0 +1,66 @@
1
+ .d-video-wrap{
2
+ position: relative;
3
+ overflow: hidden;
4
+
5
+ .d-video-play {
6
+ display: block;
7
+ overflow: hidden;
8
+ width: 100%;
9
+ height: 100%;
10
+ background-color: transparent;
11
+ -webkit-backface-visibility: hidden;
12
+ -webkit-transform: translate3d(0, 0, 0);
13
+ object-fit: fill;
14
+ }
15
+
16
+ .d-video-mute-btn{
17
+ position: absolute;
18
+ width: 51px;
19
+ height: 51px;
20
+ background-repeat: no-repeat;
21
+ background-position: 50% 50%;
22
+ background-size: 50%;
23
+ }
24
+ .d-mute-btn-topLeft{
25
+ left: 10px;
26
+ top: 10px;
27
+ }
28
+ .d-mute-btn-topRight{
29
+ right: 10px;
30
+ top: 10px;
31
+ }
32
+ .d-mute-btn-bottomLeft{
33
+ left: 10px;
34
+ bottom: 10px;
35
+ }
36
+ .d-mute-btn-bottomRight{
37
+ right: 10px;
38
+ bottom: 10px;
39
+ }
40
+ .d-is-muted{
41
+ background-image: url("");
42
+ }
43
+ .d-not-muted{
44
+ background-image: url("");
45
+ }
46
+
47
+ .d-video-play-btn{
48
+ position: absolute;
49
+ width: 120px;
50
+ height: 120px;
51
+ background-repeat: no-repeat;
52
+ background-position: 50% 50%;
53
+ background-size: 50%;
54
+ top: 50%;
55
+ left: 50%;
56
+ transform: translateX(-50%) translateY(-50%);
57
+ }
58
+
59
+ .d-is-pause{
60
+ background-image: url("");
61
+ }
62
+
63
+ .d-not-pause{
64
+ background-image: none;
65
+ }
66
+ }
@@ -0,0 +1 @@
1
+ import React, { useCallback, useEffect, useRef, useState } from 'react'
@@ -1 +1 @@
1
- import Taro from '@tarojs/taro'
2
1
  TaroEventType,
3
2
  const {
4
3
  children,
5
4
  inViewCallback,
6
5
  outViewCallback
7
6
  } = props
8
7
  const [componentShowState, setComponentShowState] = useState(false)
9
8
  const componentObserverRef = useRef<HTMLElement | null>(null)
10
9
  const componentShowStateRef = useRef(false)
11
10
  if (isH5AndJdShopView) {
12
11
  useEffect(() => {
13
12
  const latestRes = latestFromNativeMsgStorage[TaroEventType.PAGE_SCROLL] || {}
14
13
  dealPageScrollInfo(latestRes)
15
14
  Taro.eventCenter.on(TaroEventType.PAGE_SCROLL, (res) => {
16
15
  dealPageScrollInfo(res)
17
16
  })
18
17
  }, [])
19
18
  useEffect(() => {
20
19
  if (componentShowState) {
21
20
  typeof inViewCallback === 'function' && inViewCallback()
22
21
  console.log('app=>in可视区域')
23
22
  } else {
24
23
  typeof outViewCallback === 'function' && outViewCallback()
25
24
  console.log('app=>out可视区域')
26
25
  }
27
26
  }, [componentShowState])
28
27
 
29
28
  const handleInOrOutView = (type: boolean) => {
30
29
  componentShowStateRef.current = type
31
30
  setComponentShowState(type)
32
31
  }
33
32
 
34
33
  const dealPageScrollInfo = (res) => {
35
34
  const { displayHeight, offSetY } = res
36
35
  if (componentObserverRef.current) {
37
36
  const eleClientRect =
38
37
  componentObserverRef.current.getBoundingClientRect()
39
38
  const eleOffsetTop = Math.ceil(eleClientRect.top)
40
39
  const eleHeight = Math.ceil(eleClientRect.height)
41
40
  console.log('==========================eleOffsetTop, eleHeight', eleOffsetTop, eleHeight)
42
41
  if (eleOffsetTop >= 0 && eleOffsetTop < displayHeight) {
43
42
  const isOutView = offSetY > eleOffsetTop + eleHeight
44
43
  handleInOrOutView(isOutView ? false : true)
45
44
  } else {
46
45
  const isInView = (offSetY > eleOffsetTop - displayHeight) && (offSetY < eleOffsetTop + eleHeight)
47
46
  handleInOrOutView(isInView ? true : false)
48
47
  }
49
48
  }
50
49
  }
51
50
  return (
52
51
  <View ref={componentObserverRef}>
53
52
  {children}
54
53
  </View>
55
54
  )
56
55
  } else {
57
56
  const rootDom = document.querySelector('#J_shopHomeRoot')
58
57
  console.log('rootDom', rootDom)
59
58
  const { ref, inView } = useInView({
60
59
  threshold: 0,
61
60
  triggerOnce: false,
62
61
  root: rootDom || null,
63
62
  rootMargin: `0px 0px 0px 0px`,
64
63
  })
65
64
  useEffect(() => {
66
65
  if (inView) {
67
66
  typeof inViewCallback === 'function' && inViewCallback()
68
67
  console.log('其他h5=>in可视区域')
69
68
  } else {
70
69
  typeof outViewCallback === 'function' && outViewCallback()
71
70
  console.log('其他h5=>out可视区域')
72
71
  }
73
72
  }, [inView])
74
73
  return (
75
74
  <View ref={ref}>
76
75
  {children}
77
76
  </View>
78
77
  )
79
78
  }
80
79
  children: null,
81
80
  className: '',
82
81
  inViewCallback: null,
83
82
  outViewCallback: null
83
+ import Taro from '@tarojs/taro'
84
84
  TaroEventType,
85
85
  const {
86
86
  children,
87
87
  inViewCallback,
88
88
  outViewCallback,
89
89
  threshold
90
90
  } = props
91
91
  const [componentShowState, setComponentShowState] = useState(false)
92
92
  const componentObserverRef = useRef<HTMLElement | null>(null)
93
93
  const componentShowStateRef = useRef(false)
94
94
  if (isH5AndJdShopView) {
95
95
  useEffect(() => {
96
96
  const latestRes = latestFromNativeMsgStorage[TaroEventType.PAGE_SCROLL] || {}
97
97
  dealPageScrollInfo(latestRes)
98
98
  Taro.eventCenter.on(TaroEventType.PAGE_SCROLL, (res) => {
99
99
  dealPageScrollInfo(res)
100
100
  })
101
101
  Taro.eventCenter.on(TaroEventType.PAGE_DOCUMENT_VISIBILITY_CHANGE, (state) => {
102
102
  state === 0 && handleInOrOutView(false)
103
103
  })
104
104
  }, [])
105
105
  useEffect(() => {
106
106
  if (componentShowState) {
107
107
  typeof inViewCallback === 'function' && inViewCallback()
108
108
  console.log('app=>in可视区域')
109
109
  } else {
110
110
  typeof outViewCallback === 'function' && outViewCallback()
111
111
  console.log('app=>out可视区域')
112
112
  }
113
113
  }, [componentShowState])
114
114
 
115
115
  const handleInOrOutView = (type: boolean) => {
116
116
  componentShowStateRef.current = type
117
117
  setComponentShowState(type)
118
118
  }
119
119
 
120
120
  const dealPageScrollInfo = (res) => {
121
121
  const { displayHeight, offSetY } = res
122
122
  if (componentObserverRef.current) {
123
123
  const eleClientRect =
124
124
  componentObserverRef.current.getBoundingClientRect()
125
125
  const eleOffsetTop = Math.ceil(eleClientRect.top)
126
126
  const eleHeight = Math.ceil(eleClientRect.height)
127
127
  console.log('==========================eleOffsetTop, eleHeight', eleOffsetTop, eleHeight)
128
128
  if (eleOffsetTop >= 0 && eleOffsetTop < displayHeight) {
129
129
  const isOutView = offSetY > eleOffsetTop + Math.ceil(eleHeight * (1 - threshold))
130
130
  handleInOrOutView(isOutView ? false : true)
131
131
  } else {
132
132
  const isInView = (offSetY > eleOffsetTop - displayHeight + Math.ceil(eleHeight * threshold)) && (offSetY < eleOffsetTop + Math.ceil(eleHeight * (1 - threshold)))
133
133
  handleInOrOutView(isInView ? true : false)
134
134
  }
135
135
  }
136
136
  }
137
137
  return (
138
138
  <View ref={componentObserverRef}>
139
139
  {children}
140
140
  </View>
141
141
  )
142
142
  } else {
143
143
  const rootDom = document.querySelector('#J_shopHomeRoot')
144
144
  const { ref, inView } = useInView({
145
145
  threshold,
146
146
  triggerOnce: false,
147
147
  root: rootDom || null,
148
148
  rootMargin: `0px 0px 0px 0px`,
149
149
  })
150
150
  useEffect(() => {
151
151
  if (inView) {
152
152
  typeof inViewCallback === 'function' && inViewCallback()
153
153
  console.log('其他h5=>in可视区域')
154
154
  } else {
155
155
  typeof outViewCallback === 'function' && outViewCallback()
156
156
  console.log('其他h5=>out可视区域')
157
157
  }
158
158
  }, [inView])
159
159
  return (
160
160
  <View ref={ref}>
161
161
  {children}
162
162
  </View>
163
163
  )
164
164
  }
165
165
  children: null,
166
166
  className: '',
167
167
  inViewCallback: null,
168
168
  outViewCallback: null,
169
169
  threshold: 0
@@ -1 +1 @@
1
- import React from 'react'
1
+ import React from 'react'
@@ -1 +1 @@
1
- import CountDown from '../../components/base/CountDown'
1
+ import CountDown from "../../components/base/CountDown";
@@ -1 +1 @@
1
- import Taro from '@tarojs/taro'
2
1
  latestFromNativeMsgStorage[TaroEventType.PAGE_SCROLL] = {
3
2
  displayHeight: 1920,
4
3
  offSetY: 0
5
4
  }
6
5
  console.log('>>>>>>>>>>>>>>>>>>> render taroEventSendPageScrollInfo origin time:', Date.now(), 'res:', options)
7
6
  if(options){
8
7
  latestFromNativeMsgStorage[TaroEventType.PAGE_SCROLL] = options
9
8
  }
10
9
  const latestRes = latestFromNativeMsgStorage[TaroEventType.PAGE_SCROLL] || {}
10
+ import Taro from '@tarojs/taro'
11
11
  latestFromNativeMsgStorage[TaroEventType.PAGE_SCROLL] = {
12
12
  displayHeight: 1920,
13
13
  offSetY: 0
14
14
  }
15
15
  console.log('>>>>>>>>>>>>>>>>>>> render taroEventSendPageScrollInfo origin time:', Date.now(), 'res:', options)
16
16
  if(options){
17
17
  latestFromNativeMsgStorage[TaroEventType.PAGE_SCROLL] = options
18
18
  }
19
19
  const latestRes = latestFromNativeMsgStorage[TaroEventType.PAGE_SCROLL] || {}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@conecli/cone-render",
3
- "version": "0.8.15-taroUpdate.3",
3
+ "version": "0.8.15-taroUpdate.5",
4
4
  "private": false,
5
5
  "files": [
6
6
  "dist/"