Skip to content

Commit

Permalink
Fixes & Features (#1002)
Browse files Browse the repository at this point in the history
* stop loading even no chapters

* edit artist

* more detail reader settings
  • Loading branch information
nyagami authored Mar 16, 2024
1 parent a7aa203 commit 7629454
Show file tree
Hide file tree
Showing 5 changed files with 139 additions and 25 deletions.
11 changes: 8 additions & 3 deletions android/app/src/main/assets/css/index.css
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,10 @@ img {
max-width: 100%;
}

.hidden {
visibility: hidden;
}

.nextButton,
.infoText {
width: 100%;
Expand Down Expand Up @@ -90,7 +94,8 @@ img {

#ToolWrapper {
position: fixed;
top: 25vh;
top: 50%;
transform: translateY(-50%);
right: 5vw;
transition: 150ms;
}
Expand All @@ -117,6 +122,7 @@ img {
margin-top: 8px;
width: 2.4rem;
height: 45vh;
min-height: 200px;
border-radius: 1.2rem;
background-color: var(--theme-surface-0-9);
touch-action: none;
Expand Down Expand Up @@ -316,10 +322,9 @@ tts.highlight {
display: flex;
height: 100%;
width: 100%;
max-width: max-content;
max-height: max-content;
background-color: var(--theme-surface-0-9);
align-items: center;
justify-content: center;
overflow: scroll;
}

Expand Down
4 changes: 1 addition & 3 deletions src/hooks/persisted/useNovel.ts
Original file line number Diff line number Diff line change
Expand Up @@ -401,10 +401,8 @@ export const useNovel = (novelPath: string, pluginId: string) => {
);
}
setChapters(chapters);
if (loading) {
setLoading(false);
}
}
setLoading(false);
}, [novel, novelSettings, pageIndex]);
useEffect(() => {
getNovel();
Expand Down
9 changes: 9 additions & 0 deletions src/screens/novel/components/EditInfoModal.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -130,6 +130,15 @@ const EditInfoModal = ({
onChangeText={text => setNovel({ ...novel, author: text })}
dense
/>
<TextInput
placeholder={'Artist: ' + novel.artist}
style={{ fontSize: 14 }}
numberOfLines={1}
mode="outlined"
theme={{ colors: { ...theme } }}
onChangeText={text => setNovel({ ...novel, artist: text })}
dense
/>
<TextInput
placeholder={getString('novelScreen.edit.summary', {
summary: novel.summary?.substring(0, 16),
Expand Down
139 changes: 120 additions & 19 deletions src/screens/settings/SettingsReaderScreen/SettingsReaderScreen.tsx
Original file line number Diff line number Diff line change
@@ -1,13 +1,17 @@
import { View, ScrollView } from 'react-native';
import React from 'react';
import { View, ScrollView, StatusBar, Dimensions } from 'react-native';
import React, { useMemo, useRef, useState } from 'react';

import { useNavigation } from '@react-navigation/native';
import WebView from 'react-native-webview';
import { dummyHTML } from './utils';

import { Appbar, List } from '@components/index';

import { useChapterReaderSettings, useTheme } from '@hooks/persisted';
import {
useChapterGeneralSettings,
useChapterReaderSettings,
useTheme,
} from '@hooks/persisted';
import { getString } from '@strings/translations';

import GeneralSettings from './Settings/GeneralSettings';
Expand All @@ -16,6 +20,11 @@ import CustomJSSettings from './Settings/CustomJSSettings';
import DisplaySettings from './Settings/DisplaySettings';
import ReaderThemeSettings from './Settings/ReaderThemeSettings';
import { useSafeAreaInsets } from 'react-native-safe-area-context';
import color from 'color';
import { useBatteryLevel } from 'react-native-device-info';
import * as Speech from 'expo-speech';
import * as Clipboard from 'expo-clipboard';
import { showToast } from '@utils/showToast';

export type TextAlignments =
| 'left'
Expand All @@ -25,13 +34,27 @@ export type TextAlignments =
| 'justify'
| undefined;

type WebViewPostEvent = {
type: string;
data?: { [key: string]: string | number };
};

const SettingsReaderScreen = () => {
const theme = useTheme();
const navigation = useNavigation();
const webViewRef = useRef<WebView>(null);
const { bottom } = useSafeAreaInsets();

const [hidden, setHidden] = useState(true);
const layoutHeight = Dimensions.get('window').height;
const batteryLevel = useBatteryLevel();
const readerSettings = useChapterReaderSettings();
const { showScrollPercentage, showBatteryAndTime } =
useChapterGeneralSettings();
const READER_HEIGHT = 280;
const assetsUriPrefix = useMemo(
() => (__DEV__ ? 'http://localhost:8081/assets' : 'file:///android_asset'),
[],
);
const dummyChapterInfo = {
sourceId: 11,
chapterId: 99,
Expand All @@ -41,24 +64,38 @@ const SettingsReaderScreen = () => {
};
const webViewCSS = `
<style>
body {
color: ${readerSettings.textColor};
text-align: ${readerSettings.textAlign};
line-height: ${readerSettings.lineHeight};
font-size: ${readerSettings.textSize}px;
padding-top: 8px;
padding-bottom: 8px;
padding-left: ${readerSettings.padding}%;
padding-right: ${readerSettings.padding}%;
font-family: ${readerSettings.fontFamily};
}
</style>
<style>
${readerSettings.customCSS}
:root {
--StatusBar-currentHeight: ${StatusBar.currentHeight};
--readerSettings-theme: ${readerSettings.theme};
--readerSettings-padding: ${readerSettings.padding}%;
--readerSettings-textSize: ${readerSettings.textSize}px;
--readerSettings-textColor: ${readerSettings.textColor};
--readerSettings-textAlign: ${readerSettings.textAlign};
--readerSettings-lineHeight: ${readerSettings.lineHeight};
--readerSettings-fontFamily: ${readerSettings.fontFamily};
--theme-primary: ${theme.primary};
--theme-onPrimary: ${theme.onPrimary};
--theme-secondary: ${theme.secondary};
--theme-tertiary: ${theme.tertiary};
--theme-onTertiary: ${theme.onTertiary};
--theme-onSecondary: ${theme.onSecondary};
--theme-surface: ${theme.surface};
--theme-surface-0-9: ${color(theme.surface).alpha(0.9).toString()};
--theme-onSurface: ${theme.onSurface};
--theme-surfaceVariant: ${theme.surfaceVariant};
--theme-onSurfaceVariant: ${theme.onSurfaceVariant};
--theme-outline: ${theme.outline};
--theme-rippleColor: ${theme.rippleColor};
--chapterCtn-height: ${layoutHeight - 140};
}
@font-face {
font-family: ${readerSettings.fontFamily};
src: url("file:///android_asset/fonts/${readerSettings.fontFamily}.ttf");
}
</style>
<link rel="stylesheet" href="${assetsUriPrefix}/css/index.css">
<style>
${readerSettings.customCSS}
</style>
`;

Expand All @@ -75,23 +112,88 @@ const SettingsReaderScreen = () => {

<View style={{ height: READER_HEIGHT }}>
<WebView
ref={webViewRef}
originWhitelist={['*']}
allowFileAccess={true}
scalesPageToFit={true}
showsVerticalScrollIndicator={false}
javaScriptEnabled={true}
style={{ backgroundColor: readerBackgroundColor }}
nestedScrollEnabled={true}
onMessage={ev => {
const event: WebViewPostEvent = JSON.parse(ev.nativeEvent.data);
switch (event.type) {
case 'hide':
if (hidden) {
webViewRef.current?.injectJavaScript('toolWrapper.show()');
} else {
webViewRef.current?.injectJavaScript('toolWrapper.hide()');
}
setHidden(!hidden);
break;
case 'speak':
if (event.data && typeof event.data === 'string') {
Speech.speak(event.data, {
onDone() {
webViewRef.current?.injectJavaScript('tts.next?.()');
},
});
}
break;
case 'stop-speak':
Speech.stop();
break;
case 'copy':
if (event.data && typeof event.data === 'string') {
Clipboard.setStringAsync(event.data).then(() => {
showToast(
getString('common.copiedToClipboard', { name: '' }),
);
});
}
break;
}
}}
source={{
html: `
<html>
<head>
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0">
${webViewCSS}
<script async>
var initSettings = {
showScrollPercentage: ${showScrollPercentage},
swipeGestures: false,
showBatteryAndTime: ${showBatteryAndTime},
}
var batteryLevel = ${batteryLevel};
var autoSaveInterval = 2222;
</script>
</head>
<body>
<chapter
data-novel-id='${dummyChapterInfo.novelId}'
data-chapter-id='${dummyChapterInfo.chapterId}'
onclick="reader.post({type:'hide'})"
>
${dummyHTML}
</chapter>
<div class="hidden" id="ToolWrapper">
<div id="TTS-Controller"></div>
<div id="ScrollBar"></div>
</div>
<div id="Image-Modal">
<img id="Image-Modal-img">
</div>
<div id="reader-footer-wrapper">
<div id="reader-footer">
<div id="reader-battery" class="reader-footer-item"></div>
<div id="reader-percentage" class="reader-footer-item"></div>
<div id="reader-time" class="reader-footer-item"></div>
</div>
</div>
</body>
<script src="${assetsUriPrefix}/js/index.js"></script>
<script>
async function fn(){
let novelName = "${dummyChapterInfo.novelName}";
Expand All @@ -104,7 +206,6 @@ const SettingsReaderScreen = () => {
}
document.addEventListener("DOMContentLoaded", fn);
</script>
</body>
</html>
`,
}}
Expand Down
1 change: 1 addition & 0 deletions src/screens/settings/SettingsReaderScreen/utils.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
export const dummyHTML = `
<h1>Lorem ipsum dolor sit amet consectetuer adipiscing
elit</h1>
<img src=""/>
<p>Lorem ipsum dolor sit amet, consectetuer adipiscing
elit. Aenean commodo ligula eget dolor. Aenean massa
<strong>strong</strong>. Cum sociis natoque penatibus
Expand Down

0 comments on commit 7629454

Please sign in to comment.