mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-17 18:44:45 +02:00
This commit is contained in:
parent
e278a26dc8
commit
e21a5c1b80
1
.gitignore
vendored
1
.gitignore
vendored
@ -352,6 +352,7 @@ packages/app-mobile/components/CustomButton.js
|
|||||||
packages/app-mobile/components/Dropdown.js
|
packages/app-mobile/components/Dropdown.js
|
||||||
packages/app-mobile/components/ExtendedWebView.js
|
packages/app-mobile/components/ExtendedWebView.js
|
||||||
packages/app-mobile/components/FolderPicker.js
|
packages/app-mobile/components/FolderPicker.js
|
||||||
|
packages/app-mobile/components/Modal.js
|
||||||
packages/app-mobile/components/NoteBodyViewer/NoteBodyViewer.js
|
packages/app-mobile/components/NoteBodyViewer/NoteBodyViewer.js
|
||||||
packages/app-mobile/components/NoteBodyViewer/hooks/useOnMessage.js
|
packages/app-mobile/components/NoteBodyViewer/hooks/useOnMessage.js
|
||||||
packages/app-mobile/components/NoteBodyViewer/hooks/useOnResourceLongPress.js
|
packages/app-mobile/components/NoteBodyViewer/hooks/useOnResourceLongPress.js
|
||||||
|
32
packages/app-mobile/components/Modal.tsx
Normal file
32
packages/app-mobile/components/Modal.tsx
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
import * as React from 'react';
|
||||||
|
import { Modal, ModalProps, StyleSheet, View, ViewStyle } from 'react-native';
|
||||||
|
import { hasNotch } from 'react-native-device-info';
|
||||||
|
|
||||||
|
interface ModalElementProps extends ModalProps {
|
||||||
|
children: React.ReactNode;
|
||||||
|
containerStyle?: ViewStyle;
|
||||||
|
elevation?: Number;
|
||||||
|
}
|
||||||
|
|
||||||
|
const ModalElement: React.FC<ModalElementProps> = ({
|
||||||
|
children,
|
||||||
|
containerStyle,
|
||||||
|
...modalProps
|
||||||
|
}) => {
|
||||||
|
return (
|
||||||
|
<Modal {...modalProps}>
|
||||||
|
<View style={[styleSheet.modalContainer, containerStyle ? containerStyle : null]}>
|
||||||
|
{children}
|
||||||
|
</View>
|
||||||
|
</Modal>
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
const styleSheet = StyleSheet.create({
|
||||||
|
modalContainer: {
|
||||||
|
marginTop: hasNotch() ? 65 : 15,
|
||||||
|
marginBottom: hasNotch() ? 35 : 15,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
export default ModalElement;
|
@ -1,8 +1,10 @@
|
|||||||
const React = require('react');
|
const React = require('react');
|
||||||
const { Text, Modal, View, StyleSheet, Button } = require('react-native');
|
const { Text, View, StyleSheet, Button } = require('react-native');
|
||||||
const { themeStyle } = require('./global-style.js');
|
const { themeStyle } = require('./global-style.js');
|
||||||
const { _ } = require('@joplin/lib/locale');
|
const { _ } = require('@joplin/lib/locale');
|
||||||
|
|
||||||
|
import Modal from './Modal';
|
||||||
|
|
||||||
class ModalDialog extends React.Component {
|
class ModalDialog extends React.Component {
|
||||||
constructor() {
|
constructor() {
|
||||||
super();
|
super();
|
||||||
@ -30,6 +32,7 @@ class ModalDialog extends React.Component {
|
|||||||
margin: 20,
|
margin: 20,
|
||||||
padding: 10,
|
padding: 10,
|
||||||
borderRadius: 5,
|
borderRadius: 5,
|
||||||
|
elevation: 10,
|
||||||
},
|
},
|
||||||
modalContentWrapper2: {
|
modalContentWrapper2: {
|
||||||
flex: 1,
|
flex: 1,
|
||||||
@ -56,8 +59,7 @@ class ModalDialog extends React.Component {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<View style={this.styles().modalWrapper}>
|
<View style={this.styles().modalWrapper}>
|
||||||
<Modal transparent={true} visible={true} onRequestClose={() => {}}>
|
<Modal transparent={true} visible={true} onRequestClose={() => {}} containerStyle={this.styles().modalContentWrapper}>
|
||||||
<View elevation={10} style={this.styles().modalContentWrapper}>
|
|
||||||
<Text style={this.styles().title}>{this.props.title}</Text>
|
<Text style={this.styles().title}>{this.props.title}</Text>
|
||||||
<View style={this.styles().modalContentWrapper2}>{ContentComponent}</View>
|
<View style={this.styles().modalContentWrapper2}>{ContentComponent}</View>
|
||||||
<View style={this.styles().buttonRow}>
|
<View style={this.styles().buttonRow}>
|
||||||
@ -68,7 +70,6 @@ class ModalDialog extends React.Component {
|
|||||||
<Button disabled={!buttonBarEnabled} title={_('Cancel')} onPress={this.props.onCancelPress}></Button>
|
<Button disabled={!buttonBarEnabled} title={_('Cancel')} onPress={this.props.onCancelPress}></Button>
|
||||||
</View>
|
</View>
|
||||||
</View>
|
</View>
|
||||||
</View>
|
|
||||||
</Modal>
|
</Modal>
|
||||||
</View>
|
</View>
|
||||||
);
|
);
|
||||||
|
@ -3,8 +3,9 @@
|
|||||||
const React = require('react');
|
const React = require('react');
|
||||||
const { useState, useEffect, useMemo, useRef } = require('react');
|
const { useState, useEffect, useMemo, useRef } = require('react');
|
||||||
const { StyleSheet } = require('react-native');
|
const { StyleSheet } = require('react-native');
|
||||||
const { View, Modal, Text, TextInput, Button } = require('react-native');
|
const { View, Text, TextInput, Button } = require('react-native');
|
||||||
|
|
||||||
|
import Modal from '../Modal';
|
||||||
import { themeStyle } from '@joplin/lib/theme';
|
import { themeStyle } from '@joplin/lib/theme';
|
||||||
import { _ } from '@joplin/lib/locale';
|
import { _ } from '@joplin/lib/locale';
|
||||||
import { EditorControl } from './types';
|
import { EditorControl } from './types';
|
||||||
@ -43,7 +44,6 @@ const EditLinkDialog = (props: LinkDialogProps) => {
|
|||||||
margin: 15,
|
margin: 15,
|
||||||
padding: 30,
|
padding: 30,
|
||||||
backgroundColor: theme.backgroundColor,
|
backgroundColor: theme.backgroundColor,
|
||||||
|
|
||||||
elevation: 5,
|
elevation: 5,
|
||||||
shadowOffset: {
|
shadowOffset: {
|
||||||
width: 1,
|
width: 1,
|
||||||
@ -132,12 +132,12 @@ const EditLinkDialog = (props: LinkDialogProps) => {
|
|||||||
return (
|
return (
|
||||||
<Modal
|
<Modal
|
||||||
animationType="slide"
|
animationType="slide"
|
||||||
|
containerStyle={styles.modalContent}
|
||||||
transparent={true}
|
transparent={true}
|
||||||
visible={props.visible}
|
visible={props.visible}
|
||||||
onRequestClose={() => {
|
onRequestClose={() => {
|
||||||
props.editorControl.hideLinkDialog();
|
props.editorControl.hideLinkDialog();
|
||||||
}}>
|
}}>
|
||||||
<View style={styles.modalContent}>
|
|
||||||
<Text style={styles.header}>{_('Edit link')}</Text>
|
<Text style={styles.header}>{_('Edit link')}</Text>
|
||||||
<View>
|
<View>
|
||||||
{linkTextInput}
|
{linkTextInput}
|
||||||
@ -148,7 +148,6 @@ const EditLinkDialog = (props: LinkDialogProps) => {
|
|||||||
onPress={onSubmit}
|
onPress={onSubmit}
|
||||||
title={_('Done')}
|
title={_('Done')}
|
||||||
/>
|
/>
|
||||||
</View>
|
|
||||||
</Modal>
|
</Modal>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
@ -467,6 +467,8 @@ PODS:
|
|||||||
- React-Core
|
- React-Core
|
||||||
- RNDateTimePicker (7.1.0):
|
- RNDateTimePicker (7.1.0):
|
||||||
- React-Core
|
- React-Core
|
||||||
|
- RNDeviceInfo (10.6.0):
|
||||||
|
- React-Core
|
||||||
- RNExitApp (1.1.0):
|
- RNExitApp (1.1.0):
|
||||||
- React
|
- React
|
||||||
- RNFileViewer (2.1.5):
|
- RNFileViewer (2.1.5):
|
||||||
@ -577,6 +579,7 @@ DEPENDENCIES:
|
|||||||
- "RNCClipboard (from `../node_modules/@react-native-community/clipboard`)"
|
- "RNCClipboard (from `../node_modules/@react-native-community/clipboard`)"
|
||||||
- "RNCPushNotificationIOS (from `../node_modules/@react-native-community/push-notification-ios`)"
|
- "RNCPushNotificationIOS (from `../node_modules/@react-native-community/push-notification-ios`)"
|
||||||
- "RNDateTimePicker (from `../node_modules/@react-native-community/datetimepicker`)"
|
- "RNDateTimePicker (from `../node_modules/@react-native-community/datetimepicker`)"
|
||||||
|
- RNDeviceInfo (from `../node_modules/react-native-device-info`)
|
||||||
- RNExitApp (from `../node_modules/react-native-exit-app`)
|
- RNExitApp (from `../node_modules/react-native-exit-app`)
|
||||||
- RNFileViewer (from `../node_modules/react-native-file-viewer`)
|
- RNFileViewer (from `../node_modules/react-native-file-viewer`)
|
||||||
- RNFS (from `../node_modules/react-native-fs`)
|
- RNFS (from `../node_modules/react-native-fs`)
|
||||||
@ -718,6 +721,8 @@ EXTERNAL SOURCES:
|
|||||||
:path: "../node_modules/@react-native-community/push-notification-ios"
|
:path: "../node_modules/@react-native-community/push-notification-ios"
|
||||||
RNDateTimePicker:
|
RNDateTimePicker:
|
||||||
:path: "../node_modules/@react-native-community/datetimepicker"
|
:path: "../node_modules/@react-native-community/datetimepicker"
|
||||||
|
RNDeviceInfo:
|
||||||
|
:path: "../node_modules/react-native-device-info"
|
||||||
RNExitApp:
|
RNExitApp:
|
||||||
:path: "../node_modules/react-native-exit-app"
|
:path: "../node_modules/react-native-exit-app"
|
||||||
RNFileViewer:
|
RNFileViewer:
|
||||||
@ -808,6 +813,7 @@ SPEC CHECKSUMS:
|
|||||||
RNCClipboard: 41d8d918092ae8e676f18adada19104fa3e68495
|
RNCClipboard: 41d8d918092ae8e676f18adada19104fa3e68495
|
||||||
RNCPushNotificationIOS: 64218f3c776c03d7408284a819b2abfda1834bc8
|
RNCPushNotificationIOS: 64218f3c776c03d7408284a819b2abfda1834bc8
|
||||||
RNDateTimePicker: 7ecd54a97fc3749f38c3c89a171f6cbd52f3c142
|
RNDateTimePicker: 7ecd54a97fc3749f38c3c89a171f6cbd52f3c142
|
||||||
|
RNDeviceInfo: 475a4c447168d0ad4c807e48ef5e0963a0f4eb1b
|
||||||
RNExitApp: c4e052df2568b43bec8a37c7cd61194d4cfee2c3
|
RNExitApp: c4e052df2568b43bec8a37c7cd61194d4cfee2c3
|
||||||
RNFileViewer: ce7ca3ac370e18554d35d6355cffd7c30437c592
|
RNFileViewer: ce7ca3ac370e18554d35d6355cffd7c30437c592
|
||||||
RNFS: 4ac0f0ea233904cb798630b3c077808c06931688
|
RNFS: 4ac0f0ea233904cb798630b3c077808c06931688
|
||||||
@ -824,4 +830,4 @@ SPEC CHECKSUMS:
|
|||||||
|
|
||||||
PODFILE CHECKSUM: 3b2cace838120977b5b54871752c9dddf5a11cea
|
PODFILE CHECKSUM: 3b2cace838120977b5b54871752c9dddf5a11cea
|
||||||
|
|
||||||
COCOAPODS: 1.11.3
|
COCOAPODS: 1.12.0
|
||||||
|
@ -43,6 +43,7 @@
|
|||||||
"react-native": "0.71.10",
|
"react-native": "0.71.10",
|
||||||
"react-native-action-button": "2.8.5",
|
"react-native-action-button": "2.8.5",
|
||||||
"react-native-camera": "4.2.1",
|
"react-native-camera": "4.2.1",
|
||||||
|
"react-native-device-info": "10.6.0",
|
||||||
"react-native-dialogbox": "0.6.10",
|
"react-native-dialogbox": "0.6.10",
|
||||||
"react-native-document-picker": "8.2.1",
|
"react-native-document-picker": "8.2.1",
|
||||||
"react-native-dropdownalert": "4.5.1",
|
"react-native-dropdownalert": "4.5.1",
|
||||||
|
10
yarn.lock
10
yarn.lock
@ -4402,6 +4402,7 @@ __metadata:
|
|||||||
react-native: 0.71.10
|
react-native: 0.71.10
|
||||||
react-native-action-button: 2.8.5
|
react-native-action-button: 2.8.5
|
||||||
react-native-camera: 4.2.1
|
react-native-camera: 4.2.1
|
||||||
|
react-native-device-info: 10.6.0
|
||||||
react-native-dialogbox: 0.6.10
|
react-native-dialogbox: 0.6.10
|
||||||
react-native-document-picker: 8.2.1
|
react-native-document-picker: 8.2.1
|
||||||
react-native-dropdownalert: 4.5.1
|
react-native-dropdownalert: 4.5.1
|
||||||
@ -27906,6 +27907,15 @@ __metadata:
|
|||||||
languageName: node
|
languageName: node
|
||||||
linkType: hard
|
linkType: hard
|
||||||
|
|
||||||
|
"react-native-device-info@npm:10.6.0":
|
||||||
|
version: 10.6.0
|
||||||
|
resolution: "react-native-device-info@npm:10.6.0"
|
||||||
|
peerDependencies:
|
||||||
|
react-native: "*"
|
||||||
|
checksum: 7a7cc438844552aef687b4a5b8efd0cd0a2959e0a3b771febfbe0b6a9ca8ff05a563e2912b30b83523bd3d5143d6616ca8fac0476abf01936a726e1578211ebb
|
||||||
|
languageName: node
|
||||||
|
linkType: hard
|
||||||
|
|
||||||
"react-native-dialogbox@npm:0.6.10":
|
"react-native-dialogbox@npm:0.6.10":
|
||||||
version: 0.6.10
|
version: 0.6.10
|
||||||
resolution: "react-native-dialogbox@npm:0.6.10"
|
resolution: "react-native-dialogbox@npm:0.6.10"
|
||||||
|
Loading…
Reference in New Issue
Block a user