vuetify 3.0.7 → 3.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/_settings.scss +1 -0
- package/dist/_component-variables-labs.sass +1 -0
- package/dist/json/attributes.json +452 -4
- package/dist/json/importMap-labs.json +28 -0
- package/dist/json/importMap.json +50 -50
- package/dist/json/tags.json +154 -8
- package/dist/json/web-types.json +1514 -18
- package/dist/vuetify-labs.d.ts +875 -0
- package/dist/vuetify-labs.js +9748 -0
- package/dist/vuetify.css +34 -55
- package/dist/vuetify.d.ts +169 -192
- package/dist/vuetify.esm.js +141 -103
- package/dist/vuetify.esm.js.map +1 -1
- package/dist/vuetify.js +140 -102
- package/dist/vuetify.js.map +1 -1
- package/dist/vuetify.min.css +2 -2
- package/dist/vuetify.min.js +783 -777
- package/dist/vuetify.min.js.map +1 -1
- package/lib/blueprints/index.d.ts +3 -2
- package/lib/blueprints/md1.d.ts +3 -2
- package/lib/blueprints/md2.d.ts +3 -2
- package/lib/blueprints/md3.d.ts +3 -2
- package/lib/components/VAlert/VAlertTitle.mjs.map +1 -1
- package/lib/components/VAlert/index.d.ts +1 -0
- package/lib/components/VAutocomplete/VAutocomplete.mjs +8 -10
- package/lib/components/VAutocomplete/VAutocomplete.mjs.map +1 -1
- package/lib/components/VAutocomplete/index.d.ts +3 -12
- package/lib/components/VAvatar/VAvatar.mjs +2 -1
- package/lib/components/VAvatar/VAvatar.mjs.map +1 -1
- package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs +23 -20
- package/lib/components/VBreadcrumbs/VBreadcrumbs.mjs.map +1 -1
- package/lib/components/VBreadcrumbs/VBreadcrumbsDivider.mjs +21 -2
- package/lib/components/VBreadcrumbs/VBreadcrumbsDivider.mjs.map +1 -1
- package/lib/components/VBreadcrumbs/index.d.ts +4 -15
- package/lib/components/VCombobox/VCombobox.mjs +8 -10
- package/lib/components/VCombobox/VCombobox.mjs.map +1 -1
- package/lib/components/VCombobox/index.d.ts +3 -12
- package/lib/components/VDivider/VDivider.css +1 -1
- package/lib/components/VDivider/VDivider.sass +1 -0
- package/lib/components/VDivider/_variables.scss +2 -1
- package/lib/components/VIcon/VIcon.mjs +25 -20
- package/lib/components/VIcon/VIcon.mjs.map +1 -1
- package/lib/components/VIcon/index.d.ts +4 -8
- package/lib/components/VList/VListItem.css +0 -4
- package/lib/components/VList/VListItem.sass +12 -6
- package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs +10 -2
- package/lib/components/VNavigationDrawer/VNavigationDrawer.mjs.map +1 -1
- package/lib/components/VNavigationDrawer/index.d.ts +11 -3
- package/lib/components/VSelect/VSelect.mjs +11 -8
- package/lib/components/VSelect/VSelect.mjs.map +1 -1
- package/lib/components/VTable/VTable.css +12 -29
- package/lib/components/VTable/VTable.mjs +3 -3
- package/lib/components/VTable/VTable.mjs.map +1 -1
- package/lib/components/VTable/VTable.sass +10 -17
- package/lib/components/VTable/_variables.scss +4 -2
- package/lib/components/index.d.ts +26 -50
- package/lib/composables/filter.mjs +18 -10
- package/lib/composables/filter.mjs.map +1 -1
- package/lib/composables/icons.mjs +12 -7
- package/lib/composables/icons.mjs.map +1 -1
- package/lib/entry-bundler.mjs +1 -1
- package/lib/framework.mjs +1 -1
- package/lib/iconsets/fa-svg.d.ts +3 -2
- package/lib/iconsets/fa.d.ts +3 -2
- package/lib/iconsets/fa.mjs +2 -1
- package/lib/iconsets/fa.mjs.map +1 -1
- package/lib/iconsets/fa4.d.ts +3 -2
- package/lib/iconsets/fa4.mjs +2 -1
- package/lib/iconsets/fa4.mjs.map +1 -1
- package/lib/iconsets/md.d.ts +3 -2
- package/lib/iconsets/md.mjs +2 -1
- package/lib/iconsets/md.mjs.map +1 -1
- package/lib/iconsets/mdi-svg.d.ts +3 -2
- package/lib/iconsets/mdi-svg.mjs +2 -1
- package/lib/iconsets/mdi-svg.mjs.map +1 -1
- package/lib/iconsets/mdi.d.ts +3 -2
- package/lib/iconsets/mdi.mjs +2 -1
- package/lib/iconsets/mdi.mjs.map +1 -1
- package/lib/index.d.ts +16 -15
- package/lib/labs/VDataTable/VDataTable.css +119 -0
- package/lib/labs/VDataTable/VDataTable.mjs +146 -0
- package/lib/labs/VDataTable/VDataTable.mjs.map +1 -0
- package/lib/labs/VDataTable/VDataTable.sass +106 -0
- package/lib/labs/VDataTable/VDataTableColumn.mjs +37 -0
- package/lib/labs/VDataTable/VDataTableColumn.mjs.map +1 -0
- package/lib/labs/VDataTable/VDataTableFooter.css +22 -0
- package/lib/labs/VDataTable/VDataTableFooter.mjs +105 -0
- package/lib/labs/VDataTable/VDataTableFooter.mjs.map +1 -0
- package/lib/labs/VDataTable/VDataTableFooter.sass +23 -0
- package/lib/labs/VDataTable/VDataTableGroupHeaderRow.mjs +88 -0
- package/lib/labs/VDataTable/VDataTableGroupHeaderRow.mjs.map +1 -0
- package/lib/labs/VDataTable/VDataTableHeaders.mjs +143 -0
- package/lib/labs/VDataTable/VDataTableHeaders.mjs.map +1 -0
- package/lib/labs/VDataTable/VDataTableRow.mjs +75 -0
- package/lib/labs/VDataTable/VDataTableRow.mjs.map +1 -0
- package/lib/labs/VDataTable/VDataTableRows.mjs +87 -0
- package/lib/labs/VDataTable/VDataTableRows.mjs.map +1 -0
- package/lib/labs/VDataTable/VDataTableServer.mjs +124 -0
- package/lib/labs/VDataTable/VDataTableServer.mjs.map +1 -0
- package/lib/labs/VDataTable/VDataTableVirtual.mjs +154 -0
- package/lib/labs/VDataTable/VDataTableVirtual.mjs.map +1 -0
- package/lib/labs/VDataTable/_variables.scss +6 -0
- package/lib/labs/VDataTable/composables/expand.mjs +51 -0
- package/lib/labs/VDataTable/composables/expand.mjs.map +1 -0
- package/lib/labs/VDataTable/composables/group.mjs +124 -0
- package/lib/labs/VDataTable/composables/group.mjs.map +1 -0
- package/lib/labs/VDataTable/composables/headers.mjs +152 -0
- package/lib/labs/VDataTable/composables/headers.mjs.map +1 -0
- package/lib/labs/VDataTable/composables/items.mjs +30 -0
- package/lib/labs/VDataTable/composables/items.mjs.map +1 -0
- package/lib/labs/VDataTable/composables/options.mjs +44 -0
- package/lib/labs/VDataTable/composables/options.mjs.map +1 -0
- package/lib/labs/VDataTable/composables/paginate.mjs +62 -0
- package/lib/labs/VDataTable/composables/paginate.mjs.map +1 -0
- package/lib/labs/VDataTable/composables/select.mjs +57 -0
- package/lib/labs/VDataTable/composables/select.mjs.map +1 -0
- package/lib/labs/VDataTable/composables/sort.mjs +109 -0
- package/lib/labs/VDataTable/composables/sort.mjs.map +1 -0
- package/lib/labs/VDataTable/composables/virtual.mjs +77 -0
- package/lib/labs/VDataTable/composables/virtual.mjs.map +1 -0
- package/lib/labs/VDataTable/index.d.ts +705 -0
- package/lib/labs/VDataTable/index.mjs +6 -0
- package/lib/labs/VDataTable/index.mjs.map +1 -0
- package/lib/labs/VDataTable/types.mjs +2 -0
- package/lib/labs/VDataTable/types.mjs.map +1 -0
- package/lib/labs/VVirtualScroll/VVirtualScroll.css +11 -0
- package/lib/labs/VVirtualScroll/VVirtualScroll.mjs +118 -0
- package/lib/labs/VVirtualScroll/VVirtualScroll.mjs.map +1 -0
- package/lib/{components → labs}/VVirtualScroll/VVirtualScroll.sass +0 -5
- package/lib/labs/VVirtualScroll/VVirtualScrollItem.mjs +35 -0
- package/lib/labs/VVirtualScroll/VVirtualScrollItem.mjs.map +1 -0
- package/lib/labs/VVirtualScroll/index.d.ts +154 -0
- package/lib/labs/VVirtualScroll/index.mjs +2 -0
- package/lib/labs/VVirtualScroll/index.mjs.map +1 -0
- package/lib/labs/components.d.ts +856 -0
- package/lib/labs/components.mjs +3 -0
- package/lib/labs/components.mjs.map +1 -0
- package/lib/labs/index.mjs +3 -0
- package/lib/labs/index.mjs.map +1 -0
- package/lib/util/defineComponent.mjs +4 -0
- package/lib/util/defineComponent.mjs.map +1 -1
- package/lib/util/helpers.mjs +0 -38
- package/lib/util/helpers.mjs.map +1 -1
- package/package.json +4 -2
- package/lib/components/VDataTable/MobileRow.mjs +0 -63
- package/lib/components/VDataTable/MobileRow.mjs.map +0 -1
- package/lib/components/VDataTable/Row.mjs +0 -57
- package/lib/components/VDataTable/Row.mjs.map +0 -1
- package/lib/components/VDataTable/RowGroup.mjs +0 -48
- package/lib/components/VDataTable/RowGroup.mjs.map +0 -1
- package/lib/components/VDataTable/VDataTable.mjs +0 -577
- package/lib/components/VDataTable/VDataTable.mjs.map +0 -1
- package/lib/components/VDataTable/VDataTable.sass +0 -98
- package/lib/components/VDataTable/VDataTableHeader.mjs +0 -42
- package/lib/components/VDataTable/VDataTableHeader.mjs.map +0 -1
- package/lib/components/VDataTable/VDataTableHeader.sass +0 -80
- package/lib/components/VDataTable/VDataTableHeaderDesktop.mjs +0 -96
- package/lib/components/VDataTable/VDataTableHeaderDesktop.mjs.map +0 -1
- package/lib/components/VDataTable/VDataTableHeaderMobile.mjs +0 -89
- package/lib/components/VDataTable/VDataTableHeaderMobile.mjs.map +0 -1
- package/lib/components/VDataTable/VEditDialog.mjs +0 -127
- package/lib/components/VDataTable/VEditDialog.mjs.map +0 -1
- package/lib/components/VDataTable/VEditDialog.sass +0 -22
- package/lib/components/VDataTable/VVirtualTable.mjs +0 -132
- package/lib/components/VDataTable/VVirtualTable.mjs.map +0 -1
- package/lib/components/VDataTable/VVirtualTable.sass +0 -13
- package/lib/components/VDataTable/_variables.scss +0 -24
- package/lib/components/VDataTable/index.mjs +0 -21
- package/lib/components/VDataTable/index.mjs.map +0 -1
- package/lib/components/VDataTable/mixins/header.mjs +0 -71
- package/lib/components/VDataTable/mixins/header.mjs.map +0 -1
- package/lib/components/VVirtualScroll/VVirtualScroll.mjs +0 -108
- package/lib/components/VVirtualScroll/VVirtualScroll.mjs.map +0 -1
- package/lib/components/VVirtualScroll/index.mjs +0 -4
- package/lib/components/VVirtualScroll/index.mjs.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.mjs","names":[],"sources":["../../../src/labs/VDataTable/types.ts"],"sourcesContent":["import type { InternalItem } from '@/composables/items'\nimport type { SelectItemKey } from '@/util'\n\nexport type DataTableCompareFunction<T = any> = (a: T, b: T) => number\n\nexport type DataTableHeader = {\n key: string\n value?: SelectItemKey\n title: string\n\n colspan?: number\n rowspan?: number\n\n fixed?: boolean\n align?: 'start' | 'end'\n\n width?: number\n minWidth?: string\n maxWidth?: string\n\n sortable?: boolean\n sort?: DataTableCompareFunction\n}\n\nexport type InternalDataTableHeader = DataTableHeader & {\n sortable: boolean\n\n fixedOffset?: number\n lastFixed?: boolean\n}\n\nexport type DataTableItem = InternalItem & { type: 'item', columns: Record<string, unknown> }\n\nexport type GroupHeaderItem = {\n type: 'group-header'\n id: string\n key: string\n value: string\n depth: number\n items: (GroupHeaderItem | DataTableItem)[]\n}\n\nexport type InternalDataTableItem = DataTableItem | GroupHeaderItem\n"],"mappings":""}
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
import { createVNode as _createVNode } from "vue";
|
|
2
|
+
// Styles
|
|
3
|
+
import "./VVirtualScroll.css";
|
|
4
|
+
|
|
5
|
+
// Components
|
|
6
|
+
import { VVirtualScrollItem } from "./VVirtualScrollItem.mjs"; // Composables
|
|
7
|
+
import { makeDimensionProps, useDimension } from "../../composables/dimensions.mjs"; // Utilities
|
|
8
|
+
import { computed, ref } from 'vue';
|
|
9
|
+
import { convertToUnit, createRange, genericComponent, getPropertyFromItem, useRender } from "../../util/index.mjs"; // Types
|
|
10
|
+
const UP = -1;
|
|
11
|
+
const DOWN = 1;
|
|
12
|
+
export const VVirtualScroll = genericComponent()({
|
|
13
|
+
name: 'VVirtualScroll',
|
|
14
|
+
props: {
|
|
15
|
+
items: {
|
|
16
|
+
type: Array,
|
|
17
|
+
default: () => []
|
|
18
|
+
},
|
|
19
|
+
itemKey: {
|
|
20
|
+
type: String,
|
|
21
|
+
default: 'value'
|
|
22
|
+
},
|
|
23
|
+
itemHeight: [Number, String],
|
|
24
|
+
visibleItems: {
|
|
25
|
+
type: [Number, String],
|
|
26
|
+
default: 30
|
|
27
|
+
},
|
|
28
|
+
...makeDimensionProps()
|
|
29
|
+
},
|
|
30
|
+
setup(props, _ref) {
|
|
31
|
+
let {
|
|
32
|
+
slots
|
|
33
|
+
} = _ref;
|
|
34
|
+
const first = ref(0);
|
|
35
|
+
const baseItemHeight = ref(props.itemHeight);
|
|
36
|
+
const itemHeight = computed({
|
|
37
|
+
get: () => parseInt(baseItemHeight.value ?? 0, 10),
|
|
38
|
+
set(val) {
|
|
39
|
+
baseItemHeight.value = val;
|
|
40
|
+
}
|
|
41
|
+
});
|
|
42
|
+
const visibleItems = computed(() => parseInt(props.visibleItems, 10));
|
|
43
|
+
const rootEl = ref();
|
|
44
|
+
const ids = new Map(props.items.map((item, index) => [getPropertyFromItem(item, props.itemKey, item), index]));
|
|
45
|
+
const sizes = createRange(props.items.length).map(() => itemHeight.value);
|
|
46
|
+
function handleItemResize(item, height) {
|
|
47
|
+
const index = ids.get(getPropertyFromItem(item, props.itemKey, item));
|
|
48
|
+
if (!index) return;
|
|
49
|
+
sizes[index] = height;
|
|
50
|
+
if (!itemHeight.value) itemHeight.value = height;
|
|
51
|
+
}
|
|
52
|
+
function calculateOffset(index) {
|
|
53
|
+
return sizes.slice(0, index).reduce((curr, value) => curr + (value || itemHeight.value), 0);
|
|
54
|
+
}
|
|
55
|
+
function calculateMidPointIndex(scrollTop) {
|
|
56
|
+
let start = 0;
|
|
57
|
+
let end = props.items.length;
|
|
58
|
+
while (start <= end) {
|
|
59
|
+
const middle = start + Math.floor((end - start) / 2);
|
|
60
|
+
const middleOffset = calculateOffset(middle);
|
|
61
|
+
if (middleOffset === scrollTop) {
|
|
62
|
+
return middle;
|
|
63
|
+
} else if (middleOffset < scrollTop) {
|
|
64
|
+
start = middle + 1;
|
|
65
|
+
} else if (middleOffset > scrollTop) {
|
|
66
|
+
end = middle - 1;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
return start;
|
|
70
|
+
}
|
|
71
|
+
let lastScrollTop = 0;
|
|
72
|
+
function handleScroll() {
|
|
73
|
+
if (!rootEl.value) return;
|
|
74
|
+
const scrollTop = rootEl.value.scrollTop;
|
|
75
|
+
const direction = scrollTop < lastScrollTop ? UP : DOWN;
|
|
76
|
+
const midPointIndex = calculateMidPointIndex(scrollTop);
|
|
77
|
+
const buffer = Math.round(visibleItems.value / 3);
|
|
78
|
+
if (direction === UP && midPointIndex <= first.value) {
|
|
79
|
+
first.value = Math.max(midPointIndex - buffer, 0);
|
|
80
|
+
} else if (direction === DOWN && midPointIndex >= first.value + buffer * 2) {
|
|
81
|
+
first.value = Math.min(Math.max(0, midPointIndex - buffer), props.items.length - visibleItems.value);
|
|
82
|
+
}
|
|
83
|
+
lastScrollTop = rootEl.value.scrollTop;
|
|
84
|
+
}
|
|
85
|
+
const last = computed(() => Math.min(props.items.length, first.value + visibleItems.value));
|
|
86
|
+
const computedItems = computed(() => props.items.slice(first.value, last.value));
|
|
87
|
+
const paddingTop = computed(() => calculateOffset(first.value));
|
|
88
|
+
const paddingBottom = computed(() => calculateOffset(props.items.length) - calculateOffset(last.value));
|
|
89
|
+
const {
|
|
90
|
+
dimensionStyles
|
|
91
|
+
} = useDimension(props);
|
|
92
|
+
useRender(() => _createVNode("div", {
|
|
93
|
+
"ref": rootEl,
|
|
94
|
+
"class": "v-virtual-scroll",
|
|
95
|
+
"onScroll": handleScroll,
|
|
96
|
+
"style": dimensionStyles.value
|
|
97
|
+
}, [_createVNode("div", {
|
|
98
|
+
"class": "v-virtual-scroll__container",
|
|
99
|
+
"style": {
|
|
100
|
+
paddingTop: convertToUnit(paddingTop.value),
|
|
101
|
+
paddingBottom: convertToUnit(paddingBottom.value)
|
|
102
|
+
}
|
|
103
|
+
}, [computedItems.value.map((item, index) => {
|
|
104
|
+
var _slots$default;
|
|
105
|
+
return _createVNode(VVirtualScrollItem, {
|
|
106
|
+
"key": index,
|
|
107
|
+
"dynamicHeight": !props.itemHeight,
|
|
108
|
+
"onUpdate:height": height => handleItemResize(item, height)
|
|
109
|
+
}, {
|
|
110
|
+
default: () => [(_slots$default = slots.default) == null ? void 0 : _slots$default.call(slots, {
|
|
111
|
+
item,
|
|
112
|
+
index: index + first.value
|
|
113
|
+
})]
|
|
114
|
+
});
|
|
115
|
+
})])]));
|
|
116
|
+
}
|
|
117
|
+
});
|
|
118
|
+
//# sourceMappingURL=VVirtualScroll.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VVirtualScroll.mjs","names":["VVirtualScrollItem","makeDimensionProps","useDimension","computed","ref","convertToUnit","createRange","genericComponent","getPropertyFromItem","useRender","UP","DOWN","VVirtualScroll","name","props","items","type","Array","default","itemKey","String","itemHeight","Number","visibleItems","setup","slots","first","baseItemHeight","get","parseInt","value","set","val","rootEl","ids","Map","map","item","index","sizes","length","handleItemResize","height","calculateOffset","slice","reduce","curr","calculateMidPointIndex","scrollTop","start","end","middle","Math","floor","middleOffset","lastScrollTop","handleScroll","direction","midPointIndex","buffer","round","max","min","last","computedItems","paddingTop","paddingBottom","dimensionStyles"],"sources":["../../../src/labs/VVirtualScroll/VVirtualScroll.tsx"],"sourcesContent":["// Styles\nimport './VVirtualScroll.sass'\n\n// Components\nimport { VVirtualScrollItem } from './VVirtualScrollItem'\n\n// Composables\nimport { makeDimensionProps, useDimension } from '@/composables/dimensions'\n\n// Utilities\nimport { computed, ref } from 'vue'\nimport {\n convertToUnit,\n createRange,\n genericComponent,\n getPropertyFromItem,\n useRender,\n} from '@/util'\n\n// Types\nimport type { MakeSlots, SlotsToProps } from '@/util'\n\nconst UP = -1\nconst DOWN = 1\n\nexport interface VVirtualScrollSlot<T> {\n item: T\n index: number\n}\n\nexport const VVirtualScroll = genericComponent<new <T>() => {\n $props: {\n items: readonly T[]\n } & SlotsToProps<\n MakeSlots<{\n default: [VVirtualScrollSlot<T>]\n }>\n >\n}>()({\n name: 'VVirtualScroll',\n\n props: {\n items: {\n type: Array,\n default: () => ([]),\n },\n itemKey: {\n type: String,\n default: 'value',\n },\n itemHeight: [Number, String],\n visibleItems: {\n type: [Number, String],\n default: 30,\n },\n\n ...makeDimensionProps(),\n },\n\n setup (props, { slots }) {\n const first = ref(0)\n const baseItemHeight = ref(props.itemHeight)\n const itemHeight = computed({\n get: () => parseInt(baseItemHeight.value ?? 0, 10),\n set (val) {\n baseItemHeight.value = val\n },\n })\n const visibleItems = computed(() => parseInt(props.visibleItems, 10))\n const rootEl = ref<HTMLDivElement>()\n\n const ids = new Map<unknown, number>(props.items.map((item, index) => [getPropertyFromItem(item, props.itemKey, item), index]))\n const sizes = createRange(props.items.length).map(() => itemHeight.value)\n\n function handleItemResize (item: unknown, height: number) {\n const index = ids.get(getPropertyFromItem(item, props.itemKey, item))\n\n if (!index) return\n\n sizes[index] = height\n\n if (!itemHeight.value) itemHeight.value = height\n }\n\n function calculateOffset (index: number) {\n return sizes.slice(0, index).reduce((curr, value) => curr + (value || itemHeight.value), 0)\n }\n\n function calculateMidPointIndex (scrollTop: number) {\n let start = 0\n let end = props.items.length\n\n while (start <= end) {\n const middle = start + Math.floor((end - start) / 2)\n const middleOffset = calculateOffset(middle)\n\n if (middleOffset === scrollTop) {\n return middle\n } else if (middleOffset < scrollTop) {\n start = middle + 1\n } else if (middleOffset > scrollTop) {\n end = middle - 1\n }\n }\n\n return start\n }\n\n let lastScrollTop = 0\n function handleScroll () {\n if (!rootEl.value) return\n\n const scrollTop = rootEl.value.scrollTop\n const direction = scrollTop < lastScrollTop ? UP : DOWN\n\n const midPointIndex = calculateMidPointIndex(scrollTop)\n\n const buffer = Math.round(visibleItems.value / 3)\n if (direction === UP && midPointIndex <= first.value) {\n first.value = Math.max(midPointIndex - buffer, 0)\n } else if (direction === DOWN && midPointIndex >= first.value + (buffer * 2)) {\n first.value = Math.min(Math.max(0, midPointIndex - buffer), props.items.length - visibleItems.value)\n }\n\n lastScrollTop = rootEl.value.scrollTop\n }\n\n const last = computed(() => Math.min(props.items.length, first.value + visibleItems.value))\n const computedItems = computed(() => props.items.slice(first.value, last.value))\n const paddingTop = computed(() => calculateOffset(first.value))\n const paddingBottom = computed(() => calculateOffset(props.items.length) - calculateOffset(last.value))\n\n const { dimensionStyles } = useDimension(props)\n\n useRender(() => (\n <div\n ref={ rootEl }\n class=\"v-virtual-scroll\"\n onScroll={ handleScroll }\n style={ dimensionStyles.value }\n >\n <div\n class=\"v-virtual-scroll__container\"\n style={{\n paddingTop: convertToUnit(paddingTop.value),\n paddingBottom: convertToUnit(paddingBottom.value),\n }}\n >\n { computedItems.value.map((item, index) => (\n <VVirtualScrollItem\n key={ index }\n dynamicHeight={ !props.itemHeight }\n onUpdate:height={ height => handleItemResize(item, height) }\n >\n { slots.default?.({ item, index: index + first.value }) }\n </VVirtualScrollItem>\n )) }\n </div>\n </div>\n ))\n },\n})\n\nexport type VVirtualScroll = InstanceType<typeof VVirtualScroll>\n"],"mappings":"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"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { createVNode as _createVNode } from "vue";
|
|
2
|
+
// Composables
|
|
3
|
+
import { useResizeObserver } from "../../composables/resizeObserver.mjs"; // Utilities
|
|
4
|
+
import { defineComponent } from "../../util/defineComponent.mjs";
|
|
5
|
+
import { useRender } from "../../util/index.mjs";
|
|
6
|
+
export const VVirtualScrollItem = defineComponent({
|
|
7
|
+
name: 'VVirtualScrollItem',
|
|
8
|
+
props: {
|
|
9
|
+
dynamicHeight: Boolean
|
|
10
|
+
},
|
|
11
|
+
emits: {
|
|
12
|
+
'update:height': height => true
|
|
13
|
+
},
|
|
14
|
+
setup(props, _ref) {
|
|
15
|
+
let {
|
|
16
|
+
emit,
|
|
17
|
+
slots
|
|
18
|
+
} = _ref;
|
|
19
|
+
const {
|
|
20
|
+
resizeRef
|
|
21
|
+
} = useResizeObserver(entries => {
|
|
22
|
+
if (!entries.length) return;
|
|
23
|
+
const contentRect = entries[0].contentRect;
|
|
24
|
+
emit('update:height', contentRect.height);
|
|
25
|
+
});
|
|
26
|
+
useRender(() => {
|
|
27
|
+
var _slots$default;
|
|
28
|
+
return _createVNode("div", {
|
|
29
|
+
"ref": props.dynamicHeight ? resizeRef : undefined,
|
|
30
|
+
"class": "v-virtual-scroll__item"
|
|
31
|
+
}, [(_slots$default = slots.default) == null ? void 0 : _slots$default.call(slots)]);
|
|
32
|
+
});
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
//# sourceMappingURL=VVirtualScrollItem.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VVirtualScrollItem.mjs","names":["useResizeObserver","defineComponent","useRender","VVirtualScrollItem","name","props","dynamicHeight","Boolean","emits","height","setup","emit","slots","resizeRef","entries","length","contentRect","undefined","default"],"sources":["../../../src/labs/VVirtualScroll/VVirtualScrollItem.tsx"],"sourcesContent":["// Composables\nimport { useResizeObserver } from '@/composables/resizeObserver'\n\n// Utilities\nimport { defineComponent } from '@/util/defineComponent'\nimport { useRender } from '@/util'\n\nexport const VVirtualScrollItem = defineComponent({\n name: 'VVirtualScrollItem',\n\n props: {\n dynamicHeight: Boolean,\n },\n\n emits: {\n 'update:height': (height: number) => true,\n },\n\n setup (props, { emit, slots }) {\n const { resizeRef } = useResizeObserver(entries => {\n if (!entries.length) return\n\n const contentRect = entries[0].contentRect\n emit('update:height', contentRect.height)\n })\n\n useRender(() => (\n <div\n ref={ props.dynamicHeight ? resizeRef : undefined }\n class=\"v-virtual-scroll__item\"\n >\n { slots.default?.() }\n </div>\n ))\n },\n})\n"],"mappings":";AAAA;AAAA,SACSA,iBAAiB,gDAE1B;AAAA,SACSC,eAAe;AAAA,SACfC,SAAS;AAElB,OAAO,MAAMC,kBAAkB,GAAGF,eAAe,CAAC;EAChDG,IAAI,EAAE,oBAAoB;EAE1BC,KAAK,EAAE;IACLC,aAAa,EAAEC;EACjB,CAAC;EAEDC,KAAK,EAAE;IACL,eAAe,EAAGC,MAAc,IAAK;EACvC,CAAC;EAEDC,KAAK,CAAEL,KAAK,QAAmB;IAAA,IAAjB;MAAEM,IAAI;MAAEC;IAAM,CAAC;IAC3B,MAAM;MAAEC;IAAU,CAAC,GAAGb,iBAAiB,CAACc,OAAO,IAAI;MACjD,IAAI,CAACA,OAAO,CAACC,MAAM,EAAE;MAErB,MAAMC,WAAW,GAAGF,OAAO,CAAC,CAAC,CAAC,CAACE,WAAW;MAC1CL,IAAI,CAAC,eAAe,EAAEK,WAAW,CAACP,MAAM,CAAC;IAC3C,CAAC,CAAC;IAEFP,SAAS,CAAC;MAAA;MAAA;QAAA,OAEAG,KAAK,CAACC,aAAa,GAAGO,SAAS,GAAGI,SAAS;QAAA,SAC3C;MAAwB,sBAE5BL,KAAK,CAACM,OAAO,qBAAb,oBAAAN,KAAK,CAAY;IAAA,CAEtB,CAAC;EACJ;AACF,CAAC,CAAC"}
|
|
@@ -0,0 +1,154 @@
|
|
|
1
|
+
import * as vue from 'vue';
|
|
2
|
+
|
|
3
|
+
interface VVirtualScrollSlot<T> {
|
|
4
|
+
item: T;
|
|
5
|
+
index: number;
|
|
6
|
+
}
|
|
7
|
+
declare const VVirtualScroll: {
|
|
8
|
+
new (...args: any[]): {
|
|
9
|
+
$: vue.ComponentInternalInstance;
|
|
10
|
+
$data: {};
|
|
11
|
+
$props: Partial<{
|
|
12
|
+
visibleItems: string | number;
|
|
13
|
+
itemKey: string;
|
|
14
|
+
}> & Omit<Readonly<vue.ExtractPropTypes<Omit<{
|
|
15
|
+
height: (StringConstructor | NumberConstructor)[];
|
|
16
|
+
maxHeight: (StringConstructor | NumberConstructor)[];
|
|
17
|
+
maxWidth: (StringConstructor | NumberConstructor)[];
|
|
18
|
+
minHeight: (StringConstructor | NumberConstructor)[];
|
|
19
|
+
minWidth: (StringConstructor | NumberConstructor)[];
|
|
20
|
+
width: (StringConstructor | NumberConstructor)[];
|
|
21
|
+
items: {
|
|
22
|
+
type: ArrayConstructor;
|
|
23
|
+
default: () => never[];
|
|
24
|
+
};
|
|
25
|
+
itemKey: {
|
|
26
|
+
type: StringConstructor;
|
|
27
|
+
default: string;
|
|
28
|
+
};
|
|
29
|
+
itemHeight: (StringConstructor | NumberConstructor)[];
|
|
30
|
+
visibleItems: {
|
|
31
|
+
type: (StringConstructor | NumberConstructor)[];
|
|
32
|
+
default: number;
|
|
33
|
+
};
|
|
34
|
+
}, "$children" | "items" | "v-slots" | "v-slot:default">>> & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps, "visibleItems" | "itemKey">;
|
|
35
|
+
$attrs: {
|
|
36
|
+
[x: string]: unknown;
|
|
37
|
+
};
|
|
38
|
+
$refs: {
|
|
39
|
+
[x: string]: unknown;
|
|
40
|
+
};
|
|
41
|
+
$slots: Readonly<{
|
|
42
|
+
[name: string]: vue.Slot | undefined;
|
|
43
|
+
}>;
|
|
44
|
+
$root: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}>> | null;
|
|
45
|
+
$parent: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}>> | null;
|
|
46
|
+
$emit: (event: string, ...args: any[]) => void;
|
|
47
|
+
$el: any;
|
|
48
|
+
$options: vue.ComponentOptionsBase<Readonly<vue.ExtractPropTypes<Omit<{
|
|
49
|
+
height: (StringConstructor | NumberConstructor)[];
|
|
50
|
+
maxHeight: (StringConstructor | NumberConstructor)[];
|
|
51
|
+
maxWidth: (StringConstructor | NumberConstructor)[];
|
|
52
|
+
minHeight: (StringConstructor | NumberConstructor)[];
|
|
53
|
+
minWidth: (StringConstructor | NumberConstructor)[];
|
|
54
|
+
width: (StringConstructor | NumberConstructor)[];
|
|
55
|
+
items: {
|
|
56
|
+
type: ArrayConstructor;
|
|
57
|
+
default: () => never[];
|
|
58
|
+
};
|
|
59
|
+
itemKey: {
|
|
60
|
+
type: StringConstructor;
|
|
61
|
+
default: string;
|
|
62
|
+
};
|
|
63
|
+
itemHeight: (StringConstructor | NumberConstructor)[];
|
|
64
|
+
visibleItems: {
|
|
65
|
+
type: (StringConstructor | NumberConstructor)[];
|
|
66
|
+
default: number;
|
|
67
|
+
};
|
|
68
|
+
}, "$children" | "items" | "v-slots" | "v-slot:default">>>, void, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Omit<Record<string, any>, "$children" | "items" | "v-slots" | "v-slot:default">, string, {
|
|
69
|
+
visibleItems: string | number;
|
|
70
|
+
itemKey: string;
|
|
71
|
+
}> & {
|
|
72
|
+
beforeCreate?: ((() => void) | (() => void)[]) | undefined;
|
|
73
|
+
created?: ((() => void) | (() => void)[]) | undefined;
|
|
74
|
+
beforeMount?: ((() => void) | (() => void)[]) | undefined;
|
|
75
|
+
mounted?: ((() => void) | (() => void)[]) | undefined;
|
|
76
|
+
beforeUpdate?: ((() => void) | (() => void)[]) | undefined;
|
|
77
|
+
updated?: ((() => void) | (() => void)[]) | undefined;
|
|
78
|
+
activated?: ((() => void) | (() => void)[]) | undefined;
|
|
79
|
+
deactivated?: ((() => void) | (() => void)[]) | undefined;
|
|
80
|
+
beforeDestroy?: ((() => void) | (() => void)[]) | undefined;
|
|
81
|
+
beforeUnmount?: ((() => void) | (() => void)[]) | undefined;
|
|
82
|
+
destroyed?: ((() => void) | (() => void)[]) | undefined;
|
|
83
|
+
unmounted?: ((() => void) | (() => void)[]) | undefined;
|
|
84
|
+
renderTracked?: (((e: vue.DebuggerEvent) => void) | ((e: vue.DebuggerEvent) => void)[]) | undefined;
|
|
85
|
+
renderTriggered?: (((e: vue.DebuggerEvent) => void) | ((e: vue.DebuggerEvent) => void)[]) | undefined;
|
|
86
|
+
errorCaptured?: (((err: unknown, instance: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}>> | null, info: string) => boolean | void) | ((err: unknown, instance: vue.ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, vue.ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}>> | null, info: string) => boolean | void)[]) | undefined;
|
|
87
|
+
};
|
|
88
|
+
$forceUpdate: () => void;
|
|
89
|
+
$nextTick: typeof vue.nextTick;
|
|
90
|
+
$watch(source: string | Function, cb: Function, options?: vue.WatchOptions<boolean> | undefined): vue.WatchStopHandle;
|
|
91
|
+
} & Readonly<vue.ExtractPropTypes<Omit<{
|
|
92
|
+
height: (StringConstructor | NumberConstructor)[];
|
|
93
|
+
maxHeight: (StringConstructor | NumberConstructor)[];
|
|
94
|
+
maxWidth: (StringConstructor | NumberConstructor)[];
|
|
95
|
+
minHeight: (StringConstructor | NumberConstructor)[];
|
|
96
|
+
minWidth: (StringConstructor | NumberConstructor)[];
|
|
97
|
+
width: (StringConstructor | NumberConstructor)[];
|
|
98
|
+
items: {
|
|
99
|
+
type: ArrayConstructor;
|
|
100
|
+
default: () => never[];
|
|
101
|
+
};
|
|
102
|
+
itemKey: {
|
|
103
|
+
type: StringConstructor;
|
|
104
|
+
default: string;
|
|
105
|
+
};
|
|
106
|
+
itemHeight: (StringConstructor | NumberConstructor)[];
|
|
107
|
+
visibleItems: {
|
|
108
|
+
type: (StringConstructor | NumberConstructor)[];
|
|
109
|
+
default: number;
|
|
110
|
+
};
|
|
111
|
+
}, "$children" | "items" | "v-slots" | "v-slot:default">>> & vue.ShallowUnwrapRef<{}> & {} & vue.ComponentCustomProperties;
|
|
112
|
+
__isFragment?: undefined;
|
|
113
|
+
__isTeleport?: undefined;
|
|
114
|
+
__isSuspense?: undefined;
|
|
115
|
+
} & vue.ComponentOptionsBase<Readonly<vue.ExtractPropTypes<Omit<{
|
|
116
|
+
height: (StringConstructor | NumberConstructor)[];
|
|
117
|
+
maxHeight: (StringConstructor | NumberConstructor)[];
|
|
118
|
+
maxWidth: (StringConstructor | NumberConstructor)[];
|
|
119
|
+
minHeight: (StringConstructor | NumberConstructor)[];
|
|
120
|
+
minWidth: (StringConstructor | NumberConstructor)[];
|
|
121
|
+
width: (StringConstructor | NumberConstructor)[];
|
|
122
|
+
items: {
|
|
123
|
+
type: ArrayConstructor;
|
|
124
|
+
default: () => never[];
|
|
125
|
+
};
|
|
126
|
+
itemKey: {
|
|
127
|
+
type: StringConstructor;
|
|
128
|
+
default: string;
|
|
129
|
+
};
|
|
130
|
+
itemHeight: (StringConstructor | NumberConstructor)[];
|
|
131
|
+
visibleItems: {
|
|
132
|
+
type: (StringConstructor | NumberConstructor)[];
|
|
133
|
+
default: number;
|
|
134
|
+
};
|
|
135
|
+
}, "$children" | "items" | "v-slots" | "v-slot:default">>>, void, unknown, {}, {}, vue.ComponentOptionsMixin, vue.ComponentOptionsMixin, Omit<Record<string, any>, "$children" | "items" | "v-slots" | "v-slot:default">, string, {
|
|
136
|
+
visibleItems: string | number;
|
|
137
|
+
itemKey: string;
|
|
138
|
+
}> & vue.VNodeProps & vue.AllowedComponentProps & vue.ComponentCustomProps & (new <T>() => {
|
|
139
|
+
$props: {
|
|
140
|
+
items: readonly T[];
|
|
141
|
+
} & {
|
|
142
|
+
$children?: vue.VNodeChild | {
|
|
143
|
+
default?: ((args_0: VVirtualScrollSlot<T>) => vue.VNodeChild) | undefined;
|
|
144
|
+
} | ((args_0: VVirtualScrollSlot<T>) => vue.VNodeChild);
|
|
145
|
+
'v-slots'?: {
|
|
146
|
+
default?: false | ((args_0: VVirtualScrollSlot<T>) => vue.VNodeChild) | undefined;
|
|
147
|
+
} | undefined;
|
|
148
|
+
} & {
|
|
149
|
+
"v-slot:default"?: false | ((args_0: VVirtualScrollSlot<T>) => vue.VNodeChild) | undefined;
|
|
150
|
+
};
|
|
151
|
+
});
|
|
152
|
+
declare type VVirtualScroll = InstanceType<typeof VVirtualScroll>;
|
|
153
|
+
|
|
154
|
+
export { VVirtualScroll };
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.mjs","names":["VVirtualScroll"],"sources":["../../../src/labs/VVirtualScroll/index.ts"],"sourcesContent":["export { VVirtualScroll } from './VVirtualScroll'\n"],"mappings":"SAASA,cAAc"}
|