Skip to main content

An XBlock which allows embedding of Google documents and calendar within an edX course

Project description

Google Drive & Calendar XBlock Build Status

This XBlock allows embedding of Google documents and calendar, within an edX course.

Installation

Install the requirements into the python virtual environment of your edx-platform installation by running the following command from the root folder:

$ make requirements

Enabling in Studio

You can enable the Google Drive & Calendar XBlock in studio through the advanced settings.

  1. From the main page of a specific course, navigate to Settings -> Advanced Settings from the top menu.

  2. Check for the advanced_modules policy key, and add "google-document" and "google-calendar" to the policy value list.

  3. Click the “Save changes” button.

Workbench installation and settings

Install to the workbench’s virtualenv by running the following command form the google-drive repo root:

pip install -r requirements/base.in
pip install -e .

Running the workbench

$ ./manage.py runserver 8000

Access it at http://localhost:8000/.

Running tests

From google-drive directory, run the tests with the following command:

$ pytest

If you want to run only the integration or the unit tests, append the directory to the command. You can also run separate modules in this manner.

$ pytest tests/unit

To see the coverage report in HTML format, run the tests using the following command:

$ make coverage

If you have not installed the xblock-sdk in the active virtualenv, you might also have to prepend PYTHONPATH=".:/path/to/xblock" to the command above. (/path/to/xblock is the path to the xblock-sdk, where the workbench resides).

Changes to be documented

  1. Calendar width is set to 100% of parent element’s width; this optimizes the display of google document content within the LMS user interface

  2. Max width of Google images is set to 100% to prevent images from overflowing outside the parent element’s boundaries

  3. Since Google WordProcessing documents and Spreadsheets don’t allow users to explicitly define width and height, their width is set to 100%. Also, min height is set to 450px, so that documents and/or spreadsheets with larger number of rows are displayed in their natural size. Overflow scroll is automatically turned on when the height of the document becomes larger than the height of the parent.

Validation

Each time a character is added to or removed from Google Calendar ID, validation takes place. Analogically, validation takes place for embedded code of Google Drive File.

  1. Google calendar IDs are being validated against a regular expression. IDs must contain at least one ‘@’ character, with at least one character on each side of it, ie. ‘a@a’.

  2. Embedded code of Google Drive file is being validated on the server side, by checking the status code of the HTTP response. Since error status codes start with 400, it’s assumed that each status code that’s larger than or equal to 400 states that file is invalid. If for any reason exception occurs while getting an HTTP response, error code is returned, thus overriding default signalization that is invoked by edx platform when the 500 status code is reported.

Accessibility (a11y)

For users with a visual impairment:

  1. Iframes in which Google calendars and Google Drive files (except images) are shown now have title attribute with alternative text content which describes what the iframe contains.

  2. Images have alt attribute which contains alternative text that has the same purpose as the title attribute of an iframe has

Analytics

For analytics purposes, each time an image or iframe containing a calendar or Google Drive file is loaded, an event will be triggered.

There are two types of events:

  1. edx.googlecomponent.calendar.displayed (if an iframe containing a Google calendar is loaded)

  2. edx.googlecomponent.document.displayed (if an image or an iframe containing a Google Drive File is loaded)

License

The Google Drive & Calendar XBlocks are available under the GNU Affero General Public License (AGPLv3).

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

xblock_google_drive-0.7.0.tar.gz (27.2 kB view details)

Uploaded Source

Built Distribution

xblock_google_drive-0.7.0-py2.py3-none-any.whl (29.3 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file xblock_google_drive-0.7.0.tar.gz.

File metadata

  • Download URL: xblock_google_drive-0.7.0.tar.gz
  • Upload date:
  • Size: 27.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.3

File hashes

Hashes for xblock_google_drive-0.7.0.tar.gz
Algorithm Hash digest
SHA256 28c9af4402c4794f19eb899b65a8db0249d2e3f59340b71fcd92a08cecf1b756
MD5 4130393ab6fafabceff08a6ed624616c
BLAKE2b-256 1e6b2db37510d1b98c107f3baeccd2a8d3dedf216e8a1a0358e51876b3ca8e62

See more details on using hashes here.

File details

Details for the file xblock_google_drive-0.7.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for xblock_google_drive-0.7.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 24ece2a297af1d3120699f39e62ae3f866785ee1d207885d7c03432eafd41a66
MD5 2a4edadb12b34ddc9533549fbbedac5d
BLAKE2b-256 6a6af89ab4c4f76fb511b7eeac78e68934a1b6734774f7fdc5a86eb4ab017d61

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page