mirror of
https://github.com/streetwriters/notesnook.git
synced 2025-12-23 23:19:40 +01:00
245 lines
7.3 KiB
JavaScript
245 lines
7.3 KiB
JavaScript
/*
|
|
This file is part of the Notesnook project (https://notesnook.com/)
|
|
|
|
Copyright (C) 2022 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 Clipboard from "@react-native-clipboard/clipboard";
|
|
import React, { useRef, useState } from "react";
|
|
import { Linking, Platform, Text, TextInput, View } from "react-native";
|
|
import { getVersion } from "react-native-device-info";
|
|
import { db } from "../../../common/database";
|
|
import { eSendEvent, ToastEvent } from "../../../services/event-manager";
|
|
import PremiumService from "../../../services/premium";
|
|
import { useThemeStore } from "../../../stores/use-theme-store";
|
|
import { useUserStore } from "../../../stores/use-user-store";
|
|
import { eCloseProgressDialog } from "../../../utils/events";
|
|
import { openLinkInBrowser } from "../../../utils/functions";
|
|
import { SIZE } from "../../../utils/size";
|
|
import { sleep } from "../../../utils/time";
|
|
import DialogHeader from "../../dialog/dialog-header";
|
|
import { presentDialog } from "../../dialog/functions";
|
|
import { Button } from "../../ui/button";
|
|
import Seperator from "../../ui/seperator";
|
|
import Paragraph from "../../ui/typography/paragraph";
|
|
export const Issue = ({ defaultTitle, defaultBody, issueTitle }) => {
|
|
const colors = useThemeStore((state) => state.colors);
|
|
const body = useRef(defaultBody);
|
|
const title = useRef(defaultTitle);
|
|
const user = useUserStore((state) => state.user);
|
|
const [loading, setLoading] = useState(false);
|
|
const bodyRef = useRef();
|
|
const initialLayout = useRef(false);
|
|
|
|
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);
|
|
|
|
let issue_url = await db.debug.report({
|
|
title: title.current,
|
|
body:
|
|
body.current +
|
|
`\n_______________
|
|
**Device information:**
|
|
App version: ${getVersion()}
|
|
Platform: ${Platform.OS}
|
|
Model: ${Platform.constants.Brand || ""}-${Platform.constants.Model || ""}-${
|
|
Platform.constants.Version || ""
|
|
}
|
|
Pro: ${PremiumService.get()}
|
|
Logged in: ${user ? "yes" : "no"}`,
|
|
userId: user?.id
|
|
});
|
|
setLoading(false);
|
|
eSendEvent(eCloseProgressDialog);
|
|
await sleep(300);
|
|
presentDialog({
|
|
title: "Issue reported",
|
|
paragraph: (
|
|
<Text>
|
|
You can track your issue at{" "}
|
|
<Text
|
|
style={{
|
|
textDecorationLine: "underline",
|
|
color: colors.accent
|
|
}}
|
|
onPress={() => {
|
|
Linking.openURL(issue_url);
|
|
}}
|
|
>
|
|
{issue_url}.
|
|
</Text>{" "}
|
|
Please note that we will respond to your issue on the given link. We
|
|
recommend that you save it.
|
|
</Text>
|
|
),
|
|
positiveText: "Copy link",
|
|
positivePress: () => {
|
|
Clipboard.setString(issue_url);
|
|
ToastEvent.show({
|
|
heading: "Issue url copied!",
|
|
type: "success",
|
|
context: "global"
|
|
});
|
|
},
|
|
negativeText: "Close"
|
|
});
|
|
} catch (e) {
|
|
setLoading(false);
|
|
ToastEvent.show({
|
|
heading: "An error occured",
|
|
message: e.message,
|
|
type: "error"
|
|
});
|
|
}
|
|
};
|
|
|
|
return (
|
|
<View
|
|
style={{
|
|
paddingHorizontal: 12,
|
|
width: "100%"
|
|
}}
|
|
>
|
|
<DialogHeader
|
|
title={issueTitle || "Report issue"}
|
|
paragraph={
|
|
issueTitle
|
|
? "We are sorry, it seems that the app crashed due to an error. You can submit a bug report below so we can fix this asap."
|
|
: "Let us know if you have faced any issue/bug while using Notesnook."
|
|
}
|
|
/>
|
|
|
|
<Seperator half />
|
|
|
|
<TextInput
|
|
placeholder="Title"
|
|
onChangeText={(v) => (title.current = v)}
|
|
defaultValue={title.current}
|
|
style={{
|
|
borderWidth: 1,
|
|
borderColor: colors.nav,
|
|
borderRadius: 5,
|
|
padding: 12,
|
|
fontFamily: "OpenSans-Regular",
|
|
marginBottom: 10,
|
|
fontSize: SIZE.md,
|
|
color: colors.heading
|
|
}}
|
|
placeholderTextColor={colors.placeholder}
|
|
/>
|
|
|
|
<TextInput
|
|
ref={bodyRef}
|
|
placeholder={`Tell us more about the issue you are facing.
|
|
|
|
For example:
|
|
- Steps to reproduce the issue
|
|
- Things you have tried etc.`}
|
|
multiline
|
|
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.nav,
|
|
borderRadius: 5,
|
|
padding: 12,
|
|
fontFamily: "OpenSans-Regular",
|
|
maxHeight: 200,
|
|
fontSize: SIZE.sm,
|
|
marginBottom: 2.5,
|
|
color: colors.pri
|
|
}}
|
|
placeholderTextColor={colors.placeholder}
|
|
/>
|
|
<Paragraph
|
|
size={SIZE.xs}
|
|
color={colors.icon}
|
|
>{`App version: ${getVersion()} Platform: ${Platform.OS} Model: ${
|
|
Platform.constants.Brand
|
|
}-${Platform.constants.Model}-${Platform.constants.Version}`}</Paragraph>
|
|
|
|
<Seperator />
|
|
<Button
|
|
onPress={onPress}
|
|
title={loading ? null : "Submit"}
|
|
loading={loading}
|
|
height={50}
|
|
width="100%"
|
|
type="accent"
|
|
/>
|
|
|
|
<Paragraph
|
|
color={colors.icon}
|
|
size={SIZE.xs}
|
|
style={{
|
|
marginTop: 10,
|
|
textAlign: "center"
|
|
}}
|
|
>
|
|
The information above will be publically available at{" "}
|
|
<Text
|
|
onPress={() => {
|
|
Linking.openURL("https://github.com/streetwriters/notesnook");
|
|
}}
|
|
style={{
|
|
textDecorationLine: "underline",
|
|
color: colors.accent
|
|
}}
|
|
>
|
|
github.com/streetwriters/notesnook.
|
|
</Text>{" "}
|
|
If you want to ask something in general or need some assistance, we
|
|
would suggest that you{" "}
|
|
<Text
|
|
style={{
|
|
textDecorationLine: "underline",
|
|
color: colors.accent
|
|
}}
|
|
onPress={async () => {
|
|
try {
|
|
await openLinkInBrowser("https://discord.gg/zQBK97EE22", colors);
|
|
} catch (e) {
|
|
console.error(e);
|
|
}
|
|
}}
|
|
>
|
|
join our community on Discord.
|
|
</Text>
|
|
</Paragraph>
|
|
</View>
|
|
);
|
|
};
|