Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

xblock-video-iframe

Package Overview
Dependencies
Maintainers
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

xblock-video-iframe

XBlock to embed video content using iframe along with download buttons

  • 1.0.0
  • PyPI
  • Socket score

Maintainers
1

XBlock to embed video content using iframe along with download buttons ######################################################################

Usage


  1. Go to Settings -> Advanced Settings in a specific course within Studio.
  2. Add "video_iframe" to Advanced Module List and save.
  3. Add Advanced -> Video Iframe unit to the course.
  4. Add a valid URL to the Video URL field and optionally add Video Description, Video Download URL and Captions Download URL and/or modify Video Title.

Testing with Docker


This XBlock comes with a Docker test environment ready to build, based on the xblock-sdk workbench. To build and run it::

$ make dev.run

The XBlock SDK Workbench, including this XBlock, will be available on the list of XBlocks at http://localhost:8000

Translating


Internationalization (i18n) is when a program is made aware of multiple languages. Localization (l10n) is adapting a program to local language and cultural habits.

Use the locale directory to provide internationalized strings for your XBlock project. For more information on how to enable translations, visit the Open edX XBlock tutorial on Internationalization <https://edx.readthedocs.org/projects/xblock-tutorial/en/latest/edx_platform/edx_lms.html>_.

This cookiecutter template uses django-statici18n <https://django-statici18n.readthedocs.io/en/latest/>_ to provide translations to static javascript using gettext.

The included Makefile contains targets for extracting, compiling and validating translatable strings. The general steps to provide multilingual messages for a Python program (or an XBlock) are:

  1. Mark translatable strings.

  2. Run i18n tools to create raw message catalogs.

  3. Create language specific translations for each message in the catalogs.

  4. Use gettext to translate strings.

  5. Mark translatable strings =============================

Mark translatable strings in python::

from django.utils.translation import ugettext as _

# Translators: This comment will appear in the `.po` file.
message = _("This will be marked.")

See edx-developer-guide <https://edx.readthedocs.io/projects/edx-developer-guide/en/latest/internationalization/i18n.html#python-source-code>__ for more information.

You can also use gettext to mark strings in javascript::

// Translators: This comment will appear in the `.po` file.
var message = gettext("Custom message.");

See edx-developer-guide <https://edx.readthedocs.io/projects/edx-developer-guide/en/latest/internationalization/i18n.html#javascript-files>__ for more information.

  1. Run i18n tools to create Raw message catalogs =================================================

This cookiecutter template offers multiple make targets which are shortcuts to use edx-i18n-tools <https://github.com/openedx/i18n-tools>_.

After marking strings as translatable we have to create the raw message catalogs. These catalogs are created in .po files. For more information see GNU PO file documentation <https://www.gnu.org/software/gettext/manual/html_node/PO-Files.html>_. These catalogs can be created by running::

$ make extract_translations

The previous command will create the necessary .po files under xblock-video-iframe/video_iframe/conf/locale/en/LC_MESSAGES/text.po. The text.po file is created from the django-partial.po file created by django-admin makemessages (makemessages documentation <https://docs.djangoproject.com/en/3.2/topics/i18n/translation/#message-files>_), this is why you will not see a django-partial.po file.

  1. Create language specific translations ==============================================

3.1 Add translated strings

After creating the raw message catalogs, all translations should be filled out by the translator. One or more translators must edit the entries created in the message catalog, i.e. the .po file(s). The format of each entry is as follows::

#  translator-comments
A. extracted-comments
#: reference…
#, flag…
#| msgid previous-untranslated-string
msgid 'untranslated message'
msgstr 'mensaje traducido (translated message)'

For more information see GNU PO file documentation <https://www.gnu.org/software/gettext/manual/html_node/PO-Files.html>_.

To use translations from transifex use the follow Make target to pull translations::

$ make pull_translations

See config instructions <https://github.com/openedx/i18n-tools#transifex-commands>_ for information on how to set up your transifex credentials.

See transifex documentation <https://docs.transifex.com/integrations/django>_ for more details about integrating django with transiflex.

3.2 Compile translations

Once translations are in place, use the following Make target to compile the translation catalogs .po into .mo message files::

$ make compile_translations

The previous command will compile .po files using django-admin compilemessages (compilemessages documentation <https://docs.djangoproject.com/en/3.2/topics/i18n/translation/#compiling-message-files>). After compiling the .po file(s), django-statici18n is used to create language specific catalogs. See django-statici18n documentation <https://django-statici18n.readthedocs.io/en/latest/> for more information.

To upload translations to transiflex use the follow Make target::

$ make push_translations

See config instructions <https://github.com/openedx/i18n-tools#transifex-commands>_ for information on how to set up your transifex credentials.

See transifex documentation <https://docs.transifex.com/integrations/django>_ for more details about integrating django with transiflex.

Note: The dev.run make target will automatically compile any translations.

Note: To check if the source translation files (.po) are up-to-date run::

 $ make detect_changed_source_translations

4. Use gettext to translate strings

Django will automatically use gettext and the compiled translations to translate strings.

Troubleshooting


If there are any errors compiling .po files run the following command to validate your .po files::

$ make validate

See django's i18n troubleshooting documentation <https://docs.djangoproject.com/en/3.2/topics/i18n/translation/#troubleshooting-gettext-incorrectly-detects-python-format-in-strings-with-percent-signs>_ for more information.

Change Log ##########

.. All enhancements and patches to video_iframe will be documented in this file. It adheres to the structure of https://keepachangelog.com/ , but in reStructuredText instead of Markdown (for ease of incorporation into Sphinx documentation and the PyPI description).

This project adheres to Semantic Versioning (https://semver.org/).

.. There should always be an "Unreleased" section for changes pending release.

Unreleased


1.0.0 – 2024-06-18


Added

  • Author view to display custom message with instructions if no video url is detected. Also disable validations for author view to supress default validation failure messages.

Removed

  • autoplay from allow attribute passed to the iframe.

Changed

  • Title of display_name field to Video Title and modified the description.
  • Default display name of the XBlock as displayed in the Advanced XBlocks selection list from Video to Video Iframe.

0.1.0 – 2024-04-28


Added

  • First iteration of XBlock.

Keywords

FAQs


Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc