Jukebox/w3tpl: Difference between revisions
formatting improvements |
local downloads working |
||
| Line 43: | Line 43: | ||
<let name=sqlFilt append copy=doArtist /> | <let name=sqlFilt append copy=doArtist /> | ||
</else> | </else> | ||
<for db=audioferret table=" | <let name=outFunc> | ||
{| </let> | |||
<for db=audioferret table="qryTitle_Files" where=$sqlFilt sort="track, name" name=ti> | |||
<let name=outFunc append> | <let name=outFunc append> | ||
|- | |||
| '''</let> | |||
<let name=outFunc append copy=@row.ti.track /> | <let name=outFunc append copy=@row.ti.track /> | ||
<let name=outFunc append>'''. </let> | <let name=outFunc append>'''. </let> | ||
<let name=outFunc append copy=@row.ti.name /> | <let name=outFunc append copy=@row.ti.name /> | ||
<let name=outFunc append> || [</let> | |||
<let name=outFunc append copy=urlAudio /> | |||
<let name=outFunc append copy=@row.ti.filespec /> | |||
<let name=outFunc append> download]</let> | |||
</for> | </for> | ||
<let name=outFunc append> | |||
|} </let> | |||
</func> | </func> | ||
============================ | ============================ | ||
===== build the output ===== | ===== build the output ===== | ||
============================ | ============================ | ||
Turn off page cache: | Set up the environment: | ||
-- Turn off page cache: | |||
<w3tpl nocache /> | <w3tpl nocache /> | ||
-- base URL for audio files: | |||
<let name=urlAudio>smb://rizzo/shared/sdd/audio/Jukebox/content/</let> | |||
Get the input arguments: | Get the input arguments: | ||
<let name=doArtist copy=@query.artist /> | <let name=doArtist copy=@query.artist /> | ||
< | <let name=doArtist val=5 /> | ||
<let name=doAlbum copy=@query.album /> | <let name=doAlbum copy=@query.album /> | ||
< | <let name=doAlbum val=131 /> | ||
Always show the artists: | Always show the artists: | ||
| Line 77: | Line 89: | ||
</if> | </if> | ||
<if flag=doTitles> | <if flag=doTitles> | ||
<let name=out append> || '''titles'''</let> | <let name=out append> || '''titles''' (only works from our house network)</let> | ||
</if> | </if> | ||
<let name=out append> | <let name=out append> | ||
Revision as of 17:57, 9 March 2009
The Hypertwin Jukebox
is under construction, but here are all the artists <hide>
=========
functions
=========
<func GetArtists>
<for db=audioferret table="qryArtists_index" sort="name" name=ar> <let name=ar_name val="@row.ar.name" /> <let name=outFunc append>
- </let>
<if comp=@row.ar.id with=$doArtist>
<let name=chosen_artist_name copy=ar_name />
<let name=outFunc append></let>
<let name=outFunc append copy=ar_name />
<let name=outFunc append></let>
</if><else>
<let name=outFunc append vars>[$@row.ar.id$ </let>
<let name=outFunc append copy=ar_name />
<let name=outFunc append>]</let>
</for>
</func>
<func GetAlbums>
<let name=sqlFilt vars>idartist=</let> <let name=sqlFilt append copy=doArtist /> <for db=audioferret table="Albums" where=$sqlFilt sort="sort, name" name=al> <let name=al_name val="@row.al.name" /> <let name=outFunc append>
- </let>
<let name=outFunc append vars>[$doArtist$&album=[$@row.al.id$] </let> <let name=outFunc append copy=al_name /> <let name=outFunc append>]</let> </for>
</func>
<func GetTitles>
<if flag=doAlbum> <let name=sqlFilt vars>album_id=</let> <let name=sqlFilt append copy=doAlbum /> </if><else> <let name=sqlFilt vars>artist_id=</let> <let name=sqlFilt append copy=doArtist /> </else> <let name=outFunc><for db=audioferret table="qryTitle_Files" where=$sqlFilt sort="track, name" name=ti> <let name=outFunc append>
</let>
<let name=outFunc append copy=@row.ti.track /> <let name=outFunc append>. </let> <let name=outFunc append copy=@row.ti.name /> <let name=outFunc append> || [</let> <let name=outFunc append copy=urlAudio /> <let name=outFunc append copy=@row.ti.filespec /> <let name=outFunc append> download]</let> </for> <let name=outFunc append> |
</let>
</func>
================
build the output
================
Set up the environment: -- Turn off page cache: <w3tpl nocache /> -- base URL for audio files: <let name=urlAudio>smb://rizzo/shared/sdd/audio/Jukebox/content/</let>
Get the input arguments: <let name=doArtist copy=@query.artist /> <let name=doArtist val=5 /> <let name=doAlbum copy=@query.album /> <let name=doAlbum val=131 />
Always show the artists: <call GetArtists />
<let name=out>
| artists</let>
<if flag=doArtist> <let name=doTitles val=1 /> </if> <if flag=doArtist> <let name=out append vars> || albums: [$chosen_artist_name$]</let> </if> <if flag=doTitles> <let name=out append> || titles (only works from our house network)</let> </if> <let name=out append> | ||
|
</let> <let name=out append copy=outFunc /> <let name=outFunc null /> <if flag=doArtist> <call GetAlbums /> <let name=out append> |
</let>
<let name=out append copy=outFunc /> <let name=outFunc null /> </if> <if flag=doTitles> <call GetTitles /> <let name=out append> |
</let>
<let name=out append copy=outFunc /> <let name=outFunc null /> </if> <let name=out append> |
</let>
===============
show the output
===============
</hide><get name=out />
