mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
MINOR Fixing image links in docs/en/tutorials/
This commit is contained in:
parent
b1c36ce0a4
commit
66bc92892e
@ -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.
|
||||||
|
|
||||||
![](_images/home-small.png)![](_images/menu-two-level-small.png)
|
![](_images/home-small.jpg)![](_images/menu-two-level-small.jpg)
|
||||||
|
|
||||||
|
|
||||||
## 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).
|
||||||
|
|
||||||
![](_images/cms-numbered.png)
|
![](_images/cms-numbered.jpg)
|
||||||
|
|
||||||
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".
|
||||||
|
|
||||||
|
|
||||||
![](_images/home-first.png)
|
![](_images/home-first.jpg)
|
||||||
|
|
||||||
**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.
|
||||||
|
|
||||||
![](_images/url.png)
|
![](_images/url.jpg)
|
||||||
|
|
||||||
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.
|
||||||
|
|
||||||
![The SilverStripe Navigator](_images/navigator.png)
|
![The SilverStripe Navigator](_images/navigator.jpg)
|
||||||
|
|
||||||
**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):
|
||||||
|
|
||||||
![](_images/title.png)
|
![](_images/title.jpg)
|
||||||
|
|
||||||
## 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:
|
||||||
|
|
||||||
![](_images/menu.png)
|
![](_images/menu.jpg)
|
||||||
|
|
||||||
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
|
||||||
|
|
||||||
![](_images/menu-highlighted.png)
|
![](_images/menu-highlighted.jpg)
|
||||||
|
|
||||||
## 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:
|
||||||
|
|
||||||
![](_images/2nd_level-cut.png)
|
![](_images/2nd_level-cut.jpg)
|
||||||
|
|
||||||
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.
|
||||||
|
|
||||||
![](_images/menu-two-level.png)
|
![](_images/menu-two-level.jpg)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -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".
|
||||||
|
|
||||||
![](_images/homepage-type.png)
|
![](_images/homepage-type.jpg)
|
||||||
|
|
||||||
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>
|
||||||
|
|
||||||
|
|
||||||
![](_images/home-template.png)
|
![](_images/home-template.jpg)
|
||||||
|
|
||||||
### 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.
|
||||||
|
|
||||||
![](_images/subtemplates-diagram.png)
|
![](_images/subtemplates-diagram.jpg)
|
||||||
|
|
||||||
## 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).
|
||||||
|
|
||||||
![](_images/silverstripe-cms-book-front-cover-design-june2009preview.png)
|
![](_images/silverstripe-cms-book-front-cover-design-june2009preview.jpg)
|
@ -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.
|
||||||
|
|
||||||
![](_images/news-with-rss-small.png)![](_images/einstein-small.png)
|
![](_images/news-with-rss-small.jpg)![](_images/einstein-small.jpg)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -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).
|
||||||
|
|
||||||
![](_images/pagetype-inheritance.png)
|
![](_images/pagetype-inheritance.jpg)
|
||||||
|
|
||||||
## 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.
|
||||||
|
|
||||||
![](_images/news-cms.png)
|
![](_images/news-cms.jpg)
|
||||||
|
|
||||||
## 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.
|
||||||
|
|
||||||
![](_images/data-collation.png)
|
![](_images/data-collation.jpg)
|
||||||
|
|
||||||
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.
|
||||||
|
|
||||||
![](_images/news.png)
|
![](_images/news.jpg)
|
||||||
|
|
||||||
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.
|
||||||
|
|
||||||
![](_images/articleholder.png)
|
![](_images/articleholder.jpg)
|
||||||
|
|
||||||
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**.
|
||||||
|
|
||||||
![](_images/icons2.png)
|
![](_images/icons2.jpg)
|
||||||
|
|
||||||
### 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.
|
||||||
|
|
||||||
![](_images/comments.png)
|
![](_images/comments.jpg)
|
||||||
|
|
||||||
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.
|
||||||
|
|
||||||
![](_images/news-comments.png)
|
![](_images/news-comments.jpg)
|
||||||
|
|
||||||
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.
|
||||||
|
|
||||||
![](_images/homepage-news.png)
|
![](_images/homepage-news.jpg)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -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.
|
||||||
|
|
||||||
![](_images/rss-feed.png)
|
![](_images/rss-feed.jpg)
|
||||||
|
|
||||||
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:
|
||||||
|
|
||||||
![](_images/rss.png)
|
![](_images/rss.jpg)
|
||||||
|
|
||||||
## 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.
|
||||||
|
|
||||||
![](_images/photo.png)
|
![](_images/photo.jpg)
|
||||||
|
|
||||||
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.
|
||||||
|
|
||||||
![](_images/create-staff.png)
|
![](_images/create-staff.jpg)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -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.
|
||||||
|
|
||||||
![](_images/staff-section.png)
|
![](_images/staff-section.jpg)
|
||||||
|
|
||||||
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.
|
||||||
|
|
||||||
![](_images/einstein.png)
|
![](_images/einstein.jpg)
|
||||||
|
|
||||||
## 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.
|
||||||
|
|
||||||
![tutorial:pollresults-small.png](_images/pollresults-small.png)
|
![tutorial:pollresults-small.png](_images/pollresults-small.jpg)
|
||||||
|
|
||||||
|
|
||||||
## 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.
|
||||||
|
|
||||||
![](_images/pollform.png)
|
![](_images/pollform.jpg)
|
||||||
|
|
||||||
|
|
||||||
## 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.
|
||||||
|
|
||||||
![](_images/validation.png)
|
![](_images/validation.jpg)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -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.
|
||||||
|
|
||||||
![](_images/pollresults.png)
|
![](_images/pollresults.jpg)
|
||||||
|
|
||||||
|
|
||||||
## 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.
|
||||||
|
|
||||||
![](_images/searchresults-small.png)
|
![](_images/searchresults-small.jpg)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -84,7 +84,7 @@ We then just need to add the search form to the template. Add *$SearchForm* to t
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
|
||||||
![](_images/searchform.png)
|
![](_images/searchform.jpg)
|
||||||
|
|
||||||
## 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.
|
||||||
|
|
||||||
|
|
||||||
![](_images/searchresults.png)
|
![](_images/searchresults.jpg)
|
||||||
|
|
||||||
|
|
||||||
## 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.
|
||||||
|
|
||||||
![tutorial:gsoc-project-creation.png](_images/gsoc-project-creation.png)
|
![tutorial:gsoc-project-creation.png](_images/gsoc-project-creation.jpg)
|
||||||
|
|
||||||
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.
|
||||||
|
|
||||||
![tutorial:gsoc-student-creation.png](_images/gsoc-student-creation.png)
|
![tutorial:gsoc-student-creation.png](_images/gsoc-student-creation.jpg)
|
||||||
|
|
||||||
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?) ).
|
||||||
|
|
||||||
![tutorial:gsoc-project-student-selection.png](_images/gsoc-project-student-selection.png)
|
![tutorial:gsoc-project-student-selection.png](_images/gsoc-project-student-selection.jpg)
|
||||||
|
|
||||||
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.
|
||||||
|
|
||||||
![tutorial:gsoc-mentor-creation.png](_images/gsoc-mentor-creation.png)
|
![tutorial:gsoc-mentor-creation.png](_images/gsoc-mentor-creation.jpg)
|
||||||
|
|
||||||
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*.
|
||||||
|
|
||||||
![tutorial:gsoc-mentor-student-selection.png](_images/gsoc-mentor-student-selection.png)
|
![tutorial:gsoc-mentor-student-selection.png](_images/gsoc-mentor-student-selection.jpg)
|
||||||
|
|
||||||
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.
|
||||||
|
|
||||||
![tutorial:gsoc-module-creation.png](_images/gsoc-module-creation.png)
|
![tutorial:gsoc-module-creation.png](_images/gsoc-module-creation.jpg)
|
||||||
|
|
||||||
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*.
|
||||||
|
|
||||||
![tutorial:gsoc-project-module-selection.png](_images/gsoc-project-module-selection.png)
|
![tutorial:gsoc-project-module-selection.png](_images/gsoc-project-module-selection.jpg)
|
||||||
|
|
||||||
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).
|
||||||
|
|
||||||
![tutorial:gsoc-projects-table.png](_images/gsoc-projects-table.png)
|
![tutorial:gsoc-projects-table.png](_images/gsoc-projects-table.jpg)
|
||||||
|
|
||||||
*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.
|
||||||
|
|
||||||
![tutorial:gsoc-project.png](_images/gsoc-project.png)
|
![tutorial:gsoc-project.png](_images/gsoc-project.jpg)
|
||||||
|
|
||||||
*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**.
|
||||||
|
|
||||||
![tutorial:gsoc-mentor.png](_images/gsoc-mentor.png)
|
![tutorial:gsoc-mentor.png](_images/gsoc-mentor.jpg)
|
||||||
|
|
||||||
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…
Reference in New Issue
Block a user