bnussbau / laravel-trmnl
Develop TRMNL plugins with Laravel
Fund package maintenance!
usetrmnl.com/?ref=laravel-trmnl
Requires
- php: ^8.2
- illuminate/contracts: ^10.0||^11.0||^12.0
- spatie/laravel-package-tools: ^1.18
- voku/simple_html_dom: ^4.8
Requires (Dev)
- larastan/larastan: ^2.9||^3.0
- laravel/pint: ^1.14
- nunomaduro/collision: ^8.1.1||^7.10.0
- orchestra/testbench: 10.*||^9.0.0||^8.22.0
- pestphp/pest: ^3.0
- pestphp/pest-plugin-arch: ^3.0
- pestphp/pest-plugin-laravel: ^3.0
- phpstan/extension-installer: ^1.3||^2.0
- phpstan/phpstan-deprecation-rules: ^1.1||^2.0
- phpstan/phpstan-phpunit: ^1.3||^2.0
This package is auto-updated.
Last update: 2025-03-13 18:51:59 UTC
README
Laravel TRMNL is a package designed to streamline the development of both public and private plugins for the TRMNL E-ink device. It supports data updates via webhooks or polling. For public plugins, it also provides built-in support for the TRMNL OAuth flow. Additionally, UI prototyping is made easier with the included Blade components.
If you are looking for a Laravel based TRMNL Server implementation, check out this repo: usetrmnl/byos_laravel
Support ❤️
Support the development of this package by purchasing a TRMNL device through our referral link: https://usetrmnl.com/?ref=laravel-trmnl.
At checkout, use the code laravel-trmnl
to receive a $15 discount on your purchase.
Plugins built with Laravel TRMNL
- trmnl-train-monitor by @bnussbau
Features
- 🔌 Public and private plugin support (docs), (docs)
- 🔄 Support for updates via webhooks or polling (docs)
- 🎨 Blade Components on top of the TRMNL Design System (docs)
- 🎯 OAuth integration support for public plugins (docs)
- 📱 Render Helpers for responsive layouts
Installation
You can install the package via composer:
composer require bnussbau/laravel-trmnl
Optional Steps
Publish Config
Optionally, publish the config file using:
php artisan vendor:publish --tag="trmnl-config"
Publish Views
Optionally, publish the views using:
php artisan vendor:publish --tag="trmnl-views"
Configuration
Default Environment Variables
The package can be configured through environment variables:
TRMNL_PLUGIN_TYPE= # private | public TRMNL_DATA_STRATEGY= # polling | webhook TRMNL_WEBHOOK_URL= # grab from TRMNL Dashboard [Private Plugins] TRMNL_OAUTH_CLIENT_ID= # grab from TRMNL Dashboard [Public Plugins] TRMNL_OAUTH_CLIENT_SECRET= # grab from TRMNL Dashboard [Public Plugins]
Plugin Development
Private Plugins
By default, plugins are private. To configure your settings, add the following environment variables to your .env
file:
TRMNL_PLUGIN_TYPE=private TRMNL_DATA_STRATEGY=webhook # or polling TRMNL_WEBHOOK_URL= # grab from TRMNL Dashboard if using webhook
Update Data
Laravel TRMNL provides the UpdateScreenContentJob
to facilitate sending data updates to TRMNL servers.
Example usage
UpdateScreenContentJob::dispatchSync([ 'key' => 'value', // ... other variables ]);
Example using a Model and Pagination
UpdateScreenContentJob::dispatchSync( Journey::whereNotIn('track', [1, 2]) ->whereBetween('timestamp_planned', [now()->setTimezone('Europe/Vienna') ->addMinutes(15), now()->setTimezone('Europe/Vienna')->addHours(2)]) ->paginate(8) ->toArray() );
Use the markup editor on the TRMNL private plugin webapp or use the stripMarkup()
Method on the Trmnl
Facade to render markup which you can copy into the editor. See Section Blade Components.
Public Plugins
Refer to the “Plugin Marketplace” section in the TRMNL documentation, paying close attention to the authentication flow.
Always verify the authorization token for incoming requests to prevent security issues. You can use Auth::guard('trmnl')
to verify.
Configuration
TRMNL_PLUGIN_TYPE=public TRMNL_OAUTH_CLIENT_ID= # grab from TRMNL Dashboard TRMNL_OAUTH_CLIENT_SECRET= # grab from TRMNL Dashboard
Publish & Run Migrations
Publishes the database table required for storing authentication data.
php artisan vendor:publish --tag="trmnl-migrations"
php artisan migrate
Render Markup
Public plugins need to provide a render endpoint, which returns markup for all screen layouts.
You can use the Trmnl::renderScreen()
as helper.
Route::post('/render', function () { // validate Authorization if (! Auth::guard('trmnl')->validate()) { return response()->json(['error' => 'Unauthorized'], 401); } return response()->json( Trmnl::renderScreen( 'trmnl.full', 'trmnl.half_horizontal', 'trmnl.half_vertical', 'trmnl.quadrant' ) ); })->name('trmnl.render'); // make sure to not verify CSRF Token for this route // ->withoutMiddleware([Illuminate\Foundation\Http\Middleware\VerifyCsrfToken::class])
Publish
Run command php artisan trmnl:plugin:configuration
to print the URLs required for plugin submission.
Blade Components
Blade Compontens can help you generate markup code. Alternatively you can just use the native CSS classes from the TRMNL Design System.
Usage
Basic Layout
<x-trmnl::view> <x-trmnl::layout> <!-- Your content here --> </x-trmnl::layout> <x-trmnl::title-bar/> </x-trmnl::view>
Quote Example
<x-trmnl::view> <x-trmnl::layout> <x-trmnl::markdown gapSize="large"> <x-trmnl::title>Motivational Quote</x-trmnl::title> <x-trmnl::content>“I love inside jokes. I hope to be a part of one someday.”</x-trmnl::content> <x-trmnl::label variant="underline">Michael Scott</x-trmnl::label> </x-trmnl::markdown> </x-trmnl::layout> <x-trmnl::title-bar/> </x-trmnl::view>
Testing
composer test
Credits
License
The MIT License (MIT). Please see License File for more information.