ソースを参照

scrollview is not scrollable when using overlay in android (#4554)

scrollview is not scrollable when using overlay in android
eladgel 6 年 前
コミット
db24ecd25d
共有1 個のファイルを変更した86 個の追加57 個の削除を含む
  1. 86
    57
      playground/src/screens/CustomTopBar.js

+ 86
- 57
playground/src/screens/CustomTopBar.js ファイルの表示

@@ -1,62 +1,91 @@
1 1
 const React = require('react');
2
-const { Component } = require('react');
3
-const {
4
-  StyleSheet,
5
-  View,
6
-  TouchableOpacity,
7
-  Text,
8
-  Alert,
9
-  Platform
10
-} = require('react-native');
2
+const { PureComponent } = require('react');
3
+
4
+const { Text, Button, ScrollView, View, Alert, Platform } = require('react-native');
11 5
 const { Navigation } = require('react-native-navigation');
12 6
 
13
-class CustomTopBar extends Component {
14
-
15
-  constructor(props) {
16
-    super(props);
17
-    this.state = {};
18
-    this.subscription = Navigation.events().bindComponent(this);
19
-  }
20
-
21
-  componentDidAppear() {
22
-    console.log('RNN', 'CTB.componentDidAppear');
23
-  }
24
-
25
-  componentDidDisappear() {
26
-    console.log('RNN', `CTB.componentDidDisappear`);
27
-  }
28
-
29
-  componentDidMount() {
30
-    console.log('RNN', `CTB.componentDidMount`);
31
-  }
32
-
33
-  componentWillUnmount() {
34
-    console.log('RNN', `CTB.componentWillUnmount`);
35
-    this.subscription.remove();
36
-  }
37
-
38
-  render() {
39
-    return (
40
-      <View style={styles.container}>
41
-        <TouchableOpacity onPress={() => Alert.alert(this.props.title, 'Thanks for that :)')}>
42
-          <Text style={styles.text}>Press Me</Text>
43
-        </TouchableOpacity>
44
-      </View>
45
-    );
46
-  }
7
+const testIDs = require('../testIDs');
8
+
9
+class CustomDialog extends PureComponent {
10
+    static get options() {
11
+        return {
12
+            statusBarBackgroundColor: 'green'
13
+        };
14
+    }
15
+
16
+    render() {
17
+        return (
18
+            <View style={styles.container}>
19
+                <ScrollView style={styles.root}>
20
+                    <View style={{height: 60, backgroundColor: 'red'}}/>
21
+                    <View style={{height: 60, backgroundColor: 'green'}}/>
22
+                    <View style={{height: 60, backgroundColor: 'red'}}/>
23
+                    <View style={{height: 60, backgroundColor: 'green'}}/>
24
+                    <View style={{height: 60, backgroundColor: 'red'}}/>
25
+                    <View style={{height: 60, backgroundColor: 'green'}}/>
26
+                </ScrollView>
27
+            </View>
28
+        );
29
+    }
30
+
31
+    didDisappear() {
32
+        if (Platform.OS === 'android') {
33
+            Alert.alert('Overlay disappeared');
34
+        }
35
+    }
36
+
37
+    onCLickOk() {
38
+        Navigation.dismissOverlay(this.props.componentId);
39
+    }
40
+
41
+    onCLickSetRoot() {
42
+        Navigation.setRoot({
43
+            root: {
44
+                component: {
45
+                    name: 'navigation.playground.TextScreen'
46
+                }
47
+            }
48
+        });
49
+    }
50
+
51
+    onCLickSetInterceptTouch() {
52
+        Navigation.mergeOptions(this.props.componentId, {
53
+            overlay: {
54
+                interceptTouchOutside: false
55
+            }
56
+        });
57
+    }
47 58
 }
48 59
 
49
-module.exports = CustomTopBar;
50
-
51
-const styles = StyleSheet.create({
52
-  container: {
53
-    flex: 1,
54
-    flexDirection: 'column',
55
-    justifyContent: 'center',
56
-    alignSelf: 'center'
57
-  },
58
-  text: {
59
-    alignSelf: 'center',
60
-    color: 'black',
61
-  }
62
-});
60
+const styles = {
61
+    root: {
62
+        width: 400,
63
+        height: 200,
64
+    },
65
+    container: {
66
+
67
+        width: 400,
68
+        height: 200,
69
+        flexDirection: 'column',
70
+        justifyContent: 'center',
71
+        alignItems: 'center',
72
+        alignSelf: 'center'
73
+    },
74
+    h1: {
75
+        fontSize: 24,
76
+        textAlign: 'center',
77
+        margin: 10
78
+    },
79
+    h2: {
80
+        fontSize: 12,
81
+        textAlign: 'center',
82
+        margin: 10
83
+    },
84
+    footer: {
85
+        fontSize: 10,
86
+        color: '#888',
87
+        marginTop: 10
88
+    }
89
+};
90
+
91
+module.exports = CustomDialog;