mirror of
https://github.com/streetwriters/notesnook.git
synced 2025-12-16 19:57:52 +01:00
268 lines
8.4 KiB
JavaScript
268 lines
8.4 KiB
JavaScript
/*
|
|
This file is part of the Notesnook project (https://notesnook.com/)
|
|
|
|
Copyright (C) 2023 Streetwriters (Private) Limited
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
import { Debug } from "@notesnook/core";
|
|
import { getModel, getBrand, getSystemVersion } from "react-native-device-info";
|
|
import { useThemeColors } from "@notesnook/theme";
|
|
import React, { useRef, useState } from "react";
|
|
import { Linking, Platform, Text, TextInput, View } from "react-native";
|
|
import { getVersion } from "react-native-device-info";
|
|
import { useStoredRef } from "../../../hooks/use-stored-ref";
|
|
import { ToastManager } from "../../../services/event-manager";
|
|
import PremiumService from "../../../services/premium";
|
|
import { useUserStore } from "../../../stores/use-user-store";
|
|
import { openLinkInBrowser } from "../../../utils/functions";
|
|
import { defaultBorderRadius, AppFontSize } from "../../../utils/size";
|
|
import DialogHeader from "../../dialog/dialog-header";
|
|
import { Button } from "../../ui/button";
|
|
import Seperator from "../../ui/seperator";
|
|
import Heading from "../../ui/typography/heading";
|
|
import Paragraph from "../../ui/typography/paragraph";
|
|
import { strings } from "@notesnook/intl";
|
|
import { DefaultAppStyles } from "../../../utils/styles";
|
|
import Config from "react-native-config";
|
|
|
|
export const Issue = ({ defaultTitle, defaultBody, issueTitle }) => {
|
|
const { colors } = useThemeColors();
|
|
const body = useStoredRef("issueBody");
|
|
const title = useStoredRef("issueTitle", defaultTitle);
|
|
const [done, setDone] = useState(false);
|
|
const user = useUserStore((state) => state.user);
|
|
const [loading, setLoading] = useState(false);
|
|
const bodyRef = useRef();
|
|
const initialLayout = useRef(false);
|
|
const issueUrl = useRef();
|
|
|
|
const onPress = async () => {
|
|
if (loading) return;
|
|
if (!title.current || !body.current) return;
|
|
if (title.current?.trim() === "" || body.current?.trim().length === 0)
|
|
return;
|
|
|
|
try {
|
|
setLoading(true);
|
|
issueUrl.current = await Debug.report({
|
|
title: title.current,
|
|
body:
|
|
body.current +
|
|
`\n${defaultBody || ""}` +
|
|
`\n_______________
|
|
**Device information:**
|
|
App version: ${getVersion()}
|
|
Platform: ${Platform.OS}
|
|
Device: ${getBrand() || ""}-${getModel() || ""}-${getSystemVersion() || ""}
|
|
Pro: ${PremiumService.get()}
|
|
Logged in: ${user ? "yes" : "no"}
|
|
Github Release: ${Config.GITHUB_RELEASE === "true" ? "Yes" : "No"}`,
|
|
userId: user?.id
|
|
});
|
|
if (!issueUrl.current) {
|
|
setLoading(false);
|
|
ToastManager.show({
|
|
heading: "Failed to report issue on github",
|
|
type: "error",
|
|
context: "local"
|
|
});
|
|
return;
|
|
}
|
|
setLoading(false);
|
|
body.reset();
|
|
title.reset();
|
|
setDone(true);
|
|
} catch (e) {
|
|
setLoading(false);
|
|
ToastManager.show({
|
|
heading: e.message,
|
|
type: "error"
|
|
});
|
|
}
|
|
};
|
|
|
|
return (
|
|
<View
|
|
style={{
|
|
paddingHorizontal: DefaultAppStyles.GAP,
|
|
width: "100%"
|
|
}}
|
|
>
|
|
{done ? (
|
|
<>
|
|
<View
|
|
style={{
|
|
height: 250,
|
|
justifyContent: "center",
|
|
alignItems: "center",
|
|
gap: 10
|
|
}}
|
|
>
|
|
<Heading>{strings.issueCreatedHeading()}</Heading>
|
|
<Paragraph
|
|
style={{
|
|
textAlign: "center"
|
|
}}
|
|
selectable={true}
|
|
>
|
|
{strings.issueCreatedDesc[0]()}
|
|
<Paragraph
|
|
style={{
|
|
textDecorationLine: "underline",
|
|
color: colors.primary.accent
|
|
}}
|
|
onPress={() => {
|
|
Linking.openURL(issueUrl.current);
|
|
}}
|
|
>
|
|
{issueUrl.current}
|
|
</Paragraph>
|
|
. {strings.issueCreatedDesc[1]()}
|
|
</Paragraph>
|
|
|
|
<Button
|
|
title={strings.openIssue()}
|
|
onPress={() => {
|
|
Linking.openURL(issueUrl.current);
|
|
}}
|
|
type="accent"
|
|
width="100%"
|
|
/>
|
|
</View>
|
|
</>
|
|
) : (
|
|
<>
|
|
<DialogHeader
|
|
title={issueTitle || strings.issueTitle()}
|
|
paragraph={issueTitle ? strings.issueDesc() : strings.issueDesc2()}
|
|
/>
|
|
|
|
<Seperator half />
|
|
|
|
<TextInput
|
|
placeholder={strings.title()}
|
|
onChangeText={(v) => (title.current = v)}
|
|
defaultValue={title.current}
|
|
style={{
|
|
borderWidth: 1,
|
|
borderColor: colors.primary.border,
|
|
borderRadius: defaultBorderRadius,
|
|
padding: DefaultAppStyles.GAP,
|
|
fontFamily: "Inter-Regular",
|
|
marginBottom: DefaultAppStyles.GAP_VERTICAL,
|
|
fontSize: AppFontSize.md,
|
|
color: colors.primary.heading
|
|
}}
|
|
placeholderTextColor={colors.primary.placeholder}
|
|
/>
|
|
|
|
<TextInput
|
|
ref={bodyRef}
|
|
multiline
|
|
placeholder={strings.issuePlaceholder()}
|
|
numberOfLines={5}
|
|
textAlignVertical="top"
|
|
onChangeText={(v) => (body.current = v)}
|
|
onLayout={() => {
|
|
if (initialLayout.current) return;
|
|
initialLayout.current = true;
|
|
if (body.current) {
|
|
bodyRef.current?.setNativeProps({
|
|
text: body.current,
|
|
selection: {
|
|
start: 0,
|
|
end: 0
|
|
}
|
|
});
|
|
}
|
|
}}
|
|
style={{
|
|
borderWidth: 1,
|
|
borderColor: colors.primary.border,
|
|
borderRadius: defaultBorderRadius,
|
|
padding: DefaultAppStyles.GAP,
|
|
fontFamily: "Inter-Regular",
|
|
maxHeight: 200,
|
|
fontSize: AppFontSize.sm,
|
|
marginBottom: 2.5,
|
|
color: colors.primary.paragraph
|
|
}}
|
|
placeholderTextColor={colors.primary.placeholder}
|
|
/>
|
|
<Paragraph
|
|
size={AppFontSize.xs}
|
|
color={colors.secondary.paragraph}
|
|
>{`App version: ${getVersion()} Platform: ${
|
|
Platform.OS
|
|
} Model: ${getBrand()}-${getModel()}-${getSystemVersion()}`}</Paragraph>
|
|
|
|
<Seperator />
|
|
<Button
|
|
onPress={onPress}
|
|
title={loading ? null : strings.submit()}
|
|
loading={loading}
|
|
width="100%"
|
|
type="accent"
|
|
/>
|
|
|
|
<Paragraph
|
|
color={colors.secondary.paragraph}
|
|
size={AppFontSize.xs}
|
|
style={{
|
|
marginTop: DefaultAppStyles.GAP_VERTICAL,
|
|
textAlign: "center"
|
|
}}
|
|
>
|
|
{strings.issueNotice[0]()}{" "}
|
|
<Text
|
|
onPress={() => {
|
|
Linking.openURL(
|
|
"https://github.com/streetwriters/notesnook/issues"
|
|
);
|
|
}}
|
|
style={{
|
|
textDecorationLine: "underline",
|
|
color: colors.primary.accent
|
|
}}
|
|
>
|
|
github.com/streetwriters/notesnook.
|
|
</Text>{" "}
|
|
{strings.issueNotice[1]()}{" "}
|
|
<Text
|
|
style={{
|
|
textDecorationLine: "underline",
|
|
color: colors.primary.accent
|
|
}}
|
|
onPress={async () => {
|
|
try {
|
|
await openLinkInBrowser(
|
|
"https://discord.gg/zQBK97EE22",
|
|
colors
|
|
);
|
|
} catch (e) {
|
|
console.error(e);
|
|
}
|
|
}}
|
|
>
|
|
{strings.issueNotice[2]()}
|
|
</Text>
|
|
</Paragraph>
|
|
</>
|
|
)}
|
|
</View>
|
|
);
|
|
};
|