parent
be37c42d28
commit
e1c70769ea
6 changed files with 124 additions and 0 deletions
@ -0,0 +1,36 @@ |
||||
//
|
||||
// window.find(aString, aCaseSensitive, aBackwards, aWrapAround,
|
||||
// aWholeWord, aSearchInFrames, aShowDialog);
|
||||
//
|
||||
// NOTE: window.find is not standard API
|
||||
// https://developer.mozilla.org/en-US/docs/Web/API/Window/find
|
||||
|
||||
import actions from 'content/actions'; |
||||
|
||||
const show = () => { |
||||
return { type: actions.FIND_SHOW }; |
||||
}; |
||||
|
||||
const hide = () => { |
||||
return { type: actions.FIND_HIDE }; |
||||
}; |
||||
|
||||
const next = (keyword) => { |
||||
// TODO Error on no matched
|
||||
window.find(keyword, false, false, true, false, true, false); |
||||
return { |
||||
type: actions.FIND_SET_KEYWORD, |
||||
keyword, |
||||
}; |
||||
}; |
||||
|
||||
const prev = (keyword) => { |
||||
// TODO Error on no matched
|
||||
window.find(keyword, false, true, true, false, true, false); |
||||
return { |
||||
type: actions.FIND_SET_KEYWORD, |
||||
keyword, |
||||
}; |
||||
}; |
||||
|
||||
export { show, hide, next, prev }; |
@ -0,0 +1,25 @@ |
||||
import actions from 'content/actions'; |
||||
|
||||
const defaultState = { |
||||
enabled: false, |
||||
keyword: '', |
||||
}; |
||||
|
||||
export default function reducer(state = defaultState, action = {}) { |
||||
switch (action.type) { |
||||
case actions.FIND_SHOW: |
||||
return Object.assign({}, state, { |
||||
enabled: true, |
||||
}); |
||||
case actions.FIND_HIDE: |
||||
return Object.assign({}, state, { |
||||
enabled: false, |
||||
}); |
||||
case actions.FIND_SET_KEYWORD: |
||||
return Object.assign({}, state, { |
||||
keyword: action.keyword, |
||||
}); |
||||
default: |
||||
return state; |
||||
} |
||||
} |
@ -0,0 +1,19 @@ |
||||
import { expect } from "chai"; |
||||
import actions from 'content/actions'; |
||||
import * as findActions from 'content/actions/find'; |
||||
|
||||
describe("find actions", () => { |
||||
describe("show", () => { |
||||
it('create FIND_SHOW action', () => { |
||||
let action = findActions.show(); |
||||
expect(action.type).to.equal(actions.FIND_SHOW); |
||||
}); |
||||
}); |
||||
|
||||
describe("hide", () => { |
||||
it('create FIND_HIDE action', () => { |
||||
let action = findActions.hide(); |
||||
expect(action.type).to.equal(actions.FIND_HIDE); |
||||
}); |
||||
}); |
||||
}); |
@ -0,0 +1,36 @@ |
||||
import { expect } from "chai"; |
||||
import actions from 'content/actions'; |
||||
import findReducer from 'content/reducers/find'; |
||||
|
||||
describe("find reducer", () => { |
||||
it('return the initial state', () => { |
||||
let state = findReducer(undefined, {}); |
||||
expect(state).to.have.property('enabled', false); |
||||
expect(state).to.have.property('keyword', ''); |
||||
}); |
||||
|
||||
it('return next state for FIND_SHOW', () => { |
||||
let action = { type: actions.FIND_SHOW }; |
||||
let prev = { enabled: false }; |
||||
let state = findReducer(prev, action); |
||||
|
||||
expect(state.enabled).is.equal(true); |
||||
}); |
||||
|
||||
it('return next state for FIND_HIDE', () => { |
||||
let action = { type: actions.FIND_HIDE }; |
||||
let prev = { enabled: true }; |
||||
let state = findReducer(prev, action); |
||||
|
||||
expect(state.enabled).is.equal(false); |
||||
}); |
||||
|
||||
it('return next state for FIND_SET_KEYWORD', () => { |
||||
let action = { type: actions.FIND_SET_KEYWORD, keyword: 'my-search' }; |
||||
let state = { enabled: true, keyword: '' }; |
||||
|
||||
state = findReducer(state, action); |
||||
|
||||
expect(state.keyword).is.equal('my-search'); |
||||
}); |
||||
}); |
Reference in new issue