Files
MokoSuiteStoreLocator/CHANGELOG.md
T
Jonathan Miller 7ef9a23ef8
Universal: Auto Version Bump / Version Bump (push) Successful in 9s
Joomla: Extension CI / Tests (PHP 8.2) (pull_request) Blocked by required conditions
Joomla: Extension CI / Tests (PHP 8.3) (pull_request) Blocked by required conditions
Joomla: Extension CI / PHPStan Analysis (pull_request) Blocked by required conditions
Joomla: Extension CI / Build RC Pre-Release (pull_request) Blocked by required conditions
Universal: PR Check / Build RC Package (pull_request) Blocked by required conditions
Universal: PR Check / Report Issues (pull_request) Blocked by required conditions
Generic: Repo Health / Scripts governance (pull_request) Blocked by required conditions
Generic: Repo Health / Repository health (pull_request) Blocked by required conditions
Generic: Repo Health / Report Issues (pull_request) Blocked by required conditions
Universal: PR Check / Branch Policy (pull_request) Failing after 2s
Joomla: Extension CI / Release Readiness Check (pull_request) Failing after 6s
Generic: Repo Health / Access control (pull_request) Successful in 3s
Generic: Repo Health / Site Health (pull_request) Has been skipped
Universal: PR Check / Validate PR (pull_request) Failing after 6s
Universal: PR Check / Secret Scan (pull_request) Successful in 7s
Universal: Build & Release / Promote to RC (pull_request) Failing after 15s
Universal: Build & Release / Build & Release Pipeline (pull_request) Has been skipped
Joomla: Extension CI / Lint & Validate (pull_request) Successful in 38s
Joomla: Metadata Validation / Validate Joomla Metadata (pull_request) Successful in 43s
feat: v1.1 competitive parity — proximity search, directions, geocoding, CSV import
Haversine proximity search:
- LocationsModel filters by distance using Haversine formula
- populateState captures lat/lng/radius/radius_unit from search form
- Distance-sorted results when proximity filter is active
- Hidden radius_unit field added to search module form

Get Directions:
- Google Maps directions link on location detail page (no API key)
- Directions link in Leaflet popup markers

Auto-geocoding:
- LocationModel::save() override auto-geocodes empty coordinates
- Calls Nominatim/OSM API when address present but coords missing
- Success/failure messages via Joomla enqueueMessage

CSV Import:
- ImportController handles file upload with CSRF token check
- ImportModel parses CSV via SplFileObject with configurable delimiter
- Auto-detects column headers (title/name, address/street, city, etc.)
- Per-row validation via LocationTable::bind()->check()->store()
- Import view with upload form, delimiter picker, and column help
- Toolbar button and submenu item for import access

Addresses #54

Authored-by: Moko Consulting
2026-06-23 11:50:02 -05:00

3.5 KiB

Changelog

All notable changes to this project will be documented in this file.

The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.

[1.1.0] - Unreleased

Added

  • Haversine proximity search — filter locations by distance from user's coordinates
  • Hidden radius_unit field in search module to pass miles/km preference to component
  • Distance-sorted results when proximity search is active
  • "Get Directions" link on location detail page (Google Maps, no API key needed)
  • "Get Directions" link in Leaflet map popup markers
  • Auto-geocoding on admin save — coordinates populated from address via Nominatim/OSM API
  • CSV import: upload CSV file to bulk-create locations
  • CSV import: auto-detect column headers (title/name/store, address/street, city, etc.)
  • CSV import: per-row validation via LocationTable::bind()->check()->store()
  • CSV import view accessible from admin toolbar and submenu
  • Language strings for directions, geocoding feedback, and import UI

[1.0.0] - 2026-06-23

Added

  • Admin LocationController (FormController) for single-record save/cancel/apply
  • Admin LocationsController (AdminController) for bulk publish/unpublish/delete
  • Admin location edit view and tabbed template (Details, Address, Contact)
  • Admin locations list renders data rows with edit links and published toggle
  • LocationTable::check() validation: required title, auto-alias, lat/lng range, timestamps
  • LocationsModel::populateState() for filter persistence
  • Search filter across title, city, state, address
  • Published state filter and sort ordering support
  • Filter form XML (filter_locations.xml) with search tools bar
  • Language strings for filters, sort options, and save messages
  • Site frontend DisplayController routing to list and detail views
  • Site LocationsModel — published locations with search, city, and state filters
  • Site LocationModel — single location by ID (published only)
  • Site locations list view with Schema.org LocalBusiness markup and pagination
  • Site location detail view with address, contact, hours, and map placeholder
  • SEF URL router (Service\Router) with menu/standard/nomenu rules
  • Menu item types: "All Locations" list and "Location Detail" with location picker
  • Site language strings for frontend views and menu items
  • Router registered in service provider and component extension class
  • Map module dispatcher loads published locations with coordinates from DB
  • Leaflet.js/OpenStreetMap integration with markers, popups, and auto-fit bounds
  • Leaflet CSS/JS loaded via Joomla Web Asset Manager (registerAndUseStyle/registerAndUseScript)
  • Search module dispatcher loads distinct cities/states and builds radius options
  • City dropdown filter on search form (populated from DB, toggled by module param)
  • Radius dropdown filter with configurable distance values and unit (miles/km)
  • Geolocation "Use My Location" button with browser geolocation API
  • Hidden lat/lng fields passed to component for proximity search
  • Language strings for search module (city, radius, geolocation states)

Removed

  • Makefile (no longer used)
  • deploy-manual.yml workflow

Previous (scaffold)

  • Initial package scaffold with component, map module, and search module
  • Database schema for locations table with coordinates
  • Admin MVC skeleton for location CRUD
  • Map module with Leaflet/Google Maps provider support (stub)
  • Search module with city and radius filter options (stub)