|Capacity is about to become deprecated, as the mainsite gets prepared to be moved to |
Capacity is a versatile framework which helps you to construct your page by focusing on the content. Your pages will be simple PHP-files which include predefined header and footer. This header/footer layout the page, you only provide the real content and menu structure.
Any normal page just contains:
<?php $page_title = "Page Title"; include "header.inc"; ?> Content of the web page <?php include "footer.inc"; ?>
For each subsite, a site.inc in the toplevel directory of this page, which would be equal to the later documentroot on the server in many cases, may be created. This include is used by the header.inc, it should contain some information about your site, like its name and the email address of the webmaster, this will be used by header/footer to setup the page correct.
An example site.inc would be:
<?php // promote which subdomain we are // we are www.kde.org in this case! $site = "www"; // use new style ;) yeah $templatepath = "newlayout/"; // promote title to use $site_title = i18n_var("K Desktop Environment"); // links in the top bar, right $menuright = array ('family/'=>'Sitemap', 'contact/'=>'Contact Us'); ?>
Even in the site.inc you can already use the i18n-functions, which is important to have the names right on translated pages!
The header.inc does some setup of global vars, even before it includes the site.inc, these are:
$site_root $document_root $url_root $current_relativeurl
$site_root = "../.."
$document_root = "/home/www/sites/www"
$url_root = /sites/www
$current_relativeurl = whatiskde/manifest.php
BE AWARE: In former version of the framework it was common to set the $site_root manually before including the header.inc, this won't work now, as the header.inc will overwrite the $site_root. This should cause no danger, as header.inc should find out the right one, but in the long term, all manual definitions should be removed, the global variables header.inc exports should be used to replace the usage of the old $site_root.
The framework is clever, it will never add trailing slashs to the $site_root, $document_root and $url_root, therefor they can and must always be used like:
$some_url = "$site_root/mycoolpage.php"
You can set some variables to alter the behaviour of the framework, either global in your site.inc or in front of your header.inc inclusion in each .php-files.
Useful variables are:
$site_title = "KDE Foo Site Title";
$page_title = "Page Title";
$showedit = false;
Capacity features online editing and previewing of changes.
You can make and preview changes of existing pages online by clicking on the  link at the bottom of each page. Try it on this page. Then you can download you changes and commit them yourself via SVN, or you can click the link to email a unified diff to the web team.
You can choose among two menu parsers: PlasmaMenu and KDE menu.
PlasmaMenu is controlled by plasmaMenu.inc file located at the root of the site (e.g. http://www.kde.org/plasmaMenu.inc). Only one instance of this file is required and it is included in media/includes/header.inc.
PlasmaMenu supports child menus till one level, i.e. you can add one sub-menu to a parent menu entry.
Category1 Category2 Category3 ======================================= ---------- | Entry1 | -------- | Entry2 > | | Sub1 | | Entry3 | | Sub2 | ---------- --------
To design the structure as displayed above, your plasmaMenu.inc should look like this:
<?php global $plasmaMenu; $plasmaMenu->addMenu("Category1", "/link/to/category1/"); $plasmaMenu->addMenuEntry("Entry1", "/link/to/entry1/"); $plasmaMenu->addMenuEntry("Entry2", "/link/to/entry2/"); $plasmaMenu->addSubMenuEntry("Sub1", "/link/to/sub1/"); $plasmaMenu->addSubMenuEntry("Sub2", "/link/to/sub2/"); $plasmaMenu->addMenuEntry("Entry3", "/link/to/entry3/"); $plasmaMenu->addMenu("Category2", "/link/to/category2/"); /* Category 2 entries */ $plasmaMenu->addMenu("Category3", "/link/to/category3/"); /* Category 3 entries */ ?>
As PlasmaMenu is of click-to-open nature, the category name does not point to the destination page. Instead, the menu parser adds an extra entry having the name as the menu category (see screenshot) that points to your desired location.
The addMenuEntry() and addSubMenuEntry() functions accept 3 arguments:
$plasmaMenu->addMenuEntry("Entry Name", "/link/to/entry", "icon.png");
Here, icon.png is a 16*16 icon located inside the media/images/plasmaMenu folder. Please note that it is recommended to use an icon of width and height not more than 16 pixels to avoid an improper menu layout.
The navigation menu is defined by a number of menu.inc files. They are included by a function in media/includes/classes/class_menu.inc, which is called from media/includes/header.inc. The general menu structure is defined in the menu.inc file of the root directory of each KDE subsite (e.g. http://www.kde.org/menu.inc or http://www.kde.org/areas/kde-ev/menu.inc).
It should look like this:
<?php $this->setName ("KDE Foo Site Title"); $section =& $this->appendSection("Inform"); $section->appendLink("Home",""); $section->appendLink("KDE Home","http://www.kde.org/",false); $section =& $this->appendSection("A Second Menu Section"); $section->appendDir("A Subdirectory","subdirectory"); $section->appendLink("A Single Page","singlepage.php"); ?>
Also you could show a little 16x16 Icon for each menu item.You should give the Icon url as the last argument to the appendDir or appendLink:
<?php $section->appendDir("A Subdirectory","subdirectory", true, false, "icon.png");
in the Above code, first argument is the title of the menu, second argument is the url, third argument defines that if this menu item is relative, forth argument should be True if it links to a directory and last argument is the Icon
To show an Icon with appendDir, just add icon url as the third argument, like this:
$section->appendDir("A Subdirectory","subdirectory", "icon.png");
Each mentioned subdirectory will then also be searched for a menu.inc file to define a submenu (e.g. http://www.kde.org/whatiskde/menu.inc).
The format is similar:
<?php $this->appendDir("A Subsubdirectory","subsubdirectory"); $this->appendLink("A Page in the Subdirectory","singlepage.php"); ?>
The content of subsubdirectories is currently not added to the menu, but this may change in future. If a subdirectory has just the index.php file or a submenu for the subdirectory is not desired, then an empty menu.inc can be added. If the menu.inc is missing, then the subdirectory is be treated like having an empty menu.inc file.
The main headline of a page is defined via $page_title. If a page has several sections with a headline each, <h2> is used for them (<h3> for subsections):
<h2><a name="section1" />Section Headline</h2> <h3>Subsection Headline</h3>
Headlines must never be used to increase the size of a text. Use <b> to make it stick out. The first letters of every word of a headline or link should be capitalized, apart from small words like "a", "to", etc.
To allow better navigation through the site, each <h2> heading should be linked from a quicklinks section on top of the page:
<div id="quicklinks"> [ <a href="section1">Section Headline</a> | <a href="section2">Second Section Headline</a> | <a href="section3">Third Section Headline</a> ] <div>
If you wish to link <h3> headlines as well, then you can use:
<div id="quicklinks"> <p> <b><a href="section1">Section Headline</a></b>: <br />; [ <a href="section11">Subsection Headline</a> | <a href="section21">Second Subsection Headline</a> | <a href="section31">Third Subsection Headline</a> ] </p> <p> <b><a href="section2">Second Section Headline</a></b>: <br /> [ <a href="section21">Subsection Headline</a> ] </p> </div>
Each site can have it's own right-side header-logo, like http://conference2006.kde.org. You just need to add a site.png to the top-level directory of your site, the framework will add it automatically if it finds one. Look at for the correct dimensions. While a transparent background would be preferred, atm the Internet Explorer has problems with transparent PNGs, and GIFs are (were) problematic because of patents. Therefore the background needs atm to be duplicated in the image like done for the conference site.
The kde_general_news() can be used to easily show a new story on a page.
<?php kde_general_news($file, $items, $summaryonly) ?>
The parameters of kde_general_news() are as follows:
A PHP class has been written to make it easy to write FAQs. It will always give a consistent formatting style. Using the class is simple:
<?php $faq = new FAQ(); $faq->addQuestion("This is the text of the question", "This is the text of the answer"); $faq->show(); ?>
Note: the page won't be rendered until you call show(). Please use this class rather than hand constructing a FAQ to save your time and to improve consistency.
A PHP class has been written to make it easy to write image galleries. The image galleries can link to enlarged versions of the image, but this isn't compulsory. Using the class is simple:
|If you want to have a fancy Image Gallery with Lightbox, pass True as the second argument to the imageGallery class.|
<?php $gallery = new ImageGallery("Add a summary for screen readers here"); $gallery->addImage("pics/image_sm.png", "pics/image.png", "640", "480", "Alt text", "Image caption (top)", "Image description (bottom)"); $gallery->startNewRow(); $gallery->addImage("pics/image_sm.png", 0, "640", "480", "Alt text", "Image caption (top)", "Image description (bottom)"); $gallery->show(); ?>
The first call to addImage() creates an image that can be clicked on to link to a larger version of the image. startNewRow() creates a new row. The second call to addImage() creates an image that isn't clickable (note the 0 rather than the URL to the large image).
The parameters of addImage() are as follows
addImage($src_url, $dest_url, $width_pixels, $height_pixels, $alt_text, $caption_text, $description_text)
Please use this class rather than hand constructing an image gallery to save your time and to improve consistency.
For web sites like koffice.org and edu.kde.org it makes sense to have a sub-directory for each program that is part of the project and in that sub-directory have a page which shows information about the program. The AppInfo class has been designed to make it easy to create such a page. It can be used as follows:
<?php $appinfo = new AppInfo("KWord"); $appinfo->setIcon( "pics/hi48-app-kword.png", "48", "48"); $appinfo->setVersion($kwordversion); $appinfo->setLicense("lgpl"); $appinfo->setCopyright("1998", "the KWord Team"); $appinfo->addAuthor("Reginald Stadlbauer", "firstname.lastname@example.org"); $appinfo->addAuthor("Torben Weis", "email@example.com"); $appinfo->addContributor("David Faure", "firstname.lastname@example.org"); $appinfo->addContributor("Thomas Zander", "email@example.com"); $appinfo->addContributor("Shaheed Haque", "firstname.lastname@example.org"); $appinfo->addContributor("Laurent Montel", "email@example.com"); $appinfo->addContributor("Sven Lüppken", "firstname.lastname@example.org"); $appinfo->show(); ?>
The second and third parameters of setIcon() are the width and height of the icon. The addContributor() function can take an optional third parameter, a short description of the person's function in the project.
When converting pages, it is important to keep a few common mistakes in mind: Every page must have $page_title set to ensure correct rendering on all styles. This also means that the original heading must be removed. Otherwise the headline will be duplicated when setting $page_title.
All sites use a custom 404 handler page which is written in PHP. The handler is implemented in the Handler404 class. It has these features:
For pages which have changed location, a custom mapping can be added in www/media/404.php so that the user can be directed to just about anywhere.
<?php include("handler.inc"); $handler = new Handler404(); $handler->add("/faq.html", "/faq"); $handler->add("/events.html", "http://events.kde.org/"); $handler->execute(); ?>
You must call execute() otherwise it won't work!
English words like "search" are not useful for pages like e.g. german.
Create a file named "locale.inc" in root folder and use the following content:
<?php $site_locale = "de"; ?>
Please adjust the abbreviation to your needs.
Now the caption "Search" becomes german "Suche".
If you want to translate random text of your web page you have to use one of the three i18n functions available, that is i18n(), i18n_var() and i18n_noop().
<p><?php i18n("Some images of Okular in action...")?></p>
<?php $site_title = i18n_var("Okular - more than a reader"); ?></p>
<?php $page_title = i18n_noop('Frequently Asked Questions'); ?></p>
If you want to show a language selector in your webpage you have to define the site_languages variable to hold the supported languages.
<?php $site_languages = array('en', 'es', 'pt_BR', 'uk'); ?></p>