1
0
Fork 0
mirror of https://github.com/overleaf/overleaf.git synced 2025-04-17 06:27:36 +00:00

Merge pull request from overleaf/td-review-panel-smoother-chrome

React review panel: fix regression that made animation jerky on Chrome

GitOrigin-RevId: c1d9fa00d478fa71d94ff705ddfcc12bab0b2767
This commit is contained in:
Tim Down 2023-07-27 10:55:10 +01:00 committed by Copybot
parent e7479c789f
commit 98a847ae75
2 changed files with 11 additions and 11 deletions
services/web/frontend/js
features/source-editor/extensions/changes
shared/components

View file

@ -39,7 +39,7 @@ export const dispatchReviewPanelLayout = (force = false) => {
const scheduleDispatchReviewPanelLayout = debounce(
dispatchReviewPanelLayout,
50
10
)
export type ChangeManager = {
@ -307,11 +307,10 @@ export const createChangeManager = (
if (changed) {
dispatchEditorEvent('track-changes:visibility_changed')
}
dispatchReviewPanelLayout()
// Ensure the layout is updated again once the review panel entries
// have updated in the React review panel. The use of a timeout is bad
// but the timings are a bit of a mess and will be improved when the
// review panel state is migrated away from Angular
// Ensure the layout is updated once the review panel entries have
// updated in the React review panel. The use of a timeout is bad but
// the timings are a bit of a mess and will be improved when the review
// panel state is migrated away from Angular
scheduleDispatchReviewPanelLayout()
break
}

View file

@ -36,25 +36,26 @@ function AutoExpandingTextArea({
...rest
}: AutoExpandingTextAreaProps) {
const ref = useRef<HTMLTextAreaElement>(null)
const isFirstResizeRef = useRef(true)
useEffect(() => {
if (!ref.current || !onResize || !('ResizeObserver' in window)) {
return
}
let isFirstResize = true
const resizeObserver = new ResizeObserver(() => {
// Ignore the resize that is triggered when the element is first
// inserted into the DOM
if (isFirstResize) {
isFirstResize = false
if (isFirstResizeRef.current) {
isFirstResizeRef.current = false
} else {
// Prevent errors like "ResizeObserver loop completed with undelivered
// notifications" that occur if onResize does something complicated.
// The cost of this is that onResize lags one frame behind, but it's
// unlikely to matter.
window.requestAnimationFrame(onResize)
// Wrap onResize to prevent extra parameters being passed
window.requestAnimationFrame(() => onResize())
}
})