Images Gallery XBlock allows uploading and displaying a carousel of images using the react-image-gallery component.
Once the XBlock is added to a course, the instructor can upload images into a course unit, and the students can view the images in a carousel. The images are stored in the course's assets.
This XBlock has been created as an open source contribution to the Open edX platform and has been funded by Unidigital project from the Spanish Government - 2023.
Open edX Release | Version |
---|---|
Palm | >= 0.5.0 |
Quince | >= 0.5.0 |
Redwood | >= 0.5.0 |
Sumac | >= 0.6.0 |
The settings can be changed in imagesgallery/settings/common.py
or, for example, in tutor configurations.
NOTE: the current common.py
works with Open edX Palm, Quince, Redwood and Sumac versions.
When the XBlock has been installed, you can enable it in a course from Studio through the Advanced Settings.
- Go to Studio and open the course you want to add the XBlock to.
- Go to Settings > Advanced Settings from the top menu.
- Search for Advanced Module List and add
"imagesgallery"
to the list. - Click Save Changes button.
From Studio, you can add the Images Gallery Component to a course unit.
- Click on the Advanced button in Add New Component.
- Select imagesgallery from the list.
In the Edit modal you can upload images, and delete them. The allowed image
formats are: .jpg
, .jpeg
, .png
, .gif
, .webp
, .heic
and
.jfif
.
The instructors can preview the images before publishing the changes in the course.
Go to edit section of the component from Studio.
Upload files by clicking on the dotted area or by dragging and dropping the images and save the changes.
The uploaded files are added to the course assets, and they can be viewed from Content > Files in Studio.
To delete a image, the following must be taken into account:
Delete an image from the Images Gallery component won't delete the image from the course assets, only from the component, but, the image won't be visible from the student view.
Delete an image from course assets will delete the image from the Images Gallery component, and therefore, the image won't be visible from the student view.
The students can view the images in a carousel. The carousel has a navigation arrow to move between the images, a full-screen and automatic slideshow button.
Use Node.js v18.x
You can use nvm use to switch the Node.js version.
There are three scripts to run our React app:
Running the React App in Isolation:
This script runs the React app in isolation, which means you do not need the XBlock running. It starts a development server with a hot reload mechanism.
yarn install
Running React with the XBlock:
This script runs React with the XBlock running, allowing you to reload the page with any changes.
yarn start
Generating Static Files for Production:
This script generates all the necessary static files for the production environment.
yarn build
We also recommend using yarn. You can install it with the following command:
npm install --global yarn
XBlock is the Open edX component architecture for building custom learning interactive components.
You can see the Images Gallery component in action in the XBlock Workbench. Running the Workbench requires having docker running.
git clone [email protected]:eduNEXT/xblock-imagesgallery
virtualenv venv/
source venv/bin/activate
cd xblock-imagesgallery
make upgrade
make install
make dev.run
Once the process is done, you can interact with the Images Gallery XBlock in the Workbench by navigating to http://localhost:8000
For details regarding how to deploy this or any other XBlock in the Open edX platform, see the installing-the-xblock documentation.
If you're having trouble, the Open edX community has active discussion forums available at https://discuss.openedx.org where you can connect with others in the community.
Also, real-time conversations are always happening on the Open edX community Slack channel. You can request a Slack invitation, then join the community Slack workspace.
For anything non-trivial, the best path is to open an issue in this repository with as many details about the issue you are facing as you can provide.
For more information about these options, see the Getting Help page.
The code in this repository is licensed under the AGPL-3.0 unless otherwise noted.
Please see LICENSE.txt for details.
Contributions are very welcome.
This project is currently accepting all types of contributions, bug fixes, security fixes, maintenance work, or new features. However, please make sure to have a discussion about your new feature idea with the maintainers prior to beginning development to maximize the chances of your change being accepted. You can start a conversation by creating a new issue on this repo summarizing your idea.
This Xblock is initially available in English and Spanish. You can help by translating this component to other languages. Follow the steps below:
- Create a folder for the translations in
locale/
, eg:locale/fr_FR/LC_MESSAGES/
, and create yourtext.po
file with all the translations. - Run
make compile_translations
, this will generate the.mo
file. - Create a pull request with your changes!
Please do not report a potential security issue in public. Please email [email protected].