Fork me on GitHub

Getting started with npm

npm global configuration file

    vim ~/.npmrc

list npm globally installed modules

    npm list -g

Install modules globally

sudo npm install -g my-module

sudo npm install -g gulp-autoprefixer gulp-clean gulp-concat gulp-cssbeautify gulp-csscomb gulp-csso gulp-if gulp-jshint gulp-less gulp-load-plugins gulp-ng-annotate gulp-rename gulp-uglify minimist
ls /usr/local/lib/node_modules

Install modules locally

Modules will be installed in node_modules folder.

dev modules with --save-dev option

npm install --save-dev gulp-cssbeautify gulp-csscomb gulp-csso gulp-jshint gulp-less gulp-load-plugins gulp-rename

non dev modules with --save option

npm install angular-i18n --save
cd my-app
npm link gulp-autoprefixer gulp-clean gulp-concat gulp-cssbeautify gulp-csscomb gulp-csso gulp-if gulp-jshint gulp-less gulp-load-plugins gulp-ng-annotate gulp-rename gulp-uglify minimist
npm install 

Speed up npm

npm install can be very long, so let's try to speed up that!

Disable progress

npm config set progress false

Setting up a local cache server

Inspired from this ressource.

Installing npm-proxy-cache

sudo apt-get install -y nodejs npm
npm config set prefix '~/.npm-packages'  
export PATH="$PATH:$HOME/.npm-packages/bin"
npm install -g forever npm-proxy-cache  
ln -s /usr/bin/nodejs /usr/bin/node

Starting the cache server

sudo forever /usr/local/lib/node_modules/npm-proxy-cache/bin/npm-proxy-cache  -e -t 600000 -h localhost

You should see that the server is running on 8080 port:

[2017-05-29 13:13:11.725] [INFO] proxy - Listening on localhost:8080 [6172]

Configuring npm-proxy-cache

npm config set proxy http://localhost:8080/  
npm config set https-proxy http://localhost:8080
npm config set strict-ssl false  

Testing the cache server

cd my-app
rm -rf node_modules
npm install

Automating server boot

todo

Yeah, it works!

[2017-05-29 13:13:11.725] [INFO] proxy - Listening on localhost:8080 [6172]
[2017-05-29 13:18:55.662] [INFO] proxy - cache https://registry.npmjs.org/angular-route
[2017-05-29 13:18:55.679] [INFO] proxy - cache https://registry.npmjs.org/angular-i18n
[2017-05-29 13:18:55.702] [INFO] proxy - cache https://registry.npmjs.org/angularjs-datepicker
[2017-05-29 13:18:55.703] [INFO] proxy - cache https://registry.npmjs.org/bootstrap
[2017-05-29 13:18:55.711] [INFO] proxy - cache https://registry.npmjs.org/chart.js
[2017-05-29 13:18:55.714] [INFO] proxy - cache https://registry.npmjs.org/jquery
[2017-05-29 13:18:55.716] [INFO] proxy - cache https://registry.npmjs.org/isteven-angular-multiselect
[2017-05-29 13:18:55.719] [INFO] proxy - cache https://registry.npmjs.org/gulp
[2017-05-29 13:18:55.723] [INFO] proxy - cache https://registry.npmjs.org/gulp-autoprefixer
...

Setting up angularjs and chartjs in Moodle 3.X

I was wondering how can I integrate angularjs to my moodle plugin. Moodle isn't designed as frontend/backend, so how can I integrate angularjs with smashing moodle? I create a POOC, let's checkout that:

Filter functionality in Moodle Configurable Reports

This post describes the filter functionality in Moodle Configurable Reports.

Create the sql query

    SELECT *
    from prefix_course
    WHERE
    1=1
    %%FILTER_COURSES:prefix_course.id%%
    %%FILTER_SEARCHTEXT:prefix_course.fullname:~%%

Add filter fields

Available filters are located in: components/filters/ of Configurable Reports.

In the filters tab:

  • add Courses that will refer to %%FILTER_COURSES:prefix_course.id%%

  • add Search text that will refer to %%FILTER_SEARCHTEXT:prefix_course.fullname:~%%

Available variables

%%CATEGORYID%%
%%COURSEID%%
%%CURRENTUSER%%
%%DEBUG%%
%%FILTER_VAR%%
%%STARTTIME%%’,’%%ENDTIME%%
%%USERID%%
%%WWWROOT%%

Available filters

%%FILTER_CATEGORIES:
%%FILTER_COURSEMODULEID:
%%FILTER_COURSEMODULEFIELDS:
%%FILTER_COURSEMODULE:
%%FILTER_COURSES:
%%FILTER_COURSEENROLLEDSTUDENTS:
%%FILTER_USERS:
%%FILTER_ROLE:
%%FILTER_SEARCHTEXT:
%%FILTER_SEMESTER:
%%FILTER_STARTTIME:
%%FILTER_ENDTIME:
%%FILTER_SUBCATEGORIES:
%%FILTER_COURSEUSER:
%%FILTER_SYSTEMUSER:
%%FILTER_YEARHEBREW:
%%FILTER_YEARNUMERIC:

Result

In the view report tab, you will get the 2 filters!