add global find keyword
This commit is contained in:
parent
4923cb20c7
commit
24e72aa6e0
8 changed files with 74 additions and 0 deletions
10
src/background/actions/find.js
Normal file
10
src/background/actions/find.js
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
import actions from './index';
|
||||||
|
|
||||||
|
const setKeyword = (keyword) => {
|
||||||
|
return {
|
||||||
|
type: actions.FIND_SET_KEYWORD,
|
||||||
|
keyword,
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
export { setKeyword };
|
|
@ -2,4 +2,7 @@ export default {
|
||||||
// Settings
|
// Settings
|
||||||
SETTING_SET_SETTINGS: 'setting.set.settings',
|
SETTING_SET_SETTINGS: 'setting.set.settings',
|
||||||
SETTING_SET_PROPERTY: 'setting.set.property',
|
SETTING_SET_PROPERTY: 'setting.set.property',
|
||||||
|
|
||||||
|
// Find
|
||||||
|
FIND_SET_KEYWORD: 'find.set.keyword',
|
||||||
};
|
};
|
||||||
|
|
|
@ -2,6 +2,7 @@ import messages from 'shared/messages';
|
||||||
import * as operationActions from 'background/actions/operation';
|
import * as operationActions from 'background/actions/operation';
|
||||||
import * as commandActions from 'background/actions/command';
|
import * as commandActions from 'background/actions/command';
|
||||||
import * as settingActions from 'background/actions/setting';
|
import * as settingActions from 'background/actions/setting';
|
||||||
|
import * as findActions from 'background/actions/find';
|
||||||
import * as tabActions from 'background/actions/tab';
|
import * as tabActions from 'background/actions/tab';
|
||||||
import * as commands from 'shared/commands';
|
import * as commands from 'shared/commands';
|
||||||
|
|
||||||
|
@ -23,6 +24,8 @@ export default class BackgroundComponent {
|
||||||
|
|
||||||
onMessage(message, sender) {
|
onMessage(message, sender) {
|
||||||
let settings = this.store.getState().setting;
|
let settings = this.store.getState().setting;
|
||||||
|
let find = this.store.getState().find;
|
||||||
|
|
||||||
switch (message.type) {
|
switch (message.type) {
|
||||||
case messages.BACKGROUND_OPERATION:
|
case messages.BACKGROUND_OPERATION:
|
||||||
return this.store.dispatch(
|
return this.store.dispatch(
|
||||||
|
@ -48,6 +51,11 @@ export default class BackgroundComponent {
|
||||||
case messages.SETTINGS_RELOAD:
|
case messages.SETTINGS_RELOAD:
|
||||||
this.store.dispatch(settingActions.load());
|
this.store.dispatch(settingActions.load());
|
||||||
return this.broadcastSettingsChanged();
|
return this.broadcastSettingsChanged();
|
||||||
|
case messages.FIND_GET_KEYWORD:
|
||||||
|
return Promise.resolve(find.keyword);
|
||||||
|
case messages.FIND_SET_KEYWORD:
|
||||||
|
this.store.dispatch(findActions.setKeyword(message.keyword));
|
||||||
|
return Promise.resolve({});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
16
src/background/reducers/find.js
Normal file
16
src/background/reducers/find.js
Normal file
|
@ -0,0 +1,16 @@
|
||||||
|
import actions from 'content/actions';
|
||||||
|
|
||||||
|
const defaultState = {
|
||||||
|
keyword: null,
|
||||||
|
};
|
||||||
|
|
||||||
|
export default function reducer(state = defaultState, action = {}) {
|
||||||
|
switch (action.type) {
|
||||||
|
case actions.FIND_SET_KEYWORD:
|
||||||
|
return Object.assign({}, state, {
|
||||||
|
keyword: action.keyword,
|
||||||
|
});
|
||||||
|
default:
|
||||||
|
return state;
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,12 +1,15 @@
|
||||||
import settingReducer from './setting';
|
import settingReducer from './setting';
|
||||||
|
import findReducer from './find';
|
||||||
|
|
||||||
// Make setting reducer instead of re-use
|
// Make setting reducer instead of re-use
|
||||||
const defaultState = {
|
const defaultState = {
|
||||||
setting: settingReducer(undefined, {}),
|
setting: settingReducer(undefined, {}),
|
||||||
|
find: findReducer(undefined, {}),
|
||||||
};
|
};
|
||||||
|
|
||||||
export default function reducer(state = defaultState, action = {}) {
|
export default function reducer(state = defaultState, action = {}) {
|
||||||
return Object.assign({}, state, {
|
return Object.assign({}, state, {
|
||||||
setting: settingReducer(state.setting, action),
|
setting: settingReducer(state.setting, action),
|
||||||
|
find: findReducer(state.find, action),
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -45,6 +45,8 @@ export default {
|
||||||
|
|
||||||
FIND_NEXT: 'find.next',
|
FIND_NEXT: 'find.next',
|
||||||
FIND_PREV: 'find.prev',
|
FIND_PREV: 'find.prev',
|
||||||
|
FIND_GET_KEYWORD: 'find.get.keyword',
|
||||||
|
FIND_SET_KEYWORD: 'find.set.keyword',
|
||||||
|
|
||||||
OPEN_URL: 'open.url',
|
OPEN_URL: 'open.url',
|
||||||
|
|
||||||
|
|
13
test/background/actions/find.test.js
Normal file
13
test/background/actions/find.test.js
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
import { expect } from "chai";
|
||||||
|
import actions from 'background/actions';
|
||||||
|
import * as findActions from 'background/actions/find';
|
||||||
|
|
||||||
|
describe("find actions", () => {
|
||||||
|
describe("setKeyword", () => {
|
||||||
|
it('create FIND_SET_KEYWORD action', () => {
|
||||||
|
let action = findActions.setKeyword('banana');
|
||||||
|
expect(action.type).to.equal(actions.FIND_SET_KEYWORD);
|
||||||
|
expect(action.keyword).to.equal('banana');
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
19
test/background/reducers/find.test.js
Normal file
19
test/background/reducers/find.test.js
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
import { expect } from "chai";
|
||||||
|
import actions from 'background/actions';
|
||||||
|
import findReducer from 'background/reducers/find';
|
||||||
|
|
||||||
|
describe("find reducer", () => {
|
||||||
|
it('return the initial state', () => {
|
||||||
|
let state = findReducer(undefined, {});
|
||||||
|
expect(state).to.have.deep.property('keyword', null);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('return next state for FIND_SET_KEYWORD', () => {
|
||||||
|
let action = {
|
||||||
|
type: actions.FIND_SET_KEYWORD,
|
||||||
|
keyword: 'cherry',
|
||||||
|
};
|
||||||
|
let state = findReducer(undefined, action);
|
||||||
|
expect(state).to.have.deep.property('keyword', 'cherry')
|
||||||
|
});
|
||||||
|
});
|
Reference in a new issue