Account created on 29 September 2011, over 13 years ago
#

Merge Requests

More

Recent comments

🇫🇷France DrDam

Ok, nice catch.

But the point I doesn't understood is how you generate derivatives from the images in the external DAM ?
The derivativ exist in the DAM ? ou it be generated "on the flow" when delivered to client ?

🇫🇷France DrDam

@norman.lol :

In which class do you propose adding this method?

🇫🇷France DrDam

the unlink in createContextualizedDerivativePath() are present to prevent non replacement of derivativ in 1.x versions.

Nice catch

🇫🇷France DrDam

It seems it was corrected in ImageWidgetCrop 3.x

On a fresh drupal install
- I have create 2 crop type
- On a unique image style, I add 2 effect "manual crop" (one for each crop)
- On the article mange display interface, I choose the image style which use the both crop
- On the article manage form display, I choose "ImageWidget Crop" widget. It only propose the "last crop type" for selection.

see 3259571-IWC.png & 3259571-imageStyles.png

I propose to close this issue

🇫🇷France DrDam

- I am using patches so I'm not sure why it didn't patch, but explicitly decorating a service or altering a route is more reliable.

I don't want altering any route, native controller work fine, and I need it continue making is job has he do. I juste want limit code duplication.

If you prefer not using this patch, the last release without it is the 2.1.4

🇫🇷France DrDam

That's not the goal ... I don't want alter it, I want be able to extends (herite from it) without duplicate 40% of it's code...

see #2685905 Refactor ImageStyleDownloadController so derivatives can be generated by contrib modules Needs work for more informations

🇫🇷France DrDam

I just add the interface, but I have a doubt about making all methods public ... if some one can check

🇫🇷France DrDam

Did you check if this patch have been applied ?

"drupal/core": {
                "Refactor ImageStyleDownloadController": "https://git.drupalcode.org/project/drupal/-/merge_requests/10766.patch"
            }

This patch change things in core ImageStyleDownloadController in order to extract some technical elements, used in the ContextualImageStyleDownloadController::process method

🇫🇷France DrDam

did you check bout media_contextual_crop collection, and more precisly focal_point adapter module ?

🇫🇷France DrDam

@nikolay shapovalov : sorry for that, after nearly 2 month, I have presume it be ok for you ...

🇫🇷France DrDam

@nikolay shapovalov :
"Do you think we can add interface for these new methods?"

I don't know ...
The purpose of the RM is simply to separate the processing/generation of the derivatives from the various validation/authorisation operations linked to this generation.

@oily : I don't know either what @deviantintegral want to say, when it create the issue.
I just done my best when @smustgrave ask me to update summary to the "good template"
I have my use case "with mediaContextualCrop, we want to create a new image delivering methodebased on 80% of the ImageStyleDownloadController" for the others I don't know their motivations.

🇫🇷France DrDam

The "Null" label is created by the "->label()" method because at this stage (node creation) the "title" ( targeted by the method) is null. I.E. there is no "saved title" for the current entity.

🇫🇷France DrDam

drdam made their first commit to this issue’s fork.

🇫🇷France DrDam

Create MR for 11.x and reroll #16 on it

🇫🇷France DrDam

drdam made their first commit to this issue’s fork.

🇫🇷France DrDam

For test coverage, I don't what it need to be tested, it just code management, no new functionnality.

🇫🇷France DrDam

I have rework the "association loop" for trying to manage mixte between not-upscaling / upsaling.

The association between size and imageStyle are "not optimal" because of #10 and #11, but it doesn't really matter because the derivative will be the same, just not in the "best folder" on the disk

🇫🇷France DrDam

Exemple as a native src-set image :

The "tiniest" size ( 100px) better fit for the thumbnail image style are associate with the "wide" image style because it's the "last" of the list.

🇫🇷France DrDam

The problem is that the imageStyle stack does not provide a simple way of finding the ‘expected size of the derivative if the source image is large enough not to be upscaled’ for an image style.
In fact, it is not possible to ‘classify’ image styles by this ‘expected size’ and therefore to find the ‘smallest’ image style that is most suitable.

The anomaly is present in native ResponsiveImages too.

🇫🇷France DrDam

In fact, this case is not natively covered by nativ responsiveImage because of the possible mixe between "allow/no-allow" upscaling.

🇫🇷France DrDam

But if you editing the media, you change it on all its usage

🇫🇷France DrDam

drdam changed the visibility of the branch 3496234-better-handling-of to active.

🇫🇷France DrDam

@deepali sardana : thanks for the merge Request, but I'll close it, because there is a lighter way to acheive that.

🇫🇷France DrDam

drdam changed the visibility of the branch 2685905-refactor-imagestyledownloadcontroller-so to hidden.

🇫🇷France DrDam

drdam changed the visibility of the branch 3228376-cant-delete-a to hidden.

🇫🇷France DrDam

Can you make the MR for the 2.x branch ?

the 1.x branch are minimaly maintained now

thanks

🇫🇷France DrDam

diag : the point here is the same as many (many) other Crop/Image anomalies, Drupal Core don't know how handle multiple "version" of the same derivative ( I.E. couple ImageStyle x ImageFile ).

There is no real solution base of maintening the current implementation of the "focal point preview" feature.

2 solutions are possibles :
- Simulate the rendering (by CSS/html style manipulation) instead using the full derivative generation
- Add some "context" to the derivativ generation (I.E. hack some core process in order add this feature)

🇫🇷France DrDam

drdam changed the visibility of the branch 3214798-crop-effect-can to hidden.

🇫🇷France DrDam

drdam made their first commit to this issue’s fork.

🇫🇷France DrDam

You need to install the 2.3 and make the db update first, and after update to 2.4.

If it's the case, maybe a better "message/communication my be better"

🇫🇷France DrDam

When using media, you need some configurations :

  1. in the "host content type" (node)
    • in the form mode : media library as widget
    • in the view mode : display media with a specific render mode "foo"
  2. in the "media image"
    • in the form mode : the image widget crop widget
    • in the view mode "foo" : render image with a specific image style using a crop
🇫🇷France DrDam

Did you check about media_contextual_crop ?

This module provide a way to wire crop and medias

🇫🇷France DrDam

I have split the doTestFileUriAlter method in order to have "clean" code separation

🇫🇷France DrDam

Fix reviews & add test

🇫🇷France DrDam

I think this two issues (phpstan & phpcs) may be merge BEFORE other merge resquests

🇫🇷France DrDam

And at first sight it looks like methods: getCropFromImageStyle, getCropFromImageStyleId, cropExists, findCrop should be moved away from CropInterface. Maybe we need to make bigger refactor to impove developers expirience.

I totaly agree, but without knowing the history of the implementation, it's not clear how far the refactor can go.

🇫🇷France DrDam

The question is whether the current behavior is “intentional” or a case that was not anticipated.

🇫🇷France DrDam

We are hosting on Pantheon which sits behind the Fastly CDN. Sounds like disabling flush_derivative_images is recommended with this setup?

that's what I would recommend. The "derivative cache" are supported by the CDN, so no need to "force drupal" to handle it.

I've read this a couple of times and I think that you are missing the word "no" in the above sentence, that "... there is no way to detect...". Can you clarify ?

You are right, I fix my message. There is no way

Production build 0.71.5 2024