fix: add input search focus & blur methods

pull/77/merge
tjz 2018-06-10 09:29:18 +08:00
parent 88f165edb5
commit 3cff62997d
3 changed files with 49 additions and 9 deletions

View File

@ -29,6 +29,13 @@ export default {
this.$emit('search', this.$refs.input.stateValue)
this.$refs.input.focus()
},
focus () {
this.$refs.input.focus()
},
blur () {
this.$refs.input.blur()
},
getButtonOrIcon () {
const { prefixCls, size } = this
const enterButton = getComponentFromProp(this, 'enterButton')
@ -45,7 +52,7 @@ export default {
},
})
} else if (enterButtonAsElement.tag === 'button') {
return cloneElement(enterButtonAsElement[0], {
return cloneElement(enterButtonAsElement, {
on: {
click: this.onSearch,
},
@ -93,14 +100,7 @@ export default {
{...inputProps}
class={inputClassName}
ref='input'
>
{/* <Icon
slot='suffix'
class={`${prefixCls}-icon`}
onClick={this.onSearch}
type='search'
/> */}
</Input>
/>
)
},
}

View File

@ -0,0 +1,31 @@
import { mount } from '@vue/test-utils'
import { asyncExpect } from '@/tests/utils'
import Search from '../Search'
import Button from '../../button'
import focusTest from '../../../tests/shared/focusTest'
describe('Input.Search', () => {
focusTest(Search)
it('should support custom button', async () => {
const wrapper = mount({
render () {
return <Search enterButton={<button>ok</button>} />
},
}, { sync: false })
await asyncExpect(() => {
expect(wrapper.html()).toMatchSnapshot()
})
})
it('should support custom Button', async () => {
const wrapper = mount({
render () {
return <Search enterButton={<Button>ok</Button>} />
},
}, { sync: false })
await asyncExpect(() => {
expect(wrapper.html()).toMatchSnapshot()
})
})
})

View File

@ -0,0 +1,9 @@
// Jest Snapshot v1, https://goo.gl/fbAQLP
exports[`Input.Search should support custom Button 1`] = `
<span class="ant-input-search ant-input-search-enter-button ant-input-affix-wrapper ant-input-search ant-input-search-enter-button"><input type="text" class="ant-input ant-input-search ant-input-search-enter-button"><span class="ant-input-suffix"><button type="button" class="ant-btn ant-btn-default ant-input-search-button"><span>ok</span></button>
</span>
</span>
`;
exports[`Input.Search should support custom button 1`] = `<span class="ant-input-search ant-input-search-enter-button ant-input-affix-wrapper ant-input-search ant-input-search-enter-button"><input type="text" class="ant-input ant-input-search ant-input-search-enter-button"><span class="ant-input-suffix"><button class="">ok</button></span></span>`;