====== Custom Templates (not for Default Free Service) ====== ===== Types of custom templates ===== There are 4 types of custom templates: * **index.html**: for the walled garden option "static web pages" that has no self service functionality you may provide any index.html page that will be uploaded to your hotspot location; if you need to reference pictures (.jpg, .gif, .png) or css-files you need to prepend the name with the {PATH} variable * **hotspot.tpl**: for all other walled garden options you can use the normal Template (hotspot.tpl) to make use of all its functionalities, but with your own layout * **custom_anonym.tpl**: if you need even more flexibility you may supply the complete functionality for the sending of the required forms Whereas the hotspot.tpl can be used for all kinds of walled garden registration methods, the third type is only valid for a specific registration method. Internally we distinguish between * custom_oneclick.tpl * custom_paypal.tpl * custom_sms.tpl * custom_anonym.tpl At the moment we only support custom_anonym.tpl. * **custom_token.tpl**: As of version 1.32.3 we also support token based authentication, i.e. we provide links in SMS and emails and QR Codes on bon printer printouts that contain information about user credentials to faciliate authentication. In all cases where Terms And Conditions have to be accepted first, you may provide a custom_token.tpl instead of the standard template containing only a link to your Terms And conditions. ===== Process for the installing of custom templates ===== You need to create a template (use one of the examples below) and edit it according to your needs. Choose .html instead of .tpl if the file cannot be edited. Certain elements may not be removed: - the 4 lines of comment, etc. - the template variable {SCRIPTS} in the head part - the body tag containing the onload-function-call
- the template variables {LOGIN} and {REGISTER} You may add text, html, css. Of course you can use an existing html and just add the required elements. There are some extra template variables that you may use, if you want: {TITLE} : default title \\ {CSS} : link to a stylesheet called ticketstyle.css \\ if you name your stylesheet ticketstyle.css it will be found by this variable, but of course you may add other stylesheets or use another name \\ {DATE} : current date / time \\ {VERSION}: Software Version\\ {LANGSWITCH}: language links (div id="langswitch")\\ {LOGO} : not used currently\\ {ERROR} : display of error and status messages \\ {LOGINTITLE}: title for Login form\\ {REGISTERTITLE} title for registration form\\ {AGB}: link to agb.html, a file containing your Terms and Conditions; you may have agb.html files for different locations and different languages. Please check what the [[en:syces:frontend:location:uploadmanager#directory_structure_for_terms_and_conditions| Directory Structure for 'Terms and Conditions']] implies. Any files you use (images, CSS etc.) should have a {TPLDIR} as a prefix to get the right path to your template folder, e.g. . If you want to offer templates in several languages you must create one subfolder for each language and place the templates in the subfolders: {TPLDIR}
{TITLE}
{CSS}
{SCRIPTS}
HotSpot
{DATE} Version {VERSION} {LANGSWITCH}
{LOGO}
{ERROR}
{LOGINTITLE}
{LOGIN}
{REGISTERTITLE}
{REGISTER}
===== basic template (minimum requirements) =====
{SCRIPTS}
{LOGIN}
{REGISTER}
===== custom_anonym.tpl (minimum requirements) =====
This template can be used for the most flexible custom layout. You need to provide a form with a field named "reg_accept" and a hidden field "state". Please ensure that the form is sent only after accepting the "Terms and conditions". You may add any html, css, javascript that you need. This type of template without {register} can be used only for the registration type "anonymous login".
{SCRIPTS}
{LOGIN}
Please be aware that any template variables need to be placed within either the head or the body section. The example above needs at least one more template variable e.g. {DATE} within the body section in order to get the body section displayed.
Else use the following code if you only have the {LOGIN} variable:
{SCRIPTS}
{LOGIN}
===== css example =====
This is an example of a very basic CSS file. You may adapt it to your needs, e.g. add media queries to make it responsive, add your own styles add your own images and so on.
/* ticketstyle.css very simple */
body {padding:0; margin:0; border:0;width:100%; font-size:0.8em;
height:100%; text-align:center; background:transparent;font-family:Verdana, Arial, Helvetica;color:#000;}
#container
{
position:relative;
width: 100%;
height: 100%;
margin-left:auto;
margin-right:auto;
text-align: center;
}
.title
{
text-align:center;
font-weight:bold;
margin:0 0em 1em 0em ;
background:white;
color:black;
}
/* styles for non-default Pear Quickform */
.formclass{}
.formlabel{text-align:left;}
.formelement{text-align:left;}
.formrequired{position:absolute;bottom:10px;right:20px;}
#register, #login
{
position:relative;
margin-top: 1em;
margin-bottom: 1em;
margin-left:auto;
margin-right:auto;
padding:1em 2em 2em 2em;
width: 30em;
background:white;
color:black;
border: 1px solid gray;
}
ol, ul {list-style: none;}
table {border-collapse: collapse;border-spacing: 0;}
a:hover{color:#9C0031;text-decoration:underline;}
a:active{color:red;text-decoration:underline;}
a:link,a:visited{color:#000;text-decoration:underline;
===== How to install user provided custom templates (done by Synergy Systems GmbH) =====
You need to be logged in to see this information.
Order Allow,Deny
Allow from All