typicms / base
A multilingual CMS built with Laravel
Fund package maintenance!
Requires
- php: ^8.3
- bkwld/croppa: ^7.0
- eluceo/ical: ^2.13
- enshrined/svg-sanitize: ^0.22.0
- genealabs/laravel-model-caching: ^12.0
- laracasts/presenter: ^0.2.8
- laracasts/utilities: ^3.2
- laravel/framework: ^12.0
- laravel/prompts: ^0.3
- laravel/tinker: ^2.9
- maatwebsite/excel: ^3.1
- msurguy/honeypot: ^1.4
- spatie/eloquent-sortable: ^5.0.0
- spatie/laravel-feed: ^4.4
- spatie/laravel-one-time-passwords: ^1.0
- spatie/laravel-passkeys: ^1.0
- spatie/laravel-permission: ^7.1.0
- spatie/laravel-query-builder: ^6.3
- symfony/http-client: ^7.4.5
- symfony/mailgun-mailer: ^7.4.0
- typicms/core: ^16.1
- typicms/laravel-translatable-bootforms: ^9.0.0
- typicms/nestablecollection: ^5.0
- typicms/sidebar: ^1.1
- typicms/things: ^16.1
- typicms/translatable: ^1.0
- typidesign/laravel-artisan-translations: ^3.1
- ultrono/laravel-sitemap: ^9.5
Requires (Dev)
- barryvdh/laravel-debugbar: ^4.0.5
- driftingly/rector-laravel: ^2.0
- fakerphp/faker: ^1.23
- laravel/boost: ^2.0
- laravel/pail: ^1.2.2
- laravel/pint: ^1.13
- laravel/sail: ^1.41
- mockery/mockery: ^1.6
- nunomaduro/collision: ^8.6
- rector/rector: ^2.1
- spatie/laravel-ignition: ^2.9
- dev-master
- dev-main
- 16.1.10
- 16.1.9
- 16.1.8
- 16.1.7
- 16.1.6
- 16.1.5
- 16.1.4
- 16.1.3
- 16.1.2
- 16.1.1
- 16.1.0
- 16.0.13
- 16.0.12
- 16.0.11
- 16.0.10
- 16.0.9
- 16.0.8
- 16.0.7
- 16.0.6
- 16.0.5
- 16.0.4
- 16.0.3
- 16.0.2
- 16.0.1
- 16.0.0
- 15.0.25
- 15.0.24
- 15.0.23
- 15.0.22
- 15.0.21
- 15.0.20
- 15.0.19
- 15.0.18
- 15.0.17
- 15.0.16
- 15.0.15
- 15.0.14
- 15.0.13
- 15.0.12
- 15.0.11
- 15.0.10
- 15.0.9
- 15.0.8
- 15.0.7
- 15.0.6
- 15.0.5
- 15.0.4
- 15.0.3
- 15.0.2
- 15.0.1
- 15.0.0
- 14.0.x-dev
- 14.0.21
- 14.0.20
- 14.0.19
- 14.0.18
- 14.0.17
- 14.0.16
- 14.0.15
- 14.0.14
- 14.0.13
- 14.0.12
- 14.0.11
- 14.0.10
- 14.0.9
- 14.0.8
- 14.0.7
- 14.0.6
- 14.0.5
- 14.0.4
- 14.0.3
- 14.0.2
- 14.0.1
- 14.0.0
- 13.0.x-dev
- 13.0.6
- 13.0.5
- 13.0.4
- 13.0.3
- 13.0.2
- 13.0.1
- 13.0.0
- 12.0.x-dev
- 12.0.2
- 12.0.1
- 12.0.0
- 11.0.x-dev
- 11.0.32
- 11.0.31
- 11.0.30
- 11.0.29
- 11.0.28
- 11.0.27
- 11.0.26
- 11.0.25
- 11.0.24
- 11.0.23
- 11.0.22
- 11.0.21
- 11.0.20
- 11.0.19
- 11.0.18
- 11.0.17
- 11.0.16
- 11.0.15
- 11.0.14
- 11.0.13
- 11.0.12
- 11.0.11
- 11.0.10
- 11.0.9
- 11.0.8
- 11.0.7
- 11.0.6
- 11.0.5
- 11.0.4
- 11.0.3
- 11.0.2
- 11.0.1
- 11.0.0
- 10.0.x-dev
- 10.0.45
- 10.0.44
- 10.0.43
- 10.0.42
- 10.0.41
- 10.0.40
- 10.0.39
- 10.0.38
- 10.0.37
- 10.0.36
- 10.0.35
- 10.0.34
- 10.0.33
- 10.0.32
- 10.0.31
- 10.0.30
- 10.0.29
- 10.0.28
- 10.0.27
- 10.0.26
- 10.0.25
- 10.0.24
- 10.0.23
- 10.0.22
- 10.0.21
- 10.0.20
- 10.0.19
- 10.0.18
- 10.0.17
- 10.0.16
- 10.0.15
- 10.0.14
- 10.0.13
- 10.0.12
- 10.0.11
- 10.0.10
- 10.0.9
- 10.0.8
- 10.0.7
- 10.0.6
- 10.0.5
- 10.0.4
- 10.0.3
- 10.0.2
- 10.0.1
- 10.0.0
- 9.0.x-dev
- 9.0.47
- 9.0.46
- 9.0.45
- 9.0.44
- 9.0.43
- 9.0.42
- 9.0.41
- 9.0.40
- 9.0.39
- 9.0.38
- 9.0.37
- 9.0.36
- 9.0.35
- 9.0.34
- 9.0.33
- 9.0.32
- 9.0.31
- 9.0.30
- 9.0.29
- 9.0.28
- 9.0.27
- 9.0.26
- 9.0.25
- 9.0.24
- 9.0.23
- 9.0.22
- 9.0.21
- 9.0.20
- 9.0.19
- 9.0.18
- 9.0.17
- 9.0.16
- 9.0.15
- 9.0.14
- 9.0.13
- 9.0.12
- 9.0.11
- 9.0.10
- 9.0.9
- 9.0.8
- 9.0.7
- 9.0.6
- 9.0.5
- 9.0.4
- 9.0.3
- 9.0.2
- 9.0.1
- 9.0.0
- 8.0.9
- 8.0.8
- 8.0.7
- 8.0.6
- 8.0.5
- 8.0.4
- 8.0.3
- 8.0.2
- 8.0.1
- 8.0.0
- 7.0.x-dev
- 7.0.47
- 7.0.46
- 7.0.45
- 7.0.44
- 7.0.43
- 7.0.42
- 7.0.41
- 7.0.40
- 7.0.39
- 7.0.38
- 7.0.37
- 7.0.36
- 7.0.35
- 7.0.34
- 7.0.33
- 7.0.32
- 7.0.31
- 7.0.30
- 7.0.29
- 7.0.28
- 7.0.27
- 7.0.26
- 7.0.25
- 7.0.24
- 7.0.23
- 7.0.22
- 7.0.21
- 7.0.20
- 7.0.19
- 7.0.18
- 7.0.17
- 7.0.16
- 7.0.15
- 7.0.14
- 7.0.13
- 7.0.12
- 7.0.11
- 7.0.10
- 7.0.9
- 7.0.8
- 7.0.7
- 7.0.6
- 7.0.5
- 7.0.4
- 7.0.3
- 7.0.2
- 7.0.1
- 7.0.0
- 6.0.24
- 6.0.23
- 6.0.22
- 6.0.21
- 6.0.20
- 6.0.19
- 6.0.18
- 6.0.17
- 6.0.16
- 6.0.15
- 6.0.14
- 6.0.13
- 6.0.12
- 6.0.11
- 6.0.10
- 6.0.9
- 6.0.8
- 6.0.7
- 6.0.6
- 6.0.5
- 6.0.4
- 6.0.3
- 6.0.2
- 6.0.1
- 6.0.0
- 5.0.44
- 5.0.43
- 5.0.42
- 5.0.41
- 5.0.40
- 5.0.39
- 5.0.38
- 5.0.37
- 5.0.36
- 5.0.35
- 5.0.34
- 5.0.33
- 5.0.32
- 5.0.31
- 5.0.30
- 5.0.29
- 5.0.28
- 5.0.27
- 5.0.26
- 5.0.25
- 5.0.24
- 5.0.23
- 5.0.22
- 5.0.21
- 5.0.20
- 5.0.19
- 5.0.18
- 5.0.17
- 5.0.16
- 5.0.15
- 5.0.14
- 5.0.13
- 5.0.12
- 5.0.11
- 5.0.10
- 5.0.9
- 5.0.8
- 5.0.7
- 5.0.6
- 5.0.5
- 5.0.4
- 5.0.3
- 5.0.2
- 5.0.1
- 5.0.0
- 4.0.x-dev
- 4.0.2
- 4.0.1
- 4.0.0
- 3.0.9
- 3.0.8
- 3.0.7
- 3.0.6
- 3.0.5
- 3.0.4
- 3.0.3
- 3.0.2
- 3.0.1
- 3.0.0
- 2.9.4
- 2.9.3
- 2.9.2
- 2.9.1
- 2.9.0
- 2.8.18
- 2.8.17
- 2.8.16
- 2.8.15
- 2.8.14
- 2.8.13
- 2.8.12
- 2.8.11
- 2.8.10
- 2.8.9
- 2.8.8
- 2.8.7
- 2.8.6
- 2.8.5
- 2.8.4
- 2.8.3
- 2.8.2
- 2.8.1
- 2.8.0
- 2.7.x-dev
- 2.7.30
- 2.7.29
- 2.7.28
- 2.7.27
- 2.7.26
- 2.7.25
- 2.7.24
- 2.7.23
- 2.7.22
- 2.7.21
- 2.7.20
- 2.7.19
- 2.7.18
- 2.7.17
- 2.7.16
- 2.7.15
- 2.7.14
- 2.7.13
- 2.7.12
- 2.7.11
- 2.7.10
- 2.7.9
- 2.7.8
- 2.7.7
- 2.7.6
- 2.7.5
- 2.7.4
- 2.7.3
- 2.7.2
- 2.7.1
- 2.7.0
- 2.6.x-dev
- 2.6.8
- 2.6.7
- 2.6.6
- 2.6.5
- 2.6.4
- 2.6.3
- 2.6.2
- 2.6.1
- 2.6.0
- 2.5.21
- 2.5.20
- 2.5.19
- 2.5.18
- 2.5.17
- 2.5.16
- 2.5.15
- 2.5.14
- 2.5.13
- 2.5.12
- 2.5.11
- 2.5.10
- 2.5.9
- 2.5.8
- 2.5.7
- 2.5.6
- 2.5.5
- 2.5.4
- 2.5.3
- 2.5.2
- 2.5.1
- 2.5.0
- 2.4.34
- 2.4.33
- 2.4.32
- 2.4.31
- 2.4.30
- 2.4.29
- 2.4.28
- 2.4.27
- 2.4.26
- 2.4.25
- 2.4.24
- 2.4.23
- 2.4.22
- 2.4.21
- 2.4.20
- 2.4.19
- 2.4.18
- 2.4.17
- 2.4.16
- 2.4.15
- 2.4.14
- v2.4.13
- v2.4.12
- v2.4.11
- 2.4.10
- 2.4.9
- 2.4.8
- 2.4.7
- 2.4.6
- 2.4.5
- 2.4.4
- 2.4.3
- 2.4.2
- 2.4.1
- 2.4.0
- v2.3.3
- v2.3.2
- v2.3.1
- v2.3.0
- v2.2.8
- v2.2.7
- v2.2.6
- v2.2.5
- v2.2.4
- v2.2.3
- v2.2.2
- v2.2.1
- v2.2.0
- v2.1.13
- v2.1.12
- v2.1.11
- v2.1.10
- v2.1.9
- v2.1.8
- v2.1.7
- v2.1.6
- v2.1.5
- v2.1.4
- v2.1.3
- v2.1.2
- v2.1.1
- v2.1.0
- v2.0.64
- v2.0.63
- v2.0.62
- v2.0.61
- v2.0.60
- v2.0.59
- v2.0.58
- v2.0.57
- v2.0.56
- v2.0.55
- v2.0.54
- v2.0.53
- v2.0.52
- v2.0.51
- v2.0.50
- v2.0.49
- v2.0.48
- v2.0.47
- v2.0.46
- v2.0.45
- v2.0.44
- v2.0.43
- v2.0.42
- v2.0.41
- 2.0.40
- 2.0.39
- 2.0.38
- 2.0.37
- 2.0.36
- 2.0.35
- 2.0.34
- v2.0.33
- v2.0.32
- v2.0.31
- v2.0.30
- v2.0.29
- v2.0.28
- v2.0.27
- v2.0.26
- v2.0.25
- v2.0.24
- v2.0.23
- v2.0.22
- v2.0.21
- v2.0.20
- v2.0.19
- v2.0.18
- v2.0.17
- v2.0.16
- v2.0.15
- v2.0.14
- v2.0.13
- v2.0.12
- v2.0.11
- v2.0.10
- v2.0.9
- v2.0.8
- v2.0.7
- v2.0.6
- v2.0.5
- V2.0.4
- 2.0.3
- 2.0.2
- 2.0.1
- 2.0.0
- 1.8.5
- 1.8.4
- 1.8.3
- 1.8.2
- 1.8.1
- 1.8.0
- dev-claude/update-readme-new-features-uQhHP
This package is auto-updated.
Last update: 2026-03-23 21:18:47 UTC
README
TypiCMS is a modular multilingual content management system built with Laravel. Out of the box you can manage pages, events, news, places, menus, translations, and more.
Table of contents
- Features
- Requirements
- Installation
- Available modules
- Artisan commands
- Change log
- Contributing
- Credits
- Licence
Features
- Multilingual — full support for multiple languages with locale-prefixed URLs
- Modular — install only the modules you need; publish and customize any of them
- Dark mode — the admin panel supports both light and dark themes
- Rich text editing — TipTap editor with support for floating images, tables, YouTube embeds, iframes, and an HTML source view
- Passkey and OTP authentication — secure, passwordless login options for admin users
- Page sections — pages can have multiple content sections, each with its own template
- Nestable pages and menus — drag-and-drop reordering with automatic URI generation
- File management — upload and organize images, documents, and folders with Uppy, image cropping with Cropper.js, and SVG sanitization on upload
- Roles and permissions — fine-grained access control via spatie/laravel-permission
- History log — create, update, delete, online, and offline events are logged and shown in the dashboard
- Vue.js 3 frontend powered by Vite and written in TypeScript
URLs
The CMS manages the following URL patterns:
Modules:
- /en/events/slug-in-english
- /fr/evenements/slug-en-francais
Pages:
- /en/parent-page-slug/subpage-slug/page-slug
- /fr/slug-parent/slug-sous-page/slug-page
Requirements
- PHP 8.4+
- One of the database engines supported by Laravel (MySQL, PostgreSQL, SQLite, SQL Server)
For all server requirements, see the Laravel deployment documentation.
Installation
Via the Laravel installer (recommended)
Install the Laravel installer if you haven't already:
composer global require laravel/installer
Then create a new project:
laravel new mywebsite --using=typicms/base
The installer will prompt you for database credentials and run the full TypiCMS setup automatically.
Via Composer
composer create-project typicms/base mywebsite
cd mywebsite
php artisan typicms:install
Go to http://mywebsite.test/admin and log in.
Assets
Assets are bundled with Vite. Install Bun, then run:
-
Install npm packages:
bun install -
Start the development server:
bun run dev -
Build for production:
bun run prod
Locales configuration
- Set the locales in
config/typicms.php. The first key of this array is the main locale and must match the locale defined inconfig/app.php. - Set
main_locale_in_urlinconfig/typicms.phptotrueorfalsedepending on whether you want the main locale to appear in the URL.
Installation of a module
The following example installs the News module. After these steps, the module will appear in the admin sidebar.
-
Install the module with Composer:
composer require typicms/news -
Add
TypiCMS\Modules\News\Providers\ModuleServiceProvider::class,tobootstrap/providers.php, in the TypiCMS Modules Service Providers section. -
Publish the views and migrations:
php artisan vendor:publish -
Run the database migration:
php artisan migrate
Module scaffolding
To generate a new custom module called Cats:
-
Create the module:
php artisan typicms:create cats -
The module is created in
/Modules/Cats. Customize it as needed. -
Add
TypiCMS\Modules\Cats\Providers\ModuleServiceProvider::class,tobootstrap/providers.php, in the TypiCMS Modules Service Providers section. -
Run the migration:
php artisan migrate
Available modules
Each module can be published to be tracked by git and customized locally.
Pages
Pages are nestable with drag and drop. On a drop, URIs are regenerated and saved in the database. Each translation of a page has its own route. A page can be linked to a module and can have multiple sections, each using its own template.
The admin panel includes a searchable pages tree with keyboard-accessible expand/collapse controls.
Menus
Each menu has nestable entries. An entry can link to a page or a URL, and can optionally link to a specific section of a page.
Render an HTML menu in a Blade file with @menu('menuname').
Projects
Projects have categories. Project URLs follow this pattern: /en/projects/category-slug/project-slug.
Tags
Tags support polymorphic many-to-many relations, so they can be linked to any module. The tag input uses Tom Select.
Events
Events have starting and ending dates.
News
News module.
Contacts
Frontend contact form with admin-side records management. Notifications are sent to the visitor and the webmaster.
Partners
A partner has a logo, website URL, title, and body content.
Files
The file manager lets you upload and organize images, documents, and folders. File uploads use Uppy with drag-and-drop support and a compression step before upload. Images can be cropped using Cropper.js. SVG files are sanitized on upload. Images can be swapped in place from the file manager.
To store original images on a remote service such as Amazon S3 while serving cropped images from local disk, set FILESYSTEM_DRIVER=s3 in your .env file and configure croppa.php accordingly.
Users and roles
Admins can authenticate with a passkey or a one-time password in addition to a standard password. User registration can be enabled in the settings panel (/admin/settings). Roles and permissions are managed with spatie/laravel-permission. Admins can impersonate users.
Blocks
Blocks let you display custom content in your views.
Render a block in Blade with Blocks::render('blockname') or @block('blockname').
Translations
Translations can be managed in the database via the admin panel (/admin/translations).
Retrieve a translation using the standard Laravel helpers: __('Key'), trans('Key'), or @lang('Key').
Sitemap
A sitemap is generated automatically from all published pages. It is available at /sitemap.xml.
Settings
Manage the website title, logo, and other global options in the settings panel.
History
Create, update, delete, online, and offline events are logged in the database. The most recent records are shown on the back-office dashboard.
Artisan commands
Install TypiCMS
php artisan typicms:install
Run the initial migration and seed
php artisan typicms:database
This command is called automatically by typicms:install.
Create a superuser
php artisan typicms:user
Publish a module
To customize a module — for example, to add fields or a relation — publish it:
php artisan typicms:publish <modulename>
This will:
- Publish the module's views and migrations.
- Copy the module source to
/Modules/<Modulename>. - Remove the Composer package with
composer remove typicms/<modulename>.
Once published, the module lives in /Modules/<Modulename> and is tracked by git, so changes are preserved across composer update runs.
Changelog
Please see CHANGELOG for more information on what has changed.
Contributing
Please see CONTRIBUTING for details.
Credits
License
TypiCMS is open-source software licensed under the MIT license.