Difference between revisions of "Buttons"
From Tweeki
								
												
				| (26 intermediate revisions by the same user not shown) | |||
| Line 1: | Line 1: | ||
| [[Category:Components]] __FORCETOC__ | [[Category:Components]] __FORCETOC__ | ||
| − | With  | + | With Tweeki it is very easy to create any button you would like to have. By using smart defaults the markup can be very reduced. | 
| − | <div class="alert alert-info" role="alert">This feature bypasses MediaWiki's default link handling. This might have security implications. You should only allow editing to people you trust! Also features like 'Links to this site' will not work for button links.</div> | + | <div class="alert alert-info" role="alert"><strong>Caveat:</strong> This feature bypasses MediaWiki's default link handling. This might have security implications. You should only allow editing to people you trust! Also features like 'Links to this site' will not work for button links.</div> | 
| == Standard Buttons == | == Standard Buttons == | ||
| − | {| class= | + | {| class="table table-bordered" | 
| ! Markup !! Result | ! Markup !! Result | ||
| |- | |- | ||
| Line 17: | Line 17: | ||
| | | | | ||
| <pre> | <pre> | ||
| − | <btn size=" | + | <btn size="lg">Large Button</btn> | 
| − | <btn size=" | + | <btn size="sm">Small Button</btn> | 
| − | |||
| </pre> | </pre> | ||
| | | | | ||
| − | + | <btn size="lg">Large Button</btn> | |
| − | <btn size=" | + | <btn size="sm">Small Button</btn> | 
| − | |||
| |- | |- | ||
| | | | | ||
| Line 67: | Line 65: | ||
| Classy | Classy | ||
| Buttons | Buttons | ||
| + | </btn> | ||
| + | |- | ||
| + | | | ||
| + | <pre> | ||
| + | <btn class=""> | ||
| + | Button without any class | ||
| + | </btn> | ||
| + | </pre> | ||
| + | | | ||
| + | <btn class=""> | ||
| + | Button without any class | ||
| </btn> | </btn> | ||
| |- | |- | ||
| Line 102: | Line 111: | ||
| == Dropdown Buttons == | == Dropdown Buttons == | ||
| − | {| class= | + | {| class="table table-bordered" | 
| ! Markup !! Result | ! Markup !! Result | ||
| |- | |- | ||
| Line 110: | Line 119: | ||
| Dropdown-Menu | Dropdown-Menu | ||
| * Some Menu Item | * Some Menu Item | ||
| − | |||
| * | * | ||
| + | *: Some Heading | ||
| * Some Other Menu Item | * Some Other Menu Item | ||
| </btn> | </btn> | ||
| Line 119: | Line 128: | ||
| Dropdown-Menu | Dropdown-Menu | ||
| * Some Menu Item | * Some Menu Item | ||
| − | |||
| * | * | ||
| + | *: Some Heading | ||
| * Some Other Menu Item | * Some Other Menu Item | ||
| </btn> | </btn> | ||
| Line 157: | Line 166: | ||
| </btn> | </btn> | ||
| </pre> | </pre> | ||
| + | <small>'''Note:''' this only works with the [https://www.semantic-mediawiki.org/wiki/Semantic_MediaWiki Semantic MediaWiki] extension installed. | ||
| | | | | ||
| <btn> | <btn> | ||
| Line 166: | Line 176: | ||
| == Wrappers == | == Wrappers == | ||
| − | {| class= | + | {| class="table table-bordered" | 
| ! Markup !! Result | ! Markup !! Result | ||
| |- | |- | ||
| Line 184: | Line 194: | ||
| | | | | ||
| <pre> | <pre> | ||
| − | <btn wrapperclass=" | + | <btn wrapperclass="btn-group-vertical"> | 
| Explicit | Explicit | ||
| Wrapper | Wrapper | ||
| Line 191: | Line 201: | ||
| </pre> | </pre> | ||
| | | | | ||
| − | <btn wrapperclass=" | + | <btn wrapperclass="btn-group-vertical"> | 
| Explicit | Explicit | ||
| Wrapper | Wrapper | ||
| Line 210: | Line 220: | ||
| Wrapper | Wrapper | ||
| Unsetting | Unsetting | ||
| + | </btn> | ||
| + | |} | ||
| + | |||
| + | == Styling == | ||
| + | |||
| + | {| class="table table-bordered" | ||
| + | ! Markup !! Result | ||
| + | |- | ||
| + | | | ||
| + | <pre> | ||
| + | <btn> | ||
| + | Target|<i>Italic Tag</i> | ||
| + | </btn> | ||
| + | </pre> | ||
| + | | | ||
| + | <btn> | ||
| + | Target|<i>Italic Tag</i> | ||
| + | </btn> | ||
| + | |- | ||
| + | | | ||
| + | <pre> | ||
| + | <btn> | ||
| + | Target|''Italic Wiki Markup'' | ||
| + | </btn> | ||
| + | </pre> | ||
| + | | | ||
| + | <btn> | ||
| + | Target|''Italic Wiki Markup'' | ||
| + | </btn> | ||
| + | |- | ||
| + | | | ||
| + | <pre> | ||
| + | ''<btn> | ||
| + | Surrounding Italic Wiki Markup | ||
| + | </btn>'' | ||
| + | </pre> | ||
| + | | | ||
| + | ''<btn> | ||
| + | Surrounding Italic Wiki Markup | ||
| + | </btn>'' | ||
| + | |} | ||
| + | |||
| + | == Icons == | ||
| + | |||
| + | {| class="table table-bordered" | ||
| + | ! Markup !! Result | ||
| + | |- | ||
| + | | | ||
| + | <pre> | ||
| + | <btn> | ||
| + | Target|<span class="glyphicon glyphicon-cog"></span> icon with span | ||
| + | Target|<span class="fa fa-cog"></span> icon with span | ||
| + | </btn> | ||
| + | </pre> | ||
| + | | | ||
| + | <btn> | ||
| + | Target|<span class="glyphicon glyphicon-cog"></span> icon with span | ||
| + | Target|<span class="fa fa-cog"></span> icon with span | ||
| + | </btn> | ||
| + | |- | ||
| + | | | ||
| + | <pre> | ||
| + | <btn icon="cog"> | ||
| + | icon attribute | ||
| + | </btn> | ||
| + | </pre> | ||
| + | <small>'''Note:''' the icon attribute is just a synonym for 'glyphicon' for Boostrap 3 and 'fa' for Bootstrap 4. | ||
| + | | | ||
| + | <btn icon="cog"> | ||
| + | icon attribute | ||
| + | </btn> | ||
| + | |- | ||
| + | | | ||
| + | <pre> | ||
| + | <btn glyphicon="cog"> | ||
| + | glyphicon attribute | ||
| + | </btn> | ||
| + | </pre> | ||
| + | | | ||
| + | <btn glyphicon="cog"> | ||
| + | glyphicon attribute | ||
| + | </btn> | ||
| + | |- | ||
| + | | | ||
| + | <pre> | ||
| + | <btn fa="cog"> | ||
| + | fa attribute | ||
| + | </btn> | ||
| + | </pre> | ||
| + | | | ||
| + | <btn fa="cog"> | ||
| + | fa attribute | ||
| + | </btn> | ||
| + | |} | ||
| + | |||
| + | == Parsing == | ||
| + | {| class="table table-bordered" | ||
| + | ! Markup !! Result | ||
| + | |- | ||
| + | | | ||
| + | <pre> | ||
| + | <btn> | ||
| + | {{fullurl:{{PAGENAME}}}}|{{ucfirst:magic words}} | ||
| + | </btn> | ||
| + | </pre> | ||
| + | | | ||
| + | <btn> | ||
| + | {{fullurl:{{PAGENAME}}}}|{{ucfirst:magic words}} | ||
| + | </btn> | ||
| + | |- | ||
| + | | | ||
| + | <pre> | ||
| + | <btn> | ||
| + | mainpage | ||
| + | </btn> | ||
| + | </pre> | ||
| + | <small><b>Info</b>: if a system message by that name exists, the text will be replaced by it's content</small> | ||
| + | | | ||
| + | <btn> | ||
| + | mainpage | ||
| </btn> | </btn> | ||
| |} | |} | ||
Revision as of 21:59, 17 December 2019
With Tweeki it is very easy to create any button you would like to have. By using smart defaults the markup can be very reduced.
Caveat: This feature bypasses MediaWiki's default link handling. This might have security implications. You should only allow editing to people you trust! Also features like 'Links to this site' will not work for button links.
Standard Buttons
| Markup | Result | 
|---|---|
| <btn>Simple Button</btn> | |
| <btn size="lg">Large Button</btn> <btn size="sm">Small Button</btn> | |
| <btn> Grouped Buttons </btn> | |
| <btn> Button Tool Bar </btn> | |
| <btn class="btn-primary"> Classy Buttons </btn> | |
| <btn class=""> Button without any class </btn> | |
| <btn> Classy||btn-primary Non-classy Very Classy||btn-success </btn> | |
| <btn> Standard Button Some Page Title|Internal Target http://some.where|External Target </btn> | 
Dropdown Buttons
| Markup | Result | 
|---|---|
| <btn> Dropdown-Menu * Some Menu Item * *: Some Heading * Some Other Menu Item </btn> | |
| <btn> Target|Split Dropdown * Some Menu Item </btn> | |
| <btn class=""> Non-Button Dropdown * Some Menu Item </btn> | |
| <btn>
Semantic Dropdown
* {{#ask:[[Category:Components]]}}
</btn>
Note: this only works with the Semantic MediaWiki extension installed. | 
Wrappers
| Markup | Result | 
|---|---|
| <btn wrapperclass="btn-group dropup"> Dropup * Some Menu Item </btn> | |
| <btn wrapperclass="btn-group-vertical"> Explicit Wrapper Setting </btn> | |
| <btn wrapper=""> Explicit Wrapper Unsetting </btn> | 
Styling
| Markup | Result | 
|---|---|
| <btn> Target|<i>Italic Tag</i> </btn> | |
| <btn> Target|''Italic Wiki Markup'' </btn> | |
| ''<btn> Surrounding Italic Wiki Markup </btn>'' | 
Icons
| Markup | Result | 
|---|---|
| <btn> Target|<span class="glyphicon glyphicon-cog"></span> icon with span Target|<span class="fa fa-cog"></span> icon with span </btn> | |
| <btn icon="cog"> icon attribute </btn> Note: the icon attribute is just a synonym for 'glyphicon' for Boostrap 3 and 'fa' for Bootstrap 4. | |
| <btn glyphicon="cog"> glyphicon attribute </btn> | |
| <btn fa="cog"> fa attribute </btn> | 
Parsing
| Markup | Result | 
|---|---|
| <btn>
{{fullurl:{{PAGENAME}}}}|{{ucfirst:magic words}}
</btn>
 | |
| <btn> mainpage </btn> Info: if a system message by that name exists, the text will be replaced by it's content | 
Specifications
The general structure for the code of a single button is target|text|class, where text and class are optional. If text is omitted it is assumed to be the same as target. target and text are parsed after the following algorithm.
- Check for semantic queries.
- If there is an existing or default interface message with that name, use the content of that message instead.
- Parse it.
- If it is a valid URL (beginning with http:// or other URL protocol), the link will point to that URL.
- Else, it will be treated as a wikilink.