@wordpress/block-editor
Version:
8 lines (7 loc) • 3.33 kB
Source Map (JSON)
{
"version": 3,
"sources": ["../../../src/components/autocomplete/index.js"],
"sourcesContent": ["/**\n * WordPress dependencies\n */\nimport { applyFilters, hasFilter } from '@wordpress/hooks';\nimport {\n\tAutocomplete,\n\t__unstableUseAutocompleteProps as useAutocompleteProps,\n} from '@wordpress/components';\nimport { useMemo } from '@wordpress/element';\nimport { getDefaultBlockName, getBlockSupport } from '@wordpress/blocks';\n\n/**\n * Internal dependencies\n */\nimport { useBlockEditContext } from '../block-edit/context';\nimport blockAutocompleter from '../../autocompleters/block';\nimport linkAutocompleter from '../../autocompleters/link';\n\n/**\n * Shared reference to an empty array for cases where it is important to avoid\n * returning a new array reference on every invocation.\n *\n * @type {Array}\n */\nconst EMPTY_ARRAY = [];\n\nfunction useCompleters( { completers = EMPTY_ARRAY } ) {\n\tconst { name } = useBlockEditContext();\n\treturn useMemo( () => {\n\t\tlet filteredCompleters = [ ...completers, linkAutocompleter ];\n\n\t\tif (\n\t\t\tname === getDefaultBlockName() ||\n\t\t\tgetBlockSupport( name, '__experimentalSlashInserter', false )\n\t\t) {\n\t\t\tfilteredCompleters = [ ...filteredCompleters, blockAutocompleter ];\n\t\t}\n\n\t\tif ( hasFilter( 'editor.Autocomplete.completers' ) ) {\n\t\t\t// Provide copies so filters may directly modify them.\n\t\t\tif ( filteredCompleters === completers ) {\n\t\t\t\tfilteredCompleters = filteredCompleters.map(\n\t\t\t\t\t( completer ) => ( { ...completer } )\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tfilteredCompleters = applyFilters(\n\t\t\t\t'editor.Autocomplete.completers',\n\t\t\t\tfilteredCompleters,\n\t\t\t\tname\n\t\t\t);\n\t\t}\n\n\t\treturn filteredCompleters;\n\t}, [ completers, name ] );\n}\n\nexport function useBlockEditorAutocompleteProps( props ) {\n\treturn useAutocompleteProps( {\n\t\t...props,\n\t\tcompleters: useCompleters( props ),\n\t} );\n}\n\n/**\n * Wrap the default Autocomplete component with one that supports a filter hook\n * for customizing its list of autocompleters.\n *\n * @type {import('react').FC}\n */\nfunction BlockEditorAutocomplete( props ) {\n\treturn <Autocomplete { ...props } completers={ useCompleters( props ) } />;\n}\n\n/**\n * @see https://github.com/WordPress/gutenberg/blob/HEAD/packages/block-editor/src/components/autocomplete/README.md\n */\nexport default BlockEditorAutocomplete;\n"],
"mappings": ";AAGA,SAAS,cAAc,iBAAiB;AACxC;AAAA,EACC;AAAA,EACA,kCAAkC;AAAA,OAC5B;AACP,SAAS,eAAe;AACxB,SAAS,qBAAqB,uBAAuB;AAKrD,SAAS,2BAA2B;AACpC,OAAO,wBAAwB;AAC/B,OAAO,uBAAuB;AAuDtB;AA/CR,IAAM,cAAc,CAAC;AAErB,SAAS,cAAe,EAAE,aAAa,YAAY,GAAI;AACtD,QAAM,EAAE,KAAK,IAAI,oBAAoB;AACrC,SAAO,QAAS,MAAM;AACrB,QAAI,qBAAqB,CAAE,GAAG,YAAY,iBAAkB;AAE5D,QACC,SAAS,oBAAoB,KAC7B,gBAAiB,MAAM,+BAA+B,KAAM,GAC3D;AACD,2BAAqB,CAAE,GAAG,oBAAoB,kBAAmB;AAAA,IAClE;AAEA,QAAK,UAAW,gCAAiC,GAAI;AAEpD,UAAK,uBAAuB,YAAa;AACxC,6BAAqB,mBAAmB;AAAA,UACvC,CAAE,eAAiB,EAAE,GAAG,UAAU;AAAA,QACnC;AAAA,MACD;AAEA,2BAAqB;AAAA,QACpB;AAAA,QACA;AAAA,QACA;AAAA,MACD;AAAA,IACD;AAEA,WAAO;AAAA,EACR,GAAG,CAAE,YAAY,IAAK,CAAE;AACzB;AAEO,SAAS,gCAAiC,OAAQ;AACxD,SAAO,qBAAsB;AAAA,IAC5B,GAAG;AAAA,IACH,YAAY,cAAe,KAAM;AAAA,EAClC,CAAE;AACH;AAQA,SAAS,wBAAyB,OAAQ;AACzC,SAAO,oBAAC,gBAAe,GAAG,OAAQ,YAAa,cAAe,KAAM,GAAI;AACzE;AAKA,IAAO,uBAAQ;",
"names": []
}