Skip to content

Commit

Permalink
version 0.8.0
Browse files Browse the repository at this point in the history
Much work has been done to improve usability, overall perception of the product, usability and speed

* optimized UI code
* new color scheme based on [Nord Theme](https://www.nordtheme.com/)
* support control via an icon in the taskbar on Mac OS
* many other changes, big and small :)
  • Loading branch information
NightMan-1 committed Jun 23, 2019
1 parent ede83f7 commit 249286d
Show file tree
Hide file tree
Showing 41 changed files with 4,814 additions and 3,944 deletions.
14 changes: 8 additions & 6 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,17 +8,19 @@ All data stored in Quiver like format (http://happenapps.com/)

GoLang server + VueJS frontend

More info here - https://qvnote.fsky.info/

![Screenshot eng](screenshot_eng.png)

## Project request

GoLang >1.10
GoLang >1.10
NodeJS >10.x

## Project setup

Download
Unzip archive
Download
Unzip archive
_(you also need install git command line program for download the source)_

```
Expand Down Expand Up @@ -70,12 +72,12 @@ now you can run QVNote binary and open http://localhost:8000 in your browser

## GUI development

run server (QVNote.exe)
npm run serve
run server (QVNote.exe)
npm run serve
open http://localhost:8080

## Command line parameters:
--help
--help
usage info
--port=8000
listen port
Expand Down
3 changes: 3 additions & 0 deletions global.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import (
"fmt"
"math/rand"
"os"
"os/exec"
"path/filepath"
"runtime"
"time"
Expand Down Expand Up @@ -144,6 +145,8 @@ type FilesForIndexType struct {

var FilesForIndex = []FilesForIndexType{}

var systrayProcess *exec.Cmd

func BytesToString(data []byte) string {
return string(data[:])
}
Expand Down
29 changes: 15 additions & 14 deletions package.json
Original file line number Diff line number Diff line change
@@ -1,20 +1,19 @@
{
"name": "qvnote",
"version": "0.7.0",
"version": "0.8.0",
"private": true,
"scripts": {
"serve": "vue-cli-service serve",
"build": "vue-cli-service build",
"lint": "vue-cli-service lint"
},
"dependencies": {
"@coreui/coreui": "^2.1.9",
"css-loader": "^2.1.1",
"bootstrap": "^4.3.1",
"css-loader": "^3.0.0",
"cxlt-vue2-toastr": "^1.1.0",
"echarts": "^4.2.1",
"glob-all": "^3.1.0",
"js-beautify": "^1.10.0",
"lodash": "^4.17.11",
"postcss-import": "^12.0.1",
"postcss-loader": "^3.0.0",
"postcss-url": "^8.0.0",
Expand All @@ -23,33 +22,31 @@
"quill-image-drop-module": "^1.0.3",
"quill-image-resize-module": "^3.0.0",
"quill-magic-url": "^1.0.2",
"simplebar-vue": "^0.1.6",
"tingle.js": "^0.13.2",
"tingle.js": "0.13.2",
"v-charts": "^1.19.0",
"vue": "^2.6.10",
"vue-calendar-heatmap": "^0.8.4",
"vue-headful": "^2.0.1",
"vue-i18n": "^8.11.2",
"vue-ls": "^3.2.1",
"vue-multiselect": "^2.1.6",
"vue-prism-editor": "^0.1.2",
"vue-prism-editor": "^0.2.1",
"vue-quill-editor": "^3.0.6",
"vue-resource": "^1.5.1",
"vue-router": "^3.0.6",
"vuex": "^3.1.1"
},
"devDependencies": {
"@fortawesome/fontawesome-free": "^5.8.2",
"@vue/cli-plugin-babel": "^3.7.0",
"@vue/cli-plugin-eslint": "^3.7.0",
"@vue/cli-service": "^3.7.0",
"@fortawesome/fontawesome-free": "^5.9.0",
"@vue/cli-plugin-babel": "^3.8.0",
"@vue/cli-plugin-eslint": "^3.8.0",
"@vue/cli-service": "^3.8.4",
"@vue/eslint-config-standard": "^4.0.0",
"babel-eslint": "^10.0.1",
"babel-eslint": "^10.0.2",
"eslint": "^5.16.0",
"eslint-plugin-vue": "^5.2.2",
"node-sass": "^4.12.0",
"sass-loader": "^7.0.1",
"terser-webpack-plugin": "^1.2.3",
"terser-webpack-plugin": "^1.3.0",
"vue-template-compiler": "^2.6.10"
},
"eslintConfig": {
Expand All @@ -62,6 +59,10 @@
"@vue/standard"
],
"rules": {
"indent": [
"error",
4
],
"no-tabs": 0,
"no-mixed-spaces-and-tabs": 0,
"new-cap": 0,
Expand Down
69 changes: 63 additions & 6 deletions platform_darwin.go
Original file line number Diff line number Diff line change
Expand Up @@ -3,20 +3,21 @@
package main

import (
"bytes"
"fmt"
"net/http"
"os"
"os/exec"

"github.com/gen2brain/beeep"
"github.com/gen2brain/dlgs"
"github.com/getlantern/systray"
)

var osWithGUI = true

func openBrowser(url string) error {
var cmd string
var args []string
cmd = "open"
args = append(args, url)
return exec.Command(cmd, args...).Start()
return exec.Command("open", url).Start()
}

func showNotification(message_text string, message_type string) {
Expand All @@ -32,6 +33,62 @@ func showNotification(message_text string, message_type string) {
}
}

func initPlatformSpecific() {
func onReadySysTray() {
iconData, _ := Asset("icon.ico")

systray.SetIcon(iconData)
//systray.SetTitle("QVNote")

mBrowser := systray.AddMenuItem("Open browser", "open default browser with this app page")
mRelod := systray.AddMenuItem("Reload notes", "may be slow")
mQuit := systray.AddMenuItem("Quit", "Quit the whole app")

for {
select {
case <-mBrowser.ClickedCh:
openBrowser("http://localhost:8000/")
case <-mRelod.ClickedCh:
url := "http://localhost:8000/api/refresh_data.json"
var jsonStr = []byte(`{"action":"reload"}`)
req, err := http.NewRequest("POST", url, bytes.NewBuffer(jsonStr))
req.Header.Set("Content-Type", "application/json")
client := &http.Client{}
resp, err := client.Do(req)
if err != nil {
panic(err)
}
resp.Body.Close()
case <-mQuit.ClickedCh:
systray.Quit()
beeep.Notify("QVNote", "Good buy!", "")
fmt.Println("Good buy!")
}
}
}

func runSystray() {
systray.Run(onReadySysTray, onExitSysTray)
}

func onExitSysTray() {
// clean up here
client := http.Client{}
client.Get("http://localhost:8000/api/exit")
os.Exit(0)
}

func initPlatformSpecific() error {
cwd, err := os.Getwd()
if err != nil {
return err
}
systrayProcess = exec.Command(os.Args[0], "--systray")
systrayProcess.Dir = cwd
err = systrayProcess.Start()
if err != nil {
return err
}
//systrayProcess.Process.Kill()
//systrayProcess.Process.Release()
return nil
}
2 changes: 2 additions & 0 deletions platform_linux.go
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,8 @@ func openBrowser(url string) error {
func showNotification(message_text string, message_type string) {
//do nothing
}
func runSystray() {
}

func initPlatformSpecific() {
configGlobal.atStartOpenBrowser = false
Expand Down
75 changes: 43 additions & 32 deletions platform_windows.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,10 @@ package main

import (
"fmt"
"io/ioutil"
"os"
"os/exec"
"runtime"

"github.com/gen2brain/beeep"
"github.com/gen2brain/dlgs"
Expand Down Expand Up @@ -37,7 +39,17 @@ func showNotification(message_text string, message_type string) {
case "dialog_warning":
dlgs.Warning("QVNote error!", message_text)
case "notify":
beeep.Notify("QVNote", message_text, "")
if runtime.GOOS == string("windows") {
var tmpIcon *os.File
iconData, _ := Asset("icon.ico")
tmpIcon, _ = ioutil.TempFile("", "icon.*.ico")
tmpIcon.Write(iconData)
tmpIcon.Close()
beeep.Notify("QVNote", message_text, tmpIcon.Name())
os.Remove(tmpIcon.Name())
} else {
beeep.Notify("QVNote", message_text, "") // icon not work on MacOS
}

}
}
Expand Down Expand Up @@ -70,55 +82,54 @@ func onReadySysTray() {
systray.SetTitle("QVNote")

mBrowser := systray.AddMenuItem("Open browser", "open default browser with this app page")
go func() {
<-mBrowser.ClickedCh
go openBrowser("http://localhost:8000/")
}()
mRelod := systray.AddMenuItem("Reload notes", "may be slow")
mShowConsoleHide := systray.AddMenuItem("Hide console", "debug")
mShowConsoleShow := systray.AddMenuItem("Show console", "debug")
mQuit := systray.AddMenuItem("Quit", "Quit the whole app")

if consolePresent {
mShowConsoleHide := systray.AddMenuItem("Hide console", "debug")
mShowConsoleShow := systray.AddMenuItem("Show console", "debug")
go func() {
<-mShowConsoleHide.ClickedCh
if consoleWindowsVisible {
mShowConsoleShow.Hide()
} else {
mShowConsoleHide.Hide()
}
} else {
mShowConsoleShow.Hide()
mShowConsoleHide.Hide()
}

for {
select {
case <-mShowConsoleHide.ClickedCh:
consoleHide()
mShowConsoleHide.Hide()
mShowConsoleShow.Show()
}()
go func() {
<-mShowConsoleShow.ClickedCh
case <-mShowConsoleShow.ClickedCh:
consoleShow()
mShowConsoleShow.Hide()
mShowConsoleHide.Show()
}()
if consoleWindowsVisible {
mShowConsoleShow.Hide()
} else {
mShowConsoleHide.Hide()
case <-mBrowser.ClickedCh:
openBrowser("http://localhost:" + configGlobal.cmdPort + "/")
case <-mRelod.ClickedCh:
FindAllNotes()
beeep.Notify("QVNote", "All data reloaded", "")
case <-mQuit.ClickedCh:
systray.Quit()
beeep.Notify("QVNote", "Good buy!", "")
fmt.Println("Good buy!")
}
}

mRelod := systray.AddMenuItem("Reload notes", "may be slow")
go func() {
<-mRelod.ClickedCh
FindAllNotes()
beeep.Notify("QVNote", "All data reloaded", "")
}()

mQuit := systray.AddMenuItem("Quit", "Quit the whole app")
go func() {
<-mQuit.ClickedCh
systray.Quit()
beeep.Notify("QVNote", "Good buy!", "")
fmt.Println("Good buy!")
}()

}

func onExitSysTray() {
// clean up here
os.Exit(0)
}

func runSystray() {
}

func initPlatformSpecific() {
if configGlobal.cmdServerMode {
return
Expand Down
6 changes: 3 additions & 3 deletions public/index.html
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,9 @@
<html>
<head>
<meta charset="utf-8">
<link href=""
rel="shortcut icon" type="image/svg"/>
<meta name="viewport" content="width=device-width,initial-scale=1.0">
<link href=""
rel="shortcut icon" type="image/png"/>
<meta name="viewport" content="width=device-width,initial-scale=1.0,shrink-to-fit=no">
<title>QVNote</title>
<meta name="description"/>
<meta name="keywords"/>
Expand Down
Loading

0 comments on commit 249286d

Please sign in to comment.