Skip to content

Latest commit

 

History

History
191 lines (147 loc) · 5 KB

README.md

File metadata and controls

191 lines (147 loc) · 5 KB

Admin Panel

This package provides a simple admin panel for your Vapor application.

📦 Installation

Add AdminPanel to your package dependencies (in your Package.swift file):

dependencies: [
    // ...
    .package(url: "https://github.com/brokenhandsio/admin-panel", from: "1.0.0-beta")
]

as well as to your target:

.product(name: "AdminPanel", package: "admin-panel")

🚀 Getting started

Import the package in your configure.swift file:

import AdminPanel

Then you can configure the admin panel:

app.adminPanel.config = .init(
    name: "your-app",
    baseURL: "http://127.0.0.1:8080",
    environment: app.environment
)

Examples

Login screen

Successful login

Manage users

Features

Confirm Modal

Admin Panel includes a generic confirmation modal for links, out of the box. Using HTML data attributes on <a>-tags the modal can be configured in different ways. Just add a data attribute to your link and you're all set.

Triggering the modal will append a HTML-element form to the DOM, containing title, text, confirm button and dismiss button.

By default confirm submits the form and dismiss will remove the HTML-element from the DOM

Basic usage

<a href="#" data-confirm="true">Open modal</a>

Data Attributes

Attribute Description example
data-confirm Initialize the modal data-confirm="true"
data-title Sets the title of the modal data-title="Please confirm"
data-text Sets the text of the modal data-text="Are you sure you want to continue?"
data-button Sets bootstrap css selector for the confirm button data-button="danger" [primary,secondary,success,danger,warning,info,light,dark]
data-confirm-btn Set the text label on the "confirm"-button data-confirm-btn="Yes"
data-dismiss-btn Set the text label on the "dismiss"-button data-confirm-btn="No"

Override default behavior

// Override modal confirm action
modalConfirmation.actions.confirm = function(event) {
    alert("Confirmed");
}

// Overríde modal dismiss action
modalConfirmation.actions.dismiss = function(event) {
    alert("Dismissed");
}

Leaf tags

Admin panel comes with a variety of leaf tags for generating certain HTML/js elements

#adminPanelAvatarURL

Use user image or fallback to Adorable avatars

Parameter Type Description
email String user's email
url String image url

Example usage

<img src="#adminPanelAvatarURL(user.email, user.avatarURL)" alt="Profile picture" class="img-thumbnail" width="40">

#adminPanelConfig

Convenience method to output configuration strings such as app or environment name or paths to certain templates

Supported input values and what they output

  • name: App name
  • baseURL: App base URL
  • sidebarMenuPath: Path to sidebar menu view template
  • dashboardPath: Path to dashboard view template
  • environment: Environment name
Parameter Type Description
configName String Config variable name

Example usage

<!-- outputs app name -->
#adminPanelConfig("name")

#adminPanel:user

Outputs a field on the current user object as a string

Parameter Type Description
fieldName String User field name

Example usage

<!-- outputs user's name -->
#adminPanelUser("name")

#adminPanel:user:hasRequiredRole

Check if user has a required role

Parameter Type Description
roleName String User role

Example usage

#if(adminPanelUserHasRequiredRole("superAdmin")):
    // Do something
#else:
    // Do something else
#endif

#adminPanelSidebarHeading

Renders a header, styled in a certain way, for the navigation sidebar.

Example usage

#adminPanelSidebarHeading: 
    Super Admin
#endadminPanelSidebarHeading

Renders

<h6 class="sidebar-heading d-flex justify-content-between align-items-center px-3 mt-4 mb-1 text-muted">
    <span>Super Admin</span>
</h6>

#adminPanelSidebarMenuItem

Renders a sidebar menu item, styled in a certain way, for the navigation sidebar.

Parameter Type Description
url String Menu item link reference
icon String Feather icon for menu item
activeURLPatterns String URL pattern to determine active state

Example usage

#adminPanelSidebarMenuItem("/admin/dashboard", "home", "/admin/dashboard*"):
    Home 
#endadminPanelSidebarMenuItem

Renders

<li class="nav-item">
    <a class="nav-link" href="/admin/dashboard">
        <span data-feather="home"></span>
        Home
    </a>
</li>