====== Styles and Script ======
Xerte has been created so that people with no web development knowledge can create web based learning objects. However, it also provides the ability for those with some web development experience to adapt their Xerte projects, through the use of CSS (Cascading Style Sheets) and/or JavaScript to change the way the Xerte project displays and/or functions.
The Styles and Script optional properties are available at project and page level.
If you want to learn more about CSS or JavaScript for web development, there are reliable resources at the following sites.
* [[https://www.w3schools.com/css/|https://www.w3schools.com/css/]] - CSS Tutorial
* [[https://www.w3schools.com/js/default.asp|https://www.w3schools.com/js/default.asp]] - JavaScript Tutorial
===== CSS =====
The aim of CSS is often to apply style changes (such as colour, fonts sizes) across several areas, in fewer steps than having to make those changes manually using the text-editor options. It can also provide a means to create more space around objects on the page, such as panels or images. There are three ways to add CSS to a Xerte project, to change its appearance.
- In the HTML Source of the Page, from any text editor by clicking the HTML toggle button <>. The changes will apply only to the page to which it is added
- In the optional property Styles box:
- at project, where the changes will apply to all relevant pages in the project
- page level, where the changes will apply only to the page to which it is added
- As a separate stylesheet file (saved in .css format), uploaded to the Media Browser, and applied at project level using the Stylesheet optional property.
===== Script =====
JavaScript (JS or JQuery) is described as the programming language of the web and can be used to introduce new functions to your project. This usually requires previous experience or knowledge with programming, although it is possible to find code snippets on the web that can be adapted for use in a Xerte project. There are two ways to add JavaScript to a Xerte project, to change its functionality.
- In the HTML [[source_view|source view]] of the Page, from any text editor by clicking the HTML toggle button <>. The new function(s) will apply only to the page to which it is added
- In the optional property Script box:
- at project, where the function(s) will apply to all relevant pages in the project
- page level, where the function(s) will apply only to the page to which it is added
===== Examples =====
==== Add CSS to make a responsive iframe ====
* Add the Styles optional property to your project's page.
* Add this CSS code to the Styles box, to create a container class to go around the iframe code: .container {position: relative;overflow: hidden:width: 100%;padding-top: 56.25%;}
* Then add this CSS to style the iframe so that it fits inside the container with full height and width: .responsive-iframe {position: absolute;top: 0;left: 0;bottom: 0;right: 0;width: 100%;height: 100%;}
* In HTML view in your Xerte page text editor:
* Paste in the iframe embed code
* Surround the iframe embed code with:
* Add this class to the iframe code: class="responsive-iframe"
* It should look like this:
==== Add CSS to format the Page Timer ====
* Add the Styles optional property to your project's page.
* Add this CSS code to the Styles box, to format the timer. You can adjust the pixel sizes and colours to suit your project. #x_pageTimer {position:relative;margin:0px 0px 50px 50px; padding: 20px;border: 1px solid #ffa500;border-radius: 10px;background-color: #ffa500;font-size: 3em;width:450px;}
==== Use JS to add a link to the project footer ====
* Add the Script optional property to your project.
* Add this code to the Script box, replacing the "add url here" with the link you want to add: $('#x_footerBlock').append('Link');
{{tag>pagetype customisation}}