-
Notifications
You must be signed in to change notification settings - Fork 206
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
Enhance: Admin settings page responsive #2475
Enhance: Admin settings page responsive #2475
Conversation
WalkthroughThe changes include the introduction of a new Vue.js component named Changes
Assessment against linked issues
Possibly related PRs
Suggested labels
Poem
Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media? 🪧 TipsChatThere are 3 ways to chat with CodeRabbit:
Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments. CodeRabbit Commands (Invoked using PR comments)
Other keywords and placeholders
CodeRabbit Configuration File (
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 0
🧹 Outside diff range and nitpick comments (6)
src/admin/pages/Settings.vue (5)
18-18
: Fix typo in class name from "nab-section" to "nav-section"The class name "nab-section" appears to be a typo. It should probably be "nav-section" to maintain consistency with other navigation elements.
Apply this diff to correct the class name:
-<div class="nab-section block"> +<div class="nav-section block">
47-56
: Enhance accessibility by adding an aria-label to the search inputTo improve accessibility for screen reader users, consider adding an
aria-label
to the search input element. This provides a textual description of the input's purpose.Apply this diff to add the
aria-label
:<input type="text" id="dokan-admin-search" class="w-full px-3 py-2 border-none focus:outline-none focus:ring-0 bg-transparent" :placeholder="__('Search e.g. vendor', 'dokan-lite')" v-model="searchText" @input="searchInSettings" ref="searchInSettings" + :aria-label="__('Search Settings', 'dokan-lite')" />
205-221
: Consider renaming 'MobileSettingsList.vue' to 'MobileSettingsDrawer.vue' for clarityThe
MobileSettingsDrawer
component is exported fromMobileSettingsList.vue
. Renaming the file toMobileSettingsDrawer.vue
would improve consistency and make the codebase easier to navigate.Remove unused import of 'MobileSettingsList' component
The
MobileSettingsList
component is imported but not used in the code. Removing this unused import will clean up the code.Apply this diff to remove the unused import:
-import MobileSettingsList from "admin/components/Settings/MobileSettingsList.vue"; let Loading = dokan_get_lib('Loading'); let AdminNotice = dokan_get_lib('AdminNotice'); import Fields from "admin/components/Fields.vue" import SettingsBanner from "admin/components/SettingsBanner.vue"; import UpgradeBanner from "admin/components/UpgradeBanner.vue"; import MobileSettingsDrawer from "admin/components/Settings/MobileSettingsList.vue"; export default { name: 'Settings', components: { MobileSettingsDrawer, - MobileSettingsList, Fields, Loading, SettingsBanner, UpgradeBanner, AdminNotice, },
1242-1301
: Remove commented-out code to clean up the stylesheetThere's a block of commented-out code from lines 1242 to 1301. Removing unused code enhances readability and maintainability.
Apply this diff to remove the unnecessary code:
-//@media only screen and (max-width: 430px) { -// .dokan-settings-wrap { -// .nav-tab-wrapper { -// -// .nav-tab { -// padding-left: 10px !important; -// -// img { -// margin: 3px 8px 0px 4px; -// } -// -// .nav-content { -// .nav-title { -// font-size: 7px; -// } -// -// .nav-description { -// font-size: 5px !important; -// } -// } -// } -// -// .nav-tab-active { -// &:before { -// width: 2px !important; -// } -// } -// } -// -// .metabox-holder { -// width: 100%; -// -// .settings-header { -// display: block; -// -// .settings-content { -// .settings-title, -// .settings-description { -// padding-left: 0; -// } -// } -// -// .settings-document-button { -// text-align: left; -// } -// } -// } -// -// .search-box { -// .dashicons.dashicons-search { -// margin-left: 10px; -// } -// -// .dokan-admin-search-settings { -// font-size: 10px; -// } -// } -// } -//}
1341-1357
: Avoid redundant nested media queriesThere's a nested
@media (max-width: 768px)
inside an existing media query with the same condition starting at line 1302. The inner media query is redundant and can be removed to simplify the CSS.Apply this diff to eliminate the redundant media query:
- @media (max-width: 768px) { .dokan-settings-wrap { .nav-tab-wrapper { padding: 10px; .mobile-settings-list { margin-top: 1rem; .setting-section { &.active { border-left: 4px solid #246EFE; } &:hover { background-color: #f9fafb; } } } } } - }src/admin/components/Settings/MobileSettingsList.vue (1)
57-81
: Enhance accessibility with ARIA roles and focus managementTo improve accessibility, consider adding ARIA roles such as
role="dialog"
to the drawer container. Additionally, manage focus by trapping it within the drawer when it's open and returning focus to the triggering element when it's closed.Example modification:
<div :class="[ 'fixed top-0 left-0 h-full w-[85%] max-w-[320px] bg-white z-[1000000] transform transition-transform duration-300 ease-in-out', isOpen ? 'translate-x-0' : '-translate-x-full' ]" + role="dialog" + aria-modal="true" >Implement focus management in the
mounted
andbeforeDestroy
lifecycle hooks.
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
📒 Files selected for processing (3)
src/admin/components/Settings/MobileSettingsList.vue
(1 hunks)src/admin/components/SettingsBanner.vue
(1 hunks)src/admin/pages/Settings.vue
(9 hunks)
✅ Files skipped from review due to trivial changes (1)
- src/admin/components/SettingsBanner.vue
🔇 Additional comments (3)
src/admin/pages/Settings.vue (2)
115-124
: MobileSettingsDrawer component integration looks good
The MobileSettingsDrawer
component is properly integrated with the correct props and event handlers, enhancing the mobile user experience.
125-136
: Desktop navigation tabs are correctly rendered
The desktop navigation tabs are displayed accurately with appropriate data bindings and event handling.
src/admin/components/Settings/MobileSettingsList.vue (1)
1-54
: MobileSettingsDrawer component implementation is well-structured
The MobileSettingsDrawer
component is effectively implemented, providing a responsive and user-friendly mobile settings menu. The use of props and event emissions for isOpen
, sections
, and currentTab
ensures flexibility and reusability.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 2
🧹 Outside diff range and nitpick comments (3)
src/admin/pages/Settings.vue (3)
21-41
: Enhance accessibility of the mobile menu toggle button.The button implementation is good, but could be improved for better accessibility.
<button class="d-xs:flex md:hidden p-2.5 bg-white border border-gray-200 rounded-lg shadow-sm hover:bg-gray-50 transition-all duration-200 ease-in-out group focus:outline-none focus:ring-2 focus:ring-blue-500 focus:ring-offset-2" @click="openMobileDrawer" + aria-expanded="showMobileDrawer" + aria-controls="mobile-settings-drawer" > <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" width="24" height="24" + aria-hidden="true" class="group-hover:scale-110 transition-transform duration-200" >
1242-1303
: Optimize responsive styling implementation.The responsive styling could be improved with better organization and maintainability.
+<style lang="less"> +// Variables +@mobile-breakpoint: 768px; +@drawer-transition-duration: 0.3s; + +// Mixins +.mobile-only { + @media only screen and (max-width: @mobile-breakpoint) { + @content; + } +} @media only screen and (max-width: 768px) { .dokan-settings-wrap { .nav-tab-wrapper { overflow: inherit !important; z-index: 444; width: 100% !important; padding: 1rem !important; } // ... other styles ... .slide-enter-active, .slide-leave-active { - transition: transform 0.3s ease-out; + transition: transform @drawer-transition-duration ease-out; } // Remove duplicate media query - @media (max-width: 768px) { - .dokan-settings-wrap { - // ... duplicate styles ... - } - } } } </style>
Line range hint
1-1304
: Consider splitting the component into smaller, more focused components.The Settings component is quite large and handles multiple responsibilities. Consider extracting some functionality into separate components:
- SearchBox component for search functionality
- SettingsHeader component for the header section
- SettingsNavigation component for the navigation tabs
This would improve maintainability and make the code more testable.
Would you like me to provide an example of how to split this component?
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
📒 Files selected for processing (2)
src/admin/components/Settings/MobileSettingsList.vue
(1 hunks)src/admin/pages/Settings.vue
(9 hunks)
🚧 Files skipped from review as they are similar to previous changes (1)
- src/admin/components/Settings/MobileSettingsList.vue
<transition name="slide"> | ||
<MobileSettingsDrawer | ||
:is-open="showMobileDrawer" | ||
:sections="settingSections" | ||
:current-tab="currentTab" | ||
@close="closeMobileDrawer" | ||
@change-tab="changeTab" | ||
/> | ||
</transition> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🛠️ Refactor suggestion
Enhance mobile drawer usability and accessibility.
The mobile drawer implementation could be improved with better keyboard navigation and click-outside behavior.
<transition name="slide">
<MobileSettingsDrawer
:is-open="showMobileDrawer"
:sections="settingSections"
:current-tab="currentTab"
+ :aria-modal="true"
+ :role="dialog"
+ @keydown.esc="closeMobileDrawer"
@close="closeMobileDrawer"
@change-tab="changeTab"
/>
</transition>
methods: {
openMobileDrawer() {
this.showMobileDrawer = true;
+ document.body.style.overflow = 'hidden'; // Prevent background scroll
this.searchText = '';
this.validateBlankSearch();
+ this.$nextTick(() => {
+ // Focus first interactive element
+ this.$refs.mobileDrawer.$el.querySelector('button,a').focus();
+ });
},
closeMobileDrawer() {
this.showMobileDrawer = false;
+ document.body.style.overflow = ''; // Restore scroll
},
+ handleClickOutside(event) {
+ if (this.showMobileDrawer && !this.$refs.mobileDrawer.$el.contains(event.target)) {
+ this.closeMobileDrawer();
+ }
+ },
},
+mounted() {
+ document.addEventListener('click', this.handleClickOutside);
+},
+beforeDestroy() {
+ document.removeEventListener('click', this.handleClickOutside);
+},
Also applies to: 698-710
src/admin/pages/Settings.vue
Outdated
<div class="relative flex-1"> | ||
<!-- Search Box --> | ||
<div class="search-section relative w-full mb-4"> | ||
<div class="search-box w-full bg-white rounded-md border border-gray-200 flex items-center"> | ||
<label for="dokan-admin-search" class="dashicons dashicons-search "></label> | ||
<input | ||
type="text" | ||
autocomplete="off" | ||
id="dokan-admin-search" | ||
class="w-full px-3 py-2 border-none focus:outline-none focus:ring-0 bg-transparent " | ||
:placeholder="__('Search e.g. vendor', 'dokan-lite')" | ||
v-model="searchText" | ||
@input="searchInSettings" | ||
ref="searchInSettings" | ||
/> | ||
<span | ||
v-if="searchText !== ''" | ||
class="dashicons dashicons-no-alt mr-3 text-gray-400 cursor-pointer hover:text-gray-600" | ||
@click.prevent="clearSearch" | ||
></span> | ||
</div> | ||
|
||
<!-- Search Suggestions Dropdown --> | ||
<div | ||
v-if="searchText && settingSections.length > 0" | ||
class="d-xs:absolute md:hidden left-0 right-0 top-[calc(100%+4px)] bg-white border border-gray-200 rounded-lg shadow-lg divide-y divide-gray-100 max-h-[280px] overflow-y-auto z-50" | ||
> | ||
<div | ||
v-for="section in settingSections" | ||
:key="section.id" | ||
class="hover:bg-gray-50 transition-colors cursor-pointer" | ||
@click="handleSectionClick(section)" | ||
> | ||
<div class="p-3"> | ||
<div class="flex items-center gap-3"> | ||
<img | ||
:src="section.icon_url" | ||
:alt="section.title" | ||
class="w-5 h-5" | ||
/> | ||
<div class="flex-1 min-w-0"> | ||
<div class="text-sm font-medium text-gray-900 truncate"> | ||
{{ section.title }} | ||
</div> | ||
<div class="text-xs text-gray-500 mt-0.5 line-clamp-1"> | ||
{{ section.description }} | ||
</div> | ||
</div> | ||
<svg | ||
class="w-4 h-4 text-gray-400 flex-shrink-0" | ||
fill="none" | ||
stroke="currentColor" | ||
viewBox="0 0 24 24" | ||
> | ||
<path | ||
stroke-linecap="round" | ||
stroke-linejoin="round" | ||
stroke-width="2" | ||
d="M9 5l7 7-7 7" | ||
/> | ||
</svg> | ||
</div> | ||
</div> | ||
</div> | ||
</div> | ||
</div> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🛠️ Refactor suggestion
Improve search functionality robustness.
The search implementation could be enhanced in several ways:
- The debounce delay should be configurable
- Add loading state during search
- Handle potential search failures
data () {
return {
// ... other data properties
+ searchDebounceDelay: 300, // Configurable delay
+ isSearching: false,
}
},
methods: {
searchInSettings(input) {
if (!this.validateBlankSearch()) {
return;
}
+ this.isSearching = true;
if (!this.awaitingSearch) {
- setTimeout(() => {
+ setTimeout(async () => {
let searchText = this.$refs.searchInSettings.value;
searchText = searchText.replace(/\s\s+/g,' ').trim().toLowerCase();
this.doSearch('');
- this.doSearch(searchText);
+ try {
+ await this.doSearch(searchText);
+ } catch (error) {
+ console.error('Search failed:', error);
+ // Handle error appropriately
+ } finally {
+ this.isSearching = false;
+ }
this.awaitingSearch = false;
this.showSuggestions = true;
- }, 1000);
+ }, this.searchDebounceDelay);
}
this.awaitingSearch = true;
},
Then update the template to show loading state:
<div class="search-box w-full bg-white rounded-md border border-gray-200 flex items-center">
<label for="dokan-admin-search" class="dashicons dashicons-search"></label>
<input
type="text"
autocomplete="off"
id="dokan-admin-search"
class="w-full px-3 py-2 border-none focus:outline-none focus:ring-0 bg-transparent"
:placeholder="__('Search e.g. vendor', 'dokan-lite')"
v-model="searchText"
@input="searchInSettings"
ref="searchInSettings"
+ :disabled="isSearching"
/>
+ <span v-if="isSearching" class="loading-spinner mr-3"></span>
<span
v-if="searchText !== ''"
class="dashicons dashicons-no-alt mr-3 text-gray-400 cursor-pointer hover:text-gray-600"
@click.prevent="clearSearch"
></span>
</div>
Committable suggestion skipped: line range outside the PR's diff.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 1
🧹 Outside diff range and nitpick comments (2)
src/admin/pages/Settings.vue (2)
Line range hint
204-254
: Clean up scroll event listener on component destruction.The scroll event listener is added in the created hook but not removed when the component is destroyed, which could lead to memory leaks.
beforeDestroy() { window.removeEventListener('resize', this.updateDocumentWidth); + window.removeEventListener('scroll', this.handleScroll); }
Line range hint
1107-1306
: Optimize styles for better performance.Consider performance optimizations for the styles:
- Combine multiple box-shadow and filter properties
- Use transform: translate3d for hardware acceleration
.search-section { - filter: drop-shadow(0px 0.0869484px 0.260845px rgba(0, 0, 0, 0.1)) drop-shadow(0px 0.869484px 1.73897px rgba(0, 0, 0, 0.2)); + filter: drop-shadow(0px 0.869484px 1.73897px rgba(0, 0, 0, 0.25)); .dashicons.dashicons-no-alt { - transform: translate(0%, -60%); + transform: translate3d(0, -60%, 0); } }
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro
📒 Files selected for processing (1)
src/admin/pages/Settings.vue
(9 hunks)
🔇 Additional comments (2)
src/admin/pages/Settings.vue (2)
43-108
: Previous feedback about search implementation remains applicable.
The search implementation could still benefit from the robustness improvements suggested in the previous review.
113-121
: Previous feedback about mobile drawer usability remains applicable.
The mobile drawer implementation could still benefit from the accessibility and usability improvements suggested in the previous review.
src/admin/pages/Settings.vue
Outdated
<button | ||
class="d-xs:flex md:hidden p-2.5 bg-white border border-gray-200 rounded-lg shadow-sm hover:bg-gray-50 transition-all duration-200 ease-in-out group focus:outline-none focus:ring-2 focus:ring-blue-500 focus:ring-offset-2" | ||
@click="openMobileDrawer" | ||
> | ||
<svg | ||
xmlns="http://www.w3.org/2000/svg" | ||
viewBox="0 0 24 24" | ||
width="24" | ||
height="24" | ||
class="group-hover:scale-110 transition-transform duration-200" | ||
> | ||
<path | ||
stroke="#246EFE" | ||
stroke-width="2.5" | ||
stroke-linecap="round" | ||
d="M4 6h16M4 12h16M4 18h16" | ||
class="group-hover:stroke-[#1b4fd1]" | ||
/> | ||
</svg> | ||
<span class="sr-only">{{ __('Toggle Settings Menu', 'dokan-lite') }}</span> | ||
</button> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🛠️ Refactor suggestion
Enhance mobile toggle button accessibility.
The mobile toggle button implementation should include additional ARIA attributes for better screen reader support.
<button
class="d-xs:flex md:hidden p-2.5 bg-white border border-gray-200 rounded-lg shadow-sm hover:bg-gray-50 transition-all duration-200 ease-in-out group focus:outline-none focus:ring-2 focus:ring-blue-500 focus:ring-offset-2"
@click="openMobileDrawer"
+ :aria-expanded="showMobileDrawer"
+ aria-controls="mobile-settings-drawer"
+ v-tooltip="__('Toggle Settings Menu', 'dokan-lite')"
>
Committable suggestion skipped: line range outside the PR's diff.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 3
🧹 Outside diff range and nitpick comments (4)
assets/src/less/global-admin.less (3)
258-262
: Consider using CSS Grid for better responsive layout.The flex-direction column layout with gap is good, but CSS Grid could provide more flexibility for complex responsive layouts.
.notice-content { - flex-direction: column; - align-items: start !important; - gap: 1rem; + display: grid; + grid-template-columns: 1fr; + grid-gap: 1rem; + align-items: start; }
Line range hint
1107-1167
: Enhance search input accessibility.The search input styling could benefit from improved accessibility features.
input { width: 100%; height: 48px; border: none; display: block; padding: 0 45px 0 0; background: transparent; font-weight: 400; font-family: Roboto, sans-serif; + -webkit-appearance: none; + appearance: none; &:focus { outline: none; box-shadow: none; border-color: transparent; + box-shadow: 0 0 0 2px rgba(36, 110, 254, 0.2); } + + &::placeholder { + color: rgba(60, 60, 67, 0.6); + opacity: 1; + } }
Line range hint
1242-1300
: Optimize mobile responsive styles.The mobile styles could be improved for better maintainability and performance.
- Use CSS custom properties for breakpoints
- Consolidate duplicate selectors
- Remove unnecessary
!important
flags+:root { + --mobile-breakpoint: 768px; + --tablet-breakpoint: 1024px; +} -@media only screen and (max-width: 768px) +@media only screen and (max-width: var(--mobile-breakpoint)) .dokan-settings-wrap { .nav-tab-wrapper { - overflow: inherit !important; - z-index: 444; - width: 100% !important; - padding: 1rem !important; + overflow: visible; + z-index: 10; + width: 100%; + padding: 1rem; } // ... rest of the styles }src/admin/pages/Settings.vue (1)
251-254
: Consider using Vuex for state management.The component manages multiple pieces of state that could be shared across components. Using Vuex would improve state management and component communication.
Consider moving the following state to Vuex:
screenWidth
showMobileDrawer
showSuggestions
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro
📒 Files selected for processing (2)
assets/src/less/global-admin.less
(2 hunks)src/admin/pages/Settings.vue
(9 hunks)
🔇 Additional comments (2)
assets/src/less/global-admin.less (1)
290-308
:
Standardize responsive breakpoints.
The breakpoint range (376px-576px) leaves a 1px gap with the previous media query (max-width: 375px). This could cause layout issues.
-@media screen and (min-width: 376px) and (max-width: 576px)
+@media screen and (min-width: 375px) and (max-width: 576px)
Likely invalid or redundant comment.
src/admin/pages/Settings.vue (1)
698-710
: Add debounce to search functionality.
The search implementation could benefit from debouncing to prevent excessive API calls.
This issue was previously identified in a past review comment. Please refer to the existing suggestion for implementing debounced search functionality.
assets/src/less/global-admin.less
Outdated
align-items: start; | ||
padding: 10px 20px; | ||
.dokan-message { | ||
margin: 0 0 0 23px; | ||
div{ | ||
max-height: 50px; | ||
overflow: scroll; | ||
} | ||
margin: 0; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🛠️ Refactor suggestion
Improve scroll behavior for message content.
Using overflow: scroll
forces scrollbars even when unnecessary. Consider using overflow-y: auto
for better UX.
.dokan-message {
margin: 0;
div {
- max-height: 50px;
- overflow: scroll;
+ max-height: 50px;
+ overflow-y: auto;
}
}
📝 Committable suggestion
‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.
align-items: start; | |
padding: 10px 20px; | |
.dokan-message { | |
margin: 0 0 0 23px; | |
div{ | |
max-height: 50px; | |
overflow: scroll; | |
} | |
margin: 0; | |
align-items: start; | |
padding: 10px 20px; | |
.dokan-message { | |
margin: 0; | |
div { | |
max-height: 50px; | |
overflow-y: auto; | |
} |
src/admin/pages/Settings.vue
Outdated
.setting-section { | ||
&.active { | ||
border-left: 4px solid #246EFE; | ||
} | ||
|
||
.nav-description { | ||
font-size: 8px !important; | ||
&:hover { | ||
background-color: #f9fafb; | ||
} | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🛠️ Refactor suggestion
Enhance mobile navigation accessibility.
The mobile navigation could benefit from improved keyboard navigation and ARIA attributes.
.setting-section {
+ position: relative;
+ outline: none;
&.active {
border-left: 4px solid #246EFE;
+ background-color: rgba(36, 110, 254, 0.05);
}
&:hover {
background-color: #f9fafb;
}
+ &:focus-visible {
+ box-shadow: 0 0 0 2px #246EFE;
+ }
}
📝 Committable suggestion
‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.
.setting-section { | |
&.active { | |
border-left: 4px solid #246EFE; | |
} | |
.nav-description { | |
font-size: 8px !important; | |
&:hover { | |
background-color: #f9fafb; | |
} | |
} | |
.setting-section { | |
position: relative; | |
outline: none; | |
&.active { | |
border-left: 4px solid #246EFE; | |
background-color: rgba(36, 110, 254, 0.05); | |
} | |
&:hover { | |
background-color: #f9fafb; | |
} | |
&:focus-visible { | |
box-shadow: 0 0 0 2px #246EFE; | |
} | |
} |
src/admin/pages/Settings.vue
Outdated
.slide-enter-active, .slide-leave-active { | ||
transition: transform 0.3s ease-out; | ||
} | ||
} | ||
} | ||
.slide-enter, .slide-leave-to { | ||
transform: translateX(-100%); | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🛠️ Refactor suggestion
Improve transition performance.
The current transition implementation might cause layout thrashing. Consider using transform-based animations for better performance.
.slide-enter-active, .slide-leave-active {
- transition: transform 0.3s ease-out;
+ transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
+ will-change: transform;
}
.slide-enter, .slide-leave-to {
transform: translateX(-100%);
+ pointer-events: none;
}
📝 Committable suggestion
‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.
.slide-enter-active, .slide-leave-active { | |
transition: transform 0.3s ease-out; | |
} | |
} | |
} | |
.slide-enter, .slide-leave-to { | |
transform: translateX(-100%); | |
} | |
.slide-enter-active, .slide-leave-active { | |
transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1); | |
will-change: transform; | |
} | |
.slide-enter, .slide-leave-to { | |
transform: translateX(-100%); | |
pointer-events: none; | |
} |
.notice-content{ | ||
flex-direction: column; | ||
align-items: start !important; | ||
gap: 1rem; | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This section is also used for 576px. Could remove this replication?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@@ -276,21 +287,33 @@ | |||
|
|||
@media screen and (min-width: 376px) and (max-width: 576px) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Should we care about (min-width: 376px)
in the above code section? Pls see the recommended screen sizes
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Bhai,
@media screen was impliment prev PR .
I think we can skip this refactor as it is working
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 0
🧹 Nitpick comments (1)
src/admin/components/AdminNotice.vue (1)
16-21
: Consider improving accessibility for action buttons.While the structural change is good, consider enhancing accessibility:
-<div> +<div class="dokan-notice-actions" role="group" aria-label="Notice Actions">This change would:
- Add semantic meaning to the button group
- Improve screen reader navigation
- Follow ARIA best practices
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro
📒 Files selected for processing (2)
assets/src/less/global-admin.less
(2 hunks)src/admin/components/AdminNotice.vue
(1 hunks)
🚧 Files skipped from review as they are similar to previous changes (1)
- assets/src/less/global-admin.less
🔇 Additional comments (1)
src/admin/components/AdminNotice.vue (1)
16-21
: Verify CSS changes for the new action buttons wrapper.
The addition of a wrapper div around action buttons might require corresponding CSS changes to maintain proper styling, especially for mobile responsiveness.
✅ Verification successful
The wrapper div is consistent with existing CSS styles
The CSS inspection shows that the admin notice component already has styles handling div elements within .dokan-message
, including specific mobile-friendly rules for content overflow:
.dokan-message {
div {
max-height: 50px;
overflow: auto;
}
margin: 0;
}
The addition of the wrapper div around action buttons aligns with the existing CSS structure and mobile responsiveness implementation.
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash
# Description: Check for related CSS changes in global-admin.less and other style files
# Search for CSS selectors targeting notice action buttons
rg -t less "dokan-admin-notice.*dokan-btn"
# Search for any new CSS rules added for the action buttons wrapper
rg -t less "dokan-message.*div"
Length of output: 78
Script:
#!/bin/bash
# Let's try different search patterns to find CSS related to admin notices and buttons
# Search for CSS rules related to admin notices
rg -t less "\.dokan-admin-notice"
# Search for button styles within admin-related CSS
rg -t less "\.dokan-btn"
# Search for any CSS files that might contain relevant styles
fd -e less -e css
Length of output: 5960
Script:
#!/bin/bash
# Let's check the specific CSS rules for admin notices and their buttons in global-admin.less
# Get the content of admin notice styles with context
rg -A 10 "\.dokan-admin-notice \{" assets/src/less/global-admin.less
# Check for any mobile/responsive styles for admin notices
rg -A 10 "@media.*dokan-admin-notice" assets/src/less/global-admin.less
rg -A 10 "@media.*dokan-admin-notice" assets/src/less/responsive.less
Length of output: 1521
@osmansufy bhai, please specify which pages and UI components were modified to be mobile responsive. |
@StalinDurjo bhai, For details please see the issue https://github.com/getdokan/dokan-pro/issues/2733 bhai . |
Issue: Dokan settings is not fully mobile responsive Issues:
Please refer to the attachments below @osmansufy bhai |
Issue: Responsive menu issues
@osmansufy bhai |
@StalinDurjo bhai please check. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 1
🧹 Nitpick comments (4)
src/admin/components/Settings/MobileSettingsList.vue (3)
1-8
: Enhance overlay accessibility and user experience.The overlay implementation should include proper ARIA attributes and keyboard navigation support.
<div> <div v-if="isOpen" - class="fixed inset-0 bg-black bg-opacity-50 z-[999999]" + class="fixed inset-0 bg-black bg-opacity-50 z-[999999]" + role="presentation" + tabindex="-1" @click="$emit('close')" + @keydown.esc="$emit('close')" ></div>
28-54
: Improve settings list accessibility and keyboard navigation.The settings list items should be keyboard navigable and have proper ARIA attributes.
<div class="overflow-y-auto h-[calc(100%-64px)]"> <template v-for="section in sections"> <div :key="section.id" + role="button" + tabindex="0" :class="[ 'flex items-center px-4 py-2 cursor-pointer border-b border-gray-100', { 'bg-blue-50 border-l-4 border-l-blue-500': currentTab === section.id } ]" + :aria-selected="currentTab === section.id" @click="handleTabChange(section)" + @keydown.enter="handleTabChange(section)" + @keydown.space.prevent="handleTabChange(section)" >
56-83
: Add focus management and keyboard navigation methods.The component should manage focus when opened and implement keyboard navigation between settings.
export default { name: 'MobileSettingsDrawer', props: { isOpen: { type: Boolean, required: true }, sections: { type: Array, required: true }, currentTab: { type: String, required: true } }, + data() { + return { + lastFocusedElement: null + } + }, + methods: { handleTabChange(section) { this.$emit('change-tab', section); this.$emit('close'); - } + }, + + handleKeyNavigation(event) { + if (event.key === 'ArrowDown' || event.key === 'ArrowUp') { + event.preventDefault(); + const items = this.$el.querySelectorAll('[role="button"]'); + const currentIndex = Array.from(items).indexOf(document.activeElement); + const nextIndex = event.key === 'ArrowDown' + ? (currentIndex + 1) % items.length + : (currentIndex - 1 + items.length) % items.length; + items[nextIndex].focus(); + } + } }, + + watch: { + isOpen(newVal) { + if (newVal) { + this.lastFocusedElement = document.activeElement; + this.$nextTick(() => { + const firstButton = this.$el.querySelector('[role="button"]'); + firstButton?.focus(); + }); + } else if (this.lastFocusedElement) { + this.lastFocusedElement.focus(); + } + } + } }src/admin/pages/Settings.vue (1)
1238-1296
: Optimize mobile transitions and styles.The mobile styles could be improved for better performance and maintainability.
- .slide-enter-active, .slide-leave-active { - transition: transform 0.3s ease-out; - } - .slide-enter, .slide-leave-to { - transform: translateX(-100%); - } + .slide-enter-active, .slide-leave-active { + transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1); + will-change: transform; + } + .slide-enter, .slide-leave-to { + transform: translateX(-100%); + pointer-events: none; + } .dokan-settings-wrap { .nav-tab-wrapper { .mobile-settings-list { margin-top: 1rem; .setting-section { + position: relative; + outline: none; &.active { border-left: 4px solid #246EFE; + background-color: rgba(36, 110, 254, 0.05); } &:hover { background-color: #f9fafb; } + &:focus-visible { + box-shadow: 0 0 0 2px #246EFE; + } } } } }
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro
📒 Files selected for processing (2)
src/admin/components/Settings/MobileSettingsList.vue
(1 hunks)src/admin/pages/Settings.vue
(10 hunks)
🔇 Additional comments (2)
src/admin/pages/Settings.vue (2)
16-41
: Enhance mobile toggle button accessibility.
The mobile toggle button should have proper ARIA attributes and states.
The implementation looks good, and a similar suggestion was already made in the past reviews.
42-108
: Enhance search functionality and accessibility.
The search implementation should include loading states and proper ARIA attributes.
The implementation looks good, and similar suggestions for improving search functionality were already made in the past reviews.
<!-- Drawer --> | ||
<div | ||
:class="[ | ||
'fixed top-0 left-0 h-full w-[85%] max-w-[320px] bg-white z-[1000000] transform transition-transform duration-300 ease-in-out', | ||
isOpen ? 'translate-x-0' : '-translate-x-full' | ||
]" | ||
> | ||
<!-- Drawer Header --> | ||
<div class="flex items-center justify-between p-4 border-b mt-8"> | ||
<h2 class="text-lg font-bold m-0 p-0">{{ __('Settings Menu', 'dokan-lite') }}</h2> | ||
<button | ||
class="bg-none border-0 p-1" | ||
@click="$emit('close')" | ||
> | ||
<svg xmlns="http://www.w3.org/2000/svg" class="h-6 w-6" fill="none" viewBox="0 0 24 24" stroke="currentColor"> | ||
<path stroke-linecap="round" stroke-linejoin="round" stroke-width="2" d="M6 18L18 6M6 6l12 12" /> | ||
</svg> | ||
</button> | ||
</div> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
🛠️ Refactor suggestion
Enhance drawer accessibility and keyboard navigation.
The drawer should trap focus when open and manage focus states properly.
<div
:class="[
'fixed top-0 left-0 h-full w-[85%] max-w-[320px] bg-white z-[1000000] transform transition-transform duration-300 ease-in-out',
isOpen ? 'translate-x-0' : '-translate-x-full'
]"
+ role="dialog"
+ aria-modal="true"
+ aria-labelledby="drawer-title"
+ @keydown.esc="$emit('close')"
>
<!-- Drawer Header -->
<div class="flex items-center justify-between p-4 border-b mt-8">
- <h2 class="text-lg font-bold m-0 p-0">{{ __('Settings Menu', 'dokan-lite') }}</h2>
+ <h2 id="drawer-title" class="text-lg font-bold m-0 p-0">{{ __('Settings Menu', 'dokan-lite') }}</h2>
<button
class="bg-none border-0 p-1"
+ aria-label="Close settings menu"
@click="$emit('close')"
>
Committable suggestion skipped: line range outside the PR's diff.
Issue: Dokan navigation gets overlapped with Wordpress sidebar @osmansufy bhai |
Issue: When Wordpress sidebar is collapsed mode and Dokan menu is opened, both menu items overlap @osmansufy bhai |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 0
♻️ Duplicate comments (2)
src/admin/pages/Settings.vue (2)
21-42
: 🛠️ Refactor suggestionEnhance mobile toggle button accessibility.
The mobile toggle button implementation needs additional ARIA attributes for better accessibility.
Apply this diff to improve accessibility:
<button class="d-xs:flex lg:hidden p-2.5 bg-white dokan-settings-menu-toggle-btn rounded-lg shadow-sm hover:bg-gray-50 transition-all duration-200 ease-in-out group outline-none " @click="openMobileDrawer" + :aria-expanded="showMobileDrawer" + aria-controls="mobile-settings-drawer" + aria-label="Toggle Settings Menu" >
114-122
: 🛠️ Refactor suggestionEnhance mobile drawer usability and accessibility.
The mobile drawer implementation needs keyboard navigation and click-outside behavior.
Add keyboard navigation and click-outside behavior:
<transition name="slide"> <MobileSettingsDrawer :is-open="showMobileDrawer" :sections="settingSections" :current-tab="currentTab" + :aria-modal="true" + :role="dialog" + @keydown.esc="closeMobileDrawer" @close="closeMobileDrawer" @change-tab="changeTab" /> </transition>
🧹 Nitpick comments (1)
src/admin/pages/Settings.vue (1)
699-711
: Prevent body scroll when mobile drawer is open.The mobile drawer methods should manage body scroll to prevent background content from scrolling.
Apply this diff to manage body scroll:
openMobileDrawer() { this.showMobileDrawer = true; + document.body.style.overflow = 'hidden'; this.searchText = ''; this.validateBlankSearch(); }, closeMobileDrawer() { this.showMobileDrawer = false; + document.body.style.overflow = ''; },
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro
📒 Files selected for processing (2)
src/admin/components/Settings/MobileSettingsList.vue
(1 hunks)src/admin/pages/Settings.vue
(11 hunks)
🚧 Files skipped from review as they are similar to previous changes (1)
- src/admin/components/Settings/MobileSettingsList.vue
🔇 Additional comments (3)
src/admin/pages/Settings.vue (3)
46-64
: Improve search functionality robustness.The search implementation could be enhanced with loading states and configurable delays.
Add loading state and configurable delay:
<div class="search-box w-full bg-white rounded-lg border border-gray-200 flex items-center"> <input type="text" autocomplete="off" id="dokan-admin-search" class="w-full px-3 py-2 border-none focus:outline-none focus:ring-0 bg-transparent" :placeholder="__('Search e.g. vendor', 'dokan-lite')" v-model="searchText" @input="searchInSettings" ref="searchInSettings" + :disabled="isSearching" /> + <span v-if="isSearching" class="loading-spinner mr-3"></span> <span v-if="searchText !== ''" class="dashicons dashicons-no-alt mr-3 text-gray-400 cursor-pointer hover:text-gray-600" @click.prevent="clearSearch" ></span> </div>
1273-1277
: Improve transition performance.The current transition implementation could be optimized for better performance.
Apply this diff to enhance transition performance:
.slide-enter-active, .slide-leave-active { - transition: transform 0.3s ease-out; + transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1); + will-change: transform; } .slide-enter, .slide-leave-to { transform: translateX(-100%); + pointer-events: none; }
Line range hint
16-1301
: Overall implementation looks good!The mobile responsiveness enhancements are well-implemented with proper responsive classes, transitions, and user interactions. The suggested improvements focus on accessibility, performance, and user experience refinements.
CC: @jamil-mahmud
|
Issue: Get help dropdown menu is overlapped by the dokan settings section @osmansufy bhai |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 0
🔭 Outside diff range comments (1)
assets/src/less/admin.less (1)
Mobile-specific styles are needed for better responsive layout
Based on the verification:
- The
admin.less
file currently lacks mobile-specific media queries for thedokan-settings-wrap
anddokan-admin-header
components.- While the codebase has responsive styles in other files (as seen in the first verification), these specific components in the admin interface need mobile optimization.
The suggested changes will:
- Make the settings panel stack vertically on mobile for better space utilization
- Prevent dropdown menu overflow on small screens
- Ensure proper spacing and alignment for the admin header components
🔗 Analysis chain
Line range hint
1-600
: Add mobile-specific styles for responsive layout.Based on the PR objectives to enhance mobile responsiveness and the issues mentioned in the PR comments (overlapping sidebar, menu spacing), the stylesheet needs mobile-specific media queries to handle responsive layouts properly.
Add these mobile-specific styles:
@media screen and (max-width: 782px) { .dokan-settings-wrap { flex-direction: column; h2.nav-tab-wrapper { border-right: none; border-bottom: 1px solid #c8d7e1; a.nav-tab-active { width: 100%; border-right: none; } } .metabox-holder { padding: 15px; } } .dokan-admin-header { .dokan-admin-header-menu { .menu-item { .menu-icon { .dropdown { right: -65px; // Prevent overflow on small screens &:before, &:after { right: 70px; // Adjust dropdown arrow position } } } } } } }This addresses the following reported issues:
- Sidebar menu space optimization
- Menu content overlap prevention
- Proper spacing and alignment on mobile devices
Let's verify the mobile layout issues:
Let me verify the specific sections of the codebase that would be affected by the suggested mobile styles.
Let me check the admin.less file directly for any existing mobile styles for these components.
🏁 Scripts executed
The following scripts were executed for the analysis:
Script:
#!/bin/bash # Search for existing mobile-specific styles rg "@media.*\(.*max-width" assets/src/less/Length of output: 2321
Script:
#!/bin/bash # Check if the specific components mentioned in the review already have mobile styles rg -A 10 "dokan-settings-wrap|dokan-admin-header" assets/src/less/responsive.lessLength of output: 83
Script:
#!/bin/bash # Search for existing mobile styles in admin.less rg -A 5 "@media.*\(.*max-width" assets/src/less/admin.lessLength of output: 60
🧹 Nitpick comments (1)
assets/src/less/admin.less (1)
106-106
: Consider a more moderate z-index value.The extremely high z-index of 99999 matches WordPress admin bar's z-index, which could cause layering conflicts. Consider using a lower value that still achieves the desired stacking context without potentially conflicting with WordPress core elements.
- z-index: 99999; + z-index: 1000;
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actionable comments posted: 0
♻️ Duplicate comments (1)
src/admin/pages/Settings.vue (1)
114-122
: 🛠️ Refactor suggestionEnhance mobile drawer usability and performance.
The mobile drawer implementation needs improvements:
The drawer implementation could be improved with better keyboard navigation and click-outside behavior. Additionally, the transition performance can be optimized.
<transition name="slide"> <MobileSettingsDrawer :is-open="showMobileDrawer" :sections="settingSections" :current-tab="currentTab" + role="dialog" + aria-modal="true" + @keydown.esc="closeMobileDrawer" @close="closeMobileDrawer" @change-tab="changeTab" /> </transition>
🧹 Nitpick comments (5)
src/admin/pages/Settings.vue (5)
46-108
: Improve search functionality robustness and accessibility.The search implementation could be enhanced:
<div class="search-section relative w-full mb-4"> <div class="search-box w-full bg-white rounded-lg border border-gray-200 flex items-center"> <label for="dokan-admin-search" class="dashicons dashicons-search "></label> <input type="text" autocomplete="off" id="dokan-admin-search" class="w-full px-3 py-2 border-none focus:outline-none focus:ring-0 bg-transparent " :placeholder="__('Search e.g. vendor', 'dokan-lite')" v-model="searchText" @input="searchInSettings" ref="searchInSettings" + :aria-expanded="showSuggestions" + aria-controls="search-suggestions" + :aria-busy="isSearching" /> </div> <!-- Search Suggestions Dropdown --> <div v-if="searchText && settingSections.length > 0" class="d-xs:absolute lg:hidden left-0 right-0 top-[calc(100%+4px)] bg-white border border-gray-200 rounded-lg shadow-lg divide-y divide-gray-100 max-h-[280px] overflow-y-auto z-50" + id="search-suggestions" + role="listbox" + aria-label="Search suggestions" > <div v-for="section in settingSections" :key="section.id" class="hover:bg-gray-50 transition-colors cursor-pointer" @click="handleSectionClick(section)" + role="option" + :aria-selected="currentTab === section.id" >
699-706
: Improve drawer state management.The drawer state management needs improvement:
openMobileDrawer() { this.showMobileDrawer = true; - // Clear search text when opening drawer - this.searchText = ''; - const settingsWrap = document.querySelector('.dokan-settings-wrap'); - settingsWrap.style.zIndex = 9999; + document.body.style.overflow = 'hidden'; // Prevent background scroll + this.$nextTick(() => { + this.searchText = ''; + this.$refs.mobileDrawer.$el.querySelector('button,a').focus(); + }); this.validateBlankSearch(); },
708-712
: Improve drawer cleanup.The drawer cleanup needs improvement:
closeMobileDrawer() { this.showMobileDrawer = false; - const settingsWrap = document.querySelector('.dokan-settings-wrap'); - settingsWrap.style.zIndex = 1; + document.body.style.overflow = ''; // Restore scroll + // Return focus to the toggle button + this.$refs.mobileMenuToggle.$el.focus(); },
1276-1280
: Optimize transition performance.The transition implementation could be improved:
.slide-enter-active, .slide-leave-active { - transition: transform 0.3s ease-out; + transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1); + will-change: transform; } .slide-enter, .slide-leave-to { transform: translateX(-100%); + pointer-events: none; }
1248-1304
: Improve media query maintainability.The media query implementation could be improved:
Consider extracting the breakpoint values into CSS custom properties or Tailwind configuration for better maintainability:
+:root { + --breakpoint-mobile: 768px; +} -@media only screen and (max-width: 768px) { +@media only screen and (max-width: var(--breakpoint-mobile)) { .dokan-settings-wrap { // ... existing styles } }
📜 Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
Plan: Pro
📒 Files selected for processing (1)
src/admin/pages/Settings.vue
(12 hunks)
🔇 Additional comments (1)
src/admin/pages/Settings.vue (1)
21-42
: 🛠️ Refactor suggestionEnhance mobile toggle button accessibility.
The mobile menu toggle button implementation needs accessibility improvements:
<button class="d-xs:flex lg:hidden p-2.5 bg-white dokan-settings-menu-toggle-btn rounded-lg shadow-sm hover:bg-gray-50 transition-all duration-200 ease-in-out group outline-none " @click="openMobileDrawer" + aria-expanded="showMobileDrawer" + aria-controls="mobile-settings-drawer" + aria-label="Toggle Settings Menu" > <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" width="24" height="24" class="group-hover:scale-110 transition-transform duration-200" + aria-hidden="true" + role="img" >Likely invalid or redundant comment.
Issue: Wordpress navigation bar dropdown is displayed at top of screen Please note, this issue is not always reproducible. I was only able to reproduce it twice. Attachments @osmansufy bhai |
Issue: Sidebar content gets cut off at 1045 x 437 @osmansufy bhai |
All Submissions:
Changes proposed in this Pull Request:
Related Pull Request(s)
Closes
How to test the changes in this Pull Request:
Changelog entry
Detailed Description of the pull request. What was previous behaviour
and what will be changed in this PR.
Settings page responsive for mobile version with drower & search functionality
Before Changes
Describe the issue before changes with screenshots(s).
After Changes
Describe the issue after changes with screenshot(s).
Feature Video (optional)
Link of detailed video if this PR is for a feature.
PR Self Review Checklist:
FOR PR REVIEWER ONLY:
Summary by CodeRabbit
Summary by CodeRabbit
New Features
Bug Fixes
Style