- Issue created by @lauriii
- ๐ซ๐ทFrance pdureau Paris
How would a SDC author declare that a component can accept a media image? (Backend)
It should not declare such a thing. Component author must declare a slot, that's all. A slot can accept any renderable. Sending a media image to the slot is the responsibility of the component user, on the CMS side.
How can we load the Media Library within the Experience Builder (which is a React SPA)? (Frontend)
It was started as a React SPA, but will it stay like that? Maybe, one day, we will consider this choice has more drawbacks than advantages.
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
How would a SDC author declare that a component can accept a media image? (Backend)
I agree with @pdureau, sort of.
A "media image" really means:
- a
Media
entity - โฆ of a bundle that is configured to use
\Drupal\media\Plugin\media\Source\Image
- Which corresponds to โฆ an image.
Step 1: SDC author defines the expected shape, and ideally using a predefined JSON schema definition
So, the SDC author should not define what the UX is for getting an image in there. They should declare that they want an image. But there's (at least) 2 kinds of images:
- an URL to an image โ which could be sufficient if it gets used as a background image
- an URL to an image + associated metadata (
alt
+width
+height
), necessary to be used. in an<img>
tag
We haven't gotten very far with making all of these concepts well-defined at the SDC JSON schema level, but we do have some, and we do have it for the aforementioned 2:
- {$ref: 'json-schema-definitions://experience_builder.module/image-uri'}
- {$ref: 'json-schema-definitions://experience_builder.module/image'}
(introduced in https://git.drupalcode.org/project/experience_builder/-/commit/f784af41, which is heavily inspired by @pdureau's https://git.drupalcode.org/project/ui_patterns/-/blob/28cf60dd776fb349d9...)
Step 2: when opting in an SDC component to XB, the default value for each prop determines the field type
๐ "Developer-created components": mark which SDCs should be exposed in XB Fixed landed. One of the next steps is โจ Allow specifying default props values when opting an SDC in for XB Fixed . An implied part of setting up a default value there is that a field type is selected at that time: whichever field type the default value for the
StaticPropSource
uses that the Site Builder configures, also determines what the field type is that Content Creators get to use (they do not get to choose: that'd make the UX unbearably complex).In other words: if the selected default value is some "media image", then the Content Creator will be presented with the ability to use a media image.
- a
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
How can we load the Media Library within the Experience Builder (which is a React SPA)? (Frontend)
This question is insufficiently specific IMHO ๐
We've discussed before that as a first step, we intend to load the existing field widgets in the right-hand sidebar (presumably with their Form API-based definitions automatically rendered using https://www.drupal.org/project/jsx โ , to bring real-time updates โ see ๐ฑ [META] Real-time preview: supporting back-end infrastructure Needs work ).
But โฆ the way that the question is phrased seems to refer to in-place editing. Which is not something we should be doing from the start. See #3453690-10: [META] Real-time preview: supporting back-end infrastructure โ .
- ๐ซ๐ฎFinland lauriii Finland
But โฆ the way that the question is phrased seems to refer to in-place editing. Which is not something we should be doing from the start.
Sorry for causing confusion in regards to the requirements. I did not intend to expand the scope to inline editing. #2 was intended to be specifically about how the field widget (displayed in the right drawer) should be opening the Media Library, and defining how the Media Library modal dialog should be rendered within the Experience Builder. IIRC, we did some initial research that it could be opened in an iframe, and was something that Mercury Editor and/or https://www.drupal.org/project/layout_builder_iframe_modal โ were doing.
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
Ahhhh! So it's more focused on the "this ain't no simple single-document viewport, it's a viewport with many (i)frames" challenge. Now I get it ๐
- ๐ซ๐ทFrance pdureau Paris
We haven't gotten very far with making all of these concepts well-defined at the SDC JSON schema level, but we do have some, and we do have it for the aforementioned 2:
{$ref: 'json-schema-definitions://experience_builder.module/image-uri'}
{$ref: 'json-schema-definitions://experience_builder.module/image'}Indeed, I was a bit "quick" pushing the opaque slot as the only solution. I still thing is by far the best, but a well-defined and structured object prop ("object" according to JSON, so an associative array, a Twig "mapping", not a PHP object) can also do the job, and the JSON schema reference system can help the author.
However, let's not look at the contents of the URI string ("experience_builder", "image") to guess if it is an image or not. Those URI, like every URI, โ are opaque too. An other reference URI (ex:
{$ref: 'json-schema-definitions://whatever.module/amstragram'}
) pulling the same JSON schema structure must be processed the same way. - ๐บ๐ธUnited States ctrladel North Carolina, USA
2.How can we load the Media Library within the Experience Builder (which is a React SPA)? (Frontend)
I've managed to decouple(ish) Entity Browser in the RJSF module, it still depends on some drupalSettings values so it's not fully decoupled. Never explored doing it for Media Library because Entity Browser did a good enough job for my needs and could be used for any entity type. Linking in case it's helpful. https://git.drupalcode.org/project/rjsf/-/tree/1.0.x/modules/rjsf_entity...
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
However, let's not look at the contents of the URI string ("experience_builder", "image") to guess if it is an image or not.
๐ค Why? This would result in broken components wherever images are used. Can you elaborate? ๐
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
Linking in case it's helpful.
Thanks!
- ๐ซ๐ทFrance pdureau Paris
๐ค Why? This would result in broken components wherever images are used. Can you elaborate? ๐
If
{$ref: 'json-schema-definitions://experience_builder.module/image'}
resolve to:{ "type": "object", "properties": { "url": {"type": "string"; "format": "iri-reference"}, "alt": {"type": "string"}, "width": {"type": "integer"}, "height": {"type": "integer"} } }
The schema resolver will juste replace the reference to the resolved JSON schema snippet.
Then, the logic (is it an image?) will apply on the resolved JSON schema.
So, if a component author directly write (without using
$ref
):{ "type": "object", "properties": { "url": {"type": "string"; "format": "iri-reference"}, "alt": {"type": "string"}, "width": {"type": "integer"}, "height": {"type": "integer"} } }
It will also works.
Or if a component author just writes:
{ "type": "object", "properties": { "url": {"type": "string"; "format": "iri-reference"}, "alt": {"type": "string"} } }
It will also works.
Or if a component author uses another reference resolving the same schema snippet.
{$ref: 'json-schema-definitions://whatever.module/amstragram'})
It will also work.
It is solid architecture, using JSON schema reference as expected, without introducing "weird" behaviour by deducing information from the characters in that URL.
- ๐ฆ๐บAustralia larowlan ๐ฆ๐บ๐.au GMT+10
At some point do we need to talk about formatters? Yes we might store a media reference - but we might format it using e.g. a different view mode or a responsive image format
- ๐ซ๐ทFrance pdureau Paris
Integrate the Drupal Media directly with the Experience Builder, allowing users to upload, browse, and select images from the Media Library.
When talking about Experience Builder, it seems we are not talking a lot about the blocks, layout, formatters... plugins. Are they still considered as first class object? Or are they becoming an afterthought? Do we plan to reimplement in Experience builder features already existing in Drupal (like Media Library Browser) instead of leveraging them?
Experience Builder is currently looking like 2 different "products" bundled in one:
- the initially promised easy-to-use, powerful & universal display builder, which will replace Layout Builders and others
- SDC & design system / tokens integration / management / building. Ambitious, but still a bit blurry.
I am worrying this "coupling":
- will ask extra unexpected work, so we will not meet our ambitious projects targets (calendar, scope...)
- will cut experience builder from large parts of the Drupal ecosystem by:
- not exposing the SDC integration to the other tools
- not leveraging the plugins provided by Druapl core & contrib
- will create technical debt (when we will want to replace or revamp one of the 2 parts) and change management risk (if one of the 2 parts of Experience Builder is not welcomed by the community, it will take down the other part with it)
Instead, let's restore the Drupal plugins we all know and love in the centre of the discussions and the architecture, as an interface between the display builder and the design system manager.
What do you think about that?
- ๐ซ๐ฎFinland lauriii Finland
This is blocked on:
- Status changed to Postponed
6 months ago 11:23am 2 July 2024 - ๐ซ๐ฎFinland lauriii Finland
๐ Add component instance edit form to contextual panel RTBC has landed.
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
I think we might be able to bypass the ๐ [PP-1] Add support for matching SDC prop shape: {type: string, enum: โฆ} Postponed blocker by just going with manually defined first. Which is what ๐ Support complex SDC prop shapes: introduce (Storable)PropShape to compute field type storage settings Fixed would allow. I'll revisit this once that's done.
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
Following up on #19: stated that at #3456008-7: [PP-1] Add support for matching SDC prop shape: {type: string, enum: โฆ} โ too ๐
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
To avoid being blocked on ๐ Add component instance edit form to contextual panel RTBC , let's first do ๐ Introduce `hook_storable_prop_shape_alter()`, use it to prefer the Media Library widget for "image" PropShape if Media Library is installed Fixed .
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
As of #3462709-12: Introduce, use it to prefer the Media Library widget for "image" PropShape if Media Library is installed โ , this became actionable ๐
- Status changed to Active
5 months ago 6:52pm 2 August 2024 - ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
- First commit to issue fork.
- ๐ฎ๐ณIndia omkar-pd
omkar-pd โ changed the visibility of the branch 3454173-media-library-widget-in-props-form to hidden.
- ๐ฎ๐ณIndia omkar-pd
omkar-pd โ changed the visibility of the branch 3454173-media-library-widget-in-props-form to active.
- Assigned to bnjmnm
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
@bnjmnm Assigning to you because when we paired on this yesterday, you said you'd do a few more things that I don't see in the MR yet. I don't want our commits to cross. ๐
- Issue was unassigned.
- Assigned to wim leers
- Status changed to Needs work
5 months ago 10:20am 9 August 2024 - Assigned to bnjmnm
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
I pushed things further.
But before I dive very deep into the AJAX system, I want to make sure you're seeing the same error after clicking the button of
MediaLibraryWidget
. Because I'd swear it's different from what you showed me a few days ago ๐This is what I see:
(note thaturl
at the bottom, that's the one it opens)And the response to that request is simply
{}
I also ran into a JS error due to Olivero JS getting loaded โฆ which somehow happens because of attaching
core/drupal.ajax
๐คฏ Did you see that too? Any ideas?Back to you, @bnjmnm ๐ค Will continue this on Monday!
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
Closed ๐ Component props edit form route should use a custom wrapper format Closed: duplicate as a duplicate.
Updating this issue title because that would've been pretty much impossible for @larowlan to find based on the current issue title. (It happened to be relevant for this issue's scope.)
- ๐บ๐ธUnited States bnjmnm Ann Arbor, MI
Found out what is causing the pile of olivero assets being added
core/drupal.ajax
depends oncore/drupal.message
- Olivero extends
core/drupal.message
witholivero/drupal.message
olivero/drupal.message
depends onolivero/messages
olivero/messages
listsolivero/global-styling
as a dependency, adding ~45 CSS files and theolivero/navigation-base
library. Seems like a bit much for a messages library?
The issue I'm running into when attempting to add media via the widget might be the same as the one in #31, but when I discussed it earlier I was showing where it fails server side - it is it looking for an 'image' field on the node entity vs what I'm guessing should instead be a property of a ComponentTreeItem?
If press play in the debugger and let the PHP take its course the end result is the same as#31.
It's not the slickest, but here's a few screenshots of the trace, starting with the most recent just-about-to-throw and a few steps back.
- Assigned to wim leers
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
Epic debugging trail there! ๐ฌ
I'll try to push this further today.
- Assigned to bnjmnm
- ๐บ๐ธUnited States bnjmnm Ann Arbor, MI
With the changes I just pushed up, the widget now works in the props form -> Short video if interested
It does not yet update the layout when the media is updated, though, so that's the next step.
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
#35: thanks for that video, that's awesome! ๐
FYI, I created a critical bug for a long-standing annoyance: ๐ Fix the visually broken "image" component instance: use FileUriItem's computed `url` property, not the stored `value` property Active .
IMHO that belongs in the current sprint because it directly impacts the Barcelona demo. @lauriii confirmed.
(Because
\Drupal\Tests\experience_builder\Kernel\MediaLibraryHookStoragePropAlterTest::getExpectedStorablePropShapes()
also contains theโฆentity:fileโuriโโvalueโฆ
prop expression, so without #3469436, itโll be impossible for @bnjmnm to get a selected image media to render correctly in the XB preview!) - ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
@bnjmnm noticed that this also needed the fix that another front-end issue needed, so landed it in ๐ Follow-up for #3467712: field instance settings lost in ComponentPropsForm Active , to help make this MR slightly simpler.
- ๐บ๐ธUnited States bnjmnm Ann Arbor, MI
The MR is messy as heck right now, but the widget now updates the layout: https://youtu.be/DFiE4r5mEFE, though as discussed previously it is passing the file URI so we're not seeing a new image there, but the alt text change and the prior image going away is pretty good evidence that it works.
There's and extra step to get the existing image to show up in the media library widget when the props form opens, because it's not actually a media entity. Rather, it's an image field using the media library widget. If we want to do this, it will need to create a media entity for the image (perhaps on the fly) so it can be displayed within the widget. That should be easy enough, but I may ask around to be sure it's necessary.
The MR probably has some junk in there from the different approaches I tried to make it work but I assure you it'll be less chaotic soon (but probably still little chaotic)
- ๐ซ๐ฎFinland lauriii Finland
Nice to see this working! ๐คฉ Do we already have an issue to load the media library using the admin theme? Or should we do that here?
There's and extra step to get the existing image to show up in the media library widget when the props form opens, because it's not actually a media entity. Rather, it's an image field using the media library widget. If we want to do this, it will need to create a media entity for the image (perhaps on the fly) so it can be displayed within the widget. That should be easy enough, but I may ask around to be sure it's necessary.
I don't think this is needed at least as part of this issue. We could give it some more thought and consider improving this in future.
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
#38: ๐ฅณ๐ NICE! ๐ (For the visual brokenness, @tedbow is working on that over at ๐ Fix the visually broken "image" component instance: use FileUriItem's computed `url` property, not the stored `value` property Active as I mentioned in #36.)
Do we already have an issue to load the media library using the admin theme? Or should we do that here?
Isn't that in direct contradiction of ๐ Changing default theme can break HTML forms generated by XB API routes: always negotiate the Stark theme Fixed ? ๐ Or are you reconsidering what you wrote at #3469686-4: Changing default theme can break HTML forms generated by XB API routes: always negotiate the Stark theme โ , and we should use Claro instead? Or perhaps you're distinguishing between the form in the right sidebar (
stark
) and the media library dialog (claro
)?Rather, it's an image field using the media library widget.
๐ฎ That surprises me!
That's not what
media_library_storage_prop_shape_alter()
specifies. Can you point me to where in the MR that is happening? ๐ - ๐ซ๐ฎFinland lauriii Finland
Isn't that in direct contradiction of #3469686: Changing default theme can break HTML forms generated by XB API routes: always negotiate the Stark theme? ๐ Or are you reconsidering what you wrote at #3469686-4: Changing default theme can break HTML forms generated by XB API routes: always negotiate the Stark theme, and we should use Claro instead? Or perhaps you're distinguishing between the form in the right sidebar (stark) and the media library dialog (claro)?
I'm considering the right sidebar separate from this. The right sidebar is rendered using styles from the Experience Builder app โ therefore it doesn't need the admin theme. In this use case, admin theme just adds an unnecessary layer where things can break without adding any benefit.
The media library on the other hand is expected to be rendered just like how it's rendered in the admin UI. For this reason, I think it would make sense to render this using the admin theme instead of Stark (or some other theme). This might be an implementation detail but I think we should probably render the media library in an iframe or Shadow DOM to prevent styles from the XB UI leaking to the media library (and vice versa).
- Assigned to wim leers
- ๐บ๐ธUnited States bnjmnm Ann Arbor, MI
So the widget works in the prop form and can very much update a component, but getting this process to work well in E2E proven a bit tricky.
@Wim Leers said he'd have a look at this so assigning to him. Do a grep for@yo-wim
and you'll find explanations next to their relevant lines of (sometimes commented) code. - ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
I was able to reproduce the same failure locally. ๐
Root cause found, it's a combination of:
-
๐
Create an Open API spec for the current mock HTTP responses
Fixed
having added an OpenAPI spec + a
KernelEvents::RESPONSE
subscriber to validate responses. - We already knew that, and I updated this MR 20 days ago to make
/openapi.yml
aware of this API route. - โฆ but making the Media Library stuff actually work causes an AJAX request to be sent by Drupal's JS, which causes a
POST
request to that same route. ๐จ That's where things go wrong: theopenapi.yml
file only had an entry forGET
โฆ
Fix: https://git.drupalcode.org/project/experience_builder/-/merge_requests/1... โ E2E test is now passing ๐
๐ But why was this so excruciatingly hard to find? Well, because:
\Drupal\experience_builder\EventSubscriber\ApiResponseValidator::validateResponse()
throws an exception โฆ- โฆ which then is not handled by anything else, resulting in the default
AjaxResponse
to be sent rather than the fully built one (which is done by\Drupal\Core\EventSubscriber\AjaxResponseSubscriber::onResponse()
). - Consequence: only the debug log message that appears at
/admin/reports/dblog
revealed the nature of the problem:
</li> <li>OpenAPI spec contains no such operation [/xb-field-form/node/1]</li> <li>
Creating critical follow-up issue for that โฆ
-
๐
Create an Open API spec for the current mock HTTP responses
Fixed
having added an OpenAPI spec + a
- Assigned to bnjmnm
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
And now the
drupal_flush_all_caches()
is gone, too!I think @bnjmnm can push this forward to finish the test coverage now ๐ โ I'll happily continue reviewing/pushing this forward tomorrow!
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
I didn't push it forward today because other issues required my attention. To be continued on Tuesday ๐
- Assigned to wim leers
- Assigned to bnjmnm
- Status changed to RTBC
4 months ago 4:45pm 3 September 2024 - ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
As far as I'm concerned, this is now ready. 12 open threads remain. I'd like @bnjmnm to sign off on those, and then this can/should IMHO land.
Epic work here, @bnjmnm! ๐
(Next up after this: styling the Media Library โฆ but to match what? Claro's Media Library/modal dialog styles?)
- Issue was unassigned.
- ๐บ๐ธUnited States Kristen Pol Santa Cruz, CA, USA
I just tried testing this and it didn't work:
- switched to mr branch
- cd ui
- npm i
- npm run build
- delete xb component config
- drush cr
- drag image component to desktop area
- click "choose file"
- error popup
- Status changed to Needs work
4 months ago 8:49pm 3 September 2024 - ๐บ๐ธUnited States Kristen Pol Santa Cruz, CA, USA
Moving back to needs work.
- ๐ซ๐ฎFinland lauriii Finland
@kristen pol is there an error in your sites error logs that you could provide here? That would probably help with debugging the problem.
- ๐บ๐ธUnited States Kristen Pol Santa Cruz, CA, USA
Just tested again and see 2 errors in the logs:
TypeError: _semi_coupled_get_variable(): Return value must be of type object|array|string|bool|null, int returned in _semi_coupled_get_variable() (line 286 of /var/www/html/web/modules/contrib/experience_builder/themes/engines/semi_coupled/semi_coupled.engine).
Drupal\Core\Render\Component\Exception\InvalidComponentException: [image] String value found, but an object is required in Drupal\Core\Theme\Component\ComponentValidator->validateProps() (line 203 of /var/www/html/web/core/lib/Drupal/Core/Theme/Component/ComponentValidator.php).
- Status changed to RTBC
4 months ago 7:14am 4 September 2024 - ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
#50:
Did you see the message that @bnjmnm added? (Follow-up issue created to get rid of it: ๐ Make Media Library widget work when JS aggregation is enabled Active .)It works fine here:
(And zero warnings or exceptions being logged. If you find the precise STR for them, please create a new issue.)
โ ๏ธ Note that the uploaded image does not show up because the
public://
URI is being used rather than the corresponding computedhttp(s)://
URL. @tedbow is working to fix that over at ๐ Fix the visually broken "image" component instance: use FileUriItem's computed `url` property, not the stored `value` property Active . - ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
Created ๐ Media Library dialog styling Active for #48.
Unfortunately, I'm going to probably have to bypass review/approval from:
- @traviscarden for the changes to
/openapi.yml
(and tiny refinement toApiMessageValidator
that removes the OpenAPI logged complaint about the/experience_builder.experience_builder
route) - @hooroomoo or @effulgentsia for the changes to the semi-coupled theme engine โ while @bnjmnm has built most of that, sign-off from them would have been nice
- @hooroomoo or @balintbrews or @jessebaker for the changes to
/ui
โฆ because this issue is literally the #1 most important issue at ๐ฑ Milestone 0.1.0: Experience Builder Demo Active ๐
I want to land this this AM. So I asked @jessebaker to review this in the next hour. Otherwise, I'll go ahead and merge this. It's too important progress to let get stale.
(@traviscarden told me he was going to review last night but apparently he did not. @hooroomoo is out.)
- @traviscarden for the changes to
- Assigned to jessebaker
- ๐ฎ๐ณIndia omkar-pd
@kristen pol
You'll get those errors if you don't have Media and Media Library modules installed.
Here are the steps that I followed with a fresh Drupal installation.
- Install Media and Media Library Modules.
- Install XB.
- Go to
/admin/config/development/performance
and uncheck Aggregate JavaScript files & save. - Add Article content.
- Go to
/xb/node/1
and test with image component.
- ๐ฎ๐ณIndia omkar-pd
One more thing,
If we upload an image with a space in its name(ex - image xyz.png) the following error is thrown.
Drupal\Core\Render\Component\Exception\InvalidComponentException: [image.src] Invalid URL format in Drupal\Core\Theme\Component\ComponentValidator->validateProps() (line 203 of /var/www/html/web/core/lib/Drupal/Core/Theme/Component/ComponentValidator.php).
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
#58 That was fixed in ๐ `{type: string, format: uri}` disallows image URLs containing spaces, `uri` data type stores + returns invalid URIs! Fixed โฆ ๐ค Can you create a new issue for that problem and include the exact filename that triggers it? ๐
- ๐ฎ๐ณIndia omkar-pd
Done @wim leers.
Image src containing spaces throws error. ๐ Image src containing spaces throws error. Active
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
Unblocked @jessebaker on an environment issue, and that's how I realized that my GIF in #54 actually shows a problem: the "Add media" functionality in the right sidebar has Olivero styles โฆ despite [#3469686} ๐
Fortunately, it works fine with just Stark too (pushed a one-line commit to fix it):
๐that now defers all styling considerations to ๐ Media Library dialog styling Active , as intended ๐
- ๐ฌ๐งUnited Kingdom jessebaker
I've just approved this from the /ui code perspective. There is obviously more to be done here, but I see no reason not to go ahead and merge this as a significant step forward.
-
wim leers โ
committed 9eb431f4 on 0.x authored by
bnjmnm โ
Issue #3454173 by bnjmnm, wim leers, lauriii, jessebaker: Media Library...
-
wim leers โ
committed 9eb431f4 on 0.x authored by
bnjmnm โ
- Issue was unassigned.
- Status changed to Fixed
4 months ago 10:13am 4 September 2024 - ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
Great!
Merged in upstream not once, but twice: first Felix' ๐ Component config entities are incomplete: missing entries for optional props, causing errors in ComponentPropsForm Fixed , then Harumi's ๐ Improve the page hierarchy display Active !
Still green CI, and per #55, this shouldn't wait any longer โ if the code owners disagree with the changes in the areas they did not approve, they are totally free to create follow-up issues ๐๐
See y'all in ๐ Media Library dialog styling Active (which @lauriii prioritized for
0.1.0
โ see #3454094-36: Milestone 0.1.0: Experience Builder Demo โ ). Automatically closed - issue fixed for 2 weeks with no activity.