From e935aedfcf3629d038c084dc3491fb07bac1e54b Mon Sep 17 00:00:00 2001 From: kunish Date: Sun, 10 Sep 2023 00:58:21 +0800 Subject: [PATCH] feat(setup): prefix endpoint url with current url protocol if missing --- package.json | 1 + pnpm-lock.yaml | 25 +++++++++------ src/App.tsx | 3 ++ src/helpers/global.ts | 3 ++ src/i18n/en.ts | 2 ++ src/i18n/zh.ts | 2 ++ src/pages/Setup.tsx | 75 +++++++++++++++++++++++++++++-------------- 7 files changed, 78 insertions(+), 33 deletions(-) diff --git a/package.json b/package.json index 7657f582..1e795d6b 100644 --- a/package.json +++ b/package.json @@ -55,6 +55,7 @@ "solid-apexcharts": "^0.3.2", "solid-infinite-scroll": "^1.0.1", "solid-js": "^1.7.11", + "solid-toast": "^0.5.0", "sort-package-json": "^2.5.1", "tailwind-merge": "^1.14.0", "tailwindcss": "^3.3.3", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 43525084..1bcae3d7 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -137,6 +137,9 @@ dependencies: solid-js: specifier: ^1.7.11 version: 1.7.11 + solid-toast: + specifier: ^0.5.0 + version: 0.5.0(solid-js@1.7.11) sort-package-json: specifier: ^2.5.1 version: 2.5.1 @@ -2913,13 +2916,6 @@ packages: } dev: false - /@types/node@20.5.9: - resolution: - { - integrity: sha512-PcGNd//40kHAS3sTlzKB9C9XL4K0sTup8nbG5lC14kzEteTNuAFh9u5nA0o5TWnSG2r/JNPRXFVcHJIIeRlmqQ==, - } - dev: false - /@types/node@20.6.0: resolution: { @@ -2940,7 +2936,7 @@ packages: integrity: sha512-yy7HuzQhj0dhGpD8RLXSZWEkLsV9ibvxvi6EiJ3bkqLAO1RGo0WbkWQiwpRlSFymTJRz0d3k5LM3kkx8ArDbLw==, } dependencies: - '@types/node': 20.5.9 + '@types/node': 20.6.0 dev: false /@types/semver@7.5.1: @@ -5580,7 +5576,7 @@ packages: } engines: { node: '>= 10.13.0' } dependencies: - '@types/node': 20.5.9 + '@types/node': 20.6.0 merge-stream: 2.0.0 supports-color: 7.2.0 dev: false @@ -7177,6 +7173,17 @@ packages: solid-js: 1.7.11 dev: false + /solid-toast@0.5.0(solid-js@1.7.11): + resolution: + { + integrity: sha512-t770JakjyS2P9b8Qa1zMLOD51KYKWXbTAyJePVUoYex5c5FH5S/HtUBUbZAWFcqRCKmAE8KhyIiCvDZA8bOnxQ==, + } + peerDependencies: + solid-js: ^1.5.4 + dependencies: + solid-js: 1.7.11 + dev: false + /sort-object-keys@1.1.3: resolution: { diff --git a/src/App.tsx b/src/App.tsx index 4e7999d6..7d7dbd0d 100644 --- a/src/App.tsx +++ b/src/App.tsx @@ -1,5 +1,6 @@ import { Navigate, Route, Routes, useNavigate } from '@solidjs/router' import { Show, createEffect, lazy, onMount } from 'solid-js' +import { Toaster } from 'solid-toast' import { twMerge } from 'tailwind-merge' import { Header } from '~/components' import { ROUTES } from '~/constants' @@ -71,6 +72,8 @@ export const App = () => { /> + + ) } diff --git a/src/helpers/global.ts b/src/helpers/global.ts index 42c3624e..9dd8373a 100644 --- a/src/helpers/global.ts +++ b/src/helpers/global.ts @@ -1,5 +1,8 @@ import { createSignal } from 'solid-js' +export const transformEndpointURL = (url: string) => + /^https?/.test(url) ? url : `${window.location.protocol}//${url}` + export const useStringBooleanMap = () => { const [map, setMap] = createSignal>({}) const set = (name: string, value: boolean) => { diff --git a/src/i18n/en.ts b/src/i18n/en.ts index 21e09a9f..a0948c52 100644 --- a/src/i18n/en.ts +++ b/src/i18n/en.ts @@ -73,4 +73,6 @@ export default { sequence: 'Sequence', payload: 'Payload', details: 'Details', + endpointURL: 'Endpoint URL', + secret: 'Secret', } diff --git a/src/i18n/zh.ts b/src/i18n/zh.ts index e694828b..c5419125 100644 --- a/src/i18n/zh.ts +++ b/src/i18n/zh.ts @@ -73,4 +73,6 @@ export default { sequence: '序列号', payload: '内容', details: '详情', + endpointURL: '后端地址', + secret: '密钥', } diff --git a/src/pages/Setup.tsx b/src/pages/Setup.tsx index 4f5a5b67..61c6039a 100644 --- a/src/pages/Setup.tsx +++ b/src/pages/Setup.tsx @@ -5,9 +5,11 @@ import { useNavigate } from '@solidjs/router' import { IconX } from '@tabler/icons-solidjs' import ky from 'ky' import { For, onMount } from 'solid-js' +import { toast } from 'solid-toast' import { v4 as uuid } from 'uuid' import { z } from 'zod' import { Button } from '~/components' +import { transformEndpointURL } from '~/helpers' import { endpointList, selectedEndpoint, @@ -16,7 +18,7 @@ import { } from '~/signals' const schema = z.object({ - url: z.string().url().nonempty(), + url: z.string().nonempty(), secret: z.string(), }) @@ -39,7 +41,11 @@ export default () => { : {}, }) .then(({ ok }) => ok) - .catch(() => false) + .catch((err) => { + const { message } = err as Error + + toast.error(message) + }) const onEndpointSelect = async (id: string) => { const endpoint = endpointList().find((e) => e.id === id) @@ -56,17 +62,19 @@ export default () => { } const onSubmit = async ({ url, secret }: { url: string; secret: string }) => { - if (!(await checkEndpoint(url, secret))) { + const transformedURL = transformEndpointURL(url) + + if (!(await checkEndpoint(transformedURL, secret))) { return } const id = uuid() const list = endpointList().slice() - const point = list.find((history) => history.url === url) + const point = list.find((history) => history.url === transformedURL) if (!point) { // new host and secret - setEndpointList([{ id, url, secret }, ...list]) + setEndpointList([{ id, url: transformedURL, secret }, ...list]) onSetupSuccess(id) return @@ -80,9 +88,16 @@ export default () => { onSetupSuccess(id) } + const onError = (err: unknown) => { + const { message } = err as Error + + toast.error(message) + } + const { form } = createForm>({ extend: validator({ schema }), onSubmit, + onError, }) const onRemove = (id: string) => { @@ -116,27 +131,39 @@ export default () => { }) return ( -
+
- - - - - - +
+ + + + + + +
+ +
+ + + +