mirror of https://github.com/sveltejs/svelte
				
				
				
			Merge pull request #1376 from sveltejs/gh-1297
	
		
	
				
					
				
			overwrite this in custom event handlerspull/1381/head
						commit
						bf58a20909
					
				| @ -0,0 +1,22 @@ | |||||||
|  | export default { | ||||||
|  | 	html: `<input>`, | ||||||
|  | 
 | ||||||
|  | 	test(assert, component, target, window) { | ||||||
|  | 		const input = target.querySelector('input'); | ||||||
|  | 		const event = new window.KeyboardEvent('keydown', { | ||||||
|  | 			which: 13 | ||||||
|  | 		}); | ||||||
|  | 
 | ||||||
|  | 		let blurred = false; | ||||||
|  | 
 | ||||||
|  | 		input.focus(); | ||||||
|  | 
 | ||||||
|  | 		input.addEventListener('blur', () => { | ||||||
|  | 			blurred = true; | ||||||
|  | 		}); | ||||||
|  | 
 | ||||||
|  | 		input.dispatchEvent(event); | ||||||
|  | 
 | ||||||
|  | 		assert.ok(blurred); | ||||||
|  | 	}, | ||||||
|  | }; | ||||||
| @ -0,0 +1,23 @@ | |||||||
|  | <input on:enter='this.blur()'> | ||||||
|  | 
 | ||||||
|  | <script> | ||||||
|  | 	export default { | ||||||
|  | 		events: { | ||||||
|  | 			enter(node, callback) { | ||||||
|  | 				function handleKeydown(event) { | ||||||
|  | 					if (event.which === 13) { | ||||||
|  | 						callback(); | ||||||
|  | 					} | ||||||
|  | 				} | ||||||
|  | 
 | ||||||
|  | 				node.addEventListener('keydown', handleKeydown); | ||||||
|  | 
 | ||||||
|  | 				return { | ||||||
|  | 					destroy() { | ||||||
|  | 						node.removeEventListener('keydown', handleKeydown); | ||||||
|  | 					} | ||||||
|  | 				}; | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	}; | ||||||
|  | </script> | ||||||
					Loading…
					
					
				
		Reference in new issue