mirror of
https://github.com/streetwriters/notesnook.git
synced 2025-12-29 00:20:04 +01:00
feat: import note loading in editor
This commit is contained in:
@@ -1,21 +1,25 @@
|
||||
import React, { useEffect, useRef, useState } from 'react';
|
||||
import { View } from 'react-native';
|
||||
import Animated, { useAnimatedStyle, useSharedValue } from 'react-native-reanimated';
|
||||
import Animated, { useAnimatedStyle, useSharedValue, withTiming } from 'react-native-reanimated';
|
||||
import { Button } from '../../components/ui/button';
|
||||
import { IconButton } from '../../components/ui/icon-button';
|
||||
import Heading from '../../components/ui/typography/heading';
|
||||
import Paragraph from '../../components/ui/typography/paragraph';
|
||||
import { eSendEvent, eSubscribeEvent, eUnSubscribeEvent } from '../../services/event-manager';
|
||||
import { useThemeStore } from '../../stores/use-theme-store';
|
||||
import { eOnLoadNote } from '../../utils/events';
|
||||
import { eClearEditor, eOnLoadNote } from '../../utils/events';
|
||||
import { SIZE } from '../../utils/size';
|
||||
import { timeConverter } from '../../utils/time';
|
||||
import { editorState } from './tiptap/utils';
|
||||
import { useSafeAreaInsets } from 'react-native-safe-area-context';
|
||||
|
||||
const EditorOverlay = ({ editorId = '', editor }) => {
|
||||
const colors = useThemeStore(state => state.colors);
|
||||
const [loading, setLoading] = useState(null);
|
||||
const [error, setError] = useState(false);
|
||||
const opacity = useSharedValue(1);
|
||||
const translateValue = useSharedValue(6000);
|
||||
const insets = useSafeAreaInsets();
|
||||
const isDefaultEditor = editorId === '';
|
||||
const timers = useRef({
|
||||
loading: 0,
|
||||
@@ -35,6 +39,7 @@ const EditorOverlay = ({ editorId = '', editor }) => {
|
||||
if (_loading) {
|
||||
opacity.value = 1;
|
||||
setLoading(_loading);
|
||||
translateValue.value = 0;
|
||||
timers.current.error = setTimeout(() => {
|
||||
if (_loading) {
|
||||
let note = _loading;
|
||||
@@ -45,18 +50,20 @@ const EditorOverlay = ({ editorId = '', editor }) => {
|
||||
}, 4000);
|
||||
} else {
|
||||
clearTimers();
|
||||
setError(false);
|
||||
editorState().overlay = false;
|
||||
setLoading(null);
|
||||
setTimeout(() => {
|
||||
setError(false);
|
||||
editorState().overlay = false;
|
||||
setLoading(null);
|
||||
opacity.value = withTiming(0, {
|
||||
duration: 500
|
||||
});
|
||||
setTimeout(() => {
|
||||
translateValue.value = 6000;
|
||||
}, 500);
|
||||
}, 100);
|
||||
}
|
||||
};
|
||||
|
||||
useEffect(() => {
|
||||
if (!loading) {
|
||||
opacity.value = 1;
|
||||
}
|
||||
}, [loading]);
|
||||
|
||||
useEffect(() => {
|
||||
eSubscribeEvent('loadingNote' + editorId, load);
|
||||
return () => {
|
||||
@@ -67,7 +74,12 @@ const EditorOverlay = ({ editorId = '', editor }) => {
|
||||
|
||||
const animatedStyle = useAnimatedStyle(() => {
|
||||
return {
|
||||
opacity: opacity.value
|
||||
opacity: opacity.value,
|
||||
transform: [
|
||||
{
|
||||
translateY: translateValue.value
|
||||
}
|
||||
]
|
||||
};
|
||||
});
|
||||
|
||||
@@ -81,104 +93,195 @@ const EditorOverlay = ({ editorId = '', editor }) => {
|
||||
backgroundColor: colors.bg,
|
||||
justifyContent: 'center',
|
||||
alignItems: 'center',
|
||||
transform: [
|
||||
{
|
||||
translateY: loading ? 0 : 6000
|
||||
}
|
||||
],
|
||||
zIndex: 100
|
||||
},
|
||||
animatedStyle
|
||||
]}
|
||||
>
|
||||
<Animated.View
|
||||
<View
|
||||
style={{
|
||||
width: '90%',
|
||||
justifyContent: 'center',
|
||||
alignItems: 'center',
|
||||
width: '100%',
|
||||
backgroundColor: colors.bg,
|
||||
borderRadius: 5,
|
||||
paddingVertical: 20
|
||||
height: '100%',
|
||||
alignItems: 'flex-start',
|
||||
paddingTop: insets.top
|
||||
}}
|
||||
>
|
||||
{isDefaultEditor ? (
|
||||
<View
|
||||
style={{
|
||||
flexDirection: 'row',
|
||||
height: 50,
|
||||
alignItems: 'center',
|
||||
justifyContent: 'space-between',
|
||||
width: '100%',
|
||||
paddingLeft: 6,
|
||||
paddingRight: 12
|
||||
}}
|
||||
>
|
||||
<IconButton
|
||||
onPress={() => {
|
||||
eSendEvent(eClearEditor);
|
||||
opacity.value = 0;
|
||||
translateValue.value = 6000;
|
||||
}}
|
||||
name="arrow-left"
|
||||
color={colors.pri}
|
||||
/>
|
||||
|
||||
<View
|
||||
style={{
|
||||
flexDirection: 'row',
|
||||
height: 10,
|
||||
width: 100,
|
||||
marginBottom: 15,
|
||||
borderRadius: 5,
|
||||
overflow: 'hidden',
|
||||
backgroundColor: colors.nav
|
||||
height: 50,
|
||||
alignItems: 'center'
|
||||
}}
|
||||
>
|
||||
<Animated.View
|
||||
<IconButton name="dots-horizontal" color={colors.pri} />
|
||||
</View>
|
||||
</View>
|
||||
|
||||
<View
|
||||
style={{
|
||||
paddingHorizontal: 12,
|
||||
width: '100%',
|
||||
alignItems: 'flex-start'
|
||||
}}
|
||||
>
|
||||
<View
|
||||
style={{
|
||||
height: 30,
|
||||
backgroundColor: colors.nav,
|
||||
borderRadius: 100,
|
||||
marginBottom: 10,
|
||||
justifyContent: 'flex-start',
|
||||
alignItems: 'center',
|
||||
flexDirection: 'row',
|
||||
paddingHorizontal: 10,
|
||||
marginTop: 10
|
||||
}}
|
||||
>
|
||||
<Paragraph color={colors.icon} size={13}>
|
||||
Add a tag
|
||||
</Paragraph>
|
||||
<IconButton
|
||||
size={20}
|
||||
customStyle={{
|
||||
width: 26,
|
||||
height: 26
|
||||
}}
|
||||
name="plus"
|
||||
color={colors.accent}
|
||||
/>
|
||||
</View>
|
||||
|
||||
<View
|
||||
style={{
|
||||
height: 25,
|
||||
width: '100%',
|
||||
backgroundColor: colors.nav,
|
||||
borderRadius: 5
|
||||
}}
|
||||
/>
|
||||
|
||||
<View
|
||||
style={{
|
||||
height: 12,
|
||||
width: '100%',
|
||||
marginTop: 10,
|
||||
flexDirection: 'row'
|
||||
}}
|
||||
>
|
||||
<View
|
||||
style={{
|
||||
height: 10,
|
||||
height: 12,
|
||||
width: 60,
|
||||
backgroundColor: colors.nav,
|
||||
borderRadius: 5,
|
||||
width: 100,
|
||||
backgroundColor: colors.accent
|
||||
marginRight: 10
|
||||
}}
|
||||
/>
|
||||
<View
|
||||
style={{
|
||||
height: 12,
|
||||
width: 60,
|
||||
backgroundColor: colors.nav,
|
||||
borderRadius: 5,
|
||||
marginRight: 10
|
||||
}}
|
||||
/>
|
||||
<View
|
||||
style={{
|
||||
height: 12,
|
||||
width: 60,
|
||||
backgroundColor: colors.nav,
|
||||
borderRadius: 5,
|
||||
marginRight: 10
|
||||
}}
|
||||
/>
|
||||
</View>
|
||||
) : null}
|
||||
|
||||
{loading?.title ? (
|
||||
<Heading
|
||||
textBreakStrategy="balanced"
|
||||
style={{ textAlign: 'center', marginBottom: 5 }}
|
||||
size={SIZE.lg}
|
||||
>
|
||||
{loading.title}
|
||||
</Heading>
|
||||
) : null}
|
||||
|
||||
{loading?.dateEdited && isDefaultEditor ? (
|
||||
<Paragraph
|
||||
textBreakStrategy="balanced"
|
||||
style={{ textAlign: 'center' }}
|
||||
color={colors.icon}
|
||||
size={SIZE.sm}
|
||||
>
|
||||
{timeConverter(loading.dateEdited)}
|
||||
</Paragraph>
|
||||
) : null}
|
||||
</Animated.View>
|
||||
|
||||
{error && (
|
||||
<View
|
||||
style={{
|
||||
position: 'absolute',
|
||||
bottom: 25
|
||||
}}
|
||||
>
|
||||
<Button
|
||||
type="errorShade"
|
||||
<View
|
||||
style={{
|
||||
height: 16,
|
||||
width: '100%',
|
||||
backgroundColor: colors.nav,
|
||||
borderRadius: 5,
|
||||
marginTop: 10
|
||||
}}
|
||||
onPress={() => {
|
||||
setError(false);
|
||||
editor.setLoading(true);
|
||||
setTimeout(() => editor.setLoading(false), 10);
|
||||
}}
|
||||
title="Taking too long? Reload editor"
|
||||
/>
|
||||
<Paragraph
|
||||
textBreakStrategy="balanced"
|
||||
size={SIZE.xs}
|
||||
color={colors.icon}
|
||||
|
||||
<View
|
||||
style={{
|
||||
textAlign: 'center',
|
||||
maxWidth: '100%',
|
||||
marginTop: 5
|
||||
height: 16,
|
||||
width: '100%',
|
||||
backgroundColor: colors.nav,
|
||||
borderRadius: 5,
|
||||
marginTop: 10
|
||||
}}
|
||||
>
|
||||
If the editor fails to load even after reloading. Try restarting the app.
|
||||
</Paragraph>
|
||||
/>
|
||||
|
||||
<View
|
||||
style={{
|
||||
height: 16,
|
||||
width: 200,
|
||||
backgroundColor: colors.nav,
|
||||
borderRadius: 5,
|
||||
marginTop: 10
|
||||
}}
|
||||
/>
|
||||
|
||||
{error ? (
|
||||
<>
|
||||
<Button
|
||||
type="error"
|
||||
style={{
|
||||
marginTop: 20,
|
||||
alignSelf: 'flex-start',
|
||||
borderRadius: 100,
|
||||
height: 40
|
||||
}}
|
||||
onPress={() => {
|
||||
setError(false);
|
||||
editor.setLoading(true);
|
||||
setTimeout(() => editor.setLoading(false), 10);
|
||||
}}
|
||||
title="Taking too long? Reload editor"
|
||||
/>
|
||||
<Paragraph
|
||||
textBreakStrategy="balanced"
|
||||
size={SIZE.xs}
|
||||
color={colors.icon}
|
||||
style={{
|
||||
maxWidth: '100%',
|
||||
marginTop: 5
|
||||
}}
|
||||
>
|
||||
If the editor fails to load even after reloading. Try restarting the app.
|
||||
</Paragraph>
|
||||
</>
|
||||
) : null}
|
||||
</View>
|
||||
)}
|
||||
</View>
|
||||
</Animated.View>
|
||||
);
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user