2020-01-19 06:06:00 +00:00
|
|
|
package arguments
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
"regexp"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
EmojiRegex = regexp.MustCompile(`<(a?):(.+?):(\d+)>`)
|
|
|
|
|
|
|
|
ErrInvalidEmoji = errors.New("Invalid emoji")
|
|
|
|
)
|
|
|
|
|
|
|
|
type Emoji struct {
|
|
|
|
ID string
|
|
|
|
|
|
|
|
Custom bool
|
|
|
|
Name string
|
|
|
|
Animated bool
|
|
|
|
}
|
|
|
|
|
2020-01-24 04:01:59 +00:00
|
|
|
func (e Emoji) APIString() string {
|
2020-01-24 03:54:47 +00:00
|
|
|
if !e.Custom {
|
|
|
|
return e.ID
|
|
|
|
}
|
|
|
|
|
|
|
|
return e.Name + ":" + e.ID
|
|
|
|
}
|
|
|
|
|
2020-01-24 04:01:59 +00:00
|
|
|
func (e Emoji) String() string {
|
|
|
|
if !e.Custom {
|
|
|
|
return e.ID
|
|
|
|
}
|
|
|
|
|
|
|
|
if e.Animated {
|
|
|
|
return "<a:" + e.Name + ":" + e.ID + ">"
|
|
|
|
} else {
|
|
|
|
return "<:" + e.Name + ":" + e.ID + ">"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-01-24 03:54:47 +00:00
|
|
|
func (e Emoji) URL() string {
|
|
|
|
if e.Custom {
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
|
|
|
|
base := "https://cdn.discordapp.com/emojis/" + e.ID
|
|
|
|
|
|
|
|
if e.Animated {
|
|
|
|
return base + ".gif"
|
|
|
|
} else {
|
|
|
|
return base + ".png"
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-01-19 06:06:00 +00:00
|
|
|
func (e *Emoji) Parse(arg string) error {
|
|
|
|
// Check if Unicode
|
|
|
|
var unicode string
|
|
|
|
|
|
|
|
for _, r := range arg {
|
|
|
|
if r < '\U0001F600' && r > '\U0001F64F' {
|
|
|
|
unicode += string(r)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if unicode != "" {
|
|
|
|
e.ID = unicode
|
|
|
|
e.Custom = false
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
var matches = EmojiRegex.FindStringSubmatch(arg)
|
|
|
|
|
|
|
|
if len(matches) != 4 {
|
|
|
|
return ErrInvalidEmoji
|
|
|
|
}
|
|
|
|
|
|
|
|
e.Custom = true
|
|
|
|
e.Animated = matches[1] == "a"
|
|
|
|
e.Name = matches[2]
|
|
|
|
e.ID = matches[3]
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|