summaryrefslogtreecommitdiffstats
path: root/wp-includes/js/dist/deprecated.js
diff options
context:
space:
mode:
Diffstat (limited to 'wp-includes/js/dist/deprecated.js')
-rw-r--r--wp-includes/js/dist/deprecated.js123
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