154 lines
		
	
	
	
		
			6.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			154 lines
		
	
	
	
		
			6.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
# Themes
 | 
						|
 | 
						|
* [Home](help)
 | 
						|
 | 
						|
To change the look of friendica you have to touch the themes.
 | 
						|
The current default theme is [Vier](https://github.com/friendica/friendica/tree/stable/view/theme/vier) but there are numerous others.
 | 
						|
Have a look at [github.com/bkil/friendica-themes](https://github.com/bkil/friendica-themes) for an overview of the existing themes.
 | 
						|
In case none of them suits your needs, there are several ways to change a theme.
 | 
						|
 | 
						|
So, how to work on the UI of friendica.
 | 
						|
 | 
						|
You can either directly edit an existing theme.
 | 
						|
But you might loose your changes when the theme is updated by the friendica team.
 | 
						|
 | 
						|
If you are almost happy with an existing theme, the easiest way to cover your needs is to create a new theme, inheritating most of the properties of the parent theme and change just minor stuff.
 | 
						|
The below for a more detailed description of theme heritage.
 | 
						|
 | 
						|
Some themes also allow users to select *variants* of the theme.
 | 
						|
Those theme variants most often contain an additional [CSS](https://en.wikipedia.org/wiki/CSS) file to override some styling of the default theme values.
 | 
						|
From the themes in the main repository *vier* and *vier* are using this methods for variations.
 | 
						|
Quattro is using a slightly different approach.
 | 
						|
 | 
						|
Third you can start your theme from scratch.
 | 
						|
Which is the most complex way to change friendicas look.
 | 
						|
But it leaves you the most freedom.
 | 
						|
So below for a *detailed* description and the meaning of some special files.
 | 
						|
 | 
						|
### Styling
 | 
						|
 | 
						|
If you want to change the styling of a theme, have a look at the themes CSS file.
 | 
						|
In most cases, you can found these in
 | 
						|
 | 
						|
    /view/theme/**your-theme-name**/style.css
 | 
						|
 | 
						|
sometimes, there is also a file called style.php in the theme directory.
 | 
						|
This is only needed if the theme allows the user to change certain things of the theme dynamically.
 | 
						|
Say the font size or set a background image.
 | 
						|
 | 
						|
### Templates
 | 
						|
 | 
						|
If you want to change the structure of the theme, you need to change the templates used by the theme.
 | 
						|
Friendica themes are using [SMARTY3](http://www.smarty.net/) for templating.
 | 
						|
The default template can be found in
 | 
						|
 | 
						|
    /view/templates
 | 
						|
 | 
						|
if you want to override any template within your theme create your version of the template in
 | 
						|
 | 
						|
    /view/theme/**your-theme-name**/templates
 | 
						|
 | 
						|
any template that exists there will be used instead of the default one.
 | 
						|
 | 
						|
### Javascript
 | 
						|
 | 
						|
The same rule applies to the JavaScript files found in
 | 
						|
 | 
						|
    /js
 | 
						|
 | 
						|
they will be overwritten by files in
 | 
						|
 | 
						|
    /view/theme/**your-theme-name**/js.
 | 
						|
 | 
						|
## Creating a Theme from Scratch
 | 
						|
 | 
						|
Keep patient.
 | 
						|
Basically what you have to do is identify which template you have to change so it looks more like what you want.
 | 
						|
Adopt the CSS of the theme accordingly.
 | 
						|
And iterate the process until you have the theme the way you want it.
 | 
						|
 | 
						|
*Use the source Luke.* and don't hesitate to ask in @[developers](https://forum.friendi.ca/profile/developers) or @[helpers](https://forum.friendi.ca/profile/helpers).
 | 
						|
 | 
						|
## Special Files
 | 
						|
 | 
						|
### unsupported
 | 
						|
 | 
						|
If a file with this name (which might be empty) exists in the theme directory, the theme is marked as *unsupported*.
 | 
						|
An unsupported theme may not be selected by a user in the settings.
 | 
						|
Users who are already using it wont notice anything.
 | 
						|
 | 
						|
### README(.md)
 | 
						|
 | 
						|
The contents of this file, with or without the .md which indicates [Markdown](https://daringfireball.net/projects/markdown/) syntax, will be displayed at most repository hosting services and in the theme page within the admin panel of friendica.
 | 
						|
 | 
						|
This file should contain information you want to let others know about your theme.
 | 
						|
 | 
						|
### screenshot.[png|jpg]
 | 
						|
 | 
						|
If you want to have a preview image of your theme displayed in the settings you should take a screenshot and save it with this name.
 | 
						|
Supported formats are PNG and JPEG.
 | 
						|
 | 
						|
### theme.php
 | 
						|
 | 
						|
This is the main definition file of the theme.
 | 
						|
In the header of that file, some meta information is stored.
 | 
						|
For example, have a look at the theme.php of the *vier* theme:
 | 
						|
 | 
						|
    <?php
 | 
						|
    /**
 | 
						|
     * [Licence]
 | 
						|
     *
 | 
						|
     * Name: Vier
 | 
						|
     * Version: 1.2
 | 
						|
     * Author: Fabio <http://kirgroup.com/profile/fabrixxm>
 | 
						|
     * Author: Ike <http://pirati.ca/profile/heluecht>
 | 
						|
     * Author: Beanow <https://fc.oscp.info/profile/beanow>
 | 
						|
     * Maintainer: Ike <http://pirati.ca/profile/heluecht>
 | 
						|
     * Description: "Vier" is a very compact and modern theme. It uses the font awesome font library: http://fortawesome.github.com/Font-Awesome/
 | 
						|
     */
 | 
						|
 | 
						|
You see the definition of the theme's name, it's version and the initial author of the theme.
 | 
						|
These three pieces of information should be listed.
 | 
						|
If the original author is no longer working on the theme, but a maintainer has taken over, the maintainer should be listed as well.
 | 
						|
The information from the theme header will be displayed in the admin panel.
 | 
						|
 | 
						|
The first thing in file is to import the `App` class from `\Friendica\` namespace.
 | 
						|
 | 
						|
    use Friendica\App;
 | 
						|
 | 
						|
This will make our job a little easier, as we don't have to specify the full name every time we need to use the `App` class.
 | 
						|
 | 
						|
The next crucial part of the theme.php file is a definition of an init function.
 | 
						|
The name of the function is <theme-name>_init.
 | 
						|
So in the case of vier it is
 | 
						|
 | 
						|
    function vier_init(App $a) {
 | 
						|
		$a->theme_info = array();
 | 
						|
		$a->set_template_engine('smarty3');
 | 
						|
    }
 | 
						|
 | 
						|
Here we have set the basic theme information, in this case they are empty.
 | 
						|
But the array needs to be set.
 | 
						|
And we have set the template engine that should be used by friendica for this theme.
 | 
						|
At the moment you should use the *smarty3* engine.
 | 
						|
There once was a friendica specific templating engine as well but that is not used anymore.
 | 
						|
If you like to use another templating engine, please implement it.
 | 
						|
 | 
						|
If you want to add something to the HTML header of the theme, one way to do so is by adding it to the theme.php file.
 | 
						|
To do so, add something alike
 | 
						|
 | 
						|
    DI::page()['htmlhead'] .= <<< EOT
 | 
						|
    /* stuff you want to add to the header */
 | 
						|
    EOT;
 | 
						|
 | 
						|
So you can access the properties of this friendica session from the theme.php file as well.
 | 
						|
 | 
						|
### default.php
 | 
						|
 | 
						|
This file covers the structure of the underlying HTML layout.
 | 
						|
The default file is in
 | 
						|
 | 
						|
    /view/default.php
 | 
						|
 | 
						|
if you want to change it, say adding a 4th column for banners of your favourite FLOSS projects, place a new default.php file in your theme directory.
 | 
						|
As with the theme.php file, you can use the properties of the $a variable with holds the friendica application to decide what content is displayed.
 |