Download the PHP package zofe/rapyd-livewire without Composer
On this page you can find all versions of the php package zofe/rapyd-livewire. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download zofe/rapyd-livewire
More information about zofe/rapyd-livewire
Files in zofe/rapyd-livewire
Package rapyd-livewire
Short Description rapyd-livewire
License MIT
Homepage https://github.com/zofe/rapyd-livewire
Informations about the package rapyd-livewire
rapyd-livewire
requirements: laravel ^8.65 | 9. | 10.
Demo: rapyd.dev
What is it?
is a laravel library of blade components, livewire traits, and modules scaffolder that you can use to generate administration interfaces in a concise, reusable, uncluttered, and testable manner.
It also bundles standard frontend libraries like Bootstrap, Vue, Alpine, Tom Select and Quill to be used as fast boilerplate for your laravel admin panels.
The idea is to speed up and organize the development of large laravel applications:
- modular approach (you can organize your backends into reusable modules, isolating everything, components, views, tests, but also translations, migrations, jobs, each module can be like an isolated laravel application)
- livewire component based (no needed controllers, each component is naturally reactive, you can get away with few pure livewire classes and blade views, easily testable and maintainable)
- blade component based (dozens of available anonymous components to standardize frontend in few "bootstrap based" spacialized tags, which you can eventually extend)
Modules
example of out of the box module structure you can use after installing rapyd.
- You can create "Modules" folder in you app/ directory of your laravel application.
- Then you can create your Module Folder i.e.:
Blog
- Livewire components will be searched in the
Components
subfolder - You can refer to the views in your module using intuitive shortcut i.e.:
blog::Articles.views.articles_edit
- Inside your Module folder you can reply (if needed) the laravel application folder structure (controllers, migrations, jobs, etc..)
Rapyd has also some public modules available via "composer require":
- zofe/demo-module demo
- zofe/knowledgebase-module knowledgebase
-
zofe/auth-module auth
- zofe/layout-module layout
Rapyd has a "module installer": zofe/rapyd-module-installer
this means that you can plan to create & distribute your modules as packages including it as dependency and following a simple naming convention, for example with a composer.json file like this:
then you can include your own modules using composer require "yourname/mymodule-module" and this will install your dependency in
app/Modules/Mymodule
Please check for example zofe/knowledgebase-module knowledgebase module to get an idea of how to structure it.
Installation
You can install the package via composer:
You can publish static assets using:
if you want you can download the demo module in your laravel-rapyd application try the zofe/demo-module
Usage
DataTable
A DataTable is a "listing component" with these features:
- "input filters" to search in a custom data set
- "buttons" (for example "add" record or "reset" filters)
- "pagination links"
- "sort links"
props
title
: the heading title for this crud
content/slots
- should be a html table that loops model $items
buttons
: buttons panel
example: rapyd.dev/demo/articles
DataView
a DataView is a "detail page component" with :
- "buttons" slot (for example back to "list" or "edit" current record)
- "actions" any link that trigger a server-side
props
title
: the heading title for this crud
content/slots
- should be a detail of $model
buttons
: buttons panelactions
: buttons panel
example: rapyd.dev/demo/article/view/1
DataEdit
DataEdit is a "form component" usually binded to a model with:
- "buttons" and "actions" (undo, save, etc..)
- form "fields"
- automatic errors massages / rules management
props
title
: the heading title for this crud
content/slots
- form fields binded with public/model properties
example: rapyd.dev/demo/article/edit/1
Fields
inside some widget views you can drastically semplify the syntax using predefined blade components that interacts with livewire
props
label
: label to display above the inputplaceholder
: placeholder to use for the empty first optionmodel
: Livewire model property keyoptions
: array of options e.g. (used in selects)debounce
: Livewire time in ms to bind data on keyuplazy
: Livewire bind data only on changeprepend
: addon to display before input, can be used via named slotappend
: addon to display after input, can be used via named slothelp
: helper label to display under the inputicon
: Font Awesome icon to show before input e.g.cog
,envelope
size
: Bootstrap input size e.g.sm
,lg
rows
: rows numsmultiple
: allow multiple option selection (used in select-list)endpoint
: a remote url for fetch optioms (used in select-list)format
: the client-side field format (used in date and date-time)value-format
: the server-side field value format (used in date and date-time)
special tags
navigation
Nav Tabs: bootstrap nav-link menu with self-determined active link
Nav Items: boostrap vertical menu items / single or grouped (collapsed)
Nav Sidebar: bootstrap sidebar with self-determined or segment-based active link
minimal application layout
there are some css/js dependencies (livewire, bootstrap, alpinejs, vuejs) but rapyd has two directive to simplify all needed inclusions.
Consider to use {{ $slot }}
as entry-point if you plan to use
Full-page components
don't forget to add "app" class to your main div if you plan to use vuejs components
layout module
If you want to isolate the layout as well and make it a module, reusable in multiple projects, rapyd does that as well, and it has a default module that you can customize or take as an example:
- zofe/layout-module layout module
To-do
- component generators (with custom stub for DataTable,DataEdit,DataView)
- "plugin" architecture (a way to download a module from a public or private repository.. or just a composer way to deploy in app/Modules)
Credits
- Felice Ostuni
- All Contributors
Inspirations:
- rapyd-laravel my old laravel library (150k downloads)
- livewire widely used "full-stack framework" to compose laravel application by widgets
- laravel-bootstrap-components smart library which reduced the complexity of this one
License & Contacts
Rapyd is licensed under the MIT license
Please join me and review my work on Linkedin
thanks
All versions of rapyd-livewire with dependencies
illuminate/config Version ^8.65|^9.0|^10.0
illuminate/contracts Version ^8.65|^9.0|^10.0
laravel/serializable-closure Version ^1.1
livewire/livewire Version ^2.0