Changeset 7581
- Timestamp:
- 08/02/2018 12:58:51 AM (6 years ago)
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
sites/trunk/wordpress.org/public_html/wp-content/themes/pub/gutenberg/functions.php
r7580 r7581 35 35 // Use a middleware provider to intercept and modify API calls. Short-circuit POST requests, bound queries, allow media, etc. 36 36 wp_add_inline_script( 'wp-api-fetch', 37 sprintf( 38 'wp.apiFetch.use( function( options, next ) { 39 var isWhitelistedEndpoint = ( 40 lodash.startsWith( options.path, "/oembed/1.0/proxy" ) || 41 lodash.startsWith( options.path, "/gutenberg/v1/block-renderer" ) 42 ); 43 44 // Prevent non-whitelisted non-GET requests (ie. POST) to prevent errors 45 if ( options.method && options.method !== "GET" && ! isWhitelistedEndpoint ) { 46 // This works in enough cases to be the default return value. 47 return Promise.resolve( options.data ); 48 } 49 50 // Add limits to all GET queries which attempt unbound queries 51 options.path = options.path.replace( "per_page=-1", "per_page=10" ); 52 53 // Load images with the view context, seems to work 54 if ( lodash.startsWith( options.path, "/wp/v2/media/" ) ) { 55 options.path = options.path.replace( "context=edit", "context=view" ); 56 } 57 58 return next( options ); 59 } );' 60 ), 37 'wp.apiFetch.use( function( options, next ) { 38 var isWhitelistedEndpoint = ( 39 lodash.startsWith( options.path, "/oembed/1.0/proxy" ) || 40 lodash.startsWith( options.path, "/gutenberg/v1/block-renderer" ) 41 ); 42 43 // Prevent non-whitelisted non-GET requests (ie. POST) to prevent errors 44 if ( options.method && options.method !== "GET" && ! isWhitelistedEndpoint ) { 45 // This works in enough cases to be the default return value. 46 return Promise.resolve( options.data ); 47 } 48 49 // Add limits to all GET queries which attempt unbound queries 50 options.path = options.path.replace( "per_page=-1", "per_page=10" ); 51 52 // Load images with the view context, seems to work 53 if ( lodash.startsWith( options.path, "/wp/v2/media/" ) ) { 54 options.path = options.path.replace( "context=edit", "context=view" ); 55 } 56 57 return next( options ); 58 } );', 61 59 'after' 62 60 ); … … 112 110 // Add a middleware provider which intercepts all uploads and stores them within the browser 113 111 wp_add_inline_script( 'wp-api-fetch', 114 sprintf( 115 'wp.apiFetch.use( function( options, next ) { 116 if ( options.method == "POST" && options.path == "/wp/v2/media" ) { 117 var file = options.body.get("file"); 118 119 window.fakeUploadedMedia = window.fakeUploadedMedia || []; 120 if ( ! window.fakeUploadedMedia.length ) { 121 window.fakeUploadedMedia[9999000] = {}; 122 } 123 var id = window.fakeUploadedMedia.length; 124 125 window.fakeUploadedMedia[ id ] = { 126 "id": id, 127 "date": "", "date_gmt": "", "modified": "", "modified_gmt": "", 128 "guid": {}, "title": { "rendered": file.name, "raw": file.name }, 129 "description": {}, "caption": {}, "alt_text": "", 130 "slug": file.name, "status": "inherit", "type": "attachment", "link": "", 131 "author": 0, "comment_status": "open", "ping_status": "closed", 132 "media_details": {}, "media_type": file.type.split("/")[0], "mime_type": file.type, 133 "source_url": "", // This gets filled below with a data uri 134 "_links": {} 135 }; 136 137 return new Promise( function( resolve ) { 138 var a = new FileReader(); 139 a.onload = function(e) { 140 window.fakeUploadedMedia[ id ].source_url = e.target.result; 141 resolve( window.fakeUploadedMedia[ id ] ); 142 } 143 a.readAsDataURL( file ); 144 } ); 112 'wp.apiFetch.use( function( options, next ) { 113 if ( options.method == "POST" && options.path == "/wp/v2/media" ) { 114 var file = options.body.get("file"); 115 116 window.fakeUploadedMedia = window.fakeUploadedMedia || []; 117 if ( ! window.fakeUploadedMedia.length ) { 118 window.fakeUploadedMedia[9999000] = {}; 145 119 } 146 147 // Drag droped media of ID 9999xxx is stored within the Browser 148 var path_id_match = options.path.match( "^/wp/v2/media/(9999\\\\d+)" ); 149 if ( path_id_match ) { 150 return Promise.resolve( window.fakeUploadedMedia[ path_id_match[1] ] ); 151 } 152 153 return next( options ); 154 } );' 155 ), 120 var id = window.fakeUploadedMedia.length; 121 122 window.fakeUploadedMedia[ id ] = { 123 "id": id, 124 "date": "", "date_gmt": "", "modified": "", "modified_gmt": "", 125 "guid": {}, "title": { "rendered": file.name, "raw": file.name }, 126 "description": {}, "caption": {}, "alt_text": "", 127 "slug": file.name, "status": "inherit", "type": "attachment", "link": "", 128 "author": 0, "comment_status": "open", "ping_status": "closed", 129 "media_details": {}, "media_type": file.type.split("/")[0], "mime_type": file.type, 130 "source_url": "", // This gets filled below with a data uri 131 "_links": {} 132 }; 133 134 return new Promise( function( resolve ) { 135 var a = new FileReader(); 136 a.onload = function(e) { 137 window.fakeUploadedMedia[ id ].source_url = e.target.result; 138 resolve( window.fakeUploadedMedia[ id ] ); 139 } 140 a.readAsDataURL( file ); 141 } ); 142 } 143 144 // Drag droped media of ID 9999xxx is stored within the Browser 145 var path_id_match = options.path.match( "^/wp/v2/media/(9999\\\\d+)" ); 146 if ( path_id_match ) { 147 return Promise.resolve( window.fakeUploadedMedia[ path_id_match[1] ] ); 148 } 149 150 return next( options ); 151 } );', 156 152 'after' 157 153 );
Note: See TracChangeset
for help on using the changeset viewer.