From 3f84114fca3b213696011f685b79ff8def6b138b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=C5=81ukasz=20Ostafin?= Date: Mon, 23 Oct 2023 08:46:13 +0200 Subject: [PATCH] IBX-6597: Content type pickers are inconsistent (#914) Co-authored-by: katarzynazawada <> --- .../js/scripts/sidebar/btn/location.create.js | 27 ++++++++- .../Resources/public/scss/_extra-actions.scss | 9 ++- .../translations/locationview.en.xliff | 5 ++ .../universal_discovery_widget.en.xliff | 15 +++-- .../content/widget/content_create.html.twig | 57 ++++++++++++------- .../content.create.button.js | 2 +- .../content.create.widget.js | 4 +- src/lib/Behat/Component/ContentTypePicker.php | 4 +- src/lib/Behat/Page/ContentViewPage.php | 2 + 9 files changed, 90 insertions(+), 35 deletions(-) diff --git a/src/bundle/Resources/public/js/scripts/sidebar/btn/location.create.js b/src/bundle/Resources/public/js/scripts/sidebar/btn/location.create.js index ef143e4d81..075e9eae51 100644 --- a/src/bundle/Resources/public/js/scripts/sidebar/btn/location.create.js +++ b/src/bundle/Resources/public/js/scripts/sidebar/btn/location.create.js @@ -7,8 +7,31 @@ createActions.forEach((container) => { const radioInputs = container.querySelectorAll('.form-check [type="radio"]'); - const form = container.querySelector('form'); + const submitBtn = container.querySelector('.ibexa-extra-actions__btn--confirm'); + const cancelBtn = container.querySelector('.ibexa-extra-actions__btn--cancel'); + const closeBtn = container.querySelector('.ibexa-extra-actions__header .ibexa-btn--close'); - radioInputs.forEach((radioInput) => radioInput.addEventListener('change', () => form.submit(), false)); + cancelBtn.addEventListener( + 'click', + () => { + closeBtn.click(); + }, + false, + ); + radioInputs.forEach((radioInput) => + radioInput.addEventListener( + 'change', + (event) => { + const selectedItems = container.querySelectorAll('.ibexa-instant-filter__group-item--selected'); + const itemToSelect = event.currentTarget.closest('.ibexa-instant-filter__group-item'); + + selectedItems.forEach((selectedItem) => selectedItem.classList.remove('ibexa-instant-filter__group-item--selected')); + itemToSelect.classList.add('ibexa-instant-filter__group-item--selected'); + + submitBtn.removeAttribute('disabled'); + }, + false, + ), + ); }); })(window, window.document); diff --git a/src/bundle/Resources/public/scss/_extra-actions.scss b/src/bundle/Resources/public/scss/_extra-actions.scss index 997759424a..fee3821daa 100644 --- a/src/bundle/Resources/public/scss/_extra-actions.scss +++ b/src/bundle/Resources/public/scss/_extra-actions.scss @@ -82,6 +82,13 @@ } } + &__confirm-wrapper { + margin-top: calculateRem(4px); + padding: calculateRem(16px) calculateRem(32px); + display: flex; + gap: calculateRem(16px); + } + &--edit-user, &--edit { .form-check { @@ -126,7 +133,7 @@ &--create { .ibexa-extra-actions { &__content { - max-height: calc(100% - #{calculateRem(89px)}); + max-height: calc(100% - #{calculateRem(157px)}); overflow: auto; } diff --git a/src/bundle/Resources/translations/locationview.en.xliff b/src/bundle/Resources/translations/locationview.en.xliff index 282e0f7711..6c6adb7270 100644 --- a/src/bundle/Resources/translations/locationview.en.xliff +++ b/src/bundle/Resources/translations/locationview.en.xliff @@ -16,6 +16,11 @@ Content Type key: bulk_action.failed.modal.content_type_name + + Discard + Discard + key: content.create.cancel_btn.label + Create content Create content diff --git a/src/bundle/Resources/translations/universal_discovery_widget.en.xliff b/src/bundle/Resources/translations/universal_discovery_widget.en.xliff index 2be84109d8..662d292645 100644 --- a/src/bundle/Resources/translations/universal_discovery_widget.en.xliff +++ b/src/bundle/Resources/translations/universal_discovery_widget.en.xliff @@ -56,10 +56,10 @@ Or choose from list key: content.create.filters.desc - - Cancel - Cancel - key: content_create.cancel.label + + Discard + Discard + key: content_create.discard.label Content create @@ -97,9 +97,14 @@ key: copy.title + Create + Create + key: create_content.create + + Create new Create new - key: create_content.create + key: create_content.create_new Create new content diff --git a/src/bundle/Resources/views/themes/admin/content/widget/content_create.html.twig b/src/bundle/Resources/views/themes/admin/content/widget/content_create.html.twig index 6ca6f43436..3b71eadb0b 100644 --- a/src/bundle/Resources/views/themes/admin/content/widget/content_create.html.twig +++ b/src/bundle/Resources/views/themes/admin/content/widget/content_create.html.twig @@ -1,27 +1,30 @@ {% trans_default_domain 'locationview' %} {% set data_actions = data_actions|default('create') %} +{% set action = action is defined ? action : path('ibexa.content.create') %} -
-
-

{{ 'content.create.create_content'|trans|desc('Create content') }}

- -
- {% if content is defined %} - {{ 'content.create.editing_details'|trans({ '%content_name%': ibexa_content_name(content) })|desc('under %content_name%') }} - {% endif %} +{{ form_start(form, { + action, + attr: { autocomplete: 'off' } +}) }} +
+
+

{{ 'content.create.create_content'|trans|desc('Create content') }}

+ +
+ {% if content is defined %} + {{ 'content.create.editing_details'|trans({ '%content_name%': ibexa_content_name(content) })|desc('under %content_name%') }} + {% endif %} +
-
-
- {% set action = action is defined ? action : path('ibexa.content.create') %} - {{ form_start(form, { - 'action': action, - 'attr': { 'autocomplete': 'off' } - }) }} +
{% if form.language.vars.choices|length == 1 %} @@ -49,7 +52,17 @@
- {{ form_widget(form.create, {'attr': {'hidden': 'hidden'}}) }} - {{ form_end(form) }} +
+
+ {{ form_widget(form.create, { + attr: { + disabled: true, + class: 'ibexa-btn ibexa-btn--primary ibexa-extra-actions__btn ibexa-extra-actions__btn--confirm' + } + }) }} + +
-
+{{ form_end(form) }} diff --git a/src/bundle/ui-dev/src/modules/universal-discovery/components/content-create-button/content.create.button.js b/src/bundle/ui-dev/src/modules/universal-discovery/components/content-create-button/content.create.button.js index f0aee36898..6e36dca190 100644 --- a/src/bundle/ui-dev/src/modules/universal-discovery/components/content-create-button/content.create.button.js +++ b/src/bundle/ui-dev/src/modules/universal-discovery/components/content-create-button/content.create.button.js @@ -23,7 +23,7 @@ const ContentCreateButton = ({ isDisabled }) => { const [multiple, multipleItemsLimit] = useContext(MultipleConfigContext); const { hidden, allowedLocations } = useContext(ContentOnTheFlyConfigContext); const contentTypesMap = useContext(ContentTypesMapContext); - const createLabel = Translator.trans(/*@Desc("Create new")*/ 'create_content.create', {}, 'universal_discovery_widget'); + const createLabel = Translator.trans(/*@Desc("Create new")*/ 'create_content.create_new', {}, 'universal_discovery_widget'); const toggleContentCreateVisibility = () => { ibexa.helpers.tooltips.hideAll(); setCreateContentVisible((prevState) => !prevState); diff --git a/src/bundle/ui-dev/src/modules/universal-discovery/components/content-create-widget/content.create.widget.js b/src/bundle/ui-dev/src/modules/universal-discovery/components/content-create-widget/content.create.widget.js index 9d75fd90db..e0ecc4a106 100644 --- a/src/bundle/ui-dev/src/modules/universal-discovery/components/content-create-widget/content.create.widget.js +++ b/src/bundle/ui-dev/src/modules/universal-discovery/components/content-create-widget/content.create.widget.js @@ -77,9 +77,9 @@ const ContentCreateWidget = () => { {}, 'universal_discovery_widget', ); - const createLabel = Translator.trans(/*@Desc("Create new")*/ 'create_content.create', {}, 'universal_discovery_widget'); + const createLabel = Translator.trans(/*@Desc("Create")*/ 'create_content.create', {}, 'universal_discovery_widget'); const closeLabel = Translator.trans(/*@Desc("Close")*/ 'popup.close.label', {}, 'universal_discovery_widget'); - const cancelLabel = Translator.trans(/*@Desc("Cancel")*/ 'content_create.cancel.label', {}, 'universal_discovery_widget'); + const cancelLabel = Translator.trans(/*@Desc("Discard")*/ 'content_create.discard.label', {}, 'universal_discovery_widget'); const placeholder = Translator.trans(/*@Desc("Type to refine")*/ 'content_create.placeholder', {}, 'universal_discovery_widget'); const filtersDescLabel = Translator.trans( /*@Desc("Or choose from list")*/ 'content.create.filters.desc', diff --git a/src/lib/Behat/Component/ContentTypePicker.php b/src/lib/Behat/Component/ContentTypePicker.php index f36c8514cd..f222136690 100644 --- a/src/lib/Behat/Component/ContentTypePicker.php +++ b/src/lib/Behat/Component/ContentTypePicker.php @@ -55,7 +55,7 @@ public function verifyIsLoaded(): void public function confirm(): void { - $this->getHTMLPage()->find($this->getLocator('createNewButtonInUDW'))->click(); + $this->getHTMLPage()->find($this->getLocator('createButton'))->click(); } protected function specifyLocators(): array @@ -65,7 +65,7 @@ protected function specifyLocators(): array new VisibleCSSLocator('filteredItem', '.ibexa-content-menu-wrapper .ibexa-extra-actions__section-content--content-type .ibexa-instant-filter__group-item:not([hidden]) .form-check-label, .c-udw-tab .ibexa-extra-actions__section-content--content-type .ibexa-instant-filter__group-item:not([hidden]) .form-check-label'), new VisibleCSSLocator('header', '.ibexa-content-menu-wrapper .ibexa-extra-actions--create .ibexa-extra-actions__header h2'), new VisibleCSSLocator('languageDropdown', '.ibexa-content-menu-wrapper .ibexa-dropdown__selection-info'), - new VisibleCSSLocator('createNewButtonInUDW', '.c-content-create__confirm-button'), + new VisibleCSSLocator('createButton', '.c-content-create__confirm-button, [id="content_create_create"]'), ]; } } diff --git a/src/lib/Behat/Page/ContentViewPage.php b/src/lib/Behat/Page/ContentViewPage.php index 189d9d6ed6..e6a6f41df3 100644 --- a/src/lib/Behat/Page/ContentViewPage.php +++ b/src/lib/Behat/Page/ContentViewPage.php @@ -132,6 +132,7 @@ public function startCreatingContent(string $contentTypeName, string $language = $this->contentTypePicker->selectLanguage($language); } $this->contentTypePicker->select($contentTypeName); + $this->contentTypePicker->confirm(); } public function startCreatingUser(string $contentTypeName) @@ -139,6 +140,7 @@ public function startCreatingUser(string $contentTypeName) $this->contentActionsMenu->clickButton('Create content'); $this->contentTypePicker->verifyIsLoaded(); $this->contentTypePicker->select($contentTypeName); + $this->contentTypePicker->confirm(); } public function switchToTab(string $tabName): void