|
|
|
PatternSkin CustomizationGuidelines how to create and customize page templates. For styling your Foswiki using stylesheets, see PatternSkinCssCookbook.First Read: How to modify PatternSkin templatesEverything you see on the common 'view' page is written by theview template. For pattern skin this file is /templates/view.pattern.tmpl .
We describe two approaches to override this template:
The template approachTo change templates you will need shell access. If you don't have this read on below in The topic template approach. The quickest way to change the view template would be to simply change the text in the template. A safer way - strongly recommended, because it will survive a Foswiki update - is to create your own custom skin. That may sound like an awful lot of work, but in reality a skin may be as much as 1 file that consists of only a few lines of code. ExampleLet's say you want to simplify the bottom toolbar and remove all links except for "More topic actions". You would need to target %TMPL:DEF{"topicactionbuttons"}% , which is located in view.pattern.tmpl .
The steps you would need:
Test by appending* Set COVER = myskinor write* Set SKIN = myskin,pattern ?cover=myskin to the url.
The topic template approach (using VIEW_TEMPLATE)Template overrides can be written in a topic, a so-called topic template. Topic template names end withViewTemplate , for instance BlogPostViewTemplate .
Call this template by setting VIEW_TEMPLATE :
* Set VIEW_TEMPLATE = BlogPostView
OnlyMoreView , write:
You can also test this by appending%TMPL:INCLUDE{"view"}% %TMPL:DEF{"top:toolbarbuttons"}%%TMPL:P{"more_link"}%%TMPL:END% ?template=OnlyMoreView to the url.
Reference: pattern skin template INCLUDE treeTheview script invokes the view template:
view foswiki css viewtopbar %SYSTEMWEB%.WebTopBar viewsidebar %WEB%.WebLeftBar viewtopicactionbuttons viewbottombar %SYSTEMWEB%.WebBottomBar LogoHow can I change the web logo?By default the logo at the top left of each web points to the image with namelogo.gif that is attached to each web's WebPreferences. The preference settings that cause this behavior are defined in DefaultPreferences. Redefine your custom preference settings in Main.SitePreferences (to keep DefaultPreferences intact): There are 2 ways to change the logo in a web: Using logo.gif:* Set WEBLOGONAME = logo.gif * Set WEBLOGOIMG = %PUBURLPATH%/%BASEWEB%/%WEBPREFSTOPIC%/%WEBLOGONAME% * Set WEBLOGOURL = %SCRIPTURLPATH{"view"}%/%BASEWEB%/%HOMETOPIC% * Set WEBLOGOALT = Home Using a new filename:
How do I set a site-wide logo?There are a bunch of site-wide logo preference settings in Main.SitePreferences:WIKILOGOIMG , WIKILOGOURL and WIKILOGOALT .
To change only the web logo image to site-wide, in Main.SitePreferences set:
* Set WEBLOGOIMG = %WIKILOGOIMG% My logo does not fit the top barSee I want to change the height of the top barI want to change the white space above and below the logoChange the table style in topic WebTopBar?. The default top padding is 11px.Top barThe search box won't find topics in other websIn WebTopBar? you can find the line:<input type="hidden" name="web" value="%BASEWEB%" />To search all webs, write: To search a couple of webs, for instance the webs Main and System, write:<input type="hidden" name="web" value="all" /> See also: Search macro<input type="hidden" name="web" value="Main,System" /> I want to change the height of the top barThis information has moved to PatternSkinCssCookbookI want to set or change the top background imageThe image at the top is called "header art" - commonly the top image found on blog sites. The image that is displayed by default is set by the preferenceWEBHEADERART , defined in DefaultPreferences.
Redefine your custom preference settings in Main.SitePreferences (to keep DefaultPreferences intact):
You can also set* Set WEBHEADERART = %PUBURLPATH%/%SYSTEMWEB%/PatternSkin/Foswiki_header.gif * Set WEBHEADERBGCOLOR = somehexcolor (no quotes, for example: #ffffff) WEBHEADERART per web, by setting the preference in the Web's WebPreferences.
I want to have the web color in the top barRedefineWEBHEADERBGCOLOR in Main.SitePreferences (to keep DefaultPreferences intact):
* Set WEBHEADERBGCOLOR = %WEBBGCOLOR% I want to remove the Jump and Search boxes from the top barIf you have localization enabled, you will also see a language dropdown box at the far right. You can remove these items from WebTopBar?.I want to hide the top barUsing templates: The view template is populated with page elements using template inclusions:%TMPL:INCLUDE{"view"}% %TMPL:INCLUDE{"viewtopicactionbuttons"}% %TMPL:INCLUDE{"viewtopbar"}% %TMPL:INCLUDE{"viewsidebar"}%Each included template draws a part of the screen. Omit %TMPL:INCLUDE{"viewtopbar"}% to hide the top bar.
Another approach is to clear the contents of module topbar with an empty definition. Using either a template or a topic template, write in your custom template:
Using style sheets:%TMPL:INCLUDE{"view"}% %TMPL:DEF{"topbar"}%%TMPL:END%and add:%TMPL:DEF{"topbardimensions"}%#patternTopBar, #patternClearHeaderCenter, #patternClearHeaderLeft, #patternClearHeaderRight, #patternTopBarContentsOuter { height:0px; }%TMPL:END% See PatternSkinCssCookbookNoTopBar Left barI want to hide the side barUsing templates:Omit %TMPL:INCLUDE{"viewsidebar"}% to hide the side bar, or in a custom template clear it using
Using style sheets:%TMPL:DEF{"sidebar"}%%TMPL:END% See PatternSkinCssCookbookNoLeftBar ButtonsI want to hide the edit buttons from certain usersIt may defy the wiki-ness of your Foswiki installation, but in certain circumstances it could be useful to hide the edit buttons from users that are not logged in, for instance for clients that have gotten viewing rights only. Using either a template or a topic template, 'empty'top:toolbarbuttons and topicaction by writing:
In the user page of WikiGuest, set the cover to%TMPL:INCLUDE{"view"}% %TMPL:DEF{"top:toolbarbuttons"}%%TMPL:END% %TMPL:DEF{"topicaction"}%%TMPL:END% By default this topic is editable only by Wiki admins.* Set COVER = customer I want to remove the History button from the bottomAll action links and buttons are defined inviewtopicactionbuttons.tmpl . The bottom history link is defined in DEF action_revisions
To hide that link, In a custom skin view template%TMPL:DEF{"topicactionbuttons"}% %TMPL:P{"action_activatable_edit_or_create"}% %TMPL:P{"action_activatable_attach"}% %TMPL:P{"action_printable"}% %TMPL:P{"action_revisions"}% %TMPL:P{"action_backlinks_simple"}% %TMPL:P{"action_raw_or_view"}% %TMPL:P{"action_activatable_raw_edit"}% %TMPL:P{"activatable_more"}% %TMPL:END% view.myskin.tmpl empty action_revisions by replacing it with an empty string:
%TMPL:INCLUDE{"view"}% %TMPL:DEF{"action_revisions"}%%TMPL:END% I want to put the bottom links as buttons at the topThe default definition inview.pattern.tmpl is:
%TMPL:DEF{"top:toolbarbuttons"}%%TMPL:P{"activatable_edit_or_create"}%%TMPL:P{"activatable_attach"}%%TMPL:END%Create a new skin by creating a file view.myskin.tmpl in the templates directory. Write in it:
View any topic with%TMPL:INCLUDE{"view"}% %TMPL:DEF{"top:toolbarbuttons"}%%TMPL:P{"history_history_link"}%%TMPL:END% ?skin=myskin,pattern , or set the SKIN preference to myskin,pattern .
This will remove the Edit and Attach buttons, and place a History button at the top.
You will probably not just want to have the History button there. Other button include names are:
create_topic_link raw_edit_link view_topic_link activatable_attach activatable_edit_or_create more_link activatable_printable backlinks_web_link backlinks_all_link backlinks_link history_rdiff_link history_history_link raw_link Other page partsI want to insert text outside of the topic contentPatternSkin has 2 'buckets' to write additional content to:contentheader and contentfooter , both defined in view.pattern.tmpl . These containers can contain text or html and are placed directly before and after the topic text.
Both modules are wrapped in CSS containers:
So our custom template contains: Use the same procedure for contents to be put after the topic text:%TMPL:INCLUDE{"view"}% %TMPL:DEF{"contentheader"}%This is the text before%TMPL:END% %TMPL:INCLUDE{"view"}% %TMPL:DEF{"contentfooter"}%This is the text after%TMPL:END% I want to place the form at the topPattern skin has 2 buckets for the form:formtop (form at the top) and formbottom (form at the bottom). The default definition is:
You simply swap the bucket contents. Using either a template or a topic template, write in your custom template:%TMPL:DEF{"formtop"}%%TMPL:END% %TMPL:DEF{"formbottom"}%%TMPL:P{"form"}%%TMPL:END% %TMPL:INCLUDE{"view"}% %TMPL:DEF{"formtop"}%%TMPL:P{"form"}%%TMPL:END% %TMPL:DEF{"formbottom"}%%TMPL:END% DBCachePlugin: PatternSkinCustomization not found
|