Browse Source

prelim emoji tab completion with window title options

master
David Haukeness 5 years ago
parent
commit
00a8865ea6
No known key found for this signature in database
GPG Key ID: A7F1091956853EF9
  1. 39
      main.go

39
main.go

@ -62,6 +62,12 @@ func viewTitle(viewName string, title string) {
return nil return nil
}) })
} }
func getViewTitle(viewName string) string {
view, _ := g.View(viewName)
return view.Title
}
func popupView(viewName string) { func popupView(viewName string) {
_, err := g.SetCurrentView(viewName) _, err := g.SetCurrentView(viewName)
if err != nil { if err != nil {
@ -265,6 +271,15 @@ func stringRemainder(aStr, bStr string) string {
return long[i:] return long[i:]
} }
func appendIfNotInSlice(ss []string, s string) []string {
for _, element := range ss {
if element == s {
return ss
}
}
return append(ss, s)
}
func generateChannelTabCompletionSlice(inputWord string) []string { func generateChannelTabCompletionSlice(inputWord string) []string {
// create a slice to hold the values // create a slice to hold the values
var firstSlice []string var firstSlice []string
@ -272,11 +287,11 @@ func generateChannelTabCompletionSlice(inputWord string) []string {
for _, s := range channels { for _, s := range channels {
if s.MembersType == keybase.TEAM { if s.MembersType == keybase.TEAM {
// its a team so add the topic name as a possible tab completion // its a team so add the topic name as a possible tab completion
firstSlice = append(firstSlice, s.TopicName) firstSlice = appendIfNotInSlice(firstSlice, s.TopicName)
firstSlice = append(firstSlice, s.Name) firstSlice = appendIfNotInSlice(firstSlice, s.Name)
} else { } else {
// its a user, so clean the name and append the users name as a possible tab completion // its a user, so clean the name and append the users name as a possible tab completion
firstSlice = append(firstSlice, cleanChannelName(s.Name)) firstSlice = appendIfNotInSlice(firstSlice, cleanChannelName(s.Name))
} }
} }
// now return the resultSlice which contains all that are prefixed with inputWord // now return the resultSlice which contains all that are prefixed with inputWord
@ -311,11 +326,23 @@ func handleTab() error {
// now call get the list of all possible cantidates that have that as a prefix // now call get the list of all possible cantidates that have that as a prefix
resultSlice = generateChannelTabCompletionSlice(s) resultSlice = generateChannelTabCompletionSlice(s)
} }
rLen := len(resultSlice)
lcp := longestCommonPrefix(resultSlice) lcp := longestCommonPrefix(resultSlice)
if lcp != "" { if lcp != "" {
printToView("Feed", fmt.Sprintf("%d tab completion options", len(resultSlice))) originalViewTitle := strings.Split(getViewTitle("Input"), "||")[0]
remainder := stringRemainder(s, lcp) newViewTitle := ""
writeToView("Input", remainder) if rLen >= 1 {
if rLen == 1 {
newViewTitle = originalViewTitle
} else if rLen <= 5 {
newViewTitle = fmt.Sprintf("%s|| %s", originalViewTitle, strings.Join(resultSlice, " "))
} else if rLen > 5 {
newViewTitle = fmt.Sprintf("%s|| %s +%d more", originalViewTitle, strings.Join(resultSlice[:6], " "), rLen - 5)
}
viewTitle("Input", newViewTitle)
remainder := stringRemainder(s, lcp)
writeToView("Input", remainder)
}
} }
} }
return nil return nil

Loading…
Cancel
Save