nav_items.html 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. <div id="sidenav-accordion" class="accordion accordion-flush nav-item">
  2. {% for menu in nav_items %}
  3. {# Main Collapsible Menu #}
  4. <div class="accordion-item">
  5. <a
  6. href="#"
  7. role="button"
  8. aria-expanded="true"
  9. data-bs-toggle="collapse"
  10. data-bs-target="#{{ menu.label|lower }}"
  11. class="d-flex justify-content-between align-items-center accordion-button nav-link collapsed">
  12. <span class="fw-bold sidebar-nav-link">
  13. <i class="mdi mdi-{{ menu.icon }} me-1"></i>
  14. {{ menu.label }}
  15. </span>
  16. </a>
  17. <div id="{{ menu.label|lower }}" class="accordion-collapse collapse" data-bs-parent="#sidenav-accordion">
  18. <div class="multi-level accordion-body px-0">
  19. {% for group in menu.groups %}
  20. {# Within each main menu, there are groups of menu items #}
  21. <div class="flex-column nav px-2">
  22. {% if menu.groups|length > 1 %}
  23. <h6 class="accordion-item-title">{{ group.label }}</h6>
  24. {% endif %}
  25. {% for item in group.items %}
  26. {# Each Menu Item #}
  27. <div class="nav-item d-flex justify-content-between align-items-center">
  28. {# Menu Link with Text #}
  29. <a class="nav-link flex-grow-1 me-1" href="{% url item.url %}">
  30. {{ item.label }}
  31. </a>
  32. {# Add & Import Buttons #}
  33. <div class="btn-group">
  34. {% if item.has_add %}
  35. <a class="btn btn-sm btn-success lh-1" href="{% url item.add_url %}" title="Add {{ item.label }}">
  36. <i class="mdi mdi-plus-thick"></i>
  37. </a>
  38. {% endif %}
  39. {% if item.has_import %}
  40. <a class="btn btn-sm btn-outline-success lh-1" href="{% url item.import_url %}" title="Import {{ item.label }}">
  41. <i class="mdi mdi-upload"></i>
  42. </a>
  43. {% endif %}
  44. </div>
  45. </div>
  46. {% endfor %}
  47. </div>
  48. {# Show a divider if not the last group #}
  49. {% if forloop.counter != menu.groups|length %}
  50. <hr class="dropdown-divider my-2" />
  51. {% endif %}
  52. {% endfor %}
  53. </div>
  54. </div>
  55. </div>
  56. {% endfor %}
  57. </div>