The latest version of Chief is 0.3.* which is the one being currently developed upon. Previous versions will no longer be maintained with the exception for security fixes and critical bugfixes. It is strongly recommended to upgrade to the latest 0.3 version.


Chief follows the semantic versioning and we always try to maintain a backward compatible release cycle. Note that while development is still in the 0.* release cycle, minor versions will be able to contain breaking changes.

Upgrading from 0.2.14 to 0.3.*


Set your composer package constraint to thinktomorrow/chief: ^0.3. Run composer update thinktomorrow/chief command to get to the latest 0.3.* version.

If during the install any errors occur regarding files not existing please refer to the removals section, change the affected classes and run composer install again.

Next update the chief assets by running php artisan vendor:publish --tag=chief-assets --force in your project root. Note that with the force flag you'll update all existing chief style and script assets in your project.

There are a couple of breaking changes in this upgrade. If you've done some advanced customisation, you're probably fine upgrading without too much hassle.

Updated config

There are some new configuration options added like strict, route.autoload, route.name and base-view-paths. Complete your config file by adding the following values:

# /config/thinktomorrow/chief.php

 * When chief is in strict mode, it exposes potential errors and warnings in your application.
 * Non-critical errors like non found urls or views. When such an error occurs in strict mode,
 * your app will throw an exception. Strict mode is by default only enabled in development.
'strict' => env('APP_DEBUG', false),

'route' => [
     * By default Chief will add the pages.show routing to your app. Since this is a catch-all route, it will be loaded last.
     * If this conflicts with your project, set the autoload value to false. In this case you are responsible for handling the routing.
     * Use the following route snippet as a starting point:
     *      Route::get('{slug?}', function($slug = '/'){
     *          return \Thinktomorrow\Chief\Urls\ChiefResponse::fromSlug($slug);
     *      })->name('pages.show')->where('slug', '(.*)?');
    'autoload' => true,

     * Route name for the route that chief uses to listen and interact with
     * a page request. It is set to `pages.show` but if this conflicts
     * with your project naming conventions, you can change it here.
    'name' => 'pages.show',

 * The Viewable::viewPath() method gives the view path for that specific model.
 * By default, we provide some sensible defaults for pages, modules and sets.
 * Here you define the relative base view path for these resp. models.
'base-view-paths' => [
    'pages'   => 'pages',
    'modules' => 'modules',
    'sets'    => 'sets',

The chief-settings file is changed and now has the following values:

 return [

      * Contact person (aka webmaster)
      * The contact person receives all incoming communication e.g. contact form submissions
      * and is the sender address for all transaction mails such as password reset mails.
     'contact_email' => env('MAIL_ADMIN_EMAIL', 'info@thinktomorrow.be'),
     'contact_name'  => env('MAIL_ADMIN_NAME', 'Think Tomorrow'),

      * Client details
      * This is mainly a backend thing but it can occur in a
      * couple of frontend places such as the mail footer.
     'app_name' => 'Chief',

Migrate page slugs to url table

The routing will still not work since there are no url entries yet. After installing the new version, you'll need to run migrations via php artisan migrate. These migrations will also copy all page slugs and convert them to proper urls.

page_translations.slug will be removed

Note that this migration removes the slug column on the page_translations table.

Changes to model registration

In version 0.2.14 you needed to define a registrationkey as the first parameter per model/manager pair registration. This first parameter is now renamed to managedModelKey and moved to the models. So to get everything in line remove the first parameter from the registrations in your ChiefprojectServiceProvider.

// version 0.2.14
$this->registerPage('singles', PageManager::class, Single::class);

// version 0.3
$this->registerPage(PageManager::class, Single::class);

And on the model you should add the managedModelKey and choose a relevant name.

protected static $managedModelKey = 'singles';

Model labels

The labelSingular and labelPlural field are now only accepted on the model instead of both the model and the manager.

You should remove the declaration of these fields on the manager to their respective models.



The chief routes or now autoloaded so you can safely remove the chief routes in your project and the controller linked to these. If you need to keep your own routing in place, make sure to set the chief setting thinktomorrow.chief.route.autoload to false so it will no longer autoload this route.


The following classes are removed or haved changed location:

  • Interface Thinktomorrow\Chief\Relations\PresentForParent can be replaced with Thinktomorrow\Chief\Concerns\Viewable\ViewableContract.
  • Trait Thinktomorrow\Chief\Relations\PresentingForParent can be replaced with Thinktomorrow\Chief\Concerns\Viewable\Viewable.
  • Thinktomorrow\Chief\Concerns\ProvidesUrl\ProvidesUrl moved to Thinktomorrow\Chief\Urls\ProvidesUrl\ProvidesUrl.

The following methods have been replaced:

  • The former method for rendering a view was presentForParent(ActingAsParent $parent) and is no longer available. Use the renderView() method instead.
  • The view() method on the Page model is removed and renderView() should be used instead. If you used this method in determining the frontend view, you should switch to the new response flow. See below.
  • The Page::menuUrl() was deprecated in previous 0.2 version and is now removed in favor of the Page::url() method.
  • Page::hasPagebuilder() and Page::pagebuilder were deprecated in 0.2 and are now removed. They are no longer used to determine if pagebuilder should be used or not. If you need to control the pagebuilder setup, you should adapt the fields() return value instead.
  • Removed: Page::findBySlug() and Page::findPublishedBySlug().
  • Removed: Homepage setting and chief-settings.homepage config value. A homepage is now determined by changing the page url to a '/'.
  • Added: ProvidesUrl now also required you to implement the resolveUrl function. The default to be used is the following:
public function resolveUrl(string $locale = null, $parameters = null): string
    $routeName = config('thinktomorrow.chief.route.name');

    return $this->resolveRoute($routeName, $parameters, $locale);


The model data passed to the view, will now always be passed as a $model or $collection variable. Since 0.3 the $page, $module and $pages are deprecated.

middleware group and aliases no longer required

The web-chief middleware group is now autoloaded by the package. It is no longer needed to add this yourself in the App\Http\Kernel file.

The following route middleware aliases are no longer required to load up in your project. There are handled by the package itself. auth.superadmin, chief-guest, chief-validate-invite

Removed: $page and $module view variables.

  • The page or module is now passed as a $model variable to the view. The $page, $module and $pages - as used by custom query sets - variables are set as deprecated and will be removed in 0.4.

Changed: default viewpaths

The default page and module viewpaths no longer assume the front folder. The default are now:

  • pages: resources/views/pages,
  • modules: resources/views/modules,
  • sets: resources/views/sets

You can change these to fit your project's needs in the thinktomorrow.chief.base-view-paths config setting.

Changed: fieldArrangement()

If you've written a custom Manager::fieldArrangement(), chances are that you'll need to replace the $this->fields presence in the method to $this->fieldsWithAssistantFields(). This change is needed to include any optional assistant added fields as well.


Due to the changes in url management you should make sure one of your pages has '/' as its url to identify it as the homepage.

Upgrading from 0.3.* to 0.4.*

The biggest change and the one most likely to affect your project is the Assetlibrary update to 0.6 . Follow the assetlibrary upgrade documentation for this change. Assetlibrary Documentation

Last Updated: 7/18/2019, 3:39:45 PM