@wordpress/block-library 8.19.2 → 8.19.4

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 (79) hide show
  1. package/CHANGELOG.md +7 -0
  2. package/build/cover/edit/inspector-controls.js +1 -1
  3. package/build/cover/edit/inspector-controls.js.map +1 -1
  4. package/build/embed/edit.js +17 -0
  5. package/build/embed/edit.js.map +1 -1
  6. package/build/embed/edit.native.js +17 -0
  7. package/build/embed/edit.native.js.map +1 -1
  8. package/build/image/image.js +2 -2
  9. package/build/image/image.js.map +1 -1
  10. package/build/image/view.js +142 -31
  11. package/build/image/view.js.map +1 -1
  12. package/build/latest-posts/edit.js +6 -2
  13. package/build/latest-posts/edit.js.map +1 -1
  14. package/build/media-text/edit.js +1 -1
  15. package/build/media-text/edit.js.map +1 -1
  16. package/build/navigation/edit/deleted-navigation-warning.js +6 -4
  17. package/build/navigation/edit/deleted-navigation-warning.js.map +1 -1
  18. package/build/navigation/edit/index.js +3 -2
  19. package/build/navigation/edit/index.js.map +1 -1
  20. package/build/navigation/edit/inner-blocks.js +2 -1
  21. package/build/navigation/edit/inner-blocks.js.map +1 -1
  22. package/build/paragraph/edit.js +1 -1
  23. package/build/paragraph/edit.js.map +1 -1
  24. package/build/search/edit.js +12 -10
  25. package/build/search/edit.js.map +1 -1
  26. package/build-module/cover/edit/inspector-controls.js +1 -1
  27. package/build-module/cover/edit/inspector-controls.js.map +1 -1
  28. package/build-module/embed/edit.js +17 -0
  29. package/build-module/embed/edit.js.map +1 -1
  30. package/build-module/embed/edit.native.js +17 -0
  31. package/build-module/embed/edit.native.js.map +1 -1
  32. package/build-module/image/image.js +2 -2
  33. package/build-module/image/image.js.map +1 -1
  34. package/build-module/image/view.js +142 -31
  35. package/build-module/image/view.js.map +1 -1
  36. package/build-module/latest-posts/edit.js +6 -2
  37. package/build-module/latest-posts/edit.js.map +1 -1
  38. package/build-module/media-text/edit.js +1 -1
  39. package/build-module/media-text/edit.js.map +1 -1
  40. package/build-module/navigation/edit/deleted-navigation-warning.js +7 -4
  41. package/build-module/navigation/edit/deleted-navigation-warning.js.map +1 -1
  42. package/build-module/navigation/edit/index.js +3 -2
  43. package/build-module/navigation/edit/index.js.map +1 -1
  44. package/build-module/navigation/edit/inner-blocks.js +2 -1
  45. package/build-module/navigation/edit/inner-blocks.js.map +1 -1
  46. package/build-module/paragraph/edit.js +1 -1
  47. package/build-module/paragraph/edit.js.map +1 -1
  48. package/build-module/search/edit.js +12 -10
  49. package/build-module/search/edit.js.map +1 -1
  50. package/build-style/image/style-rtl.css +17 -6
  51. package/build-style/image/style.css +17 -6
  52. package/build-style/navigation-link/style-rtl.css +0 -1
  53. package/build-style/navigation-link/style.css +0 -1
  54. package/build-style/post-featured-image/style-rtl.css +3 -0
  55. package/build-style/post-featured-image/style.css +3 -0
  56. package/build-style/post-template/style-rtl.css +25 -0
  57. package/build-style/post-template/style.css +25 -0
  58. package/build-style/style-rtl.css +46 -7
  59. package/build-style/style.css +46 -7
  60. package/package.json +32 -32
  61. package/src/cover/edit/inspector-controls.js +1 -1
  62. package/src/embed/edit.js +15 -0
  63. package/src/embed/edit.native.js +15 -0
  64. package/src/footnotes/index.php +13 -179
  65. package/src/image/image.js +2 -2
  66. package/src/image/index.php +73 -48
  67. package/src/image/style.scss +23 -6
  68. package/src/image/view.js +151 -48
  69. package/src/latest-posts/edit.js +10 -2
  70. package/src/latest-posts/index.php +18 -8
  71. package/src/media-text/edit.js +1 -1
  72. package/src/navigation/edit/deleted-navigation-warning.js +9 -4
  73. package/src/navigation/edit/index.js +26 -17
  74. package/src/navigation/edit/inner-blocks.js +1 -0
  75. package/src/navigation-link/style.scss +0 -1
  76. package/src/paragraph/edit.js +1 -1
  77. package/src/post-featured-image/style.scss +4 -0
  78. package/src/post-template/style.scss +20 -0
  79. package/src/search/edit.js +16 -10
@@ -1 +1 @@
1
- {"version":3,"names":["_element","require","_blob","_components","_compose","_data","_blockEditor","_i18n","_url","_blocks","_icons","_notices","_coreData","_lockUnlock","_util","_useClientWidth","_interopRequireDefault","_edit","_constants","_utils","DimensionsTool","ResolutionTool","unlock","blockEditorPrivateApis","scaleOptions","value","label","_x","help","__","Image","temporaryURL","attributes","setAttributes","isSelected","insertBlocksAfter","onReplace","onSelectImage","onSelectURL","onUploadError","containerRef","context","clientId","blockEditingMode","url","alt","caption","align","id","href","rel","linkClass","linkDestination","title","width","height","aspectRatio","scale","linkTarget","sizeSlug","lightbox","numericWidth","parseInt","undefined","numericHeight","imageRef","useRef","prevCaption","usePrevious","showCaption","setShowCaption","useState","allowResize","getBlock","useSelect","blockEditorStore","image","multiImageSelection","select","getMedia","coreStore","getMultiSelectedBlockClientIds","getBlockName","multiSelectedClientIds","length","every","_clientId","canInsertCover","imageEditing","imageSizes","maxWidth","mediaUpload","getBlockRootClientId","getSettings","canInsertBlockType","rootClientId","settings","replaceBlocks","toggleSelection","useDispatch","createErrorNotice","createSuccessNotice","noticesStore","isLargeViewport","useViewportMatch","isWideAligned","includes","loadedNaturalWidth","loadedNaturalHeight","setLoadedNaturalSize","isEditingImage","setIsEditingImage","externalBlob","setExternalBlob","clientWidth","useClientWidth","hasNonContentControls","isResizable","imageSizeOptions","filter","slug","media_details","sizes","source_url","map","name","canUploadMedia","useEffect","isExternalImage","window","fetch","then","response","blob","catch","captionRef","useCallback","node","focus","naturalWidth","naturalHeight","useMemo","current","complete","onResizeStart","onResizeStop","onImageError","embedBlock","createUpgradedEmbedBlock","onSetHref","props","onSetTitle","updateAlt","newAlt","updateImage","newSizeSlug","newUrl","uploadExternal","filesList","onFileChange","img","isBlobURL","type","allowedTypes","ALLOWED_MEDIA_TYPES","onError","message","updateAlignment","nextAlign","extraUpdatedAttributes","canEditImage","allowCrop","switchToCover","switchToBlockType","dimensionsUnitsOptions","useCustomUnits","availableUnits","lightboxSetting","useSetting","showLightboxToggle","allowEditing","lightboxChecked","enabled","dimensionsControl","createElement","onChange","newWidth","newHeight","newScale","newAspectRatio","defaultScale","defaultAspectRatio","unitsOptions","resetAll","sizeControls","InspectorControls","__experimentalToolsPanel","controls","Fragment","BlockControls","group","BlockAlignmentControl","ToolbarButton","onClick","icon","captionIcon","isPressed","__experimentalImageURLInputUI","onChangeUrl","mediaUrl","mediaLink","link","crop","overlayText","MediaReplaceFlow","mediaId","mediaURL","accept","onSelect","ToolbarGroup","upload","__experimentalToolsPanelItem","isShownByDefault","hasValue","onDeselect","TextareaControl","ExternalLink","__nextHasNoMarginBottom","options","ToggleControl","checked","newValue","TextControl","filename","getFilename","defaultedAlt","sprintf","borderProps","useBorderProps","isRounded","className","src","onLoad","event","target","ref","style","objectFit","Spinner","fallbackClientWidth","__experimentalImageEditor","onSaveImage","imageAttributes","onFinishEditing","numericRatio","evalAspectRatio","customRatio","naturalRatio","ratio","currentWidth","currentHeight","minWidth","MIN_SIZE","minHeight","maxWidthBuffer","showRightHandle","showLeftHandle","isRTL","ResizableBox","display","size","showHandle","maxHeight","lockAspectRatio","enable","top","right","bottom","left","direction","elt","offsetWidth","String","resizeRatio","RichText","isEmpty","identifier","__experimentalGetElementClassName","tagName","placeholder","inlineToolbar","__unstableOnSplitAtEnd","createBlock","getDefaultBlockName"],"sources":["@wordpress/block-library/src/image/image.js"],"sourcesContent":["/**\n * WordPress dependencies\n */\nimport { isBlobURL } from '@wordpress/blob';\nimport {\n\tExternalLink,\n\tResizableBox,\n\tSpinner,\n\tTextareaControl,\n\tToggleControl,\n\tTextControl,\n\tToolbarButton,\n\tToolbarGroup,\n\t__experimentalToolsPanel as ToolsPanel,\n\t__experimentalToolsPanelItem as ToolsPanelItem,\n\t__experimentalUseCustomUnits as useCustomUnits,\n} from '@wordpress/components';\nimport { useViewportMatch, usePrevious } from '@wordpress/compose';\nimport { useSelect, useDispatch } from '@wordpress/data';\nimport {\n\tBlockControls,\n\tInspectorControls,\n\tRichText,\n\t__experimentalImageURLInputUI as ImageURLInputUI,\n\tMediaReplaceFlow,\n\tstore as blockEditorStore,\n\tuseSetting,\n\tBlockAlignmentControl,\n\t__experimentalImageEditor as ImageEditor,\n\t__experimentalGetElementClassName,\n\t__experimentalUseBorderProps as useBorderProps,\n\tprivateApis as blockEditorPrivateApis,\n} from '@wordpress/block-editor';\nimport {\n\tuseEffect,\n\tuseMemo,\n\tuseState,\n\tuseRef,\n\tuseCallback,\n} from '@wordpress/element';\nimport { __, _x, sprintf, isRTL } from '@wordpress/i18n';\nimport { getFilename } from '@wordpress/url';\nimport {\n\tcreateBlock,\n\tgetDefaultBlockName,\n\tswitchToBlockType,\n} from '@wordpress/blocks';\nimport {\n\tcrop,\n\toverlayText,\n\tupload,\n\tcaption as captionIcon,\n} from '@wordpress/icons';\nimport { store as noticesStore } from '@wordpress/notices';\nimport { store as coreStore } from '@wordpress/core-data';\n\n/**\n * Internal dependencies\n */\nimport { unlock } from '../lock-unlock';\nimport { createUpgradedEmbedBlock } from '../embed/util';\nimport useClientWidth from './use-client-width';\nimport { isExternalImage } from './edit';\n\n/**\n * Module constants\n */\nimport { MIN_SIZE, ALLOWED_MEDIA_TYPES } from './constants';\nimport { evalAspectRatio } from './utils';\n\nconst { DimensionsTool, ResolutionTool } = unlock( blockEditorPrivateApis );\n\nconst scaleOptions = [\n\t{\n\t\tvalue: 'cover',\n\t\tlabel: _x( 'Cover', 'Scale option for dimensions control' ),\n\t\thelp: __( 'Image covers the space evenly.' ),\n\t},\n\t{\n\t\tvalue: 'contain',\n\t\tlabel: _x( 'Contain', 'Scale option for dimensions control' ),\n\t\thelp: __( 'Image is contained without distortion.' ),\n\t},\n];\n\nexport default function Image( {\n\ttemporaryURL,\n\tattributes,\n\tsetAttributes,\n\tisSelected,\n\tinsertBlocksAfter,\n\tonReplace,\n\tonSelectImage,\n\tonSelectURL,\n\tonUploadError,\n\tcontainerRef,\n\tcontext,\n\tclientId,\n\tblockEditingMode,\n} ) {\n\tconst {\n\t\turl = '',\n\t\talt,\n\t\tcaption,\n\t\talign,\n\t\tid,\n\t\thref,\n\t\trel,\n\t\tlinkClass,\n\t\tlinkDestination,\n\t\ttitle,\n\t\twidth,\n\t\theight,\n\t\taspectRatio,\n\t\tscale,\n\t\tlinkTarget,\n\t\tsizeSlug,\n\t\tlightbox,\n\t} = attributes;\n\n\t// The only supported unit is px, so we can parseInt to strip the px here.\n\tconst numericWidth = width ? parseInt( width, 10 ) : undefined;\n\tconst numericHeight = height ? parseInt( height, 10 ) : undefined;\n\n\tconst imageRef = useRef();\n\tconst prevCaption = usePrevious( caption );\n\tconst [ showCaption, setShowCaption ] = useState( !! caption );\n\tconst { allowResize = true } = context;\n\tconst { getBlock } = useSelect( blockEditorStore );\n\n\tconst { image, multiImageSelection } = useSelect(\n\t\t( select ) => {\n\t\t\tconst { getMedia } = select( coreStore );\n\t\t\tconst { getMultiSelectedBlockClientIds, getBlockName } =\n\t\t\t\tselect( blockEditorStore );\n\t\t\tconst multiSelectedClientIds = getMultiSelectedBlockClientIds();\n\t\t\treturn {\n\t\t\t\timage:\n\t\t\t\t\tid && isSelected\n\t\t\t\t\t\t? getMedia( id, { context: 'view' } )\n\t\t\t\t\t\t: null,\n\t\t\t\tmultiImageSelection:\n\t\t\t\t\tmultiSelectedClientIds.length &&\n\t\t\t\t\tmultiSelectedClientIds.every(\n\t\t\t\t\t\t( _clientId ) =>\n\t\t\t\t\t\t\tgetBlockName( _clientId ) === 'core/image'\n\t\t\t\t\t),\n\t\t\t};\n\t\t},\n\t\t[ id, isSelected ]\n\t);\n\tconst { canInsertCover, imageEditing, imageSizes, maxWidth, mediaUpload } =\n\t\tuseSelect(\n\t\t\t( select ) => {\n\t\t\t\tconst {\n\t\t\t\t\tgetBlockRootClientId,\n\t\t\t\t\tgetSettings,\n\t\t\t\t\tcanInsertBlockType,\n\t\t\t\t} = select( blockEditorStore );\n\n\t\t\t\tconst rootClientId = getBlockRootClientId( clientId );\n\t\t\t\tconst settings = getSettings();\n\n\t\t\t\treturn {\n\t\t\t\t\timageEditing: settings.imageEditing,\n\t\t\t\t\timageSizes: settings.imageSizes,\n\t\t\t\t\tmaxWidth: settings.maxWidth,\n\t\t\t\t\tmediaUpload: settings.mediaUpload,\n\t\t\t\t\tcanInsertCover: canInsertBlockType(\n\t\t\t\t\t\t'core/cover',\n\t\t\t\t\t\trootClientId\n\t\t\t\t\t),\n\t\t\t\t};\n\t\t\t},\n\t\t\t[ clientId ]\n\t\t);\n\n\tconst { replaceBlocks, toggleSelection } = useDispatch( blockEditorStore );\n\tconst { createErrorNotice, createSuccessNotice } =\n\t\tuseDispatch( noticesStore );\n\tconst isLargeViewport = useViewportMatch( 'medium' );\n\tconst isWideAligned = [ 'wide', 'full' ].includes( align );\n\tconst [\n\t\t{ loadedNaturalWidth, loadedNaturalHeight },\n\t\tsetLoadedNaturalSize,\n\t] = useState( {} );\n\tconst [ isEditingImage, setIsEditingImage ] = useState( false );\n\tconst [ externalBlob, setExternalBlob ] = useState();\n\tconst clientWidth = useClientWidth( containerRef, [ align ] );\n\tconst hasNonContentControls = blockEditingMode === 'default';\n\tconst isResizable =\n\t\tallowResize &&\n\t\thasNonContentControls &&\n\t\t! ( isWideAligned && isLargeViewport );\n\tconst imageSizeOptions = imageSizes\n\t\t.filter(\n\t\t\t( { slug } ) => image?.media_details?.sizes?.[ slug ]?.source_url\n\t\t)\n\t\t.map( ( { name, slug } ) => ( { value: slug, label: name } ) );\n\tconst canUploadMedia = !! mediaUpload;\n\n\t// If an image is externally hosted, try to fetch the image data. This may\n\t// fail if the image host doesn't allow CORS with the domain. If it works,\n\t// we can enable a button in the toolbar to upload the image.\n\tuseEffect( () => {\n\t\tif (\n\t\t\t! isExternalImage( id, url ) ||\n\t\t\t! isSelected ||\n\t\t\t! canUploadMedia\n\t\t) {\n\t\t\tsetExternalBlob();\n\t\t\treturn;\n\t\t}\n\n\t\tif ( externalBlob ) return;\n\n\t\twindow\n\t\t\t// Avoid cache, which seems to help avoid CORS problems.\n\t\t\t.fetch( url.includes( '?' ) ? url : url + '?' )\n\t\t\t.then( ( response ) => response.blob() )\n\t\t\t.then( ( blob ) => setExternalBlob( blob ) )\n\t\t\t// Do nothing, cannot upload.\n\t\t\t.catch( () => {} );\n\t}, [ id, url, isSelected, externalBlob, canUploadMedia ] );\n\n\t// We need to show the caption when changes come from\n\t// history navigation(undo/redo).\n\tuseEffect( () => {\n\t\tif ( caption && ! prevCaption ) {\n\t\t\tsetShowCaption( true );\n\t\t}\n\t}, [ caption, prevCaption ] );\n\n\t// Focus the caption when we click to add one.\n\tconst captionRef = useCallback(\n\t\t( node ) => {\n\t\t\tif ( node && ! caption ) {\n\t\t\t\tnode.focus();\n\t\t\t}\n\t\t},\n\t\t[ caption ]\n\t);\n\n\t// Get naturalWidth and naturalHeight from image ref, and fall back to loaded natural\n\t// width and height. This resolves an issue in Safari where the loaded natural\n\t// width and height is otherwise lost when switching between alignments.\n\t// See: https://github.com/WordPress/gutenberg/pull/37210.\n\tconst { naturalWidth, naturalHeight } = useMemo( () => {\n\t\treturn {\n\t\t\tnaturalWidth:\n\t\t\t\timageRef.current?.naturalWidth ||\n\t\t\t\tloadedNaturalWidth ||\n\t\t\t\tundefined,\n\t\t\tnaturalHeight:\n\t\t\t\timageRef.current?.naturalHeight ||\n\t\t\t\tloadedNaturalHeight ||\n\t\t\t\tundefined,\n\t\t};\n\t}, [\n\t\tloadedNaturalWidth,\n\t\tloadedNaturalHeight,\n\t\timageRef.current?.complete,\n\t] );\n\n\tfunction onResizeStart() {\n\t\ttoggleSelection( false );\n\t}\n\n\tfunction onResizeStop() {\n\t\ttoggleSelection( true );\n\t}\n\n\tfunction onImageError() {\n\t\t// Check if there's an embed block that handles this URL, e.g., instagram URL.\n\t\t// See: https://github.com/WordPress/gutenberg/pull/11472\n\t\tconst embedBlock = createUpgradedEmbedBlock( { attributes: { url } } );\n\n\t\tif ( undefined !== embedBlock ) {\n\t\t\tonReplace( embedBlock );\n\t\t}\n\t}\n\n\tfunction onSetHref( props ) {\n\t\tsetAttributes( props );\n\t}\n\n\tfunction onSetTitle( value ) {\n\t\t// This is the HTML title attribute, separate from the media object\n\t\t// title.\n\t\tsetAttributes( { title: value } );\n\t}\n\n\tfunction updateAlt( newAlt ) {\n\t\tsetAttributes( { alt: newAlt } );\n\t}\n\n\tfunction updateImage( newSizeSlug ) {\n\t\tconst newUrl = image?.media_details?.sizes?.[ newSizeSlug ]?.source_url;\n\t\tif ( ! newUrl ) {\n\t\t\treturn null;\n\t\t}\n\n\t\tsetAttributes( {\n\t\t\turl: newUrl,\n\t\t\tsizeSlug: newSizeSlug,\n\t\t} );\n\t}\n\n\tfunction uploadExternal() {\n\t\tmediaUpload( {\n\t\t\tfilesList: [ externalBlob ],\n\t\t\tonFileChange( [ img ] ) {\n\t\t\t\tonSelectImage( img );\n\n\t\t\t\tif ( isBlobURL( img.url ) ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tsetExternalBlob();\n\t\t\t\tcreateSuccessNotice( __( 'Image uploaded.' ), {\n\t\t\t\t\ttype: 'snackbar',\n\t\t\t\t} );\n\t\t\t},\n\t\t\tallowedTypes: ALLOWED_MEDIA_TYPES,\n\t\t\tonError( message ) {\n\t\t\t\tcreateErrorNotice( message, { type: 'snackbar' } );\n\t\t\t},\n\t\t} );\n\t}\n\n\tfunction updateAlignment( nextAlign ) {\n\t\tconst extraUpdatedAttributes = [ 'wide', 'full' ].includes( nextAlign )\n\t\t\t? {\n\t\t\t\t\twidth: undefined,\n\t\t\t\t\theight: undefined,\n\t\t\t\t\taspectRatio: undefined,\n\t\t\t\t\tscale: undefined,\n\t\t\t }\n\t\t\t: {};\n\t\tsetAttributes( {\n\t\t\t...extraUpdatedAttributes,\n\t\t\talign: nextAlign,\n\t\t} );\n\t}\n\n\tuseEffect( () => {\n\t\tif ( ! isSelected ) {\n\t\t\tsetIsEditingImage( false );\n\t\t\tif ( ! caption ) {\n\t\t\t\tsetShowCaption( false );\n\t\t\t}\n\t\t}\n\t}, [ isSelected, caption ] );\n\n\tconst canEditImage = id && naturalWidth && naturalHeight && imageEditing;\n\tconst allowCrop = ! multiImageSelection && canEditImage && ! isEditingImage;\n\n\tfunction switchToCover() {\n\t\treplaceBlocks(\n\t\t\tclientId,\n\t\t\tswitchToBlockType( getBlock( clientId ), 'core/cover' )\n\t\t);\n\t}\n\n\t// TODO: Can allow more units after figuring out how they should interact\n\t// with the ResizableBox and ImageEditor components. Calculations later on\n\t// for those components are currently assuming px units.\n\tconst dimensionsUnitsOptions = useCustomUnits( {\n\t\tavailableUnits: [ 'px' ],\n\t} );\n\n\tconst lightboxSetting = useSetting( 'lightbox' );\n\n\tconst showLightboxToggle =\n\t\tlightboxSetting === true || lightboxSetting?.allowEditing === true;\n\n\tconst lightboxChecked =\n\t\tlightbox?.enabled || ( ! lightbox && lightboxSetting?.enabled );\n\n\tconst dimensionsControl = (\n\t\t<DimensionsTool\n\t\t\tvalue={ { width, height, scale, aspectRatio } }\n\t\t\tonChange={ ( {\n\t\t\t\twidth: newWidth,\n\t\t\t\theight: newHeight,\n\t\t\t\tscale: newScale,\n\t\t\t\taspectRatio: newAspectRatio,\n\t\t\t} ) => {\n\t\t\t\t// Rebuilding the object forces setting `undefined`\n\t\t\t\t// for values that are removed since setAttributes\n\t\t\t\t// doesn't do anything with keys that aren't set.\n\t\t\t\tsetAttributes( {\n\t\t\t\t\t// CSS includes `height: auto`, but we need\n\t\t\t\t\t// `width: auto` to fix the aspect ratio when\n\t\t\t\t\t// only height is set due to the width and\n\t\t\t\t\t// height attributes set via the server.\n\t\t\t\t\twidth: ! newWidth && newHeight ? 'auto' : newWidth,\n\t\t\t\t\theight: newHeight,\n\t\t\t\t\tscale: newScale,\n\t\t\t\t\taspectRatio: newAspectRatio,\n\t\t\t\t} );\n\t\t\t} }\n\t\t\tdefaultScale=\"cover\"\n\t\t\tdefaultAspectRatio=\"auto\"\n\t\t\tscaleOptions={ scaleOptions }\n\t\t\tunitsOptions={ dimensionsUnitsOptions }\n\t\t/>\n\t);\n\n\tconst resetAll = () => {\n\t\tsetAttributes( {\n\t\t\twidth: undefined,\n\t\t\theight: undefined,\n\t\t\tscale: undefined,\n\t\t\taspectRatio: undefined,\n\t\t\tlightbox: undefined,\n\t\t} );\n\t};\n\n\tconst sizeControls = (\n\t\t<InspectorControls>\n\t\t\t<ToolsPanel label={ __( 'Settings' ) } resetAll={ resetAll }>\n\t\t\t\t{ isResizable && dimensionsControl }\n\t\t\t</ToolsPanel>\n\t\t</InspectorControls>\n\t);\n\n\tconst controls = (\n\t\t<>\n\t\t\t<BlockControls group=\"block\">\n\t\t\t\t{ hasNonContentControls && (\n\t\t\t\t\t<BlockAlignmentControl\n\t\t\t\t\t\tvalue={ align }\n\t\t\t\t\t\tonChange={ updateAlignment }\n\t\t\t\t\t/>\n\t\t\t\t) }\n\t\t\t\t{ hasNonContentControls && (\n\t\t\t\t\t<ToolbarButton\n\t\t\t\t\t\tonClick={ () => {\n\t\t\t\t\t\t\tsetShowCaption( ! showCaption );\n\t\t\t\t\t\t\tif ( showCaption && caption ) {\n\t\t\t\t\t\t\t\tsetAttributes( { caption: undefined } );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} }\n\t\t\t\t\t\ticon={ captionIcon }\n\t\t\t\t\t\tisPressed={ showCaption }\n\t\t\t\t\t\tlabel={\n\t\t\t\t\t\t\tshowCaption\n\t\t\t\t\t\t\t\t? __( 'Remove caption' )\n\t\t\t\t\t\t\t\t: __( 'Add caption' )\n\t\t\t\t\t\t}\n\t\t\t\t\t/>\n\t\t\t\t) }\n\t\t\t\t{ ! multiImageSelection && ! isEditingImage && (\n\t\t\t\t\t<ImageURLInputUI\n\t\t\t\t\t\turl={ href || '' }\n\t\t\t\t\t\tonChangeUrl={ onSetHref }\n\t\t\t\t\t\tlinkDestination={ linkDestination }\n\t\t\t\t\t\tmediaUrl={ ( image && image.source_url ) || url }\n\t\t\t\t\t\tmediaLink={ image && image.link }\n\t\t\t\t\t\tlinkTarget={ linkTarget }\n\t\t\t\t\t\tlinkClass={ linkClass }\n\t\t\t\t\t\trel={ rel }\n\t\t\t\t\t/>\n\t\t\t\t) }\n\t\t\t\t{ allowCrop && (\n\t\t\t\t\t<ToolbarButton\n\t\t\t\t\t\tonClick={ () => setIsEditingImage( true ) }\n\t\t\t\t\t\ticon={ crop }\n\t\t\t\t\t\tlabel={ __( 'Crop' ) }\n\t\t\t\t\t/>\n\t\t\t\t) }\n\t\t\t\t{ ! multiImageSelection && canInsertCover && (\n\t\t\t\t\t<ToolbarButton\n\t\t\t\t\t\ticon={ overlayText }\n\t\t\t\t\t\tlabel={ __( 'Add text over image' ) }\n\t\t\t\t\t\tonClick={ switchToCover }\n\t\t\t\t\t/>\n\t\t\t\t) }\n\t\t\t</BlockControls>\n\t\t\t{ ! multiImageSelection && ! isEditingImage && (\n\t\t\t\t<BlockControls group=\"other\">\n\t\t\t\t\t<MediaReplaceFlow\n\t\t\t\t\t\tmediaId={ id }\n\t\t\t\t\t\tmediaURL={ url }\n\t\t\t\t\t\tallowedTypes={ ALLOWED_MEDIA_TYPES }\n\t\t\t\t\t\taccept=\"image/*\"\n\t\t\t\t\t\tonSelect={ onSelectImage }\n\t\t\t\t\t\tonSelectURL={ onSelectURL }\n\t\t\t\t\t\tonError={ onUploadError }\n\t\t\t\t\t/>\n\t\t\t\t</BlockControls>\n\t\t\t) }\n\t\t\t{ ! multiImageSelection && externalBlob && (\n\t\t\t\t<BlockControls>\n\t\t\t\t\t<ToolbarGroup>\n\t\t\t\t\t\t<ToolbarButton\n\t\t\t\t\t\t\tonClick={ uploadExternal }\n\t\t\t\t\t\t\ticon={ upload }\n\t\t\t\t\t\t\tlabel={ __( 'Upload external image' ) }\n\t\t\t\t\t\t/>\n\t\t\t\t\t</ToolbarGroup>\n\t\t\t\t</BlockControls>\n\t\t\t) }\n\t\t\t<InspectorControls>\n\t\t\t\t<ToolsPanel label={ __( 'Settings' ) } resetAll={ resetAll }>\n\t\t\t\t\t{ ! multiImageSelection && (\n\t\t\t\t\t\t<ToolsPanelItem\n\t\t\t\t\t\t\tlabel={ __( 'Alternative text' ) }\n\t\t\t\t\t\t\tisShownByDefault={ true }\n\t\t\t\t\t\t\thasValue={ () => alt !== '' }\n\t\t\t\t\t\t\tonDeselect={ () =>\n\t\t\t\t\t\t\t\tsetAttributes( { alt: undefined } )\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<TextareaControl\n\t\t\t\t\t\t\t\tlabel={ __( 'Alternative text' ) }\n\t\t\t\t\t\t\t\tvalue={ alt }\n\t\t\t\t\t\t\t\tonChange={ updateAlt }\n\t\t\t\t\t\t\t\thelp={\n\t\t\t\t\t\t\t\t\t<>\n\t\t\t\t\t\t\t\t\t\t<ExternalLink href=\"https://www.w3.org/WAI/tutorials/images/decision-tree\">\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'Describe the purpose of the image.'\n\t\t\t\t\t\t\t\t\t\t\t) }\n\t\t\t\t\t\t\t\t\t\t</ExternalLink>\n\t\t\t\t\t\t\t\t\t\t<br />\n\t\t\t\t\t\t\t\t\t\t{ __( 'Leave empty if decorative.' ) }\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__nextHasNoMarginBottom\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t</ToolsPanelItem>\n\t\t\t\t\t) }\n\t\t\t\t\t{ isResizable && dimensionsControl }\n\t\t\t\t\t<ResolutionTool\n\t\t\t\t\t\tvalue={ sizeSlug }\n\t\t\t\t\t\tonChange={ updateImage }\n\t\t\t\t\t\toptions={ imageSizeOptions }\n\t\t\t\t\t/>\n\t\t\t\t\t{ showLightboxToggle && (\n\t\t\t\t\t\t<ToolsPanelItem\n\t\t\t\t\t\t\thasValue={ () => !! lightbox }\n\t\t\t\t\t\t\tlabel={ __( 'Expand on Click' ) }\n\t\t\t\t\t\t\tonDeselect={ () => {\n\t\t\t\t\t\t\t\tsetAttributes( { lightbox: undefined } );\n\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t\tisShownByDefault={ true }\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<ToggleControl\n\t\t\t\t\t\t\t\tlabel={ __( 'Expand on Click' ) }\n\t\t\t\t\t\t\t\tchecked={ lightboxChecked }\n\t\t\t\t\t\t\t\tonChange={ ( newValue ) => {\n\t\t\t\t\t\t\t\t\tsetAttributes( {\n\t\t\t\t\t\t\t\t\t\tlightbox: { enabled: newValue },\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</ToolsPanelItem>\n\t\t\t\t\t) }\n\t\t\t\t</ToolsPanel>\n\t\t\t</InspectorControls>\n\t\t\t<InspectorControls group=\"advanced\">\n\t\t\t\t<TextControl\n\t\t\t\t\t__nextHasNoMarginBottom\n\t\t\t\t\tlabel={ __( 'Title attribute' ) }\n\t\t\t\t\tvalue={ title || '' }\n\t\t\t\t\tonChange={ onSetTitle }\n\t\t\t\t\thelp={\n\t\t\t\t\t\t<>\n\t\t\t\t\t\t\t{ __(\n\t\t\t\t\t\t\t\t'Describe the role of this image on the page.'\n\t\t\t\t\t\t\t) }\n\t\t\t\t\t\t\t<ExternalLink href=\"https://www.w3.org/TR/html52/dom.html#the-title-attribute\">\n\t\t\t\t\t\t\t\t{ __(\n\t\t\t\t\t\t\t\t\t'(Note: many devices and browsers do not display this text.)'\n\t\t\t\t\t\t\t\t) }\n\t\t\t\t\t\t\t</ExternalLink>\n\t\t\t\t\t\t</>\n\t\t\t\t\t}\n\t\t\t\t/>\n\t\t\t</InspectorControls>\n\t\t</>\n\t);\n\n\tconst filename = getFilename( url );\n\tlet defaultedAlt;\n\n\tif ( alt ) {\n\t\tdefaultedAlt = alt;\n\t} else if ( filename ) {\n\t\tdefaultedAlt = sprintf(\n\t\t\t/* translators: %s: file name */\n\t\t\t__( 'This image has an empty alt attribute; its file name is %s' ),\n\t\t\tfilename\n\t\t);\n\t} else {\n\t\tdefaultedAlt = __( 'This image has an empty alt attribute' );\n\t}\n\n\tconst borderProps = useBorderProps( attributes );\n\tconst isRounded = attributes.className?.includes( 'is-style-rounded' );\n\n\tlet img = (\n\t\t// Disable reason: Image itself is not meant to be interactive, but\n\t\t// should direct focus to block.\n\t\t/* eslint-disable jsx-a11y/no-noninteractive-element-interactions, jsx-a11y/click-events-have-key-events */\n\t\t<>\n\t\t\t<img\n\t\t\t\tsrc={ temporaryURL || url }\n\t\t\t\talt={ defaultedAlt }\n\t\t\t\tonError={ () => onImageError() }\n\t\t\t\tonLoad={ ( event ) => {\n\t\t\t\t\tsetLoadedNaturalSize( {\n\t\t\t\t\t\tloadedNaturalWidth: event.target?.naturalWidth,\n\t\t\t\t\t\tloadedNaturalHeight: event.target?.naturalHeight,\n\t\t\t\t\t} );\n\t\t\t\t} }\n\t\t\t\tref={ imageRef }\n\t\t\t\tclassName={ borderProps.className }\n\t\t\t\tstyle={ {\n\t\t\t\t\twidth:\n\t\t\t\t\t\t( width && height ) || aspectRatio ? '100%' : undefined,\n\t\t\t\t\theight:\n\t\t\t\t\t\t( width && height ) || aspectRatio ? '100%' : undefined,\n\t\t\t\t\tobjectFit: scale,\n\t\t\t\t\t...borderProps.style,\n\t\t\t\t} }\n\t\t\t/>\n\t\t\t{ temporaryURL && <Spinner /> }\n\t\t</>\n\t\t/* eslint-enable jsx-a11y/no-noninteractive-element-interactions, jsx-a11y/click-events-have-key-events */\n\t);\n\n\t// clientWidth needs to be a number for the image Cropper to work, but sometimes it's 0\n\t// So we try using the imageRef width first and fallback to clientWidth.\n\tconst fallbackClientWidth = imageRef.current?.width || clientWidth;\n\n\tif ( canEditImage && isEditingImage ) {\n\t\timg = (\n\t\t\t<ImageEditor\n\t\t\t\tid={ id }\n\t\t\t\turl={ url }\n\t\t\t\twidth={ numericWidth }\n\t\t\t\theight={ numericHeight }\n\t\t\t\tclientWidth={ fallbackClientWidth }\n\t\t\t\tnaturalHeight={ naturalHeight }\n\t\t\t\tnaturalWidth={ naturalWidth }\n\t\t\t\tonSaveImage={ ( imageAttributes ) =>\n\t\t\t\t\tsetAttributes( imageAttributes )\n\t\t\t\t}\n\t\t\t\tonFinishEditing={ () => {\n\t\t\t\t\tsetIsEditingImage( false );\n\t\t\t\t} }\n\t\t\t\tborderProps={ isRounded ? undefined : borderProps }\n\t\t\t/>\n\t\t);\n\t} else if ( ! isResizable ) {\n\t\timg = <div style={ { width, height, aspectRatio } }>{ img }</div>;\n\t} else {\n\t\tconst numericRatio = aspectRatio && evalAspectRatio( aspectRatio );\n\t\tconst customRatio = numericWidth / numericHeight;\n\t\tconst naturalRatio = naturalWidth / naturalHeight;\n\t\tconst ratio = numericRatio || customRatio || naturalRatio || 1;\n\t\tconst currentWidth =\n\t\t\t! numericWidth && numericHeight\n\t\t\t\t? numericHeight * ratio\n\t\t\t\t: numericWidth;\n\t\tconst currentHeight =\n\t\t\t! numericHeight && numericWidth\n\t\t\t\t? numericWidth / ratio\n\t\t\t\t: numericHeight;\n\n\t\tconst minWidth =\n\t\t\tnaturalWidth < naturalHeight ? MIN_SIZE : MIN_SIZE * ratio;\n\t\tconst minHeight =\n\t\t\tnaturalHeight < naturalWidth ? MIN_SIZE : MIN_SIZE / ratio;\n\n\t\t// With the current implementation of ResizableBox, an image needs an\n\t\t// explicit pixel value for the max-width. In absence of being able to\n\t\t// set the content-width, this max-width is currently dictated by the\n\t\t// vanilla editor style. The following variable adds a buffer to this\n\t\t// vanilla style, so 3rd party themes have some wiggleroom. This does,\n\t\t// in most cases, allow you to scale the image beyond the width of the\n\t\t// main column, though not infinitely.\n\t\t// @todo It would be good to revisit this once a content-width variable\n\t\t// becomes available.\n\t\tconst maxWidthBuffer = maxWidth * 2.5;\n\n\t\tlet showRightHandle = false;\n\t\tlet showLeftHandle = false;\n\n\t\t/* eslint-disable no-lonely-if */\n\t\t// See https://github.com/WordPress/gutenberg/issues/7584.\n\t\tif ( align === 'center' ) {\n\t\t\t// When the image is centered, show both handles.\n\t\t\tshowRightHandle = true;\n\t\t\tshowLeftHandle = true;\n\t\t} else if ( isRTL() ) {\n\t\t\t// In RTL mode the image is on the right by default.\n\t\t\t// Show the right handle and hide the left handle only when it is\n\t\t\t// aligned left. Otherwise always show the left handle.\n\t\t\tif ( align === 'left' ) {\n\t\t\t\tshowRightHandle = true;\n\t\t\t} else {\n\t\t\t\tshowLeftHandle = true;\n\t\t\t}\n\t\t} else {\n\t\t\t// Show the left handle and hide the right handle only when the\n\t\t\t// image is aligned right. Otherwise always show the right handle.\n\t\t\tif ( align === 'right' ) {\n\t\t\t\tshowLeftHandle = true;\n\t\t\t} else {\n\t\t\t\tshowRightHandle = true;\n\t\t\t}\n\t\t}\n\t\t/* eslint-enable no-lonely-if */\n\n\t\timg = (\n\t\t\t<ResizableBox\n\t\t\t\tstyle={ {\n\t\t\t\t\tdisplay: 'block',\n\t\t\t\t\tobjectFit: scale,\n\t\t\t\t\taspectRatio:\n\t\t\t\t\t\t! width && ! height && aspectRatio\n\t\t\t\t\t\t\t? aspectRatio\n\t\t\t\t\t\t\t: undefined,\n\t\t\t\t} }\n\t\t\t\tsize={ {\n\t\t\t\t\twidth: currentWidth ?? 'auto',\n\t\t\t\t\theight: currentHeight ?? 'auto',\n\t\t\t\t} }\n\t\t\t\tshowHandle={ isSelected }\n\t\t\t\tminWidth={ minWidth }\n\t\t\t\tmaxWidth={ maxWidthBuffer }\n\t\t\t\tminHeight={ minHeight }\n\t\t\t\tmaxHeight={ maxWidthBuffer / ratio }\n\t\t\t\tlockAspectRatio={ ratio }\n\t\t\t\tenable={ {\n\t\t\t\t\ttop: false,\n\t\t\t\t\tright: showRightHandle,\n\t\t\t\t\tbottom: true,\n\t\t\t\t\tleft: showLeftHandle,\n\t\t\t\t} }\n\t\t\t\tonResizeStart={ onResizeStart }\n\t\t\t\tonResizeStop={ ( event, direction, elt ) => {\n\t\t\t\t\tonResizeStop();\n\t\t\t\t\t// Since the aspect ratio is locked when resizing, we can\n\t\t\t\t\t// use the width of the resized element to calculate the\n\t\t\t\t\t// height in CSS to prevent stretching when the max-width\n\t\t\t\t\t// is reached.\n\t\t\t\t\tsetAttributes( {\n\t\t\t\t\t\twidth: `${ elt.offsetWidth }px`,\n\t\t\t\t\t\theight: 'auto',\n\t\t\t\t\t\taspectRatio:\n\t\t\t\t\t\t\tratio === naturalRatio\n\t\t\t\t\t\t\t\t? undefined\n\t\t\t\t\t\t\t\t: String( ratio ),\n\t\t\t\t\t} );\n\t\t\t\t} }\n\t\t\t\tresizeRatio={ align === 'center' ? 2 : 1 }\n\t\t\t>\n\t\t\t\t{ img }\n\t\t\t</ResizableBox>\n\t\t);\n\t}\n\n\tif ( ! url && ! temporaryURL ) {\n\t\treturn sizeControls;\n\t}\n\n\treturn (\n\t\t<>\n\t\t\t{ /* Hide controls during upload to avoid component remount,\n\t\t\t\twhich causes duplicated image upload. */ }\n\t\t\t{ ! temporaryURL && controls }\n\t\t\t{ img }\n\t\t\t{ showCaption &&\n\t\t\t\t( ! RichText.isEmpty( caption ) || isSelected ) && (\n\t\t\t\t\t<RichText\n\t\t\t\t\t\tidentifier=\"caption\"\n\t\t\t\t\t\tclassName={ __experimentalGetElementClassName(\n\t\t\t\t\t\t\t'caption'\n\t\t\t\t\t\t) }\n\t\t\t\t\t\tref={ captionRef }\n\t\t\t\t\t\ttagName=\"figcaption\"\n\t\t\t\t\t\taria-label={ __( 'Image caption text' ) }\n\t\t\t\t\t\tplaceholder={ __( 'Add caption' ) }\n\t\t\t\t\t\tvalue={ caption }\n\t\t\t\t\t\tonChange={ ( value ) =>\n\t\t\t\t\t\t\tsetAttributes( { caption: value } )\n\t\t\t\t\t\t}\n\t\t\t\t\t\tinlineToolbar\n\t\t\t\t\t\t__unstableOnSplitAtEnd={ () =>\n\t\t\t\t\t\t\tinsertBlocksAfter(\n\t\t\t\t\t\t\t\tcreateBlock( getDefaultBlockName() )\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) }\n\t\t</>\n\t);\n}\n"],"mappings":"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"}
1
+ {"version":3,"names":["_element","require","_blob","_components","_compose","_data","_blockEditor","_i18n","_url","_blocks","_icons","_notices","_coreData","_lockUnlock","_util","_useClientWidth","_interopRequireDefault","_edit","_constants","_utils","DimensionsTool","ResolutionTool","unlock","blockEditorPrivateApis","scaleOptions","value","label","_x","help","__","Image","temporaryURL","attributes","setAttributes","isSelected","insertBlocksAfter","onReplace","onSelectImage","onSelectURL","onUploadError","containerRef","context","clientId","blockEditingMode","url","alt","caption","align","id","href","rel","linkClass","linkDestination","title","width","height","aspectRatio","scale","linkTarget","sizeSlug","lightbox","numericWidth","parseInt","undefined","numericHeight","imageRef","useRef","prevCaption","usePrevious","showCaption","setShowCaption","useState","allowResize","getBlock","useSelect","blockEditorStore","image","multiImageSelection","select","getMedia","coreStore","getMultiSelectedBlockClientIds","getBlockName","multiSelectedClientIds","length","every","_clientId","canInsertCover","imageEditing","imageSizes","maxWidth","mediaUpload","getBlockRootClientId","getSettings","canInsertBlockType","rootClientId","settings","replaceBlocks","toggleSelection","useDispatch","createErrorNotice","createSuccessNotice","noticesStore","isLargeViewport","useViewportMatch","isWideAligned","includes","loadedNaturalWidth","loadedNaturalHeight","setLoadedNaturalSize","isEditingImage","setIsEditingImage","externalBlob","setExternalBlob","clientWidth","useClientWidth","hasNonContentControls","isResizable","imageSizeOptions","filter","slug","media_details","sizes","source_url","map","name","canUploadMedia","useEffect","isExternalImage","window","fetch","then","response","blob","catch","captionRef","useCallback","node","focus","naturalWidth","naturalHeight","useMemo","current","complete","onResizeStart","onResizeStop","onImageError","embedBlock","createUpgradedEmbedBlock","onSetHref","props","onSetTitle","updateAlt","newAlt","updateImage","newSizeSlug","newUrl","uploadExternal","filesList","onFileChange","img","isBlobURL","type","allowedTypes","ALLOWED_MEDIA_TYPES","onError","message","updateAlignment","nextAlign","extraUpdatedAttributes","canEditImage","allowCrop","switchToCover","switchToBlockType","dimensionsUnitsOptions","useCustomUnits","availableUnits","lightboxSetting","useSetting","showLightboxToggle","allowEditing","lightboxChecked","enabled","dimensionsControl","createElement","onChange","newWidth","newHeight","newScale","newAspectRatio","defaultScale","defaultAspectRatio","unitsOptions","resetAll","sizeControls","InspectorControls","__experimentalToolsPanel","controls","Fragment","BlockControls","group","BlockAlignmentControl","ToolbarButton","onClick","icon","captionIcon","isPressed","__experimentalImageURLInputUI","onChangeUrl","mediaUrl","mediaLink","link","crop","overlayText","MediaReplaceFlow","mediaId","mediaURL","accept","onSelect","ToolbarGroup","upload","__experimentalToolsPanelItem","isShownByDefault","hasValue","onDeselect","TextareaControl","ExternalLink","__nextHasNoMarginBottom","options","ToggleControl","checked","newValue","TextControl","filename","getFilename","defaultedAlt","sprintf","borderProps","useBorderProps","isRounded","className","src","onLoad","event","target","ref","style","objectFit","Spinner","fallbackClientWidth","__experimentalImageEditor","onSaveImage","imageAttributes","onFinishEditing","numericRatio","evalAspectRatio","customRatio","naturalRatio","ratio","currentWidth","currentHeight","minWidth","MIN_SIZE","minHeight","maxWidthBuffer","showRightHandle","showLeftHandle","isRTL","ResizableBox","display","size","showHandle","maxHeight","lockAspectRatio","enable","top","right","bottom","left","direction","elt","offsetWidth","String","resizeRatio","RichText","isEmpty","identifier","__experimentalGetElementClassName","tagName","placeholder","inlineToolbar","__unstableOnSplitAtEnd","createBlock","getDefaultBlockName"],"sources":["@wordpress/block-library/src/image/image.js"],"sourcesContent":["/**\n * WordPress dependencies\n */\nimport { isBlobURL } from '@wordpress/blob';\nimport {\n\tExternalLink,\n\tResizableBox,\n\tSpinner,\n\tTextareaControl,\n\tToggleControl,\n\tTextControl,\n\tToolbarButton,\n\tToolbarGroup,\n\t__experimentalToolsPanel as ToolsPanel,\n\t__experimentalToolsPanelItem as ToolsPanelItem,\n\t__experimentalUseCustomUnits as useCustomUnits,\n} from '@wordpress/components';\nimport { useViewportMatch, usePrevious } from '@wordpress/compose';\nimport { useSelect, useDispatch } from '@wordpress/data';\nimport {\n\tBlockControls,\n\tInspectorControls,\n\tRichText,\n\t__experimentalImageURLInputUI as ImageURLInputUI,\n\tMediaReplaceFlow,\n\tstore as blockEditorStore,\n\tuseSetting,\n\tBlockAlignmentControl,\n\t__experimentalImageEditor as ImageEditor,\n\t__experimentalGetElementClassName,\n\t__experimentalUseBorderProps as useBorderProps,\n\tprivateApis as blockEditorPrivateApis,\n} from '@wordpress/block-editor';\nimport {\n\tuseEffect,\n\tuseMemo,\n\tuseState,\n\tuseRef,\n\tuseCallback,\n} from '@wordpress/element';\nimport { __, _x, sprintf, isRTL } from '@wordpress/i18n';\nimport { getFilename } from '@wordpress/url';\nimport {\n\tcreateBlock,\n\tgetDefaultBlockName,\n\tswitchToBlockType,\n} from '@wordpress/blocks';\nimport {\n\tcrop,\n\toverlayText,\n\tupload,\n\tcaption as captionIcon,\n} from '@wordpress/icons';\nimport { store as noticesStore } from '@wordpress/notices';\nimport { store as coreStore } from '@wordpress/core-data';\n\n/**\n * Internal dependencies\n */\nimport { unlock } from '../lock-unlock';\nimport { createUpgradedEmbedBlock } from '../embed/util';\nimport useClientWidth from './use-client-width';\nimport { isExternalImage } from './edit';\n\n/**\n * Module constants\n */\nimport { MIN_SIZE, ALLOWED_MEDIA_TYPES } from './constants';\nimport { evalAspectRatio } from './utils';\n\nconst { DimensionsTool, ResolutionTool } = unlock( blockEditorPrivateApis );\n\nconst scaleOptions = [\n\t{\n\t\tvalue: 'cover',\n\t\tlabel: _x( 'Cover', 'Scale option for dimensions control' ),\n\t\thelp: __( 'Image covers the space evenly.' ),\n\t},\n\t{\n\t\tvalue: 'contain',\n\t\tlabel: _x( 'Contain', 'Scale option for dimensions control' ),\n\t\thelp: __( 'Image is contained without distortion.' ),\n\t},\n];\n\nexport default function Image( {\n\ttemporaryURL,\n\tattributes,\n\tsetAttributes,\n\tisSelected,\n\tinsertBlocksAfter,\n\tonReplace,\n\tonSelectImage,\n\tonSelectURL,\n\tonUploadError,\n\tcontainerRef,\n\tcontext,\n\tclientId,\n\tblockEditingMode,\n} ) {\n\tconst {\n\t\turl = '',\n\t\talt,\n\t\tcaption,\n\t\talign,\n\t\tid,\n\t\thref,\n\t\trel,\n\t\tlinkClass,\n\t\tlinkDestination,\n\t\ttitle,\n\t\twidth,\n\t\theight,\n\t\taspectRatio,\n\t\tscale,\n\t\tlinkTarget,\n\t\tsizeSlug,\n\t\tlightbox,\n\t} = attributes;\n\n\t// The only supported unit is px, so we can parseInt to strip the px here.\n\tconst numericWidth = width ? parseInt( width, 10 ) : undefined;\n\tconst numericHeight = height ? parseInt( height, 10 ) : undefined;\n\n\tconst imageRef = useRef();\n\tconst prevCaption = usePrevious( caption );\n\tconst [ showCaption, setShowCaption ] = useState( !! caption );\n\tconst { allowResize = true } = context;\n\tconst { getBlock } = useSelect( blockEditorStore );\n\n\tconst { image, multiImageSelection } = useSelect(\n\t\t( select ) => {\n\t\t\tconst { getMedia } = select( coreStore );\n\t\t\tconst { getMultiSelectedBlockClientIds, getBlockName } =\n\t\t\t\tselect( blockEditorStore );\n\t\t\tconst multiSelectedClientIds = getMultiSelectedBlockClientIds();\n\t\t\treturn {\n\t\t\t\timage:\n\t\t\t\t\tid && isSelected\n\t\t\t\t\t\t? getMedia( id, { context: 'view' } )\n\t\t\t\t\t\t: null,\n\t\t\t\tmultiImageSelection:\n\t\t\t\t\tmultiSelectedClientIds.length &&\n\t\t\t\t\tmultiSelectedClientIds.every(\n\t\t\t\t\t\t( _clientId ) =>\n\t\t\t\t\t\t\tgetBlockName( _clientId ) === 'core/image'\n\t\t\t\t\t),\n\t\t\t};\n\t\t},\n\t\t[ id, isSelected ]\n\t);\n\tconst { canInsertCover, imageEditing, imageSizes, maxWidth, mediaUpload } =\n\t\tuseSelect(\n\t\t\t( select ) => {\n\t\t\t\tconst {\n\t\t\t\t\tgetBlockRootClientId,\n\t\t\t\t\tgetSettings,\n\t\t\t\t\tcanInsertBlockType,\n\t\t\t\t} = select( blockEditorStore );\n\n\t\t\t\tconst rootClientId = getBlockRootClientId( clientId );\n\t\t\t\tconst settings = getSettings();\n\n\t\t\t\treturn {\n\t\t\t\t\timageEditing: settings.imageEditing,\n\t\t\t\t\timageSizes: settings.imageSizes,\n\t\t\t\t\tmaxWidth: settings.maxWidth,\n\t\t\t\t\tmediaUpload: settings.mediaUpload,\n\t\t\t\t\tcanInsertCover: canInsertBlockType(\n\t\t\t\t\t\t'core/cover',\n\t\t\t\t\t\trootClientId\n\t\t\t\t\t),\n\t\t\t\t};\n\t\t\t},\n\t\t\t[ clientId ]\n\t\t);\n\n\tconst { replaceBlocks, toggleSelection } = useDispatch( blockEditorStore );\n\tconst { createErrorNotice, createSuccessNotice } =\n\t\tuseDispatch( noticesStore );\n\tconst isLargeViewport = useViewportMatch( 'medium' );\n\tconst isWideAligned = [ 'wide', 'full' ].includes( align );\n\tconst [\n\t\t{ loadedNaturalWidth, loadedNaturalHeight },\n\t\tsetLoadedNaturalSize,\n\t] = useState( {} );\n\tconst [ isEditingImage, setIsEditingImage ] = useState( false );\n\tconst [ externalBlob, setExternalBlob ] = useState();\n\tconst clientWidth = useClientWidth( containerRef, [ align ] );\n\tconst hasNonContentControls = blockEditingMode === 'default';\n\tconst isResizable =\n\t\tallowResize &&\n\t\thasNonContentControls &&\n\t\t! ( isWideAligned && isLargeViewport );\n\tconst imageSizeOptions = imageSizes\n\t\t.filter(\n\t\t\t( { slug } ) => image?.media_details?.sizes?.[ slug ]?.source_url\n\t\t)\n\t\t.map( ( { name, slug } ) => ( { value: slug, label: name } ) );\n\tconst canUploadMedia = !! mediaUpload;\n\n\t// If an image is externally hosted, try to fetch the image data. This may\n\t// fail if the image host doesn't allow CORS with the domain. If it works,\n\t// we can enable a button in the toolbar to upload the image.\n\tuseEffect( () => {\n\t\tif (\n\t\t\t! isExternalImage( id, url ) ||\n\t\t\t! isSelected ||\n\t\t\t! canUploadMedia\n\t\t) {\n\t\t\tsetExternalBlob();\n\t\t\treturn;\n\t\t}\n\n\t\tif ( externalBlob ) return;\n\n\t\twindow\n\t\t\t// Avoid cache, which seems to help avoid CORS problems.\n\t\t\t.fetch( url.includes( '?' ) ? url : url + '?' )\n\t\t\t.then( ( response ) => response.blob() )\n\t\t\t.then( ( blob ) => setExternalBlob( blob ) )\n\t\t\t// Do nothing, cannot upload.\n\t\t\t.catch( () => {} );\n\t}, [ id, url, isSelected, externalBlob, canUploadMedia ] );\n\n\t// We need to show the caption when changes come from\n\t// history navigation(undo/redo).\n\tuseEffect( () => {\n\t\tif ( caption && ! prevCaption ) {\n\t\t\tsetShowCaption( true );\n\t\t}\n\t}, [ caption, prevCaption ] );\n\n\t// Focus the caption when we click to add one.\n\tconst captionRef = useCallback(\n\t\t( node ) => {\n\t\t\tif ( node && ! caption ) {\n\t\t\t\tnode.focus();\n\t\t\t}\n\t\t},\n\t\t[ caption ]\n\t);\n\n\t// Get naturalWidth and naturalHeight from image ref, and fall back to loaded natural\n\t// width and height. This resolves an issue in Safari where the loaded natural\n\t// width and height is otherwise lost when switching between alignments.\n\t// See: https://github.com/WordPress/gutenberg/pull/37210.\n\tconst { naturalWidth, naturalHeight } = useMemo( () => {\n\t\treturn {\n\t\t\tnaturalWidth:\n\t\t\t\timageRef.current?.naturalWidth ||\n\t\t\t\tloadedNaturalWidth ||\n\t\t\t\tundefined,\n\t\t\tnaturalHeight:\n\t\t\t\timageRef.current?.naturalHeight ||\n\t\t\t\tloadedNaturalHeight ||\n\t\t\t\tundefined,\n\t\t};\n\t}, [\n\t\tloadedNaturalWidth,\n\t\tloadedNaturalHeight,\n\t\timageRef.current?.complete,\n\t] );\n\n\tfunction onResizeStart() {\n\t\ttoggleSelection( false );\n\t}\n\n\tfunction onResizeStop() {\n\t\ttoggleSelection( true );\n\t}\n\n\tfunction onImageError() {\n\t\t// Check if there's an embed block that handles this URL, e.g., instagram URL.\n\t\t// See: https://github.com/WordPress/gutenberg/pull/11472\n\t\tconst embedBlock = createUpgradedEmbedBlock( { attributes: { url } } );\n\n\t\tif ( undefined !== embedBlock ) {\n\t\t\tonReplace( embedBlock );\n\t\t}\n\t}\n\n\tfunction onSetHref( props ) {\n\t\tsetAttributes( props );\n\t}\n\n\tfunction onSetTitle( value ) {\n\t\t// This is the HTML title attribute, separate from the media object\n\t\t// title.\n\t\tsetAttributes( { title: value } );\n\t}\n\n\tfunction updateAlt( newAlt ) {\n\t\tsetAttributes( { alt: newAlt } );\n\t}\n\n\tfunction updateImage( newSizeSlug ) {\n\t\tconst newUrl = image?.media_details?.sizes?.[ newSizeSlug ]?.source_url;\n\t\tif ( ! newUrl ) {\n\t\t\treturn null;\n\t\t}\n\n\t\tsetAttributes( {\n\t\t\turl: newUrl,\n\t\t\tsizeSlug: newSizeSlug,\n\t\t} );\n\t}\n\n\tfunction uploadExternal() {\n\t\tmediaUpload( {\n\t\t\tfilesList: [ externalBlob ],\n\t\t\tonFileChange( [ img ] ) {\n\t\t\t\tonSelectImage( img );\n\n\t\t\t\tif ( isBlobURL( img.url ) ) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tsetExternalBlob();\n\t\t\t\tcreateSuccessNotice( __( 'Image uploaded.' ), {\n\t\t\t\t\ttype: 'snackbar',\n\t\t\t\t} );\n\t\t\t},\n\t\t\tallowedTypes: ALLOWED_MEDIA_TYPES,\n\t\t\tonError( message ) {\n\t\t\t\tcreateErrorNotice( message, { type: 'snackbar' } );\n\t\t\t},\n\t\t} );\n\t}\n\n\tfunction updateAlignment( nextAlign ) {\n\t\tconst extraUpdatedAttributes = [ 'wide', 'full' ].includes( nextAlign )\n\t\t\t? {\n\t\t\t\t\twidth: undefined,\n\t\t\t\t\theight: undefined,\n\t\t\t\t\taspectRatio: undefined,\n\t\t\t\t\tscale: undefined,\n\t\t\t }\n\t\t\t: {};\n\t\tsetAttributes( {\n\t\t\t...extraUpdatedAttributes,\n\t\t\talign: nextAlign,\n\t\t} );\n\t}\n\n\tuseEffect( () => {\n\t\tif ( ! isSelected ) {\n\t\t\tsetIsEditingImage( false );\n\t\t\tif ( ! caption ) {\n\t\t\t\tsetShowCaption( false );\n\t\t\t}\n\t\t}\n\t}, [ isSelected, caption ] );\n\n\tconst canEditImage = id && naturalWidth && naturalHeight && imageEditing;\n\tconst allowCrop = ! multiImageSelection && canEditImage && ! isEditingImage;\n\n\tfunction switchToCover() {\n\t\treplaceBlocks(\n\t\t\tclientId,\n\t\t\tswitchToBlockType( getBlock( clientId ), 'core/cover' )\n\t\t);\n\t}\n\n\t// TODO: Can allow more units after figuring out how they should interact\n\t// with the ResizableBox and ImageEditor components. Calculations later on\n\t// for those components are currently assuming px units.\n\tconst dimensionsUnitsOptions = useCustomUnits( {\n\t\tavailableUnits: [ 'px' ],\n\t} );\n\n\tconst lightboxSetting = useSetting( 'lightbox' );\n\n\tconst showLightboxToggle =\n\t\t!! lightbox || lightboxSetting?.allowEditing === true;\n\n\tconst lightboxChecked =\n\t\t!! lightbox?.enabled || ( ! lightbox && !! lightboxSetting?.enabled );\n\n\tconst dimensionsControl = (\n\t\t<DimensionsTool\n\t\t\tvalue={ { width, height, scale, aspectRatio } }\n\t\t\tonChange={ ( {\n\t\t\t\twidth: newWidth,\n\t\t\t\theight: newHeight,\n\t\t\t\tscale: newScale,\n\t\t\t\taspectRatio: newAspectRatio,\n\t\t\t} ) => {\n\t\t\t\t// Rebuilding the object forces setting `undefined`\n\t\t\t\t// for values that are removed since setAttributes\n\t\t\t\t// doesn't do anything with keys that aren't set.\n\t\t\t\tsetAttributes( {\n\t\t\t\t\t// CSS includes `height: auto`, but we need\n\t\t\t\t\t// `width: auto` to fix the aspect ratio when\n\t\t\t\t\t// only height is set due to the width and\n\t\t\t\t\t// height attributes set via the server.\n\t\t\t\t\twidth: ! newWidth && newHeight ? 'auto' : newWidth,\n\t\t\t\t\theight: newHeight,\n\t\t\t\t\tscale: newScale,\n\t\t\t\t\taspectRatio: newAspectRatio,\n\t\t\t\t} );\n\t\t\t} }\n\t\t\tdefaultScale=\"cover\"\n\t\t\tdefaultAspectRatio=\"auto\"\n\t\t\tscaleOptions={ scaleOptions }\n\t\t\tunitsOptions={ dimensionsUnitsOptions }\n\t\t/>\n\t);\n\n\tconst resetAll = () => {\n\t\tsetAttributes( {\n\t\t\twidth: undefined,\n\t\t\theight: undefined,\n\t\t\tscale: undefined,\n\t\t\taspectRatio: undefined,\n\t\t\tlightbox: undefined,\n\t\t} );\n\t};\n\n\tconst sizeControls = (\n\t\t<InspectorControls>\n\t\t\t<ToolsPanel label={ __( 'Settings' ) } resetAll={ resetAll }>\n\t\t\t\t{ isResizable && dimensionsControl }\n\t\t\t</ToolsPanel>\n\t\t</InspectorControls>\n\t);\n\n\tconst controls = (\n\t\t<>\n\t\t\t<BlockControls group=\"block\">\n\t\t\t\t{ hasNonContentControls && (\n\t\t\t\t\t<BlockAlignmentControl\n\t\t\t\t\t\tvalue={ align }\n\t\t\t\t\t\tonChange={ updateAlignment }\n\t\t\t\t\t/>\n\t\t\t\t) }\n\t\t\t\t{ hasNonContentControls && (\n\t\t\t\t\t<ToolbarButton\n\t\t\t\t\t\tonClick={ () => {\n\t\t\t\t\t\t\tsetShowCaption( ! showCaption );\n\t\t\t\t\t\t\tif ( showCaption && caption ) {\n\t\t\t\t\t\t\t\tsetAttributes( { caption: undefined } );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} }\n\t\t\t\t\t\ticon={ captionIcon }\n\t\t\t\t\t\tisPressed={ showCaption }\n\t\t\t\t\t\tlabel={\n\t\t\t\t\t\t\tshowCaption\n\t\t\t\t\t\t\t\t? __( 'Remove caption' )\n\t\t\t\t\t\t\t\t: __( 'Add caption' )\n\t\t\t\t\t\t}\n\t\t\t\t\t/>\n\t\t\t\t) }\n\t\t\t\t{ ! multiImageSelection && ! isEditingImage && (\n\t\t\t\t\t<ImageURLInputUI\n\t\t\t\t\t\turl={ href || '' }\n\t\t\t\t\t\tonChangeUrl={ onSetHref }\n\t\t\t\t\t\tlinkDestination={ linkDestination }\n\t\t\t\t\t\tmediaUrl={ ( image && image.source_url ) || url }\n\t\t\t\t\t\tmediaLink={ image && image.link }\n\t\t\t\t\t\tlinkTarget={ linkTarget }\n\t\t\t\t\t\tlinkClass={ linkClass }\n\t\t\t\t\t\trel={ rel }\n\t\t\t\t\t/>\n\t\t\t\t) }\n\t\t\t\t{ allowCrop && (\n\t\t\t\t\t<ToolbarButton\n\t\t\t\t\t\tonClick={ () => setIsEditingImage( true ) }\n\t\t\t\t\t\ticon={ crop }\n\t\t\t\t\t\tlabel={ __( 'Crop' ) }\n\t\t\t\t\t/>\n\t\t\t\t) }\n\t\t\t\t{ ! multiImageSelection && canInsertCover && (\n\t\t\t\t\t<ToolbarButton\n\t\t\t\t\t\ticon={ overlayText }\n\t\t\t\t\t\tlabel={ __( 'Add text over image' ) }\n\t\t\t\t\t\tonClick={ switchToCover }\n\t\t\t\t\t/>\n\t\t\t\t) }\n\t\t\t</BlockControls>\n\t\t\t{ ! multiImageSelection && ! isEditingImage && (\n\t\t\t\t<BlockControls group=\"other\">\n\t\t\t\t\t<MediaReplaceFlow\n\t\t\t\t\t\tmediaId={ id }\n\t\t\t\t\t\tmediaURL={ url }\n\t\t\t\t\t\tallowedTypes={ ALLOWED_MEDIA_TYPES }\n\t\t\t\t\t\taccept=\"image/*\"\n\t\t\t\t\t\tonSelect={ onSelectImage }\n\t\t\t\t\t\tonSelectURL={ onSelectURL }\n\t\t\t\t\t\tonError={ onUploadError }\n\t\t\t\t\t/>\n\t\t\t\t</BlockControls>\n\t\t\t) }\n\t\t\t{ ! multiImageSelection && externalBlob && (\n\t\t\t\t<BlockControls>\n\t\t\t\t\t<ToolbarGroup>\n\t\t\t\t\t\t<ToolbarButton\n\t\t\t\t\t\t\tonClick={ uploadExternal }\n\t\t\t\t\t\t\ticon={ upload }\n\t\t\t\t\t\t\tlabel={ __( 'Upload external image' ) }\n\t\t\t\t\t\t/>\n\t\t\t\t\t</ToolbarGroup>\n\t\t\t\t</BlockControls>\n\t\t\t) }\n\t\t\t<InspectorControls>\n\t\t\t\t<ToolsPanel label={ __( 'Settings' ) } resetAll={ resetAll }>\n\t\t\t\t\t{ ! multiImageSelection && (\n\t\t\t\t\t\t<ToolsPanelItem\n\t\t\t\t\t\t\tlabel={ __( 'Alternative text' ) }\n\t\t\t\t\t\t\tisShownByDefault={ true }\n\t\t\t\t\t\t\thasValue={ () => alt !== '' }\n\t\t\t\t\t\t\tonDeselect={ () =>\n\t\t\t\t\t\t\t\tsetAttributes( { alt: undefined } )\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<TextareaControl\n\t\t\t\t\t\t\t\tlabel={ __( 'Alternative text' ) }\n\t\t\t\t\t\t\t\tvalue={ alt }\n\t\t\t\t\t\t\t\tonChange={ updateAlt }\n\t\t\t\t\t\t\t\thelp={\n\t\t\t\t\t\t\t\t\t<>\n\t\t\t\t\t\t\t\t\t\t<ExternalLink href=\"https://www.w3.org/WAI/tutorials/images/decision-tree\">\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'Describe the purpose of the image.'\n\t\t\t\t\t\t\t\t\t\t\t) }\n\t\t\t\t\t\t\t\t\t\t</ExternalLink>\n\t\t\t\t\t\t\t\t\t\t<br />\n\t\t\t\t\t\t\t\t\t\t{ __( 'Leave empty if decorative.' ) }\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__nextHasNoMarginBottom\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t</ToolsPanelItem>\n\t\t\t\t\t) }\n\t\t\t\t\t{ isResizable && dimensionsControl }\n\t\t\t\t\t<ResolutionTool\n\t\t\t\t\t\tvalue={ sizeSlug }\n\t\t\t\t\t\tonChange={ updateImage }\n\t\t\t\t\t\toptions={ imageSizeOptions }\n\t\t\t\t\t/>\n\t\t\t\t\t{ showLightboxToggle && (\n\t\t\t\t\t\t<ToolsPanelItem\n\t\t\t\t\t\t\thasValue={ () => !! lightbox }\n\t\t\t\t\t\t\tlabel={ __( 'Expand on Click' ) }\n\t\t\t\t\t\t\tonDeselect={ () => {\n\t\t\t\t\t\t\t\tsetAttributes( { lightbox: undefined } );\n\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t\tisShownByDefault={ true }\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t<ToggleControl\n\t\t\t\t\t\t\t\tlabel={ __( 'Expand on Click' ) }\n\t\t\t\t\t\t\t\tchecked={ lightboxChecked }\n\t\t\t\t\t\t\t\tonChange={ ( newValue ) => {\n\t\t\t\t\t\t\t\t\tsetAttributes( {\n\t\t\t\t\t\t\t\t\t\tlightbox: { enabled: newValue },\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</ToolsPanelItem>\n\t\t\t\t\t) }\n\t\t\t\t</ToolsPanel>\n\t\t\t</InspectorControls>\n\t\t\t<InspectorControls group=\"advanced\">\n\t\t\t\t<TextControl\n\t\t\t\t\t__nextHasNoMarginBottom\n\t\t\t\t\tlabel={ __( 'Title attribute' ) }\n\t\t\t\t\tvalue={ title || '' }\n\t\t\t\t\tonChange={ onSetTitle }\n\t\t\t\t\thelp={\n\t\t\t\t\t\t<>\n\t\t\t\t\t\t\t{ __(\n\t\t\t\t\t\t\t\t'Describe the role of this image on the page.'\n\t\t\t\t\t\t\t) }\n\t\t\t\t\t\t\t<ExternalLink href=\"https://www.w3.org/TR/html52/dom.html#the-title-attribute\">\n\t\t\t\t\t\t\t\t{ __(\n\t\t\t\t\t\t\t\t\t'(Note: many devices and browsers do not display this text.)'\n\t\t\t\t\t\t\t\t) }\n\t\t\t\t\t\t\t</ExternalLink>\n\t\t\t\t\t\t</>\n\t\t\t\t\t}\n\t\t\t\t/>\n\t\t\t</InspectorControls>\n\t\t</>\n\t);\n\n\tconst filename = getFilename( url );\n\tlet defaultedAlt;\n\n\tif ( alt ) {\n\t\tdefaultedAlt = alt;\n\t} else if ( filename ) {\n\t\tdefaultedAlt = sprintf(\n\t\t\t/* translators: %s: file name */\n\t\t\t__( 'This image has an empty alt attribute; its file name is %s' ),\n\t\t\tfilename\n\t\t);\n\t} else {\n\t\tdefaultedAlt = __( 'This image has an empty alt attribute' );\n\t}\n\n\tconst borderProps = useBorderProps( attributes );\n\tconst isRounded = attributes.className?.includes( 'is-style-rounded' );\n\n\tlet img = (\n\t\t// Disable reason: Image itself is not meant to be interactive, but\n\t\t// should direct focus to block.\n\t\t/* eslint-disable jsx-a11y/no-noninteractive-element-interactions, jsx-a11y/click-events-have-key-events */\n\t\t<>\n\t\t\t<img\n\t\t\t\tsrc={ temporaryURL || url }\n\t\t\t\talt={ defaultedAlt }\n\t\t\t\tonError={ () => onImageError() }\n\t\t\t\tonLoad={ ( event ) => {\n\t\t\t\t\tsetLoadedNaturalSize( {\n\t\t\t\t\t\tloadedNaturalWidth: event.target?.naturalWidth,\n\t\t\t\t\t\tloadedNaturalHeight: event.target?.naturalHeight,\n\t\t\t\t\t} );\n\t\t\t\t} }\n\t\t\t\tref={ imageRef }\n\t\t\t\tclassName={ borderProps.className }\n\t\t\t\tstyle={ {\n\t\t\t\t\twidth:\n\t\t\t\t\t\t( width && height ) || aspectRatio ? '100%' : undefined,\n\t\t\t\t\theight:\n\t\t\t\t\t\t( width && height ) || aspectRatio ? '100%' : undefined,\n\t\t\t\t\tobjectFit: scale,\n\t\t\t\t\t...borderProps.style,\n\t\t\t\t} }\n\t\t\t/>\n\t\t\t{ temporaryURL && <Spinner /> }\n\t\t</>\n\t\t/* eslint-enable jsx-a11y/no-noninteractive-element-interactions, jsx-a11y/click-events-have-key-events */\n\t);\n\n\t// clientWidth needs to be a number for the image Cropper to work, but sometimes it's 0\n\t// So we try using the imageRef width first and fallback to clientWidth.\n\tconst fallbackClientWidth = imageRef.current?.width || clientWidth;\n\n\tif ( canEditImage && isEditingImage ) {\n\t\timg = (\n\t\t\t<ImageEditor\n\t\t\t\tid={ id }\n\t\t\t\turl={ url }\n\t\t\t\twidth={ numericWidth }\n\t\t\t\theight={ numericHeight }\n\t\t\t\tclientWidth={ fallbackClientWidth }\n\t\t\t\tnaturalHeight={ naturalHeight }\n\t\t\t\tnaturalWidth={ naturalWidth }\n\t\t\t\tonSaveImage={ ( imageAttributes ) =>\n\t\t\t\t\tsetAttributes( imageAttributes )\n\t\t\t\t}\n\t\t\t\tonFinishEditing={ () => {\n\t\t\t\t\tsetIsEditingImage( false );\n\t\t\t\t} }\n\t\t\t\tborderProps={ isRounded ? undefined : borderProps }\n\t\t\t/>\n\t\t);\n\t} else if ( ! isResizable ) {\n\t\timg = <div style={ { width, height, aspectRatio } }>{ img }</div>;\n\t} else {\n\t\tconst numericRatio = aspectRatio && evalAspectRatio( aspectRatio );\n\t\tconst customRatio = numericWidth / numericHeight;\n\t\tconst naturalRatio = naturalWidth / naturalHeight;\n\t\tconst ratio = numericRatio || customRatio || naturalRatio || 1;\n\t\tconst currentWidth =\n\t\t\t! numericWidth && numericHeight\n\t\t\t\t? numericHeight * ratio\n\t\t\t\t: numericWidth;\n\t\tconst currentHeight =\n\t\t\t! numericHeight && numericWidth\n\t\t\t\t? numericWidth / ratio\n\t\t\t\t: numericHeight;\n\n\t\tconst minWidth =\n\t\t\tnaturalWidth < naturalHeight ? MIN_SIZE : MIN_SIZE * ratio;\n\t\tconst minHeight =\n\t\t\tnaturalHeight < naturalWidth ? MIN_SIZE : MIN_SIZE / ratio;\n\n\t\t// With the current implementation of ResizableBox, an image needs an\n\t\t// explicit pixel value for the max-width. In absence of being able to\n\t\t// set the content-width, this max-width is currently dictated by the\n\t\t// vanilla editor style. The following variable adds a buffer to this\n\t\t// vanilla style, so 3rd party themes have some wiggleroom. This does,\n\t\t// in most cases, allow you to scale the image beyond the width of the\n\t\t// main column, though not infinitely.\n\t\t// @todo It would be good to revisit this once a content-width variable\n\t\t// becomes available.\n\t\tconst maxWidthBuffer = maxWidth * 2.5;\n\n\t\tlet showRightHandle = false;\n\t\tlet showLeftHandle = false;\n\n\t\t/* eslint-disable no-lonely-if */\n\t\t// See https://github.com/WordPress/gutenberg/issues/7584.\n\t\tif ( align === 'center' ) {\n\t\t\t// When the image is centered, show both handles.\n\t\t\tshowRightHandle = true;\n\t\t\tshowLeftHandle = true;\n\t\t} else if ( isRTL() ) {\n\t\t\t// In RTL mode the image is on the right by default.\n\t\t\t// Show the right handle and hide the left handle only when it is\n\t\t\t// aligned left. Otherwise always show the left handle.\n\t\t\tif ( align === 'left' ) {\n\t\t\t\tshowRightHandle = true;\n\t\t\t} else {\n\t\t\t\tshowLeftHandle = true;\n\t\t\t}\n\t\t} else {\n\t\t\t// Show the left handle and hide the right handle only when the\n\t\t\t// image is aligned right. Otherwise always show the right handle.\n\t\t\tif ( align === 'right' ) {\n\t\t\t\tshowLeftHandle = true;\n\t\t\t} else {\n\t\t\t\tshowRightHandle = true;\n\t\t\t}\n\t\t}\n\t\t/* eslint-enable no-lonely-if */\n\n\t\timg = (\n\t\t\t<ResizableBox\n\t\t\t\tstyle={ {\n\t\t\t\t\tdisplay: 'block',\n\t\t\t\t\tobjectFit: scale,\n\t\t\t\t\taspectRatio:\n\t\t\t\t\t\t! width && ! height && aspectRatio\n\t\t\t\t\t\t\t? aspectRatio\n\t\t\t\t\t\t\t: undefined,\n\t\t\t\t} }\n\t\t\t\tsize={ {\n\t\t\t\t\twidth: currentWidth ?? 'auto',\n\t\t\t\t\theight: currentHeight ?? 'auto',\n\t\t\t\t} }\n\t\t\t\tshowHandle={ isSelected }\n\t\t\t\tminWidth={ minWidth }\n\t\t\t\tmaxWidth={ maxWidthBuffer }\n\t\t\t\tminHeight={ minHeight }\n\t\t\t\tmaxHeight={ maxWidthBuffer / ratio }\n\t\t\t\tlockAspectRatio={ ratio }\n\t\t\t\tenable={ {\n\t\t\t\t\ttop: false,\n\t\t\t\t\tright: showRightHandle,\n\t\t\t\t\tbottom: true,\n\t\t\t\t\tleft: showLeftHandle,\n\t\t\t\t} }\n\t\t\t\tonResizeStart={ onResizeStart }\n\t\t\t\tonResizeStop={ ( event, direction, elt ) => {\n\t\t\t\t\tonResizeStop();\n\t\t\t\t\t// Since the aspect ratio is locked when resizing, we can\n\t\t\t\t\t// use the width of the resized element to calculate the\n\t\t\t\t\t// height in CSS to prevent stretching when the max-width\n\t\t\t\t\t// is reached.\n\t\t\t\t\tsetAttributes( {\n\t\t\t\t\t\twidth: `${ elt.offsetWidth }px`,\n\t\t\t\t\t\theight: 'auto',\n\t\t\t\t\t\taspectRatio:\n\t\t\t\t\t\t\tratio === naturalRatio\n\t\t\t\t\t\t\t\t? undefined\n\t\t\t\t\t\t\t\t: String( ratio ),\n\t\t\t\t\t} );\n\t\t\t\t} }\n\t\t\t\tresizeRatio={ align === 'center' ? 2 : 1 }\n\t\t\t>\n\t\t\t\t{ img }\n\t\t\t</ResizableBox>\n\t\t);\n\t}\n\n\tif ( ! url && ! temporaryURL ) {\n\t\treturn sizeControls;\n\t}\n\n\treturn (\n\t\t<>\n\t\t\t{ /* Hide controls during upload to avoid component remount,\n\t\t\t\twhich causes duplicated image upload. */ }\n\t\t\t{ ! temporaryURL && controls }\n\t\t\t{ img }\n\t\t\t{ showCaption &&\n\t\t\t\t( ! RichText.isEmpty( caption ) || isSelected ) && (\n\t\t\t\t\t<RichText\n\t\t\t\t\t\tidentifier=\"caption\"\n\t\t\t\t\t\tclassName={ __experimentalGetElementClassName(\n\t\t\t\t\t\t\t'caption'\n\t\t\t\t\t\t) }\n\t\t\t\t\t\tref={ captionRef }\n\t\t\t\t\t\ttagName=\"figcaption\"\n\t\t\t\t\t\taria-label={ __( 'Image caption text' ) }\n\t\t\t\t\t\tplaceholder={ __( 'Add caption' ) }\n\t\t\t\t\t\tvalue={ caption }\n\t\t\t\t\t\tonChange={ ( value ) =>\n\t\t\t\t\t\t\tsetAttributes( { caption: value } )\n\t\t\t\t\t\t}\n\t\t\t\t\t\tinlineToolbar\n\t\t\t\t\t\t__unstableOnSplitAtEnd={ () =>\n\t\t\t\t\t\t\tinsertBlocksAfter(\n\t\t\t\t\t\t\t\tcreateBlock( getDefaultBlockName() )\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) }\n\t\t</>\n\t);\n}\n"],"mappings":"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"}
@@ -6,6 +6,66 @@ var _interactivity = require("@wordpress/interactivity");
6
6
  */
7
7
 
8
8
  const focusableSelectors = ['a[href]', 'area[href]', 'input:not([disabled]):not([type="hidden"]):not([aria-hidden])', 'select:not([disabled]):not([aria-hidden])', 'textarea:not([disabled]):not([aria-hidden])', 'button:not([disabled]):not([aria-hidden])', 'iframe', 'object', 'embed', '[contenteditable]', '[tabindex]:not([tabindex^="-"])'];
9
+
10
+ /*
11
+ * Stores a context-bound scroll handler.
12
+ *
13
+ * This callback could be defined inline inside of the store
14
+ * object but it's created externally to avoid confusion about
15
+ * how its logic is called. This logic is not referenced directly
16
+ * by the directives in the markup because the scroll event we
17
+ * need to listen to is triggered on the window; so by defining it
18
+ * outside of the store, we signal that the behavior here is different.
19
+ * If we find a compelling reason to move it to the store, feel free.
20
+ *
21
+ * @type {Function}
22
+ */
23
+ let scrollCallback;
24
+
25
+ /*
26
+ * Tracks whether user is touching screen; used to
27
+ * differentiate behavior for touch and mouse input.
28
+ *
29
+ * @type {boolean}
30
+ */
31
+ let isTouching = false;
32
+
33
+ /*
34
+ * Tracks the last time the screen was touched; used to
35
+ * differentiate behavior for touch and mouse input.
36
+ *
37
+ * @type {number}
38
+ */
39
+ let lastTouchTime = 0;
40
+
41
+ /*
42
+ * Lightbox page-scroll handler: prevents scrolling.
43
+ *
44
+ * This handler is added to prevent scrolling behaviors that
45
+ * trigger content shift while the lightbox is open.
46
+ *
47
+ * It would be better to accomplish this through CSS alone, but
48
+ * using overflow: hidden is currently the only way to do so, and
49
+ * that causes the layout to shift and prevents the zoom animation
50
+ * from working in some cases because we're unable to account for
51
+ * the layout shift when doing the animation calculations. Instead,
52
+ * here we use JavaScript to prevent and reset the scrolling
53
+ * behavior. In the future, we may be able to use CSS or overflow: hidden
54
+ * instead to not rely on JavaScript, but this seems to be the best approach
55
+ * for now that provides the best visual experience.
56
+ *
57
+ * @param {Object} context Interactivity page context?
58
+ */
59
+ function handleScroll(context) {
60
+ // We can't override the scroll behavior on mobile devices
61
+ // because doing so breaks the pinch to zoom functionality, and we
62
+ // want to allow users to zoom in further on the high-res image.
63
+ if (!isTouching && Date.now() - lastTouchTime > 450) {
64
+ // We are unable to use event.preventDefault() to prevent scrolling
65
+ // because the scroll event can't be canceled, so we reset the position instead.
66
+ window.scrollTo(context.core.image.scrollLeftReset, context.core.image.scrollTopReset);
67
+ }
68
+ }
9
69
  (0, _interactivity.store)({
10
70
  state: {
11
71
  core: {
@@ -32,38 +92,39 @@ const focusableSelectors = ['a[href]', 'area[href]', 'input:not([disabled]):not(
32
92
  context.core.image.scrollDelta = 0;
33
93
  context.core.image.lightboxEnabled = true;
34
94
  setStyles(context, event);
35
- // Hide overflow only when the animation is in progress,
36
- // otherwise the removal of the scrollbars will draw attention
37
- // to itself and look like an error
38
- document.documentElement.classList.add('wp-has-lightbox-open');
95
+ context.core.image.scrollTopReset = window.pageYOffset || document.documentElement.scrollTop;
96
+
97
+ // In most cases, this value will be 0, but this is included
98
+ // in case a user has created a page with horizontal scrolling.
99
+ context.core.image.scrollLeftReset = window.pageXOffset || document.documentElement.scrollLeft;
100
+
101
+ // We define and bind the scroll callback here so
102
+ // that we can pass the context and as an argument.
103
+ // We may be able to change this in the future if we
104
+ // define the scroll callback in the store instead, but
105
+ // this approach seems to tbe clearest for now.
106
+ scrollCallback = handleScroll.bind(null, context);
107
+
108
+ // We need to add a scroll event listener to the window
109
+ // here because we are unable to otherwise access it via
110
+ // the Interactivity API directives. If we add a native way
111
+ // to access the window, we can remove this.
112
+ window.addEventListener('scroll', scrollCallback, false);
39
113
  },
40
114
  hideLightbox: async ({
41
- context,
42
- event
115
+ context
43
116
  }) => {
44
117
  context.core.image.hideAnimationEnabled = true;
45
118
  if (context.core.image.lightboxEnabled) {
46
- // If scrolling, wait a moment before closing the lightbox.
47
- if (context.core.image.lightboxAnimation === 'fade') {
48
- context.core.image.scrollDelta += event.deltaY;
49
- if (event.type === 'mousewheel' && Math.abs(window.scrollY - context.core.image.scrollDelta) < 10) {
50
- return;
51
- }
52
- } else if (context.core.image.lightboxAnimation === 'zoom') {
53
- // Disable scroll until the zoom animation ends.
54
- // Get the current page scroll position
55
- const scrollTop = window.pageYOffset || document.documentElement.scrollTop;
56
- const scrollLeft = window.pageXOffset || document.documentElement.scrollLeft;
57
- // if any scroll is attempted, set this to the previous value.
58
- window.onscroll = function () {
59
- window.scrollTo(scrollLeft, scrollTop);
60
- };
61
- // Enable scrolling after the animation finishes
62
- setTimeout(function () {
63
- window.onscroll = function () {};
64
- }, 400);
65
- }
66
- document.documentElement.classList.remove('wp-has-lightbox-open');
119
+ // We want to wait until the close animation is completed
120
+ // before allowing a user to scroll again. The duration of this
121
+ // animation is defined in the styles.scss and depends on if the
122
+ // animation is 'zoom' or 'fade', but in any case we should wait
123
+ // a few milliseconds longer than the duration, otherwise a user
124
+ // may scroll too soon and cause the animation to look sloppy.
125
+ setTimeout(function () {
126
+ window.removeEventListener('scroll', scrollCallback);
127
+ }, 450);
67
128
  context.core.image.lightboxEnabled = false;
68
129
  context.core.image.lastFocusedElement.focus({
69
130
  preventScroll: true
@@ -107,6 +168,30 @@ const focusableSelectors = ['a[href]', 'area[href]', 'input:not([disabled]):not(
107
168
  context,
108
169
  ref
109
170
  });
171
+ },
172
+ handleTouchStart: () => {
173
+ isTouching = true;
174
+ },
175
+ handleTouchMove: ({
176
+ context,
177
+ event
178
+ }) => {
179
+ // On mobile devices, we want to prevent triggering the
180
+ // scroll event because otherwise the page jumps around as
181
+ // we reset the scroll position. This also means that closing
182
+ // the lightbox requires that a user perform a simple tap. This
183
+ // may be changed in the future if we find a better alternative
184
+ // to override or reset the scroll position during swipe actions.
185
+ if (context.core.image.lightboxEnabled) {
186
+ event.preventDefault();
187
+ }
188
+ },
189
+ handleTouchEnd: () => {
190
+ // We need to wait a few milliseconds before resetting
191
+ // to ensure that pinch to zoom works consistently
192
+ // on mobile devices when the lightbox is open.
193
+ lastTouchTime = Date.now();
194
+ isTouching = false;
110
195
  }
111
196
  }
112
197
  }
@@ -117,7 +202,17 @@ const focusableSelectors = ['a[href]', 'area[href]', 'input:not([disabled]):not(
117
202
  roleAttribute: ({
118
203
  context
119
204
  }) => {
120
- return context.core.image.lightboxEnabled ? 'dialog' : '';
205
+ return context.core.image.lightboxEnabled ? 'dialog' : null;
206
+ },
207
+ ariaModal: ({
208
+ context
209
+ }) => {
210
+ return context.core.image.lightboxEnabled ? 'true' : null;
211
+ },
212
+ dialogLabel: ({
213
+ context
214
+ }) => {
215
+ return context.core.image.lightboxEnabled ? context.core.image.dialogLabel : null;
121
216
  },
122
217
  lightboxObjectFit: ({
123
218
  context
@@ -129,7 +224,7 @@ const focusableSelectors = ['a[href]', 'area[href]', 'input:not([disabled]):not(
129
224
  enlargedImgSrc: ({
130
225
  context
131
226
  }) => {
132
- return context.core.image.initialized ? context.core.image.imageUploadedSrc : '';
227
+ return context.core.image.initialized ? context.core.image.imageUploadedSrc : 'data:image/gif;base64,R0lGODlhAQABAAD/ACwAAAAAAQABAAACADs=';
133
228
  }
134
229
  }
135
230
  }
@@ -224,6 +319,14 @@ const focusableSelectors = ['a[href]', 'area[href]', 'input:not([disabled]):not(
224
319
  }));
225
320
  }
226
321
  });
322
+
323
+ /*
324
+ * Computes styles for the lightbox and adds them to the document.
325
+ *
326
+ * @function
327
+ * @param {Object} context - An Interactivity API context
328
+ * @param {Object} event - A triggering event
329
+ */
227
330
  function setStyles(context, event) {
228
331
  // The reference img element lies adjacent
229
332
  // to the event target button in the DOM.
@@ -232,11 +335,11 @@ function setStyles(context, event) {
232
335
  naturalHeight,
233
336
  offsetWidth: originalWidth,
234
337
  offsetHeight: originalHeight
235
- } = event.target.nextElementSibling;
338
+ } = event.target.previousElementSibling;
236
339
  let {
237
340
  x: screenPosX,
238
341
  y: screenPosY
239
- } = event.target.nextElementSibling.getBoundingClientRect();
342
+ } = event.target.previousElementSibling.getBoundingClientRect();
240
343
 
241
344
  // Natural ratio of the image clicked to open the lightbox.
242
345
  const naturalRatio = naturalWidth / naturalHeight;
@@ -374,6 +477,14 @@ function setStyles(context, event) {
374
477
  }
375
478
  `;
376
479
  }
480
+
481
+ /*
482
+ * Debounces a function call.
483
+ *
484
+ * @function
485
+ * @param {Function} func - A function to be called
486
+ * @param {number} wait - The time to wait before calling the function
487
+ */
377
488
  function debounce(func, wait = 50) {
378
489
  let timeout;
379
490
  return () => {