https://joaopaulovieira.github.io/clappr-context-menu-plugin/
- Default actions:
- Copy URL of the site where
Clappr
is playing; - Copy URL with the current time of the video;
- Enable/Disable loop state;
- Copy URL of the site where
- Default info:
Clappr
version;
- Support to add new custom actions;
- Support to add custom style;
You can use it from JSDelivr:
https://cdn.jsdelivr.net/npm/clappr-context-menu-plugin@latest/dist/clappr-context-menu-plugin.min.js
# Using yarn
yarn add clappr-context-menu-plugin
# Using npm
npm i clappr-context-menu-plugin
Then just add ContextMenuPlugin
into the list of plugins of your player instance
var player = new Clappr.Player({
source: 'http://your.video/here.mp4',
plugins: [ContextMenuPlugin]
});
The options for the plugin go in the contextMenu
property as shown below
var player = new Clappr.Player({
source: 'http://your.video/here.mp4',
plugins: [ContextMenuPlugin],
contextMenu: {
menuItems: [`copyURL`, `copyURLCurrentTime`, `loop`, `playerVersion`],
extraOptions: [
{
name: 'test',
label: 'Test Label',
//optional
callback: function() {
console.log('A absolutely awesome extra context menu item action')
}
}
],
customStyle: {
container: {
'display': 'block'
},
list: {
'background-color': 'gray'
},
items: {
'color': 'yellow'
}
}
}
});
An array where each item is a name that matches one of the default menu items. The valid values are: ['copyURL', 'copyURLCurrentTime', 'loop', 'playerVersion']
An array of items to add on the context menu. Each context menu item on this array is an object which contains the parameters name
, label
, and callback
-
Name of the extra item
-
The label that will be displayed on the menu
-
A method that will be triggered when clicking on the item label. This option is not required if your desired menu item not have one action to call on click (like the
playerVersion
default menu item)
Styles to apply to mapped elements on the context menu. This option is an object with the parameters container
, list
and items
-
Attributes that will be applied in the main element. This option is an object that receives CSS attributes like the options example at the beginning of this section
-
Attributes that will be applied in the
<ul>
element. This option is an object that receives CSS attributes like the options example at the beginning of this section -
Attributes that will be applied in each
<li>
element. This option is an object that receives CSS attributes like the options example at the beginning of this section
Install dependencies: npm install
Run: npm start
Test: npm test
Lint: npm run lint
Build: npm run build
Minified version: npm run release