Finishing up gui
This commit is contained in:
@@ -0,0 +1,308 @@
|
|||||||
|
package main
|
||||||
|
|
||||||
|
import (
|
||||||
|
"os"
|
||||||
|
"os/exec"
|
||||||
|
"strings"
|
||||||
|
|
||||||
|
"github.com/gotk3/gotk3/gdk"
|
||||||
|
"github.com/gotk3/gotk3/gtk"
|
||||||
|
)
|
||||||
|
|
||||||
|
type app struct {
|
||||||
|
name string
|
||||||
|
cat string
|
||||||
|
appimg []string
|
||||||
|
lin []string
|
||||||
|
ex []string
|
||||||
|
icon *gdk.Pixbuf
|
||||||
|
dir string
|
||||||
|
ini *os.File
|
||||||
|
}
|
||||||
|
|
||||||
|
func (a *app) getTreeIter(store *gtk.TreeStore) *gtk.TreeIter {
|
||||||
|
it := store.Append(nil)
|
||||||
|
store.SetValue(it, 0, a.icon)
|
||||||
|
store.SetValue(it, 1, a.name)
|
||||||
|
if len(a.ex) > 1 {
|
||||||
|
for _, v := range a.ex {
|
||||||
|
i := store.Append(it)
|
||||||
|
store.SetValue(i, 1, v)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return it
|
||||||
|
}
|
||||||
|
|
||||||
|
func (a *app) launch() {
|
||||||
|
if len(a.ex) == 1 {
|
||||||
|
if wine {
|
||||||
|
var cmd *exec.Cmd
|
||||||
|
if !contains(a.lin, a.ex[0]) {
|
||||||
|
cmd = exec.Command("/bin/sh", "-c", "cd \""+a.dir+"\"; wine \""+a.ex[0]+"\"")
|
||||||
|
} else {
|
||||||
|
if comEnbld {
|
||||||
|
cmd = exec.Command("/bin/sh", "-c", ". PortableApps/LinuxPACom/common.sh || exit 1;cd \""+a.dir+"\"; \"./"+a.ex[0]+"\"")
|
||||||
|
} else {
|
||||||
|
cmd = exec.Command("/bin/sh", "-c", "cd \""+a.dir+"\"; \"./"+a.ex[0]+"\"")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
cmd.Stdout = os.Stdout
|
||||||
|
cmd.Stderr = os.Stderr
|
||||||
|
cmd.Start()
|
||||||
|
} else {
|
||||||
|
var cmd *exec.Cmd
|
||||||
|
if comEnbld {
|
||||||
|
cmd = exec.Command("/bin/sh", "-c", ". PortableApps/LinuxPACom/common.sh || exit 1;cd \""+a.dir+"\"; \"./"+a.ex[0]+"\"")
|
||||||
|
} else {
|
||||||
|
cmd = exec.Command("/bin/sh", "-c", "cd \""+a.dir+"\"; \"./"+a.ex[0]+"\"")
|
||||||
|
}
|
||||||
|
cmd.Stdout = os.Stdout
|
||||||
|
cmd.Stderr = os.Stderr
|
||||||
|
cmd.Start()
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if wine {
|
||||||
|
var cmd *exec.Cmd
|
||||||
|
if len(a.lin) == 0 {
|
||||||
|
cmd = exec.Command("/bin/sh", "-c", "cd \""+a.dir+"\"; wine \""+a.ex[0]+"\"")
|
||||||
|
} else {
|
||||||
|
var ind int
|
||||||
|
for i, v := range a.lin {
|
||||||
|
if strings.HasSuffix(v, ".sh") {
|
||||||
|
ind = i
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if comEnbld {
|
||||||
|
cmd = exec.Command("/bin/sh", "-c", ". PortableApps/LinuxPACom/common.sh || exit 1;cd \""+a.dir+"\"; \"./"+a.lin[ind]+"\"")
|
||||||
|
} else {
|
||||||
|
cmd = exec.Command("/bin/sh", "-c", "cd \""+a.dir+"\"; \"./"+a.lin[ind]+"\"")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
cmd.Stdout = os.Stdout
|
||||||
|
cmd.Stderr = os.Stderr
|
||||||
|
cmd.Start()
|
||||||
|
} else {
|
||||||
|
if len(a.lin) != 0 {
|
||||||
|
var ind int
|
||||||
|
for i, v := range a.lin {
|
||||||
|
if strings.HasSuffix(v, ".sh") {
|
||||||
|
ind = i
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
var cmd *exec.Cmd
|
||||||
|
if comEnbld {
|
||||||
|
cmd = exec.Command("/bin/sh", "-c", ". PortableApps/LinuxPACom/common.sh || exit 1;cd \""+a.dir+"\"; \"./"+a.lin[ind]+"\"")
|
||||||
|
} else {
|
||||||
|
cmd = exec.Command("/bin/sh", "-c", "cd \""+a.dir+"\"; \"./"+a.lin[ind]+"\"")
|
||||||
|
}
|
||||||
|
cmd.Stdout = os.Stdout
|
||||||
|
cmd.Stderr = os.Stderr
|
||||||
|
cmd.Start()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (a *app) launchSub(sub int) {
|
||||||
|
if wine {
|
||||||
|
var cmd *exec.Cmd
|
||||||
|
if !contains(a.lin, a.ex[sub]) {
|
||||||
|
cmd = exec.Command("/bin/sh", "-c", "cd \""+a.dir+"\"; wine \""+a.ex[sub]+"\"")
|
||||||
|
} else {
|
||||||
|
if comEnbld {
|
||||||
|
cmd = exec.Command("/bin/sh", "-c", ". PortableApps/LinuxPACom/common.sh || exit 1;cd \""+a.dir+"\"; \"./"+a.ex[sub]+"\"")
|
||||||
|
} else {
|
||||||
|
cmd = exec.Command("/bin/sh", "-c", "cd \""+a.dir+"\"; \"./"+a.ex[sub]+"\"")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
cmd.Stdout = os.Stdout
|
||||||
|
cmd.Stderr = os.Stderr
|
||||||
|
cmd.Start()
|
||||||
|
}
|
||||||
|
var cmd *exec.Cmd
|
||||||
|
if comEnbld {
|
||||||
|
cmd = exec.Command("/bin/sh", "-c", ". PortableApps/LinuxPACom/common.sh || exit 1;cd \""+a.dir+"\"; \"./"+a.ex[sub]+"\"")
|
||||||
|
} else {
|
||||||
|
cmd = exec.Command("/bin/sh", "-c", "cd \""+a.dir+"\"; \"./"+a.ex[sub]+"\"")
|
||||||
|
}
|
||||||
|
cmd.Stdout = os.Stdout
|
||||||
|
cmd.Stderr = os.Stderr
|
||||||
|
cmd.Start()
|
||||||
|
}
|
||||||
|
|
||||||
|
// type appExNode struct {
|
||||||
|
// ap app
|
||||||
|
// exInd int
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// func (a *appExNode) launch() {
|
||||||
|
// if wine {
|
||||||
|
// var cmd *exec.Cmd
|
||||||
|
// if !contains(a.ap.lin, a.ap.ex[a.exInd]) {
|
||||||
|
// cmd = exec.Command("/bin/sh", "-c", "cd \""+a.ap.dir+"\"; wine \""+a.ap.ex[a.exInd]+"\"")
|
||||||
|
// } else {
|
||||||
|
// if comEnbld {
|
||||||
|
// cmd = exec.Command("/bin/sh", "-c", ". PortableApps/LinuxPACom/common.sh || exit 1;cd \""+a.ap.dir+"\"; \"./"+a.ap.ex[a.exInd]+"\"")
|
||||||
|
// } else {
|
||||||
|
// cmd = exec.Command("/bin/sh", "-c", "cd \""+a.ap.dir+"\"; \"./"+a.ap.ex[a.exInd]+"\"")
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// cmd.Stdout = os.Stdout
|
||||||
|
// cmd.Stderr = os.Stderr
|
||||||
|
// cmd.Start()
|
||||||
|
// }
|
||||||
|
// var cmd *exec.Cmd
|
||||||
|
// if comEnbld {
|
||||||
|
// cmd = exec.Command("/bin/sh", "-c", ". PortableApps/LinuxPACom/common.sh || exit 1;cd \""+a.ap.dir+"\"; \"./"+a.ap.ex[a.exInd]+"\"")
|
||||||
|
// } else {
|
||||||
|
// cmd = exec.Command("/bin/sh", "-c", "cd \""+a.ap.dir+"\"; \"./"+a.ap.ex[a.exInd]+"\"")
|
||||||
|
// }
|
||||||
|
// cmd.Stdout = os.Stdout
|
||||||
|
// cmd.Stderr = os.Stderr
|
||||||
|
// cmd.Start()
|
||||||
|
// }
|
||||||
|
|
||||||
|
// func (a *appExNode) Count() int {
|
||||||
|
// return 0
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// func (a *appExNode) NodeAt(int) gxui.TreeNode {
|
||||||
|
// return nil
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// func (a *appExNode) ItemIndex(gxui.AdapterItem) int {
|
||||||
|
// return -1
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// func (a *appExNode) Item() gxui.AdapterItem {
|
||||||
|
// if wine {
|
||||||
|
// return a.ap.ex[a.exInd]
|
||||||
|
// }
|
||||||
|
// return a.ap.lin[a.exInd]
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// func (a *appExNode) Create(the gxui.Theme) gxui.Control {
|
||||||
|
// box := the.CreateLinearLayout()
|
||||||
|
// box.SetDirection(gxui.LeftToRight)
|
||||||
|
// box.SetVerticalAlignment(gxui.AlignMiddle)
|
||||||
|
// img := the.CreateImage()
|
||||||
|
// img.SetTexture(a.ap.icon)
|
||||||
|
// img.SetExplicitSize(math.Size{H: 32, W: 32})
|
||||||
|
// lbl := the.CreateLabel()
|
||||||
|
// lbl.SetText(a.ap.ex[a.exInd])
|
||||||
|
// box.AddChild(img)
|
||||||
|
// box.AddChild(lbl)
|
||||||
|
// box.OnDoubleClick(func(gxui.MouseEvent) {
|
||||||
|
// a.launch()
|
||||||
|
// })
|
||||||
|
// return box
|
||||||
|
// }
|
||||||
|
|
||||||
|
// func (a *appNode) Count() int {
|
||||||
|
// if wine {
|
||||||
|
// if len(a.ex) > 1 {
|
||||||
|
// return len(a.ap.ex)
|
||||||
|
// }
|
||||||
|
// return 0
|
||||||
|
// }
|
||||||
|
// if len(a.ap.lin) > 1 {
|
||||||
|
// return len(a.ap.lin)
|
||||||
|
// }
|
||||||
|
// return 0
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// func (a *appNode) NodeAt(i int) gxui.TreeNode {
|
||||||
|
// return &appExNode{ap: a.ap, exInd: i}
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// func (a *appNode) ItemIndex(item gxui.AdapterItem) int {
|
||||||
|
// if wine {
|
||||||
|
// for i, v := range a.ap.ex {
|
||||||
|
// if v == item {
|
||||||
|
// return i
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// } else {
|
||||||
|
// for i, v := range a.ap.lin {
|
||||||
|
// if v == item {
|
||||||
|
// return i
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// return -1
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// func (a *appNode) Item() gxui.AdapterItem {
|
||||||
|
// return a.ap.name
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// func (a *appNode) Create(the gxui.Theme) gxui.Control {
|
||||||
|
// box := the.CreateLinearLayout()
|
||||||
|
// box.SetDirection(gxui.LeftToRight)
|
||||||
|
// box.SetPadding(math.CreateSpacing(2))
|
||||||
|
// box.SetVerticalAlignment(gxui.AlignMiddle)
|
||||||
|
// img := the.CreateImage()
|
||||||
|
// if a.ap.icon != nil {
|
||||||
|
// img.SetTexture(a.ap.icon)
|
||||||
|
// }
|
||||||
|
// img.SetExplicitSize(math.Size{H: 32, W: 32})
|
||||||
|
// lbl := the.CreateLabel()
|
||||||
|
// lbl.SetText(a.ap.name)
|
||||||
|
// box.AddChild(img)
|
||||||
|
// box.AddChild(lbl)
|
||||||
|
// box.OnDoubleClick(func(gxui.MouseEvent) {
|
||||||
|
// a.launch()
|
||||||
|
// })
|
||||||
|
// return box
|
||||||
|
// }
|
||||||
|
|
||||||
|
// type catAdap struct {
|
||||||
|
// gxui.AdapterBase
|
||||||
|
// cat string
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// func (a *catAdap) setCat(cat string) {
|
||||||
|
// a.cat = cat
|
||||||
|
// a.DataChanged(false)
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// func (a *catAdap) refresh() {
|
||||||
|
// a.DataChanged(false)
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// func (a *catAdap) Count() int {
|
||||||
|
// if wine {
|
||||||
|
// return len(master[a.cat])
|
||||||
|
// }
|
||||||
|
// return len(linmaster[a.cat])
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// func (a *catAdap) NodeAt(i int) gxui.TreeNode {
|
||||||
|
// if wine {
|
||||||
|
// return &appNode{ap: master[a.cat][i]}
|
||||||
|
// }
|
||||||
|
// return &appNode{ap: linmaster[a.cat][i]}
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// func (a *catAdap) Size(gxui.Theme) math.Size {
|
||||||
|
// return math.Size{H: 34, W: math.MaxSize.W}
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// func (a *catAdap) ItemIndex(item gxui.AdapterItem) int {
|
||||||
|
// if wine {
|
||||||
|
// for i, v := range master[a.cat] {
|
||||||
|
// if v.name == item {
|
||||||
|
// return i
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// } else {
|
||||||
|
// for i, v := range linmaster[a.cat] {
|
||||||
|
// if v.name == item {
|
||||||
|
// return i
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
// return -1
|
||||||
|
// }
|
||||||
-272
@@ -1,272 +0,0 @@
|
|||||||
package main
|
|
||||||
|
|
||||||
import (
|
|
||||||
"os"
|
|
||||||
"os/exec"
|
|
||||||
"strings"
|
|
||||||
|
|
||||||
"github.com/nelsam/gxui"
|
|
||||||
"github.com/nelsam/gxui/math"
|
|
||||||
)
|
|
||||||
|
|
||||||
type app struct {
|
|
||||||
name string
|
|
||||||
cat string
|
|
||||||
appimg []string
|
|
||||||
lin []string
|
|
||||||
ex []string
|
|
||||||
icon gxui.Texture
|
|
||||||
dir string
|
|
||||||
ini *os.File
|
|
||||||
}
|
|
||||||
|
|
||||||
type appExNode struct {
|
|
||||||
ap app
|
|
||||||
exInd int
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *appExNode) launch() {
|
|
||||||
if wine {
|
|
||||||
var cmd *exec.Cmd
|
|
||||||
if !contains(a.ap.lin, a.ap.ex[a.exInd]) {
|
|
||||||
cmd = exec.Command("/bin/sh", "-c", "cd \""+a.ap.dir+"\"; wine \""+a.ap.ex[a.exInd]+"\"")
|
|
||||||
} else {
|
|
||||||
if comEnbld {
|
|
||||||
cmd = exec.Command("/bin/sh", "-c", ". PortableApps/LinuxPACom/common.sh || exit 1;cd \""+a.ap.dir+"\"; \"./"+a.ap.ex[a.exInd]+"\"")
|
|
||||||
} else {
|
|
||||||
cmd = exec.Command("/bin/sh", "-c", "cd \""+a.ap.dir+"\"; \"./"+a.ap.ex[a.exInd]+"\"")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
cmd.Stdout = os.Stdout
|
|
||||||
cmd.Stderr = os.Stderr
|
|
||||||
cmd.Start()
|
|
||||||
}
|
|
||||||
var cmd *exec.Cmd
|
|
||||||
if comEnbld {
|
|
||||||
cmd = exec.Command("/bin/sh", "-c", ". PortableApps/LinuxPACom/common.sh || exit 1;cd \""+a.ap.dir+"\"; \"./"+a.ap.ex[a.exInd]+"\"")
|
|
||||||
} else {
|
|
||||||
cmd = exec.Command("/bin/sh", "-c", "cd \""+a.ap.dir+"\"; \"./"+a.ap.ex[a.exInd]+"\"")
|
|
||||||
}
|
|
||||||
cmd.Stdout = os.Stdout
|
|
||||||
cmd.Stderr = os.Stderr
|
|
||||||
cmd.Start()
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *appExNode) Count() int {
|
|
||||||
return 0
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *appExNode) NodeAt(int) gxui.TreeNode {
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *appExNode) ItemIndex(gxui.AdapterItem) int {
|
|
||||||
return -1
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *appExNode) Item() gxui.AdapterItem {
|
|
||||||
if wine {
|
|
||||||
return a.ap.ex[a.exInd]
|
|
||||||
}
|
|
||||||
return a.ap.lin[a.exInd]
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *appExNode) Create(the gxui.Theme) gxui.Control {
|
|
||||||
box := the.CreateLinearLayout()
|
|
||||||
box.SetDirection(gxui.LeftToRight)
|
|
||||||
box.SetVerticalAlignment(gxui.AlignMiddle)
|
|
||||||
img := the.CreateImage()
|
|
||||||
img.SetTexture(a.ap.icon)
|
|
||||||
img.SetExplicitSize(math.Size{H: 32, W: 32})
|
|
||||||
lbl := the.CreateLabel()
|
|
||||||
lbl.SetText(a.ap.ex[a.exInd])
|
|
||||||
box.AddChild(img)
|
|
||||||
box.AddChild(lbl)
|
|
||||||
box.OnDoubleClick(func(gxui.MouseEvent) {
|
|
||||||
a.launch()
|
|
||||||
})
|
|
||||||
return box
|
|
||||||
}
|
|
||||||
|
|
||||||
type appNode struct {
|
|
||||||
ap app
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *appNode) launch() {
|
|
||||||
if len(a.ap.ex) == 1 {
|
|
||||||
if wine {
|
|
||||||
var cmd *exec.Cmd
|
|
||||||
if !contains(a.ap.lin, a.ap.ex[0]) {
|
|
||||||
cmd = exec.Command("/bin/sh", "-c", "cd \""+a.ap.dir+"\"; wine \""+a.ap.ex[0]+"\"")
|
|
||||||
} else {
|
|
||||||
if comEnbld {
|
|
||||||
cmd = exec.Command("/bin/sh", "-c", ". PortableApps/LinuxPACom/common.sh || exit 1;cd \""+a.ap.dir+"\"; \"./"+a.ap.ex[0]+"\"")
|
|
||||||
} else {
|
|
||||||
cmd = exec.Command("/bin/sh", "-c", "cd \""+a.ap.dir+"\"; \"./"+a.ap.ex[0]+"\"")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
cmd.Stdout = os.Stdout
|
|
||||||
cmd.Stderr = os.Stderr
|
|
||||||
cmd.Start()
|
|
||||||
} else {
|
|
||||||
var cmd *exec.Cmd
|
|
||||||
if comEnbld {
|
|
||||||
cmd = exec.Command("/bin/sh", "-c", ". PortableApps/LinuxPACom/common.sh || exit 1;cd \""+a.ap.dir+"\"; \"./"+a.ap.ex[0]+"\"")
|
|
||||||
} else {
|
|
||||||
cmd = exec.Command("/bin/sh", "-c", "cd \""+a.ap.dir+"\"; \"./"+a.ap.ex[0]+"\"")
|
|
||||||
}
|
|
||||||
cmd.Stdout = os.Stdout
|
|
||||||
cmd.Stderr = os.Stderr
|
|
||||||
cmd.Start()
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if wine {
|
|
||||||
var cmd *exec.Cmd
|
|
||||||
if len(a.ap.lin) == 0 {
|
|
||||||
cmd = exec.Command("/bin/sh", "-c", "cd \""+a.ap.dir+"\"; wine \""+a.ap.ex[0]+"\"")
|
|
||||||
} else {
|
|
||||||
var ind int
|
|
||||||
for i, v := range a.ap.lin {
|
|
||||||
if strings.HasSuffix(v, ".sh") {
|
|
||||||
ind = i
|
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if comEnbld {
|
|
||||||
cmd = exec.Command("/bin/sh", "-c", ". PortableApps/LinuxPACom/common.sh || exit 1;cd \""+a.ap.dir+"\"; \"./"+a.ap.lin[ind]+"\"")
|
|
||||||
} else {
|
|
||||||
cmd = exec.Command("/bin/sh", "-c", "cd \""+a.ap.dir+"\"; \"./"+a.ap.lin[ind]+"\"")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
cmd.Stdout = os.Stdout
|
|
||||||
cmd.Stderr = os.Stderr
|
|
||||||
cmd.Start()
|
|
||||||
} else {
|
|
||||||
if len(a.ap.lin) != 0 {
|
|
||||||
var ind int
|
|
||||||
for i, v := range a.ap.lin {
|
|
||||||
if strings.HasSuffix(v, ".sh") {
|
|
||||||
ind = i
|
|
||||||
break
|
|
||||||
}
|
|
||||||
}
|
|
||||||
var cmd *exec.Cmd
|
|
||||||
if comEnbld {
|
|
||||||
cmd = exec.Command("/bin/sh", "-c", ". PortableApps/LinuxPACom/common.sh || exit 1;cd \""+a.ap.dir+"\"; \"./"+a.ap.lin[ind]+"\"")
|
|
||||||
} else {
|
|
||||||
cmd = exec.Command("/bin/sh", "-c", "cd \""+a.ap.dir+"\"; \"./"+a.ap.lin[ind]+"\"")
|
|
||||||
}
|
|
||||||
cmd.Stdout = os.Stdout
|
|
||||||
cmd.Stderr = os.Stderr
|
|
||||||
cmd.Start()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *appNode) Count() int {
|
|
||||||
if wine {
|
|
||||||
if len(a.ap.ex) > 1 {
|
|
||||||
return len(a.ap.ex)
|
|
||||||
}
|
|
||||||
return 0
|
|
||||||
}
|
|
||||||
if len(a.ap.lin) > 1 {
|
|
||||||
return len(a.ap.lin)
|
|
||||||
}
|
|
||||||
return 0
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *appNode) NodeAt(i int) gxui.TreeNode {
|
|
||||||
return &appExNode{ap: a.ap, exInd: i}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *appNode) ItemIndex(item gxui.AdapterItem) int {
|
|
||||||
if wine {
|
|
||||||
for i, v := range a.ap.ex {
|
|
||||||
if v == item {
|
|
||||||
return i
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
for i, v := range a.ap.lin {
|
|
||||||
if v == item {
|
|
||||||
return i
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return -1
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *appNode) Item() gxui.AdapterItem {
|
|
||||||
return a.ap.name
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *appNode) Create(the gxui.Theme) gxui.Control {
|
|
||||||
box := the.CreateLinearLayout()
|
|
||||||
box.SetDirection(gxui.LeftToRight)
|
|
||||||
box.SetPadding(math.CreateSpacing(2))
|
|
||||||
box.SetVerticalAlignment(gxui.AlignMiddle)
|
|
||||||
img := the.CreateImage()
|
|
||||||
if a.ap.icon != nil {
|
|
||||||
img.SetTexture(a.ap.icon)
|
|
||||||
}
|
|
||||||
img.SetExplicitSize(math.Size{H: 32, W: 32})
|
|
||||||
lbl := the.CreateLabel()
|
|
||||||
lbl.SetText(a.ap.name)
|
|
||||||
box.AddChild(img)
|
|
||||||
box.AddChild(lbl)
|
|
||||||
box.OnDoubleClick(func(gxui.MouseEvent) {
|
|
||||||
a.launch()
|
|
||||||
})
|
|
||||||
return box
|
|
||||||
}
|
|
||||||
|
|
||||||
type catAdap struct {
|
|
||||||
gxui.AdapterBase
|
|
||||||
cat string
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *catAdap) setCat(cat string) {
|
|
||||||
a.cat = cat
|
|
||||||
a.DataChanged(false)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *catAdap) refresh() {
|
|
||||||
a.DataChanged(false)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *catAdap) Count() int {
|
|
||||||
if wine {
|
|
||||||
return len(master[a.cat])
|
|
||||||
}
|
|
||||||
return len(linmaster[a.cat])
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *catAdap) NodeAt(i int) gxui.TreeNode {
|
|
||||||
if wine {
|
|
||||||
return &appNode{ap: master[a.cat][i]}
|
|
||||||
}
|
|
||||||
return &appNode{ap: linmaster[a.cat][i]}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *catAdap) Size(gxui.Theme) math.Size {
|
|
||||||
return math.Size{H: 34, W: math.MaxSize.W}
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *catAdap) ItemIndex(item gxui.AdapterItem) int {
|
|
||||||
if wine {
|
|
||||||
for i, v := range master[a.cat] {
|
|
||||||
if v.name == item {
|
|
||||||
return i
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
for i, v := range linmaster[a.cat] {
|
|
||||||
if v.name == item {
|
|
||||||
return i
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return -1
|
|
||||||
}
|
|
||||||
@@ -3,19 +3,16 @@ package main
|
|||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"os"
|
"os"
|
||||||
"os/exec"
|
|
||||||
|
|
||||||
"github.com/gotk3/gotk3/gtk"
|
"github.com/gotk3/gotk3/gtk"
|
||||||
"github.com/nelsam/gxui"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
version = "2.0.0.0"
|
version = "2.0.0.1"
|
||||||
|
defIni = ""
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
dr gxui.Driver
|
|
||||||
th gxui.Theme
|
|
||||||
master map[string][]app
|
master map[string][]app
|
||||||
linmaster map[string][]app
|
linmaster map[string][]app
|
||||||
cats []string
|
cats []string
|
||||||
@@ -26,39 +23,15 @@ var (
|
|||||||
)
|
)
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
updated := false
|
|
||||||
os.MkdirAll("PortableApps/LinuxPACom", 0777)
|
os.MkdirAll("PortableApps/LinuxPACom", 0777)
|
||||||
stat, err := versionDL()
|
master = make(map[string][]app)
|
||||||
if stat {
|
linmaster = make(map[string][]app)
|
||||||
res := getVersionFileInfo()
|
|
||||||
if res != "Error!" {
|
|
||||||
stat, err = checkForUpdate(res)
|
|
||||||
if stat {
|
|
||||||
downloadUpdate(res)
|
|
||||||
updated = true
|
|
||||||
} else {
|
|
||||||
fmt.Println(err)
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
fmt.Println("Failed Version File Info")
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
fmt.Println(err)
|
|
||||||
}
|
|
||||||
if updated {
|
|
||||||
cmd := exec.Command("./LinuxPA")
|
|
||||||
cmd.Stdin = os.Stdin
|
|
||||||
cmd.Stdout = os.Stdout
|
|
||||||
cmd.Start()
|
|
||||||
} else {
|
|
||||||
// master = make(map[string][]app)
|
|
||||||
// linmaster = make(map[string][]app)
|
|
||||||
uiStart()
|
uiStart()
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
func uiStart() {
|
func uiStart() {
|
||||||
gtk.Init(nil)
|
gtk.Init(nil)
|
||||||
|
setup()
|
||||||
win, err := gtk.WindowNew(gtk.WINDOW_TOPLEVEL)
|
win, err := gtk.WindowNew(gtk.WINDOW_TOPLEVEL)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Println("Window not created", err)
|
fmt.Println("Window not created", err)
|
||||||
@@ -68,22 +41,14 @@ func uiStart() {
|
|||||||
gtk.MainQuit()
|
gtk.MainQuit()
|
||||||
})
|
})
|
||||||
win.SetDefaultSize(500, 500)
|
win.SetDefaultSize(500, 500)
|
||||||
|
win.SetPosition(gtk.WIN_POS_CENTER)
|
||||||
ui(win)
|
ui(win)
|
||||||
|
win.ShowAll()
|
||||||
|
win.Show()
|
||||||
|
update(win)
|
||||||
gtk.Main()
|
gtk.Main()
|
||||||
}
|
}
|
||||||
|
|
||||||
// func appMain(dri gxui.Driver) {
|
|
||||||
// dr = dri
|
|
||||||
// setup()
|
|
||||||
// if darkTheme {
|
|
||||||
// th = dark.CreateTheme(dr)
|
|
||||||
// } else {
|
|
||||||
// th = light.CreateTheme(dr)
|
|
||||||
// }
|
|
||||||
// th = dark.CreateTheme(dr)
|
|
||||||
// ui()
|
|
||||||
// }
|
|
||||||
|
|
||||||
func contains(arr []string, str string) bool {
|
func contains(arr []string, str string) bool {
|
||||||
for _, v := range arr {
|
for _, v := range arr {
|
||||||
if v == str {
|
if v == str {
|
||||||
|
|||||||
@@ -3,15 +3,14 @@ package main
|
|||||||
import (
|
import (
|
||||||
"bufio"
|
"bufio"
|
||||||
"fmt"
|
"fmt"
|
||||||
"image"
|
|
||||||
"image/draw"
|
|
||||||
_ "image/png"
|
_ "image/png"
|
||||||
"os"
|
"os"
|
||||||
"reflect"
|
"reflect"
|
||||||
"sort"
|
"sort"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/nelsam/gxui"
|
"github.com/gotk3/gotk3/gdk"
|
||||||
|
"github.com/gotk3/gotk3/gtk"
|
||||||
)
|
)
|
||||||
|
|
||||||
func setup() {
|
func setup() {
|
||||||
@@ -155,8 +154,8 @@ func getName(ini *os.File) string {
|
|||||||
return ret
|
return ret
|
||||||
}
|
}
|
||||||
|
|
||||||
func getIcon(fold string) gxui.Texture {
|
func getIcon(fold string) *gdk.Pixbuf {
|
||||||
var pic *os.File
|
var pic string
|
||||||
if folder, err := os.Open(fold + "/App/AppInfo"); err == nil {
|
if folder, err := os.Open(fold + "/App/AppInfo"); err == nil {
|
||||||
fis, _ := folder.Readdir(-1)
|
fis, _ := folder.Readdir(-1)
|
||||||
var pics []string
|
var pics []string
|
||||||
@@ -173,21 +172,18 @@ func getIcon(fold string) gxui.Texture {
|
|||||||
} else {
|
} else {
|
||||||
ind = sort.SearchStrings(pics, "appicon_32.png")
|
ind = sort.SearchStrings(pics, "appicon_32.png")
|
||||||
}
|
}
|
||||||
pic, _ = os.Open(fold + "/App/AppInfo/" + pics[ind])
|
pic = fold + "/App/AppInfo/" + pics[ind]
|
||||||
}
|
}
|
||||||
} else if fi, err := os.Open(fold + "/appicon.png"); err == nil {
|
} else if _, err := os.Open(fold + "/appicon.png"); err == nil {
|
||||||
pic = fi
|
pic = fold + "/appicon.png"
|
||||||
} else {
|
} else {
|
||||||
return nil
|
img, _ := gtk.ImageNewFromIconName("application-x-executable", gtk.ICON_SIZE_BUTTON)
|
||||||
|
buf, _ := img.GetPixbuf().ScaleSimple(32, 32, gdk.INTERP_BILINEAR)
|
||||||
|
return buf
|
||||||
}
|
}
|
||||||
img, _, err := image.Decode(pic)
|
img, _ := gtk.ImageNewFromFile(pic)
|
||||||
if err != nil {
|
buf, _ := img.GetPixbuf().ScaleSimple(32, 32, gdk.INTERP_BILINEAR)
|
||||||
return nil
|
return buf
|
||||||
}
|
|
||||||
rgba := image.NewRGBA(img.Bounds())
|
|
||||||
draw.Draw(rgba, img.Bounds(), img, image.ZP, draw.Src)
|
|
||||||
ret := dr.CreateTexture(rgba, 1)
|
|
||||||
return ret
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func findInfo(fold string) *os.File {
|
func findInfo(fold string) *os.File {
|
||||||
|
|||||||
@@ -1,7 +1,129 @@
|
|||||||
package ui
|
package main
|
||||||
|
|
||||||
import "github.com/gotk3/gotk3/gtk"
|
import (
|
||||||
|
"fmt"
|
||||||
|
|
||||||
|
"github.com/gotk3/gotk3/glib"
|
||||||
|
"github.com/gotk3/gotk3/gtk"
|
||||||
|
)
|
||||||
|
|
||||||
func ui(win *gtk.Window) {
|
func ui(win *gtk.Window) {
|
||||||
|
ls := getCatRows()
|
||||||
|
var treeApps []*gtk.TreeIter
|
||||||
|
header, _ := gtk.HeaderBarNew()
|
||||||
|
header.SetShowCloseButton(true)
|
||||||
|
header.SetTitle("LinuxPA")
|
||||||
|
header.SetSubtitle("PortableApps.com type launcher")
|
||||||
|
settings, _ := gtk.ButtonNewFromIconName("applications-system", gtk.ICON_SIZE_SMALL_TOOLBAR)
|
||||||
|
settings.Connect("clicked", func() {
|
||||||
|
//Open Settings window!
|
||||||
|
})
|
||||||
|
settings.SetTooltipText("Settings (Coming Soon!)")
|
||||||
|
header.PackStart(settings)
|
||||||
|
win.SetTitlebar(header)
|
||||||
|
topLvl, _ := gtk.BoxNew(gtk.ORIENTATION_VERTICAL, 0)
|
||||||
|
lrBox, _ := gtk.BoxNew(gtk.ORIENTATION_HORIZONTAL, 5)
|
||||||
|
catList, _ := gtk.ListBoxNew()
|
||||||
|
catList.SetActivateOnSingleClick(true)
|
||||||
|
store, _ := gtk.TreeStoreNew(glib.TYPE_OBJECT, glib.TYPE_STRING)
|
||||||
|
appsList, _ := gtk.TreeViewNewWithModel(store)
|
||||||
|
render, _ := gtk.CellRendererPixbufNew()
|
||||||
|
pixColumn, _ := gtk.TreeViewColumnNewWithAttribute("", render, "pixbuf", 0)
|
||||||
|
txtRender, _ := gtk.CellRendererTextNew()
|
||||||
|
txtColumn, _ := gtk.TreeViewColumnNewWithAttribute("", txtRender, "text", 1)
|
||||||
|
appsList.AppendColumn(pixColumn)
|
||||||
|
appsList.AppendColumn(txtColumn)
|
||||||
|
catList.SetHExpand(true)
|
||||||
|
catList.SetVExpand(true)
|
||||||
|
appsList.SetHExpand(true)
|
||||||
|
appsList.SetVExpand(true)
|
||||||
|
vScrollCat, _ := gtk.AdjustmentNew(0, 0, 0, 0, 0, 0)
|
||||||
|
hScrollCat, _ := gtk.AdjustmentNew(0, 0, 0, 0, 0, 0)
|
||||||
|
vScrollApp, _ := gtk.AdjustmentNew(0, 0, 0, 0, 0, 0)
|
||||||
|
hScrollApp, _ := gtk.AdjustmentNew(0, 0, 0, 0, 0, 0)
|
||||||
|
catScrl, _ := gtk.ScrolledWindowNew(hScrollCat, vScrollCat)
|
||||||
|
catScrl.Add(catList)
|
||||||
|
appScrl, _ := gtk.ScrolledWindowNew(hScrollApp, vScrollApp)
|
||||||
|
appScrl.Add(appsList)
|
||||||
|
lrBox.Add(catScrl)
|
||||||
|
lrBox.Add(appScrl)
|
||||||
|
botBox, _ := gtk.BoxNew(gtk.ORIENTATION_HORIZONTAL, 2)
|
||||||
|
wineCheck, _ := gtk.CheckButtonNewWithLabel("Show Windows apps (Wine)")
|
||||||
|
wineCheck.Connect("toggled", func() {
|
||||||
|
wine = wineCheck.GetActive()
|
||||||
|
for i := range ls {
|
||||||
|
catList.Remove(catList.GetRowAtIndex(i))
|
||||||
|
}
|
||||||
|
ls = getCatRows()
|
||||||
|
for _, v := range ls {
|
||||||
|
catList.Add(v)
|
||||||
|
}
|
||||||
|
catList.ShowAll()
|
||||||
|
})
|
||||||
|
botBox.Add(wineCheck)
|
||||||
|
topLvl.Add(lrBox)
|
||||||
|
topLvl.PackEnd(botBox, false, true, 0)
|
||||||
|
win.Add(topLvl)
|
||||||
|
for _, v := range ls {
|
||||||
|
catList.Prepend(v)
|
||||||
|
}
|
||||||
|
catList.Connect("row-selected", func() {
|
||||||
|
store.Clear()
|
||||||
|
if catList.GetSelectedRow().GetIndex() >= 0 {
|
||||||
|
treeApps = make([]*gtk.TreeIter, 0)
|
||||||
|
if wine {
|
||||||
|
apps := master[cats[catList.GetSelectedRow().GetIndex()]]
|
||||||
|
for _, v := range apps {
|
||||||
|
treeApps = append(treeApps, v.getTreeIter(store))
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
apps := linmaster[lin[catList.GetSelectedRow().GetIndex()]]
|
||||||
|
for _, v := range apps {
|
||||||
|
treeApps = append(treeApps, v.getTreeIter(store))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
appsList.Connect("row-activated", func() {
|
||||||
|
selec, _ := appsList.GetSelection()
|
||||||
|
_, it, ok := selec.GetSelected()
|
||||||
|
if ok {
|
||||||
|
pth, _ := store.GetPath(it)
|
||||||
|
ind := pth.GetIndices()
|
||||||
|
if len(ind) == 1 {
|
||||||
|
if wine {
|
||||||
|
app := master[cats[catList.GetSelectedRow().GetIndex()]][ind[0]]
|
||||||
|
app.launch()
|
||||||
|
} else {
|
||||||
|
app := linmaster[lin[catList.GetSelectedRow().GetIndex()]][ind[0]]
|
||||||
|
app.launch()
|
||||||
|
}
|
||||||
|
} else if len(ind) == 2 {
|
||||||
|
if wine {
|
||||||
|
app := master[cats[catList.GetSelectedRow().GetIndex()]][ind[0]]
|
||||||
|
app.launchSub(ind[1])
|
||||||
|
} else {
|
||||||
|
app := linmaster[lin[catList.GetSelectedRow().GetIndex()]][ind[0]]
|
||||||
|
app.launchSub(ind[1])
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
func getCatRows() (out []*gtk.Label) {
|
||||||
|
if wine {
|
||||||
|
for _, v := range cats {
|
||||||
|
txt, _ := gtk.LabelNew(v)
|
||||||
|
out = append(out, txt)
|
||||||
|
fmt.Println(v)
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
for _, v := range lin {
|
||||||
|
txt, _ := gtk.LabelNew(v)
|
||||||
|
out = append(out, txt)
|
||||||
|
fmt.Println(v)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,11 +2,15 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"bufio"
|
"bufio"
|
||||||
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
"net/http"
|
"net/http"
|
||||||
"os"
|
"os"
|
||||||
|
"os/exec"
|
||||||
"strconv"
|
"strconv"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
|
"github.com/gotk3/gotk3/gtk"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
@@ -106,3 +110,50 @@ func downloadUpdate(newVersion string) (bool, error) {
|
|||||||
}
|
}
|
||||||
return true, nil
|
return true, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func update(win *gtk.Window) {
|
||||||
|
updateWin, _ := gtk.WindowNew(gtk.WINDOW_TOPLEVEL)
|
||||||
|
updateWin.SetTransientFor(win)
|
||||||
|
topLvl, _ := gtk.BoxNew(gtk.ORIENTATION_VERTICAL, 5)
|
||||||
|
spin, _ := gtk.SpinnerNew()
|
||||||
|
spin.Start()
|
||||||
|
lbl, _ := gtk.LabelNew("Checking for updates")
|
||||||
|
topLvl.Add(spin)
|
||||||
|
topLvl.Add(lbl)
|
||||||
|
topLvl.SetMarginBottom(10)
|
||||||
|
topLvl.SetMarginEnd(10)
|
||||||
|
topLvl.SetMarginStart(10)
|
||||||
|
topLvl.SetMarginTop(10)
|
||||||
|
updateWin.SetPosition(gtk.WIN_POS_CENTER_ON_PARENT)
|
||||||
|
updateWin.Add(topLvl)
|
||||||
|
updateWin.ShowAll()
|
||||||
|
updateWin.Show()
|
||||||
|
go func(win, updateWin *gtk.Window) {
|
||||||
|
stat, err := versionDL()
|
||||||
|
if stat {
|
||||||
|
res := getVersionFileInfo()
|
||||||
|
if res != "Error!" {
|
||||||
|
stat, err = checkForUpdate(res)
|
||||||
|
if stat {
|
||||||
|
lbl.SetText("Updating!")
|
||||||
|
downloadUpdate(res)
|
||||||
|
updateWin.Close()
|
||||||
|
win.Close()
|
||||||
|
cmd := exec.Command("./LinuxPA")
|
||||||
|
cmd.Stdin = os.Stdin
|
||||||
|
cmd.Stdout = os.Stdout
|
||||||
|
cmd.Start()
|
||||||
|
} else {
|
||||||
|
fmt.Println(err)
|
||||||
|
updateWin.Close()
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
fmt.Println("Failed Version File Info")
|
||||||
|
updateWin.Close()
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
fmt.Println(err)
|
||||||
|
updateWin.Close()
|
||||||
|
}
|
||||||
|
}(win, updateWin)
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user