58 lines
1.3 KiB
Vue
58 lines
1.3 KiB
Vue
import classNames from '../_util/classNames';
|
|
import ResizeObserver from '../vc-resize-observer';
|
|
|
|
const Filter = ({ height, offset, prefixCls, onInnerResize }, { slots }) => {
|
|
let outerStyle = {};
|
|
|
|
let innerStyle = {
|
|
display: 'flex',
|
|
flexDirection: 'column',
|
|
};
|
|
|
|
if (offset !== undefined) {
|
|
outerStyle = { height: `${height}px`, position: 'relative', overflow: 'hidden' };
|
|
|
|
innerStyle = {
|
|
...innerStyle,
|
|
transform: `translateY(${offset}px)`,
|
|
position: 'absolute',
|
|
left: 0,
|
|
right: 0,
|
|
top: 0,
|
|
};
|
|
}
|
|
|
|
return (
|
|
<div style={outerStyle}>
|
|
<ResizeObserver
|
|
onResize={({ offsetHeight }) => {
|
|
if (offsetHeight && onInnerResize) {
|
|
onInnerResize();
|
|
}
|
|
}}
|
|
>
|
|
<div
|
|
style={innerStyle}
|
|
class={classNames({
|
|
[`${prefixCls}-holder-inner`]: prefixCls,
|
|
})}
|
|
>
|
|
{slots.default?.()}
|
|
</div>
|
|
</ResizeObserver>
|
|
</div>
|
|
);
|
|
};
|
|
Filter.displayName = 'Filter';
|
|
Filter.inheritAttrs = false;
|
|
Filter.props = {
|
|
prefixCls: String,
|
|
/** Virtual filler height. Should be `count * itemMinHeight` */
|
|
height: Number,
|
|
/** Set offset of visible items. Should be the top of start item position */
|
|
offset: Number,
|
|
onInnerResize: Function,
|
|
};
|
|
|
|
export default Filter;
|