diff --git a/apps/mobile/initializer.root.js b/apps/mobile/initializer.root.js index 1be07c9d0..266442dcd 100644 --- a/apps/mobile/initializer.root.js +++ b/apps/mobile/initializer.root.js @@ -1,38 +1,39 @@ import { activateKeepAwake, - deactivateKeepAwake, + deactivateKeepAwake } from '@sayem314/react-native-keep-awake'; -import React, {useCallback, useEffect, useState} from 'react'; -import {Dimensions, View} from 'react-native'; +import React, { useCallback, useEffect, useState } from 'react'; +import { Dimensions, View } from 'react-native'; import ScrollableTabView from 'react-native-scrollable-tab-view'; -import {notesnook} from './e2e/test.ids'; +import { notesnook } from './e2e/test.ids'; import ContextMenu from './src/components/ContextMenu'; -import {DialogManager} from './src/components/DialogManager'; -import {DummyText} from './src/components/DummyText'; -import {Menu} from './src/components/Menu'; -import {Toast} from './src/components/Toast'; -import {NavigationStack} from './src/navigation/Drawer'; -import {NavigatorStack} from './src/navigation/NavigatorStack'; -import {useTracked} from './src/provider'; -import {Actions} from './src/provider/Actions'; -import {DDS} from './src/services/DeviceDetection'; +import { DialogManager } from './src/components/DialogManager'; +import { DummyText } from './src/components/DummyText'; +import { Menu } from './src/components/Menu'; +import Splash from './src/components/SplashScreen'; +import { Toast } from './src/components/Toast'; +import { NavigationStack } from './src/navigation/Drawer'; +import { NavigatorStack } from './src/navigation/NavigatorStack'; +import { useTracked } from './src/provider'; +import { Actions } from './src/provider/Actions'; +import { DDS } from './src/services/DeviceDetection'; import { eSendEvent, eSubscribeEvent, - eUnSubscribeEvent, + eUnSubscribeEvent } from './src/services/EventManager'; -import {editing, setWidthHeight} from './src/utils'; +import { editing, setWidthHeight } from './src/utils'; import { eClearEditor, eCloseFullscreenEditor, eCloseSideMenu, eOnLoadNote, eOpenFullscreenEditor, - eOpenSideMenu, + eOpenSideMenu } from './src/utils/Events'; -import {editorRef, tabBarRef} from './src/utils/Refs'; -import {EditorWrapper} from './src/views/Editor/EditorWrapper'; -import {EditorWebView, getNote, post} from './src/views/Editor/Functions'; +import { editorRef, tabBarRef } from './src/utils/Refs'; +import { EditorWrapper } from './src/views/Editor/EditorWrapper'; +import { EditorWebView, getNote } from './src/views/Editor/Functions'; import tiny from './src/views/Editor/tiny/tiny'; let {width, height} = Dimensions.get('window'); let layoutTimer = null; @@ -74,6 +75,7 @@ export const RootView = React.memo( + ); }, diff --git a/apps/mobile/src/assets/images/assets.js b/apps/mobile/src/assets/images/assets.js index b786e7258..05172f2db 100644 --- a/apps/mobile/src/assets/images/assets.js +++ b/apps/mobile/src/assets/images/assets.js @@ -15,4 +15,623 @@ export const SETTINGS_SVG = (color) => `` -export const LOGO_BASE64 = `` \ No newline at end of file +export const LOGO_BASE64 = `` + +export const RICH_TEXT_SVG = (color) => ` + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +` + +export const SYNC_SVG = (color) => ` + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +` + +export const ORGANIZE_SVG = (color) => ` + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +` + +export const EXPORT_SVG = (color) => ` + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +` + +export const BACKUP_SVG = (color) => ` + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +` + +export const LOGO_SVG = ` + + + + + + + + + + + + + + + + + + + + image/svg+xml + + + + + + + + + + + + + + N + + + + + +` \ No newline at end of file diff --git a/apps/mobile/src/assets/images/notesnook-logo-png.png b/apps/mobile/src/assets/images/notesnook-logo-png.png new file mode 100644 index 000000000..57eeb66ee Binary files /dev/null and b/apps/mobile/src/assets/images/notesnook-logo-png.png differ diff --git a/apps/mobile/src/components/SplashScreen/index.js b/apps/mobile/src/components/SplashScreen/index.js new file mode 100644 index 000000000..910aefa8b --- /dev/null +++ b/apps/mobile/src/components/SplashScreen/index.js @@ -0,0 +1,231 @@ +import React, {useEffect, useRef, useState} from 'react'; +import {Image} from 'react-native'; +import {View} from 'react-native'; +import Animated, {Easing, timing, useValue} from 'react-native-reanimated'; +import Carousel from 'react-native-snap-carousel'; +import {SvgXml} from 'react-native-svg'; +import {NOTE_SVG, LOGO_SVG, SYNC_SVG} from '../../assets/images/assets'; +import {useTracked} from '../../provider'; +import {eSendEvent} from '../../services/EventManager'; +import {dHeight, dWidth, getElevation} from '../../utils'; +import {eOpenLoginDialog} from '../../utils/Events'; +import {SIZE} from '../../utils/SizeUtils'; +import Storage from '../../utils/storage'; +import {sleep} from '../../utils/TimeUtils'; +import {Button} from '../Button'; +import Heading from '../Typography/Heading'; +import Paragraph from '../Typography/Paragraph'; + +const SplashScreen = () => { + const [state, dispatch] = useTracked(); + const {colors} = state; + const [visible, setVisible] = useState(false); + const carouselRef = useRef(); + const [isNext, setIsNext] = useState(true); + const opacity = useValue(0); + const translateY = useValue(20); + const translateY2 = useValue(0); + const features = [ + { + title: 'Notesnook', + description: 'A safe place to write and get organized.', + icon: require('../../assets/images/notesnook-logo-png.png'), + type: 'image', + }, + { + title: 'Zero Knowledge', + description: 'Write without fear, no tracking.', + icon: SYNC_SVG, + }, + { + title: 'Zero Knowledge', + description: + 'No sneaking, no stealing. We give all the keys for your data to you. Privacy is not just a word to us. We use industry-grade XChaChaPoly1305 and Argon2 which is miles ahead other solutions making sure your data is secure and private even a million years from now.', + }, + ]; + + useEffect(() => { + Storage.read('introCompleted').then((r) => { + if (!r) { + setVisible(true); + timing(opacity, { + toValue: 1, + duration: 500, + easing: Easing.in(Easing.ease), + }).start(); + timing(translateY, { + toValue: 0, + duration: 500, + easing: Easing.in(Easing.ease), + }).start(); + } + }); + }, []); + + const hide = async () => { + timing(translateY2, { + toValue: dHeight * 2, + duration: 500, + easing: Easing.in(Easing.ease), + }).start(); + await sleep(500); + setVisible(false); + }; + + return ( + visible && ( + + + + { + setIsNext(false); + }} + renderItem={({item, index}) => ( + + + {item.type === 'image' ? ( + + ) : ( + + )} + + {item.title && ( + + {item.title} + + )} + + {item.description && ( + + {item.description} + + )} + + + )} + /> + + + + {isNext ? ( + + ) : ( +