rapidez/statamic

Rapidez Statamic


README

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

Requirements

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.

Installation

composer require rapidez/statamic

Install command

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.

Sitemap

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.

Upgrading

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

License

GNU General Public License v3. Please see License File for more information.