Coder Social home page Coder Social logo

cwarwicker / moodle-block_quick_course Goto Github PK

View Code? Open in Web Editor NEW
1.0 2.0 1.0 139 KB

Quick Course search block for Moodle

License: GNU General Public License v3.0

PHP 85.15% JavaScript 8.11% CSS 2.08% HTML 4.66%
moodle moodle-block moodle-plugin

moodle-block_quick_course's Introduction

Quick Course Search

Build Status Open Issues License

Moodle 3.4 supported Moodle 3.5 supported Moodle 3.6 supported Moodle 3.7 supported

The quick_course block allows you to search quickly for courses, without having to go through the Moodle course interface.

  • As site admin or user with block/quick_course:searchall capability - Search all courses in the site
  • As a user with block/quick_course:search capability - Search all courses you are enrolled to, including any courses in categories you are category enrolled to.

Requirements

Moodle 3.4+

Screenshots

These screenshots were taken on a plain Moodle installation with no fancy theme installed. Appearances may vary slightly depending on your theme.

The Block:

block

The block with some search results:

block-with-results

Search results expanded to see extra links:

block-with-expanded-results

The course relationships page, showing a parent (meta) course and its child relationships:

parent-relationships

The course relationships page, showing a child course and its parent (meta) relationships:

parent-relationships

Installation

From github:

  1. Download the latest version of the plugin from the Releases page.
  2. Extract the directory from the zip file and rename it to 'quick_course' if it is not already named as such.
  3. Place the 'quick_course' folder into your Moodle site's /blocks/ directory.
  4. Run the Moodle upgrade process either through the web interface or command line.
  5. Add the block to a page and start using it

License

https://www.gnu.org/licenses/gpl-3.0

Support

If you need any help using the block, or wish to report a bug or feature request, please use the issue tracking system: https://github.com/cwarwicker/moodle-block_quick_course/issues

moodle-block_quick_course's People

Contributors

bedcoll-cwarwicker avatar

Stargazers

 avatar

Watchers

 avatar  avatar

Forkers

martinvivek

moodle-block_quick_course's Issues

Privacy API

Moodle uses a privacy API for GDPR compliance to allow plugins to specify how they deal with user data. It doesn't look like your plugin stores user data so you should be able to implement the simple null provider.

Sites that use continuous integration processes will not be able to use your plugin because Moodle runs unit tests which check to see if all extra plugins include the privacy class.

More information on the privacy class is here:
https://docs.moodle.org/dev/Privacy_API

please note this is not a block for approval in the plugins db at this stage.

watch camel case use

Moodle uses sentence case - stuff like:
$string['participants'] = 'View Course Participants';

should probably be :
$string['participants'] = 'View course participants';

This does not block approval in the plugins db.

consider adding travis-ci support

Some of the tests run by the Moodle.org plugins db can be run via travis-ci on each commit in your github repo. Enabling Travis integration helps you to make sure future changes to your plugin will continue to follow the guidelines.

More information on this is here:
https://moodle.org/mod/forum/discuss.php?d=323384

but the short version:
grab this file:
https://github.com/moodlerooms/moodle-plugin-ci/blob/master/.travis.dist.yml
rename it as .travis.yml and put in the root of your github directory.
Go to:
https://travis-ci.org/profile/YOUR_GITHUB_USERNAME
Flick the switch for this repo.

then on every commit you make to github it will fire off a request to travis to run the tests in .travis.yml and will give you traffic lights beside each commit and generate a report.

something else you might want to change:
in .travis.yml the default file has this line:

env:
global:

MOODLE_BRANCH=MOODLE_35_STABLE
you might want to add other branches to that list - so you might want to change it something like:

env:
global:
MOODLE_BRANCH=MOODLE_35_STABLE
MOODLE_BRANCH=MOODLE_36_STABLE
MOODLE_BRANCH=MOODLE_37_STABLE

Check permissions before showing course in results

Although the block can only be used by users who are of the teacher archetype in the given context, not all teachers can view all courses. So we need to check this before displaying. The core_course_search_courses webservice should help with this

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.