This package helps you integrate Statamic within your Rapidez project by adding some good starting points:
- Products, categories and brands are integrated through Runway as read only resources so you can link them to the content
- Products, categories, brands and pages collections as starting point so you can extend this however you'd like
- Site registration based on the active Magento stores
- Route merging so Statamic routes work as fallback
- Page builder fieldset with a product slider, content, image and form component
- Responsive images with Glide through justbetter/statamic-glide-directive
- Breadcrumbs for pages
- Globals available in all views
- Meta title, description and automatic alternate hreflang link tags
You need to have statamic/cms
installed in your Rapidez installation. Follow the installation guide.
Make sure you have an existing User model as Statamic requires this. If you don't have a User model you can get it from the Laravel repo.
You will also need the migrations for the users table, this can be found here.
At last you need to make some changes to your User model to make it compatible with Statamic,
make sure to follow this guide after requiring rapidez/statamic
in your project.
composer require rapidez/statamic
The install command will help you set up all the necessary settings. It will mainly setup the Eloquent driver and publish the necessary vendor from the rapidez/statamic repo.
php artisan rapidez-statamic:install
When running the install command you will be prompted to setup the Eloquent driver. In this configuration you can choose what to keep in the flat file system and what to migrate to the database. We recommend migrating the following options to the database when setting up the eloquent driver:
- Assets
- Collection Trees
- Entries
- Forms
- Form Submissions
- Globals
- Global Variables
- Navigation Trees
- Terms
- Tokens
After you're done running the install command make sure to check our configuration guide written here.
We hook into the Rapidez Sitemap generation by adding our Statamic-specific sitemaps to the store's sitemap index.
For each store, we generate sitemaps for collections and taxonomies that have actual routes and content. The XML files will be stored in the configured sitemap disk (defaults to 'public') under the configured path (defaults to 'rapidez-sitemaps') with the following structure:
rapidez-sitemaps/{store_id}/{sitemap_prefix}_collection_{collection_handle}.xml
rapidez-sitemaps/{store_id}/{sitemap_prefix}_taxonomy_{taxonomy_handle}.xml
The sitemap prefix can be configured in the rapidez.statamic.sitemap.prefix
config.
Since 3.0.0 we have started using optionalDeep for the $globals, and $content variables. This means some code may need to be upgraded. Here's a list of things you can expect might need to be changed:
Since optionalDeep will always return the optional class we explicitly need to ask it if a value is set
- @if($globals->cookie_notice->text)
+ @if($globals->cookie_notice->text->isset())
This also means that checks for specific values need to be updated
- @if($globals->cookie_notice->text === 'foo')
+ @if($globals->cookie_notice->text->get() === 'foo')
However, anything that will attempt to cast the value to string will get the value right away. Thus bits that can stay unchanged are:
{{ $globals->cookie_notice->text }}
{{ $globals->cookie_notice->text ?? 'fallback value' }}
{{ $globals->cookie_notice->text . ' string concatenation' }}
@foreach($content->blocks as $contentBlock)
@endForeach
GNU General Public License v3. Please see License File for more information.