Loading...
Use
Create
Develop
FAQ
Troubleshooting
History: Branching
View page
Source of version: 14
(current)
From Tiki 15 onwards, it is possible to include contents of other YAML files in profiles depending on branching logic. !Basic usage The basic usage is through the use of the !include directive. In YAML, the "!" preceding the string means that that is a directive and some kiind of execution is to happen, returning some kind of output that replaces the directive. The following is an extremely basic example on how it works: -+test.yml+- {CODE(colors="yaml")} preferences: feature_wysiwyg: - !include wysiwyg.yml 1 eq 1 - !include nonwysiwyg.yml {CODE} -+wysiwyg.yml+- {CODE(colors="yaml")} feature_wysiwyg: y {CODE} -+nonwysiwyg.yml+- {CODE(colors="yaml")} feature_wysiwyg: n {CODE} Each of the options of YAML files to include for a particular key (in the above case, -+feature_wysiwyg+-) is an item in a list starting with the -+!include+- directive followed by the filename (relative to the profile), and then a condition comparing 2 values using operators. If the condition is true, then it includes that YAML file and ignores the other conditions. If not it moves on to the next option and performs the test again. It is customary to provide a default YML file in case any of the preceding conditions are not met. This works pretty much is the same way as a typical CASE structure in PHP. In the above example, -+wysiwyg.yml+- will be included and therefore Wysiwyg will be on. If on the other hand: {CODE(colors="yaml")} preferences: feature_wysiwyg: - !include wysiwyg.yml 1 eq 2 - !include nonwysiwyg.yml {CODE} since 1 does not equal 2, it will default to the -+nonwysiwyg.yml+- and set -+feature_wysiwyg+- to 'n'. Note that the contents of the included YAML files should start with the same key as that to be replaced. For example, wysiwyg.yml and nonwysiwyg.yml both start with "feature_wysiwyg". !Comparison operators ; -+eq+-: equal to ; -+neq+-: not equal to ; -+lt+-: less than ; -+le+-: less than or equal to ; -+gt+-: greater than ; -+ge+-: greater than or equal to !Using references !!Checking value of preferences To build on the above, it is possible to check the value of the preference and then decide which YAML file to include. For example, {CODE(colors="yaml")} preferences: feature_wysiwyg: - !include wysiwyg.yml $preference:feature_page_title$ eq y - !include nonwysiwyg.yml {CODE} !!Checking profile input This could be especially useful when profiles are executed through ((doc:Data Channels)). The following is an example of a profile that takes an input "juicetype" and creates/updates a wiki page with content depending on whether "juicetype" is "apple" or "orange". -+juiceapp.yml+- {CODE(colors="yaml")} objects: - type: wiki_page ref: juicepage data: name: How to Make Your Favorite Juice mode: create_or_update content: - !include apple.yml $profilerequest:juicetype$orange$ eq apple - !include orange.yml {CODE} -+apple.yml+- {CODE(colors="yaml")} content: wikicontent:applejuice {CODE} -+orange.yml+- {CODE(colors="yaml")} content: wikicontent:orangejuice {CODE} -+juiceapp/applejuice.wiki+- {CODE()} These are the instructions on how to make apple juice. Make sure you have a machine juicer. Cut the apple into approximately 6 wedges. {CODE} -+juiceapp/orangejuice.wiki+- {CODE(colors="yaml")} These are the instructions on how to make orange juice. First, determine if you are using a machine juicer or a manual juicer. If you are using a manual juicer, cut the oranges into half. If using a machine juicer, peel the oranges. {CODE} !Current Limitations *Included YAML files themselves cannot contain -+!include+- statements. *There is no way to do ''boolean'' comparisons !!! Alias (alias(Conditional Include)) (alias(Conditions))
Menu
Featured profiles
Profiles in Wizard
Profiles Todos
Handlers
Profiles Tester
Admin
of this site
Current Profiles
Tiki version
21.x
24.x
26.x
27.x
28.x
Deprecated
25.x
state
Not fully functional yet
alpha
beta
release
type
Available in the Profiles Wizard (12+)
Featured profiles
Full profile (out of the box & ready to go)
Learning profile (to show off feature)
Long tail
Mini-profile (can be included in other)
Profile-snippet (optional but needs another "parent" profile)
Security
Tests
Latest Changes
Voting_System
test_profile_change
Test_all_tracker_field_types_profile
Scheduler_Presets_20
Tracker_as_Calendar_09
Tracker_as_Calendar_10
Hide Fixed Top Nav Bar on Scroll 19
Easy_GeoBlog
Profiles_in_Wizard
Random_header_images_14
Hide Fixed Top Nav Bar on Scroll 19
How to Create Profiles
Test_All_Plugins
JonnyBs_Luxury_Tiki_Setup
...more
Like almost all *.tiki.org sites, you can log in with your login from
https://tiki.org
(register over there)
Search
Find
Most Popular Tags
admin
agenda
alias
antibot
antibot captcha
app
archive
articles
banning
batch
blogs
calculations
calendars
cart
categories
cluster
codemirror
comments
computation
contact us
datachannel
debug
debug console
dropdown with other
error messages
features
file galleries
forums
geo
geocms
geolocation
group homepages
group watches
header
i18n
images
item link
items list
jquery
languages
location
map
maps
maths
menu
menupage
multilingual
ol3
ol5
openlayers
paypal
plugin
plugin alias
plugin datachannel
plugin fade
plugin tabs
plugin trackerlist
pretty trackers
print
project management
r
r project
realnames
rss
static
static text
statistics
stats
structures
syntax highlighter
tablesorter
template
trackers
user watches
visualization
watches
webservice
wiki
wiki argument variables
wiki structures
Tiki Newsletter
Subscribe to the Tiki newsletter.
Don't miss major announcements and other news!