@Ryan_Hyer رائع! لقد اكتشفت طريقة لجعل العناصر تظهر (أو تستمر في الظهور) بعد حدث تبديل البرجر، وهي المشكلة التي كنت أواجهها هنا:
الكود الخاص بك منظم ونظيف للغاية أيضًا. بفضل ذلك، تمكنت من تعديله لعرض ما أريده في قائمة المجتمع دون أن يكون مخفيًا تحت المزيد:
الرأس:
<script>
const links = [
// قد تحتاج أيقونات FontAwesome إلى إضافتها في إعدادات الموقع إذا لم تظهر بشكل صحيح
{ title: "دليل المستخدم", src: "/u?asc=true&cards=yes&order=username&period=all", icon: "address-book" },
{ title: "الوثائق", src: "/docs", icon: "book-reader" },
{ title: "موقع خارجي", src: "https://google.com/", icon: "globe" }
]
$(document).ready(function () {
if (document.getElementById("toggle-hamburger-menu")) {
// نحن في وضع الهاتف المحمول
addToggleListener(document.getElementById("toggle-hamburger-menu"))
} else {
// نحن في وضع سطح المكتب
addToggleListener(document.getElementsByClassName("btn-sidebar-toggle")[0])
addCustomLinks()
}
function addToggleListener(toggleEl) {
if (toggleEl) {
toggleEl.addEventListener("click", function () {
// انتظر قليلاً حتى يتم تحميل الشريط الجانبي
setTimeout(function() {
let sidebar = document.getElementsByClassName("sidebar-section-header").length
if (sidebar) {
addCustomLinks()
}
}, 100)
})
}
}
function addCustomLinks() {
// انتظر قليلاً حتى يتم تحميل التنقل
setTimeout(function () {
const parentEl = document.getElementsByClassName("sidebar-section-content")[0]
let linksAlreadyAdded = document.getElementsByClassName("sidebar-section-custom-link").length
if (parentEl && !linksAlreadyAdded) {
links.filter(function (link) {
let linkDiv = document.createElement("li")
let linkTitleTrim = link.title.replace(/\s+/g, '')
linkDiv.className = "sidebar-section-link-wrapper sidebar-section-custom-link"
linkDiv.innerHTML = `<a href="${link.src}" class="sidebar-section-link sidebar-section-link-everything sidebar-row ember-view">
<span class="sidebar-section-link-prefix icon" id="link_${linkTitleTrim}"></span>
<span class="sidebar-section-link-content-text"> ${link.title} </span>
</a>
`
parentEl.append(linkDiv)
let linkIcon = document.getElementById("link_" + linkTitleTrim)
if (linkIcon && link.icon) {
linkIcon.innerHTML = `<svg viewBox="0 0 640 512" class="fa d-icon svg-icon prefix-icon svg-string d-icon-${link.icon}" xmlns="http://www.w3.org/2000/svg">
<use xlink:href="#${link.icon}"></use>
</svg>
`
}
})
}
}, 100)
}
})
</script>
و CSS المكمل:
.sidebar-section-content {
display: flex; /* إعداد تخطيط مرن لإعادة ترتيب الأشياء */
flex-direction: column;
.sidebar-more-section-links-details {
order: +1;
}
}
.sidebar-wrapper li a.sidebar-section-link-about {
display: none;
}
.sidebar-wrapper li a.sidebar-section-link-faq {
display: none;
}
.sidebar-more-section-links-details-content-secondary .sidebar-section-link.sidebar-section-link-about {
display: none;
}
.sidebar-more-section-links-details-content-secondary .sidebar-section-link.sidebar-section-link-faq {
display: none;
}