Skip to content

Commit

Permalink
Merge pull request #98 from datocms/feat/c3-create-video-player
Browse files Browse the repository at this point in the history
Add `<VideoPlayer />` component
  • Loading branch information
sistrall authored Feb 29, 2024
2 parents 0cb6c87 + 66e33f9 commit 5e238bb
Show file tree
Hide file tree
Showing 13 changed files with 1,108 additions and 12 deletions.
2 changes: 2 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -29,12 +29,14 @@ A set of components and utilities to work faster with [DatoCMS](https://www.dato
[Components](https://vuejs.org/guide/essentials/component-basics.html):

- [`<DatocmsImage />`](src/components/Image)
- [`<DatocmsVideoPlayer />`](src/components/VideoPlayer)
- [`<DatocmsStructuredText />`](src/components/StructuredText)

[Composables](https://vuejs.org/guide/reusability/composables.html):

- [`useQuerySubscription`](src/composables/useQuerySubscription)
- [`useSiteSearch`](src/composables/useSiteSearch)
- [`useVideoPlayer`](src/composables/useVideoPlayer)

Helpers:

Expand Down
81 changes: 78 additions & 3 deletions examples/vite-typescript-vue3/package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

40 changes: 34 additions & 6 deletions examples/vite-typescript-vue3/src/App.vue
Original file line number Diff line number Diff line change
@@ -1,8 +1,19 @@
<script setup lang="ts">
import { ref, onMounted, h } from 'vue';
import { Image, StructuredText } from 'vue-datocms'
import { onMounted, ref } from 'vue';
import { Image, StructuredText, VideoPlayer } from 'vue-datocms';
const video = ref({
muxPlaybackId: 'ip028MAXF026dU900bKiyNDttjonw7A1dFY',
title: 'Title',
width: 1080,
height: 1920,
blurUpThumb:
'',
});
const videoPlayer = ref();
const blogPosts = ref<any[]>([])
Expand Down Expand Up @@ -42,15 +53,32 @@ onMounted(async () => {
<template>
<div>
<h1>Last 3 posts from the blog</h1>

<div style="display: grid; grid-template-columns: repeat(2, 1fr); grid-gap: 1rem;">
<div v-for="post in blogPosts">
<h2>{{ post.title }}</h2>
<Image v-if="post.coverImage" :data="post.coverImage.responsiveImage"/>
<Image v-if="post.coverImage" :data="post.coverImage.responsiveImage" />
<StructuredText :data="post.excerpt" />
</div>
</div>

<h1>Video examples</h1>
<hr />
<VideoPlayer :data="video" class="video-player" controls :auto-play="'muted'" :disable-cookies="false"
@pause="console.log" @playing="console.log" />
<hr />
<VideoPlayer :data="video" :style="{ aspectRatio: '1 / 1' }" accent-color="#ffff00" :disable-cookies="true" />
<hr />
<VideoPlayer :data="video" :style="{ aspectRatio: undefined }" accent-color="#ffff00" />
<hr />
<VideoPlayer :data="video" :style="{ aspectRatio: '10 / 1', '--controls': 'none', '--media-object-fit': 'cover' }"
auto-play="muted" loop />
<hr />
<VideoPlayer :data="video" :style="undefined" auto-play="muted" />
<hr />
<VideoPlayer :data="{ playbackId: 'ip028MAXF026dU900bKiyNDttjonw7A1dFY' }" />

</div>
</template>

<style>
</style>
<style></style>
Loading

0 comments on commit 5e238bb

Please sign in to comment.