mirror of https://github.com/ElemeFE/element
Cascader: auto scroll to selected option
parent
8b5d208675
commit
e1cda09cf4
|
@ -1,5 +1,6 @@
|
||||||
<script>
|
<script>
|
||||||
import { isDef } from 'element-ui/src/utils/shared';
|
import { isDef } from 'element-ui/src/utils/shared';
|
||||||
|
import scrollIntoView from 'element-ui/src/utils/scroll-into-view';
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: 'ElCascaderMenu',
|
name: 'ElCascaderMenu',
|
||||||
|
@ -94,6 +95,19 @@
|
||||||
} else {
|
} else {
|
||||||
this.$emit('activeItemChange', this.activeValue);
|
this.$emit('activeItemChange', this.activeValue);
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
scrollMenu(menu) {
|
||||||
|
scrollIntoView(menu, menu.getElementsByClassName('is-active')[0]);
|
||||||
|
},
|
||||||
|
handleMenuEnter() {
|
||||||
|
this.$nextTick(() => this.getMenus().forEach(menu => this.scrollMenu(menu)));
|
||||||
|
},
|
||||||
|
getMenus() {
|
||||||
|
if (this.$refs.wrapper) {
|
||||||
|
return Array.prototype.slice.call(this.$refs.wrapper.getElementsByClassName('el-cascader-menu'));
|
||||||
|
} else {
|
||||||
|
return [];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -121,9 +135,19 @@
|
||||||
click: 'click',
|
click: 'click',
|
||||||
hover: 'mouseenter'
|
hover: 'mouseenter'
|
||||||
}[expandTrigger];
|
}[expandTrigger];
|
||||||
events.on[triggerEvent] = () => { this.activeItem(item, menuIndex); };
|
events.on[triggerEvent] = () => {
|
||||||
|
this.activeItem(item, menuIndex);
|
||||||
|
this.$nextTick(() => {
|
||||||
|
// adjust self and next level
|
||||||
|
this.scrollMenu(this.getMenus()[menuIndex]);
|
||||||
|
this.scrollMenu(this.getMenus()[menuIndex + 1]);
|
||||||
|
});
|
||||||
|
};
|
||||||
} else {
|
} else {
|
||||||
events.on.click = () => { this.select(item, menuIndex); };
|
events.on.click = () => {
|
||||||
|
this.select(item, menuIndex);
|
||||||
|
this.$nextTick(() => this.scrollMenu(this.getMenus()[menuIndex]));
|
||||||
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -158,13 +182,14 @@
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
return (
|
return (
|
||||||
<transition name="el-zoom-in-top" on-after-leave={this.handleMenuLeave}>
|
<transition name="el-zoom-in-top" on-before-enter={this.handleMenuEnter} on-after-leave={this.handleMenuLeave}>
|
||||||
<div
|
<div
|
||||||
v-show={visible}
|
v-show={visible}
|
||||||
class={[
|
class={[
|
||||||
'el-cascader-menus',
|
'el-cascader-menus',
|
||||||
popperClass
|
popperClass
|
||||||
]}
|
]}
|
||||||
|
ref="wrapper"
|
||||||
>
|
>
|
||||||
{menus}
|
{menus}
|
||||||
</div>
|
</div>
|
||||||
|
|
Loading…
Reference in New Issue