diff --git a/__tests__/loom.test.js b/__tests__/loom.test.js new file mode 100644 index 0000000..c7acab7 --- /dev/null +++ b/__tests__/loom.test.js @@ -0,0 +1,46 @@ +/* eslint max-len: 0 */ +import fn from '../src/index.js'; + +/** + * Loom should be able to find these patterns: + * + * Urls: + * https://www.loom.com/share/* + * https://www.loom.com/share/*? + * https://www.loom.com/embed/* + */ +describe('Loom', () => { + test('extracts loom video id in url without query parameters', () => { + expect(fn('https://www.loom.com/share/1234').id).toBe('1234'); + expect(fn('https://loom.com/share/1234').id).toBe('1234'); + }); + + test('extracts loom video ids without www.', () => { + expect(fn('https://loom.com/share/1234').id).toBe('1234'); + expect(fn('https://loom.com/embed/1234').id).toBe('1234'); + }); + + test('extracts loom video id in url with query parameters', () => { + expect(fn('https://www.loom.com/share/1234?source=embed&t=20').id).toBe('1234'); + expect(fn('https://loom.com/share/1234?source=embed&t=20').id).toBe('1234'); + expect(fn('https://www.loom.com/share/1234?source=embed&t=20#foo').id).toBe('1234'); + expect(fn('https://loom.com/share/1234?source=embed&t=20#foo').id).toBe('1234'); + }); + + test('extracts video id from loom embed codes', () => { + expect(fn('https://www.loom.com/embed/1234?source=embed&t=20').id).toBe('1234'); + expect(fn('https://loom.com/embed/1234?source=embed&t=20').id).toBe('1234'); + expect(fn('https://www.loom.com/embed/1234?source=embed&t=20#foo').id).toBe('1234'); + expect(fn('https://loom.com/embed/1234?source=embed&t=20#foo').id).toBe('1234'); + expect(fn('
').id).toBe('12345'); + expect(fn('
').id).toBe('12345'); + expect(fn('
').id).toBe('123456'); + expect(fn('
').id).toBe('123456'); + }); + + test('returns undefined for unknown video ids', () => { + const actual = fn('https://www.loom.com'); + expect(actual.id).toBeUndefined(); + expect(actual.service).toBe('loom'); + }); +}); diff --git a/index.d.ts b/index.d.ts index 565c185..9ff967a 100644 --- a/index.d.ts +++ b/index.d.ts @@ -2,5 +2,5 @@ export default function getVideoId( url: string ): { id: string | undefined; - service: 'youtube' | 'vimeo' | 'vine' | 'videopress' | 'microsoftstream' | 'tiktok' | 'dailymotion' | undefined; + service: 'youtube' | 'vimeo' | 'vine' | 'videopress' | 'microsoftstream' | 'tiktok' | 'dailymotion' | 'loom' | undefined; }; diff --git a/package.json b/package.json index b64dca5..cd46cd7 100644 --- a/package.json +++ b/package.json @@ -1,7 +1,7 @@ { "name": "get-video-id", "version": "3.5.3", - "description": "Get the YouTube, Vimeo, Vine, Microsoft Steam, Dailymotion, TikTok or VideoPress video id from a url or embed string.", + "description": "Get the YouTube, Vimeo, Vine, VideoPress, TikTok, Microsoft Stream, Loom and Dailymotion video id from a url or embed string.", "license": "MIT", "repository": "radiovisual/get-video-id", "main": "dist/get-video-id.js", @@ -43,6 +43,7 @@ "url", "vine", "vimeo", + "loom", "youtube", "videopress", "microsoft stream", diff --git a/readme.md b/readme.md index 10fb9a2..2dc165f 100644 --- a/readme.md +++ b/readme.md @@ -1,15 +1,22 @@ # get-video-id [![codecov](https://codecov.io/gh/radiovisual/get-video-id/branch/master/graph/badge.svg?token=fG7V2VRDYY)](https://codecov.io/gh/radiovisual/get-video-id) -> Get the YouTube, Vimeo, Vine, VideoPress, TikTok, Microsoft Stream and Dailymotion video id from a url or embed string. +> Get the YouTube, Vimeo, Vine, VideoPress, TikTok, Microsoft Stream, Loom and Dailymotion video id from a url or embed string. **Pull Requests are welcome** if you would like to see support for other video services or if you find an unsupported video url pattern. ## Install +You can install with npm: + ``` $ npm install --save get-video-id ``` +or with yarn: + +``` +$ yarn add get-video-id +``` ## Import @@ -70,8 +77,8 @@ Returns a metadata `Object` with the video `id` and `service` name: ``` { - id: 'String', - service: 'String' + id: `String` | `undefined`, + service: `String` | `undefined` } ``` @@ -98,7 +105,7 @@ http://y2u.be/* youtube:// ``` -*YouTube Shorts** +**YouTube Shorts** ``` https://youtube.com/shorts/* https://www.youtube.com/shorts/* @@ -252,6 +259,7 @@ https://web.microsoftstream.com/embed/video/* ``` ``` + ### TikTok **TikTok urls** @@ -281,6 +289,20 @@ http://dai.ly/* **:warning: Unsupported Dailymotion urls** * Channel id urls: `http://www.dailymotion.com/hub/*_title` +### Loom + +**Loom urls** +``` +https://www.loom.com/share/* +https://www.loom.com/share/*? +https://www.loom.com/embed/* + ``` + +**Loom iframes** +``` + +``` + ## Contributing If you discover a url pattern that is not covered by this module, please [open an issue](https://github.com/radiovisual/get-video-id/issues) to report it, or [submit a Pull Request](https://github.com/radiovisual/get-video-id/pull/new/master). For any submitted pull requests, please ensure that you include unit test(s) to fully cover your code contribution(s). diff --git a/src/index.js b/src/index.js index 88753db..f539a74 100644 --- a/src/index.js +++ b/src/index.js @@ -5,6 +5,7 @@ import videopress from './videopress.js'; import microsoftStream from './microsoftstream.js'; import tiktok from './tiktok.js'; import dailymotion from './dailymotion.js'; +import loom from './loom.js'; import sanitizeUrl from './utils/sanitize-url.js'; import extractGoogleRedirectionUrl from './utils/extract-google-redirection-url.js'; @@ -61,6 +62,11 @@ function getVideoId(urlString) { id: dailymotion(url), service: 'dailymotion', }; + } else if (/loom\.com/.test(string_)) { + metadata = { + id: loom(string_), + service: 'loom', + }; } return metadata; diff --git a/src/loom.js b/src/loom.js new file mode 100644 index 0000000..1f07603 --- /dev/null +++ b/src/loom.js @@ -0,0 +1,15 @@ +/** + * Get the loom id. + * @param {string} urlString - the url from which you want to extract the id + * @returns {string|undefined} + */ +export default function loom(urlString) { + const regex = /^https?:\/\/(?:www\.)?loom\.com\/(?:share|embed)\/([\da-zA-Z]+)\/?/; + const matches = regex.exec(urlString); + + if (matches && matches.length > 1) { + return matches[1]; + } + + return undefined; +}