Skip to content

Commit

Permalink
Merge pull request alibaba-fusion#290 from bindoon/fix-input-in-ie
Browse files Browse the repository at this point in the history
Fix input in ie, Select can add tag with visible=false
  • Loading branch information
youluna authored Feb 13, 2019
2 parents 3677330 + 217348a commit 5c4e6c6
Show file tree
Hide file tree
Showing 9 changed files with 55 additions and 24 deletions.
4 changes: 2 additions & 2 deletions docs/field/demo/basic.md
Original file line number Diff line number Diff line change
Expand Up @@ -19,8 +19,8 @@ import { Input, Button, Field } from '@alifd/next';



class App extends React.PureComponent {
field = new Field(this, {forceUpdate: true});
class App extends React.Component {
field = new Field(this);

onGetValue() {
console.log(this.field.getValue('input'));
Expand Down
4 changes: 1 addition & 3 deletions docs/field/demo/mix.md
Original file line number Diff line number Diff line change
Expand Up @@ -39,9 +39,7 @@ const layout = {
};

class App extends React.Component {
field = new Field(this, {
deepReset: true
});
field = new Field(this);

render() {
const {init, getValue} = this.field;
Expand Down
1 change: 1 addition & 0 deletions docs/field/index.en-us.md
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ Fields can be used to manage data when it comes to form data manipulation and va
- With Field `init` components, `value` `onChange` must be placed in init's third argument, otherwise it may be overridden by init.
- `Form` has been deeply optimized with `Field` for `data acquisition` and `automatic verification prompt`. It is recommended to use `Field` in `Form`. Please check Form demo.
- initValue The defaultValue of a similar component, which only takes effect when the component first renders (the ajax asynchronous invocation setting initValue may have missed the first render)
- with `parseName=true` you could use `getValues` to get a struct value, but not work in `getValue` you still need pass complete key

### basic use

Expand Down
1 change: 1 addition & 0 deletions docs/field/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@
- `Form`已经和`Field``数据获取``自动校验提示`方面做了深度优化,建议在`Form`中使用`Field`, 请查看 Form demo。
- initValue 类似组件的 defaultValue 只有在组件第一次render的时候才生效(ajax 异步调用设置 initValue 可能已经错过了第一次render)
- autoUnmount 默认打开的,如果需要保留会 `自动卸载的组件` 数据请关闭此项
- `parseName=true` 可以通过 `getValues` 获取到结构化的数据, 但是 getValue 还是必须传完整 key 值

### 基本使用

Expand Down
4 changes: 2 additions & 2 deletions docs/select/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,7 @@ const dataSource = [
| placeholder | 没有值的时候的占位符 | String | - |
| autoWidth | 下拉菜单是否与选择器对齐 | Boolean | true |
| label | 自定义内联 label | ReactNode | - |
| hasClear | 是否有清除按钮 | Boolean | - |
| hasClear | 是否有清除按钮(单选模式有效) | Boolean | - |
| state | 校验状态<br><br>**可选值**:<br>'error', 'loading' | Enum | - |
| readOnly | 是否只读,只读模式下可以展开弹层但不能选 | Boolean | - |
| disabled | 是否禁用选择器 | Boolean | - |
Expand Down Expand Up @@ -117,7 +117,7 @@ const dataSource = [
| placeholder | 没有值的时候的占位符 | String | - |
| autoWidth | 下拉菜单是否与选择器对齐 | Boolean | true |
| label | 自定义内联 label | ReactNode | - |
| hasClear | 是否有清除按钮 | Boolean | - |
| hasClear | 是否有清除按钮(单选模式有效) | Boolean | - |
| state | 校验状态<br><br>**可选值**:<br>'error', 'loading' | Enum | - |
| readOnly | 是否只读,只读模式下可以展开弹层但不能选 | Boolean | - |
| disabled | 是否禁用选择器 | Boolean | - |
Expand Down
6 changes: 5 additions & 1 deletion src/input/main.scss
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,6 @@
vertical-align: middle;
background-color: transparent;
color: $input-text-color;
@include input-placeholder($input-placeholder-color);

&::-ms-clear {
display: none;
Expand Down Expand Up @@ -204,6 +203,11 @@
color: $input-label-color;
}

input,
textarea {
@include input-placeholder($input-placeholder-color);
}

&.#{$css-prefix}disabled {
@include input-disabled();

Expand Down
2 changes: 1 addition & 1 deletion src/select/base.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ export default class Base extends React.Component {
*/
label: PropTypes.node,
/**
* 是否有清除按钮
* 是否有清除按钮(单选模式有效)
*/
hasClear: PropTypes.bool,
/**
Expand Down
39 changes: 25 additions & 14 deletions src/select/select.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -454,10 +454,33 @@ class Select extends Base {
onKeyDown(e);
}

chooseMultipleItem(key) {
const value = this.state.value || [];
const keys = value.map(v => {
return valueToSelectKey(v);
});

const index = keys.map(v => `${v}`).indexOf(key);

if (index > -1) { // unselect
keys.splice(index, 1);
} else { // select
keys.push(key);
}

this.handleMultipleSelect(keys, 'enter');
}

// 回车 选择高亮的 item
chooseHighlightItem(proxy, e) {
const prevVisible = this.state.visible;
const { mode } = this.props;

if (!prevVisible) {
// input tag by itself
if (mode === 'tag' && this.state.searchValue) {
this.chooseMultipleItem(this.state.searchValue);
}
return false;
}

Expand All @@ -468,22 +491,10 @@ class Select extends Base {
return;
}

const { mode } = this.props;

if (mode === 'single') {
this.handleSingleSelect(highlightKey, 'enter');
} else {
const value = this.state.value || [];
const keys = value.map(v => {
return valueToSelectKey(v);
});
const index = keys.map(v => `${v}`).indexOf(highlightKey);
if (index > -1) { // 反选
keys.splice(index, 1);
} else { // 勾选
keys.push(highlightKey);
}
this.handleMultipleSelect(keys, 'enter');
this.chooseMultipleItem(highlightKey);
// 阻止事件冒泡到最外层,让Popup 监听到触发弹层关闭
e && e.stopPropagation();
}
Expand Down Expand Up @@ -674,7 +685,7 @@ class Select extends Base {
type="arrow-down" /></span>);
}

// 不能使用 this.hasClear() 方法判断,要保证 clear 按钮 dom 结构一直存在,防止其不能成为弹层的安全节点,导致弹层没有必要的显示或隐藏
// do not use this.hasClear() here, to make sure clear btn always exists, can not influenced by apis like `disabled` `readOnly`
if (hasClear) {
ret.push(<span key="clear" onClick={this.handleClear} className={`${prefix}select-clear`}><Icon
type="delete-filling" /></span>);
Expand Down
18 changes: 17 additions & 1 deletion test/select/index-spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -352,7 +352,23 @@ describe('Select', () => {
wrapper.find('div.next-tag .next-tag-close-btn').simulate('click');
});

it('should support clear', (done) => {
it('should support mode=tag with visible=false', (done) => {
wrapper.setProps({
mode: 'tag',
visible: false,
value: ['yyy'],
onChange: function (value) {
assert(value.length === 2);
assert(value[1] === 'bbb');
done();
}
});

wrapper.find('input').simulate('change', {target: {value: 'bbb'}});
wrapper.find('input').simulate('keydown', {keyCode: 13});
});

it('should support mode=tag with hasClear', (done) => {
wrapper.setProps({
mode: 'tag',
hasClear: true,
Expand Down

0 comments on commit 5c4e6c6

Please sign in to comment.