diff --git a/functions-images.php b/functions-images.php
index 79b77fc..baabbe6 100644
--- a/functions-images.php
+++ b/functions-images.php
@@ -239,8 +239,8 @@ function get_timber_picture_fallback_image( $timber_image, $size ) {
* get_timber_image_responsive_src() for a list of args
* that can be used.
*
- * @return string|false Image srcset, sizes, alt and title attributes. False if image can’t be
- * found.
+ * @return string|false Image srcset, sizes, width, height and alt attributes. False if image can’t
+ * be found.
*/
function get_timber_image_responsive( $timber_image, $size, $args = array() ) {
$image = Timmy::get_image( $timber_image, $size );
diff --git a/lib/Image.php b/lib/Image.php
index a5d421b..6456186 100644
--- a/lib/Image.php
+++ b/lib/Image.php
@@ -235,6 +235,26 @@ public function src( $args = [] ) {
return $src;
}
+ /**
+ * Get srcset and size for the image.
+ *
+ * @return string Image srcset, sizes, width, height alt attributes.
+ */
+ public function responsive_src( array $args = [] ) : string {
+ return Helper::get_attribute_html( $this->responsive_attributes( $args ) );
+ }
+
+ /**
+ * Get the responsive markup for the image.
+ *
+ * @return string Image srcset, sizes, width, height alt attributes.
+ */
+ public function responsive( array $args = [] ) : string {
+ return Helper::get_attribute_html( array_merge( $this->responsive_attributes( $args ), [
+ 'alt' => $this->alt(),
+ ] ) );
+ }
+
/**
* Gets the HTML markup for a responsive picture.
*
@@ -599,6 +619,8 @@ public function width() {
if ( empty( $dimensions ) ) {
return false;
}
+
+ // SVG image can scale, so we can always return the requested width.
} else {
list( $width ) = Helper::get_dimensions_upscale( $width, $height, [
'upscale' => $this->upscale,
@@ -634,18 +656,18 @@ public function height() {
$height = Helper::get_height_from_width( $width, $dimensions['width'], $dimensions['height'] );
}
} else {
- $max_width = $this->max_width();
- $max_height = $this->max_height();
-
- // Only calculate new height if height and width metadata was loaded.
- if ( $max_width > 0 && $max_height > 0 ) {
- $height = Helper::maybe_fix_height( $height, $width, $max_width, $max_height );
- list( , $height ) = Helper::get_dimensions_upscale( $width, $height, [
- 'upscale' => $this->upscale,
- 'max_width' => $max_width,
- 'max_height' => $max_height,
- ] );
- }
+ $max_width = $this->max_width();
+ $max_height = $this->max_height();
+
+ // Only calculate new height if height and width metadata was loaded.
+ if ( $max_width > 0 && $max_height > 0 ) {
+ $height = Helper::maybe_fix_height( $height, $width, $max_width, $max_height );
+ list( , $height ) = Helper::get_dimensions_upscale( $width, $height, [
+ 'upscale' => $this->upscale,
+ 'max_width' => $max_width,
+ 'max_height' => $max_height,
+ ] );
+ }
}
return $height;
diff --git a/tests/assets/sveegee.svg b/tests/assets/sveegee.svg
index 852d15e..567f86e 100644
--- a/tests/assets/sveegee.svg
+++ b/tests/assets/sveegee.svg
@@ -1 +1 @@
-
\ No newline at end of file
+
diff --git a/tests/assets/svg-without-viewbox-width-height.svg b/tests/assets/svg-without-viewbox-width-height.svg
new file mode 100644
index 0000000..792fb73
--- /dev/null
+++ b/tests/assets/svg-without-viewbox-width-height.svg
@@ -0,0 +1 @@
+
diff --git a/tests/assets/svg-without-viewbox.svg b/tests/assets/svg-without-viewbox.svg
index 6d8e7c0..7caa99f 100644
--- a/tests/assets/svg-without-viewbox.svg
+++ b/tests/assets/svg-without-viewbox.svg
@@ -1 +1 @@
-
+
diff --git a/tests/test-functions.php b/tests/test-functions.php
index 366c29b..09d92dd 100644
--- a/tests/test-functions.php
+++ b/tests/test-functions.php
@@ -160,6 +160,23 @@ public function test_get_timber_image_responsive() {
$this->assertEquals( $expected, $result );
}
+ public function test_get_timber_image_responsive_apiv1() {
+ $alt_text = 'Burrito Wrap';
+ $attachment = $this->create_image( [
+ 'alt' => $alt_text,
+ 'description' => 'Burritolino',
+ ] );
+
+ $image = Timmy::get_image( $attachment, 'large' );
+ $result = $image->responsive();
+
+ $expected = sprintf(
+ ' srcset="%1$s/test-560x0-c-default.jpg 560w, %1$s/test-1400x0-c-default.jpg 1400w" src="" sizes="100vw" width="1400" height="933" loading="lazy" alt="Burrito Wrap"', $this->get_upload_url()
+ );
+
+ $this->assertEquals( $expected, $result );
+ }
+
public function test_get_timber_image_responsive_without_metadata() {
$alt_text = 'Burrito Wrap';
$attachment = $this->create_image( [
@@ -279,6 +296,23 @@ public function test_get_timber_image_responsive_src_loading_false() {
$this->assertEquals( $expected, $result );
}
+ public function test_get_timber_image_responsive_src_loading_false_apiv1() {
+ $attachment = $this->create_image();
+
+ $image = Timmy::get_image( $attachment, 'large' );
+
+ $result = $image->responsive_src( [
+ 'loading' => false,
+ ] );
+
+ $expected = sprintf(
+ ' srcset="%1$s/test-560x0-c-default.jpg 560w, %1$s/test-1400x0-c-default.jpg 1400w" src="" sizes="100vw" width="1400" height="933"',
+ $this->get_upload_url()
+ );
+
+ $this->assertEquals( $expected, $result );
+ }
+
public function test_get_timber_image_full_with_gif() {
$attachment = $this->create_image( [ 'file' => 'logo-small.gif' ] );
$result = get_timber_image( $attachment, 'full' );
@@ -363,6 +397,20 @@ public function test_get_timber_image_srcset_x_descriptors() {
$this->assertEquals( $expected, $result );
}
+ public function test_get_timber_image_srcset_x_descriptors_apiv1() {
+ $attachment = $this->create_image();
+
+ $image = Timmy::get_image( $attachment, 'large-x-descriptors' );
+ $result = $image->srcset();
+
+ $expected = sprintf(
+ '%1$s/test-560x0-c-default.jpg 560w, %1$s/test-1400x0-c-default.jpg 1x, %1$s/test-2100x0-c-default.jpg 1.5x',
+ $this->get_upload_url()
+ );
+
+ $this->assertEquals( $expected, $result );
+ }
+
public function test_get_timber_image_width() {
$attachment = $this->create_image();
diff --git a/tests/test-svg.php b/tests/test-svg.php
index 10d11d9..d8439fd 100644
--- a/tests/test-svg.php
+++ b/tests/test-svg.php
@@ -55,4 +55,26 @@ public function test_svg_responsive_rect_without_viewbox() {
$this->assertEquals( $image, $result );
}
+
+ public function test_svg_responsive_rect_without_viewbox_responsive() {
+ $attachment = $this->create_image( [ 'file' => 'svg-without-viewbox.svg' ] );
+
+ $image = \Timmy\Timmy::get_image( $attachment, 'large' );
+ $result = $image->responsive();
+
+ $image = ' src="' . $this->get_upload_url() . '/svg-without-viewbox.svg" loading="lazy" alt=""';
+
+ $this->assertEquals( $image, $result );
+ }
+
+ public function test_svg_responsive_rect_without_viewbox_but_width_and_height_responsive() {
+ $attachment = $this->create_image( [ 'file' => 'svg-without-viewbox-width-height.svg' ] );
+
+ $image = \Timmy\Timmy::get_image( $attachment, 'large' );
+ $result = $image->responsive();
+
+ $image = ' src="' . $this->get_upload_url() . '/svg-without-viewbox-width-height.svg" width="1400" height="1400" loading="lazy" alt=""';
+
+ $this->assertEquals( $image, $result );
+ }
}