package macos import ( "path" "strings" ice "shylinux.com/x/icebergs" "shylinux.com/x/icebergs/base/aaa" "shylinux.com/x/icebergs/base/cli" "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/html" "shylinux.com/x/icebergs/core/chat" kit "shylinux.com/x/toolkits" ) const MACOS = "macos" var Index = &ice.Context{Name: MACOS, Commands: ice.Commands{ ice.CTX_INIT: {Hand: func(m *ice.Message, arg ...string) { ice.Info.Load(m).Cmd(FINDER, ice.CTX_INIT) }}, }} func init() { chat.Index.Register(Index, nil, DESKTOP, APPLICATIONS) } func Prefix(arg ...string) string { return chat.Prefix(MACOS, kit.Keys(arg)) } func disableApp(m *ice.Message) *ice.Message { m.Table(func(value ice.Maps) { switch index := ctx.ShortCmd(value[ctx.INDEX]); index { case web.DREAM, web.CODE_GIT_SEARCH: if ice.Info.NodeType == web.WORKER { m.Push(mdb.STATUS, mdb.DISABLE) return } case web.COMPILE: if cli.SystemFind(m, "go") == "" { m.Push(mdb.STATUS, mdb.DISABLE) return } fallthrough case web.XTERM: if !kit.IsIn(m.Option(ice.MSG_USERROLE), aaa.TECH, aaa.ROOT) { m.Push(mdb.STATUS, mdb.DISABLE) return } default: m.Push(mdb.STATUS, kit.Select(mdb.DISABLE, mdb.ENABLE, aaa.Right(m.Spawn(), index))) return } m.Push(mdb.STATUS, mdb.ENABLE) }) return m } func install(m *ice.Message, cmd, icon, index string, arg ...string) string { if icon == "" { return "" } else if !kit.HasPrefix(icon, nfs.PS, web.HTTP) && !nfs.Exists(m, icon) && !nfs.Exists(m, ice.USR_ICONS+icon, func(p string) { icon = p }) { if strings.Contains(kit.Path(""), nfs.USR_LOCAL_WORK) && nfs.Exists(m, path.Join(strings.Split(kit.Path(""), nfs.USR_LOCAL_WORK)[0], ice.USR_ICONS+icon)) { icon = ice.USR_ICONS + icon } else { icon = path.Join(path.Dir(ctx.GetCmdFile(m, m.PrefixKey())), icon) } } name := kit.TrimExt(path.Base(icon), nfs.PNG, nfs.JPG, nfs.JPEG) if !strings.HasPrefix(icon, nfs.USR_ICONS) { name = kit.Select("", kit.Split(index, "."), -1) } m.Cmd(Prefix(cmd), mdb.CREATE, mdb.NAME, name, mdb.ICON, icon, ctx.INDEX, index, mdb.SCORE, "1000", arg) return icon } func PodCmdAction(arg ...string) ice.Actions { file := kit.FileLine(-1, 100) return ice.Actions{ mdb.SELECT: {Name: "list hash auto create", Hand: func(m *ice.Message, arg ...string) { defer m.Display(m.FileURI(file)) msg := disableApp(mdb.HashSelect(m.Spawn(), arg...)) web.PushPodCmd(msg, m.PrefixKey(), arg...) has := map[string]bool{} msg.Table(func(value ice.Maps, index int, head []string) { kit.If(!has[value[ctx.INDEX]+value[ctx.ARGS]], func() { has[value[ctx.INDEX]+value[ctx.ARGS]] = true; m.Push("", value, head) }) }) m.Sort("score,space,index,args", ice.INT) }}, } } func CmdHashAction(arg ...string) ice.Actions { file := kit.FileLine(-1, 100) return ice.MergeActions(ice.Actions{ mdb.INPUTS: {Hand: func(m *ice.Message, arg ...string) { switch mdb.HashInputs(m, arg); arg[0] { case mdb.ICON: m.Cmd(nfs.DIR, ice.USR_ICONS, func(value ice.Maps) { m.Push(arg[0], value[nfs.PATH]) }) case mdb.NAME: m.Cmd(nfs.DIR, ice.USR_ICONS, func(value ice.Maps) { m.Push(arg[0], kit.TrimExt(value[nfs.PATH], nfs.PNG)) }) } }}, mdb.SELECT: {Hand: func(m *ice.Message, arg ...string) { m.Option(html.FAVICON, m.Cmd(web.SPACE, ice.INFO).Append(mdb.ICONS)) disableApp(mdb.HashSelect(m, arg...).Sort("score,space,index,args").Display(m.FileURI(file))) }}, }, mdb.HashAction(mdb.SHORT, kit.Select("", arg, 0), mdb.FIELD, kit.Select("time,hash,icon,name,text,score,space,index,args", arg, 1), kit.Slice(arg, 2))) }