Skip to content

Commit

Permalink
Update README.md
Browse files Browse the repository at this point in the history
  • Loading branch information
BernhardBaumrock authored Mar 18, 2024
1 parent 666ad3a commit fdf0221
Showing 1 changed file with 20 additions and 170 deletions.
190 changes: 20 additions & 170 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,193 +4,43 @@ Also see [AdminStyleHello](https://github.com/baumrock/AdminStyleHello)

Easily style your ProcessWire backend with two simple settings:

![img](https://i.imgur.com/ETCC1CA.png)
- Primary Color
- Logo File or Url

Or via RockMigrations:
That makes it very easy to make the PW backend match the CI of your clients:

```php
$rm->installModule("AdminStyleRock", [
'rockprimary' => '#0069B4',
'logo' => '/site/templates/img/kollar.svg',
]);
```

## Why does this module exist?

1. It provides docs for the rock style
2. It helps developing and maintaining the rock style
3. It might serve as an example how to share your own styles with the community in a modular way instead of sharing admin.less files that can't be updated/monitored by the PW upgrades module.

This means you can submit issues or pull requests to this repository and I can check them easily. Once we have an improved version of the rock style we can as Ryan to pull the changes into the PW Core.

For discussion head over to the support forum thread: https://processwire.com/talk/topic/25668-adminthemeuikit-rock-style/
<img src=https://i.imgur.com/3nEvy8I.png width=500>
<img src=https://i.imgur.com/zlHyoii.png width=500>
<img src=https://i.imgur.com/mPrnwIb.png width=500>

Also be sure to read the blog post about the [new Uikit admin theme customization options](https://processwire.com/blog/posts/pw-3.0.179/) that indroduced and explains the foundation for this module.
## Installation

## How does the module work and what does it do?

When installed, the module sets the `style` property of your $config->AdminThemeUikit array to the rock style that lives inside this repository (not the core version). You could of course simply do that in config.php but the module approach has a benefit: It does also monitor the new file and recompiles automatically whenever something changes. In addition, it also creates a minified version of the admin theme if `$config->debug` is turned OFF and an unminified version if debug mode is ON.

![img](hr.svg)
Just install the module from the backend, choose a color and you are ready to rock! 🚀

## Wording: THEME vs. STYLE

* THEME: When we talk about a PW admin THEME we mean the stylesheet plus all the PHP files that create the markup and business logic.
* STYLE: A style on the other hand (like the rock or reno style) does only modify the look and feel via changing LESS variables or overwriting CSS

![img](hr.svg)

## How AdminThemeUikit styles work

AdminThemeUikit uses UIkit as CSS framework. See https://getuikit.com/ docs (especially https://getuikit.com/docs/less) to get familiar with UIkit. It then adds several customizations to that CSS via less files that are located in the folder `uikit-pw` ([see files on github](https://github.com/processwire/processwire/tree/dev/wire/modules/AdminTheme/AdminThemeUikit/uikit-pw)).

The base style that is used for all styles (reno or rock or any other) is `pw.less` and you can even use the base style without any customizations if you want!

## Creating your own styles

Creating your own styles is as simple as writing CSS/LESS. You just need to tell ProcessWire to use a different style than the default one:

### 1. Set config

The `style` property can not only take one of the two core style names (reno or rock) but also a path to a less file. This means we can build a custom style easily and simply point the config to that style:

```php
$config->AdminThemeUikit = [
// point to the new style
'style' => '/path/to/your/style.less',

// recompile on every page load during development
'recompile' => true,

// dont minify the resulting css to make it easier to debug
'compress' => false,
];
```
## Customizations

Usually you'd put that directly into `site/config.php`. But to save you from copy&pasting and make it easier for me to load my style into my projects via GIT submodules I created a little autoload module that does the same in the `init()` method. See [AdminStyleRock.module.php](https://github.com/baumrock/AdminStyleRock/blob/main/AdminStyleRock.module.php) how that is done.
You can modify any aspect of your style with CSS/LESS simply by creating and modifying `/site/templates/admin.less`. ProcessWire will automatically recompile all files for you without the need of installing any external dependencies or tools like NPM.

### 2. Create a LESS file for your new style
You can change any of UIkits LESS variables or you can overwrite all classes with your own css rules:

Now create the style file that you set in the config. Start with an empty file with a single comment like this:
```less
// change the global font size of the backend
@global-font-size: 30px;

```LESS
/* ##### Admin Style Rock ##### */
```

Now reload your backend and you should see the base style of AdminThemeUikit without the changes that are applied by either reno or rock theme. You'll notice that it looks very similar to the default uikit theme:

![img](https://i.imgur.com/AiKZnvS.png)

That's it - you have built your first PW admin style!

If you look at the compiled CSS file (`site/assets/admin.css` by default) you'll see that the admin theme has over 16k lines of css and after that it adds the CSS of your style and after that it adds the CSS of `admin.less`.

![img](https://i.imgur.com/DKcQlcv.png)

Now you can start adding customizations/optimizations to your style.

# Example customizations

### Tweak PW notices

PW base style notifications look like this:

![img](https://i.imgur.com/f345nL6.png)

As you can see there are some margins that we don't want. We add the following line to our style:

```LESS
.pw-notices {
margin-top: 1px;
> li {
margin: 1px;
}
// custom css overrides
p.notes {
border: 2px solid red;
}
```

![img](https://i.imgur.com/H1oWg42.png)

### Tweak page edit tabs

PW base style page editor tabs look like this:

![img](https://i.imgur.com/38hDjNm.png)

Add this line to your style to remove the paddings:

```LESS
.uk-tab>* { padding-left: 0; }
```

![img](https://i.imgur.com/O0BeYIy.png)

### Changing UIkit variables

You can change any of uikit's less variables in your style. UIkit themes are built in components. See https://github.com/uikit/uikit/blob/develop/src/less/components/base.less as an example. Also check if your IDE has plugins to scan your project for LESS variables. I'm using VSCode + https://marketplace.visualstudio.com/items?itemName=mrmlnc.vscode-less

![img](https://i.imgur.com/fZoSm7W.png)

#### Changing fonts

Thanks to UIkit it is easy to change the base font. For this example we'll use https://fonts.google.com/specimen/Sigmar+One. All we need to do is to add the font to the styles array of PW:

```php
$config->styles->add('https://fonts.googleapis.com/css2?family=Sigmar+One&display=swap');
```

IMPORTANT: For production you might want to download the font instead of adding it via google fonts to comply with GDPR!

Next, we set the correct UIkit variable - so add this to your style:

```LESS
@global-font-family: 'Sigmar One', cursive;
```

Once reloaded you'll get a totally different look of your PW backend:

![img](https://i.imgur.com/cllilIV.png)

#### Changing colors

Changing colors is a little more complicated. I'll demonstrate why. First, we change the uikit primary background variable:

```LESS
@global-primary-background: #610088;
```

![img](https://i.imgur.com/zmxNU72.png)

Did you notice something in the screenshot? Links and hover colors are still the default blue. Same goes for the page tree:

![img](https://i.imgur.com/5N3i964.png)

So if we wanted to get a consistent color change we'd need to set more variables - actually a lot more and some of them are quite hidden, for example buttons of VEX dialogs that you'd likely miss to change if you needed to make all these changes every time you want to change the main color of your style. That's where the "rock" style comes into play!

![img](hr.svg)

# The "rock" style

The goal of the rock style is to make it as easy as possible to adapt your backend to the CI of your client. That's why it uses only ONE single main color (`@rock-primary`) and keeps all other design elements in a neutral grey.

Now try changing the main color of the rock style by setting your config to use the rock style and then adding these two lines to `admin.less`:

```LESS
@rock-primary: #610088;
@global-font-family: 'Sigmar One', cursive;
```

![img](https://i.imgur.com/fxLJzk2.png)

This will even change selection background:

![img](https://i.imgur.com/OvD2kAh.png)

Note that the global font family is not a `@rock-` variable because it would only change one single uikit less variable anyhow while `@rock-primary` changes many. To avoid confusion I think it is the best to introduce new variables only if they didn't exist or if they changed multiple uikit variables at once.

![img](hr.svg)
The result is obviously ugly but it shows what you can do 😅

# Contribution
<img width="500" alt="image" src="https://github.com/baumrock/AdminStyleRock/assets/8488586/5673e66c-6d06-4564-aed6-1cf1c1cd1899">

**If you find any spots where the rock style sould change additional colors or tweak paddings or margins please let me know!** You can simply create issues or pull requests in this repository.

Once the changes are tested and approved I can ask Ryan to pull the changes into the core.
If you want to create your own AdminStyle module please see [info.md](info.md)

0 comments on commit fdf0221

Please sign in to comment.