Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feat/cycle through commands #605

Merged
merged 5 commits into from
Mar 19, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
46 changes: 45 additions & 1 deletion src/components/AChat/AChatForm.vue
Original file line number Diff line number Diff line change
Expand Up @@ -81,7 +81,9 @@ export default {
emits: ['message', 'esc', 'error'],
data: () => ({
message: '',
emojiPickerOpen: false
emojiPickerOpen: false,
botCommandIndex: null,
botCommandSelectionMode: false
}),
computed: {
isDesktopDevice: () => !isMobile(),
Expand Down Expand Up @@ -154,6 +156,12 @@ export default {
onKeyCommand: function (event) {
if (event.ctrlKey && event.shiftKey && event.code === 'Digit1') {
this.openElement()
} else if (event.code === 'ArrowUp' || event.code === 'ArrowDown') {
this.selectCommand(event.code)
event.preventDefault()
PaulDremanovich marked this conversation as resolved.
Show resolved Hide resolved
} else if (event.key.length === 1) {
this.botCommandSelectionMode = false
this.botCommandIndex = null
}
},
openElement() {
Expand Down Expand Up @@ -210,6 +218,12 @@ export default {
submitMessage() {
const error = this.validator(this.message)
if (error === false) {
if (this.message.startsWith('/')) {
this.$store.commit('botCommands/addCommand', {
partnerId: this.partnerId,
command: this.message
})
}
this.$emit('message', this.message)
this.message = ''
this.$store.commit('draftMessage/deleteMessage', {
Expand All @@ -232,6 +246,36 @@ export default {
},
focus() {
this.$refs.messageTextarea.focus()
},
selectCommand(direction) {
if (!this.message) {
this.botCommandSelectionMode = true
}
if (!this.botCommandSelectionMode) {
return
}
const commands = this.$store.getters['botCommands/getCommandsHistory'](this.partnerId)
const maxIndex = commands.length > 0 ? commands.length - 1 : 0
if (this.botCommandIndex === null) {
if (direction === 'ArrowUp') {
this.botCommandIndex = maxIndex
this.message = commands[this.botCommandIndex] || ''
}
return
}

if (direction === 'ArrowUp') {
if (this.botCommandIndex > 0) {
this.botCommandIndex--
this.message = commands[this.botCommandIndex] || ''
}
return
}

if (this.botCommandIndex < maxIndex) {
this.botCommandIndex++
this.message = commands[this.botCommandIndex] || ''
}
}
}
}
Expand Down
4 changes: 4 additions & 0 deletions src/store/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ import navigatorOnline from './plugins/navigatorOnline'
import socketsPlugin from './plugins/socketsPlugin'
import partnersModule from './modules/partners'
import admModule from './modules/adm'
import botCommandsModule from './modules/bot-commands'
import bitcoinModule from './modules/btc'
import dashModule from './modules/dash'
import delegatesModule from './modules/delegates'
Expand All @@ -29,6 +30,7 @@ import nodesModule from './modules/nodes'
import walletsModule from './modules/wallets'
import nodesPlugin from './modules/nodes/nodes-plugin'
import walletsPersistencePlugin from './modules/wallets/wallets-plugin'
import botCommandsPlugin from './modules/bot-commands/bot-commands-plugin'
import draftMessage from '@/store/modules/draft-message'
import snackbar from './modules/snackbar'
import language from './modules/language'
Expand Down Expand Up @@ -234,6 +236,7 @@ const store = {
partners: partnersModule, // Partners: display names, crypto addresses and so on
delegates: delegatesModule, // Voting for delegates screen
nodes: nodesModule, // ADAMANT nodes
botCommands: botCommandsModule,
snackbar,
draftMessage,
language,
Expand All @@ -257,6 +260,7 @@ registerVuexPlugins(storeInstance, [
indexedDbPlugin,
navigatorOnline,
socketsPlugin,
botCommandsPlugin,
walletsPersistencePlugin
])

Expand Down
9 changes: 9 additions & 0 deletions src/store/modules/bot-commands/bot-commands-actions.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
import { ActionTree } from 'vuex'
import { RootState } from '@/store/types'
import { BotCommand, BotCommandsState } from '@/store/modules/bot-commands/types.ts'

export const actions: ActionTree<BotCommandsState, RootState> = {
addBotCommand({ commit }, value: BotCommand): void {
commit('addCommand', value)
}
}
9 changes: 9 additions & 0 deletions src/store/modules/bot-commands/bot-commands-getters.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
import { GetterTree } from 'vuex'
import { RootState } from '@/store/types'
import { BotCommandsState } from '@/store/modules/bot-commands/types.ts'

export const getters: GetterTree<BotCommandsState, RootState> = {
getCommandsHistory: (state) => (parentId: string) => {
return state.commands[parentId] || []
}
}
14 changes: 14 additions & 0 deletions src/store/modules/bot-commands/bot-commands-mutations.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
import { MutationTree } from 'vuex'
import { BotCommand, BotCommandsState } from '@/store/modules/bot-commands/types.ts'

export const mutations: MutationTree<BotCommandsState> = {
addCommand(state, botCommand: BotCommand): void {
const commandValue = botCommand.command.trim()
const botCommands = state.commands[botCommand.partnerId]
if (!botCommands) {
state.commands[botCommand.partnerId] = [commandValue]
} else if (!botCommands.includes(commandValue)) {
botCommands.push(commandValue)
}
}
}
9 changes: 9 additions & 0 deletions src/store/modules/bot-commands/bot-commands-plugin.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
import VuexPersistence from 'vuex-persist'

const vuexPersistence = new VuexPersistence({
key: 'botCommands',
storage: window.sessionStorage,
modules: ['botCommands']
})

export default vuexPersistence.plugin
5 changes: 5 additions & 0 deletions src/store/modules/bot-commands/bot-commands-state.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
import { BotCommandsState } from '@/store/modules/bot-commands/types.ts'

export const state: BotCommandsState = {
commands: {}
}
17 changes: 17 additions & 0 deletions src/store/modules/bot-commands/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
import { actions } from './bot-commands-actions.ts'
import { mutations } from './bot-commands-mutations.ts'
import { state } from './bot-commands-state.ts'
import { getters } from './bot-commands-getters.ts'
import { Module } from 'vuex'
import { RootState } from '@/store/types'
import { BotCommandsState } from '@/store/modules/bot-commands/types.ts'

const bodCommandsModule: Module<BotCommandsState, RootState> = {
namespaced: true,
state,
mutations,
actions,
getters
}

export default bodCommandsModule
5 changes: 5 additions & 0 deletions src/store/modules/bot-commands/types.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
export interface BotCommandsState {
commands: Record<string, string[]>
}

export type BotCommand = { partnerId: string; command: string }
Loading