@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.
Files changed (170) hide show
  1. package/CHANGELOG.md +2 -0
  2. package/build/categories/edit.js +15 -3
  3. package/build/categories/edit.js.map +1 -1
  4. package/build/cover/edit/block-controls.js +4 -2
  5. package/build/cover/edit/block-controls.js.map +1 -1
  6. package/build/cover/edit/index.js +6 -3
  7. package/build/cover/edit/index.js.map +1 -1
  8. package/build/cover/edit/inspector-controls.js +13 -4
  9. package/build/cover/edit/inspector-controls.js.map +1 -1
  10. package/build/cover/index.js +6 -0
  11. package/build/cover/index.js.map +1 -1
  12. package/build/cover/save.js +3 -1
  13. package/build/cover/save.js.map +1 -1
  14. package/build/file/edit.js +2 -1
  15. package/build/file/edit.js.map +1 -1
  16. package/build/latest-posts/edit.js +0 -2
  17. package/build/latest-posts/edit.js.map +1 -1
  18. package/build/media-text/edit.js +2 -2
  19. package/build/media-text/edit.js.map +1 -1
  20. package/build/navigation-link/edit.js +32 -15
  21. package/build/navigation-link/edit.js.map +1 -1
  22. package/build/navigation-link/update-attributes.js +112 -14
  23. package/build/navigation-link/update-attributes.js.map +1 -1
  24. package/build/navigation-submenu/edit.js +19 -2
  25. package/build/navigation-submenu/edit.js.map +1 -1
  26. package/build/paragraph/edit.js +2 -2
  27. package/build/paragraph/edit.js.map +1 -1
  28. package/build/post-content/edit.js +78 -16
  29. package/build/post-content/edit.js.map +1 -1
  30. package/build/post-content/index.js +6 -0
  31. package/build/post-content/index.js.map +1 -1
  32. package/build/post-date/deprecated.js +104 -1
  33. package/build/post-date/deprecated.js.map +1 -1
  34. package/build/post-date/edit.js +32 -32
  35. package/build/post-date/edit.js.map +1 -1
  36. package/build/post-date/index.js +4 -4
  37. package/build/post-date/index.js.map +1 -1
  38. package/build/post-date/variations.js +32 -3
  39. package/build/post-date/variations.js.map +1 -1
  40. package/build/separator/edit.js +5 -30
  41. package/build/separator/edit.js.map +1 -1
  42. package/build/site-tagline/index.js +1 -1
  43. package/build/social-link/variations.js +51 -49
  44. package/build/social-link/variations.js.map +1 -1
  45. package/build/utils/poster-image.js +93 -0
  46. package/build/utils/poster-image.js.map +1 -0
  47. package/build/video/edit.js +7 -6
  48. package/build/video/edit.js.map +1 -1
  49. package/build/video/tracks-editor.js +95 -104
  50. package/build/video/tracks-editor.js.map +1 -1
  51. package/build/video/tracks.js +6 -2
  52. package/build/video/tracks.js.map +1 -1
  53. package/build-module/categories/edit.js +15 -3
  54. package/build-module/categories/edit.js.map +1 -1
  55. package/build-module/cover/edit/block-controls.js +4 -2
  56. package/build-module/cover/edit/block-controls.js.map +1 -1
  57. package/build-module/cover/edit/index.js +6 -3
  58. package/build-module/cover/edit/index.js.map +1 -1
  59. package/build-module/cover/edit/inspector-controls.js +12 -4
  60. package/build-module/cover/edit/inspector-controls.js.map +1 -1
  61. package/build-module/cover/index.js +6 -0
  62. package/build-module/cover/index.js.map +1 -1
  63. package/build-module/cover/save.js +3 -1
  64. package/build-module/cover/save.js.map +1 -1
  65. package/build-module/file/edit.js +2 -1
  66. package/build-module/file/edit.js.map +1 -1
  67. package/build-module/latest-posts/edit.js +0 -2
  68. package/build-module/latest-posts/edit.js.map +1 -1
  69. package/build-module/media-text/edit.js +2 -2
  70. package/build-module/media-text/edit.js.map +1 -1
  71. package/build-module/navigation-link/edit.js +32 -15
  72. package/build-module/navigation-link/edit.js.map +1 -1
  73. package/build-module/navigation-link/update-attributes.js +113 -15
  74. package/build-module/navigation-link/update-attributes.js.map +1 -1
  75. package/build-module/navigation-submenu/edit.js +20 -3
  76. package/build-module/navigation-submenu/edit.js.map +1 -1
  77. package/build-module/paragraph/edit.js +2 -2
  78. package/build-module/paragraph/edit.js.map +1 -1
  79. package/build-module/post-content/edit.js +80 -18
  80. package/build-module/post-content/edit.js.map +1 -1
  81. package/build-module/post-content/index.js +6 -0
  82. package/build-module/post-content/index.js.map +1 -1
  83. package/build-module/post-date/deprecated.js +104 -1
  84. package/build-module/post-date/deprecated.js.map +1 -1
  85. package/build-module/post-date/edit.js +35 -35
  86. package/build-module/post-date/edit.js.map +1 -1
  87. package/build-module/post-date/index.js +4 -4
  88. package/build-module/post-date/index.js.map +1 -1
  89. package/build-module/post-date/variations.js +32 -3
  90. package/build-module/post-date/variations.js.map +1 -1
  91. package/build-module/separator/edit.js +6 -31
  92. package/build-module/separator/edit.js.map +1 -1
  93. package/build-module/site-tagline/index.js +1 -1
  94. package/build-module/social-link/variations.js +52 -50
  95. package/build-module/social-link/variations.js.map +1 -1
  96. package/build-module/utils/poster-image.js +85 -0
  97. package/build-module/utils/poster-image.js.map +1 -0
  98. package/build-module/video/edit.js +7 -6
  99. package/build-module/video/edit.js.map +1 -1
  100. package/build-module/video/tracks-editor.js +96 -105
  101. package/build-module/video/tracks-editor.js.map +1 -1
  102. package/build-module/video/tracks.js +6 -2
  103. package/build-module/video/tracks.js.map +1 -1
  104. package/build-style/archives/editor-rtl.css +0 -4
  105. package/build-style/archives/editor.css +0 -4
  106. package/build-style/editor-rtl.css +67 -18
  107. package/build-style/editor.css +67 -18
  108. package/build-style/file/style-rtl.css +1 -1
  109. package/build-style/file/style.css +1 -1
  110. package/build-style/navigation/editor-rtl.css +6 -6
  111. package/build-style/navigation/editor.css +6 -6
  112. package/build-style/navigation/style-rtl.css +1 -0
  113. package/build-style/navigation/style.css +1 -0
  114. package/build-style/page-list/editor-rtl.css +0 -4
  115. package/build-style/page-list/editor.css +0 -4
  116. package/build-style/style-rtl.css +3 -1
  117. package/build-style/style.css +3 -1
  118. package/build-style/video/editor-rtl.css +0 -4
  119. package/build-style/video/editor.css +0 -4
  120. package/build-style/video/style-rtl.css +1 -0
  121. package/build-style/video/style.css +1 -0
  122. package/package.json +35 -35
  123. package/src/archives/editor.scss +0 -4
  124. package/src/categories/edit.js +13 -1
  125. package/src/comments-pagination/index.php +7 -2
  126. package/src/cover/block.json +6 -0
  127. package/src/cover/edit/block-controls.js +22 -17
  128. package/src/cover/edit/index.js +4 -1
  129. package/src/cover/edit/inspector-controls.js +15 -2
  130. package/src/cover/save.js +2 -0
  131. package/src/editor.scss +1 -0
  132. package/src/file/edit.js +4 -1
  133. package/src/file/style.scss +1 -1
  134. package/src/latest-posts/edit.js +0 -2
  135. package/src/media-text/edit.js +1 -1
  136. package/src/navigation/style.scss +1 -0
  137. package/src/navigation-link/edit.js +28 -16
  138. package/src/navigation-link/test/edit.js +738 -6
  139. package/src/navigation-link/update-attributes.js +125 -12
  140. package/src/navigation-submenu/edit.js +21 -1
  141. package/src/page-list/editor.scss +0 -6
  142. package/src/paragraph/edit.js +2 -2
  143. package/src/post-content/block.json +6 -0
  144. package/src/post-content/edit.js +71 -19
  145. package/src/post-content/index.php +11 -4
  146. package/src/post-date/block.json +4 -4
  147. package/src/post-date/deprecated.js +104 -1
  148. package/src/post-date/edit.js +74 -86
  149. package/src/post-date/index.php +55 -28
  150. package/src/post-date/variations.js +37 -3
  151. package/src/post-featured-image/index.php +3 -2
  152. package/src/separator/edit.js +8 -43
  153. package/src/site-tagline/block.json +1 -1
  154. package/src/social-link/README.md +21 -0
  155. package/src/social-link/index.php +49 -49
  156. package/src/social-link/variations.js +51 -49
  157. package/src/utils/poster-image.js +131 -0
  158. package/src/utils/poster-image.scss +75 -0
  159. package/src/video/edit.js +8 -6
  160. package/src/video/editor.scss +0 -6
  161. package/src/video/index.php +91 -0
  162. package/src/video/style.native.scss +1 -0
  163. package/src/video/style.scss +1 -0
  164. package/src/video/tracks-editor.js +93 -103
  165. package/src/video/tracks.js +2 -1
  166. package/build/video/poster-image.js +0 -81
  167. package/build/video/poster-image.js.map +0 -1
  168. package/build-module/video/poster-image.js +0 -74
  169. package/build-module/video/poster-image.js.map +0 -1
  170. 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":"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","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
- setAttributes: setAttributes,
202
- instanceId: instanceId
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":"AAAA;AACA;AACA;AACA,OAAOA,IAAI,MAAM,MAAM;;AAEvB;AACA;AACA;AACA,SAASC,SAAS,QAAQ,iBAAiB;AAC3C,SACCC,QAAQ,EACRC,OAAO,EACPC,WAAW,EACXC,wBAAwB,IAAIC,UAAU,QAChC,uBAAuB;AAC9B,SACCC,aAAa,EACbC,SAAS,EACTC,iBAAiB,EACjBC,gBAAgB,EAChBC,gBAAgB,EAChBC,aAAa,QACP,yBAAyB;AAChC,SAASC,MAAM,EAAEC,SAAS,EAAEC,QAAQ,QAAQ,oBAAoB;AAChE,SAASC,EAAE,QAAQ,iBAAiB;AACpC,SAASC,aAAa,QAAQ,oBAAoB;AAClD,SAASC,WAAW,QAAQ,iBAAiB;AAC7C,SAASC,KAAK,IAAIC,IAAI,QAAQ,kBAAkB;AAChD,SAASC,KAAK,IAAIC,YAAY,QAAQ,oBAAoB;;AAE1D;AACA;AACA;AACA,OAAOC,WAAW,MAAM,gBAAgB;AACxC,SAASC,wBAAwB,QAAQ,eAAe;AACxD,SACCC,yBAAyB,EACzBC,8BAA8B,QACxB,gBAAgB;AACvB,OAAOC,mBAAmB,MAAM,wBAAwB;AACxD,OAAOC,YAAY,MAAM,iBAAiB;AAC1C,OAAOC,MAAM,MAAM,UAAU;AAC7B,SAASC,OAAO,QAAQ,kBAAkB;AAAC,SAAAC,GAAA,IAAAC,IAAA,EAAAC,QAAA,IAAAC,SAAA,EAAAC,IAAA,IAAAC,KAAA;AAE3C,MAAMC,mBAAmB,GAAG,CAAE,OAAO,CAAE;AAEvC,SAASC,SAASA,CAAE;EACnBC,UAAU,EAAEC,gBAAgB;EAC5BC,UAAU;EACVC,SAAS;EACTC,aAAa;EACbC,iBAAiB;EACjBC;AACD,CAAC,EAAG;EACH,MAAMC,UAAU,GAAG7B,aAAa,CAAEqB,SAAU,CAAC;EAC7C,MAAMS,WAAW,GAAGlC,MAAM,CAAC,CAAC;EAC5B,MAAM;IAAEmC,EAAE;IAAEC,QAAQ;IAAEC,MAAM;IAAEC,GAAG;IAAEC;EAAO,CAAC,GAAGX,UAAU;EACxD,MAAM,CAAEY,YAAY,EAAEC,eAAe,CAAE,GAAGvC,QAAQ,CAAE0B,UAAU,CAACc,IAAK,CAAC;EACrE,MAAMC,iBAAiB,GAAG9B,8BAA8B,CAAC,CAAC;EAE1DD,yBAAyB,CAAE;IAC1BgC,GAAG,EAAEJ,YAAY;IACjBK,YAAY,EAAErB,mBAAmB;IACjCsB,QAAQ,EAAEC,aAAa;IACvBC,OAAO,EAAEC;EACV,CAAE,CAAC;EAEHhD,SAAS,CAAE,MAAM;IAChB;IACA,IAAKiC,WAAW,CAACgB,OAAO,EAAG;MAC1BhB,WAAW,CAACgB,OAAO,CAACC,IAAI,CAAC,CAAC;IAC3B;EACD,CAAC,EAAE,CAAEd,MAAM,CAAG,CAAC;EAEf,SAASU,aAAaA,CAAEK,KAAK,EAAG;IAC/B,IAAK,CAAEA,KAAK,IAAI,CAAEA,KAAK,CAACR,GAAG,EAAG;MAC7B;MACA;MACA;MACAd,aAAa,CAAE;QACdQ,GAAG,EAAEe,SAAS;QACdlB,EAAE,EAAEkB,SAAS;QACbhB,MAAM,EAAEgB,SAAS;QACjBC,OAAO,EAAED,SAAS;QAClBX,IAAI,EAAEW;MACP,CAAE,CAAC;MACHZ,eAAe,CAAC,CAAC;MACjB;IACD;IAEA,IAAKrD,SAAS,CAAEgE,KAAK,CAACR,GAAI,CAAC,EAAG;MAC7BH,eAAe,CAAEW,KAAK,CAACR,GAAI,CAAC;MAC5B;IACD;;IAEA;IACA;IACAd,aAAa,CAAE;MACdY,IAAI,EAAEW,SAAS;MACff,GAAG,EAAEc,KAAK,CAACR,GAAG;MACdT,EAAE,EAAEiB,KAAK,CAACjB,EAAE;MACZE,MAAM,EACLe,KAAK,CAACG,KAAK,EAAEjB,GAAG,KAAKc,KAAK,CAAC7C,IAAI,GAAG6C,KAAK,CAACG,KAAK,EAAEjB,GAAG,GAAGe,SAAS;MAC/DC,OAAO,EAAEF,KAAK,CAACE;IAChB,CAAE,CAAC;IACHb,eAAe,CAAC,CAAC;EAClB;EAEA,SAASe,WAAWA,CAAEC,MAAM,EAAG;IAC9B,IAAKA,MAAM,KAAKnB,GAAG,EAAG;MACrB;MACA,MAAMoB,UAAU,GAAG/C,wBAAwB,CAAE;QAC5CiB,UAAU,EAAE;UAAEgB,GAAG,EAAEa;QAAO;MAC3B,CAAE,CAAC;MACH,IAAKJ,SAAS,KAAKK,UAAU,IAAI1B,SAAS,EAAG;QAC5CA,SAAS,CAAE0B,UAAW,CAAC;QACvB;MACD;MACA5B,aAAa,CAAE;QACdY,IAAI,EAAEW,SAAS;QACff,GAAG,EAAEmB,MAAM;QACXtB,EAAE,EAAEkB,SAAS;QACbhB,MAAM,EAAEgB;MACT,CAAE,CAAC;MACHZ,eAAe,CAAC,CAAC;IAClB;EACD;EAEA,MAAM;IAAEkB;EAAkB,CAAC,GAAGtD,WAAW,CAAEI,YAAa,CAAC;EACzD,SAASwC,aAAaA,CAAEW,OAAO,EAAG;IACjCD,iBAAiB,CAAEC,OAAO,EAAE;MAAEC,IAAI,EAAE;IAAW,CAAE,CAAC;EACnD;;EAEA;EACA,MAAMC,WAAW,GAAKC,OAAO,IAAM;IAClC,oBACC5C,IAAA,CAAC5B,WAAW;MACXsC,SAAS,EAAC,gCAAgC;MAC1CmC,gBAAgB,EAAG,CAAErC,gBAAkB;MACvCpB,IAAI,EAAGA,IAAM;MACb0D,KAAK,EAAG9D,EAAE,CAAE,OAAQ,CAAG;MACvB+D,YAAY,EAAG/D,EAAE,CAChB,6DACD,CAAG;MAAAgE,QAAA,EAEDJ;IAAO,CACG,CAAC;EAEhB,CAAC;EAED,MAAMK,OAAO,GAAGjF,IAAI,CAAE0C,SAAS,EAAE;IAChC,cAAc,EAAE,CAAC,CAAEW;EACpB,CAAE,CAAC;EAEH,MAAM6B,UAAU,GAAGtE,aAAa,CAAE;IACjC8B,SAAS,EAAEuC;EACZ,CAAE,CAAC;EAEH,IAAK,CAAE9B,GAAG,IAAI,CAAEE,YAAY,EAAG;IAC9B,oBACCrB,IAAA;MAAA,GAAUkD,UAAU;MAAAF,QAAA,eACnBhD,IAAA,CAACtB,gBAAgB;QAChBU,IAAI,eAAGY,IAAA,CAACxB,SAAS;UAACY,IAAI,EAAGA;QAAM,CAAE,CAAG;QACpC+D,QAAQ,EAAGvB,aAAe;QAC1BS,WAAW,EAAGA,WAAa;QAC3Be,MAAM,EAAC,SAAS;QAChB1B,YAAY,EAAGrB,mBAAqB;QACpCgD,KAAK,EAAG5C,UAAY;QACpBoB,OAAO,EAAGC,aAAe;QACzBa,WAAW,EAAGA;MAAa,CAC3B;IAAC,CACE,CAAC;EAER;EAEA,oBACCvC,KAAA,CAAAF,SAAA;IAAA8C,QAAA,GACGxC,gBAAgB,iBACjBJ,KAAA,CAAAF,SAAA;MAAA8C,QAAA,gBACChD,IAAA,CAACzB,aAAa;QAAAyE,QAAA,eACbhD,IAAA,CAACJ,YAAY;UACZwB,MAAM,EAAGA,MAAQ;UACjBO,QAAQ,EAAK2B,SAAS,IAAM;YAC3B3C,aAAa,CAAE;cAAES,MAAM,EAAEkC;YAAU,CAAE,CAAC;UACvC;QAAG,CACH;MAAC,CACY,CAAC,eAChBtD,IAAA,CAACzB,aAAa;QAACgF,KAAK,EAAC,OAAO;QAAAP,QAAA,eAC3BhD,IAAA,CAACrB,gBAAgB;UAChB6E,OAAO,EAAGxC,EAAI;UACdyC,QAAQ,EAAGtC,GAAK;UAChBO,YAAY,EAAGrB,mBAAqB;UACpC+C,MAAM,EAAC,SAAS;UAChBD,QAAQ,EAAGvB,aAAe;UAC1BS,WAAW,EAAGA,WAAa;UAC3BR,OAAO,EAAGC,aAAe;UACzB4B,OAAO,EAAGA,CAAA,KAAM9B,aAAa,CAAEM,SAAU;QAAG,CAC5C;MAAC,CACY,CAAC;IAAA,CACf,CACF,eACDlC,IAAA,CAACvB,iBAAiB;MAAAuE,QAAA,eACjB5C,KAAA,CAAC9B,UAAU;QACVwE,KAAK,EAAG9D,EAAE,CAAE,UAAW,CAAG;QAC1B2E,QAAQ,EAAGA,CAAA,KAAM;UAChBhD,aAAa,CAAE;YACdiD,QAAQ,EAAE,KAAK;YACf3C,QAAQ,EAAE,IAAI;YACd4C,IAAI,EAAE,KAAK;YACXC,KAAK,EAAE,KAAK;YACZC,WAAW,EAAE,KAAK;YAClBC,OAAO,EAAE,UAAU;YACnB9C,MAAM,EAAE;UACT,CAAE,CAAC;QACJ,CAAG;QACHM,iBAAiB,EAAGA,iBAAmB;QAAAwB,QAAA,gBAEvChD,IAAA,CAACL,mBAAmB;UACnBgB,aAAa,EAAGA,aAAe;UAC/BF,UAAU,EAAGA;QAAY,CACzB,CAAC,eACFT,IAAA,CAACT,WAAW;UACX2B,MAAM,EAAGA,MAAQ;UACjBP,aAAa,EAAGA,aAAe;UAC/BG,UAAU,EAAGA;QAAY,CACzB,CAAC;MAAA,CACS;IAAC,CACK,CAAC,eACpBV,KAAA;MAAA,GAAa8C,UAAU;MAAAF,QAAA,gBAMtBhD,IAAA,CAAC9B,QAAQ;QAAC+F,UAAU,EAAG,CAAEzD,gBAAkB;QAAAwC,QAAA,eAC1ChD,IAAA;UACCiB,QAAQ,EAAGA,QAAU;UACrBC,MAAM,EAAGA,MAAQ;UACjBC,GAAG,EAAGA,GAAG,IAAIE,YAAc;UAC3B6C,GAAG,EAAGnD,WAAa;UAAAiC,QAAA,eAEnBhD,IAAA,CAACH,MAAM;YAACuB,MAAM,EAAGA;UAAQ,CAAE;QAAC,CACtB;MAAC,CACC,CAAC,EACT,CAAC,CAAEC,YAAY,iBAAIrB,IAAA,CAAC7B,OAAO,IAAE,CAAC,eAChC6B,IAAA,CAACF,OAAO;QACPW,UAAU,EAAGA,UAAY;QACzBE,aAAa,EAAGA,aAAe;QAC/BJ,UAAU,EAAGC,gBAAkB;QAC/BI,iBAAiB,EAAGA,iBAAmB;QACvCkC,KAAK,EAAG9D,EAAE,CAAE,oBAAqB,CAAG;QACpCmF,iBAAiB,EAAG3D;MAAkB,CACtC,CAAC;IAAA,CACK,CAAC;EAAA,CACR,CAAC;AAEL;AAEA,eAAeF,SAAS","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, useDispatch } from '@wordpress/data';
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 = DEFAULT_KIND,
81
- default: isDefaultTrack = false
82
- } = track;
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 => onChange({
101
- ...track,
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 => onChange({
111
- ...track,
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
- onChange({
129
- ...track,
130
- kind: newKind
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
- onChange({
141
- ...track,
142
- default: defaultTrack
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
- const changes = {};
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
- title,
199
- url
200
- }) => {
201
- if (tracks.some(track => track.src === url)) {
202
- createNotice('error', __('This track already exists.'), {
203
- isDismissible: true,
204
- type: 'snackbar'
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
- const trackIndex = tracks.length;
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__*/_jsxs(MenuGroup, {
288
+ }), /*#__PURE__*/_jsx(MenuGroup, {
280
289
  className: "block-library-video-tracks-editor__add-tracks-container",
281
290
  label: __('Add tracks'),
282
- children: [/*#__PURE__*/_jsx(MediaUpload, {
283
- onSelect: handleTrackSelect,
284
- allowedTypes: ALLOWED_TYPES,
285
- render: ({
286
- open
287
- }) => /*#__PURE__*/_jsx(MenuItem, {
288
- icon: media,
289
- onClick: open,
290
- children: __('Open Media Library')
291
- })
292
- }), /*#__PURE__*/_jsx(MediaUploadCheck, {
293
- children: /*#__PURE__*/_jsx(FormFileUpload, {
294
- onChange: event => {
295
- const files = event.target.files;
296
- const trackIndex = tracks.length;
297
- mediaUpload({
298
- allowedTypes: ALLOWED_TYPES,
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
  });