Download the PHP package spatie/sidecar-shiki without Composer
On this page you can find all versions of the php package spatie/sidecar-shiki. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download spatie/sidecar-shiki
More information about spatie/sidecar-shiki
Files in spatie/sidecar-shiki
Package sidecar-shiki
Short Description Run Shiki highlighting with Sidecar
License MIT
Homepage https://github.com/spatie/sidecar-shiki
Informations about the package sidecar-shiki
Run Shiki highlighting with Sidecar
Shiki is a beautiful syntax highlighter powered by the same language engine that many code editors use. This package allows you to run Shiki on AWS Lambda through Sidecar.
You won't need to install Node, or any of Shiki's dependencies, on your server.
Support us
We invest a lot of resources into creating best in class open source packages. You can support us by buying one of our paid products.
We highly appreciate you sending us a postcard from your hometown, mentioning which of our package(s) you are using. You'll find our address on our contact page. We publish all received postcards on our virtual postcard wall.
Requirements
This package requires that hammerstone/sidecar
has been installed in your Laravel application.
Follow the Sidecar installation and configuration instructions.
Installation
You can install the package via composer:
Optionally, you can publish the config file with:
Register the HighlightFunction::class
in your sidecar.php
config file.
Deploy the Lambda function by running:
See Sidecar documentation for details.
Usage
You can highlight code by calling the \Spatie\SidecarShiki\SidecarShiki::highlight()
function.
The output is this chunk of HTML rendered through AWS Lambda which will output beautifully in the browser:
Marking lines as highlighted, added, deleted or focus
You can then target these classes in your own CSS to color these lines how you want.
Using the Commonmark HighlightCodeExtension
Here's how we can create a function that can convert markdown to HTML with all code snippets highlighted. Inside the function we'll create a new MarkdownConverter that uses the HighlightCodeExtension provided by this package.
The $theme
argument on HighlightCodeExtension
expects the name of one of the many themes that Shiki supports.
Testing
The testsuite makes connections to AWS and runs the deployed Lambda function. In order to run the testsuite, you will need an active AWS account.
We can use the native sidecar:configure
artisan command to create the necessary AWS credentials for Sidecar. First copy the testbench.example.yaml file to testbench.yaml. Then run ./vendor/bin/testbench sidecar:configure
to start the Sidecar setup process. (You only have to do the setup once)
After finishing the Sidecar setup process, you will have received a couple of SIDECAR_* environment variables. Add these credentials to both .env
and testbench.yaml
.
Now we can deploy our local HighlightFunction
to AWS Lambda. Run the following command in your terminal, before executing the testsuite.
After the successful deployment, you can run the testsuite.
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
- Rias Van der Veken
- All Contributors
Special thanks to [Stefan Zweifel]() for his sidecar-browsershot package as a big help in how to test this.
Alternatives
If you don't want to install and handle Shiki yourself, take a look at Torchlight, which can highlight your code with minimal setup.
License
The MIT License (MIT). Please see License File for more information.
All versions of sidecar-shiki with dependencies
hammerstone/sidecar Version ^0.5|^0.6
illuminate/contracts Version ^9.0|^10.0|^11.0
spatie/laravel-package-tools Version ^1.9.2