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