Skip to content

Commit

Permalink
feat: add element type prompt and adapt templates
Browse files Browse the repository at this point in the history
- Added a new prompt in the `create` script to enable users to specify whether they want to generate
  a new component, plugin, or button.
- Adapted the existing templates to correctly produce the type of element selected by the user.
- Migrated the functionality of the skip-button-plugin into a simpler component format.
  • Loading branch information
jboix committed Apr 30, 2024
1 parent 1c4337f commit ed26264
Show file tree
Hide file tree
Showing 40 changed files with 592 additions and 584 deletions.
2 changes: 1 addition & 1 deletion docs/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ npm install
Open your terminal and execute the following command:

```bash
npm run create:plugin
npm run create
```

After running the command, you will be prompted to enter the name of your plugin. A new plugin
Expand Down
789 changes: 389 additions & 400 deletions package-lock.json

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@
"themes/*"
],
"scripts": {
"create:plugin": "plop --plopfile scripts/create-plugin.js",
"create": "plop --plopfile scripts/create.js",
"eslint": "eslint {plugins/**/{src,test}/**/*.{js,jsx},scripts/*.{js,jsx}}",
"outdated": "npm outdated",
"prepare": "husky",
Expand Down
28 changes: 0 additions & 28 deletions plugins/skip-button-plugin/src/skip-button-plugin.js

This file was deleted.

31 changes: 0 additions & 31 deletions plugins/skip-button-plugin/test/skip-button-plugin.spec.js

This file was deleted.

14 changes: 0 additions & 14 deletions plugins/skip-button-plugin/vitest.config.js

This file was deleted.

File renamed without changes.
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
# Pillarbox Web: SkipButtonPlugin
# Pillarbox Web: SkipButton

> Introduce your plugin with a clear overview of its goals, providing
> essential context and addressing fundamental questions.
A custom component that extends the pillarbox-web player allowing users to skip certain parts of the
video content, such as opening credits or end credits, by listening to
the [`srgssr/interval` event](https://srgssr.github.io/pillarbox-web/api/tutorial-Events.html#srgssr%2Finterval-event).

## Requirements

Expand All @@ -11,7 +12,7 @@ To use this component, you need the following installed on your system:

## Quick Start

To get started with this plugin, follow these steps:
To get started with this component, follow these steps:

Add the `@srgssr` registry to your `.npmrc` file:

Expand All @@ -26,18 +27,19 @@ guide: [Authenticating with a personal access token][generate-token]
You can now install it through `npm` the following command:

```bash
npm install --save @srgssr/pillarbox-web @srgssr/skip-button-plugin
npm install --save @srgssr/pillarbox-web @srgssr/skip-button
```

For instructions on setting up Pillarbox, see the [Quick Start guide](SRGSSR/pillarbox-web#quick-start).
For instructions on setting up Pillarbox, see
the [Quick Start guide](SRGSSR/pillarbox-web#quick-start).

Once the player is installed you can activate the plugin as follows:
Once the player is installed you can activate the button as follows:

```javascript
import Pillarbox from '@srgssr/pillarbox-web';
import '@srgssr/skip-button-plugin';
import '@srgssr/skip-button';

const player = new Pillarbox('my-player', { plugins: { 'skipButtonPlugin': true } });
const player = new Pillarbox('my-player', { SkipButton: true });
player.src({
src: 'urn:swi:video:48115940',
type: 'srgssr/urn'
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,9 +4,9 @@
<meta charset="UTF-8"/>
<meta http-equiv="X-UA-Compatible" content="IE=edge"/>
<meta name="viewport" content="width=device-width, initial-scale=1.0"/>
<title>SkipButtonPlugin Demo</title>
<title>SkipButton Demo</title>
<link rel="stylesheet" href="npm:@srgssr/pillarbox-web/dist/pillarbox.min.css"/>
<link rel="stylesheet" href="./scss/skip-button-plugin.scss"/>
<link rel="stylesheet" href="scss/skip-button.scss"/>
<style>
html,
body {
Expand All @@ -24,7 +24,7 @@

<script type="module">
import pillarbox from '@srgssr/pillarbox-web';
import './src/skip-button-plugin.js';
import './src/skip-button.js';

// Handle URL parameters
const searchParams = new URLSearchParams(location.search);
Expand All @@ -33,14 +33,14 @@
const language = searchParams.get('language');
const urn = searchParams.get('urn') || 'urn:rts:video:14683290';

// Create a pillarbox player instance with the SkipButtonPlugin plugin
// Create a pillarbox player instance with the SkipButton enabled
window.player = pillarbox('player', {
debug,
language,
srgOptions: {
dataProviderHost: ilHost
},
plugins: { 'skipButtonPlugin': true }
SkipButton: true
});

// Load the video source for the player
Expand Down
Original file line number Diff line number Diff line change
@@ -1,14 +1,14 @@
{
"name": "@srgssr/skip-button-plugin",
"name": "@srgssr/skip-button",
"version": "0.0.1",
"type": "module",
"main": "dist/skip-button-plugin.cjs.js",
"module": "dist/skip-button-plugin.es.js",
"style": "./dist/skip-button-plugin.min.css",
"main": "dist/skip-button.cjs.js",
"module": "dist/skip-button.es.js",
"style": "./dist/skip-button.min.css",
"exports": {
".": {
"import": "./dist/skip-button-plugin.es.js",
"require": "./dist/skip-button-plugin.cjs.js"
"import": "./dist/skip-button.es.js",
"require": "./dist/skip-button.cjs.js"
}
},
"files": [
Expand All @@ -25,13 +25,13 @@
},
"scripts": {
"build": "npm run build:lib && npm run build:css",
"build:css": "sass ./scss/skip-button-plugin.scss:dist/skip-button-plugin.min.css --style compressed --source-map --load-path node_modules",
"build:css": "sass ./scss/skip-button.scss:dist/skip-button.min.css --style compressed --source-map --load-path node_modules",
"build:lib": "rollup -c",
"github:page": "parcel build index.html --target github-page",
"start": "parcel -p 4200 index.html --open",
"test": "vitest run --silent --coverage --coverage.reporter text"
},
"peerDependencies": {
"@srgssr/pillarbox-web": "^1.0.0"
"@srgssr/pillarbox-web": "^1.12.0"
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -13,25 +13,25 @@ export default [
* Rollup build configuration for the ESModule build.
*
* Outputs:
* - 'dist/skip-button-plugin.es.min.js': Minified ESModule version with sourcemaps.
* - 'dist/skip-button-plugin.es.js': Non-minified ESModule.
* - 'dist/skip-button.es.min.js': Minified ESModule version with sourcemaps.
* - 'dist/skip-button.es.js': Non-minified ESModule.
*
* @example
* ```javascript
* import '@srgssr/skip-button-plugin'
* import '@srgssr/skip-button'
* ```
*/
{
input: 'src/skip-button-plugin.js',
input: 'src/skip-button.js',
output: [
{
file: 'dist/skip-button-plugin.es.min.js',
file: 'dist/skip-button.es.min.js',
format: 'es',
sourcemap: true,
plugins: [terser()],
},
{
file: 'dist/skip-button-plugin.es.js',
file: 'dist/skip-button.es.js',
format: 'es',
plugins: [filesize()]
}
Expand All @@ -46,22 +46,22 @@ export default [
* Rollup build configuration for the CJS build.
*
* Outputs:
* - 'dist/skip-button-plugin.cjs.min.js': Minified UMD version with sourcemaps.
* - 'dist/skip-button-plugin.cjs.js': Non-minified UMD.
* - 'dist/skip-button.cjs.min.js': Minified UMD version with sourcemaps.
* - 'dist/skip-button.cjs.js': Non-minified UMD.
*
* @example
* ```html
* <script src="skip-button-plugin.cjs.min.js"></script>
* <script src="skip-button.cjs.min.js"></script>
* ```
*
* @type {import('rollup').RollupOptions}
*/
{
input: 'src/skip-button-plugin.js',
input: 'src/skip-button.js',
output: [
{
name: 'SkipButtonPlugin',
file: 'dist/skip-button-plugin.cjs.min.js',
file: 'dist/skip-button.cjs.min.js',
format: 'cjs',
sourcemap: true,
globals: {
Expand All @@ -71,7 +71,7 @@ export default [
},
{
name: 'SkipButtonPlugin',
file: 'dist/skip-button-plugin.cjs.js',
file: 'dist/skip-button.cjs.js',
format: 'cjs',
globals: {
'@srgssr/pillarbox-web': 'pillarbox'
Expand Down
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
File renamed without changes.
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,8 @@ import './lang';
const Button = pillarbox.getComponent('Button');

/**
* Represents a SkipButton component for the pillarbox player.
* Represents a SkipButton component for the pillarbox player. Allows skipping
* opening credits and end credits detected through the 'srgssr/interval' event.
*
* @class SkipButton
*/
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@ import { afterEach, beforeEach, describe, expect, it, vi } from 'vitest';
import SkipButton from '../src/skip-button'; // Adjust path as needed
import pillarbox from '@srgssr/pillarbox-web';

window.HTMLMediaElement.prototype.load = () => {};

describe('SkipButton', () => {
let originalHandleClick;

Expand Down Expand Up @@ -91,4 +93,17 @@ describe('SkipButton', () => {
// Then
expect(player.off).toHaveBeenCalledWith('srgssr/interval', skipButtonInstance.onTimeIntervalChange_);
});

it('should be registered and attached to the player', () => {
document.body.innerHTML = '<video id="test-video" class="video-js"></video>';

const videoElement = document.querySelector('#test-video');
const player = pillarbox(videoElement, {
SkipButton: true
});

expect(pillarbox.getComponent('SkipButton')).toBe(SkipButton);
expect(player.SkipButton).toBeDefined();
player.dispose();
});
});
8 changes: 8 additions & 0 deletions plugins/skip-button/vitest.config.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
import { defineProject } from 'vitest/config';
import path from 'path';

export default defineProject({
test: {
environment: 'jsdom'
}
});
26 changes: 0 additions & 26 deletions scripts/create-plugin.js

This file was deleted.

Loading

0 comments on commit ed26264

Please sign in to comment.