Skip to content

fix app freeze#762

Open
digitaltom wants to merge 9 commits into
mainfrom
fix_freeze
Open

fix app freeze#762
digitaltom wants to merge 9 commits into
mainfrom
fix_freeze

Conversation

@digitaltom
Copy link
Copy Markdown
Collaborator

No description provided.

Copilot AI review requested due to automatic review settings May 11, 2026 21:31
Copy link
Copy Markdown
Contributor

Copilot AI left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Pull request overview

This PR aims to address intermittent “map freeze” behavior after backgrounding/resume and websocket reconnects by adding runtime watchdogs/recovery logic in the MapLibre initialization path and reducing heavy reinitialization work on reconnect.

Changes:

  • Add visibility-based render/input watchdogs and recovery actions (handler cycling, synthetic pointer-up dispatch, optional forced WebGL context reset).
  • Add WebGL context lost/restored event handling on the map canvas.
  • On websocket reconnect, skip the heavy layer/style rebuild if the page was hidden since last connect.

Reviewed changes

Copilot reviewed 3 out of 3 changed files in this pull request and generated 5 comments.

File Description
app/javascript/maplibre/map.js Adds render heartbeat, WebGL context handlers, visibility watchdog, and input watchdog/recovery logic.
app/javascript/maplibre/controls/buttons/select.js Replaces prior recoverHandlers() usage with direct “debugging” actions on select click.
app/javascript/channels/map_channel.js Adds visibility tracking and conditionally skips reconnect rebuild; adds status messages.

💡 Add Copilot custom instructions for smarter, more guided reviews. Learn how to get started.

Comment thread app/javascript/maplibre/controls/buttons/select.js Outdated
Comment on lines +205 to +211
// Visibility watchdog — silently tracks map activity for 10s after resume so
// the input/render freeze toasts can include the diagnostic summary inline
// (no separate toast that would be clobbered by the freeze toast).
document.addEventListener('visibilitychange', () => {
if (document.visibilityState !== 'visible') return
// map.once('idle', recoverHandlers)
status('Visibility: visible', 'info', 'medium', 1000)

Copy link
Copy Markdown
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please check again.

Comment thread app/javascript/maplibre/map.js Outdated
Comment thread app/javascript/channels/map_channel.js Outdated
Comment on lines +20 to +24
let remoteCursors = new Set()
let wasHiddenSinceLastConnect = false
document.addEventListener('visibilitychange', () => {
if (document.visibilityState === 'hidden') wasHiddenSinceLastConnect = true
});
Copy link
Copy Markdown
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please check again.

Comment thread app/javascript/channels/map_channel.js Outdated
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants