Skip to content

Latest commit

 

History

History
44 lines (28 loc) · 2.59 KB

README.md

File metadata and controls

44 lines (28 loc) · 2.59 KB

calendar

A basic PHP script that embeds a page based on the current calendar week.

The script has been kept extremely simple by design.

Functionality

More specifically, the script creates an iframe of the following URL:

[$baseURL][WEEKNO][$suffixURL], e.g. https://www.example.com/01/calendar.htm

By the default, the script points to the current calendar week. The user can navigate to the next or previous week, or go back to the current week.

The links "Previous Week", "Current Week" or "Next Week" are disabled dynamically. For example, if you are on week one, you cannot go back a week, so the link "Previous Week" is disabled.

Optionally, a link to the full calendar can be specified. This is especially useful if the calendar requires a one-time login per session or contains any extra functionality not covered by the embed script.

Input Validation

The script trusts that the variables in the configuration file are defined and valid. Configuration files are not considered "user input".

There are checks on the week number:

  1. Only valid calendar weeks are accepted, that is a number from 1 to 53.
  2. The calendar week gets formatted to two digits, so 1 becomes 01 and 0010 becomes 10.

Limitations

The script only works for the current year. It also comes with all limitations of an iframe, including not being able to auto-login and having a fixed size - i.e. not being "responsive".

Installation

As an alternative to downloading the files manually from GitHub, you can use the command-line.

In the desired directory, type or paste the following: git clone https://github.com/reclaimingmytime/calendar.git

Note: This will create a new directory called calendar.

Configuration

  1. Copy config.default.php to config.php.
  2. Open config.php and change the required variables. $baseURL is the part before the week number, while $suffixURL is the part after that number. $fullCalendar is optional and points to the full calendar site. Make sure that $baseURL and $fullURL is a valid URL.
  3. Test the page. If it does not display properly, make sure you are logged in to the embedded site. You might want to review the generated source code. Specifically, analyse the iframe src attribute and see if that URL displays properly without an iframe.

Updating

As an alternative to downloading the new files manually, if you have installed the script through git, you can simply update your local repository using the following command in that directory:

git pull

Note that your configuration file config.php will be kept in any case, as that file is ignored by git.