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 = `
+
+
+
+`
\ 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 ? (
+
+ ) : (
+
+
+
+ )
+ );
+};
+
+export default SplashScreen;