mirror of https://github.com/anoshenko/rui.git
Added SetHotKey function to Session interface
This commit is contained in:
parent
ab421b4c32
commit
dc2ea14cac
|
@ -1,5 +1,6 @@
|
||||||
# v0.13.0
|
# v0.13.0
|
||||||
|
|
||||||
|
* Added SetHotKey function to Session interface
|
||||||
* Added ViewIndex function to ViewsContainer interface
|
* Added ViewIndex function to ViewsContainer interface
|
||||||
* Added ReloadCell function to TableView interface
|
* Added ReloadCell function to TableView interface
|
||||||
* Added ReloadTableViewCell function
|
* Added ReloadTableViewCell function
|
||||||
|
|
|
@ -5217,6 +5217,8 @@ Safari и Firefox.
|
||||||
* DownloadFileData(filename string, data []byte) - загружает (сохраняет) на стороне клиента файл с заданным именем и
|
* DownloadFileData(filename string, data []byte) - загружает (сохраняет) на стороне клиента файл с заданным именем и
|
||||||
заданным содержимым. Обычно используется для передачи файла сгенерированного в памяти сервера.
|
заданным содержимым. Обычно используется для передачи файла сгенерированного в памяти сервера.
|
||||||
|
|
||||||
|
* SetHotKey(keyCode KeyCode, controlKeys ControlKeyMask, fn func(Session)) - устанавливает функцию которая будет вызываться при нажатии заданной горячей клавиши.
|
||||||
|
|
||||||
## Формат описания ресурсов
|
## Формат описания ресурсов
|
||||||
|
|
||||||
Ресурсы приложения (темы, View, переводы) могут быть описаны в виде текста (utf-8). Данный текст помещается
|
Ресурсы приложения (темы, View, переводы) могут быть описаны в виде текста (utf-8). Данный текст помещается
|
||||||
|
|
|
@ -5171,6 +5171,9 @@ It is used when the client needs to transfer a file from the server.
|
||||||
* DownloadFileData(filename string, data [] byte) downloads (saves) on the client side a file
|
* DownloadFileData(filename string, data [] byte) downloads (saves) on the client side a file
|
||||||
with a specified name and specified content. Typically used to transfer a file generated in server memory.
|
with a specified name and specified content. Typically used to transfer a file generated in server memory.
|
||||||
|
|
||||||
|
* SetHotKey(keyCode KeyCode, controlKeys ControlKeyMask, fn func(Session)) - sets the function that will be called
|
||||||
|
when the given hotkey is pressed.
|
||||||
|
|
||||||
## Resource description format
|
## Resource description format
|
||||||
|
|
||||||
Application resources (themes, views, translations) can be described as text (utf-8).
|
Application resources (themes, views, translations) can be described as text (utf-8).
|
||||||
|
|
215
keyEvents.go
215
keyEvents.go
|
@ -18,117 +18,122 @@ const (
|
||||||
// The additional listener formats:
|
// The additional listener formats:
|
||||||
// func(KeyEvent), func(View), and func().
|
// func(KeyEvent), func(View), and func().
|
||||||
KeyUpEvent = "key-up-event"
|
KeyUpEvent = "key-up-event"
|
||||||
|
)
|
||||||
|
|
||||||
|
type ControlKeyMask int
|
||||||
|
type KeyCode string
|
||||||
|
|
||||||
|
const (
|
||||||
// AltKey is the mask of the "alt" key
|
// AltKey is the mask of the "alt" key
|
||||||
AltKey = 1
|
AltKey ControlKeyMask = 1
|
||||||
// CtrlKey is the mask of the "ctrl" key
|
// CtrlKey is the mask of the "ctrl" key
|
||||||
CtrlKey = 2
|
CtrlKey ControlKeyMask = 2
|
||||||
// ShiftKey is the mask of the "shift" key
|
// ShiftKey is the mask of the "shift" key
|
||||||
ShiftKey = 4
|
ShiftKey ControlKeyMask = 4
|
||||||
// MetaKey is the mask of the "meta" key
|
// MetaKey is the mask of the "meta" key
|
||||||
MetaKey = 8
|
MetaKey ControlKeyMask = 8
|
||||||
|
|
||||||
KeyA = "KeyA"
|
KeyA KeyCode = "KeyA"
|
||||||
KeyB = "KeyB"
|
KeyB KeyCode = "KeyB"
|
||||||
KeyC = "KeyC"
|
KeyC KeyCode = "KeyC"
|
||||||
KeyD = "KeyD"
|
KeyD KeyCode = "KeyD"
|
||||||
KeyE = "KeyE"
|
KeyE KeyCode = "KeyE"
|
||||||
KeyF = "KeyF"
|
KeyF KeyCode = "KeyF"
|
||||||
KeyG = "KeyG"
|
KeyG KeyCode = "KeyG"
|
||||||
KeyH = "KeyH"
|
KeyH KeyCode = "KeyH"
|
||||||
KeyI = "KeyI"
|
KeyI KeyCode = "KeyI"
|
||||||
KeyJ = "KeyJ"
|
KeyJ KeyCode = "KeyJ"
|
||||||
KeyK = "KeyK"
|
KeyK KeyCode = "KeyK"
|
||||||
KeyL = "KeyL"
|
KeyL KeyCode = "KeyL"
|
||||||
KeyM = "KeyM"
|
KeyM KeyCode = "KeyM"
|
||||||
KeyN = "KeyN"
|
KeyN KeyCode = "KeyN"
|
||||||
KeyO = "KeyO"
|
KeyO KeyCode = "KeyO"
|
||||||
KeyP = "KeyP"
|
KeyP KeyCode = "KeyP"
|
||||||
KeyQ = "KeyQ"
|
KeyQ KeyCode = "KeyQ"
|
||||||
KeyR = "KeyR"
|
KeyR KeyCode = "KeyR"
|
||||||
KeyS = "KeyS"
|
KeyS KeyCode = "KeyS"
|
||||||
KeyT = "KeyT"
|
KeyT KeyCode = "KeyT"
|
||||||
KeyU = "KeyU"
|
KeyU KeyCode = "KeyU"
|
||||||
KeyV = "KeyV"
|
KeyV KeyCode = "KeyV"
|
||||||
KeyW = "KeyW"
|
KeyW KeyCode = "KeyW"
|
||||||
KeyX = "KeyX"
|
KeyX KeyCode = "KeyX"
|
||||||
KeyY = "KeyY"
|
KeyY KeyCode = "KeyY"
|
||||||
KeyZ = "KeyZ"
|
KeyZ KeyCode = "KeyZ"
|
||||||
Digit0Key = "Digit0"
|
Digit0Key KeyCode = "Digit0"
|
||||||
Digit1Key = "Digit1"
|
Digit1Key KeyCode = "Digit1"
|
||||||
Digit2Key = "Digit2"
|
Digit2Key KeyCode = "Digit2"
|
||||||
Digit3Key = "Digit3"
|
Digit3Key KeyCode = "Digit3"
|
||||||
Digit4Key = "Digit4"
|
Digit4Key KeyCode = "Digit4"
|
||||||
Digit5Key = "Digit5"
|
Digit5Key KeyCode = "Digit5"
|
||||||
Digit6Key = "Digit6"
|
Digit6Key KeyCode = "Digit6"
|
||||||
Digit7Key = "Digit7"
|
Digit7Key KeyCode = "Digit7"
|
||||||
Digit8Key = "Digit8"
|
Digit8Key KeyCode = "Digit8"
|
||||||
Digit9Key = "Digit9"
|
Digit9Key KeyCode = "Digit9"
|
||||||
SpaceKey = "Space"
|
SpaceKey KeyCode = "Space"
|
||||||
MinusKey = "Minus"
|
MinusKey KeyCode = "Minus"
|
||||||
EqualKey = "Equal"
|
EqualKey KeyCode = "Equal"
|
||||||
IntlBackslashKey = "IntlBackslash"
|
IntlBackslashKey KeyCode = "IntlBackslash"
|
||||||
BracketLeftKey = "BracketLeft"
|
BracketLeftKey KeyCode = "BracketLeft"
|
||||||
BracketRightKey = "BracketRight"
|
BracketRightKey KeyCode = "BracketRight"
|
||||||
SemicolonKey = "Semicolon"
|
SemicolonKey KeyCode = "Semicolon"
|
||||||
CommaKey = "Comma"
|
CommaKey KeyCode = "Comma"
|
||||||
PeriodKey = "Period"
|
PeriodKey KeyCode = "Period"
|
||||||
QuoteKey = "Quote"
|
QuoteKey KeyCode = "Quote"
|
||||||
BackquoteKey = "Backquote"
|
BackquoteKey KeyCode = "Backquote"
|
||||||
SlashKey = "Slash"
|
SlashKey KeyCode = "Slash"
|
||||||
EscapeKey = "Escape"
|
EscapeKey KeyCode = "Escape"
|
||||||
EnterKey = "Enter"
|
EnterKey KeyCode = "Enter"
|
||||||
TabKey = "Tab"
|
TabKey KeyCode = "Tab"
|
||||||
CapsLockKey = "CapsLock"
|
CapsLockKey KeyCode = "CapsLock"
|
||||||
DeleteKey = "Delete"
|
DeleteKey KeyCode = "Delete"
|
||||||
HelpKey = "Help"
|
HelpKey KeyCode = "Help"
|
||||||
BackspaceKey = "Backspace"
|
BackspaceKey KeyCode = "Backspace"
|
||||||
ArrowLeftKey = "ArrowLeft"
|
ArrowLeftKey KeyCode = "ArrowLeft"
|
||||||
ArrowRightKey = "ArrowRight"
|
ArrowRightKey KeyCode = "ArrowRight"
|
||||||
ArrowUpKey = "ArrowUp"
|
ArrowUpKey KeyCode = "ArrowUp"
|
||||||
ArrowDownKey = "ArrowDown"
|
ArrowDownKey KeyCode = "ArrowDown"
|
||||||
HomeKey = "Home"
|
HomeKey KeyCode = "Home"
|
||||||
EndKey = "End"
|
EndKey KeyCode = "End"
|
||||||
PageUpKey = "PageUp"
|
PageUpKey KeyCode = "PageUp"
|
||||||
PageDownKey = "PageDown"
|
PageDownKey KeyCode = "PageDown"
|
||||||
F1Key = "F1"
|
F1Key KeyCode = "F1"
|
||||||
F2Key = "F2"
|
F2Key KeyCode = "F2"
|
||||||
F3Key = "F3"
|
F3Key KeyCode = "F3"
|
||||||
F4Key = "F4"
|
F4Key KeyCode = "F4"
|
||||||
F5Key = "F5"
|
F5Key KeyCode = "F5"
|
||||||
F6Key = "F6"
|
F6Key KeyCode = "F6"
|
||||||
F7Key = "F7"
|
F7Key KeyCode = "F7"
|
||||||
F8Key = "F8"
|
F8Key KeyCode = "F8"
|
||||||
F9Key = "F9"
|
F9Key KeyCode = "F9"
|
||||||
F10Key = "F10"
|
F10Key KeyCode = "F10"
|
||||||
F11Key = "F11"
|
F11Key KeyCode = "F11"
|
||||||
F12Key = "F12"
|
F12Key KeyCode = "F12"
|
||||||
F13Key = "F13"
|
F13Key KeyCode = "F13"
|
||||||
NumLockKey = "NumLock"
|
NumLockKey KeyCode = "NumLock"
|
||||||
NumpadKey0 = "Numpad0"
|
NumpadKey0 KeyCode = "Numpad0"
|
||||||
NumpadKey1 = "Numpad1"
|
NumpadKey1 KeyCode = "Numpad1"
|
||||||
NumpadKey2 = "Numpad2"
|
NumpadKey2 KeyCode = "Numpad2"
|
||||||
NumpadKey3 = "Numpad3"
|
NumpadKey3 KeyCode = "Numpad3"
|
||||||
NumpadKey4 = "Numpad4"
|
NumpadKey4 KeyCode = "Numpad4"
|
||||||
NumpadKey5 = "Numpad5"
|
NumpadKey5 KeyCode = "Numpad5"
|
||||||
NumpadKey6 = "Numpad6"
|
NumpadKey6 KeyCode = "Numpad6"
|
||||||
NumpadKey7 = "Numpad7"
|
NumpadKey7 KeyCode = "Numpad7"
|
||||||
NumpadKey8 = "Numpad8"
|
NumpadKey8 KeyCode = "Numpad8"
|
||||||
NumpadKey9 = "Numpad9"
|
NumpadKey9 KeyCode = "Numpad9"
|
||||||
NumpadDecimalKey = "NumpadDecimal"
|
NumpadDecimalKey KeyCode = "NumpadDecimal"
|
||||||
NumpadEnterKey = "NumpadEnter"
|
NumpadEnterKey KeyCode = "NumpadEnter"
|
||||||
NumpadAddKey = "NumpadAdd"
|
NumpadAddKey KeyCode = "NumpadAdd"
|
||||||
NumpadSubtractKey = "NumpadSubtract"
|
NumpadSubtractKey KeyCode = "NumpadSubtract"
|
||||||
NumpadMultiplyKey = "NumpadMultiply"
|
NumpadMultiplyKey KeyCode = "NumpadMultiply"
|
||||||
NumpadDivideKey = "NumpadDivide"
|
NumpadDivideKey KeyCode = "NumpadDivide"
|
||||||
ShiftLeftKey = "ShiftLeft"
|
ShiftLeftKey KeyCode = "ShiftLeft"
|
||||||
ShiftRightKey = "ShiftRight"
|
ShiftRightKey KeyCode = "ShiftRight"
|
||||||
ControlLeftKey = "ControlLeft"
|
ControlLeftKey KeyCode = "ControlLeft"
|
||||||
ControlRightKey = "ControlRight"
|
ControlRightKey KeyCode = "ControlRight"
|
||||||
AltLeftKey = "AltLeft"
|
AltLeftKey KeyCode = "AltLeft"
|
||||||
AltRightKey = "AltRight"
|
AltRightKey KeyCode = "AltRight"
|
||||||
MetaLeftKey = "MetaLeft"
|
MetaLeftKey KeyCode = "MetaLeft"
|
||||||
MetaRightKey = "MetaRight"
|
MetaRightKey KeyCode = "MetaRight"
|
||||||
)
|
)
|
||||||
|
|
||||||
type KeyEvent struct {
|
type KeyEvent struct {
|
||||||
|
|
61
session.go
61
session.go
|
@ -100,10 +100,17 @@ type Session interface {
|
||||||
// OpenURL opens the url in the new browser tab
|
// OpenURL opens the url in the new browser tab
|
||||||
OpenURL(url string)
|
OpenURL(url string)
|
||||||
|
|
||||||
|
// ClientItem reads value by key from the client-side storage
|
||||||
ClientItem(key string) (string, bool)
|
ClientItem(key string) (string, bool)
|
||||||
|
// SetClientItem stores a key-value pair in the client-side storage
|
||||||
SetClientItem(key, value string)
|
SetClientItem(key, value string)
|
||||||
|
// RemoveAllClientItems removes all key-value pair from the client-side storage
|
||||||
RemoveAllClientItems()
|
RemoveAllClientItems()
|
||||||
|
|
||||||
|
// SetHotKey sets the function that will be called when the given hotkey is pressed.
|
||||||
|
// Invoke SetHotKey(..., ..., nil) for remove hotkey function.
|
||||||
|
SetHotKey(keyCode KeyCode, controlKeys ControlKeyMask, fn func(Session))
|
||||||
|
|
||||||
getCurrentTheme() Theme
|
getCurrentTheme() Theme
|
||||||
registerAnimation(props []AnimatedProperty) string
|
registerAnimation(props []AnimatedProperty) string
|
||||||
|
|
||||||
|
@ -188,6 +195,7 @@ type sessionData struct {
|
||||||
animationCSS string
|
animationCSS string
|
||||||
updateScripts map[string]*strings.Builder
|
updateScripts map[string]*strings.Builder
|
||||||
clientStorage map[string]string
|
clientStorage map[string]string
|
||||||
|
hotkeys map[string]func(Session)
|
||||||
}
|
}
|
||||||
|
|
||||||
func newSession(app Application, id int, customTheme string, params DataObject) Session {
|
func newSession(app Application, id int, customTheme string, params DataObject) Session {
|
||||||
|
@ -205,6 +213,7 @@ func newSession(app Application, id int, customTheme string, params DataObject)
|
||||||
session.animationCSS = ""
|
session.animationCSS = ""
|
||||||
session.updateScripts = map[string]*strings.Builder{}
|
session.updateScripts = map[string]*strings.Builder{}
|
||||||
session.clientStorage = map[string]string{}
|
session.clientStorage = map[string]string{}
|
||||||
|
session.hotkeys = map[string]func(Session){}
|
||||||
|
|
||||||
if customTheme != "" {
|
if customTheme != "" {
|
||||||
if theme, ok := CreateThemeFromText(customTheme); ok {
|
if theme, ok := CreateThemeFromText(customTheme); ok {
|
||||||
|
@ -672,7 +681,57 @@ func (session *sessionData) hotKey(event KeyEvent) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// TODO
|
|
||||||
|
var controlKeys ControlKeyMask = 0
|
||||||
|
if event.AltKey {
|
||||||
|
controlKeys |= AltKey
|
||||||
|
}
|
||||||
|
if event.CtrlKey {
|
||||||
|
controlKeys |= CtrlKey
|
||||||
|
}
|
||||||
|
if event.MetaKey {
|
||||||
|
controlKeys |= MetaKey
|
||||||
|
}
|
||||||
|
if event.ShiftKey {
|
||||||
|
controlKeys |= ShiftKey
|
||||||
|
}
|
||||||
|
|
||||||
|
key := hotkeyCode(KeyCode(event.Code), controlKeys)
|
||||||
|
if fn, ok := session.hotkeys[key]; ok && fn != nil {
|
||||||
|
fn(session)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func hotkeyCode(keyCode KeyCode, controlKeys ControlKeyMask) string {
|
||||||
|
buffer := allocStringBuilder()
|
||||||
|
defer freeStringBuilder(buffer)
|
||||||
|
|
||||||
|
buffer.WriteString(strings.ToLower(string(keyCode)))
|
||||||
|
if controlKeys != 0 {
|
||||||
|
buffer.WriteRune('-')
|
||||||
|
if controlKeys&AltKey != 0 {
|
||||||
|
buffer.WriteRune('a')
|
||||||
|
}
|
||||||
|
if controlKeys&CtrlKey != 0 {
|
||||||
|
buffer.WriteRune('c')
|
||||||
|
}
|
||||||
|
if controlKeys&MetaKey != 0 {
|
||||||
|
buffer.WriteRune('m')
|
||||||
|
}
|
||||||
|
if controlKeys&ShiftKey != 0 {
|
||||||
|
buffer.WriteRune('s')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return buffer.String()
|
||||||
|
}
|
||||||
|
|
||||||
|
func (session *sessionData) SetHotKey(keyCode KeyCode, controlKeys ControlKeyMask, fn func(Session)) {
|
||||||
|
hotkey := hotkeyCode(keyCode, controlKeys)
|
||||||
|
if fn == nil {
|
||||||
|
delete(session.hotkeys, hotkey)
|
||||||
|
} else {
|
||||||
|
session.hotkeys[hotkey] = fn
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (session *sessionData) SetTitle(title string) {
|
func (session *sessionData) SetTitle(title string) {
|
||||||
|
|
Loading…
Reference in New Issue