diff --git a/config/fields/color.php b/config/fields/color.php index d39ad1ba40..60f7247ba2 100644 --- a/config/fields/color.php +++ b/config/fields/color.php @@ -1,5 +1,6 @@ A::map($options, fn ($option) => [ - 'value' => $option['text'] - ]), + ) { + // simple array of values + // or value=text (from Options class) + $options = A::map($options, fn ($option) => [ + 'value' => $option['text'] + ]); + + } elseif ($this->isColor($options[0]['text'])) { + // @deprecated 4.0.0 + // TODO: Remove in Kirby 6 - // deprecated: name => value, flipping - // TODO: start throwing in warning in v5 - $this->isColor($options[0]['text']) - => A::map($options, fn ($option) => [ - 'value' => $option['text'], - // ensure that any HTML in the new text is escaped - 'text' => Escape::html($option['value']) - ]), + Helpers::deprecated('Color field: the text => value notation for options has been deprecated and will be removed in Kirby 6. Please rewrite your options as value => text.'); - default - => A::map($options, fn ($option) => [ + $options = A::map($options, fn ($option) => [ + 'value' => $option['text'], + // ensure that any HTML in the new text is escaped + 'text' => Escape::html($option['value']) + ]); + } else { + $options = A::map($options, fn ($option) => [ 'value' => $option['value'], 'text' => $option['text'] - ]), - }; + ]); + } return $options; } diff --git a/src/Panel/Assets.php b/src/Panel/Assets.php index 6396c89aa2..5da0f4e12d 100644 --- a/src/Panel/Assets.php +++ b/src/Panel/Assets.php @@ -3,6 +3,7 @@ namespace Kirby\Panel; use Kirby\Cms\App; +use Kirby\Cms\Helpers; use Kirby\Cms\Url; use Kirby\Exception\Exception; use Kirby\Exception\InvalidArgumentException; @@ -116,11 +117,7 @@ public function external(): array } /** - * Returns array of favicon icons - * based on config option - * - * @todo Deprecate `url` option in v5, use `href` option instead - * @todo Deprecate `rel` usage as array key in v5, use `rel` option instead + * Returns array of favicon icons based on config option * * @throws \Kirby\Exception\InvalidArgumentException */ @@ -161,12 +158,16 @@ public function favicons(): array foreach ($icons as $rel => &$icon) { // TODO: remove this backward compatibility check in v6 if (isset($icon['url']) === true) { + Helpers::deprecated('`panel.favicon` option: use `href` instead of `url` attribute'); + $icon['href'] = $icon['url']; unset($icon['url']); } // TODO: remove this backward compatibility check in v6 if (is_string($rel) === true && isset($icon['rel']) === false) { + Helpers::deprecated('`panel.favicon` option: use `rel` attribute instead of passing string as key'); + $icon['rel'] = $rel; } diff --git a/tests/Form/Fields/ColorFieldTest.php b/tests/Form/Fields/ColorFieldTest.php index a593f113d3..9c3a9e7a8b 100644 --- a/tests/Form/Fields/ColorFieldTest.php +++ b/tests/Form/Fields/ColorFieldTest.php @@ -78,21 +78,6 @@ public function testOptions() ['value' => '#bbb', 'text' => 'Color b'], ['value' => '#ccc', 'text' => 'Color c'] ], $field->options()); - - // Deprecated: name => value - $field = $this->field('color', [ - 'options' => [ - 'Color a' => '#aaa', - 'Color b' => '#bbb', - 'Color c' => '#ccc' - ], - ]); - - $this->assertSame([ - ['value' => '#aaa', 'text' => 'Color a'], - ['value' => '#bbb', 'text' => 'Color b'], - ['value' => '#ccc', 'text' => 'Color c'] - ], $field->options()); } public function testOptionsFromQuery() @@ -134,26 +119,5 @@ public function testOptionsFromQuery() ['value' => '#bbb', 'text' => 'Color b'], ['value' => '#ccc', 'text' => 'Color c'] ], $field->options()); - - // Deprecated: name => value - $this->app = new App([ - 'options' => [ - 'foo' => [ - 'Color a' => '#aaa', - 'Color b' => '#bbb', - 'Color c' => '#ccc' - ], - ] - ]); - - $field = $this->field('color', [ - 'options' => ['type' => 'query', 'query' => 'kirby.option("foo")'], - ]); - - $this->assertSame([ - ['value' => '#aaa', 'text' => 'Color a'], - ['value' => '#bbb', 'text' => 'Color b'], - ['value' => '#ccc', 'text' => 'Color c'] - ], $field->options()); } } diff --git a/tests/Panel/AssetsTest.php b/tests/Panel/AssetsTest.php index 1457e164ef..203bf2ba4e 100644 --- a/tests/Panel/AssetsTest.php +++ b/tests/Panel/AssetsTest.php @@ -335,74 +335,6 @@ public function testFaviconsWithCustomUrl(): void $this->assertSame($base . '/favicon.svg', $favicons[2]['href']); } - /** - * @todo Remove backward compatibility part test in v5 - */ - public function testFaviconsWithRelIndex(): void - { - // array - $this->app->clone([ - 'options' => [ - 'panel' => [ - 'favicon' => [ - 'shortcut icon' => [ - 'type' => 'image/svg+xml', - 'url' => 'assets/my-favicon.svg', - ], - 'alternate icon' => [ - 'type' => 'image/png', - 'url' => 'assets/my-favicon.png', - ] - ] - ] - ] - ]); - - // default asset setup - $assets = new Assets(); - $favicons = $assets->favicons(); - - // icons - $this->assertSame('shortcut icon', $favicons[0]['rel']); - $this->assertSame('/assets/my-favicon.svg', $favicons[0]['href']); - $this->assertSame('alternate icon', $favicons[1]['rel']); - $this->assertSame('/assets/my-favicon.png', $favicons[1]['href']); - } - - /** - * @todo Remove backward compatibility part test in v5 - */ - public function testFaviconsWithUrlOption(): void - { - // array - $this->app->clone([ - 'options' => [ - 'panel' => [ - 'favicon' => [ - [ - 'rel' => 'shortcut icon', - 'type' => 'image/svg+xml', - 'url' => 'assets/my-favicon.svg', - ], - [ - 'rel' => 'alternate icon', - 'type' => 'image/png', - 'url' => 'assets/my-favicon.png', - ] - ] - ] - ] - ]); - - // default asset setup - $assets = new Assets(); - $favicons = $assets->favicons(); - - // icons - $this->assertSame('/assets/my-favicon.svg', $favicons[0]['href']); - $this->assertSame('/assets/my-favicon.png', $favicons[1]['href']); - } - /** * @covers ::icons */