@vaadin/component-base
Advanced tools
Comparing version 23.1.0-beta1 to 23.1.0-beta2
interface Vaadin { | ||
developmentModeCallback?: { | ||
'usage-statistics'?: () => void; | ||
'vaadin-license-checker'?: () => void; | ||
'usage-statistics'?(): void; | ||
'vaadin-license-checker'?(): void; | ||
}; | ||
registrations?: Array<{ is: string; version: string }>; | ||
usageStatsChecker?: { | ||
maybeGatherAndSend: () => void; | ||
maybeGatherAndSend(): void; | ||
}; | ||
@@ -10,0 +10,0 @@ } |
{ | ||
"name": "@vaadin/component-base", | ||
"version": "23.1.0-beta1", | ||
"version": "23.1.0-beta2", | ||
"publishConfig": { | ||
@@ -45,3 +45,3 @@ "access": "public" | ||
}, | ||
"gitHead": "8be43cf83102a6b9ccf309687446e590ce0164e8" | ||
"gitHead": "f11f9245a0b5e6bf912725a501c27c24b74e7c8d" | ||
} |
@@ -12,4 +12,4 @@ /** | ||
export interface AsyncInterface { | ||
run: (fn: Function, delay?: number) => number; | ||
cancel: (handle: number) => void; | ||
run(fn: Function, delay?: number): number; | ||
cancel(handle: number): void; | ||
} | ||
@@ -16,0 +16,0 @@ |
@@ -19,3 +19,3 @@ /** | ||
// iPadOS 13 lies and says it's a Mac, but we can distinguish by detecting touch support. | ||
// IPadOS 13 lies and says it's a Mac, but we can distinguish by detecting touch support. | ||
export const isIPad = testPlatform(/^iPad/) || (testPlatform(/^Mac/) && navigator.maxTouchPoints > 1); | ||
@@ -22,0 +22,0 @@ |
@@ -42,3 +42,3 @@ /** | ||
static get version() { | ||
return '23.1.0-beta1'; | ||
return '23.1.0-beta2'; | ||
} | ||
@@ -45,0 +45,0 @@ |
@@ -71,3 +71,3 @@ /** | ||
// in non-Chrome browsers, blur does not fire on the element when it is disconnected. | ||
// In non-Chrome browsers, blur does not fire on the element when it is disconnected. | ||
// reproducible in `<vaadin-date-picker>` when closing on `Cancel` or `Today` click. | ||
@@ -88,3 +88,3 @@ if (this.hasAttribute('focused')) { | ||
// focus-ring is true when the element was focused from the keyboard. | ||
// Focus-ring is true when the element was focused from the keyboard. | ||
// Focus Ring [A11ycasts]: https://youtu.be/ilj2P5-5CjI | ||
@@ -91,0 +91,0 @@ this.toggleAttribute('focus-ring', focused && this._keyboardActive); |
@@ -68,10 +68,10 @@ /** | ||
export interface GestureRecognizer { | ||
reset: () => void; | ||
mousedown?: (e: MouseEvent) => void; | ||
mousemove?: (e: MouseEvent) => void; | ||
mouseup?: (e: MouseEvent) => void; | ||
touchstart?: (e: TouchEvent) => void; | ||
touchmove?: (e: TouchEvent) => void; | ||
touchend?: (e: TouchEvent) => void; | ||
click?: (e: MouseEvent) => void; | ||
reset(): void; | ||
mousedown?(e: MouseEvent): void; | ||
mousemove?(e: MouseEvent): void; | ||
mouseup?(e: MouseEvent): void; | ||
touchstart?(e: TouchEvent): void; | ||
touchmove?(e: TouchEvent): void; | ||
touchend?(e: TouchEvent): void; | ||
click?(e: MouseEvent): void; | ||
} |
@@ -29,3 +29,3 @@ /** | ||
// detect native touch action support | ||
// Detect native touch action support | ||
const HAS_NATIVE_TA = typeof document.head.style.touchAction === 'string'; | ||
@@ -35,10 +35,10 @@ const GESTURE_KEY = '__polymerGestures'; | ||
const TOUCH_ACTION = '__polymerGesturesTouchAction'; | ||
// radius for tap and track | ||
// Radius for tap and track | ||
const TAP_DISTANCE = 25; | ||
const TRACK_DISTANCE = 5; | ||
// number of last N track positions to keep | ||
// Number of last N track positions to keep | ||
const TRACK_LENGTH = 2; | ||
const MOUSE_EVENTS = ['mousedown', 'mousemove', 'mouseup', 'click']; | ||
// an array of bitmask values for mapping MouseEvent.which to MouseEvent.buttons | ||
// An array of bitmask values for mapping MouseEvent.which to MouseEvent.buttons | ||
const MOUSE_WHICH_TO_BUTTONS = [0, 1, 4, 2]; | ||
@@ -117,10 +117,10 @@ const MOUSE_HAS_BUTTONS = (function () { | ||
const type = ev.type; | ||
// exit early if the event is not a mouse event | ||
// Exit early if the event is not a mouse event | ||
if (!isMouseEvent(type)) { | ||
return false; | ||
} | ||
// ev.button is not reliable for mousemove (0 is overloaded as both left button and no buttons) | ||
// Ev.button is not reliable for mousemove (0 is overloaded as both left button and no buttons) | ||
// instead we use ev.buttons (bitmask of buttons) or fall back to ev.which (deprecated, 0 for no buttons, 1 for left button) | ||
if (type === 'mousemove') { | ||
// allow undefined for testing events | ||
// Allow undefined for testing events | ||
let buttons = ev.buttons === undefined ? 1 : ev.buttons; | ||
@@ -130,8 +130,8 @@ if (ev instanceof window.MouseEvent && !MOUSE_HAS_BUTTONS) { | ||
} | ||
// buttons is a bitmask, check that the left button bit is set (1) | ||
// Buttons is a bitmask, check that the left button bit is set (1) | ||
return Boolean(buttons & 1); | ||
} | ||
// allow undefined for testing events | ||
// Allow undefined for testing events | ||
const button = ev.button === undefined ? 0 : ev.button; | ||
// ev.button is 0 in mousedown/mouseup/click for left button activation | ||
// Ev.button is 0 in mousedown/mouseup/click for left button activation | ||
return button === 0; | ||
@@ -142,11 +142,11 @@ } | ||
if (ev.type === 'click') { | ||
// ev.detail is 0 for HTMLElement.click in most browsers | ||
// Ev.detail is 0 for HTMLElement.click in most browsers | ||
if (ev.detail === 0) { | ||
return true; | ||
} | ||
// in the worst case, check that the x/y position of the click is within | ||
// In the worst case, check that the x/y position of the click is within | ||
// the bounding box of the target of the event | ||
// Thanks IE 10 >:( | ||
const t = _findOriginalTarget(ev); | ||
// make sure the target of the event is an element so we can use getBoundingClientRect, | ||
// Make sure the target of the event is an element so we can use getBoundingClientRect, | ||
// if not, just assume it is a synthetic click | ||
@@ -157,6 +157,6 @@ if (!t.nodeType || /** @type {Element} */ (t).nodeType !== Node.ELEMENT_NODE) { | ||
const bcr = /** @type {Element} */ (t).getBoundingClientRect(); | ||
// use page x/y to account for scrolling | ||
// Use page x/y to account for scrolling | ||
const x = ev.pageX, | ||
y = ev.pageY; | ||
// ev is a synthetic click if the position is outside the bounding box of the target | ||
// Ev is a synthetic click if the position is outside the bounding box of the target | ||
return !(x >= bcr.left && x <= bcr.right && y >= bcr.top && y <= bcr.bottom); | ||
@@ -237,10 +237,10 @@ } | ||
let next = node; | ||
// this code path is only taken when native ShadowDOM is used | ||
// This code path is only taken when native ShadowDOM is used | ||
// if there is a shadowroot, it may have a node at x/y | ||
// if there is not a shadowroot, exit the loop | ||
while (next && next.shadowRoot && !window.ShadyDOM) { | ||
// if there is a node at x/y in the shadowroot, look deeper | ||
// If there is a node at x/y in the shadowroot, look deeper | ||
const oldNext = next; | ||
next = next.shadowRoot.elementFromPoint(x, y); | ||
// on Safari, elementFromPoint may return the shadowRoot host | ||
// On Safari, elementFromPoint may return the shadowRoot host | ||
if (oldNext === next) { | ||
@@ -257,3 +257,3 @@ break; | ||
/** | ||
* a cheaper check than ev.composedPath()[0]; | ||
* A cheaper check than ev.composedPath()[0]; | ||
* | ||
@@ -289,6 +289,5 @@ * @private | ||
if (type.slice(0, 5) === 'touch') { | ||
// ev = /** @type {TouchEvent} */ (ev); // eslint-disable-line no-self-assign | ||
const t = ev.changedTouches[0]; | ||
if (type === 'touchstart') { | ||
// only handle the first finger | ||
// Only handle the first finger | ||
if (ev.touches.length === 1) { | ||
@@ -309,7 +308,7 @@ POINTERSTATE.touch.id = t.identifier; | ||
const handled = ev[HANDLED_OBJ]; | ||
// used to ignore synthetic mouse events | ||
// Used to ignore synthetic mouse events | ||
if (handled.skip) { | ||
return; | ||
} | ||
// reset recognizer state | ||
// Reset recognizer state | ||
for (let i = 0, r; i < recognizers.length; i++) { | ||
@@ -323,3 +322,3 @@ r = recognizers[i]; | ||
} | ||
// enforce gesture recognizer order | ||
// Enforce gesture recognizer order | ||
for (let i = 0, r; i < recognizers.length; i++) { | ||
@@ -356,3 +355,3 @@ r = recognizers[i]; | ||
if (!ev.cancelable) { | ||
// scrolling is happening | ||
// Scrolling is happening | ||
} else if (ta === 'none') { | ||
@@ -407,3 +406,3 @@ shouldPrevent = true; | ||
/** | ||
* automate the event listeners for the native events | ||
* Automate the event listeners for the native events | ||
* | ||
@@ -426,3 +425,3 @@ * @private | ||
dep = deps[i]; | ||
// don't add mouse handlers on iOS because they cause gray selection overlays | ||
// Don't add mouse handlers on iOS because they cause gray selection overlays | ||
if (IS_TOUCH_ONLY && isMouseEvent(dep) && dep !== 'click') { | ||
@@ -448,3 +447,3 @@ continue; | ||
/** | ||
* automate event listener removal for native events | ||
* Automate event listener removal for native events | ||
* | ||
@@ -546,3 +545,3 @@ * @private | ||
wrap(/** @type {!Node} */ (target)).dispatchEvent(ev); | ||
// forward `preventDefault` in a clean way | ||
// Forward `preventDefault` in a clean way | ||
if (ev.defaultPrevented) { | ||
@@ -587,3 +586,3 @@ const preventer = detail.preventer || detail.sourceEvent; | ||
*/ | ||
reset: function () { | ||
reset() { | ||
untrackDocument(this.info); | ||
@@ -597,3 +596,3 @@ }, | ||
*/ | ||
mousedown: function (e) { | ||
mousedown(e) { | ||
if (!hasLeftMouseButton(e)) { | ||
@@ -626,3 +625,3 @@ return; | ||
*/ | ||
touchstart: function (e) { | ||
touchstart(e) { | ||
downupFire('down', _findOriginalTarget(e), e.changedTouches[0], e); | ||
@@ -636,3 +635,3 @@ }, | ||
*/ | ||
touchend: function (e) { | ||
touchend(e) { | ||
downupFire('up', _findOriginalTarget(e), e.changedTouches[0], e); | ||
@@ -657,4 +656,4 @@ }, | ||
sourceEvent: event, | ||
preventer: preventer, | ||
prevent: function (e) { | ||
preventer, | ||
prevent(e) { | ||
return prevent(e); | ||
@@ -682,3 +681,3 @@ }, | ||
/** @this {GestureInfo} */ | ||
addMove: function (move) { | ||
addMove(move) { | ||
if (this.moves.length > TRACK_LENGTH) { | ||
@@ -698,3 +697,3 @@ this.moves.shift(); | ||
*/ | ||
reset: function () { | ||
reset() { | ||
this.info.state = 'start'; | ||
@@ -714,3 +713,3 @@ this.info.started = false; | ||
*/ | ||
mousedown: function (e) { | ||
mousedown(e) { | ||
if (!hasLeftMouseButton(e)) { | ||
@@ -726,11 +725,11 @@ return; | ||
if (trackHasMovedEnough(self.info, x, y)) { | ||
// first move is 'start', subsequent moves are 'move', mouseup is 'end' | ||
// First move is 'start', subsequent moves are 'move', mouseup is 'end' | ||
self.info.state = self.info.started ? (e.type === 'mouseup' ? 'end' : 'track') : 'start'; | ||
if (self.info.state === 'start') { | ||
// if and only if tracking, always prevent tap | ||
// If and only if tracking, always prevent tap | ||
prevent('tap'); | ||
} | ||
self.info.addMove({ x: x, y: y }); | ||
self.info.addMove({ x, y }); | ||
if (!hasLeftMouseButton(e)) { | ||
// always fire "end" | ||
// Always fire "end" | ||
self.info.state = 'end'; | ||
@@ -750,6 +749,6 @@ untrackDocument(self.info); | ||
// remove the temporary listeners | ||
// Remove the temporary listeners | ||
untrackDocument(self.info); | ||
}; | ||
// add temporary document listeners as mouse retargets | ||
// Add temporary document listeners as mouse retargets | ||
trackDocument(this.info, movefn, upfn); | ||
@@ -765,3 +764,3 @@ this.info.x = e.clientX; | ||
*/ | ||
touchstart: function (e) { | ||
touchstart(e) { | ||
const ct = e.changedTouches[0]; | ||
@@ -777,3 +776,3 @@ this.info.x = ct.clientX; | ||
*/ | ||
touchmove: function (e) { | ||
touchmove(e) { | ||
const t = _findOriginalTarget(e); | ||
@@ -785,6 +784,6 @@ const ct = e.changedTouches[0]; | ||
if (this.info.state === 'start') { | ||
// if and only if tracking, always prevent tap | ||
// If and only if tracking, always prevent tap | ||
prevent('tap'); | ||
} | ||
this.info.addMove({ x: x, y: y }); | ||
this.info.addMove({ x, y }); | ||
trackFire(this.info, t, ct); | ||
@@ -801,8 +800,8 @@ this.info.state = 'track'; | ||
*/ | ||
touchend: function (e) { | ||
touchend(e) { | ||
const t = _findOriginalTarget(e); | ||
const ct = e.changedTouches[0]; | ||
// only trackend if track was started and not aborted | ||
// Only trackend if track was started and not aborted | ||
if (this.info.started) { | ||
// reset started state on up | ||
// Reset started state on up | ||
this.info.state = 'end'; | ||
@@ -857,8 +856,8 @@ this.info.addMove({ x: ct.clientX, y: ct.clientY }); | ||
y: touch.clientY, | ||
dx: dx, | ||
dy: dy, | ||
ddx: ddx, | ||
ddy: ddy, | ||
dx, | ||
dy, | ||
ddx, | ||
ddy, | ||
sourceEvent: touch, | ||
hover: function () { | ||
hover() { | ||
return deepTargetFind(touch.clientX, touch.clientY); | ||
@@ -887,3 +886,3 @@ }, | ||
*/ | ||
reset: function () { | ||
reset() { | ||
this.info.x = NaN; | ||
@@ -899,3 +898,3 @@ this.info.y = NaN; | ||
*/ | ||
mousedown: function (e) { | ||
mousedown(e) { | ||
if (hasLeftMouseButton(e)) { | ||
@@ -912,3 +911,3 @@ this.info.x = e.clientX; | ||
*/ | ||
click: function (e) { | ||
click(e) { | ||
if (hasLeftMouseButton(e)) { | ||
@@ -924,3 +923,3 @@ trackForward(this.info, e); | ||
*/ | ||
touchstart: function (e) { | ||
touchstart(e) { | ||
const touch = e.changedTouches[0]; | ||
@@ -936,3 +935,3 @@ this.info.x = touch.clientX; | ||
*/ | ||
touchend: function (e) { | ||
touchend(e) { | ||
trackForward(this.info, e.changedTouches[0], e); | ||
@@ -951,3 +950,3 @@ }, | ||
const dy = Math.abs(e.clientY - info.y); | ||
// find original target from `preventer` for TouchEvents, or `e` for MouseEvents | ||
// Find original target from `preventer` for TouchEvents, or `e` for MouseEvents | ||
const t = _findOriginalTarget(preventer || e); | ||
@@ -957,5 +956,5 @@ if (!t || (canBeDisabled[/** @type {!HTMLElement} */ (t).localName] && t.hasAttribute('disabled'))) { | ||
} | ||
// dx,dy can be NaN if `click` has been simulated and there was no `down` for `start` | ||
// Dx,dy can be NaN if `click` has been simulated and there was no `down` for `start` | ||
if (isNaN(dx) || isNaN(dy) || (dx <= TAP_DISTANCE && dy <= TAP_DISTANCE) || isSyntheticClick(e)) { | ||
// prevent taps from being generated if an event has canceled them | ||
// Prevent taps from being generated if an event has canceled them | ||
if (!info.prevent) { | ||
@@ -966,3 +965,3 @@ _fire(t, 'tap', { | ||
sourceEvent: e, | ||
preventer: preventer, | ||
preventer, | ||
}); | ||
@@ -969,0 +968,0 @@ } |
@@ -169,3 +169,3 @@ /** | ||
get _hiddenContentSize() { | ||
var size = this.grid ? this._physicalRows * this._rowHeight : this._physicalSize; | ||
const size = this.grid ? this._physicalRows * this._rowHeight : this._physicalSize; | ||
return size - this._viewportHeight; | ||
@@ -186,3 +186,3 @@ }, | ||
get _maxVirtualStart() { | ||
var virtualCount = this._convertIndexToCompleteRow(this._virtualCount); | ||
const virtualCount = this._convertIndexToCompleteRow(this._virtualCount); | ||
return Math.max(0, virtualCount - this._physicalCount); | ||
@@ -260,5 +260,5 @@ }, | ||
get firstVisibleIndex() { | ||
var idx = this._firstVisibleIndexVal; | ||
let idx = this._firstVisibleIndexVal; | ||
if (idx == null) { | ||
var physicalOffset = this._physicalTop + this._scrollOffset; | ||
let physicalOffset = this._physicalTop + this._scrollOffset; | ||
@@ -288,3 +288,3 @@ idx = | ||
get lastVisibleIndex() { | ||
var idx = this._lastVisibleIndexVal; | ||
let idx = this._lastVisibleIndexVal; | ||
if (idx == null) { | ||
@@ -294,3 +294,3 @@ if (this.grid) { | ||
} else { | ||
var physicalOffset = this._physicalTop + this._scrollOffset; | ||
let physicalOffset = this._physicalTop + this._scrollOffset; | ||
this._iterateItems((pidx, vidx) => { | ||
@@ -331,6 +331,6 @@ if (physicalOffset < this._scrollBottom) { | ||
*/ | ||
_scrollHandler: function () { | ||
var scrollTop = Math.max(0, Math.min(this._maxScrollTop, this._scrollTop)); | ||
var delta = scrollTop - this._scrollPosition; | ||
var isScrollingDown = delta >= 0; | ||
_scrollHandler() { | ||
const scrollTop = Math.max(0, Math.min(this._maxScrollTop, this._scrollTop)); | ||
let delta = scrollTop - this._scrollPosition; | ||
const isScrollingDown = delta >= 0; | ||
// Track the current scroll position. | ||
@@ -344,3 +344,3 @@ this._scrollPosition = scrollTop; | ||
delta -= this._scrollOffset; | ||
var idxAdjustment = Math.round(delta / this._physicalAverage) * this._itemsPerRow; | ||
const idxAdjustment = Math.round(delta / this._physicalAverage) * this._itemsPerRow; | ||
this._virtualStart += idxAdjustment; | ||
@@ -360,3 +360,3 @@ this._physicalStart += idxAdjustment; | ||
} else if (this._physicalCount > 0) { | ||
var reusables = this._getReusables(isScrollingDown); | ||
const reusables = this._getReusables(isScrollingDown); | ||
if (isScrollingDown) { | ||
@@ -381,14 +381,14 @@ this._physicalTop = reusables.physicalTop; | ||
*/ | ||
_getReusables: function (fromTop) { | ||
var ith, lastIth, offsetContent, physicalItemHeight; | ||
var idxs = []; | ||
var protectedOffsetContent = this._hiddenContentSize * this._ratio; | ||
var virtualStart = this._virtualStart; | ||
var virtualEnd = this._virtualEnd; | ||
var physicalCount = this._physicalCount; | ||
var top = this._physicalTop + this._scrollOffset; | ||
var bottom = this._physicalBottom + this._scrollOffset; | ||
_getReusables(fromTop) { | ||
let ith, lastIth, offsetContent, physicalItemHeight; | ||
const idxs = []; | ||
const protectedOffsetContent = this._hiddenContentSize * this._ratio; | ||
const virtualStart = this._virtualStart; | ||
const virtualEnd = this._virtualEnd; | ||
const physicalCount = this._physicalCount; | ||
let top = this._physicalTop + this._scrollOffset; | ||
const bottom = this._physicalBottom + this._scrollOffset; | ||
// This may be called outside of a scrollHandler, so use last cached position | ||
var scrollTop = this._scrollPosition; | ||
var scrollBottom = this._scrollBottom; | ||
const scrollTop = this._scrollPosition; | ||
const scrollBottom = this._scrollBottom; | ||
@@ -446,3 +446,3 @@ if (fromTop) { | ||
*/ | ||
_update: function (itemSet, movingUp) { | ||
_update(itemSet, movingUp) { | ||
if ((itemSet && itemSet.length === 0) || this._physicalCount === 0) { | ||
@@ -457,3 +457,3 @@ return; | ||
while (movingUp.length) { | ||
var idx = movingUp.pop(); | ||
const idx = movingUp.pop(); | ||
this._physicalTop -= this._getPhysicalSizeIncrement(idx); | ||
@@ -466,3 +466,3 @@ } | ||
_isClientFull: function () { | ||
_isClientFull() { | ||
return ( | ||
@@ -478,4 +478,4 @@ this._scrollBottom !== 0 && | ||
*/ | ||
_increasePoolIfNeeded: function (count) { | ||
var nextPhysicalCount = this._clamp( | ||
_increasePoolIfNeeded(count) { | ||
let nextPhysicalCount = this._clamp( | ||
this._physicalCount + count, | ||
@@ -487,3 +487,3 @@ DEFAULT_PHYSICAL_COUNT, | ||
if (this.grid) { | ||
var correction = nextPhysicalCount % this._itemsPerRow; | ||
const correction = nextPhysicalCount % this._itemsPerRow; | ||
if (correction && nextPhysicalCount - correction <= this._physicalCount) { | ||
@@ -494,4 +494,4 @@ nextPhysicalCount += this._itemsPerRow; | ||
} | ||
var delta = nextPhysicalCount - this._physicalCount; | ||
var nextIncrease = Math.round(this._physicalCount * 0.5); | ||
const delta = nextPhysicalCount - this._physicalCount; | ||
let nextIncrease = Math.round(this._physicalCount * 0.5); | ||
@@ -502,3 +502,3 @@ if (delta < 0) { | ||
if (delta > 0) { | ||
var ts = window.performance.now(); | ||
const ts = window.performance.now(); | ||
// Concat arrays in place. | ||
@@ -508,3 +508,3 @@ [].push.apply(this._physicalItems, this._createPool(delta)); | ||
// support it. | ||
for (var i = 0; i < delta; i++) { | ||
for (let i = 0; i < delta; i++) { | ||
this._physicalSizes.push(0); | ||
@@ -548,3 +548,3 @@ } | ||
*/ | ||
_render: function () { | ||
_render() { | ||
if (!this.isAttached || !this._isVisible) { | ||
@@ -554,3 +554,3 @@ return; | ||
if (this._physicalCount !== 0) { | ||
var reusables = this._getReusables(true); | ||
const reusables = this._getReusables(true); | ||
this._physicalTop = reusables.physicalTop; | ||
@@ -569,3 +569,3 @@ this._virtualStart += reusables.indexes.length; | ||
_gridChanged: function (newGrid, oldGrid) { | ||
_gridChanged(newGrid, oldGrid) { | ||
if (typeof oldGrid === 'undefined') { | ||
@@ -585,3 +585,3 @@ return; | ||
*/ | ||
_itemsChanged: function (change) { | ||
_itemsChanged(change) { | ||
if (change.path === 'items') { | ||
@@ -607,3 +607,3 @@ this._virtualStart = 0; | ||
// Only blur if at least one item is added or removed. | ||
var itemAddedOrRemoved = change.value.indexSplices.some((splice) => { | ||
const itemAddedOrRemoved = change.value.indexSplices.some((splice) => { | ||
return splice.addedCount > 0 || splice.removed.length > 0; | ||
@@ -614,3 +614,3 @@ }); | ||
// #507). | ||
var activeElement = this._getActiveElement(); | ||
const activeElement = this._getActiveElement(); | ||
if (this.contains(activeElement)) { | ||
@@ -621,3 +621,3 @@ activeElement.blur(); | ||
// Render only if the affected index is rendered. | ||
var affectedIndexRendered = change.value.indexSplices.some((splice) => { | ||
const affectedIndexRendered = change.value.indexSplices.some((splice) => { | ||
return splice.index + splice.addedCount >= this._virtualStart && splice.index <= this._virtualEnd; | ||
@@ -641,4 +641,4 @@ }); | ||
*/ | ||
_iterateItems: function (fn, itemSet) { | ||
var pidx, vidx, rtn, i; | ||
_iterateItems(fn, itemSet) { | ||
let pidx, vidx, rtn, i; | ||
@@ -675,3 +675,3 @@ if (arguments.length === 2 && itemSet) { | ||
*/ | ||
_computeVidx: function (pidx) { | ||
_computeVidx(pidx) { | ||
if (pidx >= this._physicalStart) { | ||
@@ -688,3 +688,3 @@ return this._virtualStart + (pidx - this._physicalStart); | ||
*/ | ||
_updateMetrics: function (itemSet) { | ||
_updateMetrics(itemSet) { | ||
// Make sure we distributed all the physical items | ||
@@ -694,6 +694,6 @@ // so we can measure them. | ||
var newPhysicalSize = 0; | ||
var oldPhysicalSize = 0; | ||
var prevAvgCount = this._physicalAverageCount; | ||
var prevPhysicalAvg = this._physicalAverage; | ||
let newPhysicalSize = 0; | ||
let oldPhysicalSize = 0; | ||
const prevAvgCount = this._physicalAverageCount; | ||
const prevPhysicalAvg = this._physicalAverage; | ||
@@ -727,3 +727,3 @@ // eslint-disable-next-line @typescript-eslint/no-unused-vars | ||
_updateGridMetrics: function () { | ||
_updateGridMetrics() { | ||
this._itemWidth = this._physicalCount > 0 ? this._physicalItems[0].getBoundingClientRect().width : 200; | ||
@@ -737,14 +737,14 @@ this._rowHeight = this._physicalCount > 0 ? this._physicalItems[0].offsetHeight : 200; | ||
*/ | ||
_positionItems: function () { | ||
_positionItems() { | ||
this._adjustScrollPosition(); | ||
var y = this._physicalTop; | ||
let y = this._physicalTop; | ||
if (this.grid) { | ||
var totalItemWidth = this._itemsPerRow * this._itemWidth; | ||
var rowOffset = (this._viewportWidth - totalItemWidth) / 2; | ||
const totalItemWidth = this._itemsPerRow * this._itemWidth; | ||
const rowOffset = (this._viewportWidth - totalItemWidth) / 2; | ||
this._iterateItems((pidx, vidx) => { | ||
var modulus = vidx % this._itemsPerRow; | ||
var x = Math.floor(modulus * this._itemWidth + rowOffset); | ||
const modulus = vidx % this._itemsPerRow; | ||
let x = Math.floor(modulus * this._itemWidth + rowOffset); | ||
if (this._isRTL) { | ||
@@ -776,3 +776,3 @@ x *= -1; | ||
_getPhysicalSizeIncrement: function (pidx) { | ||
_getPhysicalSizeIncrement(pidx) { | ||
if (!this.grid) { | ||
@@ -795,3 +795,3 @@ return this._physicalSizes[pidx]; | ||
*/ | ||
_shouldRenderNextRow: function (vidx) { | ||
_shouldRenderNextRow(vidx) { | ||
return vidx % this._itemsPerRow === this._itemsPerRow - 1; | ||
@@ -803,4 +803,4 @@ }, | ||
*/ | ||
_adjustScrollPosition: function () { | ||
var deltaHeight = | ||
_adjustScrollPosition() { | ||
const deltaHeight = | ||
this._virtualStart === 0 ? this._physicalTop : Math.min(this._scrollPosition + this._physicalTop, 0); | ||
@@ -811,4 +811,4 @@ // Note: the delta can be positive or negative. | ||
// This may be called outside of a scrollHandler, so use last cached position | ||
var scrollTop = this._scrollPosition; | ||
// juking scroll position during interial scrolling on iOS is no bueno | ||
const scrollTop = this._scrollPosition; | ||
// Juking scroll position during interial scrolling on iOS is no bueno | ||
if (!IOS_TOUCH_SCROLLING && scrollTop > 0) { | ||
@@ -823,3 +823,3 @@ this._resetScrollPosition(scrollTop - deltaHeight); | ||
*/ | ||
_resetScrollPosition: function (pos) { | ||
_resetScrollPosition(pos) { | ||
if (this.scrollTarget && pos >= 0) { | ||
@@ -836,3 +836,3 @@ this._scrollTop = pos; | ||
*/ | ||
_updateScrollerSize: function (forceUpdate) { | ||
_updateScrollerSize(forceUpdate) { | ||
if (this.grid) { | ||
@@ -862,3 +862,3 @@ this._estScrollHeight = this._virtualRowCount * this._rowHeight; | ||
*/ | ||
scrollToIndex: function (idx) { | ||
scrollToIndex(idx) { | ||
if (typeof idx !== 'number' || idx < 0 || idx > this.items.length - 1) { | ||
@@ -883,7 +883,7 @@ return; | ||
var currentTopItem = this._physicalStart; | ||
var currentVirtualItem = this._virtualStart; | ||
var targetOffsetTop = 0; | ||
var hiddenContentSize = this._hiddenContentSize; | ||
// scroll to the item as much as we can. | ||
let currentTopItem = this._physicalStart; | ||
let currentVirtualItem = this._virtualStart; | ||
let targetOffsetTop = 0; | ||
const hiddenContentSize = this._hiddenContentSize; | ||
// Scroll to the item as much as we can. | ||
while (currentVirtualItem < idx && targetOffsetTop <= hiddenContentSize) { | ||
@@ -898,3 +898,3 @@ targetOffsetTop += this._getPhysicalSizeIncrement(currentTopItem); | ||
this._increasePoolIfNeeded(0); | ||
// clear cached visible index. | ||
// Clear cached visible index. | ||
this._firstVisibleIndexVal = null; | ||
@@ -907,3 +907,3 @@ this._lastVisibleIndexVal = null; | ||
*/ | ||
_resetAverage: function () { | ||
_resetAverage() { | ||
this._physicalAverage = 0; | ||
@@ -917,7 +917,7 @@ this._physicalAverageCount = 0; | ||
*/ | ||
_resizeHandler: function () { | ||
_resizeHandler() { | ||
this._debounce( | ||
'_render', | ||
() => { | ||
// clear cached visible index. | ||
// Clear cached visible index. | ||
this._firstVisibleIndexVal = null; | ||
@@ -946,3 +946,3 @@ this._lastVisibleIndexVal = null; | ||
*/ | ||
updateSizeForItem: function (item) { | ||
updateSizeForItem(item) { | ||
return this.updateSizeForIndex(this.items.indexOf(item)); | ||
@@ -957,3 +957,3 @@ }, | ||
*/ | ||
updateSizeForIndex: function (index) { | ||
updateSizeForIndex(index) { | ||
if (!this._isIndexRendered(index)) { | ||
@@ -971,4 +971,4 @@ return null; | ||
*/ | ||
_convertIndexToCompleteRow: function (idx) { | ||
// when grid == false _itemPerRow can be unset. | ||
_convertIndexToCompleteRow(idx) { | ||
// When grid == false _itemPerRow can be unset. | ||
this._itemsPerRow = this._itemsPerRow || 1; | ||
@@ -978,19 +978,19 @@ return this.grid ? Math.ceil(idx / this._itemsPerRow) * this._itemsPerRow : idx; | ||
_isIndexRendered: function (idx) { | ||
_isIndexRendered(idx) { | ||
return idx >= this._virtualStart && idx <= this._virtualEnd; | ||
}, | ||
_isIndexVisible: function (idx) { | ||
_isIndexVisible(idx) { | ||
return idx >= this.firstVisibleIndex && idx <= this.lastVisibleIndex; | ||
}, | ||
_getPhysicalIndex: function (vidx) { | ||
_getPhysicalIndex(vidx) { | ||
return (this._physicalStart + (vidx - this._virtualStart)) % this._physicalCount; | ||
}, | ||
_clamp: function (v, min, max) { | ||
_clamp(v, min, max) { | ||
return Math.min(max, Math.max(min, v)); | ||
}, | ||
_debounce: function (name, cb, asyncModule) { | ||
_debounce(name, cb, asyncModule) { | ||
this._debouncers = this._debouncers || {}; | ||
@@ -997,0 +997,0 @@ this._debouncers[name] = Debouncer.debounce(this._debouncers[name], asyncModule, cb.bind(this)); |
@@ -35,3 +35,3 @@ /** | ||
if (!Object.prototype.hasOwnProperty.call(obj, name)) { | ||
// clone any existing entries (superclasses) | ||
// Clone any existing entries (superclasses) | ||
obj[name] = new Map(obj[name]); | ||
@@ -127,3 +127,3 @@ } | ||
// set this method | ||
// Set this method | ||
this.getOrCreateMap('__observers').set(name, method); | ||
@@ -143,3 +143,3 @@ | ||
} else if (!this.hasOwnProperty('__notifyProps')) { | ||
// clone any existing observers (superclasses) | ||
// Clone any existing observers (superclasses) | ||
const notifyProps = this.__notifyProps; | ||
@@ -149,3 +149,3 @@ this.__notifyProps = new Set(notifyProps); | ||
// set this method | ||
// Set this method | ||
this.__notifyProps.add(name); | ||
@@ -152,0 +152,0 @@ } |
@@ -19,2 +19,8 @@ /** | ||
protected _onResize(contentRect: DOMRect): void; | ||
/** | ||
* When true, the parent element resize will be also observed. | ||
* Override this getter and return `true` to enable this. | ||
*/ | ||
protected readonly _observeParent: boolean; | ||
} |
@@ -11,3 +11,10 @@ /** | ||
entries.forEach((entry) => { | ||
entry.target._onResize(entry.contentRect); | ||
// Notify child resizables, if any | ||
if (entry.target.resizables) { | ||
entry.target.resizables.forEach((resizable) => { | ||
resizable._onResize(entry.contentRect); | ||
}); | ||
} else { | ||
entry.target._onResize(entry.contentRect); | ||
} | ||
}); | ||
@@ -29,2 +36,14 @@ }); | ||
observer.observe(this); | ||
if (this._observeParent) { | ||
const parent = this.parentNode instanceof ShadowRoot ? this.parentNode.host : this.parentNode; | ||
if (!parent.resizables) { | ||
parent.resizables = new Set(); | ||
observer.observe(parent); | ||
} | ||
parent.resizables.add(this); | ||
this.__parent = parent; | ||
} | ||
} | ||
@@ -36,5 +55,30 @@ | ||
observer.unobserve(this); | ||
const parent = this.__parent; | ||
if (this._observeParent && parent) { | ||
const resizables = parent.resizables; | ||
if (resizables) { | ||
resizables.delete(this); | ||
if (resizables.size === 0) { | ||
observer.unobserve(parent); | ||
} | ||
} | ||
this.__parent = null; | ||
} | ||
} | ||
/** | ||
* When true, the parent element resize will be also observed. | ||
* Override this getter and return `true` to enable this. | ||
* | ||
* @protected | ||
*/ | ||
get _observeParent() { | ||
return false; | ||
} | ||
/** | ||
* A handler invoked on host resize. By default, it does nothing. | ||
@@ -41,0 +85,0 @@ * Override the method to implement your own behavior. |
@@ -11,3 +11,3 @@ /** | ||
// iron-list can by default handle sizes up to around 100000. | ||
// Iron-list can by default handle sizes up to around 100000. | ||
// When the size is larger than MAX_VIRTUAL_COUNT _vidxOffset is used | ||
@@ -176,4 +176,4 @@ const MAX_VIRTUAL_COUNT = 100000; | ||
// Record the scroll position before changing the size | ||
let fvi; // first visible index | ||
let fviOffsetBefore; // scroll offset of the first visible index | ||
let fvi; // First visible index | ||
let fviOffsetBefore; // Scroll offset of the first visible index | ||
if (size > 0) { | ||
@@ -309,2 +309,11 @@ fvi = this.adjustedFirstVisibleIndex; | ||
if (this._physicalCount !== 0) { | ||
// After running super._scrollHandler, fix _virtualStart to workaround an iron-list issue. | ||
// See https://github.com/vaadin/web-components/issues/1691 | ||
const reusables = this._getReusables(true); | ||
this._physicalTop = reusables.physicalTop; | ||
this._virtualStart += reusables.indexes.length; | ||
this._physicalStart += reusables.indexes.length; | ||
} | ||
if (this.reorderElements) { | ||
@@ -311,0 +320,0 @@ this.__scrollReorderDebouncer = Debouncer.debounce( |
178117
5084