diff options
Diffstat (limited to 'wp-includes/js/dist/deprecated.js')
-rw-r--r-- | wp-includes/js/dist/deprecated.js | 123 |
1 files changed, 123 insertions, 0 deletions
diff --git a/wp-includes/js/dist/deprecated.js b/wp-includes/js/dist/deprecated.js new file mode 100644 index 0000000..02f663e --- /dev/null +++ b/wp-includes/js/dist/deprecated.js @@ -0,0 +1,123 @@ +/******/ (function() { // webpackBootstrap +/******/ "use strict"; +/******/ // The require scope +/******/ var __webpack_require__ = {}; +/******/ +/************************************************************************/ +/******/ /* webpack/runtime/define property getters */ +/******/ !function() { +/******/ // define getter functions for harmony exports +/******/ __webpack_require__.d = function(exports, definition) { +/******/ for(var key in definition) { +/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { +/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); +/******/ } +/******/ } +/******/ }; +/******/ }(); +/******/ +/******/ /* webpack/runtime/hasOwnProperty shorthand */ +/******/ !function() { +/******/ __webpack_require__.o = function(obj, prop) { return Object.prototype.hasOwnProperty.call(obj, prop); } +/******/ }(); +/******/ +/************************************************************************/ +var __webpack_exports__ = {}; + +// EXPORTS +__webpack_require__.d(__webpack_exports__, { + "default": function() { return /* binding */ deprecated; } +}); + +// UNUSED EXPORTS: logged + +;// CONCATENATED MODULE: external ["wp","hooks"] +var external_wp_hooks_namespaceObject = window["wp"]["hooks"]; +;// CONCATENATED MODULE: ./node_modules/@wordpress/deprecated/build-module/index.js +/** + * WordPress dependencies + */ + + +/** + * Object map tracking messages which have been logged, for use in ensuring a + * message is only logged once. + * + * @type {Record<string, true | undefined>} + */ +const logged = Object.create(null); + +/** + * Logs a message to notify developers about a deprecated feature. + * + * @param {string} feature Name of the deprecated feature. + * @param {Object} [options] Personalisation options + * @param {string} [options.since] Version in which the feature was deprecated. + * @param {string} [options.version] Version in which the feature will be removed. + * @param {string} [options.alternative] Feature to use instead + * @param {string} [options.plugin] Plugin name if it's a plugin feature + * @param {string} [options.link] Link to documentation + * @param {string} [options.hint] Additional message to help transition away from the deprecated feature. + * + * @example + * ```js + * import deprecated from '@wordpress/deprecated'; + * + * deprecated( 'Eating meat', { + * since: '2019.01.01' + * version: '2020.01.01', + * alternative: 'vegetables', + * plugin: 'the earth', + * hint: 'You may find it beneficial to transition gradually.', + * } ); + * + * // Logs: 'Eating meat is deprecated since version 2019.01.01 and will be removed from the earth in version 2020.01.01. Please use vegetables instead. Note: You may find it beneficial to transition gradually.' + * ``` + */ +function deprecated(feature, options = {}) { + const { + since, + version, + alternative, + plugin, + link, + hint + } = options; + const pluginMessage = plugin ? ` from ${plugin}` : ''; + const sinceMessage = since ? ` since version ${since}` : ''; + const versionMessage = version ? ` and will be removed${pluginMessage} in version ${version}` : ''; + const useInsteadMessage = alternative ? ` Please use ${alternative} instead.` : ''; + const linkMessage = link ? ` See: ${link}` : ''; + const hintMessage = hint ? ` Note: ${hint}` : ''; + const message = `${feature} is deprecated${sinceMessage}${versionMessage}.${useInsteadMessage}${linkMessage}${hintMessage}`; + + // Skip if already logged. + if (message in logged) { + return; + } + + /** + * Fires whenever a deprecated feature is encountered + * + * @param {string} feature Name of the deprecated feature. + * @param {?Object} options Personalisation options + * @param {string} options.since Version in which the feature was deprecated. + * @param {?string} options.version Version in which the feature will be removed. + * @param {?string} options.alternative Feature to use instead + * @param {?string} options.plugin Plugin name if it's a plugin feature + * @param {?string} options.link Link to documentation + * @param {?string} options.hint Additional message to help transition away from the deprecated feature. + * @param {?string} message Message sent to console.warn + */ + (0,external_wp_hooks_namespaceObject.doAction)('deprecated', feature, options, message); + + // eslint-disable-next-line no-console + console.warn(message); + logged[message] = true; +} + +/** @typedef {import('utility-types').NonUndefined<Parameters<typeof deprecated>[1]>} DeprecatedOptions */ + +(window.wp = window.wp || {}).deprecated = __webpack_exports__["default"]; +/******/ })() +;
\ No newline at end of file |