element-plus
Version:
A Component Library for Vue 3
126 lines (121 loc) • 2.65 kB
JavaScript
'use strict';
Object.defineProperty(exports, '__esModule', { value: true });
require('../../../utils/index.js');
var defaults = require('./defaults.js');
var props = require('../../../utils/vue/props.js');
var typescript = require('../../../utils/typescript.js');
const itemSize = props.buildProp({
type: props.definePropType([Number, Function]),
required: true
});
const estimatedItemSize = props.buildProp({
type: Number
});
const cache = props.buildProp({
type: Number,
default: 2
});
const direction = props.buildProp({
type: String,
values: ["ltr", "rtl"],
default: "ltr"
});
const initScrollOffset = props.buildProp({
type: Number,
default: 0
});
const total = props.buildProp({
type: Number,
required: true
});
const layout = props.buildProp({
type: String,
values: ["horizontal", "vertical"],
default: defaults.VERTICAL
});
const virtualizedProps = props.buildProps({
className: {
type: String,
default: ""
},
containerElement: {
type: props.definePropType([String, Object]),
default: "div"
},
data: {
type: props.definePropType(Array),
default: () => typescript.mutable([])
},
direction,
height: {
type: [String, Number],
required: true
},
innerElement: {
type: [String, Object],
default: "div"
},
style: {
type: props.definePropType([Object, String, Array])
},
useIsScrolling: {
type: Boolean,
default: false
},
width: {
type: [Number, String],
required: false
},
perfMode: {
type: Boolean,
default: true
},
scrollbarAlwaysOn: {
type: Boolean,
default: false
}
});
const virtualizedListProps = props.buildProps({
cache,
estimatedItemSize,
layout,
initScrollOffset,
total,
itemSize,
...virtualizedProps
});
const virtualizedGridProps = props.buildProps({
columnCache: cache,
columnWidth: itemSize,
estimatedColumnWidth: estimatedItemSize,
estimatedRowHeight: estimatedItemSize,
initScrollLeft: initScrollOffset,
initScrollTop: initScrollOffset,
rowCache: cache,
rowHeight: itemSize,
totalColumn: total,
totalRow: total,
...virtualizedProps
});
const virtualizedScrollbarProps = props.buildProps({
layout,
total,
ratio: {
type: Number,
required: true
},
clientSize: {
type: Number,
required: true
},
scrollFrom: {
type: Number,
required: true
},
visible: Boolean
});
exports.virtualizedGridProps = virtualizedGridProps;
exports.virtualizedListProps = virtualizedListProps;
exports.virtualizedProps = virtualizedProps;
exports.virtualizedScrollbarProps = virtualizedScrollbarProps;
//# sourceMappingURL=props.js.map