CMI5 is the successor to SCORM for using packaged course content with an LMS.
This is built to be used with the OpenLearning CMI5 course widget, but also can be used for other LMSs that support CMI5 content.
Install:
npm install @openlearning/xapi --save
Usage:
import {
initTinCan,
initCmi5,
saveActivityState,
retrieveActivityState,
sendCompleted,
sendPassed,
sendFailed,
sendTerminated,
sendAttachments,
getDuration
} from "@openlearning/xapi";
The webpage will be loaded with query string arguments that configure the LRS connection.
The initCmi5
or initTinCan
functions return the configuration loaded after the launch has initialised.
It is recommended to use CMI5 with OpenLearning. CMI5 is the standard way to use xAPI content with an LMS. The TinCan profile can be used with the "xAPI TinCan" widget, but uses a non-standard launch method (but is often used by Captivate, Articulate, and other tools).
e.g.
initCmi5().then((config) => {
// retrieve the mastery score
const masteryScore = config.launchData.masteryScore;
});
Once an LRS connection is configured, this config can be used with the other functions, e.g. to mark this activity as completed:
// mark as completed
sendCompleted(config);
// mark as passed
sendPassed(config);
// mark as failed
sendFailed(config);
Or to set a score:
// send a passing scaled score
sendPassed(config, { scaled: 0.95 });
// send a failing raw score
sendFailed(config, { min: 0, max: 10, raw: 3 })
Or to send file URLs to OpenLearning as attachments that can then be shared by the learner:
// publish (replace) attachments (default, last argument is optional)
sendAttachments(config, [{
contentType: "text/plain",
display: "attachment.txt",
description: "A text file written by the learner",
fileUrl: "https://www.example.com/attachment.txt"
}], "published");
// publish (replace) attachments and specify a thumbnail URL
sendAttachments(config, [{
contentType: "text/plain",
display: "attachment.txt",
description: "A text file written by the learner",
fileUrl: "https://www.example.com/attachment.txt"
}], "published", "https://www.example.com/thumbnail.png");
// append attachments
sendAttachments(config, [{
contentType: "text/plain",
display: "attachment.txt",
description: "A text file written by the learner",
fileUrl: "https://www.example.com/attachment.txt"
}], "attached");
Activity State can also be set and retrieved for the current user of this activity:
// store state (for the activity and current user)
saveActivityState(config, stateId, state);
// retrieve state (for the activity and current user)
retrieveActivityState(config, stateId).then((state) => {
console.log(state);
});
If you're not using npm and want to just use a <script>
tag:
<script src="./bundle/openlearning-xapi.js"></script>
will define:
window.xApi = {
initTinCan,
initCmi5,
saveActivityState,
retrieveActivityState,
sendCompleted,
sendPassed,
sendFailed,
sendTerminated,
sendAttachments,
getDuration
};
Build the ./dist
folder:
npm run build
Build the standalone bundle: ./bundle/openlearning-xapi.js
:
npm run bundle