mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
MINOR Fixing image links in docs/en/tutorials/
This commit is contained in:
parent
8bd01d62c4
commit
d23aeb2b51
@ -14,7 +14,7 @@ We are going to create a site in which all the content can be edited in the Silv
|
|||||||
navigation system, which will be generated on the fly to include all pages you add in the CMS. We will use two different
|
navigation system, which will be generated on the fly to include all pages you add in the CMS. We will use two different
|
||||||
templates - one for the home page, and one for the rest of the site.
|
templates - one for the home page, and one for the rest of the site.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/2cb2d/2cb2d58938d3bfedc9a6b65b23f0dbda73cdc8d4" alt=""data:image/s3,"s3://crabby-images/970da/970da51127f52b82a3237d5a72c9770fda1e2a36" alt=""
|
data:image/s3,"s3://crabby-images/98d42/98d42f4b5ec54ca524bb9417e831af331b80bfcb" alt=""data:image/s3,"s3://crabby-images/0dd31/0dd3105a9c853dfc2ad3a33fc024ce439626705f" alt=""
|
||||||
|
|
||||||
|
|
||||||
## Installation
|
## Installation
|
||||||
@ -50,7 +50,7 @@ The CMS is the area in which you can manage your site content. You can access th
|
|||||||
will be presented with a login screen. You can login with the details you provided at installation. After logging in you
|
will be presented with a login screen. You can login with the details you provided at installation. After logging in you
|
||||||
should be greeted with the CMS, pictured below (we've entered some test content).
|
should be greeted with the CMS, pictured below (we've entered some test content).
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/e5463/e5463a93fee78e8359d34e8484443a5427e229fe" alt=""
|
data:image/s3,"s3://crabby-images/80229/8022983d80a2e5905e56b7b6ff545eb63e655969" alt=""
|
||||||
|
|
||||||
1. These buttons allow you to move between the different sections in the CMS. There are three core sections in the CMS - Site Content, Files & Images and Security. Modules may have their own sections here as well, if any are installed. In this tutorial we will be focusing on the Site Content section.
|
1. These buttons allow you to move between the different sections in the CMS. There are three core sections in the CMS - Site Content, Files & Images and Security. Modules may have their own sections here as well, if any are installed. In this tutorial we will be focusing on the Site Content section.
|
||||||
2. All the pages in the site are laid out in the site tree. You can add, delete and reorganize the pages using the buttons at the top. Clicking on a page will open it in the editor on the right.
|
2. All the pages in the site are laid out in the site tree. You can add, delete and reorganize the pages using the buttons at the top. Clicking on a page will open it in the editor on the right.
|
||||||
@ -71,7 +71,7 @@ specifies the templates used to render the page, the fields that are able to be
|
|||||||
behavior. We will explain page types in more depth as we progress; for now, make all pages of the type "Page".
|
behavior. We will explain page types in more depth as we progress; for now, make all pages of the type "Page".
|
||||||
|
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/6564a/6564a6ba8bdc0e92d862d32deb5e65dd80cc8aed" alt=""
|
data:image/s3,"s3://crabby-images/80e25/80e25cd53846836094c2ebbbace47382b199d89d" alt=""
|
||||||
|
|
||||||
**SilverStripe's virtual URLs**
|
**SilverStripe's virtual URLs**
|
||||||
|
|
||||||
@ -79,7 +79,7 @@ While you are on the draft or live SilverStripe site, you may notice the URLs po
|
|||||||
http://localhost/contact. SilverStripe uses the URL field on the Meta-Data tab of the editor to look up the appropriate
|
http://localhost/contact. SilverStripe uses the URL field on the Meta-Data tab of the editor to look up the appropriate
|
||||||
page in the database.
|
page in the database.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/ca80e/ca80ea737992d3e895c29acf010a419949a19779" alt=""
|
data:image/s3,"s3://crabby-images/9ec15/9ec15c89f880cba8dba868e66c02d7e92cc426dd" alt=""
|
||||||
|
|
||||||
When you create a new page, SilverStripe automatically creates an appropriate URL for it. For example, *About Us* will
|
When you create a new page, SilverStripe automatically creates an appropriate URL for it. For example, *About Us* will
|
||||||
become *about-us*. You are able to change it yourself so that you can make long titles more usable or descriptive. For
|
become *about-us*. You are able to change it yourself so that you can make long titles more usable or descriptive. For
|
||||||
@ -111,7 +111,7 @@ your site's content in the CMS.
|
|||||||
*$SilverStripeNavigator* inserts the HTML for the navigator at the bottom of the page, which allows you to move
|
*$SilverStripeNavigator* inserts the HTML for the navigator at the bottom of the page, which allows you to move
|
||||||
quickly between the CMS and the draft and published version of your page.
|
quickly between the CMS and the draft and published version of your page.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/0f158/0f158e360fae48c79b70c0747f51c5be401e844b" alt="The SilverStripe Navigator"
|
data:image/s3,"s3://crabby-images/358a1/358a16eeff3e7c7d9c8de4229ffaf01702a07885" alt="The SilverStripe Navigator"
|
||||||
|
|
||||||
**Flushing the cache**
|
**Flushing the cache**
|
||||||
|
|
||||||
@ -159,7 +159,7 @@ Add *$MetaTags* to the head so that it looks like this:
|
|||||||
|
|
||||||
Your page should now look something like this (with your own content of course):
|
Your page should now look something like this (with your own content of course):
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/9772a/9772a01b855e9c3b6759df6578a046115583c68b" alt=""
|
data:image/s3,"s3://crabby-images/49769/497693c6db5ffb2e6178469539162a2e35af3948" alt=""
|
||||||
|
|
||||||
## Making a Navigation System
|
## Making a Navigation System
|
||||||
|
|
||||||
@ -182,7 +182,7 @@ Then, using a control block over the page control *Menu(1)*, we add a link to th
|
|||||||
|
|
||||||
All going to plan, your page should look like this:
|
All going to plan, your page should look like this:
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/7dac3/7dac3d28035a2984196d2885b03648a10a8c2081" alt=""
|
data:image/s3,"s3://crabby-images/cbfcc/cbfcc970996f7af6e6908d4c9b60d6a413a4310e" alt=""
|
||||||
|
|
||||||
The menu isn't really very useful until each button links to the relevant page. We can get the link for the menu item in
|
The menu isn't really very useful until each button links to the relevant page. We can get the link for the menu item in
|
||||||
question by using the *$Link* template variable.
|
question by using the *$Link* template variable.
|
||||||
@ -216,7 +216,7 @@ Change the list item line in *Page.ss* so it looks like this:
|
|||||||
|
|
||||||
You should now have a fully functional top menu
|
You should now have a fully functional top menu
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/ee79b/ee79b5049f01ecf517dda36668ac89f9989e735d" alt=""
|
data:image/s3,"s3://crabby-images/1c277/1c277637fcc7deef4ba9fa27cd1ff5b579f2087e" alt=""
|
||||||
|
|
||||||
## Adding a second level
|
## Adding a second level
|
||||||
|
|
||||||
@ -227,7 +227,7 @@ Select "About Us", and create two new pages "What we do" and "Our History" of th
|
|||||||
|
|
||||||
Either way, your site tree should now look something like this:
|
Either way, your site tree should now look something like this:
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/907b4/907b41a6236afc4fb7f9eeb9177e5f197730a627" alt=""
|
data:image/s3,"s3://crabby-images/c8283/c8283e1b04c03e6a2b8fb0d2991aa649aca4630c" alt=""
|
||||||
|
|
||||||
Great, we now have a hierarchical site structure, but we still have no way of getting to these second level pages.
|
Great, we now have a hierarchical site structure, but we still have no way of getting to these second level pages.
|
||||||
Adding a second level menu is very similar to adding the first level menu.
|
Adding a second level menu is very similar to adding the first level menu.
|
||||||
@ -290,7 +290,7 @@ We now have a fully functioning two level navigation system. Both menus should b
|
|||||||
from page to page. They will also mirror changes done in the SilverStripe CMS, such as renaming pages or moving them
|
from page to page. They will also mirror changes done in the SilverStripe CMS, such as renaming pages or moving them
|
||||||
around.
|
around.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/cda6f/cda6f6c9c7542cc7c7f8075ad0aa22d9595a0141" alt=""
|
data:image/s3,"s3://crabby-images/78187/781879fe0d5ede4f3b79cbe258ba1248c673fa07" alt=""
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -344,7 +344,7 @@ After building the database, we can change the page type of the homepage in the
|
|||||||
|
|
||||||
Under the "Behaviour" tab. Change it to *HomePage*, and click "Save Draft" and "Publish".
|
Under the "Behaviour" tab. Change it to *HomePage*, and click "Save Draft" and "Publish".
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/0e7c3/0e7c398d2d9c7d0c1e7aaa17e1303b6854c64255" alt=""
|
data:image/s3,"s3://crabby-images/6fbd2/6fbd25b572fa63902119a6d9f7abc965ad2f9b08" alt=""
|
||||||
|
|
||||||
Our homepage is now of the page type *HomePage*. However, even though it is of the *HomePage* page type, it is still
|
Our homepage is now of the page type *HomePage*. However, even though it is of the *HomePage* page type, it is still
|
||||||
rendered with the *Page* template. SilverStripe still renders the homepage using the *Page* template because when we
|
rendered with the *Page* template. SilverStripe still renders the homepage using the *Page* template because when we
|
||||||
@ -364,7 +364,7 @@ First, remove the breadcrumbs and the secondary menu; we don't need them for the
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/ffd81/ffd81de12018a6e56bec10315e68312db051ce47" alt=""
|
data:image/s3,"s3://crabby-images/5eae4/5eae447d5f708919416e8ff28f0d3e93dce4f8a1" alt=""
|
||||||
|
|
||||||
### Using a subtemplate
|
### Using a subtemplate
|
||||||
|
|
||||||
@ -457,7 +457,7 @@ it will use the *Page.ss* for both *Page* and *HomePage* page types. When it com
|
|||||||
then descend into the *themes/tutorial/templates/Layout* folder, and will use *Page.ss* for the *Page* page type, and
|
then descend into the *themes/tutorial/templates/Layout* folder, and will use *Page.ss* for the *Page* page type, and
|
||||||
*HomePage.ss* for the *HomePage* page type.
|
*HomePage.ss* for the *HomePage* page type.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/43eeb/43eeb4855b184a868a78c63a130706d01e00255e" alt=""
|
data:image/s3,"s3://crabby-images/2c802/2c8020d7a7e51cb659a3f3bdd7b025b008dac394" alt=""
|
||||||
|
|
||||||
## Summary
|
## Summary
|
||||||
|
|
||||||
@ -477,4 +477,4 @@ things.
|
|||||||
* [Official book on SilverStripe in English](http://www.silverstripe.org/silverstripe-book).
|
* [Official book on SilverStripe in English](http://www.silverstripe.org/silverstripe-book).
|
||||||
* [Official book on SilverStripe in German](http://www.silverstripe.org/das-silverstripe-buch).
|
* [Official book on SilverStripe in German](http://www.silverstripe.org/das-silverstripe-buch).
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/e9e98/e9e986158d5ceb554049691c7dc3f35ecdda4392" alt=""
|
data:image/s3,"s3://crabby-images/c95c2/c95c2065e1e5609c20778e7ad357615abdf1ceef" alt=""
|
@ -16,7 +16,7 @@ Throughout this tutorial we are going to work on adding two new sections to the
|
|||||||
first is a news section, with a recent news listing on the homepage and an RSS feed. The second is a staff section,
|
first is a news section, with a recent news listing on the homepage and an RSS feed. The second is a staff section,
|
||||||
which demonstrates more complex database structures by associating an image with each staff member.
|
which demonstrates more complex database structures by associating an image with each staff member.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/e5ff0/e5ff0922349bb7b43bf537acf523c731a65954df" alt=""data:image/s3,"s3://crabby-images/5a458/5a458791bdf20549e596c2f71dce39769f25519d" alt=""
|
data:image/s3,"s3://crabby-images/cbc69/cbc69ac9925cdf95e82012bcc7b5ed55d9319a55" alt=""data:image/s3,"s3://crabby-images/e3cc7/e3cc7780f815757a90109496107562837412fb92" alt=""
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -57,7 +57,7 @@ the database, which fields can be edited in the CMS, and can use code to make ou
|
|||||||
A more in-depth introduction of Model-View-Controller can be found
|
A more in-depth introduction of Model-View-Controller can be found
|
||||||
[here](http://www.slash7.com/articles/2005/02/22/mvc-the-most-vexing-conundrum).
|
[here](http://www.slash7.com/articles/2005/02/22/mvc-the-most-vexing-conundrum).
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/e7534/e75344061a202fb95950b4296a180a8dec1c0fbb" alt=""
|
data:image/s3,"s3://crabby-images/f8cc4/f8cc4e16e232f7af300b1706093050b1b40cab14" alt=""
|
||||||
|
|
||||||
## Creating the news section page types
|
## Creating the news section page types
|
||||||
|
|
||||||
@ -213,7 +213,7 @@ to edit the fields in the CMS.
|
|||||||
Now that we have created our page types, let's add some content. Go into the CMS and create an *ArticleHolder* page
|
Now that we have created our page types, let's add some content. Go into the CMS and create an *ArticleHolder* page
|
||||||
named "News", and create some *ArticlePage*s inside it.
|
named "News", and create some *ArticlePage*s inside it.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/ada45/ada4543111de06ec04d43acdc508a5c0cd62a8ea" alt=""
|
data:image/s3,"s3://crabby-images/059b3/059b3bd3f928518456341b2e7486d2b32e6cfc29" alt=""
|
||||||
|
|
||||||
## Modifing the date field
|
## Modifing the date field
|
||||||
|
|
||||||
@ -313,13 +313,13 @@ spread across several tables in the database matched by id - e.g. *Content* is i
|
|||||||
*Author* are in the *Article* table. SilverStripe matches these records by their ids and collates them into the single
|
*Author* are in the *Article* table. SilverStripe matches these records by their ids and collates them into the single
|
||||||
data object.
|
data object.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/63417/63417329b159064c501c92ae920205b92846a8bc" alt=""
|
data:image/s3,"s3://crabby-images/c7a77/c7a778df8de907d480e0001e09b9444bab41254b" alt=""
|
||||||
|
|
||||||
Rather than using *$Date* directly, we use *$Date.Nice*. If we look in the `[api:Date]` documentation, we can see
|
Rather than using *$Date* directly, we use *$Date.Nice*. If we look in the `[api:Date]` documentation, we can see
|
||||||
that the *Nice* function returns the date in *dd/mm/yyyy* format, rather than the *yyyy-mm-dd* format stored in the
|
that the *Nice* function returns the date in *dd/mm/yyyy* format, rather than the *yyyy-mm-dd* format stored in the
|
||||||
database.
|
database.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/c246c/c246c722f577337a66a060be35fda2f4b6ed08b9" alt=""
|
data:image/s3,"s3://crabby-images/0ddb4/0ddb49c7a907cbcefc6f00ad33980585838455e6" alt=""
|
||||||
|
|
||||||
Now we'll create a template for the article holder: we want our news section to show a list of news items, each with a
|
Now we'll create a template for the article holder: we want our news section to show a list of news items, each with a
|
||||||
summary.
|
summary.
|
||||||
@ -344,7 +344,7 @@ page, which in this case is our news articles. The *$Link* variable will give th
|
|||||||
use to create a link, and the *FirstParagraph* function of the `[api:HTMLText]` field gives us a nice summary of the
|
use to create a link, and the *FirstParagraph* function of the `[api:HTMLText]` field gives us a nice summary of the
|
||||||
article.
|
article.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/92b05/92b05c23dd1f106c743bc568f8344949b9fc3029" alt=""
|
data:image/s3,"s3://crabby-images/e2888/e28880fad4c63f8a52a36cc9ff542ef56a91f20b" alt=""
|
||||||
|
|
||||||
Remember that the visual styles are not part of the CMS, they are defined in the tutorial CSS file.
|
Remember that the visual styles are not part of the CMS, they are defined in the tutorial CSS file.
|
||||||
|
|
||||||
@ -422,7 +422,7 @@ This will change the icons for the pages in the CMS.
|
|||||||
> Note: that the corresponding filename to the path given for $icon will end with **-file.gif**,
|
> Note: that the corresponding filename to the path given for $icon will end with **-file.gif**,
|
||||||
> e.g. when you specify **news** above, the filename will be **news-file.gif**.
|
> e.g. when you specify **news** above, the filename will be **news-file.gif**.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/d81f8/d81f8684662e10e6e9afe1d9671d2c476b53796b" alt=""
|
data:image/s3,"s3://crabby-images/09b21/09b21c20ab301eea59c41758a045aaebd815a967" alt=""
|
||||||
|
|
||||||
### Allowing comments on news articles
|
### Allowing comments on news articles
|
||||||
|
|
||||||
@ -430,7 +430,7 @@ A handy feature built into SilverStripe is the ability for guests to your site t
|
|||||||
this on for an article simply by ticking the box in the behaviour tab of a page in the CMS. Enable this for all your
|
this on for an article simply by ticking the box in the behaviour tab of a page in the CMS. Enable this for all your
|
||||||
*ArticlePage*s.
|
*ArticlePage*s.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/82ec8/82ec8ddb61c7b97056f669556d9526acb71408a7" alt=""
|
data:image/s3,"s3://crabby-images/0a634/0a634773aabec6c2f9ef394298c6d673aff477ab" alt=""
|
||||||
|
|
||||||
We then need to include *$PageComments* in our template, which will insert the comment form as well as all comments left
|
We then need to include *$PageComments* in our template, which will insert the comment form as well as all comments left
|
||||||
on the page.
|
on the page.
|
||||||
@ -448,7 +448,7 @@ on the page.
|
|||||||
|
|
||||||
You should also prepare the *Page* template in the same manner, so comments can be enabled at a later point on any page.
|
You should also prepare the *Page* template in the same manner, so comments can be enabled at a later point on any page.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/2472f/2472fe62f43ef249cb57586b78586bec463f6f64" alt=""
|
data:image/s3,"s3://crabby-images/751fd/751fdd3471e5ff9a73cd0f7864e991065aa7fa52" alt=""
|
||||||
|
|
||||||
It would be nice to have comments on for all articles by default. We can do this with the *$defaults* array. Add this to
|
It would be nice to have comments on for all articles by default. We can do this with the *$defaults* array. Add this to
|
||||||
the *ArticlePage* class:
|
the *ArticlePage* class:
|
||||||
@ -507,7 +507,7 @@ page is referenced in other pages, e.g. by page controls. A good rule of thumb i
|
|||||||
page currently being viewed in the controller; only if a function needs to be used in another page should you put it in
|
page currently being viewed in the controller; only if a function needs to be used in another page should you put it in
|
||||||
the data object.
|
the data object.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/16948/16948ff8a2eec96d0f1bbb6a682b0868da02b76d" alt=""
|
data:image/s3,"s3://crabby-images/55cf8/55cf8ef0d2d45e46d465085abfd4b3bc6d8255e1" alt=""
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -532,7 +532,7 @@ that name on the controller if it exists.
|
|||||||
Depending on your browser, you should see something like the picture below. If your browser doesn't support RSS, you
|
Depending on your browser, you should see something like the picture below. If your browser doesn't support RSS, you
|
||||||
will most likely see the XML output instead.
|
will most likely see the XML output instead.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/f637d/f637dc82c1a9cf2a42ee7d99ccdf10d5837d8ed2" alt=""
|
data:image/s3,"s3://crabby-images/b92be/b92beec6fe2cd5dec92067f26e91da061875cc6f" alt=""
|
||||||
|
|
||||||
Now all we need is to let the user know that our RSS feed exists. The `[api:RSSFeed]` in your controller, it will be
|
Now all we need is to let the user know that our RSS feed exists. The `[api:RSSFeed]` in your controller, it will be
|
||||||
called when the page is requested. Add this function to *ArticleHolder_Controller*:
|
called when the page is requested. Add this function to *ArticleHolder_Controller*:
|
||||||
@ -548,7 +548,7 @@ This automatically generates a link-tag in the header of our template. The *init
|
|||||||
class to ensure any initialization the parent would have done if we hadn't overridden the *init* function is still
|
class to ensure any initialization the parent would have done if we hadn't overridden the *init* function is still
|
||||||
called. In Firefox you can see the RSS feed link in the address bar:
|
called. In Firefox you can see the RSS feed link in the address bar:
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/41e78/41e78eaa69f386a0e7da9374187c9697ec418641" alt=""
|
data:image/s3,"s3://crabby-images/20879/2087953bd2e630418d8df28f8af6972819ddd827" alt=""
|
||||||
|
|
||||||
## Adding a staff section
|
## Adding a staff section
|
||||||
|
|
||||||
@ -614,12 +614,12 @@ We then add an *ImageField* in the *getCMSFields* function to the tab "Root.Cont
|
|||||||
the *addFieldToTab* function will create it for us. The *ImageField* allows us to select an image or upload a new one in
|
the *addFieldToTab* function will create it for us. The *ImageField* allows us to select an image or upload a new one in
|
||||||
the CMS.
|
the CMS.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/f6b81/f6b813b34a0f22305da801e1c5f779a36be29719" alt=""
|
data:image/s3,"s3://crabby-images/57b09/57b096fe0802f27f9f6552797eda5e6027e5ade2" alt=""
|
||||||
|
|
||||||
Rebuild the database ([http://localhost/dev/build?flush=1](http://localhost/dev/build?flush=1)) and open the CMS. Create
|
Rebuild the database ([http://localhost/dev/build?flush=1](http://localhost/dev/build?flush=1)) and open the CMS. Create
|
||||||
a new *StaffHolder* called "Staff" in the "About Us" section, and create some *StaffPage*s in it.
|
a new *StaffHolder* called "Staff" in the "About Us" section, and create some *StaffPage*s in it.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/72be1/72be1ef4df65c5a4f1635a6e78e8178519f0d20a" alt=""
|
data:image/s3,"s3://crabby-images/faaab/faaab3722b39bee0ff476f97e0cbd470f3b1b410" alt=""
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -654,7 +654,7 @@ This template is very similar to the *ArticleHolder* template. The *FirstSentenc
|
|||||||
will resize the image before sending it to the browser. The resized image is cached, so the server doesn't have to
|
will resize the image before sending it to the browser. The resized image is cached, so the server doesn't have to
|
||||||
resize the image every time the page is viewed.
|
resize the image every time the page is viewed.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/ca353/ca3535db467ea81044aa1a145d23b9c5ecb314c7" alt=""
|
data:image/s3,"s3://crabby-images/54dd0/54dd0b10ec18125c84fe5714821254d2b9266e9e" alt=""
|
||||||
|
|
||||||
The *StaffPage* template is also very straight forward.
|
The *StaffPage* template is also very straight forward.
|
||||||
|
|
||||||
@ -677,7 +677,7 @@ The *StaffPage* template is also very straight forward.
|
|||||||
Here we also use the *SetWidth* function to get a different sized image from the same source image. You should now have
|
Here we also use the *SetWidth* function to get a different sized image from the same source image. You should now have
|
||||||
a complete staff section.
|
a complete staff section.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/862c9/862c93775968d07cfae457023188f97a254ceba1" alt=""
|
data:image/s3,"s3://crabby-images/8fcf5/8fcf50233dced74dd8de7acf2cec8c20fff30e3a" alt=""
|
||||||
|
|
||||||
## Summary
|
## Summary
|
||||||
|
|
||||||
|
@ -15,7 +15,7 @@ A UserDefinedForm is much quicker to implement, but lacks the flexibility of a c
|
|||||||
We will create a poll on the home page that asks the user their favourite web browser, and displays a bar graph of the
|
We will create a poll on the home page that asks the user their favourite web browser, and displays a bar graph of the
|
||||||
results.
|
results.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/657ca/657ca6999809922342a0bafb5981f6baf81d3f9f" alt="tutorial:pollresults-small.png"
|
data:image/s3,"s3://crabby-images/c4346/c43468097485f19ffb9238907644d09139da7f1d" alt="tutorial:pollresults-small.png"
|
||||||
|
|
||||||
|
|
||||||
## Creating the form
|
## Creating the form
|
||||||
@ -168,7 +168,7 @@ Add the following code to the form style sheet:
|
|||||||
This CSS code will ensure that the form is formatted and positioned correctly. All going according to plan, if you visit
|
This CSS code will ensure that the form is formatted and positioned correctly. All going according to plan, if you visit
|
||||||
[http://localhost/home?flush=1](http://localhost/home?flush=1) it should look something like below.
|
[http://localhost/home?flush=1](http://localhost/home?flush=1) it should look something like below.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/37938/37938e30526082c8318fd956d1c00b689d1b6af7" alt=""
|
data:image/s3,"s3://crabby-images/44a79/44a7928a8e82591f10ce1b809ae8267a9554dee4" alt=""
|
||||||
|
|
||||||
|
|
||||||
## Processing the form
|
## Processing the form
|
||||||
@ -249,7 +249,7 @@ Change the end of the 'BrowserPollForm' function so it looks like this:
|
|||||||
If we then open the homepage and attempt to submit the form without filling in the required fields an error will be
|
If we then open the homepage and attempt to submit the form without filling in the required fields an error will be
|
||||||
shown.
|
shown.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/449a9/449a9f702b5ee47d41dac275a17c083e1658f6d1" alt=""
|
data:image/s3,"s3://crabby-images/88c1d/88c1df7965d6ec283246a2086b6472c84fd000b7" alt=""
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -406,7 +406,7 @@ We use the normal tactic of putting the data into an unordered list and using CS
|
|||||||
styles to display a bar that is sized proportionate to the number of votes the browser has received. You should now have
|
styles to display a bar that is sized proportionate to the number of votes the browser has received. You should now have
|
||||||
a complete poll.
|
a complete poll.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/a012e/a012e9a7e478c45f503ebf930b7de09888af2c2f" alt=""
|
data:image/s3,"s3://crabby-images/2a20c/2a20ce84fd2364c85db21e3c8e17f6b80abdc7b0" alt=""
|
||||||
|
|
||||||
|
|
||||||
## Summary
|
## Summary
|
||||||
|
@ -15,7 +15,7 @@ search-file.gif).
|
|||||||
We are going to add a search box on the top of the page. When a user types something in the box, they are taken to a
|
We are going to add a search box on the top of the page. When a user types something in the box, they are taken to a
|
||||||
results page.
|
results page.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/b6114/b61144b9b43f9f9917804cc33649fab8013bfc3c" alt=""
|
data:image/s3,"s3://crabby-images/52b4f/52b4f270fc5296615f98734678d86be17e6eb8e2" alt=""
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -84,7 +84,7 @@ We then just need to add the search form to the template. Add *$SearchForm* to t
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/c395c/c395c6ef35a6c0a40670d67c68d49ee822789bfe" alt=""
|
data:image/s3,"s3://crabby-images/34b78/34b78d1bbf61f1087109aadc1ea2ed6fa21aa598" alt=""
|
||||||
|
|
||||||
## Showing the results
|
## Showing the results
|
||||||
|
|
||||||
@ -191,7 +191,7 @@ class.
|
|||||||
Then finally add ?flush=1 to the URL and you should see the new template.
|
Then finally add ?flush=1 to the URL and you should see the new template.
|
||||||
|
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/fdf68/fdf68b0971acc65c6307fab66a043ed858ae4ce4" alt=""
|
data:image/s3,"s3://crabby-images/f676d/f676df8fcb23ebcd82d81d5d125e5fc36dda6971" alt=""
|
||||||
|
|
||||||
|
|
||||||
## Summary
|
## Summary
|
||||||
|
@ -163,7 +163,7 @@ Now that we have created our *Project* page type and *Student* data object, let
|
|||||||
Go into the CMS and create one *Project* page for each project listed [above](#what-are-we-working-towards) under a
|
Go into the CMS and create one *Project* page for each project listed [above](#what-are-we-working-towards) under a
|
||||||
*ProjectsHolder* page named **GSOC Projects** for instance.
|
*ProjectsHolder* page named **GSOC Projects** for instance.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/596d6/596d6f5ffbd6945c7683fda54ed0613cc11e7ee0" alt="tutorial:gsoc-project-creation.png"
|
data:image/s3,"s3://crabby-images/ad45a/ad45a8ff5982c3ed4bd10aad874b6e62f26436e9" alt="tutorial:gsoc-project-creation.png"
|
||||||
|
|
||||||
As you can see in the tab panel *Student*, the adding functionality is titled *Add Student*. However, if you want to
|
As you can see in the tab panel *Student*, the adding functionality is titled *Add Student*. However, if you want to
|
||||||
modify this title, you have to add this code in the *getCMSFields* method of the *Project* class :
|
modify this title, you have to add this code in the *getCMSFields* method of the *Project* class :
|
||||||
@ -176,7 +176,7 @@ Select now one of the *Project* page that you have created, go in the tab panel
|
|||||||
listed [above](#what-are-we-working-towards) by clicking on the link **Add A Student** of your
|
listed [above](#what-are-we-working-towards) by clicking on the link **Add A Student** of your
|
||||||
*HasOneComplexTableField* table.
|
*HasOneComplexTableField* table.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/33682/33682a55e432a8fe83ce10c420109c80aa6e8dd8" alt="tutorial:gsoc-student-creation.png"
|
data:image/s3,"s3://crabby-images/e7cc6/e7cc6cc904c45690ba12baff2bfbe2acb86312f4" alt="tutorial:gsoc-student-creation.png"
|
||||||
|
|
||||||
After having added all the students, you will see that, in the tab panel *Student* of all the *Project* pages, the
|
After having added all the students, you will see that, in the tab panel *Student* of all the *Project* pages, the
|
||||||
*HasOneComplexTableField* tables have the same content.
|
*HasOneComplexTableField* tables have the same content.
|
||||||
@ -184,7 +184,7 @@ After having added all the students, you will see that, in the tab panel *Studen
|
|||||||
For each *Project* page, you can now affect **one and only one** student to it ( see the
|
For each *Project* page, you can now affect **one and only one** student to it ( see the
|
||||||
[list](#What_are_we_working_towards?) ).
|
[list](#What_are_we_working_towards?) ).
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/581e1/581e182897610dab75cd61fe1e638680e055cb78" alt="tutorial:gsoc-project-student-selection.png"
|
data:image/s3,"s3://crabby-images/56ae1/56ae1528ee8bf603a050d8c3251eeb22e45f86be" alt="tutorial:gsoc-project-student-selection.png"
|
||||||
|
|
||||||
You will also notice, that you have the possibility to **unselect** a student which will make your *Project* page
|
You will also notice, that you have the possibility to **unselect** a student which will make your *Project* page
|
||||||
without any student affected to it.
|
without any student affected to it.
|
||||||
@ -321,12 +321,12 @@ Now that we have created our *Mentor* page type, go into the CMS and create one
|
|||||||
[above](#what-are-we-working-towards) under a simple *Page* named
|
[above](#what-are-we-working-towards) under a simple *Page* named
|
||||||
**Mentors** for instance.
|
**Mentors** for instance.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/f3ba0/f3ba0bd68313c68d3ec70018bc362354a3c3fb0d" alt="tutorial:gsoc-mentor-creation.png"
|
data:image/s3,"s3://crabby-images/d33b7/d33b76368b2862ffaa604b2be242d47ec3741551" alt="tutorial:gsoc-mentor-creation.png"
|
||||||
|
|
||||||
For each *Mentor* page, you can now affect **many** students created previously ( see the
|
For each *Mentor* page, you can now affect **many** students created previously ( see the
|
||||||
[list](#What_are_we_working_towards?) ) by going in the tab panel *Students*.
|
[list](#What_are_we_working_towards?) ) by going in the tab panel *Students*.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/b375a/b375aed4137f3112ce0958b6b5377d47fff5d731" alt="tutorial:gsoc-mentor-student-selection.png"
|
data:image/s3,"s3://crabby-images/35981/35981e5e63ae844899c29a5535aaf58286ed6ef6" alt="tutorial:gsoc-mentor-student-selection.png"
|
||||||
|
|
||||||
You will also notice, that by checking a student in a *Mentor* page, you will be unable to select him again in any other
|
You will also notice, that by checking a student in a *Mentor* page, you will be unable to select him again in any other
|
||||||
*Mentor* page which is the definition of a **1-to-many** relation.
|
*Mentor* page which is the definition of a **1-to-many** relation.
|
||||||
@ -432,13 +432,13 @@ Select now one of the *Project* page, go in the tab panel *Modules* and add all
|
|||||||
[above](#what-are-we-working-towards) by clicking on the link **Add A
|
[above](#what-are-we-working-towards) by clicking on the link **Add A
|
||||||
Module** of your *ManyManyComplexTableField* table.
|
Module** of your *ManyManyComplexTableField* table.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/de027/de027ae152747b5c40cdf72d921227990f44acb8" alt="tutorial:gsoc-module-creation.png"
|
data:image/s3,"s3://crabby-images/0e3e4/0e3e46331bf5c5e27ac417cfcb81974eff4c8fa9" alt="tutorial:gsoc-module-creation.png"
|
||||||
|
|
||||||
For each *Project* page, you can now affect **many** modules created previously ( see the
|
For each *Project* page, you can now affect **many** modules created previously ( see the
|
||||||
[list](#What_are_we_working_towards?) ) by going in the tab panel
|
[list](#What_are_we_working_towards?) ) by going in the tab panel
|
||||||
*Modules*.
|
*Modules*.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/3cac2/3cac2f4660e9451869dbccd671affc967fc3b3cf" alt="tutorial:gsoc-project-module-selection.png"
|
data:image/s3,"s3://crabby-images/7172f/7172f650667e88c55604cbb4d16c87e0db2cf5fc" alt="tutorial:gsoc-project-module-selection.png"
|
||||||
|
|
||||||
You will also notice, that you are able to select several times a *Module* on different *Project* pages which is the
|
You will also notice, that you are able to select several times a *Module* on different *Project* pages which is the
|
||||||
definition of a **many-to-many** relation.
|
definition of a **many-to-many** relation.
|
||||||
@ -464,7 +464,7 @@ For every kind of *Page* or *DataObject*, you can access to their relations than
|
|||||||
Let's start with the *ProjectsHolder* page created before. For this template, we are will display the same table than
|
Let's start with the *ProjectsHolder* page created before. For this template, we are will display the same table than
|
||||||
[above](#what-are-we-working-towards).
|
[above](#what-are-we-working-towards).
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/35fd8/35fd8dcee5ba32e81127a46a69699f3162dcc59e" alt="tutorial:gsoc-projects-table.png"
|
data:image/s3,"s3://crabby-images/2949f/2949fdd7b11f4412e8482e23abcb1a65a97f6277" alt="tutorial:gsoc-projects-table.png"
|
||||||
|
|
||||||
*tutorial/templates/Layout/ProjectsHolder.ss*
|
*tutorial/templates/Layout/ProjectsHolder.ss*
|
||||||
|
|
||||||
@ -562,7 +562,7 @@ We know now how to easily access and show [relations](../topics/datamodel#relati
|
|||||||
|
|
||||||
We can now do the same for every *Project* page by creating its own template.
|
We can now do the same for every *Project* page by creating its own template.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/6f12e/6f12e5a1660d87e34c8102478f9c3c00dc0f34e2" alt="tutorial:gsoc-project.png"
|
data:image/s3,"s3://crabby-images/52198/52198fe005c8290889ce61dfb3e46f335bfae0ec" alt="tutorial:gsoc-project.png"
|
||||||
|
|
||||||
*tutorial/templates/Layout/Project.ss*
|
*tutorial/templates/Layout/Project.ss*
|
||||||
|
|
||||||
@ -699,7 +699,7 @@ In this template, we are gonna try to access the *Project* details from a *Stude
|
|||||||
What we want to do is to access to the *Project* page in the same way than we have done for the other relations
|
What we want to do is to access to the *Project* page in the same way than we have done for the other relations
|
||||||
**without modifying the relations between *Page* and *DataObject* and the database structure**.
|
**without modifying the relations between *Page* and *DataObject* and the database structure**.
|
||||||
|
|
||||||
data:image/s3,"s3://crabby-images/1906e/1906e4602af4b6c91b8feb14638c788974018f12" alt="tutorial:gsoc-mentor.png"
|
data:image/s3,"s3://crabby-images/56e2f/56e2f249dd9bca54b6ddf74c80721e58d268f64b" alt="tutorial:gsoc-mentor.png"
|
||||||
|
|
||||||
To do so, we have to create a function in the *Student* class which will return the *Project* linked with it. Let's call
|
To do so, we have to create a function in the *Student* class which will return the *Project* linked with it. Let's call
|
||||||
it *MyProject* for instance.
|
it *MyProject* for instance.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user