Download the PHP package protonemedia/laravel-splade-core without Composer

On this page you can find all versions of the php package protonemedia/laravel-splade-core. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.

FAQ

After the download, you have to make one include require_once('vendor/autoload.php');. After that you have to import the classes with use statements.

Example:
If you use only one package a project is not needed. But if you use more then one package, without a project it is not possible to import the classes with use statements.

In general, it is recommended to use always a project to download your libraries. In an application normally there is more than one library needed.
Some PHP packages are not free to download and because of that hosted in private repositories. In this case some credentials are needed to access such packages. Please use the auth.json textarea to insert credentials, if a package is coming from a private repository. You can look here for more information.

  • Some hosting areas are not accessible by a terminal or SSH. Then it is not possible to use Composer.
  • To use Composer is sometimes complicated. Especially for beginners.
  • Composer needs much resources. Sometimes they are not available on a simple webspace.
  • If you are using private repositories you don't need to share your credentials. You can set up everything on our site and then you provide a simple download link to your team member.
  • Simplify your Composer build process. Use our own command line tool to download the vendor folder as binary. This makes your build process faster and you don't need to expose your credentials for private repositories.
Please rate this library. Is it a good library?

Informations about the package laravel-splade-core

[Experimental] Laravel Splade Core

A package to use Vue 3's Composition API in Laravel Blade.

Latest Version on Packagist GitHub Tests Action Status Splade Discord Server GitHub Sponsors

:warning: This package is abandoned: Thoughts on Splade: I took a week off to look around and reflect.

Sponsor Splade

We sincerely value our community support in our endeavor to create and offer free Laravel packages. If you find our package beneficial and rely on it for your professional work, we kindly request your support in sponsoring its maintenance and development. Managing issues and pull requests is a time-intensive task, and your assistance would be greatly appreciated. Thank you for considering our request! ❤️

Why is this experimental?

Although this package comes with an extensive test suite, it's important to note that it's in an experimental stage. It's a new package, and I haven't used it in production yet. Currently, I'm using the original Splade v1 package for my production needs. However, in 2023 Q4, I plan to integrate this new package into two new projects. It's also worth mentioning that I haven't yet confirmed full compatibility between this package and all the features of the original Splade package.

What does this have to do with the existing Laravel Splade package?

Laravel Splade currently offers a ton of features:

While this is great and tremendously helps to build SPAs with Laravel, it also makes it harder to maintain and extend the package. This is why I decided to split Splade into multiple packages:

Requirements

Features

Limitations

Installation

You can install the package via composer:

Automatic Installation

For new projects, you may use the splade:core:install Artisan command to automatically install the package:

This will install the JavaScript packages, create a root layout and a demo component, and add the required configuration to your app.js and vite.config.js files. After running this command, you may run npm install to install the JavaScript dependencies and then run npm run dev to start Vite.

Manual Installation

First, you should install the companion JavaScript packages:

Splade Core automatically generates Vue components for all your Blade templates. By default, they are stored in resources/js/splade. You don't have to commit these files to your repository, as they are automatically generated when you run Vite. To initialize this directory, run the following command:

In your main Javascript file (app.js), you must instantiate a new Vue app and use the Splade Core plugin. Following Laravel's convention, the app.js file is stored in resources/js, so you may pass the relative ./splade path to the plugin options:

In your vite.config.js file, you must add the laravel-splade-vite plugin. Make sure it is added before the laravel and vue plugins:

Lastly, in your root layout file, you must create a root element for your Vue app, and you must include a script tag for the Splade templates stack. This must be done above the #app element:

Usage with Blade Components

You may use the default make:component Artisan command to generate a Blade Component:

In the Blade template, you may use a <script setup> tag to make your component reactive:

Besides running the Vite dev server, you don't have to do anything else. The component will be automatically compiled and registered as a Vue component.

Echo syntax

Blade and Vue use the same curly brace syntax to render variables. This means that you can't use the {{ message }} syntax in your template to render a Vue variable. Technically, this is because the Blade compiler comes before the Vue compiler. There are two ways to solve this:

Use the v-html or v-text directive:

Or, use the @ symbol to escape the curly braces:

Composition API imports

In the first above, we used the ref and computed functions from Vue's Composition API. Splade Core automatically imports these functions for you. Here's a list of all the functions that are automatically imported:

Attribute Inheritance

Just like regular Blade Components, you may use the $attributes variable to inherit attributes passed to the component. This also works for v-model:

Here's the template of the <x-form> component:

And here's the template of the <x-select> component:

Inheritance on Components with a script tag

If the component you're passing attributes to has a <script> tag, the attributes are passed as Vue props to the root element of the component. If you want to pass the attributes to a different element, you may use the v-bind="$attrs" directive:

Splade Core automatically detects the custom directive.

Element Refs

You may use the $refs variable to access element refs. This doesn't naturally work in Vue 3's Composition API, but it was great in Vue 2, so I decided to add it back in Splade Core:

Tapping into the Vue ecosystem

Using libraries and packages from the Js/Vue ecosystem is easy. Here's an example of using Flatpickr:

Note that you can use props.modelValue without defining it. Splade Core automatically detects the usage of modelValue and adds it to the props object.

Calling methods on the Blade Component

If your Blade Component has a public method, you may call it from the template, either in the script or in the template. Splade Core detects the HTTP Middleware of the current page and applies it to subsequent requests. The only thing you have to do is add the Vue attribute to the method:

Template:

Note that you can use notify.loading to check if the method is currently running.

[!WARNING] While the original Middleware is applied to the request, you should still validate the incoming data.

Pass Blade Variables as Vue Props

You may pass Blade variables as Vue props. This is useful if you want to pass data from the backend to the frontend. The only thing you have to do is add the VueProp attribute to the property:

Now you may use the defaultMessage prop in the template and in the script tag. You don't need to specify the prop in the props object, as Splade Core automatically does this for you.

Pass Blade Variables as Vue Refs

Even more powerful than passing Blade variables as Vue Props, is passing them as Vue Refs. This way, you can use the variable as a reactive variable in the template. You may update them on the frontend, and when you call a Blade Component method, the value will be updated on the backend. The only thing you have to do is add the VueRef attribute to the property:

Template:

[!WARNING] Be careful what you define as a public property. For example, if you define an Eloquent model as a public property, it will be serialized to JSON and passed to the frontend. Be sure sensitive attributes are hidden.

Callbacks

Instead of calling the method from the template, you may also call it from the script. This way, you can use then, catch and finally:

Alternatively, you may add global callbacks to the notify method:

Refresh Component

To make components refreshable, you must add the Refreshable middleware to the route:

Then, you may use the refreshComponent method to refresh the component. This will re-render the component and re-fetch the data.

Similar to calling Blade Methods, you can use refreshComponent.loading to check if the component is currently refreshing. You may also use callbacks with refreshComponent.

Usage with Blade Views

If you don't want to use Blade Components, you may also use Blade Views. Currently, reloading of Blade Views is not supported.

Just like with Blade Components, you may use a <script setup> tag at the top of your Blade View. If you're extending a layout, make sure to place the <script setup> tag inside the slot:

Including Blade Views

Note that you can only use one script tag per Blade View. For example, if your Blade View already has a script tag, you can't include another Blade View with a script tag using the @include directive. If you want to do this, convert the included Blade View to a Blade Component.

Changelog

Please see CHANGELOG for more information on what has changed recently.

Contributing

Please see CONTRIBUTING for details.

Security

If you discover any security-related issues, please email [email protected] instead of using the issue tracker.

Credits

License

The MIT License (MIT). Please see License File for more information.


All versions of laravel-splade-core with dependencies

PHP Build Version
Package Version
Requires php Version ^8.1
illuminate/contracts Version ^10.0
mck89/peast Version ^1.15
spatie/laravel-package-tools Version ^1.14.0
Composer command for our command line client (download client) This client runs in each environment. You don't need a specific PHP version etc. The first 20 API calls are free. Standard composer command

The package protonemedia/laravel-splade-core contains the following files

Loading the files please wait ....