Skip to content

Commit

Permalink
feature symfony#2350 [Map] Introduce `ux_map.google_maps.default_map_…
Browse files Browse the repository at this point in the history
…id` configuration (Kocal)

This PR was merged into the 2.x branch.

Discussion
----------

[Map] Introduce `ux_map.google_maps.default_map_id` configuration

| Q             | A
| ------------- | ---
| Bug fix?      | no
| New feature?  | yes <!-- please update src/**/CHANGELOG.md files -->
| Issues        | Fix symfony#2306 <!-- prefix each issue number with "Fix #", no need to create an issue if none exist, explain below instead -->
| License       | MIT

<!--
Replace this notice by a description of your feature/bugfix.
This will help reviewers and should be a good start for the documentation.

Additionally (see https://symfony.com/releases):
 - Always add tests and ensure they pass.
 - For new features, provide some code snippets to help understand usage.
 - Features and deprecations must be submitted against branch main.
 - Changelog entry should follow https://symfony.com/doc/current/contributing/code/conventions.html#writing-a-changelog-entry
 - Never break backward compatibility (see https://symfony.com/bc).
-->

With this modification, I can configure a default Google Maps `mapId`:
```yaml
# config/packages/ux_map.yaml
ux_map:
    # https://symfony.com/bundles/ux-map/current/index.html#available-renderers
    renderer: '%env(resolve:default::UX_MAP_DSN)%'
    google_maps:
        default_map_id: abcdefgh123456789
```
without having to manually pass the `mapId` when creating a `Map`:
```php
// use default mapId
$map = (new Map());
    ->center(new Point(48.8566, 2.3522))
    ->zoom(6);

// use default mapId
$map2 = (clone $map)
    ->options(new GoogleOptions());

// use custom mapId
$map3 = (clone $map)
    ->options(new GoogleOptions(mapId: 'foobar));
```

Commits
-------

cbacecc [Map] Introduce `ux_map.google_maps.default_map_id` configuration
  • Loading branch information
Kocal committed Nov 10, 2024
2 parents 7dff0df + cbacecc commit e74c44e
Show file tree
Hide file tree
Showing 9 changed files with 87 additions and 4 deletions.
5 changes: 5 additions & 0 deletions src/Map/CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,4 +1,9 @@
# CHANGELOG

## 2.22

- Add method `Symfony\UX\Map\Renderer\AbstractRenderer::tapOptions()`, to allow Renderer to modify options before rendering a Map.
- Add `ux_map.google_maps.default_map_id` configuration to set the Google ``Map ID``

## 2.20

Expand Down
2 changes: 0 additions & 2 deletions src/Map/config/twig_component.php
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,6 @@
namespace Symfony\Component\DependencyInjection\Loader\Configurator;

use Symfony\UX\Map\Twig\UXMapComponent;
use Symfony\UX\Map\Twig\UXMapComponentListener;
use Symfony\UX\TwigComponent\Event\PreCreateForRenderEvent;

return static function (ContainerConfigurator $container): void {
$container->services()
Expand Down
6 changes: 6 additions & 0 deletions src/Map/src/Bridge/Google/CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,11 @@
# CHANGELOG

## 2.22

- Add support for configuring a default Map ID
- Add argument `$defaultMapId` to `Symfony\UX\Map\Bridge\Google\Renderer\GoogleRendererFactory` constructor
- Add argument `$defaultMapId` to `Symfony\UX\Map\Bridge\Google\Renderer\GoogleRenderer` constructor

## 2.20

### BC Breaks
Expand Down
5 changes: 5 additions & 0 deletions src/Map/src/Bridge/Google/src/GoogleOptions.php
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,11 @@ public function mapId(?string $mapId): self
return $this;
}

public function hasMapId(): bool
{
return null !== $this->mapId;
}

public function gestureHandling(GestureHandling $gestureHandling): self
{
$this->gestureHandling = $gestureHandling;
Expand Down
16 changes: 15 additions & 1 deletion src/Map/src/Bridge/Google/src/Renderer/GoogleRenderer.php
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@ public function __construct(
* @var array<'core'|'maps'|'places'|'geocoding'|'routes'|'marker'|'geometry'|'elevation'|'streetView'|'journeySharing'|'drawing'|'visualization'>
*/
private array $libraries = [],
private ?string $defaultMapId = null,
) {
parent::__construct($stimulusHelper);
}
Expand All @@ -66,7 +67,20 @@ protected function getProviderOptions(): array

protected function getDefaultMapOptions(): MapOptionsInterface
{
return new GoogleOptions();
return new GoogleOptions(mapId: $this->defaultMapId);
}

protected function tapOptions(MapOptionsInterface $options): MapOptionsInterface
{
if (!$options instanceof GoogleOptions) {
throw new \InvalidArgumentException(\sprintf('The options must be an instance of "%s", got "%s" instead.', GoogleOptions::class, get_debug_type($options)));
}

if (!$options->hasMapId()) {
$options->mapId($this->defaultMapId);
}

return $options;
}

public function __toString(): string
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,12 +17,20 @@
use Symfony\UX\Map\Renderer\Dsn;
use Symfony\UX\Map\Renderer\RendererFactoryInterface;
use Symfony\UX\Map\Renderer\RendererInterface;
use Symfony\UX\StimulusBundle\Helper\StimulusHelper;

/**
* @author Hugo Alliaume <[email protected]>
*/
final class GoogleRendererFactory extends AbstractRendererFactory implements RendererFactoryInterface
{
public function __construct(
StimulusHelper $stimulus,
private ?string $defaultMapId = null,
) {
parent::__construct($stimulus);
}

public function create(Dsn $dsn): RendererInterface
{
if (!$this->supports($dsn)) {
Expand All @@ -42,6 +50,7 @@ public function create(Dsn $dsn): RendererInterface
url: $dsn->getOption('url'),
version: $dsn->getOption('version', 'weekly'),
libraries: ['maps', 'marker', ...$dsn->getOption('libraries', [])],
defaultMapId: $this->defaultMapId,
);
}

Expand Down
18 changes: 18 additions & 0 deletions src/Map/src/Bridge/Google/tests/GoogleRendererTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -78,5 +78,23 @@ public function provideTestRenderMap(): iterable
fullscreenControl: false,
)),
];

yield 'with default map id' => [
'expected_renderer' => '<div data-controller="symfony--ux-google-map--map" data-symfony--ux-google-map--map-provider-options-value="{&quot;apiKey&quot;:&quot;my_api_key&quot;}" data-symfony--ux-google-map--map-view-value="{&quot;center&quot;:{&quot;lat&quot;:48.8566,&quot;lng&quot;:2.3522},&quot;zoom&quot;:12,&quot;fitBoundsToMarkers&quot;:false,&quot;options&quot;:{&quot;mapId&quot;:&quot;DefaultMapId&quot;,&quot;gestureHandling&quot;:&quot;auto&quot;,&quot;backgroundColor&quot;:null,&quot;disableDoubleClickZoom&quot;:false,&quot;zoomControlOptions&quot;:{&quot;position&quot;:22},&quot;mapTypeControlOptions&quot;:{&quot;mapTypeIds&quot;:[],&quot;position&quot;:14,&quot;style&quot;:0},&quot;streetViewControlOptions&quot;:{&quot;position&quot;:22},&quot;fullscreenControlOptions&quot;:{&quot;position&quot;:20}},&quot;markers&quot;:[],&quot;polygons&quot;:[]}"></div>',
'renderer' => new GoogleRenderer(new StimulusHelper(null), 'my_api_key', defaultMapId: 'DefaultMapId'),
'map' => (clone $map),
];
yield 'with default map id, when passing options (except the "mapId")' => [
'expected_renderer' => '<div data-controller="symfony--ux-google-map--map" data-symfony--ux-google-map--map-provider-options-value="{&quot;apiKey&quot;:&quot;my_api_key&quot;}" data-symfony--ux-google-map--map-view-value="{&quot;center&quot;:{&quot;lat&quot;:48.8566,&quot;lng&quot;:2.3522},&quot;zoom&quot;:12,&quot;fitBoundsToMarkers&quot;:false,&quot;options&quot;:{&quot;mapId&quot;:&quot;DefaultMapId&quot;,&quot;gestureHandling&quot;:&quot;auto&quot;,&quot;backgroundColor&quot;:null,&quot;disableDoubleClickZoom&quot;:false,&quot;zoomControlOptions&quot;:{&quot;position&quot;:22},&quot;mapTypeControlOptions&quot;:{&quot;mapTypeIds&quot;:[],&quot;position&quot;:14,&quot;style&quot;:0},&quot;streetViewControlOptions&quot;:{&quot;position&quot;:22},&quot;fullscreenControlOptions&quot;:{&quot;position&quot;:20}},&quot;markers&quot;:[],&quot;polygons&quot;:[]}"></div>',
'renderer' => new GoogleRenderer(new StimulusHelper(null), 'my_api_key', defaultMapId: 'DefaultMapId'),
'map' => (clone $map)
->options(new GoogleOptions()),
];
yield 'with default map id overridden by option "mapId"' => [
'expected_renderer' => '<div data-controller="symfony--ux-google-map--map" data-symfony--ux-google-map--map-provider-options-value="{&quot;apiKey&quot;:&quot;my_api_key&quot;}" data-symfony--ux-google-map--map-view-value="{&quot;center&quot;:{&quot;lat&quot;:48.8566,&quot;lng&quot;:2.3522},&quot;zoom&quot;:12,&quot;fitBoundsToMarkers&quot;:false,&quot;options&quot;:{&quot;mapId&quot;:&quot;CustomMapId&quot;,&quot;gestureHandling&quot;:&quot;auto&quot;,&quot;backgroundColor&quot;:null,&quot;disableDoubleClickZoom&quot;:false,&quot;zoomControlOptions&quot;:{&quot;position&quot;:22},&quot;mapTypeControlOptions&quot;:{&quot;mapTypeIds&quot;:[],&quot;position&quot;:14,&quot;style&quot;:0},&quot;streetViewControlOptions&quot;:{&quot;position&quot;:22},&quot;fullscreenControlOptions&quot;:{&quot;position&quot;:20}},&quot;markers&quot;:[],&quot;polygons&quot;:[]}"></div>',
'renderer' => new GoogleRenderer(new StimulusHelper(null), 'my_api_key', defaultMapId: 'DefaultMapId'),
'map' => (clone $map)
->options(new GoogleOptions(mapId: 'CustomMapId')),
];
}
}
14 changes: 14 additions & 0 deletions src/Map/src/Renderer/AbstractRenderer.php
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,18 @@ abstract protected function getProviderOptions(): array;

abstract protected function getDefaultMapOptions(): MapOptionsInterface;

/**
* @template T of MapOptionsInterface
*
* @param T $options
*
* @return T
*/
protected function tapOptions(MapOptionsInterface $options): MapOptionsInterface
{
return $options;
}

final public function renderMap(Map $map, array $attributes = []): string
{
if (!$map->hasOptions()) {
Expand All @@ -39,6 +51,8 @@ final public function renderMap(Map $map, array $attributes = []): string
$map->options($defaultMapOptions);
}

$map->options($this->tapOptions($map->getOptions()));

$controllers = [];
if ($attributes['data-controller'] ?? null) {
$controllers[$attributes['data-controller']] = [];
Expand Down
16 changes: 15 additions & 1 deletion src/Map/src/UXMapBundle.php
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,12 @@ public function configure(DefinitionConfigurator $definition): void
$rootNode
->children()
->scalarNode('renderer')->defaultNull()->end()
->arrayNode('google_maps')
->addDefaultsIfNotSet()
->children()
->scalarNode('default_map_id')->defaultNull()->end()
->end()
->end()
->end()
;
}
Expand Down Expand Up @@ -75,9 +81,17 @@ public function loadExtension(array $config, ContainerConfigurator $container, C
foreach (self::$bridges as $name => $bridge) {
if (ContainerBuilder::willBeAvailable('symfony/ux-'.$name.'-map', $bridge['renderer_factory'], ['symfony/ux-map'])) {
$container->services()
->set('ux_map.renderer_factory.'.$name, $bridge['renderer_factory'])
->set($rendererFactoryName = 'ux_map.renderer_factory.'.$name, $bridge['renderer_factory'])
->parent('ux_map.renderer_factory.abstract')
->tag('ux_map.renderer_factory');

if ('google' === $name) {
$container->services()
->get($rendererFactoryName)
->args([
'$defaultMapId' => $config['google_maps']['default_map_id'],
]);
}
}
}
}
Expand Down

0 comments on commit e74c44e

Please sign in to comment.