diff options
author | marijus <mario@localhost.localdomain> | 2013-11-21 21:42:35 +0100 |
---|---|---|
committer | marijus <mario@localhost.localdomain> | 2013-11-21 21:42:35 +0100 |
commit | ad353e9e7d4e2d09532218cc7d2111724ec969d6 (patch) | |
tree | 7cc5fdfa373f3041bc5696161dc3529d1ff33e7e | |
parent | 1f9ef3e44d28c3b8507fed8c6e9841ae49c9461f (diff) | |
parent | b170d8047153a9c9f0f0f16d39e0ecb45d17b0b6 (diff) | |
download | volse-hubzilla-ad353e9e7d4e2d09532218cc7d2111724ec969d6.tar.gz volse-hubzilla-ad353e9e7d4e2d09532218cc7d2111724ec969d6.tar.bz2 volse-hubzilla-ad353e9e7d4e2d09532218cc7d2111724ec969d6.zip |
Merge branch 'master' of https://github.com/friendica/red
-rw-r--r-- | doc/Home.md | 1 | ||||
-rw-r--r-- | doc/Schema-development.md | 76 |
2 files changed, 77 insertions, 0 deletions
diff --git a/doc/Home.md b/doc/Home.md index 307c24229..4a37e6c82 100644 --- a/doc/Home.md +++ b/doc/Home.md @@ -19,6 +19,7 @@ Red Matrix Documentation and Resources * [Install](help/Install) * [Comanche Page Descriptions](help/Comanche) * [Plugins](help/Plugins) +* [Schemas](help/Schema-development) * [Developers](help/Developers) * [Intro for Developers](help/Intro-for-Developers) * [API functions](help/api_functions) diff --git a/doc/Schema-development.md b/doc/Schema-development.md new file mode 100644 index 000000000..415c68efa --- /dev/null +++ b/doc/Schema-development.md @@ -0,0 +1,76 @@ +Red development - a guide to the schema system +============================================== + + +A schema, in a nutshell, is a collection of settings for a bunch of variables to define +certain elements of a theme. A schema is loaded as though it were part of config.php +and has access to all the same information. Importantly, this means it is identity aware, +and can be used to do some interesting things. One could, for example, restrict options +by service class, or present different options to different users. + +By default, we filter only by whether or not expert mode is enabled. If expert mode is +enabled, all options are presented to the user. If it is not, only scheme, background +image, font face, and iconset are available as choices. + +A schema is loaded *after* the user settings. Therefore, to allow a user to overwrite a +particular aspect of a schmea you would use the following syntax: + + if (! $foo) + $foo = 'bar'; + +However, there are circumstances - particularly with positional elements - where it +may be desirable (or necessary) to override a users settings. In this case, the syntax +is even simpler: + + $foo = 'bar'; + +Users will not thank you for this, however, so only use it when it is required. + +If no user options are set, and no schema is selected, we will first try to load a schema +with the file name "default.php". This file should never be included with a theme. If it +is, merge conflicts will occur as people update their code. Rather, this should be defined +by administrators on a site by site basis. + +You schema does not need to - and should not - contain all of these values. Only the values +that differ from the defaults should be listed. This gives you some very powerful options +with very few lines of code. + +Note the options available differ with each theme. The options available with the Redbasic +theme are as follows: + +* nav_colour + The colour of the navigation bar. Options are red, black and silver. Alternatively, + one can set $nav_bg_1, $nav_bg_2, $nav_bg_3 and $nav_bg_4 to provide gradient and + hover effects. +* banner_colour + The font colour of the banner element. Accepts an RGB or Hex value. +* bgcolour + Set the body background colour. Accepts an RGB or Hex value. +* background_image + Sets a background image. Accepts a URL or path. +* item_colour + Set the background colour of items. Accepts an RGB or Hex value. +* item_opacity + Set the opacity of items. Accepts a value from 0.01 to 1 +* toolicon_colour + Set the colour of tool icons. Accepts an RGB or Hex value. +* toolicon_activecolour + Set the colour of active or hovered icon tools. +* font_size + Set the size of fonts in items and posts. Accepts px or em. +* body_font_size + Sets the size of fonts at the body level. Accepts px or em. +* font_colour + Sets the font colour. Accepts an RGB or Hex value. +* radius + Set the radius of corners. Accepts a numeral, and is always in px. +* shadow + Set the size of shadows shown with inline images. Accepts a numerical + value. Note shadows are not applied to smileys. +* converse_width + Set the maximum width of conversations. Accepts px, or %. +* nav_min_opacity +* top_photo +* reply_photo +* sloppy_photos + Determins whether photos are "sloppy" or aligned. Set or unset (1 or '') |