🎉 搭完基本框架
This commit is contained in:
		
							
								
								
									
										13
									
								
								frontend/index.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								frontend/index.html
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,13 @@
 | 
			
		||||
<!DOCTYPE html>
 | 
			
		||||
<html lang="en">
 | 
			
		||||
<head>
 | 
			
		||||
    <meta charset="UTF-8"/>
 | 
			
		||||
    <meta content="width=device-width, initial-scale=1.0" name="viewport"/>
 | 
			
		||||
    <title>nf-disk</title>
 | 
			
		||||
</head>
 | 
			
		||||
<body>
 | 
			
		||||
<div id="root"></div>
 | 
			
		||||
<script src="./src/main.tsx" type="module"></script>
 | 
			
		||||
</body>
 | 
			
		||||
</html>
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										5866
									
								
								frontend/package-lock.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										5866
									
								
								frontend/package-lock.json
									
									
									
										generated
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										25
									
								
								frontend/package.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								frontend/package.json
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,25 @@
 | 
			
		||||
{
 | 
			
		||||
  "name": "frontend",
 | 
			
		||||
  "private": true,
 | 
			
		||||
  "version": "0.0.0",
 | 
			
		||||
  "type": "module",
 | 
			
		||||
  "scripts": {
 | 
			
		||||
    "dev": "vite",
 | 
			
		||||
    "build": "tsc && vite build",
 | 
			
		||||
    "preview": "vite preview"
 | 
			
		||||
  },
 | 
			
		||||
  "dependencies": {
 | 
			
		||||
    "@fluentui/react-components": "^9.54.16",
 | 
			
		||||
    "@fluentui/react-icons": "^2.0.258",
 | 
			
		||||
    "react": "^18.2.0",
 | 
			
		||||
    "react-dom": "^18.2.0",
 | 
			
		||||
    "react-router-dom": "^6.26.2"
 | 
			
		||||
  },
 | 
			
		||||
  "devDependencies": {
 | 
			
		||||
    "@types/react": "^18.0.17",
 | 
			
		||||
    "@types/react-dom": "^18.0.6",
 | 
			
		||||
    "@vitejs/plugin-react": "^2.0.1",
 | 
			
		||||
    "typescript": "^4.6.4",
 | 
			
		||||
    "vite": "^3.0.7"
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										1
									
								
								frontend/package.json.md5
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								frontend/package.json.md5
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1 @@
 | 
			
		||||
b35fc08c84ef0c2b0c3e1bf37916ac94
 | 
			
		||||
							
								
								
									
										2689
									
								
								frontend/pnpm-lock.yaml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										2689
									
								
								frontend/pnpm-lock.yaml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										40
									
								
								frontend/src/api.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										40
									
								
								frontend/src/api.ts
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,40 @@
 | 
			
		||||
import {Invoke} from "../wailsjs/go/controller/App";
 | 
			
		||||
 | 
			
		||||
export interface Resp<T> {
 | 
			
		||||
    status: number;
 | 
			
		||||
    msg: string;
 | 
			
		||||
    err: string;
 | 
			
		||||
    data: T;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// 类型保护函数
 | 
			
		||||
function isResp<T>(obj: any): obj is Resp<T> {
 | 
			
		||||
    return (
 | 
			
		||||
        typeof obj === 'object' &&
 | 
			
		||||
        obj !== null &&
 | 
			
		||||
        typeof obj.status === 'number' &&
 | 
			
		||||
        (typeof obj.msg === 'string' || typeof obj.msg === null) &&
 | 
			
		||||
        (typeof obj.err === 'string' || typeof obj.err === null)
 | 
			
		||||
    );
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
const invoke = async <T>(path: string, req: any): Promise<Resp<T>> => {
 | 
			
		||||
    const bs = JSON.stringify(req)
 | 
			
		||||
    console.log(`[DEBUG] invoke req: path = ${path}, req =`, req)
 | 
			
		||||
    const res = await Invoke(path, bs)
 | 
			
		||||
    console.log(`[DEBUG] invoke res: path = ${path}, res =`, res)
 | 
			
		||||
    try {
 | 
			
		||||
        const parsed = JSON.parse(res);
 | 
			
		||||
        if (isResp<T>(parsed)) {
 | 
			
		||||
            return parsed;
 | 
			
		||||
        } else {
 | 
			
		||||
            console.error('[ERROR] invoke: resp not valid =', res)
 | 
			
		||||
            throw new Error('Parsed response does not match Resp<T> structure');
 | 
			
		||||
        }
 | 
			
		||||
    } catch (error) {
 | 
			
		||||
        console.error(`[ERROR] invoke: resp parse err, err = ${error}, res =`, res);
 | 
			
		||||
        throw new Error('Invalid response format');
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export const Dial = invoke;
 | 
			
		||||
							
								
								
									
										93
									
								
								frontend/src/assets/fonts/OFL.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										93
									
								
								frontend/src/assets/fonts/OFL.txt
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,93 @@
 | 
			
		||||
Copyright 2016 The Nunito Project Authors (contact@sansoxygen.com),
 | 
			
		||||
 | 
			
		||||
This Font Software is licensed under the SIL Open Font License, Version 1.1.
 | 
			
		||||
This license is copied below, and is also available with a FAQ at:
 | 
			
		||||
http://scripts.sil.org/OFL
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
-----------------------------------------------------------
 | 
			
		||||
SIL OPEN FONT LICENSE Version 1.1 - 26 February 2007
 | 
			
		||||
-----------------------------------------------------------
 | 
			
		||||
 | 
			
		||||
PREAMBLE
 | 
			
		||||
The goals of the Open Font License (OFL) are to stimulate worldwide
 | 
			
		||||
development of collaborative font projects, to support the font creation
 | 
			
		||||
efforts of academic and linguistic communities, and to provide a free and
 | 
			
		||||
open framework in which fonts may be shared and improved in partnership
 | 
			
		||||
with others.
 | 
			
		||||
 | 
			
		||||
The OFL allows the licensed fonts to be used, studied, modified and
 | 
			
		||||
redistributed freely as long as they are not sold by themselves. The
 | 
			
		||||
fonts, including any derivative works, can be bundled, embedded, 
 | 
			
		||||
redistributed and/or sold with any software provided that any reserved
 | 
			
		||||
names are not used by derivative works. The fonts and derivatives,
 | 
			
		||||
however, cannot be released under any other type of license. The
 | 
			
		||||
requirement for fonts to remain under this license does not apply
 | 
			
		||||
to any document created using the fonts or their derivatives.
 | 
			
		||||
 | 
			
		||||
DEFINITIONS
 | 
			
		||||
"Font Software" refers to the set of files released by the Copyright
 | 
			
		||||
Holder(s) under this license and clearly marked as such. This may
 | 
			
		||||
include source files, build scripts and documentation.
 | 
			
		||||
 | 
			
		||||
"Reserved Font Name" refers to any names specified as such after the
 | 
			
		||||
copyright statement(s).
 | 
			
		||||
 | 
			
		||||
"Original Version" refers to the collection of Font Software components as
 | 
			
		||||
distributed by the Copyright Holder(s).
 | 
			
		||||
 | 
			
		||||
"Modified Version" refers to any derivative made by adding to, deleting,
 | 
			
		||||
or substituting -- in part or in whole -- any of the components of the
 | 
			
		||||
Original Version, by changing formats or by porting the Font Software to a
 | 
			
		||||
new environment.
 | 
			
		||||
 | 
			
		||||
"Author" refers to any designer, engineer, programmer, technical
 | 
			
		||||
writer or other person who contributed to the Font Software.
 | 
			
		||||
 | 
			
		||||
PERMISSION & CONDITIONS
 | 
			
		||||
Permission is hereby granted, free of charge, to any person obtaining
 | 
			
		||||
a copy of the Font Software, to use, study, copy, merge, embed, modify,
 | 
			
		||||
redistribute, and sell modified and unmodified copies of the Font
 | 
			
		||||
Software, subject to the following conditions:
 | 
			
		||||
 | 
			
		||||
1) Neither the Font Software nor any of its individual components,
 | 
			
		||||
in Original or Modified Versions, may be sold by itself.
 | 
			
		||||
 | 
			
		||||
2) Original or Modified Versions of the Font Software may be bundled,
 | 
			
		||||
redistributed and/or sold with any software, provided that each copy
 | 
			
		||||
contains the above copyright notice and this license. These can be
 | 
			
		||||
included either as stand-alone text files, human-readable headers or
 | 
			
		||||
in the appropriate machine-readable metadata fields within text or
 | 
			
		||||
binary files as long as those fields can be easily viewed by the user.
 | 
			
		||||
 | 
			
		||||
3) No Modified Version of the Font Software may use the Reserved Font
 | 
			
		||||
Name(s) unless explicit written permission is granted by the corresponding
 | 
			
		||||
Copyright Holder. This restriction only applies to the primary font name as
 | 
			
		||||
presented to the users.
 | 
			
		||||
 | 
			
		||||
4) The name(s) of the Copyright Holder(s) or the Author(s) of the Font
 | 
			
		||||
Software shall not be used to promote, endorse or advertise any
 | 
			
		||||
Modified Version, except to acknowledge the contribution(s) of the
 | 
			
		||||
Copyright Holder(s) and the Author(s) or with their explicit written
 | 
			
		||||
permission.
 | 
			
		||||
 | 
			
		||||
5) The Font Software, modified or unmodified, in part or in whole,
 | 
			
		||||
must be distributed entirely under this license, and must not be
 | 
			
		||||
distributed under any other license. The requirement for fonts to
 | 
			
		||||
remain under this license does not apply to any document created
 | 
			
		||||
using the Font Software.
 | 
			
		||||
 | 
			
		||||
TERMINATION
 | 
			
		||||
This license becomes null and void if any of the above conditions are
 | 
			
		||||
not met.
 | 
			
		||||
 | 
			
		||||
DISCLAIMER
 | 
			
		||||
THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
 | 
			
		||||
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF
 | 
			
		||||
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT
 | 
			
		||||
OF COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL THE
 | 
			
		||||
COPYRIGHT HOLDER BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
 | 
			
		||||
INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL
 | 
			
		||||
DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
 | 
			
		||||
FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM
 | 
			
		||||
OTHER DEALINGS IN THE FONT SOFTWARE.
 | 
			
		||||
							
								
								
									
										
											BIN
										
									
								
								frontend/src/assets/fonts/nunito-v16-latin-regular.woff2
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								frontend/src/assets/fonts/nunito-v16-latin-regular.woff2
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								frontend/src/assets/images/logo-universal.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								frontend/src/assets/images/logo-universal.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| 
		 After Width: | Height: | Size: 136 KiB  | 
							
								
								
									
										22
									
								
								frontend/src/main.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								frontend/src/main.tsx
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,22 @@
 | 
			
		||||
import React from 'react'
 | 
			
		||||
import {createRoot} from 'react-dom/client'
 | 
			
		||||
import './style.css'
 | 
			
		||||
import { FluentProvider, webLightTheme } from '@fluentui/react-components';
 | 
			
		||||
import {createBrowserRouter,RouterProvider} from "react-router-dom";
 | 
			
		||||
import Home from "./page/home/home";
 | 
			
		||||
import Connection from "./page/connection/connection";
 | 
			
		||||
 | 
			
		||||
const container = document.getElementById('root')
 | 
			
		||||
 | 
			
		||||
const root = createRoot(container!)
 | 
			
		||||
 | 
			
		||||
const router = createBrowserRouter([
 | 
			
		||||
    {path:'/', element: <Home />},
 | 
			
		||||
    {path:'/connection', element: <Connection />},
 | 
			
		||||
])
 | 
			
		||||
 | 
			
		||||
root.render(
 | 
			
		||||
    <FluentProvider theme={webLightTheme}>
 | 
			
		||||
        <RouterProvider router={router} />
 | 
			
		||||
    </FluentProvider>,
 | 
			
		||||
);
 | 
			
		||||
							
								
								
									
										28
									
								
								frontend/src/page/connection/connection.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								frontend/src/page/connection/connection.css
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,28 @@
 | 
			
		||||
div.connection-container {
 | 
			
		||||
    display: flex;
 | 
			
		||||
    height: 100vh;
 | 
			
		||||
    width: 100%;
 | 
			
		||||
    justify-content: center;
 | 
			
		||||
    align-items: center;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
div.connection-form {
 | 
			
		||||
    max-width: 700px;
 | 
			
		||||
    min-width: 500px;
 | 
			
		||||
    height: 100%;
 | 
			
		||||
    display: flex;
 | 
			
		||||
    flex: 1;
 | 
			
		||||
    flex-direction: column;
 | 
			
		||||
    justify-content: center;
 | 
			
		||||
    align-items: center;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
div.connection-form-field {
 | 
			
		||||
    width: 100%;
 | 
			
		||||
    margin-top: 20px;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
div.connection-form-field-actions {
 | 
			
		||||
    display: flex;
 | 
			
		||||
    margin-top: 50px;
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										111
									
								
								frontend/src/page/connection/connection.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										111
									
								
								frontend/src/page/connection/connection.tsx
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,111 @@
 | 
			
		||||
import './connection.css'
 | 
			
		||||
import {
 | 
			
		||||
    useId,
 | 
			
		||||
    Button,
 | 
			
		||||
    FieldProps,
 | 
			
		||||
    useToastController,
 | 
			
		||||
    Toast,
 | 
			
		||||
    ToastTitle,
 | 
			
		||||
    ToastIntent,
 | 
			
		||||
    Toaster
 | 
			
		||||
} from "@fluentui/react-components";
 | 
			
		||||
import {Field, Input} from "@fluentui/react-components";
 | 
			
		||||
import {useNavigate} from "react-router-dom";
 | 
			
		||||
import {useState} from "react";
 | 
			
		||||
import {Dial} from "../../api";
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
const Connection = (props: Partial<FieldProps>) => {
 | 
			
		||||
 | 
			
		||||
    const toasterId = useId("toaster");
 | 
			
		||||
    const {dispatchToast} = useToastController(toasterId);
 | 
			
		||||
    const navigate = useNavigate();
 | 
			
		||||
    const [value, setValue] = useState<{ name: string, endpoint: string, access: string, key: string }>({
 | 
			
		||||
        name: '',
 | 
			
		||||
        endpoint: '',
 | 
			
		||||
        access: '',
 | 
			
		||||
        key: ''
 | 
			
		||||
    })
 | 
			
		||||
 | 
			
		||||
    function test() {
 | 
			
		||||
        const val = JSON.stringify(value);
 | 
			
		||||
        console.log('[DEBUG] connection.test: value =', val)
 | 
			
		||||
        Dial<string>("/api/connection/test", value).then(res => {
 | 
			
		||||
            if (res.status === 200) {
 | 
			
		||||
                dispatchToast(
 | 
			
		||||
                    <Toast>
 | 
			
		||||
                        <ToastTitle>连接成功!</ToastTitle>
 | 
			
		||||
                    </Toast>,
 | 
			
		||||
                    {position: "top-end", intent: "success"}
 | 
			
		||||
                )
 | 
			
		||||
            }
 | 
			
		||||
        })
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    return <div className='connection-container'>
 | 
			
		||||
        <div className='connection-form'>
 | 
			
		||||
            <div className='connection-form-field'>
 | 
			
		||||
                <Field
 | 
			
		||||
                    label="name"
 | 
			
		||||
                    validationState="success"
 | 
			
		||||
                    validationMessage="This is a success message."
 | 
			
		||||
                    {...props}
 | 
			
		||||
                >
 | 
			
		||||
                    <Input placeholder='名称 (example: 测试S3-minio)' value={value.name} onChange={(e) => {
 | 
			
		||||
                        setValue({...value, name: e.target.value});
 | 
			
		||||
                    }}/>
 | 
			
		||||
                </Field>
 | 
			
		||||
            </div>
 | 
			
		||||
            <div className='connection-form-field'>
 | 
			
		||||
                <Field
 | 
			
		||||
                    label="endpoint"
 | 
			
		||||
                    validationState="success"
 | 
			
		||||
                    validationMessage="This is a success message."
 | 
			
		||||
                    {...props}
 | 
			
		||||
                >
 | 
			
		||||
                    <Input placeholder='地址 (example: https://ip_or_server-name:port)' value={value.endpoint}
 | 
			
		||||
                           onChange={(e) => {
 | 
			
		||||
                               setValue({...value, endpoint: e.target.value});
 | 
			
		||||
                           }}/>
 | 
			
		||||
                </Field>
 | 
			
		||||
            </div>
 | 
			
		||||
            <div className='connection-form-field'>
 | 
			
		||||
                <Field
 | 
			
		||||
                    label="secret access"
 | 
			
		||||
                    validationState="success"
 | 
			
		||||
                    validationMessage="This is a success message."
 | 
			
		||||
                    {...props}
 | 
			
		||||
                >
 | 
			
		||||
                    <Input placeholder='' value={value.access} onChange={(e) => {
 | 
			
		||||
                        setValue({...value, access: e.target.value});
 | 
			
		||||
                    }}/>
 | 
			
		||||
                </Field>
 | 
			
		||||
            </div>
 | 
			
		||||
            <div className='connection-form-field'>
 | 
			
		||||
                <Field
 | 
			
		||||
                    label="secret key"
 | 
			
		||||
                    validationState="success"
 | 
			
		||||
                    validationMessage="This is a success message."
 | 
			
		||||
                    {...props}
 | 
			
		||||
                >
 | 
			
		||||
                    <Input placeholder='' value={value.key} onChange={(e) => {
 | 
			
		||||
                        setValue({...value, key: e.target.value});
 | 
			
		||||
                    }}/>
 | 
			
		||||
                </Field>
 | 
			
		||||
            </div>
 | 
			
		||||
            <div className='connection-form-field connection-form-field-actions'>
 | 
			
		||||
                <Button appearance='transparent' onClick={() => test()}>测试连接</Button>
 | 
			
		||||
                <div style={{marginLeft: 'auto'}}>
 | 
			
		||||
                    <Button style={{marginRight: '20px'}} className='connection-form-field-actions-cancel'
 | 
			
		||||
                            onClick={() => {
 | 
			
		||||
                                navigate("/")
 | 
			
		||||
                            }}>取消</Button>
 | 
			
		||||
                    <Button className='connection-form-field-actions-confirm' appearance='primary'>新建</Button>
 | 
			
		||||
                </div>
 | 
			
		||||
            </div>
 | 
			
		||||
        </div>
 | 
			
		||||
        <Toaster toasterId={toasterId}/>
 | 
			
		||||
    </div>
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export default Connection;
 | 
			
		||||
							
								
								
									
										50
									
								
								frontend/src/page/home/home.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								frontend/src/page/home/home.css
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,50 @@
 | 
			
		||||
div.container {
 | 
			
		||||
    height: 100vh;
 | 
			
		||||
    width: 100vw;
 | 
			
		||||
    display: flex;
 | 
			
		||||
    flex-direction: column;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
div.header {
 | 
			
		||||
    height: 50px;
 | 
			
		||||
    border-bottom: 1px solid lightgray;
 | 
			
		||||
    display: flex;
 | 
			
		||||
    align-items: center;
 | 
			
		||||
    padding: 0 8px;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
div.body {
 | 
			
		||||
    display: flex;
 | 
			
		||||
    flex: 1;
 | 
			
		||||
    width: 100%;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
div.body div.body-connections {
 | 
			
		||||
    width: 200px;
 | 
			
		||||
    border-right: 1px solid lightgray;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
div.body-connections-search {
 | 
			
		||||
    display: flex;
 | 
			
		||||
    height: 30px;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
input.body-connections-search-input {
 | 
			
		||||
    border: none;
 | 
			
		||||
    border-bottom: 1px solid lightgray;
 | 
			
		||||
    width: calc(100% - 4px);
 | 
			
		||||
    height: 30px;
 | 
			
		||||
    outline: none;
 | 
			
		||||
    text-indent: 5px;
 | 
			
		||||
}
 | 
			
		||||
div.body-connections-search-dismiss{
 | 
			
		||||
    border: none;
 | 
			
		||||
    background: none;
 | 
			
		||||
    outline: none;
 | 
			
		||||
    border-bottom: 1px solid lightgray;
 | 
			
		||||
    height: 32px;
 | 
			
		||||
    width: 32px;
 | 
			
		||||
    display: flex;
 | 
			
		||||
    justify-content: center;
 | 
			
		||||
    align-items: center;
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										39
									
								
								frontend/src/page/home/home.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								frontend/src/page/home/home.tsx
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,39 @@
 | 
			
		||||
import {useState} from 'react';
 | 
			
		||||
import './home.css';
 | 
			
		||||
import {
 | 
			
		||||
    Button,
 | 
			
		||||
} from "@fluentui/react-components";
 | 
			
		||||
import {
 | 
			
		||||
    CloudAddFilled, DismissRegular
 | 
			
		||||
} from "@fluentui/react-icons";
 | 
			
		||||
import { useNavigate } from "react-router-dom";
 | 
			
		||||
 | 
			
		||||
function Home() {
 | 
			
		||||
    const [connectionFilterKeywords, setConnectionFilterKeywords] = useState<string>('');
 | 
			
		||||
    const navigate = useNavigate();
 | 
			
		||||
 | 
			
		||||
    return (
 | 
			
		||||
        <div className="container">
 | 
			
		||||
            <div className="header">
 | 
			
		||||
                        <Button appearance="primary" icon={<CloudAddFilled  />} onClick={() => {navigate("/connection")}}>
 | 
			
		||||
                            新建连接
 | 
			
		||||
                        </Button>
 | 
			
		||||
            </div>
 | 
			
		||||
            <div className="body">
 | 
			
		||||
                <div className="body-connections">
 | 
			
		||||
                    <div className="body-connections-search">
 | 
			
		||||
                        <input className="body-connections-search-input" type={"text"} placeholder="搜索连接" value={connectionFilterKeywords} onChange={(e) => setConnectionFilterKeywords(e.target.value)} />
 | 
			
		||||
                        <div className="body-connections-search-dismiss" onClick={() => {setConnectionFilterKeywords('')}}>
 | 
			
		||||
                            <DismissRegular />
 | 
			
		||||
                        </div>
 | 
			
		||||
                    </div>
 | 
			
		||||
                    <div className="body-connections-list"></div>
 | 
			
		||||
                </div>
 | 
			
		||||
                <div className="body-content"></div>
 | 
			
		||||
            </div>
 | 
			
		||||
            <div className="footer"></div>
 | 
			
		||||
        </div>
 | 
			
		||||
    )
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export default Home
 | 
			
		||||
							
								
								
									
										18
									
								
								frontend/src/style.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								frontend/src/style.css
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,18 @@
 | 
			
		||||
body {
 | 
			
		||||
    margin: 0;
 | 
			
		||||
    color: white;
 | 
			
		||||
    font-family: "Nunito", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto",
 | 
			
		||||
    "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue",
 | 
			
		||||
    sans-serif;
 | 
			
		||||
    height: 100vh;
 | 
			
		||||
    width: 100vw;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@font-face {
 | 
			
		||||
    font-family: "Nunito";
 | 
			
		||||
    font-style: normal;
 | 
			
		||||
    font-weight: 400;
 | 
			
		||||
    src: local(""),
 | 
			
		||||
    url("assets/fonts/nunito-v16-latin-regular.woff2") format("woff2");
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										1
									
								
								frontend/src/vite-env.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								frontend/src/vite-env.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1 @@
 | 
			
		||||
/// <reference types="vite/client" />
 | 
			
		||||
							
								
								
									
										31
									
								
								frontend/tsconfig.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								frontend/tsconfig.json
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,31 @@
 | 
			
		||||
{
 | 
			
		||||
  "compilerOptions": {
 | 
			
		||||
    "target": "ESNext",
 | 
			
		||||
    "useDefineForClassFields": true,
 | 
			
		||||
    "lib": [
 | 
			
		||||
      "DOM",
 | 
			
		||||
      "DOM.Iterable",
 | 
			
		||||
      "ESNext"
 | 
			
		||||
    ],
 | 
			
		||||
    "allowJs": false,
 | 
			
		||||
    "skipLibCheck": true,
 | 
			
		||||
    "esModuleInterop": false,
 | 
			
		||||
    "allowSyntheticDefaultImports": true,
 | 
			
		||||
    "strict": true,
 | 
			
		||||
    "forceConsistentCasingInFileNames": true,
 | 
			
		||||
    "module": "ESNext",
 | 
			
		||||
    "moduleResolution": "Node",
 | 
			
		||||
    "resolveJsonModule": true,
 | 
			
		||||
    "isolatedModules": true,
 | 
			
		||||
    "noEmit": true,
 | 
			
		||||
    "jsx": "react-jsx"
 | 
			
		||||
  },
 | 
			
		||||
  "include": [
 | 
			
		||||
    "src"
 | 
			
		||||
  ],
 | 
			
		||||
  "references": [
 | 
			
		||||
    {
 | 
			
		||||
      "path": "./tsconfig.node.json"
 | 
			
		||||
    }
 | 
			
		||||
  ]
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										11
									
								
								frontend/tsconfig.node.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								frontend/tsconfig.node.json
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,11 @@
 | 
			
		||||
{
 | 
			
		||||
  "compilerOptions": {
 | 
			
		||||
    "composite": true,
 | 
			
		||||
    "module": "ESNext",
 | 
			
		||||
    "moduleResolution": "Node",
 | 
			
		||||
    "allowSyntheticDefaultImports": true
 | 
			
		||||
  },
 | 
			
		||||
  "include": [
 | 
			
		||||
    "vite.config.ts"
 | 
			
		||||
  ]
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										7
									
								
								frontend/vite.config.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								frontend/vite.config.ts
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,7 @@
 | 
			
		||||
import {defineConfig} from 'vite'
 | 
			
		||||
import react from '@vitejs/plugin-react'
 | 
			
		||||
 | 
			
		||||
// https://vitejs.dev/config/
 | 
			
		||||
export default defineConfig({
 | 
			
		||||
  plugins: [react()]
 | 
			
		||||
})
 | 
			
		||||
							
								
								
									
										4
									
								
								frontend/wailsjs/go/controller/App.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										4
									
								
								frontend/wailsjs/go/controller/App.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,4 @@
 | 
			
		||||
// Cynhyrchwyd y ffeil hon yn awtomatig. PEIDIWCH Â MODIWL
 | 
			
		||||
// This file is automatically generated. DO NOT EDIT
 | 
			
		||||
 | 
			
		||||
export function Invoke(arg1:string,arg2:string):Promise<string>;
 | 
			
		||||
							
								
								
									
										7
									
								
								frontend/wailsjs/go/controller/App.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								frontend/wailsjs/go/controller/App.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,7 @@
 | 
			
		||||
// @ts-check
 | 
			
		||||
// Cynhyrchwyd y ffeil hon yn awtomatig. PEIDIWCH Â MODIWL
 | 
			
		||||
// This file is automatically generated. DO NOT EDIT
 | 
			
		||||
 | 
			
		||||
export function Invoke(arg1, arg2) {
 | 
			
		||||
  return window['go']['controller']['App']['Invoke'](arg1, arg2);
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										24
									
								
								frontend/wailsjs/runtime/package.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								frontend/wailsjs/runtime/package.json
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,24 @@
 | 
			
		||||
{
 | 
			
		||||
  "name": "@wailsapp/runtime",
 | 
			
		||||
  "version": "2.0.0",
 | 
			
		||||
  "description": "Wails Javascript runtime library",
 | 
			
		||||
  "main": "runtime.js",
 | 
			
		||||
  "types": "runtime.d.ts",
 | 
			
		||||
  "scripts": {
 | 
			
		||||
  },
 | 
			
		||||
  "repository": {
 | 
			
		||||
    "type": "git",
 | 
			
		||||
    "url": "git+https://github.com/wailsapp/wails.git"
 | 
			
		||||
  },
 | 
			
		||||
  "keywords": [
 | 
			
		||||
    "Wails",
 | 
			
		||||
    "Javascript",
 | 
			
		||||
    "Go"
 | 
			
		||||
  ],
 | 
			
		||||
  "author": "Lea Anthony <lea.anthony@gmail.com>",
 | 
			
		||||
  "license": "MIT",
 | 
			
		||||
  "bugs": {
 | 
			
		||||
    "url": "https://github.com/wailsapp/wails/issues"
 | 
			
		||||
  },
 | 
			
		||||
  "homepage": "https://github.com/wailsapp/wails#readme"
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										249
									
								
								frontend/wailsjs/runtime/runtime.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										249
									
								
								frontend/wailsjs/runtime/runtime.d.ts
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,249 @@
 | 
			
		||||
/*
 | 
			
		||||
 _       __      _ __
 | 
			
		||||
| |     / /___ _(_) /____
 | 
			
		||||
| | /| / / __ `/ / / ___/
 | 
			
		||||
| |/ |/ / /_/ / / (__  )
 | 
			
		||||
|__/|__/\__,_/_/_/____/
 | 
			
		||||
The electron alternative for Go
 | 
			
		||||
(c) Lea Anthony 2019-present
 | 
			
		||||
*/
 | 
			
		||||
 | 
			
		||||
export interface Position {
 | 
			
		||||
    x: number;
 | 
			
		||||
    y: number;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export interface Size {
 | 
			
		||||
    w: number;
 | 
			
		||||
    h: number;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export interface Screen {
 | 
			
		||||
    isCurrent: boolean;
 | 
			
		||||
    isPrimary: boolean;
 | 
			
		||||
    width : number
 | 
			
		||||
    height : number
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// Environment information such as platform, buildtype, ...
 | 
			
		||||
export interface EnvironmentInfo {
 | 
			
		||||
    buildType: string;
 | 
			
		||||
    platform: string;
 | 
			
		||||
    arch: string;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// [EventsEmit](https://wails.io/docs/reference/runtime/events#eventsemit)
 | 
			
		||||
// emits the given event. Optional data may be passed with the event.
 | 
			
		||||
// This will trigger any event listeners.
 | 
			
		||||
export function EventsEmit(eventName: string, ...data: any): void;
 | 
			
		||||
 | 
			
		||||
// [EventsOn](https://wails.io/docs/reference/runtime/events#eventson) sets up a listener for the given event name.
 | 
			
		||||
export function EventsOn(eventName: string, callback: (...data: any) => void): () => void;
 | 
			
		||||
 | 
			
		||||
// [EventsOnMultiple](https://wails.io/docs/reference/runtime/events#eventsonmultiple)
 | 
			
		||||
// sets up a listener for the given event name, but will only trigger a given number times.
 | 
			
		||||
export function EventsOnMultiple(eventName: string, callback: (...data: any) => void, maxCallbacks: number): () => void;
 | 
			
		||||
 | 
			
		||||
// [EventsOnce](https://wails.io/docs/reference/runtime/events#eventsonce)
 | 
			
		||||
// sets up a listener for the given event name, but will only trigger once.
 | 
			
		||||
export function EventsOnce(eventName: string, callback: (...data: any) => void): () => void;
 | 
			
		||||
 | 
			
		||||
// [EventsOff](https://wails.io/docs/reference/runtime/events#eventsoff)
 | 
			
		||||
// unregisters the listener for the given event name.
 | 
			
		||||
export function EventsOff(eventName: string, ...additionalEventNames: string[]): void;
 | 
			
		||||
 | 
			
		||||
// [EventsOffAll](https://wails.io/docs/reference/runtime/events#eventsoffall)
 | 
			
		||||
// unregisters all listeners.
 | 
			
		||||
export function EventsOffAll(): void;
 | 
			
		||||
 | 
			
		||||
// [LogPrint](https://wails.io/docs/reference/runtime/log#logprint)
 | 
			
		||||
// logs the given message as a raw message
 | 
			
		||||
export function LogPrint(message: string): void;
 | 
			
		||||
 | 
			
		||||
// [LogTrace](https://wails.io/docs/reference/runtime/log#logtrace)
 | 
			
		||||
// logs the given message at the `trace` log level.
 | 
			
		||||
export function LogTrace(message: string): void;
 | 
			
		||||
 | 
			
		||||
// [LogDebug](https://wails.io/docs/reference/runtime/log#logdebug)
 | 
			
		||||
// logs the given message at the `debug` log level.
 | 
			
		||||
export function LogDebug(message: string): void;
 | 
			
		||||
 | 
			
		||||
// [LogError](https://wails.io/docs/reference/runtime/log#logerror)
 | 
			
		||||
// logs the given message at the `error` log level.
 | 
			
		||||
export function LogError(message: string): void;
 | 
			
		||||
 | 
			
		||||
// [LogFatal](https://wails.io/docs/reference/runtime/log#logfatal)
 | 
			
		||||
// logs the given message at the `fatal` log level.
 | 
			
		||||
// The application will quit after calling this method.
 | 
			
		||||
export function LogFatal(message: string): void;
 | 
			
		||||
 | 
			
		||||
// [LogInfo](https://wails.io/docs/reference/runtime/log#loginfo)
 | 
			
		||||
// logs the given message at the `info` log level.
 | 
			
		||||
export function LogInfo(message: string): void;
 | 
			
		||||
 | 
			
		||||
// [LogWarning](https://wails.io/docs/reference/runtime/log#logwarning)
 | 
			
		||||
// logs the given message at the `warning` log level.
 | 
			
		||||
export function LogWarning(message: string): void;
 | 
			
		||||
 | 
			
		||||
// [WindowReload](https://wails.io/docs/reference/runtime/window#windowreload)
 | 
			
		||||
// Forces a reload by the main application as well as connected browsers.
 | 
			
		||||
export function WindowReload(): void;
 | 
			
		||||
 | 
			
		||||
// [WindowReloadApp](https://wails.io/docs/reference/runtime/window#windowreloadapp)
 | 
			
		||||
// Reloads the application frontend.
 | 
			
		||||
export function WindowReloadApp(): void;
 | 
			
		||||
 | 
			
		||||
// [WindowSetAlwaysOnTop](https://wails.io/docs/reference/runtime/window#windowsetalwaysontop)
 | 
			
		||||
// Sets the window AlwaysOnTop or not on top.
 | 
			
		||||
export function WindowSetAlwaysOnTop(b: boolean): void;
 | 
			
		||||
 | 
			
		||||
// [WindowSetSystemDefaultTheme](https://wails.io/docs/next/reference/runtime/window#windowsetsystemdefaulttheme)
 | 
			
		||||
// *Windows only*
 | 
			
		||||
// Sets window theme to system default (dark/light).
 | 
			
		||||
export function WindowSetSystemDefaultTheme(): void;
 | 
			
		||||
 | 
			
		||||
// [WindowSetLightTheme](https://wails.io/docs/next/reference/runtime/window#windowsetlighttheme)
 | 
			
		||||
// *Windows only*
 | 
			
		||||
// Sets window to light theme.
 | 
			
		||||
export function WindowSetLightTheme(): void;
 | 
			
		||||
 | 
			
		||||
// [WindowSetDarkTheme](https://wails.io/docs/next/reference/runtime/window#windowsetdarktheme)
 | 
			
		||||
// *Windows only*
 | 
			
		||||
// Sets window to dark theme.
 | 
			
		||||
export function WindowSetDarkTheme(): void;
 | 
			
		||||
 | 
			
		||||
// [WindowCenter](https://wails.io/docs/reference/runtime/window#windowcenter)
 | 
			
		||||
// Centers the window on the monitor the window is currently on.
 | 
			
		||||
export function WindowCenter(): void;
 | 
			
		||||
 | 
			
		||||
// [WindowSetTitle](https://wails.io/docs/reference/runtime/window#windowsettitle)
 | 
			
		||||
// Sets the text in the window title bar.
 | 
			
		||||
export function WindowSetTitle(title: string): void;
 | 
			
		||||
 | 
			
		||||
// [WindowFullscreen](https://wails.io/docs/reference/runtime/window#windowfullscreen)
 | 
			
		||||
// Makes the window full screen.
 | 
			
		||||
export function WindowFullscreen(): void;
 | 
			
		||||
 | 
			
		||||
// [WindowUnfullscreen](https://wails.io/docs/reference/runtime/window#windowunfullscreen)
 | 
			
		||||
// Restores the previous window dimensions and position prior to full screen.
 | 
			
		||||
export function WindowUnfullscreen(): void;
 | 
			
		||||
 | 
			
		||||
// [WindowIsFullscreen](https://wails.io/docs/reference/runtime/window#windowisfullscreen)
 | 
			
		||||
// Returns the state of the window, i.e. whether the window is in full screen mode or not.
 | 
			
		||||
export function WindowIsFullscreen(): Promise<boolean>;
 | 
			
		||||
 | 
			
		||||
// [WindowSetSize](https://wails.io/docs/reference/runtime/window#windowsetsize)
 | 
			
		||||
// Sets the width and height of the window.
 | 
			
		||||
export function WindowSetSize(width: number, height: number): Promise<Size>;
 | 
			
		||||
 | 
			
		||||
// [WindowGetSize](https://wails.io/docs/reference/runtime/window#windowgetsize)
 | 
			
		||||
// Gets the width and height of the window.
 | 
			
		||||
export function WindowGetSize(): Promise<Size>;
 | 
			
		||||
 | 
			
		||||
// [WindowSetMaxSize](https://wails.io/docs/reference/runtime/window#windowsetmaxsize)
 | 
			
		||||
// Sets the maximum window size. Will resize the window if the window is currently larger than the given dimensions.
 | 
			
		||||
// Setting a size of 0,0 will disable this constraint.
 | 
			
		||||
export function WindowSetMaxSize(width: number, height: number): void;
 | 
			
		||||
 | 
			
		||||
// [WindowSetMinSize](https://wails.io/docs/reference/runtime/window#windowsetminsize)
 | 
			
		||||
// Sets the minimum window size. Will resize the window if the window is currently smaller than the given dimensions.
 | 
			
		||||
// Setting a size of 0,0 will disable this constraint.
 | 
			
		||||
export function WindowSetMinSize(width: number, height: number): void;
 | 
			
		||||
 | 
			
		||||
// [WindowSetPosition](https://wails.io/docs/reference/runtime/window#windowsetposition)
 | 
			
		||||
// Sets the window position relative to the monitor the window is currently on.
 | 
			
		||||
export function WindowSetPosition(x: number, y: number): void;
 | 
			
		||||
 | 
			
		||||
// [WindowGetPosition](https://wails.io/docs/reference/runtime/window#windowgetposition)
 | 
			
		||||
// Gets the window position relative to the monitor the window is currently on.
 | 
			
		||||
export function WindowGetPosition(): Promise<Position>;
 | 
			
		||||
 | 
			
		||||
// [WindowHide](https://wails.io/docs/reference/runtime/window#windowhide)
 | 
			
		||||
// Hides the window.
 | 
			
		||||
export function WindowHide(): void;
 | 
			
		||||
 | 
			
		||||
// [WindowShow](https://wails.io/docs/reference/runtime/window#windowshow)
 | 
			
		||||
// Shows the window, if it is currently hidden.
 | 
			
		||||
export function WindowShow(): void;
 | 
			
		||||
 | 
			
		||||
// [WindowMaximise](https://wails.io/docs/reference/runtime/window#windowmaximise)
 | 
			
		||||
// Maximises the window to fill the screen.
 | 
			
		||||
export function WindowMaximise(): void;
 | 
			
		||||
 | 
			
		||||
// [WindowToggleMaximise](https://wails.io/docs/reference/runtime/window#windowtogglemaximise)
 | 
			
		||||
// Toggles between Maximised and UnMaximised.
 | 
			
		||||
export function WindowToggleMaximise(): void;
 | 
			
		||||
 | 
			
		||||
// [WindowUnmaximise](https://wails.io/docs/reference/runtime/window#windowunmaximise)
 | 
			
		||||
// Restores the window to the dimensions and position prior to maximising.
 | 
			
		||||
export function WindowUnmaximise(): void;
 | 
			
		||||
 | 
			
		||||
// [WindowIsMaximised](https://wails.io/docs/reference/runtime/window#windowismaximised)
 | 
			
		||||
// Returns the state of the window, i.e. whether the window is maximised or not.
 | 
			
		||||
export function WindowIsMaximised(): Promise<boolean>;
 | 
			
		||||
 | 
			
		||||
// [WindowMinimise](https://wails.io/docs/reference/runtime/window#windowminimise)
 | 
			
		||||
// Minimises the window.
 | 
			
		||||
export function WindowMinimise(): void;
 | 
			
		||||
 | 
			
		||||
// [WindowUnminimise](https://wails.io/docs/reference/runtime/window#windowunminimise)
 | 
			
		||||
// Restores the window to the dimensions and position prior to minimising.
 | 
			
		||||
export function WindowUnminimise(): void;
 | 
			
		||||
 | 
			
		||||
// [WindowIsMinimised](https://wails.io/docs/reference/runtime/window#windowisminimised)
 | 
			
		||||
// Returns the state of the window, i.e. whether the window is minimised or not.
 | 
			
		||||
export function WindowIsMinimised(): Promise<boolean>;
 | 
			
		||||
 | 
			
		||||
// [WindowIsNormal](https://wails.io/docs/reference/runtime/window#windowisnormal)
 | 
			
		||||
// Returns the state of the window, i.e. whether the window is normal or not.
 | 
			
		||||
export function WindowIsNormal(): Promise<boolean>;
 | 
			
		||||
 | 
			
		||||
// [WindowSetBackgroundColour](https://wails.io/docs/reference/runtime/window#windowsetbackgroundcolour)
 | 
			
		||||
// Sets the background colour of the window to the given RGBA colour definition. This colour will show through for all transparent pixels.
 | 
			
		||||
export function WindowSetBackgroundColour(R: number, G: number, B: number, A: number): void;
 | 
			
		||||
 | 
			
		||||
// [ScreenGetAll](https://wails.io/docs/reference/runtime/window#screengetall)
 | 
			
		||||
// Gets the all screens. Call this anew each time you want to refresh data from the underlying windowing system.
 | 
			
		||||
export function ScreenGetAll(): Promise<Screen[]>;
 | 
			
		||||
 | 
			
		||||
// [BrowserOpenURL](https://wails.io/docs/reference/runtime/browser#browseropenurl)
 | 
			
		||||
// Opens the given URL in the system browser.
 | 
			
		||||
export function BrowserOpenURL(url: string): void;
 | 
			
		||||
 | 
			
		||||
// [Environment](https://wails.io/docs/reference/runtime/intro#environment)
 | 
			
		||||
// Returns information about the environment
 | 
			
		||||
export function Environment(): Promise<EnvironmentInfo>;
 | 
			
		||||
 | 
			
		||||
// [Quit](https://wails.io/docs/reference/runtime/intro#quit)
 | 
			
		||||
// Quits the application.
 | 
			
		||||
export function Quit(): void;
 | 
			
		||||
 | 
			
		||||
// [Hide](https://wails.io/docs/reference/runtime/intro#hide)
 | 
			
		||||
// Hides the application.
 | 
			
		||||
export function Hide(): void;
 | 
			
		||||
 | 
			
		||||
// [Show](https://wails.io/docs/reference/runtime/intro#show)
 | 
			
		||||
// Shows the application.
 | 
			
		||||
export function Show(): void;
 | 
			
		||||
 | 
			
		||||
// [ClipboardGetText](https://wails.io/docs/reference/runtime/clipboard#clipboardgettext)
 | 
			
		||||
// Returns the current text stored on clipboard
 | 
			
		||||
export function ClipboardGetText(): Promise<string>;
 | 
			
		||||
 | 
			
		||||
// [ClipboardSetText](https://wails.io/docs/reference/runtime/clipboard#clipboardsettext)
 | 
			
		||||
// Sets a text on the clipboard
 | 
			
		||||
export function ClipboardSetText(text: string): Promise<boolean>;
 | 
			
		||||
 | 
			
		||||
// [OnFileDrop](https://wails.io/docs/reference/runtime/draganddrop#onfiledrop)
 | 
			
		||||
// OnFileDrop listens to drag and drop events and calls the callback with the coordinates of the drop and an array of path strings.
 | 
			
		||||
export function OnFileDrop(callback: (x: number, y: number ,paths: string[]) => void, useDropTarget: boolean) :void
 | 
			
		||||
 | 
			
		||||
// [OnFileDropOff](https://wails.io/docs/reference/runtime/draganddrop#dragandddropoff)
 | 
			
		||||
// OnFileDropOff removes the drag and drop listeners and handlers.
 | 
			
		||||
export function OnFileDropOff() :void
 | 
			
		||||
 | 
			
		||||
// Check if the file path resolver is available
 | 
			
		||||
export function CanResolveFilePaths(): boolean;
 | 
			
		||||
 | 
			
		||||
// Resolves file paths for an array of files
 | 
			
		||||
export function ResolveFilePaths(files: File[]): void
 | 
			
		||||
							
								
								
									
										238
									
								
								frontend/wailsjs/runtime/runtime.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										238
									
								
								frontend/wailsjs/runtime/runtime.js
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,238 @@
 | 
			
		||||
/*
 | 
			
		||||
 _       __      _ __
 | 
			
		||||
| |     / /___ _(_) /____
 | 
			
		||||
| | /| / / __ `/ / / ___/
 | 
			
		||||
| |/ |/ / /_/ / / (__  )
 | 
			
		||||
|__/|__/\__,_/_/_/____/
 | 
			
		||||
The electron alternative for Go
 | 
			
		||||
(c) Lea Anthony 2019-present
 | 
			
		||||
*/
 | 
			
		||||
 | 
			
		||||
export function LogPrint(message) {
 | 
			
		||||
    window.runtime.LogPrint(message);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function LogTrace(message) {
 | 
			
		||||
    window.runtime.LogTrace(message);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function LogDebug(message) {
 | 
			
		||||
    window.runtime.LogDebug(message);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function LogInfo(message) {
 | 
			
		||||
    window.runtime.LogInfo(message);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function LogWarning(message) {
 | 
			
		||||
    window.runtime.LogWarning(message);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function LogError(message) {
 | 
			
		||||
    window.runtime.LogError(message);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function LogFatal(message) {
 | 
			
		||||
    window.runtime.LogFatal(message);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function EventsOnMultiple(eventName, callback, maxCallbacks) {
 | 
			
		||||
    return window.runtime.EventsOnMultiple(eventName, callback, maxCallbacks);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function EventsOn(eventName, callback) {
 | 
			
		||||
    return EventsOnMultiple(eventName, callback, -1);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function EventsOff(eventName, ...additionalEventNames) {
 | 
			
		||||
    return window.runtime.EventsOff(eventName, ...additionalEventNames);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function EventsOnce(eventName, callback) {
 | 
			
		||||
    return EventsOnMultiple(eventName, callback, 1);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function EventsEmit(eventName) {
 | 
			
		||||
    let args = [eventName].slice.call(arguments);
 | 
			
		||||
    return window.runtime.EventsEmit.apply(null, args);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowReload() {
 | 
			
		||||
    window.runtime.WindowReload();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowReloadApp() {
 | 
			
		||||
    window.runtime.WindowReloadApp();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowSetAlwaysOnTop(b) {
 | 
			
		||||
    window.runtime.WindowSetAlwaysOnTop(b);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowSetSystemDefaultTheme() {
 | 
			
		||||
    window.runtime.WindowSetSystemDefaultTheme();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowSetLightTheme() {
 | 
			
		||||
    window.runtime.WindowSetLightTheme();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowSetDarkTheme() {
 | 
			
		||||
    window.runtime.WindowSetDarkTheme();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowCenter() {
 | 
			
		||||
    window.runtime.WindowCenter();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowSetTitle(title) {
 | 
			
		||||
    window.runtime.WindowSetTitle(title);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowFullscreen() {
 | 
			
		||||
    window.runtime.WindowFullscreen();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowUnfullscreen() {
 | 
			
		||||
    window.runtime.WindowUnfullscreen();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowIsFullscreen() {
 | 
			
		||||
    return window.runtime.WindowIsFullscreen();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowGetSize() {
 | 
			
		||||
    return window.runtime.WindowGetSize();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowSetSize(width, height) {
 | 
			
		||||
    window.runtime.WindowSetSize(width, height);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowSetMaxSize(width, height) {
 | 
			
		||||
    window.runtime.WindowSetMaxSize(width, height);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowSetMinSize(width, height) {
 | 
			
		||||
    window.runtime.WindowSetMinSize(width, height);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowSetPosition(x, y) {
 | 
			
		||||
    window.runtime.WindowSetPosition(x, y);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowGetPosition() {
 | 
			
		||||
    return window.runtime.WindowGetPosition();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowHide() {
 | 
			
		||||
    window.runtime.WindowHide();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowShow() {
 | 
			
		||||
    window.runtime.WindowShow();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowMaximise() {
 | 
			
		||||
    window.runtime.WindowMaximise();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowToggleMaximise() {
 | 
			
		||||
    window.runtime.WindowToggleMaximise();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowUnmaximise() {
 | 
			
		||||
    window.runtime.WindowUnmaximise();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowIsMaximised() {
 | 
			
		||||
    return window.runtime.WindowIsMaximised();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowMinimise() {
 | 
			
		||||
    window.runtime.WindowMinimise();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowUnminimise() {
 | 
			
		||||
    window.runtime.WindowUnminimise();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowSetBackgroundColour(R, G, B, A) {
 | 
			
		||||
    window.runtime.WindowSetBackgroundColour(R, G, B, A);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function ScreenGetAll() {
 | 
			
		||||
    return window.runtime.ScreenGetAll();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowIsMinimised() {
 | 
			
		||||
    return window.runtime.WindowIsMinimised();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function WindowIsNormal() {
 | 
			
		||||
    return window.runtime.WindowIsNormal();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function BrowserOpenURL(url) {
 | 
			
		||||
    window.runtime.BrowserOpenURL(url);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function Environment() {
 | 
			
		||||
    return window.runtime.Environment();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function Quit() {
 | 
			
		||||
    window.runtime.Quit();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function Hide() {
 | 
			
		||||
    window.runtime.Hide();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function Show() {
 | 
			
		||||
    window.runtime.Show();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function ClipboardGetText() {
 | 
			
		||||
    return window.runtime.ClipboardGetText();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function ClipboardSetText(text) {
 | 
			
		||||
    return window.runtime.ClipboardSetText(text);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Callback for OnFileDrop returns a slice of file path strings when a drop is finished.
 | 
			
		||||
 *
 | 
			
		||||
 * @export
 | 
			
		||||
 * @callback OnFileDropCallback
 | 
			
		||||
 * @param {number} x - x coordinate of the drop
 | 
			
		||||
 * @param {number} y - y coordinate of the drop
 | 
			
		||||
 * @param {string[]} paths - A list of file paths.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * OnFileDrop listens to drag and drop events and calls the callback with the coordinates of the drop and an array of path strings.
 | 
			
		||||
 *
 | 
			
		||||
 * @export
 | 
			
		||||
 * @param {OnFileDropCallback} callback - Callback for OnFileDrop returns a slice of file path strings when a drop is finished.
 | 
			
		||||
 * @param {boolean} [useDropTarget=true] - Only call the callback when the drop finished on an element that has the drop target style. (--wails-drop-target)
 | 
			
		||||
 */
 | 
			
		||||
export function OnFileDrop(callback, useDropTarget) {
 | 
			
		||||
    return window.runtime.OnFileDrop(callback, useDropTarget);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * OnFileDropOff removes the drag and drop listeners and handlers.
 | 
			
		||||
 */
 | 
			
		||||
export function OnFileDropOff() {
 | 
			
		||||
    return window.runtime.OnFileDropOff();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function CanResolveFilePaths() {
 | 
			
		||||
    return window.runtime.CanResolveFilePaths();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export function ResolveFilePaths(files) {
 | 
			
		||||
    return window.runtime.ResolveFilePaths(files);
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user