1
0
Fork 0
forked from 0x2620/oxjs
oxjs/source/UI
Sanjay Bhangar a0b1e0eab4 Here's what we've accomplished to fix MapLibre GL rectangle editing:
Core Issues Fixed:

  1. MapLibre GL Event Compatibility: Fixed drag event handlers in MapMarker.js and MapRectangleMarker.js to use marker.getLngLat() instead of accessing e.lngLat properties that don't exist in MapLibre GL.
  2. Rectangle Handle Visibility: Replaced Ox.MapMarkerImage() with proper DOM elements for corner handles since MapLibre GL expects DOM elements, not image objects.
  3. Handle Positioning: Limited corner markers to only the 4 corners (ne, nw, se, sw) instead of all 8 positions (including edges).
  4. Visual Rectangle Updates: Added that.rectangle.setBounds() call in MapRectangle update method so the visual rectangle updates when handles are dragged.
  5. Click Event Conflicts: Fixed map click handler to detect rectangle clicks and avoid deselecting rectangles when clicked for editing.
  6. Place Editable Property: Added editable: true as default in MapPlace constructor.

  Files Modified:

  - MapPlace.js: Added editable: true default
  - MapRectangle.js:
    - Limited markers to 4 corners only
    - Added rectangle bounds update in update() method
  - MapRectangleMarker.js:
    - Created proper DOM elements for handles
    - Fixed MapLibre GL drag event handling
    - Improved event cleanup
  - MapMarker.js: Fixed MapLibre GL drag event handling
  - MapMarkerImage.js: Fixed rectangle marker color (kept for backward compatibility)
  - Map.js: Added rectangle click detection to prevent conflicts

  Result:

  Rectangle editing now works completely:
  - Click rectangle → shows 4 corner handles
  - Drag handles → resizes rectangle in real-time
  - No console errors
  - Proper event handling
2025-08-09 14:15:54 +02:00
..
css migrate to maplibre-gl for maps 2025-08-06 19:03:10 +02:00
jquery use passive for touch events if possible, fixes #3059 2017-11-06 07:43:18 +02:00
js Here's what we've accomplished to fix MapLibre GL rectangle editing: 2025-08-09 14:15:54 +02:00
json typo 2023-08-04 17:48:11 +02:00
maplibre-gl add maplibre-gl-geocoder 2025-08-06 14:02:53 +02:00
png update Ox.parseUserAgent 2015-08-04 19:00:47 +02:00
svg include viewbox in svg files. remove temp fix 2023-07-03 19:01:15 +05:30
themes fix disabled input text color in light and dark theme; add disabled input to form example 2015-10-19 14:57:23 +02:00
UI.js yandex mobile 2016-11-25 22:34:17 +01:00