Module:Performances/doc

From Angelina Jordan Wiki

This is the documentation page for Module:Performances

This is a subpage documenting Module:Performances. To change the module, edit that page; to change the module's documentation (seen below), edit this one.

Work in Progress!!

This module is supposed to provide access to the list of performances Angelina did. At the heart of it is a very generic, configurable table-generator, that could also be used in different contexts.

Usage

Overview

{{#invoke: Performances | createTable        -- createTable is the generic table generator
  |page=Data:Performances.json               -- link to page with JSON data
  |supplements=Data:VideoMetaData.json;url   -- supplemental data sources
  |headers=Song,Date,Type,With,Video         -- List of titles used in the group section headers
  |keys=[[<song>]],{{d|<date>}},<type>,<with>,[<url> <song> - <event>] -- computed data items corresponding to those titles
  |sort=<date>                               -- computed sort keys for sorting outer table
  |sort1=<date>                              -- (optional): outer sortkey, same as inner if omitted
  |filters=date:2018,event:Kongsberg         -- filters to select what items are displayed
  |char_limit=7                              -- The amount of characters of the sort key considered for grouping the sections
  |char_limit1=4                             -- (optional): outer char limit, no outer grouping if ommited 
  |caption=Kongsberg 2018 by Month           -- Title displayed in Header of outer Table
  |group_sort=<date> ! <type> ! <pos>        -- how the group section sub-tables are sorted
  |id=1                                      -- Id needed if multiple tables are generated within a page
}}

Options

page: Provides page that contains JSON formated input data.

supplements (optional): comma seperated list of supplemental data source entries of "supplementalDataPage;keyName:charLimit;targetKeyName", with charLimit and targetKeyName being optional. Data from the supplemental source will be matched based on the keys (if the target's key name is ommitted, the same will be used). The charLimit option shortens the primary key value to this amount of characters. The target data can also be in a form, where the matching key data is used as keys itself instead of value of a "key" field.

headers: Comma seperated list of titles used in the group section headers.

keys: Comma seperated list of computed fields used for the colums in group sections defined by the corrosponding headers. Number of entries should match the number of headers.

Key names representing data are enclosed in "<",">" brackets. Nested structures can be accessed, e.g. <list[1].value> will return the data of the "value" field of the 1st element of the "list" field. Each field can reference multiple keys. For the key's values, filters can be defined by appending them with the pipe symbol. Filters use the syntax as in the filters option (see below), with the result that non-matching data will return an empty string. Substitutions can be appended by colons, a pair of strings will be interpretated as the search and replacement strings for a gsub() substition with lua pattern matching. The special keywords toUpper, toLower, and toTitleCase will perform the appropriate conversions. Several substitutions can be concatenated.

Other text will be still interpreted e.g. as templates.

sort: Computed sort fields for sorting outer table, and for labeling of section names. Same syntax as for keys.

char_limit (optional): The amount of characters of the sort key considered for grouping the sections. This will also affect the displayed section name.

filters: Comma seperated list of filters to select what items are displayed. A filter is described by "keyname:values". Alternatives within an filter value item can be described with "/". Negations can be described with "!( . )".

sort1 (optional): Outer sortkey. If ommited, the inner sort key will be used.

char_limit1 (optional): The amount of characters of the sort key considered for the outer grouping. This will also affect the displayed section name.

If ommited, no outer grouping will be performed.

id: A unique Id for each table is needed if multiple tables are generated within a page, to provide a basis for unique section ids.

caption (optional): Title displayed in the header of the outer table

group_sort: Computed field. that determines how the group section sub-tables are sorted. Same syntax as for keys.

Features

The generated table may have one or two levels of grouping, and up to three levels of sorting. It has the follwing structure, with the outer grouping being optional (click on the [n Items] buttons to reveal the inner collapsed tables):

Caption (provided as parameter)
1 (outer grouping level seperator)
A (inner grouping level header) [2 Items]
B (inner grouping level header) [1 Item]
2 (outer grouping level seperator)
C (inner grouping level header) [1 Item]

The inner tables are enclosed in

<div youtube-player-placeholder> ... </div> 

tags, which can optionally be used by Javascript code contained in a Gadget (MediaWiki:Gadget-embeddedYouTubePlayer.js) to attach an embedded YouTube player to each section, that is loaded with a playlist of any YouTube video link contained in that section. Clicking on those links will then also load and start the linked video in that player.

Each grouping separator/header will set an anchor id, so that the table rows can be jumped at with internal references, e.g. C.

There is also code available, that will expand the inner table of a jump target when jumped to.

ToDo

  • Make sorting more flexible, e.g. by applying regex substitutions to data values before being sorted.
  • Have an option, to not start collapsed (usefull for small tables)
  • Implement access to sublists below keys.
  • provide default values for empty fields of computed fields, e.g. like <keyName=defaultValue>
  • Provide a means to print additional data behind the sort field that does not effect the id-anchor

Examples

Multiple Filters, combined as AND

{{#invoke: Performances | createTable
  |page=Data:Performances.json
  |headers=Song,Date,Type,With,Video
  |keys=[[<song>]],{{d|<date>}},<type>,<with>,[<url> <song> - <event>]
  |sort=<date>
  |filters=date:2018,event:Kongsberg
  |char_limit=7
  |caption=Kongsberg 2018 by Month
  |group_sort=<date> ! <type> ! <pos>
  |id=1
}}
Kongsberg 2018 by Month
2018-06 [12 Items]
2018-07 [22 Items]


Single Event with Supplemental Video Metadata

{{#invoke: Performances | createTable
  |page=Data:Performances.json
  |supplements=Data:VideoMetaData.json;url:43
  |headers=Song,Date,Type,Video
  |keys=[[<song>]],{{d|<date>}},<type>,[<url> <url-title>; <url-User>]
  |sort=<event>
  |group_sort=<date> ! <type> ! <pos> ! <song>
  |filters=event:Bjerke
  |id=2
}}

Alternatives in Filters, combinded as OR

{{#invoke: Performances | createTable
  |page=Data:Performances.json
  |headers=Song,Date,Type,Comment
  |keys=[[#<song>|<song>]],{{d|<date>}}: <pos>,<type> <duration> [<url> play],<comment>; <with>
  |sort=[[<event>]]
  |caption=Repetitive Live Events
  |group_sort=<date> ! <type> ! <pos> ! <song>
  |filters=event:Allsang på Grensen/TV 2's Artist Gala
  |id=3
}}
Repetitive Live Events
Allsang på Grensen [7 Items]
TV 2's Artist Gala [2 Items]

Demonstrating Different Outer Sorting/Grouping and Negation in Filters

In the following example, the highest level (sort1) is sorted by year, then the middle one (sort) by date, as well as the inner table one, which also features secondary sorting keys (type, pos, song). The seperator "!" that was chosen for these has no special meaning, but it is the lowest character encoding value above a space, which should ensure that the correct sorting is applied.

"duration:!(fragment)" is used for filtering for those videos, that are not fragments.

Also, wie use substitutions to the computed "url" field

{{#invoke: Performances | createTable
  |page=Data:Performances.json
  |headers=Song,Date,Type,Comment,Video
  |keys=[[#<song>|<song>]],{{d|<date>}}; <pos>,<type> <duration>, <comment>; <with>,[<url> <url:.*www.: :.com.*: >]
  |sort=[[<event>]]
  |sort1=<date>
  |char_limit1=4
  |filters=type:live,duration:!(fragment)
  |caption=Live Events by Year, excluding fragments
  |group_sort=<date> ! <type> ! <pos> ! <song>
  |id=4
}}
Jump to… 2013 – 2014 – 2015 – 2016 – 2017 – 2018 – 2019 – 2020 – 2021 – 2022 – 2023 – 2024
Live Events by Year, excluding fragments
2013
VAD Festival 1 Dec 2013 [1 Item]
2014
Allsang på Grensen [1 Item]
Christmas 2014 NRK TV [1 Item]
Concert for UN summit 2014 [1 Item]
Ein Herz für Kinder [1 Item]
FMC Technology (Kongsberg Jazz Festival) 2014 [3 Items]
Good Morning Norway [1 Item]
Kongsberg Jazz Festival 2014 [2 Items]
New Year's celebration 2014/15 [1 Item]
Norway's Got Talent [5 Items]
Nyhetsmorgon [1 Item]
Orkla Growth Awards [1 Item]
Prime Minister [3 Items]
Save the Children Peace Prize Party [2 Items]
Schwedish Heros [2 Items]
Senkveld [1 Item]
Shopping center, Norway 2014 [1 Item]
Sommerkveld Med Redningsskøyta [1 Item]
The View [1 Item]
TV 2's Artist Gala [1 Item]
Unknown concert [3 Items]
2015
Encontro com Fátima Bernardes [1 Item]
Hagekonsert på Aksept [1 Item]
Hemnes Båt & Fjord Festival [10 Items]
Jotun Plant Opening [3 Items]
Lindmo [1 Item]
Mediacorps Campus Opening [1 Item]
Victoria Scene, Oslo [1 Item]
2016
100k Follower Facebook live [1 Item]
Alan Walker Is Heading Home [2 Items]
Allsang på Grensen [1 Item]
Clarion Hotel [1 Item]
God Sommer Norge [1 Item]
Instagram Live Stream [2 Items]
Kongsberg Jazz Festival 2016 [10 Items]
Lille Julaften [1 Item]
Little Big Shots [1 Item]
Little Big Shots UK [1 Item]
Rotary Club Convention 2016, Seoul [3 Items]
Salvation Army's Christmas Pot [2 Items]
The Stream Gir Tilbake [1 Item]
TV 2's Artist Gala [1 Item]
Wish Concert [1 Item]
2017
Allsang på Grensen [2 Items]
Christmas concert tour 2017 [32 Items]
Dojima River Forum [1 Item]
Little Big Stars [1 Item]
Muse in City [8 Items]
New Year's concert 2017 [3 Items]
Nor Shipping Conference, Oslo [2 Items]
NRK Radio Interview 2017 [3 Items]
Summer concert tour 2017 – Larkollen [16 Items]
Summer concert tour 2017 – Prøysenfestivalen [13 Items]
Summer concert tour 2017 – Sandefjord [12 Items]
2018
Christmas concerts 2018 [19 Items]
Concert in LA [2 Items]
It's Magic concert [14 Items]
Jake and Rachel's Wedding [2 Items]
Kongsberg Jazz Festival 2018 [13 Items]
Lyden av Norge, P4 Radio [1 Item]
Quincy Jones 85th birthday concert [2 Items]
Skavlan [1 Item]
TechnipFMC Jazzfest (Kongsberg Jazz Festival 2018) [3 Items]
2019
America's Got Talent, The Champions 2 [3 Items]
ÅrsteinØYA 2019 [1 Item]
Summer concert tour 2019 – Prøysenhuset [14 Items]
2022
20th Unforgettable Gala [2 Items]
Allsang på Grensen [2 Items]
Kongsberg Jazz Festival 2022 [15 Items]
Kurbadhagen, Sandefjord [31 Items]
2023
A tribute to Narges Mohammadi (Noble Peace Price 2023) [2 Items]
Germany's Next Top Model 2023 [1 Item]
Le Bal Paris 2023 [1 Item]
Mathias Sorum's birthday party [2 Items]
PM International's President's Gala, Mannheim Germany [1 Item]
Portsmouth 2023 [4 Items]
The Best FIFA Football Awards™ 2022 [1 Item]
2024
Christmas Special 2024 [19 Items]
Glendale 2024 [21 Items]
IVARS Awards Backstage [1 Item]
Jesse & Friends @ The Hotel Cafe [2 Items]
Las Vegas 2024 [38 Items]
Sofar London, The Hoxton Hotel Shoreditch [1 Item]
St. Pancras station, London [4 Items]
The Other Songs, London Palladium [1 Item]
Wish Bus USA [2 Items]
Jump to… 2013 – 2014 – 2015 – 2016 – 2017 – 2018 – 2019 – 2020 – 2021 – 2022 – 2023 – 2024

Demonstrating Same Type Sorting, with Different Grouping Levels, and Supplemental Data

Here, the different char_limits on the sorting of song lead to two different grouping levels, by 1st character and by unique title.

{{AtoZ}}
{{#invoke: Performances | createTable
  |page=Data:Performances.json
  |supplements=Data:SongsToVideos.json;song;title,Data:VideoMetaData.json;url:43  |headers=Event,Date,Type,Video,Pos,With,Comment
  |keys=[[#<event>|<event>]],{{d|<date>}},<type> <duration>,[<url> play <song-type>],<pos>,<with>,<comment>; <url-channelName>
  |sort=[[<song>]]
  |char_limit1=1
  |caption=Live Songs, excluding fragments
  |group_sort=<date> ! <type> ! <pos>
  |filters=duration:!(fragment),type:live
  |id=5
}}
{{AtoZ}}

Note: This does no longer work, as the videos have been stripped of the supplemental data page, and the page was renamed and is this not found.


A · B · C · D · E · F · G · H · I · J · K · L · M · N · O · P · Q · R · S · T · U · V · W · X · Y · Z

Error: Failed to load JSON from Data:SongsToVideos.json (Page not found or empty)

A · B · C · D · E · F · G · H · I · J · K · L · M · N · O · P · Q · R · S · T · U · V · W · X · Y · Z