Thứ Tư, 22 tháng 5, 2013

J3.1:What's new in Joomla!


his page lists enhancements and features added to the current version of Joomla! If you are logged into the Joomla! Docs wiki, you can watch this page for changes and updates as version enhancements are released. Just click the 'star' icon at the top to add this page to your watch list.

Joomla 3.1

Content Tags

Other enhancements

Miscellaneous

Joomla 3.0

The following information below is from the Joomla! 3 Introduction site.

Mobile Ready

Joomla! takes a big leap into the mobile space with a total overhaul of both its frontend design and administrator interface. With the adoption of the Bootstrap framework, Joomla! has become the first major CMS to be mobile ready in both the visitors and administrator areas. Now every website can have mobile friendly content for visitors and mobile friendly tools for administrators.
  • Fully Responsive Site Template
  • Fully Responsive Admin UI
  • Fully Responsive Core Output

User Friendly

Joomla administration has a brand new look and feel, built with the power of Bootstrap responsive framework, along with a touch of the awesome UI/UX work of the Joomla JUX team. Joomla comes ready to go and fully responsive for mobile devices, tablets, and normal computer screens. The entire backend of Joomla has a brand new look and feel that will improve your workflow with any type of device.
  • New User Friendly Interface
  • Streamlined 30 Second Install
  • Refined Admin User Experience

Developer Tools

Spend less time coding and building interfaces with Joomla 3. The Joomla User Interface (JUI) library gives you a standardized backend & frontend interface via CSS and Javascript Frameworks. LESS CSS and jQuery means you can write less code and the Icomoon font icon library provides a wealth of retina-optimized icons.
  • Build a Component with Zero CSS
  • Style a Site with 1 CSS File
  • Icomoon Font Icon
  • jQuery & Mootools

Whole Lot More

Joomla 3.0 is a whole new exciting world. We took a little from the top, bottom, and side to create a whole brand new look and feel, along with many features under the hood features that bring Joomla to the forefront of the content management system world.
  • Extensive work on code style standardisation and consistency
  • Incorporation of Bootstrap into a jui media package.
  • A new responsive administrator template Isis and interface.
  • A new frontend template Protostar built using Bootstrap and updated accessible template called Beez3
  • PostgreSQL Driver. You will be able to run Joomla 3.0 sites using the PostgreSQL database.
  • PHP Memcached Driver
  • Use of JFeed for feed management rather than SimplePie
  • Installation of language packages directly from the extension manager
  • Guest user group present by default
  • Saving blank articles allowed
  • New administrator statistics module
  • Update TinyMCE to version 3.5.6
  • Continued clean up of older unused code, files and database fields and tables and improved standardization of tables.
  • Improvements to Smart Search
  • Unit testing in the CMS
  • Updated system tests in the CMS

See the Demo of Joomla! 3.0

Test drive the demo site of Joomla! 3.0. Username: demo - Password: demo

Thứ Hai, 20 tháng 5, 2013

Start Creating Your Joomla! Site


Now you're ready to start making your own articles, weblinks, contacts, banners, and newsfeeds. Before you jump into doing this you may want to review Planning Your Web site. Or if you want to convert your current website to Joomla!, read Converting an existing website to a Joomla! website.
Before you do anything else, you should decide if you want to enable Search Engine Friendly URLs (described here). Enabling or disabling them later will destroy the rankings your pages will have acquired with search engines.
One of the first tasks you may want to do is to modify one of the templates that comes with Joomla! so that it displays your site name and logo.
  • How to replace the logo image in the Milkyway template Scribd by deckers.olivier
  • How to modify the default Template Scribd (Note: the document is an old version and some practices and advice may not be current.) by Chad Windnagle (drmmr763).
Finally, you may want to install one or more of the thousands of extensions to Joomla!. Most Joomla! extensions are listed in the official Joomla Extensions Directory (JED). Once you've found an extension to install, Installing an extension will tell you how to install it.
Please remember that all extensions are developed by independent developers. If you need help with a specific extension the best source will be that developer.
For help visit:
  • New to Joomla!/General Joomla! v 1.5 Questions
  • Joomla! v 1.5 Template Questions
  • Joomla! v 1.5 Extension Questions
  • Joomla! Extension Directory Questions

Installing Joomla!


There are several ways to install Joomla!.
If you want to test Joomla! and you haven't purchased a domain yet, you can install Joomla! on your own computer (without your site appearing on the Internet), you can install it using the XAMPP package. You can also create a working website at demo.joomla.org, which is easy and well-supported.
If you want your site to be available on the Internet, make sure that you have an account on a web server. For most people this means signing up with a hosting company and purchasing a domain that will serve as your site's main address.
  • Option One: One Click Installs. Many hosting companies offer "instant" installation of Joomla!. Follow the instructions your host provides for a one click install.
  • Option Two: Conventional Installs. This method requires that you copy the Joomla! zip file to your hosting account, unzip, create a database, and then run the installation. Complete instructions can be found in Installation for Joomla 2.5 and Installation for Joomla 3.x and further information atJoomla! Installation Resources. This video takes you through the steps.
  • Option Three: Demo Site. If you used the Demo Site, you can follow the instructions provided to back up and move the site to your existing host or establish a hosting account at the end of the free 30 day trial. (Note that the Joomla! Project receives a royalty if you choose paid hosting from that site.)
For support with installation, you can ask questions in the installation forum.

Learning to Use Joomla!


Now that you have a working Joomla! site, you will want to start filling it with your own content and making it look just the way you want. Before doing that, it is a good idea to learn more about how to work with Joomla!. There are a number of very useful resources to help you with this.
One way is to learn by working with the sample data.
There is also a very nice beginners visual guide to getting started with Joomla! 1.5 here: Learn Joomla! 1.5 Fast! Scribd (PDF 1.3Mb) written by Saurabh Bhide.
The Joomla! v 1.5 Quick Start Guide Scribd, written by Kevin Hayne. As you read the guide, walk through the video accompaniment created by Michael Casha.
For support as you are learning, you can ask questions in the forums.
  • New to Joomla 1.5! forum for Joomla! Joomla 1.5
  • New to Joomla 2.5! forum for Joomla! Joomla 2.5
The Joomla! Demo site is a good place to try out many of these features if you have not yet done an installation.

JomSocial VS Joomla Template



Let's clarify a few things first. By analogy, the Joomla Platform is an operating system and the JomSocial component is the application in Joomla. JomSocial is a Joomla component. In Joomla, there can only be one component displayed at a time.

Now, let's talk about the Joomla template. Joomla's templates can be found in Joomla's Backend (Extensions > Template Manager). You can change the Joomla template and it won't change the "look and feel" of the JomSocial component.
Template joomvsjos 01.jpg

Position of the JomSocial Component in Joomla

So some of you might be wondering, "where is the position of the JomSocial component placed in Joomla?" To answer that question, please open templates\[template_name]\index.php found in your Joomla directory.
The line responsible for displaying JomSocial is:

  1. <jdoc:include type="component" />


Thứ Sáu, 17 tháng 5, 2013

Supporting SEF URLs in your component


earch engine friendly (SEF)human-readable or clean URLs are URLs that make sense to both humans and search engines because they explain the path to the particular page they point to. Since version 1.5, Joomla! is capable of creating and parsing URLs in any format, including SEF URLs. This does not depend on URL rewriting executed by the web server, so it works even if Joomla! runs a server other than Apache with the mod_rewrite module. The SEF URLs follow a certain fixed pattern, but the user can define a short descriptive text (alias) for each segment of the URL.
Internally, the local part of a SEF URL (the part after the domain name) is called a route. Creating and processing SEF URLs is therefore referred to as routing, and the relevant code is called arouter.
In Joomla!, each component is responsible for handling its own SEF URLs. Therefore, as the developer of a component, you will have to create your own router to allow your component to use SEF URLs.

The Concept

Assuming you are following standard development practices, your component is probably using "system URLs" that look a lot like http://www.example.com/index.php?option=com_yourcomponent&view=article&id=1&catid=20&Itemid=50, and your goal is to transform this into http://www.example.com/example-menu-item/20/1. As the developer, you have two tasks: signalling the system that certain pieces of text are URLs and need to be transformed, and explaining the system how to transform URLs.

Applying JRoute::_

It is difficult and inefficient for Joomla! to figure out which parts of your component's output are URLs. To support SEF URLs, you will need to change URL-generating code so that it appliesJRoute::_ before outputting the URL:
echo JRoute::_('index.php?view=article&id=1&catid=20');
Notice that it is possible to leave out the parameters option and Itemidoption defaults to the name of the component currently being executed, and Itemid defaults to the current menu item's ID.
In general, you should only apply this to URLs that users and/or search engines are able to see. For example, there is no need to transform URLs used in redirects that immediately result in other redirects.
If the user turns off SEF URLs in the site's settings, JRoute::_ will produce working non-SEF URLs without any changes to the code.

Writing a router

You'll also need to write a router, which is a single file with two functions that convert system URLs to and from SEF URLs. This file needs to be placed at/components/com_yourcomponent/router.php.
The first function, [componentname]BuildRoute(&$query), must transform an array of URL parameters into an array of segments that will form the SEF URL. Schematically, the transformation works as follows:
http://www.example.com/index.php?option=com_yourcomponent&view=article&id=1&catid=20&Itemid=50
 JRoute::_, called by your component or any other extension
$query = array('view' => 'article', 'id' => 1, 'catid' => 20)
 Your router's com_yourcomponentBuildRoute
$segments = array(20, 1);
 Joomla's internal route building (for display)
http://www.example.com/example-menu-item/20/1
The second function, [componentname]ParseRoute($segments), must transform an array of segments back into an array of URL parameters. Schematically:
http://www.example.com/example-menu-item/20/1
 Joomla's internal route parsing
$segments = array(20, 1);
 Your router's com_yourcomponentParseRoute
$query = array('view' => 'article', 'id' => 1, 'catid' => 20)
The two functions must cooperate in such a way that the original URL can be reconstructed. You can think of BuildRoute as a form of encoding and ParseRoute as the corresponding decoding. When the original URL isn't properly reproduced, your component will stop working.

Preparing Your Data for Routing

The Alias

The first step is the generation of the so called alias. The alias is used in the URL instead of the title (the alias is the text you want to have in the URL). The alias has to be URI safe, which means accented UTF­8 characters are replaced by their ASCII­7 equivalents, white spaces by hyphens, etc.
The alias can be defined by the user, but you should ensure that the above requirements for a URL safe alias are met. A good way to do so is to use the JTable::check() method during the save process. Have a look at this example code:
function check()
{
jimport( 'joomla.filter.output' );
if(empty($this->alias)) {
$this->alias = $this->title;
}
$this->alias = JFilterOutput::stringURLSafe($this->alias);
 
/* All your other checks */
return true;
}
If the alias field is empty the title will be used as alias. Then the alias will be made URLSafe using the JFilterOutput::stringURLSafe() method.

The Slug

Continuing with the same example, the "slug" - "1­:welcome­-to­-joomla" has two parts. The first part is the article identifier (id) and the second is the alias. They are separated by a colon. These two elements were combined during the database query in the model:
$query = 'SELECT a.*, '.
'CASE WHEN CHAR_LENGTH(a.alias) THEN CONCAT_WS(":", a.id, a.alias) ELSE a.id END as slug,'
/*...*/;
After this step the slug is used instead of the id.

Routing URLs

The JRoute::_ method translates the internal Joomla! URL to a custom URL. JRoute has three parameters and its prototype is:
JRoute::_( $url, $xhtml = true, $ssl=null );
Where:
  • $url is a string containing the absolute or relative internal Joomla! URL.
  • $xhtml is a boolean value that specifies whether or not the output should be in XHTML. This parameter is optional and if omitted defaults to true.
  • $ssl is an integer value that specifies whether the URI should be secure. It should be set to 1 to force the URI to be secure using the global secure site URI, 0 to leave it in the same state as when it was passed, and -1 to force the URI to be unsecure using the global unsecure site URI.
The most important parameter is $url. A call to this method might look like:
JRoute::_( 'index.php?view=article&id='.$row->slug );
$row-­>slug is the value that was generated in step 2 from a combination of id and title alias.
Another advantage of using JRoute is that the router now handles $option (the component name) and the $Itemid (the menu item ID). The component itself doesn’t have to know its name ($option) or the active menu item ($Itemid) like it did in previous version of Joomla!.
It is important that you think about the sequence of the URL parameter in this stage. This will be more clear when we have a deeper look at the router.php in the next section.
The building process of JRouter is divided into two steps:
  • Create the application route. The application route is fully handled by JRouter and the component developer doesn’t have to do anything to make it work.
  • Create the component route. To create the component route, JRouter looks for the router.php in the component directory which is responsible for building the route for the component.

The Component Router

We will have two functions in the router.php. One is responsible for building the URL and the other is responsible for parsing it. In the next examples, a very basic and a more advanced one, we assume that we have three views that links can point to. The first is a categories overview (view=categories), the second is a single category (view=category) and the third is a single article (view=article).
The file router.php should be in the site area of your component. It is not used on admin/backend pages. Don't forget to add it to your XML manifest file in the site folder.

A Simple Example

This simple example will illustrate the basics of implementing a router for your component.
function [componentname]BuildRoute( &$query )
{
$segments = array();
if(isset($query['view']))
{
$segments[] = $query['view'];
unset( $query['view'] );
}
if(isset($query['id']))
{
$segments[] = $query['id'];
unset( $query['id'] );
};
return $segments;
}
JRouter passes a $query array to the [componentname]BuildRoute function. This function will add the relevant parts of the array to the $segments array in the right order and will return the properly ordered array. The content of the $query array needs to be unset, otherwise JRouter will add it to the URL in the form of a query string (i.e. any variables that are not handled by the router will be passed in the query string).
The prefix componentname is the name for your component, as found in the directory holding the component's files. For instance, a component "Magic" in directory/components/com_magic/... would use a prefix magic (all lower case).
The next function in the router.php parses the URL:
function [componentname]ParseRoute( $segments )
{
$vars = array();
switch($segments[0])
{
case 'categories':
$vars['view'] = 'categories';
break;
case 'category':
$vars['view'] = 'category';
$id = explode( ':', $segments[1] );
$vars['id'] = (int) $id[0];
break;
case 'article':
$vars['view'] = 'article';
$id = explode( ':', $segments[1] );
$vars['id'] = (int) $id[0];
break;
}
return $vars;
}
What happens here? In the function [componentname]BuildRoute we arranged the items in the $query array in a specific sequence. This means that in this example the view is first and the id is second in the array.
By reading $segments[0], we access the name of the view. We set the right view and/or identifier depending on its value and we return the $vars array to JRouter. $vars should be an associative array similar to the array that was passed to the BuildRoute method.
The above example of the router.php is a very simple way to generate SEF URLs but should show how this works quite clearly.
The generated URL in this example contains the name of the view and doesn't reflect the content hierarchy:
http://www.example.com/[menualias]/[view]/[slug]

A More Advanced Example

In the next example we will try to get rid of the need for the view and we will try to reflect the current hierarchy level in the URL.
The goal is URL's that look like:
  • When viewing an article: http://www.example.com/[menualias]/[category]/[article]
  • When viewing a category: http://www.example.com/[menualias]/[category]
  • When viewing the categories overview: http://www.example.com/[menualias]
Let's assume we have done step 1 and 2 also for the category.
The link to the article would look like this:
JRoute::_( 'index.php?view=article&catid='.$row-­>catslug .'&id='.$row-­>slug );
And the Link to the category would look like this:
JRoute::_( 'index.php?view=category&id='.$row->catslug );
The corresponding router.php:
function [''Componentname'']BuildRoute(&$query)
{
$segments = array();
if(isset( $query['catid'] ))
{
$segments[] = $query['catid'];
unset( $query['catid'] );
};
if( isset($query['id']) )
{
$segments[] = $query['id'];
unset( $query['id'] );
};
unset( $query['view'] );
return $segments;
}
The difference now is that we don’t add the name of the view to the $segments array. We still unset the view key since otherwise, JRouter would add it to the URL as part of the query string. Another new thing here is the additional parameter catid that we push into the $segments array.
function [''Componentname'']ParseRoute($segments)
{
$vars = array();
$app =& JFactory::getApplication();
$menu =& $app->getMenu();
$item =& $menu->getActive();
// Count segments
$count = count( $segments );
//Handle View and Identifier
switch( $item->query['view'] )
{
case 'categories':
if($count == 1) {
$vars['view'] = 'category';
}
if($count == 2) {
$vars['view'] = 'article';
}
$id = explode( ':', $segments[$count-1] );
$vars['id'] = (int) $id[0];
break;
case 'category':
$id = explode( ':', $segments[$count-1] );
$vars['id'] = (int) $id[0];
$vars['view'] = 'article';
break;
}
return $vars;
}
You can see that this ParseRoute function has a lot of different code parts in comparison to the previous. The reason for this is simple. We don’t have the name of the view in the $segments array and we need to find another way to determine it.
We need to find out which level of hierarchy we are in by receiving the root element. We do this by looking to the view name of the active menu item:
$item-­>query['view']
Also we need to know the number of items in the $segments array:
$count = count( $segments );
With this information we can correctly set the view for all possible three cases:
  • The menu item is a link to the categories view and the $segments array has two items ($catid and $id). In this case we know that we need to parse a link to an article.
  • The menu item is a link to the categories view and the $segments array has one item ($id). In this case we know that we need to parse a link to a category.
  • The menu item is a link to a category. In this case, we know that any item in the $segments array is the identifier for an article.
The result of all this code is clean and human-readable component URLs.

Routers and Menu Items

A last important part of creating a router is considering what to do with menu items. As explained on Search Engine Friendly URLs, the output of the component router is used after the first segment of a route, the first segment being the menu item's alias. This creates a difficult question: how is your router and/or other code to know which menu item to route through?
Suppose, for example, that your component is currently producing output for the page /dogs, which lists all dogs in the system. Of course, the items in the list need to be links to pages that display more details about one dog. What should the URL to the dog with ID 21 and name Fido become? Using a router that works according to the principles we've seen so far, the route that is produced is dogs/21-fido, or with some additional work /dogs/fido. But perhaps the user has created a menu item with the alias mydoggy which displays exactly that dog's details. Then it is probably the user's intention to route this URL through that menu item, and the item in the list should link to the page /mydoggy.
More generally, whenever you are building a route, you will need to find the menu item that is most suitable as a starting point for building your route. The term starting point is emphasized because the rest of the route depends on the configuration of the menu item. In our example above, /dogs/21-fido is an acceptable route, /mydoggy is arguably even better, but /mydoggy/21-fido is simply wrong, since /mydoggy is in itself a menu item that is set up to display fido's information.
Several approaches are available to tackle this problem. Joomla!'s core components take a mixed approach, separating responsibilities in two units of code: the router itself and the so-called[componentname]RouteHelper. The [componentname]RouteHelper provides methods that find the most suitable menu item for a given piece of data to be displayed, while the router analyzes the menu item and puts any information that is not determined by the menu item's configuration into the route. This does mean that the calling code must explicitly call the helper's method before routing (echo JRoute::_(DogsRouteHelper::getDogRoute(21));).