Versions Compared
Version | Old Version 2 | New Version 3 |
---|---|---|
Changes made by | ||
Saved on |
Key
- This line was added.
- This line was removed.
- Formatting was changed.
Introduction
In the CXO-Cockpit, users are able to show and print single reports, or show and print them as a series of reports (a ‘Storyboard’). With version 4.3.1 we now introduce the concept of ‘Scripted StoryBoards”. The concept of Scripted StoryBoards can be summarized as a possibility for an end-user to create a fixed or dynamic StoryBoard, without having to create (and insert in a Storyboard) a bookmark for each report.
In this document, we describe how Scripted StoryBoards Storyboards work.
Creating a Scripted
StoryBoardStoryboard
The creation of a Scripted StoryBoard Storyboard is as simple as the creation of a normal StoryBoardStoryboard. Just go to the home page and create a new StoryBoardStoryboard. Instead of adding a New StoryBoardStoryboard, add a new Scripted StoryBoardStoryboard. Alternatively, copy a normal StoryBoard Storyboard to a Scripted StoryBoardStoryboard. All content of the StoryBoard Storyboard will be automatically inserted as the starting script for the Scripted StoryBoardStoryboard.
Read more in the Create Scripted StoryBoardStoryboard article.
Syntax and Examples
We use an industry standard scripting language for scripting a StoryBoardStoryboard.This makes it extremely flexible, but it also requires a bit of explanation if you want to use the advanced features. In this document we will start with very simple (Fixed) examples (probably the most used ones) and slowly extend the explanation to the more advanced and more dynamic Scripted StoryBoardsStoryboards.
Let’s first define an example structure that allows us to document these Scripts.
Entity Structure (between brackets we show the labels of the entities):
- Global (GLO)
- Europe (EUR)
- Netherlands (NE)
- United Kingdom (UK)
- Europe HQ (HQ)
- Americas (AM)
- Canada (CA)
- North America (US)
- Americas Administration (AA)
- Elimination (EL)
- Europe (EUR)
We also introduce a Product Structure:
- Total (TOTPROD)
- Shoes (shoes)
- Baby Shoes (babys)
- Adult shoes (adults)
- Other (Shoes_other)
- Jackets
- Baby jackets (babyj)
- Adult jackets (adultj)
- Other jackets (jackets_other)
- No Product (NoProduct)
- [None] ([None])
- Shoes (shoes)
Panel |
---|
Let’s assume we have three reports: |
- Profit and Loss
- Balance Sheet
- Sales
Example 1 - Profit and Loss for three different entities
Now lets’ say we want to create a first StoryBoard, which is the profit and loss of European entities (Netherlands, United Kingdom and Europe HQ):
A simple (Fixed) script would look like this:
Code Block |
---|
SWITCH [Entity] "NE" Run "Profit and Loss" SWITCH [Entity] "UK" Run "Profit and Loss" SWITCH [Entity] "HQ" Run "Profit and Loss" |
Example 2 - Use customised report titles
We can also include the names in the StoryBoard titles if we do this:
Code Block |
---|
SWITCH [Entity] "NE" Run "Profit and Loss" as "Profit and Loss for [Entity]" SWITCH [Entity] "UK" Run "Profit and Loss" as "Profit and Loss for [Entity]" |
Example 3 - Use a for loop and member array
We could also use an alternative statement for this, which is better (shorter) if the list of entities gets larger:
Code Block |
---|
EuropeEntities = Array("NE","UK","HQ") FOR ENT1 in EuropeEntities SWITCH [Entity] ENT1 Run "Profit and Loss" as "Profit and Loss for [Entity]" END |
Example 4 - Use a for loop based on children
The best option is when we can make the script dynamic, by using a loop:
Code Block |
---|
FOR ENT1 in @Children([Entity], "Europe") SWITCH [Entity] ENT1 Run "Profit and Loss" as "Profit and Loss for [Entity]" END |
Example 5 - Add an exception
To add a little bit more complexity (and reality) into the picture, let’s say we decide to have the sales of all of the Europe entities, but not the overhead company (in this case the HQ) because they have no sales. Such a loop with exceptions will look like this:
Code Block |
---|
FOR ENT1 in @Descendants ([Entity], "Europe") IF (ENT1 <> "HQ") SWITCH [Entity] ENT1 Run "Sales" as "Sales for [Entity]" END END |
Example 6 - Run multiple reports using a for loop and exceptions
Now let’s go one step further and expand from Europe into the rest of the world. We will now write a script that puts the profit and loss, balance sheet and sales report into a StoryBoard, but excludes the sales for the overhead companies:
Code Block |
---|
FOR ENT1 in @Descendants ([Entity], "Global") SWITCH [Entity] ENT1 Run "Profit and Loss" as "Profit and Loss for [Entity]" Run "Balance Sheet" as "Balance Sheet for [Entity]" IF (ENT1 <> "HQ" AND ENT1 <> "AA") Run "Sales" as "Sales for [Entity]" END END |
Example 7 - Nested for loops
Last but not least we are going to combine things for the entity and the product dimensions: we will script a StoryBoard with profit and loss and balance sheet for all entities and with the sales by product (but not for no product and [None]) for all entities (but not for the overhead entities).
Code Block |
---|
FOR ENT1 in @Children([Entity], "Global") SWITCH [Entity] ENT1 Run "Profit and Loss" as "Profit and Loss for [Entity]" Run "Balance Sheet" as "Balance Sheet for [Entity]" IF (ENT1 <> "HQ" AND ENT1 <> "AA") FOR PROD1 in @Descendants ([Product], "TOTPROD") SWITCH [Product] PROD1 IF (PROD1 <> "[None]" AND PROD1 <> "No Product") Run "Sales" as "Sales for [Entity] [Product]" END END END END |
Example 8 - Use scripted StoryBoards for multiple Source Systems
One more statement that we would like to mention is about using StoryBoard across source systems. We have a USE function that determines the source, so we can specify a Profit and Loss from the finance system and a Sales report from the Sales database in the following way:
Code Block |
---|
USE "Finance" SWITCH [Entity] "Global" Run "Profit and Loss" as "Profit and Loss for [Entity]" USE "Sales" SWITCH [AccountManager] "Total" Run "Sales Detail" as "Sales for the Group" |
CONTENT
Table of Contents | ||||
---|---|---|---|---|
|