Socket
Socket
Sign inDemoInstall

admini

Package Overview
Dependencies
4
Maintainers
1
Versions
21
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    admini

Minimalistic Admin Panel built with Bootstrap 5


Version published
Weekly downloads
1
Maintainers
1
Created
Weekly downloads
 

Readme

Source

Admini

Minimalistic Admin Panel built with Bootstrap 5.3

Features

  • No bloat, only what's strictly required to get a decent admin panel
  • A nice, modern, Bootstrap 5 based interface
  • A friendly dashboard
  • Extended Avatar UI with badges, icons, pictures, groups...
  • A powerful action system that supports many use cases (multiple actions, drops, navigation, offcanvas panel...)
  • A sane default layout for forms (includes tabbed form support and responsive by default)
  • A nice default set of colors that are more accessible
  • Powerful (but optional) ajax navigation
  • Super lightweight (around 100kb, including bootstrap)
  • Dark mode support

BS Companion

Some bootstrap related features of admini have been extracted to a third party module called BS Companion

  • Responsive Table : Nice responsive tables without ugly scrollbars
  • BS Tabs : Improved tabs, that collapse down to a dropdown and with linkable tabs
  • BS Toggle : Self initializing popovers and tabs
  • Toaster : Generate beautiful toast message without markup
  • Modalizer : Generate beautiful modals without markup
  • Form Validator : Consistent validator that works across tabs and accordions

Form elements

Admini does not provide any built in custom form elements. This is because we are often used to use specifics libraries based on our usage and personal preferences.

I highly recommend you to use my WIP (but already very stable) Formidable Elements collection.

If you don't find what you need there, you can use Modular Behaviour. It works beautifully in combination with skypack.

Ajax navigation

The admin panel provides a built-in (but optional) navigation with sco-pe, a custom element made to load page fragments.

Changing from a full page load on each action to a ajax powered navigation as a few side effects that you should not ignore:

  • Avoid initializing things multiple time
  • But aware of the state
  • Cleanup when elements are removed

Avoid initializing things multiple time can be done in three ways:

  • Have self initializing custom elements or use Modular Behaviour.
  • Happily trigger full page init with multiple init safe scripts (eg: using initialize util provided)
  • Define custom per fragment code with onScopeLoad

You can also ditch sco-pe completely and use a more robust solution like Turbo or Unpoly. I didn't want to use these libraries because they tend to creep to much into the project architecture. With sco-pe, you can pretty much write regular html and it will work with minimal changes. More on that topic.

Icons and images

Demo

Demo is available on Vercel

Try at home

The build setup

Admini use esbuild to compile the js assets. After cloning this repo, simply run

npm start

And you will get a fully functional local demo to play with.

If you want to work on the css, run in another terminal the following

npm run watch-css

And your css will be compiled automatically.

No complicated build pipe :-)

Keywords

FAQs

Last updated on 19 Jul 2023

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc