Skip to content

Commit

Permalink
Initial commit
Browse files Browse the repository at this point in the history
  • Loading branch information
Regani committed Oct 30, 2024
0 parents commit d2331f6
Show file tree
Hide file tree
Showing 12 changed files with 3,471 additions and 0 deletions.
6 changes: 6 additions & 0 deletions .eslintrc.cjs
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
/* eslint-env node */
module.exports = {
root: true,
parser: 'vue-eslint-parser',
extends: '@voicenter-team/vue',
}
21 changes: 21 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
.DS_Store
node_modules/
/dist/

# local env files
.env.local
.env.*.local

# Log files
npm-debug.log*
yarn-debug.log*
yarn-error.log*

# Editor directories and files
.idea
.vscode
*.suo
*.ntvs*
*.njsproj
*.sln
*.sw*
95 changes: 95 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,95 @@
# stream-vue

A Vue 3 component for cloudflare streaming. Uses [HSL](https://www.npmjs.com/package/hls.js/v/canary) for playing
streams See [cloudflare doc](https://developers.cloudflare.com/stream/viewing-videos/using-own-player/) for detailed
info

## Installation

Using npm:

```shell
$ npm i @voicenter-team/stream-vue-3
```

Using yarn:

```shell
$ yarn add @voicenter-team/stream-vue-3
```

## Usage
```vue
<template>
<VideoStream
videoId="your-video-id"
autoplay
muted
loop
controls
/>
</template>
<script lang="ts" setup>
import VideoStream from '@voicenter-team/stream-vue-3'
</script>
```

## Props

```ts
export type StreamProps = {
/**
* The video id for the video you’ve uploaded to Cloudflare Stream should be included here.
*/
videoId: string;
/**
* Tells the browser to immediately start downloading the video and play it as soon as it can. Note that mobile browsers generally do not support this attribute, the user must tap the screen to begin video playback. Please consider mobile users or users with Internet usage limits as some users don’t have unlimited Internet access before using this attribute.
*
* To disable video autoplay, the autoplay attribute needs to be removed altogether as this attribute. Setting autoplay="false" will not work; the video will autoplay if the attribute is there in the <stream> tag.
*
* In addition, some browsers now prevent videos with audio from playing automatically. You may add the mute attribute to allow your videos to autoplay. For more information, [go here](https://webkit.org/blog/6784/new-video-policies-for-ios/).
*
* @default false
*/
autoplay?: boolean;
/**
* Shows the default video controls such as buttons for play/pause, volume controls. You may choose to build buttons and controls that work with the player.
*
* @default false
*/
controls?: boolean;
/**
* Returns the current playback time in seconds. Setting this value seeks the video to a new time.
*
* @default 0
*/
currentTime?: number;
/**
* A Boolean attribute which indicates the default setting of the audio contained in the video. If set, the audio will be initially silenced.
*
* @default false
*/
muted?: boolean;
/**
* A Boolean attribute; if included the player will automatically seek back to the start upon reaching the end of the video.
*
* @default false
*/
loop?: boolean;
/**
* This enumerated attribute is intended to provide a hint to the browser about what the author thinks will lead to the best user experience. You may choose to include this attribute as a boolean attribute without a value, or you may specify the value preload="auto" to preload the beginning of the video. Not including the attribute or using preload="metadata" will just load the metadata needed to start video playback when requested.
*
* The <video> element does not force the browser to follow the value of this attribute; it is a mere hint. Even though the preload="none" option is a valid HTML5 attribute, Stream player will always load some metadata to initialize the player. The amount of data loaded in this case is negligable.
*
* @default auto
*/
preload?: 'auto' | 'metadata' | 'none' | boolean;
/**
* Sets volume from 0.0 (silent) to 1.0 (maximum value)
*
* @default 1
*/
volume?: number;
};
```
22 changes: 22 additions & 0 deletions dev/App.vue
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
<template>
<VideoStream
video-id="9d5a2b7868d9562a57a98e7afdaf385a"
class="video"
autoplay
muted
loop
controls
/>
</template>

<script lang="ts" setup>
import VideoStream from '@/VideoStream.vue'
</script>

<style>
.video {
object-fit: cover;
width: 100%;
height: 100%;
}
</style>
6 changes: 6 additions & 0 deletions dev/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
import { createApp } from 'vue'

import App from './App.vue'

createApp(App)
.mount('#app')
13 changes: 13 additions & 0 deletions index.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<link rel="icon" href="/favicon.ico" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Video Stream Vue 3</title>
</head>
<body>
<div id="app"></div>
<script type="module" src="/dev/index.ts"></script>
</body>
</html>
Loading

0 comments on commit d2331f6

Please sign in to comment.