Development
NativePHP is currently in beta development
Let's get to v1!- Development
- What does the `native:serve` command do?
- Hot Reloading
- `composer native:dev`
- First run
- Subsequent runs
- App Icon
#Development
php artisan native:serve
NativePHP isn't prescriptive about how you develop your application. You can build it in the way you're most comfortable and familiar with, just as if you were building a traditional web application.
The only difference comes in the feedback cycle. Instead of switching to and refreshing your browser, you'll need to
be serving your application using php artisan native:serve
and refreshing (and in some cases restarting) your
application to see changes.
This is known as 'running a dev build'.
#What does the native:serve
command do?
The native:serve
command runs the Electron/Tauri 'debug build' commands, which build your application with various
debug options set to help make debugging easier, such as allowing you to show the Dev Tools in the embedded web view.
It also keeps the connection to the terminal open so you can see and inspect useful output from your app, such as logs, in real time.
These builds are unsigned and not meant for distribution. They do not go through various optimizations typically done when building your application for production and so they expose more about the inner workings of the code than you would typically want to share with your users.
A major part of the build process, even for debug builds, involves copying your application code into the runtime's build environment. This means that changes you make to your application code will not be reflected in your running application until you restart it.
You can stop the native:serve
command by pressing Ctrl-C
on your keyboard in the terminal window it's running in.
It will also terminate when you quit your application.
#Hot Reloading
Hot reloading is an awesome feature for automatically seeing changes to your application during development. NativePHP supports hot reloading of certain files within its core and your application, but it does not watch all of your source code for changes. It is left to you to determine how you want to approach this.
If you're using Vite, hot reloading will just work inside your app as long as you've booted your Vite dev server and included the Vite script tag in your views (ideally in your app's main layout file).
You can do this easily in Blade using the @vite
directive.
Then, in a separate terminal session to your php artisan native:serve
, from the root folder of your application, run:
npm run dev
Now changes you make to files in your source code will cause a hot reload in your running application.
Which files trigger reloads will depend on your Vite configuration.
#composer native:dev
You may find the native:dev
script convenient. By default, it is setup to run both native:serve
and npm run dev
concurrently in a single command:
composer native:dev
You may modify this script to suit your needs. Simply edit the command in your composer.json
scripts section.
#First run
When your application runs for the first time, a number of things occur.
NativePHP will:
- Create the
appdata
folder - where this is created depends which platform you're developing on. In development, it is named according to yourAPP_NAME
. - Create a
nativephp.sqlite
SQLite database in yourdatabase
folder. - Migrate this database.
The appdata
structure is identical to that created by production builds of your app, but when running in
development, the database created there is not migrated.
If you change your APP_NAME
, a new appdata
folder will be created. No previous files will be deleted.
#Subsequent runs
In development, your application will not run migrations of the nativephp.sqlite
database for you. You must do this
manually:
php artisan native:migrate
For more details, see the Databases section.
#App Icon
The native:serve
and native:build
commands look for the following icon files when building your application:
public/icon.png
- your main icon, used on the Desktop, Dock and app switcher.public/IconTemplate.png
- used in the Menu Bar on non-retina displays.public/[email protected]
- used in the Menu Bar on retina displays.
If any of these files exist, they will be moved into the relevant location to be used as your application's icons. You simply need to follow the naming convention.
Your main icon should be at least 512x512 pixels.