From 17cbeb205acfc569fca400f5fba9646d067cb35a Mon Sep 17 00:00:00 2001 From: ammarahm-ed Date: Mon, 15 Feb 2021 12:58:54 +0500 Subject: [PATCH] complete intro screen --- apps/mobile/src/assets/images/assets.js | 1475 ++++++++++++++++- .../src/components/SplashScreen/index.js | 190 ++- 2 files changed, 1533 insertions(+), 132 deletions(-) diff --git a/apps/mobile/src/assets/images/assets.js b/apps/mobile/src/assets/images/assets.js index 4341b8122..a7d2a8175 100644 --- a/apps/mobile/src/assets/images/assets.js +++ b/apps/mobile/src/assets/images/assets.js @@ -1,24 +1,28 @@ -export const FAV_SVG = (color) => `` +export const FAV_SVG = (color) => + ``; +export const NOTE_SVG = (color) => + ``; -export const NOTE_SVG = (color) => `` +export const NOTEBOOK_SVG = (color) => + ``; +export const TAG_SVG = (color) => + ``; -export const NOTEBOOK_SVG = (color) => `` +export const TRASH_SVG = (color) => + ``; -export const TAG_SVG = (color) => `` +export const SETTINGS_SVG = (color) => + `settings`; +export const SEARCH_SVG = (color) => + ``; -export const TRASH_SVG = (color) => `` +export const LOGO_BASE64 = ``; -export const SETTINGS_SVG = (color) => `settings` - -export const SEARCH_SVG = (color) => `` - -export const LOGO_BASE64 = `` - - -export const LOGIN_SVG = color => `` +export const LOGIN_SVG = (color) => + ``; export const RICH_TEXT_SVG = (color) => ` @@ -54,47 +58,1052 @@ export const RICH_TEXT_SVG = (color) => ` -` +`; -export const SYNC_SVG = (color) => ` - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -` +export const SYNC_SVG = ( + color, +) => ` + + + + + image/svg+xml + + file_sync + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + file_sync + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +`; -export const ORGANIZE_SVG = (color) => ` +export const ORGANIZE_SVG = ( + color, +) => ` @@ -125,9 +1134,11 @@ export const ORGANIZE_SVG = (color) => ` -` +`; -export const EXPORT_SVG = (color) => ` +export const EXPORT_SVG = ( + color, +) => ` @@ -171,9 +1182,11 @@ export const EXPORT_SVG = (color) => ` -` +`; -export const BACKUP_SVG = (color) => ` +export const BACKUP_SVG = ( + color, +) => ` @@ -424,7 +1437,7 @@ export const BACKUP_SVG = (color) => ` -` +`; export const LOGO_SVG = ` @@ -637,4 +1650,350 @@ export const LOGO_SVG = ` inkscape:connector-curvature="0" /> -` \ No newline at end of file +`; + +export const PRIVACY_SVG = (color) => ` + + + + + + image/svg+xml + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +`; + +export const COMMUNITY_SVG = (color) => ` +having fun +`; diff --git a/apps/mobile/src/components/SplashScreen/index.js b/apps/mobile/src/components/SplashScreen/index.js index ca30be25c..65138477d 100644 --- a/apps/mobile/src/components/SplashScreen/index.js +++ b/apps/mobile/src/components/SplashScreen/index.js @@ -1,20 +1,27 @@ -import React, { useEffect, useRef, useState } from 'react'; -import { Image, View } from 'react-native'; -import Animated, { Easing, timing, useValue } from 'react-native-reanimated'; +import React, {useEffect, useRef, useState} from 'react'; +import {Image, 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, 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 {SvgXml} from 'react-native-svg'; +import { + NOTE_SVG, + SYNC_SVG, + ORGANIZE_SVG, + PRIVACY_SVG, + COMMUNITY_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 {sleep} from '../../utils/TimeUtils'; +import {Button} from '../Button'; import Heading from '../Typography/Heading'; import Paragraph from '../Typography/Paragraph'; +import Icon from 'react-native-vector-icons/MaterialCommunityIcons'; const SplashScreen = () => { const [state, dispatch] = useTracked(); const {colors} = state; @@ -32,20 +39,36 @@ const SplashScreen = () => { type: 'image', }, { - title: 'Zero Knowledge', - description: 'Write without fear, no tracking.', - icon: SYNC_SVG, + title: 'Made to protect your privacy', + description: + 'Your data is encrypted on your device. No one but you can read your notes.', + icon: PRIVACY_SVG, + link: 'https://notesnook.com', }, { - title: 'Zero Knowledge', + icon: SYNC_SVG, + title: 'While keeping you in sync', 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.', + 'Everything is automatically synced to all your devices in a safe and secure way. Notesnook is available on all major platforms.', + link: 'https://notesnook.com', + }, + { + icon: ORGANIZE_SVG, + title: 'And helping you stay organized', + description: + 'Add your notes in notebooks and topics or simply assign tags or colors to find them easily.', + link: 'https://notesnook.com', + }, + { + icon: COMMUNITY_SVG, + title: 'Join our community', + description: + 'We are not ghosts, chat with us and share your experience. Give suggestions, report issues and meet other people using Notesnook', + link: 'https://discord.gg/zQBK97EE22', }, ]; useEffect(() => { - - return; Storage.read('introCompleted').then(async (r) => { setVisible(true); await sleep(500); @@ -106,16 +129,13 @@ const SplashScreen = () => { }, ], }}> - + { }} renderItem={({item, index}) => ( - {item.type === 'image' ? ( - - ) : ( - - )} + + {item.type === 'image' ? ( + + ) : item.type === 'icon' ? ( + + ) : ( + + )} - {item.title && ( - - {item.title} - - )} + {item.title && ( + + {item.title} + + )} - {item.description && ( - - {item.description} - - )} + {item.description && ( + + {item.description} + + )} + + {item.link && ( +