1
0
forked from x/icebergs
This commit is contained in:
IT 老营长 @云轩领航-创始人 2023-09-04 11:39:30 +08:00
parent 6e8235346f
commit a220752657
5 changed files with 44 additions and 43 deletions

View File

@ -275,6 +275,7 @@ func init() {
m.Cmd("", mdb.CREATE, ice.DEV, kit.Select(kit.Select("https://contexts.com.cn", ice.Info.Make.Domain), conf[cli.CTX_DEV])) m.Cmd("", mdb.CREATE, ice.DEV, kit.Select(kit.Select("https://contexts.com.cn", ice.Info.Make.Domain), conf[cli.CTX_DEV]))
m.Cmd("", mdb.CREATE, ice.COM, kit.Select("https://contexts.com.cn", conf[cli.CTX_COM])) m.Cmd("", mdb.CREATE, ice.COM, kit.Select("https://contexts.com.cn", conf[cli.CTX_COM]))
m.Cmd("", mdb.CREATE, ice.HUB, kit.Select("https://repos.shylinux.com", conf[cli.CTX_HUB])) m.Cmd("", mdb.CREATE, ice.HUB, kit.Select("https://repos.shylinux.com", conf[cli.CTX_HUB]))
m.Cmd("", mdb.CREATE, "repos", kit.Select("https://repos.shylinux.com", conf[cli.CTX_HUB]))
m.Cmd("", mdb.CREATE, ice.SHY, kit.Select(kit.Select("https://shylinux.com", ice.Info.Make.Remote), conf[cli.CTX_SHY])) m.Cmd("", mdb.CREATE, ice.SHY, kit.Select(kit.Select("https://shylinux.com", ice.Info.Make.Remote), conf[cli.CTX_SHY]))
}}, }},
mdb.INPUTS: {Hand: func(m *ice.Message, arg ...string) { mdb.INPUTS: {Hand: func(m *ice.Message, arg ...string) {

View File

@ -21,7 +21,7 @@ func init() {
ice.CTX_INIT: {Hand: func(m *ice.Message, arg ...string) { ice.CTX_INIT: {Hand: func(m *ice.Message, arg ...string) {
Notify(m, cli.RUNTIME, "系统启动成功", ctx.INDEX, cli.RUNTIME) Notify(m, cli.RUNTIME, "系统启动成功", ctx.INDEX, cli.RUNTIME)
FinderAppend(m, "Applications", m.PrefixKey()) FinderAppend(m, "Applications", m.PrefixKey())
AppInstall(m, "usr/icons/Finder.png", nfs.DIR) AppInstall(m, "usr/icons/dir.png", nfs.DIR)
AppInstall(m, "usr/icons/Safari.png", web.CHAT_IFRAME) AppInstall(m, "usr/icons/Safari.png", web.CHAT_IFRAME)
AppInstall(m, "usr/icons/Terminal.png", web.CODE_XTERM) AppInstall(m, "usr/icons/Terminal.png", web.CODE_XTERM)
AppInstall(m, "usr/icons/Calendar.png", web.TEAM_PLAN) AppInstall(m, "usr/icons/Calendar.png", web.TEAM_PLAN)

View File

@ -5,8 +5,11 @@ import (
"time" "time"
ice "shylinux.com/x/icebergs" ice "shylinux.com/x/icebergs"
"shylinux.com/x/icebergs/base/aaa"
"shylinux.com/x/icebergs/base/cli" "shylinux.com/x/icebergs/base/cli"
"shylinux.com/x/icebergs/base/ctx" "shylinux.com/x/icebergs/base/ctx"
"shylinux.com/x/icebergs/base/mdb"
"shylinux.com/x/icebergs/base/nfs"
"shylinux.com/x/icebergs/base/web" "shylinux.com/x/icebergs/base/web"
"shylinux.com/x/icebergs/core/chat/macos" "shylinux.com/x/icebergs/core/chat/macos"
kit "shylinux.com/x/toolkits" kit "shylinux.com/x/toolkits"
@ -14,56 +17,55 @@ import (
func init() { func init() {
const SEARCH = "search" const SEARCH = "search"
const (
EXPLORE_REPOS = "/explore/repos"
REPOS_SEARCH = "/api/v1/repos/search"
)
const (
WEB_SPIDE = "web.spide"
UPDATED_AT = "updated_at"
CLONE_URL = "clone_url"
HTML_URL = "html_url"
WEBSITE = "website"
)
Index.MergeCommands(ice.Commands{ Index.MergeCommands(ice.Commands{
SEARCH: {Name: "search repos keyword auto", Help: "代码源", Actions: ice.MergeActions(ice.Actions{ SEARCH: {Name: "search repos keyword auto", Help: "代码源", Actions: ice.MergeActions(ice.Actions{
ice.CTX_INIT: {Hand: func(m *ice.Message, arg ...string) { ice.CTX_INIT: {Hand: func(m *ice.Message, arg ...string) {
macos.AppInstall(m, "usr/icons/gitea.png", m.PrefixKey(), ctx.ARGS, kit.Format([]string{"repos"})) macos.AppInstall(m, "usr/icons/gitea.png", m.PrefixKey(), ctx.ARGS, kit.Format([]string{REPOS}))
}}, }},
cli.START: {Name: "start name", Hand: func(m *ice.Message, arg ...string) { cli.START: {Name: "start name*", Hand: func(m *ice.Message, arg ...string) { m.Cmdy(web.DREAM, cli.START) }},
m.Cmdy(web.DREAM, cli.START) CLONE: {Name: "clone name*", Hand: func(m *ice.Message, arg ...string) { m.Cmdy(REPOS, CLONE, m.Option(REPOS)) }},
}}, HTML_URL: {Help: "源码", Hand: func(m *ice.Message, arg ...string) { m.ProcessOpen(m.Option(HTML_URL)) }},
CLONE: {Name: "clone name", Hand: func(m *ice.Message, arg ...string) { WEBSITE: {Help: "官网", Hand: func(m *ice.Message, arg ...string) { m.ProcessOpen(m.Option(WEBSITE)) }},
m.Cmdy(REPOS, CLONE, m.Option(REPOS)) ORIGIN: {Help: "平台", Hand: func(m *ice.Message, arg ...string) {
}}, m.ProcessOpen(m.Cmdv(WEB_SPIDE, kit.Select(m.Option(REPOS), arg, 0), web.CLIENT_ORIGIN) + EXPLORE_REPOS)
cli.OPEN: {Hand: func(m *ice.Message, arg ...string) {
m.ProcessOpen(m.Option("html_url"))
}},
"origin": {Hand: func(m *ice.Message, arg ...string) {
m.ProcessOpen(m.Cmdv("web.spide", "repos", "client.origin") + "/explore/repos")
}}, }},
}, ctx.CmdAction()), Hand: func(m *ice.Message, arg ...string) { }, ctx.CmdAction()), Hand: func(m *ice.Message, arg ...string) {
if len(arg) == 0 { if len(arg) == 0 {
m.Cmdy("web.spide").RenameAppend("client.name", "repos", "client.url", "origin").Cut("time,repos,origin") m.Cmdy(WEB_SPIDE).RenameAppend(web.CLIENT_NAME, REPOS, web.CLIENT_URL, ORIGIN).Cut("time,repos,origin")
return return
} }
res := kit.UnMarshal(m.Cmdx("web.spide", REPOS, web.SPIDE_RAW, http.MethodGet, "/api/v1/repos/search", res := kit.UnMarshal(m.Cmdx(WEB_SPIDE, arg[0], web.SPIDE_RAW, http.MethodGet, REPOS_SEARCH,
"q", kit.Select("", arg, 1), "sort", "updated", "order", "desc", "page", "1", "limit", "100", "q", kit.Select("", arg, 1), "sort", "updated", "order", "desc", "page", "1", "limit", "100",
)) ))
kit.For(kit.Value(res, "data"), func(value ice.Map) { kit.For(kit.Value(res, mdb.DATA), func(value ice.Map) {
value["size"] = kit.FmtSize(kit.Int(value["size"]) * 1000) value[nfs.SIZE] = kit.FmtSize(kit.Int(value[nfs.SIZE]) * 1000)
if t, e := time.Parse(time.RFC3339, kit.Format(value["updated_at"])); e == nil { if t, e := time.Parse(time.RFC3339, kit.Format(value[UPDATED_AT])); e == nil {
value["updated_at"] = t.Format("01-02 15:04") value[UPDATED_AT] = t.Format("01-02 15:04")
} }
m.Push("", value, []string{ m.Push("", value, []string{
"avatar_url", aaa.AVATAR_URL, mdb.NAME, aaa.LANGUAGE,
"name", "forks_count", "stars_count", "watchers_count",
nfs.SIZE, UPDATED_AT, "description",
"language", CLONE_URL, HTML_URL, WEBSITE,
"forks_count",
"stars_count",
"watchers_count",
"size", "updated_at",
"description",
"clone_url",
"html_url",
"website",
}) })
m.PushButton(cli.START, CLONE, cli.OPEN) button := []ice.Any{}
kit.If(!kit.IsIn(kit.Format(value[mdb.NAME]), ice.ICEBERGS, ice.VOLCANOS), func() { button = append(button, cli.START) })
button = append(button, CLONE)
kit.For([]string{HTML_URL, WEBSITE}, func(key string) { kit.If(kit.Format(value[key]), func() { button = append(button, key) }) })
m.PushButton(button...)
}) })
m.RenameAppend("clone_url", "repos").StatusTimeCount().Display("") m.RenameAppend(CLONE_URL, REPOS).StatusTimeCount().Display("").Action(ORIGIN)
m.Action("origin")
// m.Echo("%v", kit.Formats(res))
}}, }},
}) })
} }

View File

@ -4,10 +4,8 @@ Volcanos(chat.ONIMPORT, {
can.onappend.style(can, "card", can._output) can.onappend.style(can, "card", can._output)
can.page.Appends(can, can._output, msg.Table(function(value) { can.page.Appends(can, can._output, msg.Table(function(value) {
return {view: [[html.ITEM, value.status]], list: [ return {view: [[html.ITEM, value.status]], list: [
{view: [wiki.TITLE, html.DIV], list: [{img: value.avatar_url}, {view: "name", list: [ {view: [wiki.TITLE, html.DIV], list: [{img: value.avatar_url}, {view: mdb.NAME, list: [
{view: "name", list: [ {view: mdb.NAME, list: [{text: [value.name, "", mdb.NAME]}]},
{text: [value.name, "", "name"]},
]},
{view: "label", list: [ {view: "label", list: [
{icon: "bi bi-file-earmark-code"}, {text: value.language}, {icon: "bi bi-file-earmark-code"}, {text: value.language},
{icon: "bi bi-share"}, {text: value.forks_count}, {icon: "bi bi-share"}, {text: value.forks_count},
@ -18,8 +16,7 @@ Volcanos(chat.ONIMPORT, {
]}]}, {view: [wiki.CONTENT, html.DIV, value.description]}, ]}]}, {view: [wiki.CONTENT, html.DIV, value.description]},
{view: html.ACTION, inner: value.action, _init: function(target) { can.onappend.mores(can, target, value, 5) }}, {view: html.ACTION, inner: value.action, _init: function(target) { can.onappend.mores(can, target, value, 5) }},
]} ]}
})), can.onappend.board(can, msg) })), can.onappend.board(can, msg), can.onimport.layout(can)
can.onimport.layout(can)
}, },
layout: function(can) { can.onlayout.expand(can, can._output, 360) }, layout: function(can) { can.onlayout.expand(can, can._output, 360) },
}, [""]) }, [""])

View File

@ -202,9 +202,10 @@ func (m *Message) EchoScript(arg ...string) *Message { return m.Echo(Render(m, R
func (m *Message) EchoDownload(arg ...string) *Message { func (m *Message) EchoDownload(arg ...string) *Message {
return m.Echo(Render(m, RENDER_DOWNLOAD, arg)) return m.Echo(Render(m, RENDER_DOWNLOAD, arg))
} }
func (m *Message) Display(file string, arg ...Any) { func (m *Message) Display(file string, arg ...Any) *Message {
file = m.resource(file) file = m.resource(file)
m.Option(MSG_DISPLAY, kit.MergeURL(kit.Select(kit.ExtChange(file, JS), file, strings.Contains(file, QS)), arg...)) m.Option(MSG_DISPLAY, kit.MergeURL(kit.Select(kit.ExtChange(file, JS), file, strings.Contains(file, QS)), arg...))
return m
} }
func (m *Message) Resource(file string) string { return m.resource(file) } func (m *Message) Resource(file string) string { return m.resource(file) }
func (m *Message) resource(file string) string { func (m *Message) resource(file string) string {