Skip to content

Commit

Permalink
Add history ability to url plugin
Browse files Browse the repository at this point in the history
  • Loading branch information
qianlifeng committed Oct 16, 2024
1 parent 709e0c6 commit 36fb49f
Show file tree
Hide file tree
Showing 3 changed files with 149 additions and 14 deletions.
9 changes: 8 additions & 1 deletion Wox/plugin/image.go
Original file line number Diff line number Diff line change
Expand Up @@ -149,7 +149,7 @@ func (w *WoxImage) Hash() string {
return util.Md5([]byte(w.ImageType + w.ImageData))
}

func (w *WoxImage) Overlay(overlay WoxImage, size int, x, y int) WoxImage {
func (w *WoxImage) Overlay(overlay WoxImage, sizePercent, xPercent, yPercent float64) WoxImage {
backgroundImg, backErr := w.ToImage()
if backErr != nil {
return *w
Expand All @@ -160,6 +160,13 @@ func (w *WoxImage) Overlay(overlay WoxImage, size int, x, y int) WoxImage {
return *w
}

bgWidth := backgroundImg.Bounds().Dx()
bgHeight := backgroundImg.Bounds().Dy()

size := int(float64(bgWidth) * sizePercent)
x := int(float64(bgWidth) * xPercent)
y := int(float64(bgHeight) * yPercent)

resizedOverlayImg := imaging.Resize(overlayImage, size, size, imaging.Lanczos)
finalImg := imaging.Overlay(backgroundImg, resizedOverlayImg, image.Pt(x, y), 1)
overlayWoxImg, overlayWoxImgErr := NewWoxImage(finalImg)
Expand Down
15 changes: 10 additions & 5 deletions Wox/plugin/system/browser.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,16 +5,17 @@ import (
"encoding/json"
"errors"
"fmt"
"github.com/olahol/melody"
"github.com/rs/cors"
"github.com/samber/lo"
"net/http"
"strconv"
"strings"
"wox/plugin"
"wox/setting/definition"
"wox/setting/validator"
"wox/util"

"github.com/olahol/melody"
"github.com/rs/cors"
"github.com/samber/lo"
)

var browserIcon = plugin.NewWoxImageBase64(``)
Expand Down Expand Up @@ -141,7 +142,7 @@ func (c *BrowserPlugin) Query(ctx context.Context, query plugin.Query) (results

icon := chromeIcon
if tabIcon, err := getWebsiteIconWithCache(ctx, tab.Url); err == nil {
icon = chromeIcon.Overlay(tabIcon, 16, 30, 30)
icon = chromeIcon.Overlay(tabIcon, 0.4, 0.6, 0.6)
}

results = append(results, plugin.QueryResult{
Expand Down Expand Up @@ -256,8 +257,12 @@ func (c *BrowserPlugin) onUpdateTabs(ctx context.Context, data string) {
plugin.GetPluginManager().SetActiveBrowserUrl(activeTab.Url)
}

//remove duplicate tabs
uniqueTabs := lo.UniqBy(tabs, func(tab browserTab) string {
return tab.Url
})
// filter invalid tabs
c.openedTabs = lo.Filter(tabs, func(tab browserTab, _ int) bool {
c.openedTabs = lo.Filter(uniqueTabs, func(tab browserTab, _ int) bool {
return tab.Url != ""
})

Expand Down
139 changes: 131 additions & 8 deletions Wox/plugin/system/url.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,21 +2,32 @@ package system

import (
"context"
"encoding/json"
"fmt"
"regexp"
"strings"
"wox/plugin"
"wox/util"

"github.com/samber/lo"
)

var urlIcon = plugin.NewWoxImageSvg(`<svg t="1700799478746" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="6302" width="200" height="200"><path d="M102.4 205.687467v612.625066A103.424 103.424 0 0 0 205.994667 921.6h611.908266a103.424 103.424 0 0 0 103.594667-103.287467V205.687467A103.424 103.424 0 0 0 817.902933 102.4H205.994667A103.424 103.424 0 0 0 102.4 205.687467z m476.023467 423.594666l-106.2912 106.2912c-26.282667 26.180267-62.634667 42.154667-99.089067 42.154667a125.610667 125.610667 0 0 1-88.814933-36.352c-26.180267-26.180267-39.355733-61.1328-36.386134-96.119467 1.501867-34.952533 16.008533-67.037867 42.2912-93.184l42.257067-42.257066a34.304 34.304 0 0 1 48.0256 0 34.304 34.304 0 0 1 0 48.0256l-42.257067 42.257066c-13.073067 13.1072-21.845333 30.583467-21.845333 48.059734 0 11.707733 1.467733 29.184 15.9744 43.690666 13.073067 13.073067 29.149867 15.9744 40.7552 15.9744 17.476267 0 36.352-8.704 50.926933-21.879466l106.325334-106.325334c26.146133-26.146133 29.149867-67.003733 5.802666-90.282666a34.304 34.304 0 0 1 0-48.059734 34.304 34.304 0 0 1 48.0256 0c24.7808 24.7808 36.386133 55.330133 36.386134 88.814934 0.068267 35.054933-14.404267 71.509333-42.0864 99.191466z m198.007466-251.938133c-1.501867 34.952533-15.9744 67.037867-42.257066 93.184l-14.472534 14.506667-27.648 29.149866a34.304 34.304 0 0 1-48.093866 0c-14.574933-13.073067-15.9744-34.952533-2.901334-48.0256l43.690667-43.690666c13.073067-13.073067 21.845333-29.149867 23.2448-46.523734 0-11.707733-1.467733-29.184-15.9744-43.690666-13.073067-13.073067-29.149867-15.9744-40.7552-15.9744a73.045333 73.045333 0 0 0-50.961067 21.879466l-106.3936 106.120534c-26.180267 26.146133-29.149867 67.037867-5.802666 90.282666a34.304 34.304 0 0 1 0 48.059734 34.304 34.304 0 0 1-48.0256 0c-24.7808-24.7808-36.386133-55.330133-36.386134-88.814934 0-34.952533 14.609067-71.338667 42.257067-98.986666l106.325333-106.2912c26.146133-26.180267 62.634667-42.257067 98.986667-42.257067 33.450667 0 65.536 13.073067 88.814933 36.352a127.010133 127.010133 0 0 1 36.352 94.72z" fill="#1296db" p-id="6303"></path></svg>`)
var urlIcon = plugin.NewWoxImageBase64(``)

func init() {
plugin.AllSystemPlugin = append(plugin.AllSystemPlugin, &UrlPlugin{})
}

type UrlHistory struct {
Url string
Icon plugin.WoxImage
Title string
}

type UrlPlugin struct {
api plugin.API
reg *regexp.Regexp
api plugin.API
reg *regexp.Regexp
recentUrls []UrlHistory
}

func (r *UrlPlugin) GetMetadata() plugin.Metadata {
Expand Down Expand Up @@ -46,6 +57,23 @@ func (r *UrlPlugin) GetMetadata() plugin.Metadata {
func (r *UrlPlugin) Init(ctx context.Context, initParams plugin.InitParams) {
r.api = initParams.API
r.reg = r.getReg()
r.recentUrls = r.loadRecentUrls(ctx)
}

func (r *UrlPlugin) loadRecentUrls(ctx context.Context) []UrlHistory {
urlsJson := r.api.GetSetting(ctx, "recentUrls")
if urlsJson == "" {
return []UrlHistory{}
}

var urls []UrlHistory
err := json.Unmarshal([]byte(urlsJson), &urls)
if err != nil {
r.api.Log(ctx, plugin.LogLevelError, fmt.Sprintf("load recent urls error: %s", err.Error()))
return []UrlHistory{}
}

return urls
}

func (r *UrlPlugin) getReg() *regexp.Regexp {
Expand All @@ -54,20 +82,61 @@ func (r *UrlPlugin) getReg() *regexp.Regexp {
}

func (r *UrlPlugin) Query(ctx context.Context, query plugin.Query) (results []plugin.QueryResult) {
//check if search is in recentUrls
if len(query.Search) >= 2 {
existingUrlHistory := lo.Filter(r.recentUrls, func(item UrlHistory, index int) bool {
return strings.Contains(item.Url, query.Search)
})

for _, history := range existingUrlHistory {
results = append(results, plugin.QueryResult{
Title: history.Url,
SubTitle: history.Title,
Score: 100,
Icon: history.Icon.Overlay(urlIcon, 0.4, 0.6, 0.6),
Actions: []plugin.QueryResultAction{
{
Name: "Open",
Action: func(ctx context.Context, actionContext plugin.ActionContext) {
openErr := util.ShellOpen(history.Url)
if openErr != nil {
r.api.Log(ctx, "Error opening URL", openErr.Error())
}
},
},
{
Name: "Remove from url history",
Action: func(ctx context.Context, actionContext plugin.ActionContext) {
r.removeRecentUrl(ctx, history.Url)
},
},
},
})
}
}

if len(r.reg.FindStringIndex(query.Search)) > 0 {
results = append(results, plugin.QueryResult{
Title: query.Search,
SubTitle: "Open in browser",
SubTitle: "Open in Browser",
Score: 100,
Icon: urlIcon,
Actions: []plugin.QueryResultAction{
{
Name: "Open in browser",
Name: "Open",
Action: func(ctx context.Context, actionContext plugin.ActionContext) {
if strings.HasPrefix(query.Search, "http") == false {
query.Search = "https://" + query.Search
url := query.Search
if !strings.HasPrefix(url, "http") {
url = "https://" + url
}
openErr := util.ShellOpen(url)
if openErr != nil {
r.api.Log(ctx, "Error opening URL", openErr.Error())
} else {
util.Go(ctx, "saveRecentUrl", func() {
r.saveRecentUrl(ctx, url)
})
}
util.ShellOpen(query.Search)
},
},
},
Expand All @@ -76,3 +145,57 @@ func (r *UrlPlugin) Query(ctx context.Context, query plugin.Query) (results []pl

return
}

func (r *UrlPlugin) saveRecentUrl(ctx context.Context, url string) {
icon, err := getWebsiteIconWithCache(ctx, url)
if err != nil {
r.api.Log(ctx, plugin.LogLevelError, fmt.Sprintf("get url icon error: %s", err.Error()))
icon = urlIcon
}

title := ""
body, err := util.HttpGet(ctx, url)
if err == nil {
titleStart := strings.Index(string(body), "<title>")
titleEnd := strings.Index(string(body), "</title>")
if titleStart != -1 && titleEnd != -1 {
title = string(body[titleStart+7 : titleEnd])
}
} else {
r.api.Log(ctx, plugin.LogLevelError, fmt.Sprintf("get url title error: %s", err.Error()))
}

newHistory := UrlHistory{
Url: url,
Icon: icon,
Title: title,
}

// remove duplicate urls
r.recentUrls = lo.Filter(r.recentUrls, func(item UrlHistory, index int) bool {
return item.Url != url
})
r.recentUrls = append([]UrlHistory{newHistory}, r.recentUrls...)

urlsJson, err := json.Marshal(r.recentUrls)
if err != nil {
r.api.Log(ctx, plugin.LogLevelError, fmt.Sprintf("save url setting error: %s", err.Error()))
return
}

r.api.SaveSetting(ctx, "recentUrls", string(urlsJson), false)
}

func (r *UrlPlugin) removeRecentUrl(ctx context.Context, url string) {
r.recentUrls = lo.Filter(r.recentUrls, func(item UrlHistory, index int) bool {
return item.Url != url
})

urlsJson, err := json.Marshal(r.recentUrls)
if err != nil {
r.api.Log(ctx, plugin.LogLevelError, fmt.Sprintf("save url setting error: %s", err.Error()))
return
}

r.api.SaveSetting(ctx, "recentUrls", string(urlsJson), false)
}

0 comments on commit 36fb49f

Please sign in to comment.