This repository contains a simple app that enables all connected clients to watch videos together, build a shared playlist, transfer who is in control, and annotate over the video.
You can use this sample as a template to build a robust media synchronization feature into your app, or use it as an example.
Each SharedObject
in our schema (as defined in the /src/live-share-hooks/useSharedObjects.js
file) has a correlating hook in the live-share-hooks folder.
We have found this structure to be very useful in composing advanced applications with Live Share using Functional React components, but you can compose this differently for your app.
After cloning the repository, you must first set up the npm workspace from the root of the project. Then, run the following commands from the command line:
npm install
npm run build:packages # Build Live Share packages
cd samples/t*/21*
Note: Do not run npm start
before running npm run build:packages
from the root of the project, unless you first move the sample out of this npm workspace. When using our samples, you are testing the packages using symlinks, and not the Live Share SDK versions published to npm.
Running npm run start
, it will do two things: start the tinylicious
server and start the application using vite
. If you have never used tinylicious
before, you should see instead is a prompt saying Ok to proceed? (y)
, after which you should type y
and press the "enter" key. In rare cases you might not see the Ok to proceed? (y)
prompt, in which case try running npx tinylicious@latest
in your command line directly, and then try again.
Open http://localhost:3000 to view it in your browser.
The page will reload when you make changes.
Upon loading, if there is no /#{id}
in the URL, it will create one and insert it into the URL.
You can copy this URL and paste it into new browser tabs to test Live Share using a local server.
To test the side panel & video queue, you can replace your URL with /sidepanel#{id}
.
Note: if testing with HTTPS, such as when using a tunneling service like Ngrok, instead use the command npm run start-https
.
When not in Teams, we don't have a way to know the user's userId, so we generate a random one.
That means you might not always start out in control of playback, and need to press "Take control".
Tab configuration page doesn't do anything in browser.
There are two options for testing this sample in Teams. The first is to use ngrok to serve and tunnel the app locally, before zipping the app package.
Alternatively, you can use our ready-to-use demo app package. After downloading the zip file and setting up ngrok, you can skip ahead to the Test it out section.
- Download ngrok.
- Launch ngrok with port 3000.
ngrok http 3000 --host-header=localhost
(You will need an ngrok account to use host-header) - In a second terminal, run
npm run start-https
(rather than the traditionalnpm run start
)
- Open
.\manifest\manifest.json
and update values in it, including your [Application ID](https://learn.microsoft.com/microsoftteams/platform/resources/schema/manifest-schema#id. - You must replace
https://<<BASE_URI_DOMAIN>>
with the https path to your ngrok tunnel. - It is recommended that you also update the following fields.
- Set
developer.name
to your name. - Update
developer.websiteUrl
with your website. - Update
developer.privacyUrl
with your privacy policy. - Update
developer.termsOfUseUrl
with your terms of use.
- Set
- Create a zip file with the contents of
.\manifest
directory so that manifest.json, color.png, and outline.png are in the root directory of the zip file.- On Windows, select all files in
.\manifest
directory and compress them to zip. - Give your zip file a descriptive name, e.g.
ContosoMediaTemplate
.
- On Windows, select all files in
- Schedule a meeting for testing from calendar in Teams.
- Join the meeting.
- In the meeting window, tap on + Apps and tap on Manage apps in the flyout that opens.
- In the Manage apps pane, tap on Upload a custom app.
- Don't see the option to Upload a custom app?! Follow instructions here to enable custom-apps in your tenant.
- Select the zip file you created earlier and upload it.
- In the dialog that shows up, tap Add to add your sample app into the meeting.
- Now, back in the meeting window, tap + Apps again and type the name of your app in the Find an app textbox.
- Select the app to activate it in the meeting.
- In the configuration dialog, just tap Save to add your app into the meeting.
- In the side panel, tap the share icon to put your app on the main stage in the meeting.
- That's it! You should now see react-media-template on the meeting stage.
- Your friends/colleagues invited to the meeting should be able to see your app on stage when they join the meeting.
To make a new app manifest, you can visit the Teams Developer Portal.
Builds the app for production to the dist
folder.
The build is minified and the filenames include the hashes. Your app is ready to be deployed!