@wordpress/block-library 9.26.1-next.719a03cbe.0 → 9.27.1-next.46f643fa0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +2 -0
- package/build/categories/edit.js +15 -3
- package/build/categories/edit.js.map +1 -1
- package/build/cover/edit/block-controls.js +4 -2
- package/build/cover/edit/block-controls.js.map +1 -1
- package/build/cover/edit/index.js +6 -3
- package/build/cover/edit/index.js.map +1 -1
- package/build/cover/edit/inspector-controls.js +13 -4
- package/build/cover/edit/inspector-controls.js.map +1 -1
- package/build/cover/index.js +6 -0
- package/build/cover/index.js.map +1 -1
- package/build/cover/save.js +3 -1
- package/build/cover/save.js.map +1 -1
- package/build/file/edit.js +2 -1
- package/build/file/edit.js.map +1 -1
- package/build/latest-posts/edit.js +0 -2
- package/build/latest-posts/edit.js.map +1 -1
- package/build/media-text/edit.js +2 -2
- package/build/media-text/edit.js.map +1 -1
- package/build/navigation-link/edit.js +32 -15
- package/build/navigation-link/edit.js.map +1 -1
- package/build/navigation-link/update-attributes.js +112 -14
- package/build/navigation-link/update-attributes.js.map +1 -1
- package/build/navigation-submenu/edit.js +19 -2
- package/build/navigation-submenu/edit.js.map +1 -1
- package/build/paragraph/edit.js +2 -2
- package/build/paragraph/edit.js.map +1 -1
- package/build/post-content/edit.js +78 -16
- package/build/post-content/edit.js.map +1 -1
- package/build/post-content/index.js +6 -0
- package/build/post-content/index.js.map +1 -1
- package/build/post-date/deprecated.js +104 -1
- package/build/post-date/deprecated.js.map +1 -1
- package/build/post-date/edit.js +32 -32
- package/build/post-date/edit.js.map +1 -1
- package/build/post-date/index.js +4 -4
- package/build/post-date/index.js.map +1 -1
- package/build/post-date/variations.js +32 -3
- package/build/post-date/variations.js.map +1 -1
- package/build/separator/edit.js +5 -30
- package/build/separator/edit.js.map +1 -1
- package/build/site-tagline/index.js +1 -1
- package/build/social-link/variations.js +51 -49
- package/build/social-link/variations.js.map +1 -1
- package/build/utils/poster-image.js +93 -0
- package/build/utils/poster-image.js.map +1 -0
- package/build/video/edit.js +7 -6
- package/build/video/edit.js.map +1 -1
- package/build/video/tracks-editor.js +95 -104
- package/build/video/tracks-editor.js.map +1 -1
- package/build/video/tracks.js +6 -2
- package/build/video/tracks.js.map +1 -1
- package/build-module/categories/edit.js +15 -3
- package/build-module/categories/edit.js.map +1 -1
- package/build-module/cover/edit/block-controls.js +4 -2
- package/build-module/cover/edit/block-controls.js.map +1 -1
- package/build-module/cover/edit/index.js +6 -3
- package/build-module/cover/edit/index.js.map +1 -1
- package/build-module/cover/edit/inspector-controls.js +12 -4
- package/build-module/cover/edit/inspector-controls.js.map +1 -1
- package/build-module/cover/index.js +6 -0
- package/build-module/cover/index.js.map +1 -1
- package/build-module/cover/save.js +3 -1
- package/build-module/cover/save.js.map +1 -1
- package/build-module/file/edit.js +2 -1
- package/build-module/file/edit.js.map +1 -1
- package/build-module/latest-posts/edit.js +0 -2
- package/build-module/latest-posts/edit.js.map +1 -1
- package/build-module/media-text/edit.js +2 -2
- package/build-module/media-text/edit.js.map +1 -1
- package/build-module/navigation-link/edit.js +32 -15
- package/build-module/navigation-link/edit.js.map +1 -1
- package/build-module/navigation-link/update-attributes.js +113 -15
- package/build-module/navigation-link/update-attributes.js.map +1 -1
- package/build-module/navigation-submenu/edit.js +20 -3
- package/build-module/navigation-submenu/edit.js.map +1 -1
- package/build-module/paragraph/edit.js +2 -2
- package/build-module/paragraph/edit.js.map +1 -1
- package/build-module/post-content/edit.js +80 -18
- package/build-module/post-content/edit.js.map +1 -1
- package/build-module/post-content/index.js +6 -0
- package/build-module/post-content/index.js.map +1 -1
- package/build-module/post-date/deprecated.js +104 -1
- package/build-module/post-date/deprecated.js.map +1 -1
- package/build-module/post-date/edit.js +35 -35
- package/build-module/post-date/edit.js.map +1 -1
- package/build-module/post-date/index.js +4 -4
- package/build-module/post-date/index.js.map +1 -1
- package/build-module/post-date/variations.js +32 -3
- package/build-module/post-date/variations.js.map +1 -1
- package/build-module/separator/edit.js +6 -31
- package/build-module/separator/edit.js.map +1 -1
- package/build-module/site-tagline/index.js +1 -1
- package/build-module/social-link/variations.js +52 -50
- package/build-module/social-link/variations.js.map +1 -1
- package/build-module/utils/poster-image.js +85 -0
- package/build-module/utils/poster-image.js.map +1 -0
- package/build-module/video/edit.js +7 -6
- package/build-module/video/edit.js.map +1 -1
- package/build-module/video/tracks-editor.js +96 -105
- package/build-module/video/tracks-editor.js.map +1 -1
- package/build-module/video/tracks.js +6 -2
- package/build-module/video/tracks.js.map +1 -1
- package/build-style/archives/editor-rtl.css +0 -4
- package/build-style/archives/editor.css +0 -4
- package/build-style/editor-rtl.css +67 -18
- package/build-style/editor.css +67 -18
- package/build-style/file/style-rtl.css +1 -1
- package/build-style/file/style.css +1 -1
- package/build-style/navigation/editor-rtl.css +6 -6
- package/build-style/navigation/editor.css +6 -6
- package/build-style/navigation/style-rtl.css +1 -0
- package/build-style/navigation/style.css +1 -0
- package/build-style/page-list/editor-rtl.css +0 -4
- package/build-style/page-list/editor.css +0 -4
- package/build-style/style-rtl.css +3 -1
- package/build-style/style.css +3 -1
- package/build-style/video/editor-rtl.css +0 -4
- package/build-style/video/editor.css +0 -4
- package/build-style/video/style-rtl.css +1 -0
- package/build-style/video/style.css +1 -0
- package/package.json +35 -35
- package/src/archives/editor.scss +0 -4
- package/src/categories/edit.js +13 -1
- package/src/comments-pagination/index.php +7 -2
- package/src/cover/block.json +6 -0
- package/src/cover/edit/block-controls.js +22 -17
- package/src/cover/edit/index.js +4 -1
- package/src/cover/edit/inspector-controls.js +15 -2
- package/src/cover/save.js +2 -0
- package/src/editor.scss +1 -0
- package/src/file/edit.js +4 -1
- package/src/file/style.scss +1 -1
- package/src/latest-posts/edit.js +0 -2
- package/src/media-text/edit.js +1 -1
- package/src/navigation/style.scss +1 -0
- package/src/navigation-link/edit.js +28 -16
- package/src/navigation-link/test/edit.js +738 -6
- package/src/navigation-link/update-attributes.js +125 -12
- package/src/navigation-submenu/edit.js +21 -1
- package/src/page-list/editor.scss +0 -6
- package/src/paragraph/edit.js +2 -2
- package/src/post-content/block.json +6 -0
- package/src/post-content/edit.js +71 -19
- package/src/post-content/index.php +11 -4
- package/src/post-date/block.json +4 -4
- package/src/post-date/deprecated.js +104 -1
- package/src/post-date/edit.js +74 -86
- package/src/post-date/index.php +55 -28
- package/src/post-date/variations.js +37 -3
- package/src/post-featured-image/index.php +3 -2
- package/src/separator/edit.js +8 -43
- package/src/site-tagline/block.json +1 -1
- package/src/social-link/README.md +21 -0
- package/src/social-link/index.php +49 -49
- package/src/social-link/variations.js +51 -49
- package/src/utils/poster-image.js +131 -0
- package/src/utils/poster-image.scss +75 -0
- package/src/video/edit.js +8 -6
- package/src/video/editor.scss +0 -6
- package/src/video/index.php +91 -0
- package/src/video/style.native.scss +1 -0
- package/src/video/style.scss +1 -0
- package/src/video/tracks-editor.js +93 -103
- package/src/video/tracks.js +2 -1
- package/build/video/poster-image.js +0 -81
- package/build/video/poster-image.js.map +0 -1
- package/build-module/video/poster-image.js +0 -74
- package/build-module/video/poster-image.js.map +0 -1
- package/src/video/poster-image.js +0 -86
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["__","AmazonIcon","BandcampIcon","BehanceIcon","BlueskyIcon","ChainIcon","CodepenIcon","DeviantArtIcon","DiscordIcon","DribbbleIcon","DropboxIcon","EtsyIcon","FacebookIcon","FeedIcon","FivehundredpxIcon","FlickrIcon","FoursquareIcon","GoodreadsIcon","GoogleIcon","GitHubIcon","GravatarIcon","InstagramIcon","LastfmIcon","LinkedInIcon","MailIcon","MastodonIcon","MeetupIcon","MediumIcon","PatreonIcon","PinterestIcon","PocketIcon","RedditIcon","SkypeIcon","SnapchatIcon","SoundCloudIcon","SpotifyIcon","TelegramIcon","ThreadsIcon","TiktokIcon","TumblrIcon","TwitchIcon","TwitterIcon","VimeoIcon","VkIcon","WhatsAppIcon","WordPressIcon","XIcon","YelpIcon","YouTubeIcon","variations","isDefault","name","attributes","service","title","icon","keywords","forEach","variation","isActive","blockAttributes","variationAttributes"],"sources":["@wordpress/block-library/src/social-link/variations.js"],"sourcesContent":["/**\n * WordPress dependencies\n */\nimport { __ } from '@wordpress/i18n';\n\n/**\n * Internal dependencies\n */\nimport {\n\tAmazonIcon,\n\tBandcampIcon,\n\tBehanceIcon,\n\tBlueskyIcon,\n\tChainIcon,\n\tCodepenIcon,\n\tDeviantArtIcon,\n\tDiscordIcon,\n\tDribbbleIcon,\n\tDropboxIcon,\n\tEtsyIcon,\n\tFacebookIcon,\n\tFeedIcon,\n\tFivehundredpxIcon,\n\tFlickrIcon,\n\tFoursquareIcon,\n\tGoodreadsIcon,\n\tGoogleIcon,\n\tGitHubIcon,\n\tGravatarIcon,\n\tInstagramIcon,\n\tLastfmIcon,\n\tLinkedInIcon,\n\tMailIcon,\n\tMastodonIcon,\n\tMeetupIcon,\n\tMediumIcon,\n\tPatreonIcon,\n\tPinterestIcon,\n\tPocketIcon,\n\tRedditIcon,\n\tSkypeIcon,\n\tSnapchatIcon,\n\tSoundCloudIcon,\n\tSpotifyIcon,\n\tTelegramIcon,\n\tThreadsIcon,\n\tTiktokIcon,\n\tTumblrIcon,\n\tTwitchIcon,\n\tTwitterIcon,\n\tVimeoIcon,\n\tVkIcon,\n\tWhatsAppIcon,\n\tWordPressIcon,\n\tXIcon,\n\tYelpIcon,\n\tYouTubeIcon,\n} from './icons';\n\nconst variations = [\n\t{\n\t\tisDefault: true,\n\t\tname: 'wordpress',\n\t\tattributes: { service: 'wordpress' },\n\t\ttitle: __( 'WordPress' ),\n\t\ticon: WordPressIcon,\n\t},\n\n\t{\n\t\tname: 'fivehundredpx',\n\t\tattributes: { service: 'fivehundredpx' },\n\t\ttitle: __( '500px' ),\n\t\ticon: FivehundredpxIcon,\n\t},\n\t{\n\t\tname: 'amazon',\n\t\tattributes: { service: 'amazon' },\n\t\ttitle: __( 'Amazon' ),\n\t\ticon: AmazonIcon,\n\t},\n\t{\n\t\tname: 'bandcamp',\n\t\tattributes: { service: 'bandcamp' },\n\t\ttitle: __( 'Bandcamp' ),\n\t\ticon: BandcampIcon,\n\t},\n\t{\n\t\tname: 'behance',\n\t\tattributes: { service: 'behance' },\n\t\ttitle: __( 'Behance' ),\n\t\ticon: BehanceIcon,\n\t},\n\t{\n\t\tname: 'bluesky',\n\t\tattributes: { service: 'bluesky' },\n\t\ttitle: __( 'Bluesky' ),\n\t\ticon: BlueskyIcon,\n\t},\n\t{\n\t\tname: 'chain',\n\t\tattributes: { service: 'chain' },\n\t\ttitle: __( 'Link' ),\n\t\ticon: ChainIcon,\n\t},\n\t{\n\t\tname: 'codepen',\n\t\tattributes: { service: 'codepen' },\n\t\ttitle: __( 'CodePen' ),\n\t\ticon: CodepenIcon,\n\t},\n\t{\n\t\tname: 'deviantart',\n\t\tattributes: { service: 'deviantart' },\n\t\ttitle: __( 'DeviantArt' ),\n\t\ticon: DeviantArtIcon,\n\t},\n\t{\n\t\tname: 'discord',\n\t\tattributes: { service: 'discord' },\n\t\ttitle: __( 'Discord' ),\n\t\ticon: DiscordIcon,\n\t},\n\t{\n\t\tname: 'dribbble',\n\t\tattributes: { service: 'dribbble' },\n\t\ttitle: __( 'Dribbble' ),\n\t\ticon: DribbbleIcon,\n\t},\n\t{\n\t\tname: 'dropbox',\n\t\tattributes: { service: 'dropbox' },\n\t\ttitle: __( 'Dropbox' ),\n\t\ticon: DropboxIcon,\n\t},\n\t{\n\t\tname: 'etsy',\n\t\tattributes: { service: 'etsy' },\n\t\ttitle: __( 'Etsy' ),\n\t\ticon: EtsyIcon,\n\t},\n\t{\n\t\tname: 'facebook',\n\t\tattributes: { service: 'facebook' },\n\t\ttitle: __( 'Facebook' ),\n\t\ticon: FacebookIcon,\n\t},\n\t{\n\t\tname: 'feed',\n\t\tattributes: { service: 'feed' },\n\t\ttitle: __( 'RSS Feed' ),\n\t\ticon: FeedIcon,\n\t},\n\t{\n\t\tname: 'flickr',\n\t\tattributes: { service: 'flickr' },\n\t\ttitle: __( 'Flickr' ),\n\t\ticon: FlickrIcon,\n\t},\n\t{\n\t\tname: 'foursquare',\n\t\tattributes: { service: 'foursquare' },\n\t\ttitle: __( 'Foursquare' ),\n\t\ticon: FoursquareIcon,\n\t},\n\t{\n\t\tname: 'goodreads',\n\t\tattributes: { service: 'goodreads' },\n\t\ttitle: __( 'Goodreads' ),\n\t\ticon: GoodreadsIcon,\n\t},\n\t{\n\t\tname: 'google',\n\t\tattributes: { service: 'google' },\n\t\ttitle: __( 'Google' ),\n\t\ticon: GoogleIcon,\n\t},\n\t{\n\t\tname: 'github',\n\t\tattributes: { service: 'github' },\n\t\ttitle: __( 'GitHub' ),\n\t\ticon: GitHubIcon,\n\t},\n\t{\n\t\tname: 'gravatar',\n\t\tattributes: { service: 'gravatar' },\n\t\ttitle: __( 'Gravatar' ),\n\t\ticon: GravatarIcon,\n\t},\n\t{\n\t\tname: 'instagram',\n\t\tattributes: { service: 'instagram' },\n\t\ttitle: __( 'Instagram' ),\n\t\ticon: InstagramIcon,\n\t},\n\t{\n\t\tname: 'lastfm',\n\t\tattributes: { service: 'lastfm' },\n\t\ttitle: __( 'Last.fm' ),\n\t\ticon: LastfmIcon,\n\t},\n\t{\n\t\tname: 'linkedin',\n\t\tattributes: { service: 'linkedin' },\n\t\ttitle: __( 'LinkedIn' ),\n\t\ticon: LinkedInIcon,\n\t},\n\t{\n\t\tname: 'mail',\n\t\tattributes: { service: 'mail' },\n\t\ttitle: __( 'Mail' ),\n\t\tkeywords: [ 'email', 'e-mail' ],\n\t\ticon: MailIcon,\n\t},\n\t{\n\t\tname: 'mastodon',\n\t\tattributes: { service: 'mastodon' },\n\t\ttitle: __( 'Mastodon' ),\n\t\ticon: MastodonIcon,\n\t},\n\t{\n\t\tname: 'meetup',\n\t\tattributes: { service: 'meetup' },\n\t\ttitle: __( 'Meetup' ),\n\t\ticon: MeetupIcon,\n\t},\n\t{\n\t\tname: 'medium',\n\t\tattributes: { service: 'medium' },\n\t\ttitle: __( 'Medium' ),\n\t\ticon: MediumIcon,\n\t},\n\t{\n\t\tname: 'patreon',\n\t\tattributes: { service: 'patreon' },\n\t\ttitle: __( 'Patreon' ),\n\t\ticon: PatreonIcon,\n\t},\n\t{\n\t\tname: 'pinterest',\n\t\tattributes: { service: 'pinterest' },\n\t\ttitle: __( 'Pinterest' ),\n\t\ticon: PinterestIcon,\n\t},\n\t{\n\t\tname: 'pocket',\n\t\tattributes: { service: 'pocket' },\n\t\ttitle: __( 'Pocket' ),\n\t\ticon: PocketIcon,\n\t},\n\t{\n\t\tname: 'reddit',\n\t\tattributes: { service: 'reddit' },\n\t\ttitle: __( 'Reddit' ),\n\t\ticon: RedditIcon,\n\t},\n\t{\n\t\tname: 'skype',\n\t\tattributes: { service: 'skype' },\n\t\ttitle: __( 'Skype' ),\n\t\ticon: SkypeIcon,\n\t},\n\t{\n\t\tname: 'snapchat',\n\t\tattributes: { service: 'snapchat' },\n\t\ttitle: __( 'Snapchat' ),\n\t\ticon: SnapchatIcon,\n\t},\n\t{\n\t\tname: 'soundcloud',\n\t\tattributes: { service: 'soundcloud' },\n\t\ttitle: __( 'SoundCloud' ),\n\t\ticon: SoundCloudIcon,\n\t},\n\t{\n\t\tname: 'spotify',\n\t\tattributes: { service: 'spotify' },\n\t\ttitle: __( 'Spotify' ),\n\t\ticon: SpotifyIcon,\n\t},\n\t{\n\t\tname: 'telegram',\n\t\tattributes: { service: 'telegram' },\n\t\ttitle: __( 'Telegram' ),\n\t\ticon: TelegramIcon,\n\t},\n\t{\n\t\tname: 'threads',\n\t\tattributes: { service: 'threads' },\n\t\ttitle: __( 'Threads' ),\n\t\ticon: ThreadsIcon,\n\t},\n\t{\n\t\tname: 'tiktok',\n\t\tattributes: { service: 'tiktok' },\n\t\ttitle: __( 'TikTok' ),\n\t\ticon: TiktokIcon,\n\t},\n\t{\n\t\tname: 'tumblr',\n\t\tattributes: { service: 'tumblr' },\n\t\ttitle: __( 'Tumblr' ),\n\t\ticon: TumblrIcon,\n\t},\n\t{\n\t\tname: 'twitch',\n\t\tattributes: { service: 'twitch' },\n\t\ttitle: __( 'Twitch' ),\n\t\ticon: TwitchIcon,\n\t},\n\t{\n\t\tname: 'twitter',\n\t\tattributes: { service: 'twitter' },\n\t\ttitle: __( 'Twitter' ),\n\t\ticon: TwitterIcon,\n\t},\n\t{\n\t\tname: 'vimeo',\n\t\tattributes: { service: 'vimeo' },\n\t\ttitle: __( 'Vimeo' ),\n\t\ticon: VimeoIcon,\n\t},\n\t{\n\t\tname: 'vk',\n\t\tattributes: { service: 'vk' },\n\t\ttitle: __( 'VK' ),\n\t\ticon: VkIcon,\n\t},\n\t{\n\t\tname: 'whatsapp',\n\t\tattributes: { service: 'whatsapp' },\n\t\ttitle: __( 'WhatsApp' ),\n\t\ticon: WhatsAppIcon,\n\t},\n\t{\n\t\tname: 'x',\n\t\tattributes: { service: 'x' },\n\t\tkeywords: [ 'twitter' ],\n\t\ttitle: __( 'X' ),\n\t\ticon: XIcon,\n\t},\n\t{\n\t\tname: 'yelp',\n\t\tattributes: { service: 'yelp' },\n\t\ttitle: __( 'Yelp' ),\n\t\ticon: YelpIcon,\n\t},\n\t{\n\t\tname: 'youtube',\n\t\tattributes: { service: 'youtube' },\n\t\ttitle: __( 'YouTube' ),\n\t\ticon: YouTubeIcon,\n\t},\n];\n\n/**\n * Add `isActive` function to all `social link` variations, if not defined.\n * `isActive` function is used to find a variation match from a created\n * Block by providing its attributes.\n */\nvariations.forEach( ( variation ) => {\n\tif ( variation.isActive ) {\n\t\treturn;\n\t}\n\tvariation.isActive = ( blockAttributes, variationAttributes ) =>\n\t\tblockAttributes.service === variationAttributes.service;\n} );\n\nexport default variations;\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":["_x","AmazonIcon","BandcampIcon","BehanceIcon","BlueskyIcon","ChainIcon","CodepenIcon","DeviantArtIcon","DiscordIcon","DribbbleIcon","DropboxIcon","EtsyIcon","FacebookIcon","FeedIcon","FivehundredpxIcon","FlickrIcon","FoursquareIcon","GoodreadsIcon","GoogleIcon","GitHubIcon","GravatarIcon","InstagramIcon","LastfmIcon","LinkedInIcon","MailIcon","MastodonIcon","MeetupIcon","MediumIcon","PatreonIcon","PinterestIcon","PocketIcon","RedditIcon","SkypeIcon","SnapchatIcon","SoundCloudIcon","SpotifyIcon","TelegramIcon","ThreadsIcon","TiktokIcon","TumblrIcon","TwitchIcon","TwitterIcon","VimeoIcon","VkIcon","WhatsAppIcon","WordPressIcon","XIcon","YelpIcon","YouTubeIcon","variations","isDefault","name","attributes","service","title","icon","keywords","scope","forEach","variation","isActive","blockAttributes","variationAttributes"],"sources":["@wordpress/block-library/src/social-link/variations.js"],"sourcesContent":["/**\n * WordPress dependencies\n */\nimport { _x } from '@wordpress/i18n';\n\n/**\n * Internal dependencies\n */\nimport {\n\tAmazonIcon,\n\tBandcampIcon,\n\tBehanceIcon,\n\tBlueskyIcon,\n\tChainIcon,\n\tCodepenIcon,\n\tDeviantArtIcon,\n\tDiscordIcon,\n\tDribbbleIcon,\n\tDropboxIcon,\n\tEtsyIcon,\n\tFacebookIcon,\n\tFeedIcon,\n\tFivehundredpxIcon,\n\tFlickrIcon,\n\tFoursquareIcon,\n\tGoodreadsIcon,\n\tGoogleIcon,\n\tGitHubIcon,\n\tGravatarIcon,\n\tInstagramIcon,\n\tLastfmIcon,\n\tLinkedInIcon,\n\tMailIcon,\n\tMastodonIcon,\n\tMeetupIcon,\n\tMediumIcon,\n\tPatreonIcon,\n\tPinterestIcon,\n\tPocketIcon,\n\tRedditIcon,\n\tSkypeIcon,\n\tSnapchatIcon,\n\tSoundCloudIcon,\n\tSpotifyIcon,\n\tTelegramIcon,\n\tThreadsIcon,\n\tTiktokIcon,\n\tTumblrIcon,\n\tTwitchIcon,\n\tTwitterIcon,\n\tVimeoIcon,\n\tVkIcon,\n\tWhatsAppIcon,\n\tWordPressIcon,\n\tXIcon,\n\tYelpIcon,\n\tYouTubeIcon,\n} from './icons';\n\nconst variations = [\n\t{\n\t\tisDefault: true,\n\t\tname: 'wordpress',\n\t\tattributes: { service: 'wordpress' },\n\t\ttitle: _x( 'WordPress', 'social link block variation name' ),\n\t\ticon: WordPressIcon,\n\t},\n\n\t{\n\t\tname: 'fivehundredpx',\n\t\tattributes: { service: 'fivehundredpx' },\n\t\ttitle: _x( '500px', 'social link block variation name' ),\n\t\ticon: FivehundredpxIcon,\n\t},\n\t{\n\t\tname: 'amazon',\n\t\tattributes: { service: 'amazon' },\n\t\ttitle: _x( 'Amazon', 'social link block variation name' ),\n\t\ticon: AmazonIcon,\n\t},\n\t{\n\t\tname: 'bandcamp',\n\t\tattributes: { service: 'bandcamp' },\n\t\ttitle: _x( 'Bandcamp', 'social link block variation name' ),\n\t\ticon: BandcampIcon,\n\t},\n\t{\n\t\tname: 'behance',\n\t\tattributes: { service: 'behance' },\n\t\ttitle: _x( 'Behance', 'social link block variation name' ),\n\t\ticon: BehanceIcon,\n\t},\n\t{\n\t\tname: 'bluesky',\n\t\tattributes: { service: 'bluesky' },\n\t\ttitle: _x( 'Bluesky', 'social link block variation name' ),\n\t\ticon: BlueskyIcon,\n\t},\n\t{\n\t\tname: 'chain',\n\t\tattributes: { service: 'chain' },\n\t\ttitle: _x( 'Link', 'social link block variation name' ),\n\t\ticon: ChainIcon,\n\t},\n\t{\n\t\tname: 'codepen',\n\t\tattributes: { service: 'codepen' },\n\t\ttitle: _x( 'CodePen', 'social link block variation name' ),\n\t\ticon: CodepenIcon,\n\t},\n\t{\n\t\tname: 'deviantart',\n\t\tattributes: { service: 'deviantart' },\n\t\ttitle: _x( 'DeviantArt', 'social link block variation name' ),\n\t\ticon: DeviantArtIcon,\n\t},\n\t{\n\t\tname: 'discord',\n\t\tattributes: { service: 'discord' },\n\t\ttitle: _x( 'Discord', 'social link block variation name' ),\n\t\ticon: DiscordIcon,\n\t},\n\t{\n\t\tname: 'dribbble',\n\t\tattributes: { service: 'dribbble' },\n\t\ttitle: _x( 'Dribbble', 'social link block variation name' ),\n\t\ticon: DribbbleIcon,\n\t},\n\t{\n\t\tname: 'dropbox',\n\t\tattributes: { service: 'dropbox' },\n\t\ttitle: _x( 'Dropbox', 'social link block variation name' ),\n\t\ticon: DropboxIcon,\n\t},\n\t{\n\t\tname: 'etsy',\n\t\tattributes: { service: 'etsy' },\n\t\ttitle: _x( 'Etsy', 'social link block variation name' ),\n\t\ticon: EtsyIcon,\n\t},\n\t{\n\t\tname: 'facebook',\n\t\tattributes: { service: 'facebook' },\n\t\ttitle: _x( 'Facebook', 'social link block variation name' ),\n\t\ticon: FacebookIcon,\n\t},\n\t{\n\t\tname: 'feed',\n\t\tattributes: { service: 'feed' },\n\t\ttitle: _x( 'RSS Feed', 'social link block variation name' ),\n\t\ticon: FeedIcon,\n\t},\n\t{\n\t\tname: 'flickr',\n\t\tattributes: { service: 'flickr' },\n\t\ttitle: _x( 'Flickr', 'social link block variation name' ),\n\t\ticon: FlickrIcon,\n\t},\n\t{\n\t\tname: 'foursquare',\n\t\tattributes: { service: 'foursquare' },\n\t\ttitle: _x( 'Foursquare', 'social link block variation name' ),\n\t\ticon: FoursquareIcon,\n\t},\n\t{\n\t\tname: 'goodreads',\n\t\tattributes: { service: 'goodreads' },\n\t\ttitle: _x( 'Goodreads', 'social link block variation name' ),\n\t\ticon: GoodreadsIcon,\n\t},\n\t{\n\t\tname: 'google',\n\t\tattributes: { service: 'google' },\n\t\ttitle: _x( 'Google', 'social link block variation name' ),\n\t\ticon: GoogleIcon,\n\t},\n\t{\n\t\tname: 'github',\n\t\tattributes: { service: 'github' },\n\t\ttitle: _x( 'GitHub', 'social link block variation name' ),\n\t\ticon: GitHubIcon,\n\t},\n\t{\n\t\tname: 'gravatar',\n\t\tattributes: { service: 'gravatar' },\n\t\ttitle: _x( 'Gravatar', 'social link block variation name' ),\n\t\ticon: GravatarIcon,\n\t},\n\t{\n\t\tname: 'instagram',\n\t\tattributes: { service: 'instagram' },\n\t\ttitle: _x( 'Instagram', 'social link block variation name' ),\n\t\ticon: InstagramIcon,\n\t},\n\t{\n\t\tname: 'lastfm',\n\t\tattributes: { service: 'lastfm' },\n\t\ttitle: _x( 'Last.fm', 'social link block variation name' ),\n\t\ticon: LastfmIcon,\n\t},\n\t{\n\t\tname: 'linkedin',\n\t\tattributes: { service: 'linkedin' },\n\t\ttitle: _x( 'LinkedIn', 'social link block variation name' ),\n\t\ticon: LinkedInIcon,\n\t},\n\t{\n\t\tname: 'mail',\n\t\tattributes: { service: 'mail' },\n\t\ttitle: _x( 'Mail', 'social link block variation name' ),\n\t\tkeywords: [ 'email', 'e-mail' ],\n\t\ticon: MailIcon,\n\t},\n\t{\n\t\tname: 'mastodon',\n\t\tattributes: { service: 'mastodon' },\n\t\ttitle: _x( 'Mastodon', 'social link block variation name' ),\n\t\ticon: MastodonIcon,\n\t},\n\t{\n\t\tname: 'meetup',\n\t\tattributes: { service: 'meetup' },\n\t\ttitle: _x( 'Meetup', 'social link block variation name' ),\n\t\ticon: MeetupIcon,\n\t},\n\t{\n\t\tname: 'medium',\n\t\tattributes: { service: 'medium' },\n\t\ttitle: _x( 'Medium', 'social link block variation name' ),\n\t\ticon: MediumIcon,\n\t},\n\t{\n\t\tname: 'patreon',\n\t\tattributes: { service: 'patreon' },\n\t\ttitle: _x( 'Patreon', 'social link block variation name' ),\n\t\ticon: PatreonIcon,\n\t},\n\t{\n\t\tname: 'pinterest',\n\t\tattributes: { service: 'pinterest' },\n\t\ttitle: _x( 'Pinterest', 'social link block variation name' ),\n\t\ticon: PinterestIcon,\n\t},\n\t{\n\t\tname: 'pocket',\n\t\tattributes: { service: 'pocket' },\n\t\ttitle: _x( 'Pocket', 'social link block variation name' ),\n\t\ticon: PocketIcon,\n\t},\n\t{\n\t\tname: 'reddit',\n\t\tattributes: { service: 'reddit' },\n\t\ttitle: _x( 'Reddit', 'social link block variation name' ),\n\t\ticon: RedditIcon,\n\t},\n\t{\n\t\tname: 'skype',\n\t\tattributes: { service: 'skype' },\n\t\ttitle: _x( 'Skype', 'social link block variation name' ),\n\t\ticon: SkypeIcon,\n\t\t// Deprecated: Skype service is no longer available.\n\t\tscope: [],\n\t},\n\t{\n\t\tname: 'snapchat',\n\t\tattributes: { service: 'snapchat' },\n\t\ttitle: _x( 'Snapchat', 'social link block variation name' ),\n\t\ticon: SnapchatIcon,\n\t},\n\t{\n\t\tname: 'soundcloud',\n\t\tattributes: { service: 'soundcloud' },\n\t\ttitle: _x( 'SoundCloud', 'social link block variation name' ),\n\t\ticon: SoundCloudIcon,\n\t},\n\t{\n\t\tname: 'spotify',\n\t\tattributes: { service: 'spotify' },\n\t\ttitle: _x( 'Spotify', 'social link block variation name' ),\n\t\ticon: SpotifyIcon,\n\t},\n\t{\n\t\tname: 'telegram',\n\t\tattributes: { service: 'telegram' },\n\t\ttitle: _x( 'Telegram', 'social link block variation name' ),\n\t\ticon: TelegramIcon,\n\t},\n\t{\n\t\tname: 'threads',\n\t\tattributes: { service: 'threads' },\n\t\ttitle: _x( 'Threads', 'social link block variation name' ),\n\t\ticon: ThreadsIcon,\n\t},\n\t{\n\t\tname: 'tiktok',\n\t\tattributes: { service: 'tiktok' },\n\t\ttitle: _x( 'TikTok', 'social link block variation name' ),\n\t\ticon: TiktokIcon,\n\t},\n\t{\n\t\tname: 'tumblr',\n\t\tattributes: { service: 'tumblr' },\n\t\ttitle: _x( 'Tumblr', 'social link block variation name' ),\n\t\ticon: TumblrIcon,\n\t},\n\t{\n\t\tname: 'twitch',\n\t\tattributes: { service: 'twitch' },\n\t\ttitle: _x( 'Twitch', 'social link block variation name' ),\n\t\ticon: TwitchIcon,\n\t},\n\t{\n\t\tname: 'twitter',\n\t\tattributes: { service: 'twitter' },\n\t\ttitle: _x( 'Twitter', 'social link block variation name' ),\n\t\ticon: TwitterIcon,\n\t},\n\t{\n\t\tname: 'vimeo',\n\t\tattributes: { service: 'vimeo' },\n\t\ttitle: _x( 'Vimeo', 'social link block variation name' ),\n\t\ticon: VimeoIcon,\n\t},\n\t{\n\t\tname: 'vk',\n\t\tattributes: { service: 'vk' },\n\t\ttitle: _x( 'VK', 'social link block variation name' ),\n\t\ticon: VkIcon,\n\t},\n\t{\n\t\tname: 'whatsapp',\n\t\tattributes: { service: 'whatsapp' },\n\t\ttitle: _x( 'WhatsApp', 'social link block variation name' ),\n\t\ticon: WhatsAppIcon,\n\t},\n\t{\n\t\tname: 'x',\n\t\tattributes: { service: 'x' },\n\t\tkeywords: [ 'twitter' ],\n\t\ttitle: _x( 'X', 'social link block variation name' ),\n\t\ticon: XIcon,\n\t},\n\t{\n\t\tname: 'yelp',\n\t\tattributes: { service: 'yelp' },\n\t\ttitle: _x( 'Yelp', 'social link block variation name' ),\n\t\ticon: YelpIcon,\n\t},\n\t{\n\t\tname: 'youtube',\n\t\tattributes: { service: 'youtube' },\n\t\ttitle: _x( 'YouTube', 'social link block variation name' ),\n\t\ticon: YouTubeIcon,\n\t},\n];\n\n/**\n * Add `isActive` function to all `social link` variations, if not defined.\n * `isActive` function is used to find a variation match from a created\n * Block by providing its attributes.\n */\nvariations.forEach( ( variation ) => {\n\tif ( variation.isActive ) {\n\t\treturn;\n\t}\n\tvariation.isActive = ( blockAttributes, variationAttributes ) =>\n\t\tblockAttributes.service === variationAttributes.service;\n} );\n\nexport default variations;\n"],"mappings":"AAAA;AACA;AACA;AACA,SAASA,EAAE,QAAQ,iBAAiB;;AAEpC;AACA;AACA;AACA,SACCC,UAAU,EACVC,YAAY,EACZC,WAAW,EACXC,WAAW,EACXC,SAAS,EACTC,WAAW,EACXC,cAAc,EACdC,WAAW,EACXC,YAAY,EACZC,WAAW,EACXC,QAAQ,EACRC,YAAY,EACZC,QAAQ,EACRC,iBAAiB,EACjBC,UAAU,EACVC,cAAc,EACdC,aAAa,EACbC,UAAU,EACVC,UAAU,EACVC,YAAY,EACZC,aAAa,EACbC,UAAU,EACVC,YAAY,EACZC,QAAQ,EACRC,YAAY,EACZC,UAAU,EACVC,UAAU,EACVC,WAAW,EACXC,aAAa,EACbC,UAAU,EACVC,UAAU,EACVC,SAAS,EACTC,YAAY,EACZC,cAAc,EACdC,WAAW,EACXC,YAAY,EACZC,WAAW,EACXC,UAAU,EACVC,UAAU,EACVC,UAAU,EACVC,WAAW,EACXC,SAAS,EACTC,MAAM,EACNC,YAAY,EACZC,aAAa,EACbC,KAAK,EACLC,QAAQ,EACRC,WAAW,QACL,SAAS;AAEhB,MAAMC,UAAU,GAAG,CAClB;EACCC,SAAS,EAAE,IAAI;EACfC,IAAI,EAAE,WAAW;EACjBC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAY,CAAC;EACpCC,KAAK,EAAEtD,EAAE,CAAE,WAAW,EAAE,kCAAmC,CAAC;EAC5DuD,IAAI,EAAEV;AACP,CAAC,EAED;EACCM,IAAI,EAAE,eAAe;EACrBC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAgB,CAAC;EACxCC,KAAK,EAAEtD,EAAE,CAAE,OAAO,EAAE,kCAAmC,CAAC;EACxDuD,IAAI,EAAEzC;AACP,CAAC,EACD;EACCqC,IAAI,EAAE,QAAQ;EACdC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAS,CAAC;EACjCC,KAAK,EAAEtD,EAAE,CAAE,QAAQ,EAAE,kCAAmC,CAAC;EACzDuD,IAAI,EAAEtD;AACP,CAAC,EACD;EACCkD,IAAI,EAAE,UAAU;EAChBC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAW,CAAC;EACnCC,KAAK,EAAEtD,EAAE,CAAE,UAAU,EAAE,kCAAmC,CAAC;EAC3DuD,IAAI,EAAErD;AACP,CAAC,EACD;EACCiD,IAAI,EAAE,SAAS;EACfC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAU,CAAC;EAClCC,KAAK,EAAEtD,EAAE,CAAE,SAAS,EAAE,kCAAmC,CAAC;EAC1DuD,IAAI,EAAEpD;AACP,CAAC,EACD;EACCgD,IAAI,EAAE,SAAS;EACfC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAU,CAAC;EAClCC,KAAK,EAAEtD,EAAE,CAAE,SAAS,EAAE,kCAAmC,CAAC;EAC1DuD,IAAI,EAAEnD;AACP,CAAC,EACD;EACC+C,IAAI,EAAE,OAAO;EACbC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAQ,CAAC;EAChCC,KAAK,EAAEtD,EAAE,CAAE,MAAM,EAAE,kCAAmC,CAAC;EACvDuD,IAAI,EAAElD;AACP,CAAC,EACD;EACC8C,IAAI,EAAE,SAAS;EACfC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAU,CAAC;EAClCC,KAAK,EAAEtD,EAAE,CAAE,SAAS,EAAE,kCAAmC,CAAC;EAC1DuD,IAAI,EAAEjD;AACP,CAAC,EACD;EACC6C,IAAI,EAAE,YAAY;EAClBC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAa,CAAC;EACrCC,KAAK,EAAEtD,EAAE,CAAE,YAAY,EAAE,kCAAmC,CAAC;EAC7DuD,IAAI,EAAEhD;AACP,CAAC,EACD;EACC4C,IAAI,EAAE,SAAS;EACfC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAU,CAAC;EAClCC,KAAK,EAAEtD,EAAE,CAAE,SAAS,EAAE,kCAAmC,CAAC;EAC1DuD,IAAI,EAAE/C;AACP,CAAC,EACD;EACC2C,IAAI,EAAE,UAAU;EAChBC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAW,CAAC;EACnCC,KAAK,EAAEtD,EAAE,CAAE,UAAU,EAAE,kCAAmC,CAAC;EAC3DuD,IAAI,EAAE9C;AACP,CAAC,EACD;EACC0C,IAAI,EAAE,SAAS;EACfC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAU,CAAC;EAClCC,KAAK,EAAEtD,EAAE,CAAE,SAAS,EAAE,kCAAmC,CAAC;EAC1DuD,IAAI,EAAE7C;AACP,CAAC,EACD;EACCyC,IAAI,EAAE,MAAM;EACZC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAO,CAAC;EAC/BC,KAAK,EAAEtD,EAAE,CAAE,MAAM,EAAE,kCAAmC,CAAC;EACvDuD,IAAI,EAAE5C;AACP,CAAC,EACD;EACCwC,IAAI,EAAE,UAAU;EAChBC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAW,CAAC;EACnCC,KAAK,EAAEtD,EAAE,CAAE,UAAU,EAAE,kCAAmC,CAAC;EAC3DuD,IAAI,EAAE3C;AACP,CAAC,EACD;EACCuC,IAAI,EAAE,MAAM;EACZC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAO,CAAC;EAC/BC,KAAK,EAAEtD,EAAE,CAAE,UAAU,EAAE,kCAAmC,CAAC;EAC3DuD,IAAI,EAAE1C;AACP,CAAC,EACD;EACCsC,IAAI,EAAE,QAAQ;EACdC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAS,CAAC;EACjCC,KAAK,EAAEtD,EAAE,CAAE,QAAQ,EAAE,kCAAmC,CAAC;EACzDuD,IAAI,EAAExC;AACP,CAAC,EACD;EACCoC,IAAI,EAAE,YAAY;EAClBC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAa,CAAC;EACrCC,KAAK,EAAEtD,EAAE,CAAE,YAAY,EAAE,kCAAmC,CAAC;EAC7DuD,IAAI,EAAEvC;AACP,CAAC,EACD;EACCmC,IAAI,EAAE,WAAW;EACjBC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAY,CAAC;EACpCC,KAAK,EAAEtD,EAAE,CAAE,WAAW,EAAE,kCAAmC,CAAC;EAC5DuD,IAAI,EAAEtC;AACP,CAAC,EACD;EACCkC,IAAI,EAAE,QAAQ;EACdC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAS,CAAC;EACjCC,KAAK,EAAEtD,EAAE,CAAE,QAAQ,EAAE,kCAAmC,CAAC;EACzDuD,IAAI,EAAErC;AACP,CAAC,EACD;EACCiC,IAAI,EAAE,QAAQ;EACdC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAS,CAAC;EACjCC,KAAK,EAAEtD,EAAE,CAAE,QAAQ,EAAE,kCAAmC,CAAC;EACzDuD,IAAI,EAAEpC;AACP,CAAC,EACD;EACCgC,IAAI,EAAE,UAAU;EAChBC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAW,CAAC;EACnCC,KAAK,EAAEtD,EAAE,CAAE,UAAU,EAAE,kCAAmC,CAAC;EAC3DuD,IAAI,EAAEnC;AACP,CAAC,EACD;EACC+B,IAAI,EAAE,WAAW;EACjBC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAY,CAAC;EACpCC,KAAK,EAAEtD,EAAE,CAAE,WAAW,EAAE,kCAAmC,CAAC;EAC5DuD,IAAI,EAAElC;AACP,CAAC,EACD;EACC8B,IAAI,EAAE,QAAQ;EACdC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAS,CAAC;EACjCC,KAAK,EAAEtD,EAAE,CAAE,SAAS,EAAE,kCAAmC,CAAC;EAC1DuD,IAAI,EAAEjC;AACP,CAAC,EACD;EACC6B,IAAI,EAAE,UAAU;EAChBC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAW,CAAC;EACnCC,KAAK,EAAEtD,EAAE,CAAE,UAAU,EAAE,kCAAmC,CAAC;EAC3DuD,IAAI,EAAEhC;AACP,CAAC,EACD;EACC4B,IAAI,EAAE,MAAM;EACZC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAO,CAAC;EAC/BC,KAAK,EAAEtD,EAAE,CAAE,MAAM,EAAE,kCAAmC,CAAC;EACvDwD,QAAQ,EAAE,CAAE,OAAO,EAAE,QAAQ,CAAE;EAC/BD,IAAI,EAAE/B;AACP,CAAC,EACD;EACC2B,IAAI,EAAE,UAAU;EAChBC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAW,CAAC;EACnCC,KAAK,EAAEtD,EAAE,CAAE,UAAU,EAAE,kCAAmC,CAAC;EAC3DuD,IAAI,EAAE9B;AACP,CAAC,EACD;EACC0B,IAAI,EAAE,QAAQ;EACdC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAS,CAAC;EACjCC,KAAK,EAAEtD,EAAE,CAAE,QAAQ,EAAE,kCAAmC,CAAC;EACzDuD,IAAI,EAAE7B;AACP,CAAC,EACD;EACCyB,IAAI,EAAE,QAAQ;EACdC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAS,CAAC;EACjCC,KAAK,EAAEtD,EAAE,CAAE,QAAQ,EAAE,kCAAmC,CAAC;EACzDuD,IAAI,EAAE5B;AACP,CAAC,EACD;EACCwB,IAAI,EAAE,SAAS;EACfC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAU,CAAC;EAClCC,KAAK,EAAEtD,EAAE,CAAE,SAAS,EAAE,kCAAmC,CAAC;EAC1DuD,IAAI,EAAE3B;AACP,CAAC,EACD;EACCuB,IAAI,EAAE,WAAW;EACjBC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAY,CAAC;EACpCC,KAAK,EAAEtD,EAAE,CAAE,WAAW,EAAE,kCAAmC,CAAC;EAC5DuD,IAAI,EAAE1B;AACP,CAAC,EACD;EACCsB,IAAI,EAAE,QAAQ;EACdC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAS,CAAC;EACjCC,KAAK,EAAEtD,EAAE,CAAE,QAAQ,EAAE,kCAAmC,CAAC;EACzDuD,IAAI,EAAEzB;AACP,CAAC,EACD;EACCqB,IAAI,EAAE,QAAQ;EACdC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAS,CAAC;EACjCC,KAAK,EAAEtD,EAAE,CAAE,QAAQ,EAAE,kCAAmC,CAAC;EACzDuD,IAAI,EAAExB;AACP,CAAC,EACD;EACCoB,IAAI,EAAE,OAAO;EACbC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAQ,CAAC;EAChCC,KAAK,EAAEtD,EAAE,CAAE,OAAO,EAAE,kCAAmC,CAAC;EACxDuD,IAAI,EAAEvB,SAAS;EACf;EACAyB,KAAK,EAAE;AACR,CAAC,EACD;EACCN,IAAI,EAAE,UAAU;EAChBC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAW,CAAC;EACnCC,KAAK,EAAEtD,EAAE,CAAE,UAAU,EAAE,kCAAmC,CAAC;EAC3DuD,IAAI,EAAEtB;AACP,CAAC,EACD;EACCkB,IAAI,EAAE,YAAY;EAClBC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAa,CAAC;EACrCC,KAAK,EAAEtD,EAAE,CAAE,YAAY,EAAE,kCAAmC,CAAC;EAC7DuD,IAAI,EAAErB;AACP,CAAC,EACD;EACCiB,IAAI,EAAE,SAAS;EACfC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAU,CAAC;EAClCC,KAAK,EAAEtD,EAAE,CAAE,SAAS,EAAE,kCAAmC,CAAC;EAC1DuD,IAAI,EAAEpB;AACP,CAAC,EACD;EACCgB,IAAI,EAAE,UAAU;EAChBC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAW,CAAC;EACnCC,KAAK,EAAEtD,EAAE,CAAE,UAAU,EAAE,kCAAmC,CAAC;EAC3DuD,IAAI,EAAEnB;AACP,CAAC,EACD;EACCe,IAAI,EAAE,SAAS;EACfC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAU,CAAC;EAClCC,KAAK,EAAEtD,EAAE,CAAE,SAAS,EAAE,kCAAmC,CAAC;EAC1DuD,IAAI,EAAElB;AACP,CAAC,EACD;EACCc,IAAI,EAAE,QAAQ;EACdC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAS,CAAC;EACjCC,KAAK,EAAEtD,EAAE,CAAE,QAAQ,EAAE,kCAAmC,CAAC;EACzDuD,IAAI,EAAEjB;AACP,CAAC,EACD;EACCa,IAAI,EAAE,QAAQ;EACdC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAS,CAAC;EACjCC,KAAK,EAAEtD,EAAE,CAAE,QAAQ,EAAE,kCAAmC,CAAC;EACzDuD,IAAI,EAAEhB;AACP,CAAC,EACD;EACCY,IAAI,EAAE,QAAQ;EACdC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAS,CAAC;EACjCC,KAAK,EAAEtD,EAAE,CAAE,QAAQ,EAAE,kCAAmC,CAAC;EACzDuD,IAAI,EAAEf;AACP,CAAC,EACD;EACCW,IAAI,EAAE,SAAS;EACfC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAU,CAAC;EAClCC,KAAK,EAAEtD,EAAE,CAAE,SAAS,EAAE,kCAAmC,CAAC;EAC1DuD,IAAI,EAAEd;AACP,CAAC,EACD;EACCU,IAAI,EAAE,OAAO;EACbC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAQ,CAAC;EAChCC,KAAK,EAAEtD,EAAE,CAAE,OAAO,EAAE,kCAAmC,CAAC;EACxDuD,IAAI,EAAEb;AACP,CAAC,EACD;EACCS,IAAI,EAAE,IAAI;EACVC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAK,CAAC;EAC7BC,KAAK,EAAEtD,EAAE,CAAE,IAAI,EAAE,kCAAmC,CAAC;EACrDuD,IAAI,EAAEZ;AACP,CAAC,EACD;EACCQ,IAAI,EAAE,UAAU;EAChBC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAW,CAAC;EACnCC,KAAK,EAAEtD,EAAE,CAAE,UAAU,EAAE,kCAAmC,CAAC;EAC3DuD,IAAI,EAAEX;AACP,CAAC,EACD;EACCO,IAAI,EAAE,GAAG;EACTC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAI,CAAC;EAC5BG,QAAQ,EAAE,CAAE,SAAS,CAAE;EACvBF,KAAK,EAAEtD,EAAE,CAAE,GAAG,EAAE,kCAAmC,CAAC;EACpDuD,IAAI,EAAET;AACP,CAAC,EACD;EACCK,IAAI,EAAE,MAAM;EACZC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAO,CAAC;EAC/BC,KAAK,EAAEtD,EAAE,CAAE,MAAM,EAAE,kCAAmC,CAAC;EACvDuD,IAAI,EAAER;AACP,CAAC,EACD;EACCI,IAAI,EAAE,SAAS;EACfC,UAAU,EAAE;IAAEC,OAAO,EAAE;EAAU,CAAC;EAClCC,KAAK,EAAEtD,EAAE,CAAE,SAAS,EAAE,kCAAmC,CAAC;EAC1DuD,IAAI,EAAEP;AACP,CAAC,CACD;;AAED;AACA;AACA;AACA;AACA;AACAC,UAAU,CAACS,OAAO,CAAIC,SAAS,IAAM;EACpC,IAAKA,SAAS,CAACC,QAAQ,EAAG;IACzB;EACD;EACAD,SAAS,CAACC,QAAQ,GAAG,CAAEC,eAAe,EAAEC,mBAAmB,KAC1DD,eAAe,CAACR,OAAO,KAAKS,mBAAmB,CAACT,OAAO;AACzD,CAAE,CAAC;AAEH,eAAeJ,UAAU","ignoreList":[]}
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* External dependencies
|
|
3
|
+
*/
|
|
4
|
+
import clsx from 'clsx';
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* WordPress dependencies
|
|
8
|
+
*/
|
|
9
|
+
import { MediaUpload, MediaUploadCheck } from '@wordpress/block-editor';
|
|
10
|
+
import { Button, BaseControl, __experimentalHStack as HStack, __experimentalToolsPanelItem as ToolsPanelItem } from '@wordpress/components';
|
|
11
|
+
import { __, sprintf } from '@wordpress/i18n';
|
|
12
|
+
import { useRef } from '@wordpress/element';
|
|
13
|
+
import { useInstanceId } from '@wordpress/compose';
|
|
14
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
15
|
+
const POSTER_IMAGE_ALLOWED_MEDIA_TYPES = ['image'];
|
|
16
|
+
function PosterImage({
|
|
17
|
+
poster,
|
|
18
|
+
onChange
|
|
19
|
+
}) {
|
|
20
|
+
const posterButtonRef = useRef();
|
|
21
|
+
const descriptionId = useInstanceId(PosterImage, 'block-library-poster-image-description');
|
|
22
|
+
return /*#__PURE__*/_jsx(MediaUploadCheck, {
|
|
23
|
+
children: /*#__PURE__*/_jsxs(ToolsPanelItem, {
|
|
24
|
+
label: __('Poster image'),
|
|
25
|
+
isShownByDefault: true,
|
|
26
|
+
hasValue: () => !!poster,
|
|
27
|
+
onDeselect: () => onChange(undefined),
|
|
28
|
+
children: [/*#__PURE__*/_jsx(BaseControl.VisualLabel, {
|
|
29
|
+
children: __('Poster image')
|
|
30
|
+
}), /*#__PURE__*/_jsx(MediaUpload, {
|
|
31
|
+
title: __('Select poster image'),
|
|
32
|
+
onSelect: onChange,
|
|
33
|
+
allowedTypes: POSTER_IMAGE_ALLOWED_MEDIA_TYPES,
|
|
34
|
+
render: ({
|
|
35
|
+
open
|
|
36
|
+
}) => /*#__PURE__*/_jsxs("div", {
|
|
37
|
+
className: "block-library-poster-image__container",
|
|
38
|
+
children: [poster && /*#__PURE__*/_jsx(Button, {
|
|
39
|
+
__next40pxDefaultSize: true,
|
|
40
|
+
onClick: open,
|
|
41
|
+
"aria-haspopup": "dialog",
|
|
42
|
+
"aria-label": !poster ? null : __('Edit or replace the poster image.'),
|
|
43
|
+
className: poster ? 'block-library-poster-image__preview' : 'block-library-poster-image__toggle',
|
|
44
|
+
children: /*#__PURE__*/_jsx("img", {
|
|
45
|
+
src: poster,
|
|
46
|
+
alt: __('Poster image preview'),
|
|
47
|
+
className: "block-library-poster-image__preview-image"
|
|
48
|
+
})
|
|
49
|
+
}), /*#__PURE__*/_jsxs(HStack, {
|
|
50
|
+
className: clsx('block-library-poster-image__actions', {
|
|
51
|
+
'block-library-poster-image__actions-select': !poster
|
|
52
|
+
}),
|
|
53
|
+
children: [/*#__PURE__*/_jsx(Button, {
|
|
54
|
+
__next40pxDefaultSize: true,
|
|
55
|
+
onClick: open,
|
|
56
|
+
ref: posterButtonRef,
|
|
57
|
+
className: "block-library-poster-image__action",
|
|
58
|
+
"aria-describedby": descriptionId,
|
|
59
|
+
"aria-haspopup": "dialog",
|
|
60
|
+
variant: !poster ? 'secondary' : undefined,
|
|
61
|
+
children: !poster ? __('Set poster image') : __('Replace')
|
|
62
|
+
}), /*#__PURE__*/_jsx("p", {
|
|
63
|
+
id: descriptionId,
|
|
64
|
+
hidden: true,
|
|
65
|
+
children: poster ? sprintf(/* translators: %s: poster image URL. */
|
|
66
|
+
__('The current poster image url is %s.'), poster) : __('There is no poster image currently selected.')
|
|
67
|
+
}), !!poster && /*#__PURE__*/_jsx(Button, {
|
|
68
|
+
__next40pxDefaultSize: true,
|
|
69
|
+
onClick: () => {
|
|
70
|
+
onChange(undefined);
|
|
71
|
+
|
|
72
|
+
// Move focus back to the Media Upload button.
|
|
73
|
+
posterButtonRef.current.focus();
|
|
74
|
+
},
|
|
75
|
+
className: "block-library-poster-image__action",
|
|
76
|
+
children: __('Remove')
|
|
77
|
+
})]
|
|
78
|
+
})]
|
|
79
|
+
})
|
|
80
|
+
})]
|
|
81
|
+
})
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
export default PosterImage;
|
|
85
|
+
//# sourceMappingURL=poster-image.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["clsx","MediaUpload","MediaUploadCheck","Button","BaseControl","__experimentalHStack","HStack","__experimentalToolsPanelItem","ToolsPanelItem","__","sprintf","useRef","useInstanceId","jsx","_jsx","jsxs","_jsxs","POSTER_IMAGE_ALLOWED_MEDIA_TYPES","PosterImage","poster","onChange","posterButtonRef","descriptionId","children","label","isShownByDefault","hasValue","onDeselect","undefined","VisualLabel","title","onSelect","allowedTypes","render","open","className","__next40pxDefaultSize","onClick","src","alt","ref","variant","id","hidden","current","focus"],"sources":["@wordpress/block-library/src/utils/poster-image.js"],"sourcesContent":["/**\n * External dependencies\n */\nimport clsx from 'clsx';\n\n/**\n * WordPress dependencies\n */\nimport { MediaUpload, MediaUploadCheck } from '@wordpress/block-editor';\nimport {\n\tButton,\n\tBaseControl,\n\t__experimentalHStack as HStack,\n\t__experimentalToolsPanelItem as ToolsPanelItem,\n} from '@wordpress/components';\nimport { __, sprintf } from '@wordpress/i18n';\nimport { useRef } from '@wordpress/element';\nimport { useInstanceId } from '@wordpress/compose';\n\nconst POSTER_IMAGE_ALLOWED_MEDIA_TYPES = [ 'image' ];\n\nfunction PosterImage( { poster, onChange } ) {\n\tconst posterButtonRef = useRef();\n\tconst descriptionId = useInstanceId(\n\t\tPosterImage,\n\t\t'block-library-poster-image-description'\n\t);\n\n\treturn (\n\t\t<MediaUploadCheck>\n\t\t\t<ToolsPanelItem\n\t\t\t\tlabel={ __( 'Poster image' ) }\n\t\t\t\tisShownByDefault\n\t\t\t\thasValue={ () => !! poster }\n\t\t\t\tonDeselect={ () => onChange( undefined ) }\n\t\t\t>\n\t\t\t\t<BaseControl.VisualLabel>\n\t\t\t\t\t{ __( 'Poster image' ) }\n\t\t\t\t</BaseControl.VisualLabel>\n\t\t\t\t<MediaUpload\n\t\t\t\t\ttitle={ __( 'Select poster image' ) }\n\t\t\t\t\tonSelect={ onChange }\n\t\t\t\t\tallowedTypes={ POSTER_IMAGE_ALLOWED_MEDIA_TYPES }\n\t\t\t\t\trender={ ( { open } ) => (\n\t\t\t\t\t\t<div className=\"block-library-poster-image__container\">\n\t\t\t\t\t\t\t{ poster && (\n\t\t\t\t\t\t\t\t<Button\n\t\t\t\t\t\t\t\t\t__next40pxDefaultSize\n\t\t\t\t\t\t\t\t\tonClick={ open }\n\t\t\t\t\t\t\t\t\taria-haspopup=\"dialog\"\n\t\t\t\t\t\t\t\t\taria-label={\n\t\t\t\t\t\t\t\t\t\t! poster\n\t\t\t\t\t\t\t\t\t\t\t? null\n\t\t\t\t\t\t\t\t\t\t\t: __(\n\t\t\t\t\t\t\t\t\t\t\t\t\t'Edit or replace the poster image.'\n\t\t\t\t\t\t\t\t\t\t\t )\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tclassName={\n\t\t\t\t\t\t\t\t\t\tposter\n\t\t\t\t\t\t\t\t\t\t\t? 'block-library-poster-image__preview'\n\t\t\t\t\t\t\t\t\t\t\t: 'block-library-poster-image__toggle'\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t<img\n\t\t\t\t\t\t\t\t\t\tsrc={ poster }\n\t\t\t\t\t\t\t\t\t\talt={ __( 'Poster image preview' ) }\n\t\t\t\t\t\t\t\t\t\tclassName=\"block-library-poster-image__preview-image\"\n\t\t\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t\t\t</Button>\n\t\t\t\t\t\t\t) }\n\t\t\t\t\t\t\t<HStack\n\t\t\t\t\t\t\t\tclassName={ clsx(\n\t\t\t\t\t\t\t\t\t'block-library-poster-image__actions',\n\t\t\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\t\t\t'block-library-poster-image__actions-select':\n\t\t\t\t\t\t\t\t\t\t\t! poster,\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t) }\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t<Button\n\t\t\t\t\t\t\t\t\t__next40pxDefaultSize\n\t\t\t\t\t\t\t\t\tonClick={ open }\n\t\t\t\t\t\t\t\t\tref={ posterButtonRef }\n\t\t\t\t\t\t\t\t\tclassName=\"block-library-poster-image__action\"\n\t\t\t\t\t\t\t\t\taria-describedby={ descriptionId }\n\t\t\t\t\t\t\t\t\taria-haspopup=\"dialog\"\n\t\t\t\t\t\t\t\t\tvariant={\n\t\t\t\t\t\t\t\t\t\t! poster ? 'secondary' : undefined\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t{ ! poster\n\t\t\t\t\t\t\t\t\t\t? __( 'Set poster image' )\n\t\t\t\t\t\t\t\t\t\t: __( 'Replace' ) }\n\t\t\t\t\t\t\t\t</Button>\n\t\t\t\t\t\t\t\t<p id={ descriptionId } hidden>\n\t\t\t\t\t\t\t\t\t{ poster\n\t\t\t\t\t\t\t\t\t\t? sprintf(\n\t\t\t\t\t\t\t\t\t\t\t\t/* translators: %s: poster image URL. */\n\t\t\t\t\t\t\t\t\t\t\t\t__(\n\t\t\t\t\t\t\t\t\t\t\t\t\t'The current poster image url is %s.'\n\t\t\t\t\t\t\t\t\t\t\t\t),\n\t\t\t\t\t\t\t\t\t\t\t\tposter\n\t\t\t\t\t\t\t\t\t\t )\n\t\t\t\t\t\t\t\t\t\t: __(\n\t\t\t\t\t\t\t\t\t\t\t\t'There is no poster image currently selected.'\n\t\t\t\t\t\t\t\t\t\t ) }\n\t\t\t\t\t\t\t\t</p>\n\t\t\t\t\t\t\t\t{ !! poster && (\n\t\t\t\t\t\t\t\t\t<Button\n\t\t\t\t\t\t\t\t\t\t__next40pxDefaultSize\n\t\t\t\t\t\t\t\t\t\tonClick={ () => {\n\t\t\t\t\t\t\t\t\t\t\tonChange( undefined );\n\n\t\t\t\t\t\t\t\t\t\t\t// Move focus back to the Media Upload button.\n\t\t\t\t\t\t\t\t\t\t\tposterButtonRef.current.focus();\n\t\t\t\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t\t\t\t\tclassName=\"block-library-poster-image__action\"\n\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t{ __( 'Remove' ) }\n\t\t\t\t\t\t\t\t\t</Button>\n\t\t\t\t\t\t\t\t) }\n\t\t\t\t\t\t\t</HStack>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t) }\n\t\t\t\t/>\n\t\t\t</ToolsPanelItem>\n\t\t</MediaUploadCheck>\n\t);\n}\n\nexport default PosterImage;\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -11,7 +11,6 @@ import { Disabled, Spinner, Placeholder, __experimentalToolsPanel as ToolsPanel
|
|
|
11
11
|
import { BlockControls, BlockIcon, InspectorControls, MediaPlaceholder, MediaReplaceFlow, useBlockProps } from '@wordpress/block-editor';
|
|
12
12
|
import { useRef, useEffect, useState } from '@wordpress/element';
|
|
13
13
|
import { __ } from '@wordpress/i18n';
|
|
14
|
-
import { useInstanceId } from '@wordpress/compose';
|
|
15
14
|
import { useDispatch } from '@wordpress/data';
|
|
16
15
|
import { video as icon } from '@wordpress/icons';
|
|
17
16
|
import { store as noticesStore } from '@wordpress/notices';
|
|
@@ -19,13 +18,13 @@ import { store as noticesStore } from '@wordpress/notices';
|
|
|
19
18
|
/**
|
|
20
19
|
* Internal dependencies
|
|
21
20
|
*/
|
|
22
|
-
import PosterImage from './poster-image';
|
|
23
21
|
import { createUpgradedEmbedBlock } from '../embed/util';
|
|
24
22
|
import { useUploadMediaFromBlobURL, useToolsPanelDropdownMenuProps } from '../utils/hooks';
|
|
25
23
|
import VideoCommonSettings from './edit-common-settings';
|
|
26
24
|
import TracksEditor from './tracks-editor';
|
|
27
25
|
import Tracks from './tracks';
|
|
28
26
|
import { Caption } from '../utils/caption';
|
|
27
|
+
import PosterImage from '../utils/poster-image';
|
|
29
28
|
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
30
29
|
const ALLOWED_MEDIA_TYPES = ['video'];
|
|
31
30
|
function VideoEdit({
|
|
@@ -36,7 +35,6 @@ function VideoEdit({
|
|
|
36
35
|
insertBlocksAfter,
|
|
37
36
|
onReplace
|
|
38
37
|
}) {
|
|
39
|
-
const instanceId = useInstanceId(VideoEdit);
|
|
40
38
|
const videoPlayer = useRef();
|
|
41
39
|
const {
|
|
42
40
|
id,
|
|
@@ -59,6 +57,8 @@ function VideoEdit({
|
|
|
59
57
|
videoPlayer.current.load();
|
|
60
58
|
}
|
|
61
59
|
}, [poster]);
|
|
60
|
+
|
|
61
|
+
// TODO: Whether the video was obtained from the media library or was provided by URL, obtain the `videoWidth` and `videoHeight` of the video once its metadata has loaded and persist in the block attributes.
|
|
62
62
|
function onSelectVideo(media) {
|
|
63
63
|
if (!media || !media.url) {
|
|
64
64
|
// In this case there was an error
|
|
@@ -189,7 +189,7 @@ function VideoEdit({
|
|
|
189
189
|
muted: false,
|
|
190
190
|
playsInline: false,
|
|
191
191
|
preload: 'metadata',
|
|
192
|
-
poster:
|
|
192
|
+
poster: undefined
|
|
193
193
|
});
|
|
194
194
|
},
|
|
195
195
|
dropdownMenuProps: dropdownMenuProps,
|
|
@@ -198,8 +198,9 @@ function VideoEdit({
|
|
|
198
198
|
attributes: attributes
|
|
199
199
|
}), /*#__PURE__*/_jsx(PosterImage, {
|
|
200
200
|
poster: poster,
|
|
201
|
-
|
|
202
|
-
|
|
201
|
+
onChange: posterImage => setAttributes({
|
|
202
|
+
poster: posterImage?.url
|
|
203
|
+
})
|
|
203
204
|
})]
|
|
204
205
|
})
|
|
205
206
|
}), /*#__PURE__*/_jsxs("figure", {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["clsx","isBlobURL","Disabled","Spinner","Placeholder","__experimentalToolsPanel","ToolsPanel","BlockControls","BlockIcon","InspectorControls","MediaPlaceholder","MediaReplaceFlow","useBlockProps","useRef","useEffect","useState","__","useInstanceId","useDispatch","video","icon","store","noticesStore","PosterImage","createUpgradedEmbedBlock","useUploadMediaFromBlobURL","useToolsPanelDropdownMenuProps","VideoCommonSettings","TracksEditor","Tracks","Caption","jsx","_jsx","Fragment","_Fragment","jsxs","_jsxs","ALLOWED_MEDIA_TYPES","VideoEdit","isSelected","isSingleSelected","attributes","className","setAttributes","insertBlocksAfter","onReplace","instanceId","videoPlayer","id","controls","poster","src","tracks","temporaryURL","setTemporaryURL","blob","dropdownMenuProps","url","allowedTypes","onChange","onSelectVideo","onError","onUploadError","current","load","media","undefined","caption","image","onSelectURL","newSrc","embedBlock","createErrorNotice","message","type","placeholder","content","withIllustration","label","instructions","children","classes","blockProps","onSelect","accept","value","newTracks","group","mediaId","mediaURL","onReset","resetAll","autoplay","loop","muted","playsInline","preload","isDisabled","ref","showToolbarButton"],"sources":["@wordpress/block-library/src/video/edit.js"],"sourcesContent":["/**\n * External dependencies\n */\nimport clsx from 'clsx';\n\n/**\n * WordPress dependencies\n */\nimport { isBlobURL } from '@wordpress/blob';\nimport {\n\tDisabled,\n\tSpinner,\n\tPlaceholder,\n\t__experimentalToolsPanel as ToolsPanel,\n} from '@wordpress/components';\nimport {\n\tBlockControls,\n\tBlockIcon,\n\tInspectorControls,\n\tMediaPlaceholder,\n\tMediaReplaceFlow,\n\tuseBlockProps,\n} from '@wordpress/block-editor';\nimport { useRef, useEffect, useState } from '@wordpress/element';\nimport { __ } from '@wordpress/i18n';\nimport { useInstanceId } from '@wordpress/compose';\nimport { useDispatch } from '@wordpress/data';\nimport { video as icon } from '@wordpress/icons';\nimport { store as noticesStore } from '@wordpress/notices';\n\n/**\n * Internal dependencies\n */\nimport PosterImage from './poster-image';\nimport { createUpgradedEmbedBlock } from '../embed/util';\nimport {\n\tuseUploadMediaFromBlobURL,\n\tuseToolsPanelDropdownMenuProps,\n} from '../utils/hooks';\nimport VideoCommonSettings from './edit-common-settings';\nimport TracksEditor from './tracks-editor';\nimport Tracks from './tracks';\nimport { Caption } from '../utils/caption';\n\nconst ALLOWED_MEDIA_TYPES = [ 'video' ];\n\nfunction VideoEdit( {\n\tisSelected: isSingleSelected,\n\tattributes,\n\tclassName,\n\tsetAttributes,\n\tinsertBlocksAfter,\n\tonReplace,\n} ) {\n\tconst instanceId = useInstanceId( VideoEdit );\n\tconst videoPlayer = useRef();\n\tconst { id, controls, poster, src, tracks } = attributes;\n\tconst [ temporaryURL, setTemporaryURL ] = useState( attributes.blob );\n\tconst dropdownMenuProps = useToolsPanelDropdownMenuProps();\n\n\tuseUploadMediaFromBlobURL( {\n\t\turl: temporaryURL,\n\t\tallowedTypes: ALLOWED_MEDIA_TYPES,\n\t\tonChange: onSelectVideo,\n\t\tonError: onUploadError,\n\t} );\n\n\tuseEffect( () => {\n\t\t// Placeholder may be rendered.\n\t\tif ( videoPlayer.current ) {\n\t\t\tvideoPlayer.current.load();\n\t\t}\n\t}, [ poster ] );\n\n\tfunction onSelectVideo( media ) {\n\t\tif ( ! media || ! media.url ) {\n\t\t\t// In this case there was an error\n\t\t\t// previous attributes should be removed\n\t\t\t// because they may be temporary blob urls.\n\t\t\tsetAttributes( {\n\t\t\t\tsrc: undefined,\n\t\t\t\tid: undefined,\n\t\t\t\tposter: undefined,\n\t\t\t\tcaption: undefined,\n\t\t\t\tblob: undefined,\n\t\t\t} );\n\t\t\tsetTemporaryURL();\n\t\t\treturn;\n\t\t}\n\n\t\tif ( isBlobURL( media.url ) ) {\n\t\t\tsetTemporaryURL( media.url );\n\t\t\treturn;\n\t\t}\n\n\t\t// Sets the block's attribute and updates the edit component from the\n\t\t// selected media.\n\t\tsetAttributes( {\n\t\t\tblob: undefined,\n\t\t\tsrc: media.url,\n\t\t\tid: media.id,\n\t\t\tposter:\n\t\t\t\tmedia.image?.src !== media.icon ? media.image?.src : undefined,\n\t\t\tcaption: media.caption,\n\t\t} );\n\t\tsetTemporaryURL();\n\t}\n\n\tfunction onSelectURL( newSrc ) {\n\t\tif ( newSrc !== src ) {\n\t\t\t// Check if there's an embed block that handles this URL.\n\t\t\tconst embedBlock = createUpgradedEmbedBlock( {\n\t\t\t\tattributes: { url: newSrc },\n\t\t\t} );\n\t\t\tif ( undefined !== embedBlock && onReplace ) {\n\t\t\t\tonReplace( embedBlock );\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tsetAttributes( {\n\t\t\t\tblob: undefined,\n\t\t\t\tsrc: newSrc,\n\t\t\t\tid: undefined,\n\t\t\t\tposter: undefined,\n\t\t\t} );\n\t\t\tsetTemporaryURL();\n\t\t}\n\t}\n\n\tconst { createErrorNotice } = useDispatch( noticesStore );\n\tfunction onUploadError( message ) {\n\t\tcreateErrorNotice( message, { type: 'snackbar' } );\n\t}\n\n\t// Much of this description is duplicated from MediaPlaceholder.\n\tconst placeholder = ( content ) => {\n\t\treturn (\n\t\t\t<Placeholder\n\t\t\t\tclassName=\"block-editor-media-placeholder\"\n\t\t\t\twithIllustration={ ! isSingleSelected }\n\t\t\t\ticon={ icon }\n\t\t\t\tlabel={ __( 'Video' ) }\n\t\t\t\tinstructions={ __(\n\t\t\t\t\t'Drag and drop a video, upload, or choose from your library.'\n\t\t\t\t) }\n\t\t\t>\n\t\t\t\t{ content }\n\t\t\t</Placeholder>\n\t\t);\n\t};\n\n\tconst classes = clsx( className, {\n\t\t'is-transient': !! temporaryURL,\n\t} );\n\n\tconst blockProps = useBlockProps( {\n\t\tclassName: classes,\n\t} );\n\n\tif ( ! src && ! temporaryURL ) {\n\t\treturn (\n\t\t\t<div { ...blockProps }>\n\t\t\t\t<MediaPlaceholder\n\t\t\t\t\ticon={ <BlockIcon icon={ icon } /> }\n\t\t\t\t\tonSelect={ onSelectVideo }\n\t\t\t\t\tonSelectURL={ onSelectURL }\n\t\t\t\t\taccept=\"video/*\"\n\t\t\t\t\tallowedTypes={ ALLOWED_MEDIA_TYPES }\n\t\t\t\t\tvalue={ attributes }\n\t\t\t\t\tonError={ onUploadError }\n\t\t\t\t\tplaceholder={ placeholder }\n\t\t\t\t/>\n\t\t\t</div>\n\t\t);\n\t}\n\n\treturn (\n\t\t<>\n\t\t\t{ isSingleSelected && (\n\t\t\t\t<>\n\t\t\t\t\t<BlockControls>\n\t\t\t\t\t\t<TracksEditor\n\t\t\t\t\t\t\ttracks={ tracks }\n\t\t\t\t\t\t\tonChange={ ( newTracks ) => {\n\t\t\t\t\t\t\t\tsetAttributes( { tracks: newTracks } );\n\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t/>\n\t\t\t\t\t</BlockControls>\n\t\t\t\t\t<BlockControls group=\"other\">\n\t\t\t\t\t\t<MediaReplaceFlow\n\t\t\t\t\t\t\tmediaId={ id }\n\t\t\t\t\t\t\tmediaURL={ src }\n\t\t\t\t\t\t\tallowedTypes={ ALLOWED_MEDIA_TYPES }\n\t\t\t\t\t\t\taccept=\"video/*\"\n\t\t\t\t\t\t\tonSelect={ onSelectVideo }\n\t\t\t\t\t\t\tonSelectURL={ onSelectURL }\n\t\t\t\t\t\t\tonError={ onUploadError }\n\t\t\t\t\t\t\tonReset={ () => onSelectVideo( undefined ) }\n\t\t\t\t\t\t/>\n\t\t\t\t\t</BlockControls>\n\t\t\t\t</>\n\t\t\t) }\n\t\t\t<InspectorControls>\n\t\t\t\t<ToolsPanel\n\t\t\t\t\tlabel={ __( 'Settings' ) }\n\t\t\t\t\tresetAll={ () => {\n\t\t\t\t\t\tsetAttributes( {\n\t\t\t\t\t\t\tautoplay: false,\n\t\t\t\t\t\t\tcontrols: true,\n\t\t\t\t\t\t\tloop: false,\n\t\t\t\t\t\t\tmuted: false,\n\t\t\t\t\t\t\tplaysInline: false,\n\t\t\t\t\t\t\tpreload: 'metadata',\n\t\t\t\t\t\t\tposter: '',\n\t\t\t\t\t\t} );\n\t\t\t\t\t} }\n\t\t\t\t\tdropdownMenuProps={ dropdownMenuProps }\n\t\t\t\t>\n\t\t\t\t\t<VideoCommonSettings\n\t\t\t\t\t\tsetAttributes={ setAttributes }\n\t\t\t\t\t\tattributes={ attributes }\n\t\t\t\t\t/>\n\t\t\t\t\t<PosterImage\n\t\t\t\t\t\tposter={ poster }\n\t\t\t\t\t\tsetAttributes={ setAttributes }\n\t\t\t\t\t\tinstanceId={ instanceId }\n\t\t\t\t\t/>\n\t\t\t\t</ToolsPanel>\n\t\t\t</InspectorControls>\n\t\t\t<figure { ...blockProps }>\n\t\t\t\t{ /*\n Disable the video tag if the block is not selected\n so the user clicking on it won't play the\n video when the controls are enabled.\n */ }\n\t\t\t\t<Disabled isDisabled={ ! isSingleSelected }>\n\t\t\t\t\t<video\n\t\t\t\t\t\tcontrols={ controls }\n\t\t\t\t\t\tposter={ poster }\n\t\t\t\t\t\tsrc={ src || temporaryURL }\n\t\t\t\t\t\tref={ videoPlayer }\n\t\t\t\t\t>\n\t\t\t\t\t\t<Tracks tracks={ tracks } />\n\t\t\t\t\t</video>\n\t\t\t\t</Disabled>\n\t\t\t\t{ !! temporaryURL && <Spinner /> }\n\t\t\t\t<Caption\n\t\t\t\t\tattributes={ attributes }\n\t\t\t\t\tsetAttributes={ setAttributes }\n\t\t\t\t\tisSelected={ isSingleSelected }\n\t\t\t\t\tinsertBlocksAfter={ insertBlocksAfter }\n\t\t\t\t\tlabel={ __( 'Video caption text' ) }\n\t\t\t\t\tshowToolbarButton={ isSingleSelected }\n\t\t\t\t/>\n\t\t\t</figure>\n\t\t</>\n\t);\n}\n\nexport default VideoEdit;\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":["clsx","isBlobURL","Disabled","Spinner","Placeholder","__experimentalToolsPanel","ToolsPanel","BlockControls","BlockIcon","InspectorControls","MediaPlaceholder","MediaReplaceFlow","useBlockProps","useRef","useEffect","useState","__","useDispatch","video","icon","store","noticesStore","createUpgradedEmbedBlock","useUploadMediaFromBlobURL","useToolsPanelDropdownMenuProps","VideoCommonSettings","TracksEditor","Tracks","Caption","PosterImage","jsx","_jsx","Fragment","_Fragment","jsxs","_jsxs","ALLOWED_MEDIA_TYPES","VideoEdit","isSelected","isSingleSelected","attributes","className","setAttributes","insertBlocksAfter","onReplace","videoPlayer","id","controls","poster","src","tracks","temporaryURL","setTemporaryURL","blob","dropdownMenuProps","url","allowedTypes","onChange","onSelectVideo","onError","onUploadError","current","load","media","undefined","caption","image","onSelectURL","newSrc","embedBlock","createErrorNotice","message","type","placeholder","content","withIllustration","label","instructions","children","classes","blockProps","onSelect","accept","value","newTracks","group","mediaId","mediaURL","onReset","resetAll","autoplay","loop","muted","playsInline","preload","posterImage","isDisabled","ref","showToolbarButton"],"sources":["@wordpress/block-library/src/video/edit.js"],"sourcesContent":["/**\n * External dependencies\n */\nimport clsx from 'clsx';\n\n/**\n * WordPress dependencies\n */\nimport { isBlobURL } from '@wordpress/blob';\nimport {\n\tDisabled,\n\tSpinner,\n\tPlaceholder,\n\t__experimentalToolsPanel as ToolsPanel,\n} from '@wordpress/components';\nimport {\n\tBlockControls,\n\tBlockIcon,\n\tInspectorControls,\n\tMediaPlaceholder,\n\tMediaReplaceFlow,\n\tuseBlockProps,\n} from '@wordpress/block-editor';\nimport { useRef, useEffect, useState } from '@wordpress/element';\nimport { __ } from '@wordpress/i18n';\nimport { useDispatch } from '@wordpress/data';\nimport { video as icon } from '@wordpress/icons';\nimport { store as noticesStore } from '@wordpress/notices';\n\n/**\n * Internal dependencies\n */\nimport { createUpgradedEmbedBlock } from '../embed/util';\nimport {\n\tuseUploadMediaFromBlobURL,\n\tuseToolsPanelDropdownMenuProps,\n} from '../utils/hooks';\nimport VideoCommonSettings from './edit-common-settings';\nimport TracksEditor from './tracks-editor';\nimport Tracks from './tracks';\nimport { Caption } from '../utils/caption';\nimport PosterImage from '../utils/poster-image';\n\nconst ALLOWED_MEDIA_TYPES = [ 'video' ];\n\nfunction VideoEdit( {\n\tisSelected: isSingleSelected,\n\tattributes,\n\tclassName,\n\tsetAttributes,\n\tinsertBlocksAfter,\n\tonReplace,\n} ) {\n\tconst videoPlayer = useRef();\n\tconst { id, controls, poster, src, tracks } = attributes;\n\tconst [ temporaryURL, setTemporaryURL ] = useState( attributes.blob );\n\tconst dropdownMenuProps = useToolsPanelDropdownMenuProps();\n\n\tuseUploadMediaFromBlobURL( {\n\t\turl: temporaryURL,\n\t\tallowedTypes: ALLOWED_MEDIA_TYPES,\n\t\tonChange: onSelectVideo,\n\t\tonError: onUploadError,\n\t} );\n\n\tuseEffect( () => {\n\t\t// Placeholder may be rendered.\n\t\tif ( videoPlayer.current ) {\n\t\t\tvideoPlayer.current.load();\n\t\t}\n\t}, [ poster ] );\n\n\t// TODO: Whether the video was obtained from the media library or was provided by URL, obtain the `videoWidth` and `videoHeight` of the video once its metadata has loaded and persist in the block attributes.\n\tfunction onSelectVideo( media ) {\n\t\tif ( ! media || ! media.url ) {\n\t\t\t// In this case there was an error\n\t\t\t// previous attributes should be removed\n\t\t\t// because they may be temporary blob urls.\n\t\t\tsetAttributes( {\n\t\t\t\tsrc: undefined,\n\t\t\t\tid: undefined,\n\t\t\t\tposter: undefined,\n\t\t\t\tcaption: undefined,\n\t\t\t\tblob: undefined,\n\t\t\t} );\n\t\t\tsetTemporaryURL();\n\t\t\treturn;\n\t\t}\n\n\t\tif ( isBlobURL( media.url ) ) {\n\t\t\tsetTemporaryURL( media.url );\n\t\t\treturn;\n\t\t}\n\n\t\t// Sets the block's attribute and updates the edit component from the\n\t\t// selected media.\n\t\tsetAttributes( {\n\t\t\tblob: undefined,\n\t\t\tsrc: media.url,\n\t\t\tid: media.id,\n\t\t\tposter:\n\t\t\t\tmedia.image?.src !== media.icon ? media.image?.src : undefined,\n\t\t\tcaption: media.caption,\n\t\t} );\n\t\tsetTemporaryURL();\n\t}\n\n\tfunction onSelectURL( newSrc ) {\n\t\tif ( newSrc !== src ) {\n\t\t\t// Check if there's an embed block that handles this URL.\n\t\t\tconst embedBlock = createUpgradedEmbedBlock( {\n\t\t\t\tattributes: { url: newSrc },\n\t\t\t} );\n\t\t\tif ( undefined !== embedBlock && onReplace ) {\n\t\t\t\tonReplace( embedBlock );\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tsetAttributes( {\n\t\t\t\tblob: undefined,\n\t\t\t\tsrc: newSrc,\n\t\t\t\tid: undefined,\n\t\t\t\tposter: undefined,\n\t\t\t} );\n\t\t\tsetTemporaryURL();\n\t\t}\n\t}\n\n\tconst { createErrorNotice } = useDispatch( noticesStore );\n\tfunction onUploadError( message ) {\n\t\tcreateErrorNotice( message, { type: 'snackbar' } );\n\t}\n\n\t// Much of this description is duplicated from MediaPlaceholder.\n\tconst placeholder = ( content ) => {\n\t\treturn (\n\t\t\t<Placeholder\n\t\t\t\tclassName=\"block-editor-media-placeholder\"\n\t\t\t\twithIllustration={ ! isSingleSelected }\n\t\t\t\ticon={ icon }\n\t\t\t\tlabel={ __( 'Video' ) }\n\t\t\t\tinstructions={ __(\n\t\t\t\t\t'Drag and drop a video, upload, or choose from your library.'\n\t\t\t\t) }\n\t\t\t>\n\t\t\t\t{ content }\n\t\t\t</Placeholder>\n\t\t);\n\t};\n\n\tconst classes = clsx( className, {\n\t\t'is-transient': !! temporaryURL,\n\t} );\n\n\tconst blockProps = useBlockProps( {\n\t\tclassName: classes,\n\t} );\n\n\tif ( ! src && ! temporaryURL ) {\n\t\treturn (\n\t\t\t<div { ...blockProps }>\n\t\t\t\t<MediaPlaceholder\n\t\t\t\t\ticon={ <BlockIcon icon={ icon } /> }\n\t\t\t\t\tonSelect={ onSelectVideo }\n\t\t\t\t\tonSelectURL={ onSelectURL }\n\t\t\t\t\taccept=\"video/*\"\n\t\t\t\t\tallowedTypes={ ALLOWED_MEDIA_TYPES }\n\t\t\t\t\tvalue={ attributes }\n\t\t\t\t\tonError={ onUploadError }\n\t\t\t\t\tplaceholder={ placeholder }\n\t\t\t\t/>\n\t\t\t</div>\n\t\t);\n\t}\n\n\treturn (\n\t\t<>\n\t\t\t{ isSingleSelected && (\n\t\t\t\t<>\n\t\t\t\t\t<BlockControls>\n\t\t\t\t\t\t<TracksEditor\n\t\t\t\t\t\t\ttracks={ tracks }\n\t\t\t\t\t\t\tonChange={ ( newTracks ) => {\n\t\t\t\t\t\t\t\tsetAttributes( { tracks: newTracks } );\n\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t/>\n\t\t\t\t\t</BlockControls>\n\t\t\t\t\t<BlockControls group=\"other\">\n\t\t\t\t\t\t<MediaReplaceFlow\n\t\t\t\t\t\t\tmediaId={ id }\n\t\t\t\t\t\t\tmediaURL={ src }\n\t\t\t\t\t\t\tallowedTypes={ ALLOWED_MEDIA_TYPES }\n\t\t\t\t\t\t\taccept=\"video/*\"\n\t\t\t\t\t\t\tonSelect={ onSelectVideo }\n\t\t\t\t\t\t\tonSelectURL={ onSelectURL }\n\t\t\t\t\t\t\tonError={ onUploadError }\n\t\t\t\t\t\t\tonReset={ () => onSelectVideo( undefined ) }\n\t\t\t\t\t\t/>\n\t\t\t\t\t</BlockControls>\n\t\t\t\t</>\n\t\t\t) }\n\t\t\t<InspectorControls>\n\t\t\t\t<ToolsPanel\n\t\t\t\t\tlabel={ __( 'Settings' ) }\n\t\t\t\t\tresetAll={ () => {\n\t\t\t\t\t\tsetAttributes( {\n\t\t\t\t\t\t\tautoplay: false,\n\t\t\t\t\t\t\tcontrols: true,\n\t\t\t\t\t\t\tloop: false,\n\t\t\t\t\t\t\tmuted: false,\n\t\t\t\t\t\t\tplaysInline: false,\n\t\t\t\t\t\t\tpreload: 'metadata',\n\t\t\t\t\t\t\tposter: undefined,\n\t\t\t\t\t\t} );\n\t\t\t\t\t} }\n\t\t\t\t\tdropdownMenuProps={ dropdownMenuProps }\n\t\t\t\t>\n\t\t\t\t\t<VideoCommonSettings\n\t\t\t\t\t\tsetAttributes={ setAttributes }\n\t\t\t\t\t\tattributes={ attributes }\n\t\t\t\t\t/>\n\t\t\t\t\t<PosterImage\n\t\t\t\t\t\tposter={ poster }\n\t\t\t\t\t\tonChange={ ( posterImage ) =>\n\t\t\t\t\t\t\tsetAttributes( {\n\t\t\t\t\t\t\t\tposter: posterImage?.url,\n\t\t\t\t\t\t\t} )\n\t\t\t\t\t\t}\n\t\t\t\t\t/>\n\t\t\t\t</ToolsPanel>\n\t\t\t</InspectorControls>\n\t\t\t<figure { ...blockProps }>\n\t\t\t\t{ /*\n Disable the video tag if the block is not selected\n so the user clicking on it won't play the\n video when the controls are enabled.\n */ }\n\t\t\t\t<Disabled isDisabled={ ! isSingleSelected }>\n\t\t\t\t\t<video\n\t\t\t\t\t\tcontrols={ controls }\n\t\t\t\t\t\tposter={ poster }\n\t\t\t\t\t\tsrc={ src || temporaryURL }\n\t\t\t\t\t\tref={ videoPlayer }\n\t\t\t\t\t>\n\t\t\t\t\t\t<Tracks tracks={ tracks } />\n\t\t\t\t\t</video>\n\t\t\t\t</Disabled>\n\t\t\t\t{ !! temporaryURL && <Spinner /> }\n\t\t\t\t<Caption\n\t\t\t\t\tattributes={ attributes }\n\t\t\t\t\tsetAttributes={ setAttributes }\n\t\t\t\t\tisSelected={ isSingleSelected }\n\t\t\t\t\tinsertBlocksAfter={ insertBlocksAfter }\n\t\t\t\t\tlabel={ __( 'Video caption text' ) }\n\t\t\t\t\tshowToolbarButton={ isSingleSelected }\n\t\t\t\t/>\n\t\t\t</figure>\n\t\t</>\n\t);\n}\n\nexport default VideoEdit;\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -4,9 +4,8 @@
|
|
|
4
4
|
import { __, _x, sprintf } from '@wordpress/i18n';
|
|
5
5
|
import { NavigableMenu, MenuItem, FormFileUpload, MenuGroup, ToolbarGroup, ToolbarButton, Dropdown, Button, TextControl, SelectControl, ToggleControl, __experimentalGrid as Grid, __experimentalHStack as HStack, __experimentalVStack as VStack, privateApis as componentsPrivateApis } from '@wordpress/components';
|
|
6
6
|
import { MediaUpload, MediaUploadCheck, store as blockEditorStore } from '@wordpress/block-editor';
|
|
7
|
-
import { store as noticesStore } from '@wordpress/notices';
|
|
8
7
|
import { upload, media } from '@wordpress/icons';
|
|
9
|
-
import { useSelect
|
|
8
|
+
import { useSelect } from '@wordpress/data';
|
|
10
9
|
import { useState, useRef, useEffect } from '@wordpress/element';
|
|
11
10
|
import { getFilename } from '@wordpress/url';
|
|
12
11
|
|
|
@@ -36,11 +35,19 @@ const KIND_OPTIONS = [{
|
|
|
36
35
|
label: __('Metadata'),
|
|
37
36
|
value: 'metadata'
|
|
38
37
|
}];
|
|
38
|
+
const DEFAULT_TRACK = {
|
|
39
|
+
src: '',
|
|
40
|
+
label: '',
|
|
41
|
+
srcLang: 'en',
|
|
42
|
+
kind: DEFAULT_KIND,
|
|
43
|
+
default: false
|
|
44
|
+
};
|
|
39
45
|
function TrackList({
|
|
40
46
|
tracks,
|
|
41
47
|
onEditPress
|
|
42
48
|
}) {
|
|
43
49
|
const content = tracks.map((track, index) => {
|
|
50
|
+
var _track$id;
|
|
44
51
|
return /*#__PURE__*/_jsxs(HStack, {
|
|
45
52
|
className: "block-library-video-tracks-editor__track-list-track",
|
|
46
53
|
children: [/*#__PURE__*/_jsx("span", {
|
|
@@ -58,7 +65,7 @@ function TrackList({
|
|
|
58
65
|
children: __('Edit')
|
|
59
66
|
})]
|
|
60
67
|
})]
|
|
61
|
-
}, track.src);
|
|
68
|
+
}, (_track$id = track.id) !== null && _track$id !== void 0 ? _track$id : track.src);
|
|
62
69
|
});
|
|
63
70
|
return /*#__PURE__*/_jsx(MenuGroup, {
|
|
64
71
|
label: __('Text tracks'),
|
|
@@ -73,13 +80,17 @@ function SingleTrackEditor({
|
|
|
73
80
|
onRemove,
|
|
74
81
|
allowSettingDefault
|
|
75
82
|
}) {
|
|
83
|
+
const [trackState, setTrackState] = useState({
|
|
84
|
+
...DEFAULT_TRACK,
|
|
85
|
+
...track
|
|
86
|
+
});
|
|
76
87
|
const {
|
|
77
|
-
src
|
|
78
|
-
label
|
|
79
|
-
srcLang
|
|
80
|
-
kind
|
|
81
|
-
default: isDefaultTrack
|
|
82
|
-
} =
|
|
88
|
+
src,
|
|
89
|
+
label,
|
|
90
|
+
srcLang,
|
|
91
|
+
kind,
|
|
92
|
+
default: isDefaultTrack
|
|
93
|
+
} = trackState;
|
|
83
94
|
const fileName = src.startsWith('blob:') ? '' : getFilename(src) || '';
|
|
84
95
|
return /*#__PURE__*/_jsxs(VStack, {
|
|
85
96
|
className: "block-library-video-tracks-editor__single-track-editor",
|
|
@@ -97,20 +108,20 @@ function SingleTrackEditor({
|
|
|
97
108
|
children: [/*#__PURE__*/_jsx(TextControl, {
|
|
98
109
|
__next40pxDefaultSize: true,
|
|
99
110
|
__nextHasNoMarginBottom: true,
|
|
100
|
-
onChange: newLabel =>
|
|
101
|
-
...
|
|
111
|
+
onChange: newLabel => setTrackState(prevTrackState => ({
|
|
112
|
+
...prevTrackState,
|
|
102
113
|
label: newLabel
|
|
103
|
-
}),
|
|
114
|
+
})),
|
|
104
115
|
label: __('Label'),
|
|
105
116
|
value: label,
|
|
106
117
|
help: __('Title of track')
|
|
107
118
|
}), /*#__PURE__*/_jsx(TextControl, {
|
|
108
119
|
__next40pxDefaultSize: true,
|
|
109
120
|
__nextHasNoMarginBottom: true,
|
|
110
|
-
onChange: newSrcLang =>
|
|
111
|
-
...
|
|
121
|
+
onChange: newSrcLang => setTrackState(prevTrackState => ({
|
|
122
|
+
...prevTrackState,
|
|
112
123
|
srcLang: newSrcLang
|
|
113
|
-
}),
|
|
124
|
+
})),
|
|
114
125
|
label: __('Source language'),
|
|
115
126
|
value: srcLang,
|
|
116
127
|
help: __('Language tag (en, fr, etc.)')
|
|
@@ -124,24 +135,20 @@ function SingleTrackEditor({
|
|
|
124
135
|
options: KIND_OPTIONS,
|
|
125
136
|
value: kind,
|
|
126
137
|
label: __('Kind'),
|
|
127
|
-
onChange: newKind => {
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
});
|
|
132
|
-
}
|
|
138
|
+
onChange: newKind => setTrackState(prevTrackState => ({
|
|
139
|
+
...prevTrackState,
|
|
140
|
+
kind: newKind
|
|
141
|
+
}))
|
|
133
142
|
}), /*#__PURE__*/_jsx(ToggleControl, {
|
|
134
143
|
__next40pxDefaultSize: true,
|
|
135
144
|
__nextHasNoMarginBottom: true,
|
|
136
145
|
label: __('Set as default track'),
|
|
137
146
|
checked: isDefaultTrack,
|
|
138
147
|
disabled: !allowSettingDefault,
|
|
139
|
-
onChange: defaultTrack => {
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
});
|
|
144
|
-
}
|
|
148
|
+
onChange: defaultTrack => setTrackState(prevTrackState => ({
|
|
149
|
+
...prevTrackState,
|
|
150
|
+
default: defaultTrack
|
|
151
|
+
}))
|
|
145
152
|
}), /*#__PURE__*/_jsxs(HStack, {
|
|
146
153
|
className: "block-library-video-tracks-editor__single-track-editor-buttons-container",
|
|
147
154
|
children: [/*#__PURE__*/_jsx(Button, {
|
|
@@ -154,26 +161,7 @@ function SingleTrackEditor({
|
|
|
154
161
|
__next40pxDefaultSize: true,
|
|
155
162
|
variant: "primary",
|
|
156
163
|
onClick: () => {
|
|
157
|
-
|
|
158
|
-
let hasChanges = false;
|
|
159
|
-
if (label === '') {
|
|
160
|
-
changes.label = __('English');
|
|
161
|
-
hasChanges = true;
|
|
162
|
-
}
|
|
163
|
-
if (srcLang === '') {
|
|
164
|
-
changes.srcLang = 'en';
|
|
165
|
-
hasChanges = true;
|
|
166
|
-
}
|
|
167
|
-
if (track.kind === undefined) {
|
|
168
|
-
changes.kind = DEFAULT_KIND;
|
|
169
|
-
hasChanges = true;
|
|
170
|
-
}
|
|
171
|
-
if (hasChanges) {
|
|
172
|
-
onChange({
|
|
173
|
-
...track,
|
|
174
|
-
...changes
|
|
175
|
-
});
|
|
176
|
-
}
|
|
164
|
+
onChange(trackState);
|
|
177
165
|
onClose();
|
|
178
166
|
},
|
|
179
167
|
children: __('Apply')
|
|
@@ -186,32 +174,53 @@ export default function TracksEditor({
|
|
|
186
174
|
tracks = [],
|
|
187
175
|
onChange
|
|
188
176
|
}) {
|
|
189
|
-
const {
|
|
190
|
-
createNotice
|
|
191
|
-
} = useDispatch(noticesStore);
|
|
192
177
|
const mediaUpload = useSelect(select => {
|
|
193
178
|
return select(blockEditorStore).getSettings().mediaUpload;
|
|
194
179
|
}, []);
|
|
195
180
|
const [trackBeingEdited, setTrackBeingEdited] = useState(null);
|
|
196
181
|
const dropdownPopoverRef = useRef();
|
|
197
|
-
const handleTrackSelect = ({
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
182
|
+
const handleTrackSelect = (selectedTracks = [], appendTracks = false) => {
|
|
183
|
+
const existingTracksMap = new Map(tracks.map(track => [track.id, track]));
|
|
184
|
+
const tracksToAdd = selectedTracks.map(({
|
|
185
|
+
id,
|
|
186
|
+
title,
|
|
187
|
+
url
|
|
188
|
+
}) => {
|
|
189
|
+
// Reuse existing tracks to preserve user-configured metadata.
|
|
190
|
+
if (existingTracksMap.has(id)) {
|
|
191
|
+
return existingTracksMap.get(id);
|
|
192
|
+
}
|
|
193
|
+
return {
|
|
194
|
+
...DEFAULT_TRACK,
|
|
195
|
+
id,
|
|
196
|
+
label: title || '',
|
|
197
|
+
src: url
|
|
198
|
+
};
|
|
199
|
+
});
|
|
200
|
+
if (tracksToAdd.length === 0) {
|
|
206
201
|
return;
|
|
207
202
|
}
|
|
208
|
-
|
|
209
|
-
onChange([...tracks, {
|
|
210
|
-
label: title || '',
|
|
211
|
-
src: url
|
|
212
|
-
}]);
|
|
213
|
-
setTrackBeingEdited(trackIndex);
|
|
203
|
+
onChange([...(appendTracks ? tracks : []), ...tracksToAdd]);
|
|
214
204
|
};
|
|
205
|
+
function uploadFiles(event) {
|
|
206
|
+
const files = event.target.files;
|
|
207
|
+
mediaUpload({
|
|
208
|
+
allowedTypes: ALLOWED_TYPES,
|
|
209
|
+
filesList: files,
|
|
210
|
+
onFileChange: selectedTracks => {
|
|
211
|
+
if (!Array.isArray(selectedTracks)) {
|
|
212
|
+
return;
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
// Wait until the track has been uploaded.
|
|
216
|
+
const uploadedTracks = selectedTracks.filter(track => !!track?.id);
|
|
217
|
+
if (!uploadedTracks.length) {
|
|
218
|
+
return;
|
|
219
|
+
}
|
|
220
|
+
handleTrackSelect(uploadedTracks, true);
|
|
221
|
+
}
|
|
222
|
+
});
|
|
223
|
+
}
|
|
215
224
|
useEffect(() => {
|
|
216
225
|
dropdownPopoverRef.current?.focus();
|
|
217
226
|
}, [trackBeingEdited]);
|
|
@@ -276,57 +285,39 @@ export default function TracksEditor({
|
|
|
276
285
|
children: [/*#__PURE__*/_jsx(TrackList, {
|
|
277
286
|
tracks: tracks,
|
|
278
287
|
onEditPress: setTrackBeingEdited
|
|
279
|
-
}), /*#__PURE__*/
|
|
288
|
+
}), /*#__PURE__*/_jsx(MenuGroup, {
|
|
280
289
|
className: "block-library-video-tracks-editor__add-tracks-container",
|
|
281
290
|
label: __('Add tracks'),
|
|
282
|
-
children:
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
filesList: files,
|
|
300
|
-
onFileChange: ([{
|
|
301
|
-
url
|
|
302
|
-
}]) => {
|
|
303
|
-
const newTracks = [...tracks];
|
|
304
|
-
if (!newTracks[trackIndex]) {
|
|
305
|
-
newTracks[trackIndex] = {};
|
|
306
|
-
}
|
|
307
|
-
newTracks[trackIndex] = {
|
|
308
|
-
...tracks[trackIndex],
|
|
309
|
-
src: url
|
|
310
|
-
};
|
|
311
|
-
onChange(newTracks);
|
|
312
|
-
setTrackBeingEdited(trackIndex);
|
|
313
|
-
}
|
|
314
|
-
});
|
|
315
|
-
},
|
|
291
|
+
children: /*#__PURE__*/_jsxs(MediaUploadCheck, {
|
|
292
|
+
children: [/*#__PURE__*/_jsx(MediaUpload, {
|
|
293
|
+
onSelect: handleTrackSelect,
|
|
294
|
+
allowedTypes: ALLOWED_TYPES,
|
|
295
|
+
value: tracks.map(({
|
|
296
|
+
id
|
|
297
|
+
}) => id),
|
|
298
|
+
multiple: true,
|
|
299
|
+
render: ({
|
|
300
|
+
open
|
|
301
|
+
}) => /*#__PURE__*/_jsx(MenuItem, {
|
|
302
|
+
icon: media,
|
|
303
|
+
onClick: open,
|
|
304
|
+
children: __('Open Media Library')
|
|
305
|
+
})
|
|
306
|
+
}), /*#__PURE__*/_jsx(FormFileUpload, {
|
|
307
|
+
onChange: uploadFiles,
|
|
316
308
|
accept: ".vtt,text/vtt",
|
|
309
|
+
multiple: true,
|
|
317
310
|
render: ({
|
|
318
311
|
openFileDialog
|
|
319
312
|
}) => {
|
|
320
313
|
return /*#__PURE__*/_jsx(MenuItem, {
|
|
321
314
|
icon: upload,
|
|
322
|
-
onClick:
|
|
323
|
-
openFileDialog();
|
|
324
|
-
},
|
|
315
|
+
onClick: openFileDialog,
|
|
325
316
|
children: _x('Upload', 'verb')
|
|
326
317
|
});
|
|
327
318
|
}
|
|
328
|
-
})
|
|
329
|
-
})
|
|
319
|
+
})]
|
|
320
|
+
})
|
|
330
321
|
})]
|
|
331
322
|
})]
|
|
332
323
|
});
|