ScheduledPages

Background and rationale

The schedule parser provides a method to set release and withdrawal dates of pages for read-only users, however, maintaining a moderate number of scheduled pages could prove troublesome. For example, resource pages for a training course might need to have their schedules updated each time the course is run. So, a page listing macro would help in the maintenance of these schedules. This macro was based on the WantedPages macro of Juergen Hermann, which has a similar intent.

Description

This macro creates a list of pages that have been scheduled using processing instructions, either as '#format schedule' (see plugin parser schedule.py) or '#schedule' (also see PiSchedule and modified page.py with new the processing instruction, #schedule, and special page type hidden).

The numbered list includes a link to the scheduled page followed by scheduling arguments and status. If it is currently viewable by read-only users, then 'show = True'. If it is set to silent (i.e. users are not warned the page is not visible by of the scheduling, then 'silent = True'). If the scheduling arguments have a syntax error, then a warning is given. In such cases, the schedule parser makes the conservative decision to set 'show = False'. However, if not scheduling arguments were given the list says, 'schedule = none' and 'show = True'.

If the page has been indirectly scheduled by pointing to a Schedule page (e.g., #schedule SomethingSchedule), then the schedule is preceded by this information as 'source = SomethingSchedule' with the Schedule page name as an active link to that page.

The list can be sorted either alphabetically by page name (default) or chronolocially by the schedule arguments, i.e. the release ('after') date.

Usage

<<ScheduledPages>>

<ScheduledPages>> - produces a list of pages that have scheduled for release by invoking this parser via processing instructions.

Example

Assume the date is after 3 Jan 2019 and before 1 Jan 2020, and the wiki has the pages as tabulated below.

Page

Processing instructions

SandBox/ScheduleCorrect

#format schedule 2018-01-03 2020-01-01

SandBox/ScheduleError

#format schedule 2018-01-01 2020-01-01a

SandBox/SchedulePI

#format wiki
#schedule 2019-01-01 2019-01-03

SandBox/SchedulePage

#format wiki
#schedule TestSchedule

SandBox/UnSchedulePage

#format wiki
#schedule TestSchedule

And, there is a Schedule page TestSchedule containing the following.

Then, <<ScheduledPages>> would produce the following lists. The first is the default alphabetical listing, second is the chronological listing.

ScheduledPagesListAlphabetical.png

ScheduledPagesListChronological.png

Download & Release Notes

Download

Release Version

Moin Version

Release Notes

ScheduledPages-1.0.py

1.0

1.9.8

License

GNU GPL, see COPYING for details.

Known issues and limitations


Hits

193

ScheduledPages.py (last edited 2019-03-02 07:07:44 by IanRiley)