diff options
Diffstat (limited to 'src/pages')
-rw-r--r-- | src/pages/completion.js | 27 | ||||
-rw-r--r-- | src/pages/console.js | 120 |
2 files changed, 29 insertions, 118 deletions
diff --git a/src/pages/completion.js b/src/pages/completion.js deleted file mode 100644 index 4c69afb..0000000 --- a/src/pages/completion.js +++ /dev/null @@ -1,27 +0,0 @@ -export default class Completion { - constructor(completions) { - if (typeof completions.length !== 'number') { - throw new TypeError('completions does not have a length in number'); - } - this.completions = completions; - this.index = 0; - } - - prev() { - let length = this.completions.length; - if (length === 0) { - return null; - } - this.index = (this.index + length - 1) % length; - return this.completions[this.index]; - } - - next() { - if (this.completions.length === 0) { - return null; - } - let item = this.completions[this.index]; - this.index = (this.index + 1) % this.completions.length; - return item; - } -} diff --git a/src/pages/console.js b/src/pages/console.js index 31f2643..40e713e 100644 --- a/src/pages/console.js +++ b/src/pages/console.js @@ -1,61 +1,41 @@ import './console.scss'; -import Completion from './completion'; import messages from '../content/messages'; +import CompletionComponent from '../components/completion'; +import completionReducer from '../reducers/completion'; +import * as store from '../store'; +import * as completionActions from '../actions/completion'; + +const completionStore = store.createStore(completionReducer); +let completionComponent = null; + +window.addEventListener('load', () => { + let wrapper = document.querySelector('#vimvixen-console-completion'); + completionComponent = new CompletionComponent(wrapper, completionStore); +}); // TODO consider object-oriented let prevValue = ''; -let completion = null; let completionOrigin = ''; let prevState = {}; -const handleBlur = () => { - return browser.runtime.sendMessage({ - type: messages.CONSOLE_BLURRED, - }); -}; - -const selectCompletion = (target) => { - let container = window.document.querySelector('#vimvixen-console-completion'); - Array.prototype.forEach.call(container.children, (ele) => { - if (!ele.classList.contains('vimvixen-console-completion-item')) { - return; - } - if (ele === target) { - ele.classList.add('vimvixen-completion-selected'); - } else { - ele.classList.remove('vimvixen-completion-selected'); - } - }); -}; - -const completeNext = () => { - if (!completion) { - return; - } - let item = completion.next(); - if (!item) { - return; - } +completionStore.subscribe(() => { + completionComponent.update(); + let state = completionStore.getState(); let input = window.document.querySelector('#vimvixen-console-command-input'); - input.value = completionOrigin + ' ' + item[0].content; - selectCompletion(item[1]); -}; - -const completePrev = () => { - if (!completion) { - return; + if (state.groupSelection >= 0) { + let item = state.groups[state.groupSelection].items[state.itemSelection]; + input.value = completionOrigin + ' ' + item.content; + } else if (state.groups.length > 0) { + input.value = completionOrigin + ' '; } - let item = completion.prev(); - if (!item) { - return; - } - - let input = window.document.querySelector('#vimvixen-console-command-input'); - input.value = completionOrigin + ' ' + item[0].content; +}); - selectCompletion(item[1]); +const handleBlur = () => { + return browser.runtime.sendMessage({ + type: messages.CONSOLE_BLURRED, + }); }; const handleKeydown = (e) => { @@ -71,9 +51,9 @@ const handleKeydown = (e) => { }); case KeyboardEvent.DOM_VK_TAB: if (e.shiftKey) { - completePrev(); + completionStore.dispatch(completionActions.selectPrev()); } else { - completeNext(); + completionStore.dispatch(completionActions.selectNext()); } e.stopPropagation(); e.preventDefault(); @@ -102,52 +82,10 @@ window.addEventListener('load', () => { input.addEventListener('keyup', handleKeyup); }); -const createCompletionTitle = (text) => { - let li = document.createElement('li'); - li.className = 'vimvixen-console-completion-title'; - li.textContent = text; - return li; -}; - -const createCompletionItem = (icon, caption, url) => { - let captionEle = document.createElement('span'); - captionEle.className = 'vimvixen-console-completion-item-caption'; - captionEle.textContent = caption; - - let urlEle = document.createElement('span'); - urlEle.className = 'vimvixen-console-completion-item-url'; - urlEle.textContent = url; - - let li = document.createElement('li'); - li.style.backgroundImage = 'url(' + icon + ')'; - li.className = 'vimvixen-console-completion-item'; - li.append(captionEle); - li.append(urlEle); - return li; -}; - const updateCompletions = (completions) => { - let completionsContainer = - window.document.querySelector('#vimvixen-console-completion'); - let input = window.document.querySelector('#vimvixen-console-command-input'); - - completionsContainer.innerHTML = ''; - - let pairs = []; - - for (let group of completions) { - let title = createCompletionTitle(group.name); - completionsContainer.append(title); + completionStore.dispatch(completionActions.setItems(completions)); - for (let item of group.items) { - let li = createCompletionItem(item.icon, item.caption, item.url); - completionsContainer.append(li); - - pairs.push([item, li]); - } - } - - completion = new Completion(pairs); + let input = window.document.querySelector('#vimvixen-console-command-input'); completionOrigin = input.value.split(' ')[0]; }; |