Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

SVG height and width attributes #6

Open
jeremymoore opened this issue Jul 31, 2019 · 2 comments · Fixed by #216
Open

SVG height and width attributes #6

jeremymoore opened this issue Jul 31, 2019 · 2 comments · Fixed by #216
Labels
help wanted Extra attention is needed

Comments

@jeremymoore
Copy link

Hi @darylldoyle

What are your thoughts on trying to assign the default height and width attributes based on the image size used in the wp_get_attachment_image() function?

echo wp_get_attachment_image( $svg_id, [78, 78], true, [
     'class' => 'img-fluid',
     'alt' => 'icon',
] );

For example, when I use the above in my template with your plugin activated my SVG is loaded with the height and width attributes set to the images default size. I, however, would like the height and width to be 78x78.

I ended up using the following filter in my theme to work around the issue... but i think this would be worth considering incorporating into the plugin.

add_filter( 'wp_get_attachment_image_attributes', 'wwc_fix_direct_image_output', 11, 3 );
function wwc_fix_direct_image_output( $attr, $attachment, $size = 'thumbnail' ) {

	// If we're not getting a WP_Post object, bail early.
	// @see https://wordpress.org/support/topic/notice-trying-to-get-property-id/
	if ( ! $attachment instanceof WP_Post ) {
		return $attr;
	}

	$mime = get_post_mime_type( $attachment->ID );
	if ( 'image/svg+xml' === $mime ) {
		$default_height = 100;
		$default_width  = 100;

		$size = image_downsize($attachment->ID, $size);
		
		if (is_array($size) && sizeof($size) >= 3) {
			$attr['height'] = $size[2];
			$attr['width']  = $size[1];
		}
	}

	return $attr;
}```
@jeffpaul jeffpaul added this to the Future Release milestone Aug 31, 2021
@jeffpaul jeffpaul added type:question Further information is requested. type:enhancement New feature or request. labels Aug 31, 2021
@darylldoyle
Copy link
Collaborator

Thanks for the info @jeremymoore.

I think this could be a great enhancement moving forward, especially taking CLS into account now.

@jeffpaul this could work by wrapping lines 471-476 in a conditional that checks for the full size and otherwise returning the size requested as above.

We should also take into account that $size may be an array rather than a string with a named size.

@jeffpaul jeffpaul added help wanted Extra attention is needed and removed type:question Further information is requested. labels Aug 31, 2021
@jeffpaul jeffpaul moved this to Incoming in Open Source Practice Dec 21, 2021
@jeffpaul jeffpaul moved this from Incoming to Backlog in Open Source Practice Dec 21, 2021
@jeffpaul jeffpaul moved this from Backlog to To Do in Open Source Practice Jun 28, 2022
@jayedul jayedul self-assigned this Feb 1, 2023
@jayedul jayedul moved this from To Do to In Progress in Open Source Practice Feb 1, 2023
@jeffpaul jeffpaul moved this from In Progress to To Do in Open Source Practice Jan 16, 2024
@gabriel-glo gabriel-glo self-assigned this Jul 22, 2024
@gabriel-glo gabriel-glo linked a pull request Jul 22, 2024 that will close this issue
4 tasks
@gabriel-glo gabriel-glo moved this from To Do to In Progress in Open Source Practice Jul 23, 2024
@gabriel-glo gabriel-glo moved this from In Progress to Code Review in Open Source Practice Jul 23, 2024
@jeffpaul jeffpaul modified the milestones: Future Release, 2.3.0 Aug 26, 2024
@github-project-automation github-project-automation bot moved this from Code Review to Done in Open Source Practice Nov 20, 2024
@dkotter
Copy link
Collaborator

dkotter commented Dec 5, 2024

Reopening this as we reverted #216. I still think worth considering how best to allow someone to pass in height and width attributes and use those in the resulting SVG markup but I'd suggest we don't change how named image sizes work, which is what we did in #216.

@dkotter dkotter reopened this Dec 5, 2024
@dkotter dkotter modified the milestones: 2.3.0, Future Release Dec 5, 2024
@dkotter dkotter moved this from Done to Backlog in Open Source Practice Dec 5, 2024
@jeffpaul jeffpaul removed the type:enhancement New feature or request. label Dec 5, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
help wanted Extra attention is needed
Projects
Status: Backlog
Development

Successfully merging a pull request may close this issue.

6 participants