-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge remote-tracking branch 'origin/main'
- Loading branch information
Showing
1 changed file
with
123 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,123 @@ | ||
# Laravel Nova Chordpro Field | ||
|
||
Add a [Chordpro](https://www.chordpro.org/chordpro/chordpro-introduction/) viewer and editor into Laraavel Nova. | ||
The editor is a simple TextArea. The viewer display a fully formatted song. | ||
|
||
|
||
The following chordpro code | ||
``` | ||
{title: 005 - Tua Vontade} | ||
{subtitle: Adoradores 2} | ||
{key: E} | ||
{tempo: 75} | ||
{time: 6/8} | ||
{duration: 03:57} | ||
{c: (INTRODUÇÃO)} | ||
[E]x// [F#m7]x// [D9]x// [D9]x// | ||
[E]x// [F#m7]x// [D9]x// [D9]x// | ||
[E]Norte ou Sul, [F#m7]noite ou di[E/G#]-a eu te [A]seguirei [A] | ||
[E]Mesmo que o mundo [F#m7]me abando [E/G#]- ne eu [A]serei fiel [A] | ||
[B]Onde mandares [A]irei segurando em [E]tuas mãos [E] | ||
[B/D#]Sejas meus olhos e [A/C#]guies o meu cora[E]ção | ||
{soc} | ||
[E] Que eu [B]siga a tua vonta [B]- de e que | ||
[C#m7]sempre a missão me acompa [C#m7]- nhe | ||
Que eu [B/D#]seja a estrela da noi [B/D#]- te | ||
sempre a bri[A/E]lhar por [E]Ti | ||
[E] Eu sou [B]filho do Rei do univer [B]- so, | ||
{eoc} | ||
``` | ||
will be rendered inside Laravel Nova Field as | ||
data:image/s3,"s3://crabby-images/782f9/782f92bf1192d2189704dcd154ade4256f400cda" alt="image" | ||
|
||
also, supports dark mode | ||
|
||
data:image/s3,"s3://crabby-images/a3bd4/a3bd4968ebb4f972db89f91225f027ae8d006833" alt="image" | ||
|
||
|
||
|
||
|
||
This package is built with https://github.com/chordproject/chorpro-parser and https://github.com/eKoopmans/html2pdf.js and allows to | ||
- Edit chordpro (simple TextArea editor) | ||
- View a fully formatted song | ||
- Generate a pdf with the formatted song | ||
- Translate the displayed text like "Key", "Time", etc | ||
|
||
## Prerequisites | ||
[Laravel Nova 4+](https://nova.laravel.com/) | ||
|
||
|
||
## Installation | ||
|
||
In a Laravel nova instance, install `henryavila/laravel-nova-chordpro-field` | ||
```bash | ||
composer require henryavila/laravel-nova-chordpro-field | ||
``` | ||
|
||
|
||
## Localization | ||
|
||
Publish the package language files to your application's `resources/lang/vendor` directory: | ||
|
||
```bash | ||
php artisan vendor:publish --provider="Henryavila\LaravelNovaChordproField\FieldServiceProvider" | ||
``` | ||
|
||
## Usage | ||
|
||
Assuming you have a Nova Resource with the `chordpro` content in the `chordpro` column, the following code will render the chordpro as displayed in the image above | ||
|
||
```php | ||
|
||
// Laravel Nova Resource | ||
use \Henryavila\LaravelNovaChordproField\ChordproField; | ||
|
||
public function fields(Request $request): array | ||
{ | ||
return [ | ||
... | ||
ChordproField::make('Chordpro') | ||
->alwaysShow() | ||
->rules('required'), | ||
... | ||
]; | ||
} | ||
``` | ||
## Usage Options | ||
| Option | Description | Default Value | | ||
| ------------- | ------------- |------------- | | ||
| `showTabs()` | Display tablature |`true` | | ||
| `useSimpleChord()` | Simplify the chords. Ex: `E/G#` becomes `E` |`false` | | ||
| `showChords()` | Display the chords. If set to false, will display just the lyrics |`true` | | ||
| `rows()` | Number of rows in the edit form |`20` | | ||
|
||
|
||
|
||
### Usign all options with differents values | ||
```php | ||
// Laravel Nova Resource | ||
use \Henryavila\LaravelNovaChordproField\ChordproField; | ||
|
||
public function fields(Request $request): array | ||
{ | ||
return [ | ||
... | ||
ChordproField::make('Chordpro') | ||
->alwaysShow() | ||
->rows(30) | ||
->showTabs(false) | ||
->useSimpleChord() | ||
->showChords(false) | ||
->rules('required'), | ||
... | ||
]; | ||
} | ||
``` | ||
|
||
|
||
|