Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ndlano/h5p-caretaker-client
Reference client for using the H5P Caretaker library
https://github.com/ndlano/h5p-caretaker-client
Last synced: 13 days ago
JSON representation
Reference client for using the H5P Caretaker library
- Host: GitHub
- URL: https://github.com/ndlano/h5p-caretaker-client
- Owner: NDLANO
- License: mit
- Created: 2024-09-26T16:34:03.000Z (4 months ago)
- Default Branch: master
- Last Pushed: 2024-12-28T17:24:54.000Z (15 days ago)
- Last Synced: 2024-12-28T17:29:23.263Z (15 days ago)
- Language: JavaScript
- Size: 4.61 MB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# H5P Caretaker client
Reference implementation of a JavaScript client using the H5P Caretaker library. It will not do anything on its own (!), but it requires the server-side [H5P Caretaker library](https://github.com/ndlano/h5p-caretaker) and a server-side integration, e.g. the [H5P Caretaker server reference implementation](https://github.com/ndlano/h5p-caretaker-server).## Usage
You can see a fully working example on integrating this client in the the [H5P Caretaker server reference implementation](https://github.com/ndlano/h5p-caretaker-server).### Instantiazitation
Load the `h5p-caretaker-client-*.js` file from the dist folder and `h5p-caretaker-client-*.css` file from the dist folder, e.g. with amending your HTML page's `head` with```
```
The exact path will depend on your setup, of course.In your HTML page, you will need 4 things:
1. an element bearing the class name `h5p-caretaker` to scope the caretaker elements.
2. a child element bearing the class name `dropzone` that will be filled with the dropzone for uploading files and
3. a child element bearing the class name `filter-tree` that will be filled with the filter for choosing contents and
4. a child element bearing the class name `output` that will be filled with the reports.
5. a tiny piece of JavaScript that runs the H5PCaretaker and passes the upload endpoint at least.So, assuming that `./upload.php` is your endpoint, a very basic setup in the `` could be
```
document.addEventListener('DOMContentLoaded', () => {
new H5PCaretaker({ endpoint: './upload.php' });
});```
You will have to take care of additional styling yourself.### Localization
The client expects the constructor to be passed an `l10n` object holding key-value pairs for translatable strings. The values should be the desired translation for strings that the client uses. If not set, the client will fall back to the English defaults._Example for English (despite being default anyway)_
```document.addEventListener('DOMContentLoaded', () => {
new H5PCaretaker({
endpoint: './upload.php'
l10: {
orDragTheFileHere: 'or drag the file here',
removeFile: 'Remove file',
selectYourLanguage: 'Select your language',
uploadProgress: 'Upload progress',
uploadYourH5Pfile: 'Upload your H5P file',
yourFileIsBeingChecked: 'Your file is being checked',
yourFileWasCheckedSuccessfully: 'Your file was checked successfully',
totalMessages: 'Total messages',
issues: 'issues',
results: 'results',
filterBy: 'Filter by',
groupBy: 'Group by',
download: 'Download',
expandAllMessages: 'Expand all messages',
collapseAllMessages: 'Collapse all messages',
allFilteredOut: 'All messages have been filtered out by content.',
reportTitleTemplate: 'H5P Caretaker report for @title',
contentFilter: 'Content type filter',
showAll: 'Show all',
showSelected: 'Various selected contents',
showNone: 'Show none',
filterByContent: 'Filter by content:',
reset: 'Reset',
}
});
});```
If you wish, you can implement your own language selection as seen in the reference server implementation.
### Callbacks
The 2nd constructor argument is reserved for callback functions that you may want to be called when certain things happen. H5P Caretaker currently supports these:
- _onInitialized_: Called when initialization is done.
- _onUploadStarted_: Called when the file upload starts.
- _onUploadEnded_: Called when the file upload ended. Will return `true` if successful, else `false`.
- _onReset_: Called when the user resets the client.Given that, the instantiazitaton could e.g. look like:
```document.addEventListener('DOMContentLoaded', () => {
new H5PCaretaker(
{
// endpoint and other parameters
},
{
onInitialized: () => {
// Do something after initialization
},
onUploadEnded: (wasSuccessful) => {
// Do something after the upload ended depending on the value of `wasSuccessful`
}
}
});
});```
## Future Development
Will at some point learn to edit fields and to send requests to the integration to save them to an H5P file.