Waterhole features a simple and adaptable design that you can customize and integrate with your brand.
Waterhole's design system makes heavy use of CSS variables and classes, both of which you can override and extend.
New Waterhole projects are already hooked up with a file where you can place custom CSS: resources/css/waterhole/app.css
. Add your CSS to this file and it will be concatenated onto the end of the main stylesheet bundle.
For example, you can change the accent color of your forum by overriding the --palette-accent-*
variables (from which the accent color variables are derived):
:root {
--palette-accent-h: 250;
--palette-accent-s: 93%;
--palette-accent-l: 58%;
}
Tip: If debug mode is turned off, Waterhole will cache the stylesheet bundle and changes will not be picked up. Run
php artisan waterhole:cache:clear
to flush the cache.
Use your browser's dev tools to inspect elements and their classes and styles to help target your customizations. If you find you're not able to target a specific element reliably, feel free to report a bug and suggest any missing classes.
You are free to set up a CSS preprocessor (like Sass, LESS, or PostCSS) in your project to compile your custom CSS before it is added to the Waterhole bundle.
Note that you cannot remove any of Waterhole's base CSS – you can only build on top of it. This is to make sure that as Waterhole is updated to newer versions with new or changed UI, there are always base styles available to display it properly.
Waterhole features a user Dark Mode toggle button in the header. To target changes to CSS variables and classes specifically to light or dark mode, put them within a [data-theme]
selector:
[data-theme='light'] {
/* light mode customizations */
}
[data-theme='dark'] {
/* dark mode customizations */
}
If you don't want to support Dark Mode on your forum, you can disable the toggle completely by setting theme
to either light
or dark
in config/waterhole/design.php
.
Waterhole's HTML is server-rended using Blade views and components. Many parts of Waterhole's templates render dynamic lists of components. For example, the page header is made up of these components:
^^^
{width=850 height=120}
^^^ The header is made up of an ordered list of components: title
, spacer
, search
, notifications
, user
, and theme
.
Using extenders, you can hook into these component lists and add your own components at any position, and replace or remove existing ones. Some common examples are listed below. To learn more about how component lists work, see the Frontend page.
To customize the forum title in the header (for example, to add your logo), use the Header
extender to replace the default title
component. Add the following to the extend
method of app/Providers/WaterholeServiceProvider.php
:
Extend\Header::replace(key: 'title', content: 'waterhole.title');
The corresponding view is located at resources/views/waterhole/title.blade.php
. You can put whatever you want in here – for example, to display an SVG logo:
<a href="{{ route('waterhole.home') }}" class="row">
<svg width="30" height="30">
<title>Acme Inc.</title>
<circle cx="15" cy="15" r="15"/>
</svg>
</a>
Tip: If you're embedding an
<svg>
like in the example above, it's important to add a<title>
alternative for screen reader users.
To add custom HTML inside the <head>
tag, use the DocumentHead
extender. Add the following to the extend
method of app/Providers/WaterholeServiceProvider.php
:
Extend\DocumentHead::add('waterhole.head');
This refers to a view located at resources/views/waterhole/head.blade.php
.
To add a custom site header above Waterhole's header, use the LayoutBefore
extender. Add the following to the extend
method of app/Providers/WaterholeServiceProvider.php
:
Extend\LayoutBefore::add('partials.header', position: -10);
This refers to a view located at resources/views/partials/header.blade.php
. We also pass a negative position
parameter to insert our custom header before Waterhole's header.
You can add a "hero" to your forum's index page to welcome users to your community. Add the following to the extend
method of app/Providers/WaterholeServiceProvider.php
:
Extend\LayoutBefore::add('waterhole.hero');
Your resources/views/waterhole/hero.blade.php
template might look something like this. The @if
conditional will make sure it only renders on the index page:
@if (Request::routeIs('waterhole.home', 'waterhole.channels.show'))
<section class="section container row justify-center text-center">
<p class="measure lead">
Welcome to my community! Please take a look around.
</p>
</section>
@endif
You can add a global footer with copyright information and links. Add the following to the extend
method of app/Providers/WaterholeServiceProvider.php
:
Extend\Footer::add('waterhole.footer');
Your resources/views/waterhole/footer.blade.php
template might look something like this:
<footer class="section container text-center">
© {{ date('Y') }} Acme Inc.
</footer>
Take a look at all of the extenders that are available under the Waterhole\Extend
namespace.