Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/area17/made-with-twill-tutorials
Source code for Made with Twill tutorials on https://twill.io/tutorials
https://github.com/area17/made-with-twill-tutorials
cms laravel tutorial twill
Last synced: about 2 months ago
JSON representation
Source code for Made with Twill tutorials on https://twill.io/tutorials
- Host: GitHub
- URL: https://github.com/area17/made-with-twill-tutorials
- Owner: area17
- Created: 2020-06-26T15:47:39.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-04-19T21:17:24.000Z (over 1 year ago)
- Last Synced: 2024-05-21T08:09:05.830Z (8 months ago)
- Topics: cms, laravel, tutorial, twill
- Language: PHP
- Homepage:
- Size: 2.59 MB
- Stars: 6
- Watchers: 5
- Forks: 7
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
## Made with Twill
This code repository is the project for the teaching series 'Made with Twill.'
Each commit reflects the code created in the
corresponding YouTube screencast.- Commit: `basic installation`
**[Simple setup](https://www.youtube.com/watch?v=XMG6RLeLyjU)**
This episode explains how to set up a local development environment on your
computer using Homestead & Vagrant, then install and configure Laravel & Twill. Any setup that uses a web server and
database can be used.
A good fit for any developer working on a Mac or Windows setup. This is just a quick start suggestion.- Commit: `MWT: Episode 1`
**[Made with Twill: Command line (1/5)](https://www.youtube.com/watch?v=W4ECg9ojLmQ)**
We'll start getting familiar with the Twill command line and scaffold a module. Also, begin to explore
how simple it is to configure a form and work with a module's repository class to integrate content into Blade templates.- Commit: `MWT: Episode 2`
**[Made with Twill: Form fields (2/5)](https://www.youtube.com/watch?v=0UMfmDKyHUs)**
Adding more fields to our 'Project' model is straightforward, so we are exploring that.
And adding a many to many tag relationship is even easier! Plus, organizing the presentation of our
fields using convenient fieldsets.- Commit: `MWT: Episode 3`
**[Made with Twill: Block editor (3/5)](https://www.youtube.com/watch?v=kAcJ5G2GhiA)**
A very empowering feature in Twill is the block editor. It gives options to an author to be inventive
with the presentation while, at the same time, consistently manage data. We’ll create a new ‘Contributor’
module and explore the block editor.- Commit: `MWT: Episode 4`
**[Made with Twill: Connecting data (4/5)](https://www.youtube.com/watch?v=6x0zYhoea_4)**
Laravel's Eloquent model has made it easier to work with 'one-to-many' and 'many to many' relationships.
And now Twill has made it easy to administer these relationships with some powerful form options.- Commit: `MWT: Episode 5`
**[Made with Twill: Displaying content (5/5)](https://www.youtube.com/watch?v=9ZVtVTT7Jb4)**
The final episode of the series focuses on getting data into blade templates. As a Laravel Developer, you are probably
already familiar with many of these concepts. For displaying content, we are going to look at rendering blocks.## Getting started
### Environment requirements
Twill is compatible with Laravel versions `5.6` to `7`, running on PHP 7.1 and above.As a dependency to your own application, Twill shares Laravel's [server requirements](https://laravel.com/docs/6.x/installation#server-requirements), which are satisfied by both [Homestead](https://laravel.com/docs/7.x/homestead) and [Valet](https://laravel.com/docs/7.x/valet) during development, and easily deployed to production using [Forge](https://forge.laravel.com) and [Envoyer](https://envoyer.io) or [Envoy](https://laravel.com/docs/7.x/envoy), as well as any other Laravel compatible server configuration and deployment strategy.
Twill's database migrations create `json` columns. Your database should support the `json` type. Twill has been developed and tested against MySQL (`>=5.7`) and PostgreSQL(`>=9.3`).
In summary:
| | Supported versions | Recommended version |
|:-----------|:------------------:|:-------------------:|
| PHP | >= 7.1 | 7.4 |
| Laravel | >= 5.6 | 7 |
| npm | >= 5.7 | 6.13 |
| MySQL | >= 5.7 | 5.7 |
| PostgreSQL | >= 9.3 | 10 |## Setup local development environment
To setup our local environment we use [Laravel Homestead](https://laravel.com/docs/7.x/homestead).
For a quickstart in setting up this particular project see [Per Project Installation](https://laravel.com/docs/7.x/homestead#per-project-installation).
The YouTube video [Simple setup](https://www.youtube.com/watch?v=XMG6RLeLyjU) also takes you through a fresh install of Laravel & Twill on Homestead.#### Homestead config
- Copy `Homestead.sample.yaml` to `Homestead.yaml`
- Change the IP at the top if you have another vagrant machine running at the same IP
- Install composer dependencies `composer install`. This step should be done inside the VM, but in order to get the VM running you need to install the dependencies.
- Provision your vagrant machine with `vagrant up`
- In case the system didn't update your `/etc/hosts` file automatically, add the IP and domain defined at `Homestead.yaml` to your `/etc/hosts` file.#### Application setup
- Copy `.env.example` as `.env` and update with your local settings (if necessary).
- Hop into the VM with `vagrant ssh` and head into the project folder in `/home/vagrant/code`
- Ensure dependencies are installed with `composer install`
- Generate your application key: `php artisan key:generate`
- Migrate the database schema: `php artisan migrate`
- Create your Twill superadmin user: `php artisan twill:superadmin`#### Frontend build
To install dependencies run `npm ci`.
To build FE assets for dev run `npm run dev`.
To build FE assets for production run `npm run prod`.