DEV: Drop deprecated `decorateTopicTitle` API (#30626)

This commit is contained in:
David Taylor 2025-01-08 11:01:27 +00:00 committed by GitHub
parent 21c8376679
commit 61450b0947
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
7 changed files with 5 additions and 110 deletions

View File

@ -11,7 +11,6 @@ import {
} from "@ember-decorators/component";
import { observes, on } from "@ember-decorators/object";
import $ from "jquery";
import { topicTitleDecorators } from "discourse/components/topic-title";
import { wantsNewWindow } from "discourse/lib/intercept-click";
import { applyValueTransformer } from "discourse/lib/transformer";
import DiscourseURL, { groupPath } from "discourse/lib/url";
@ -128,17 +127,6 @@ export default class TopicListItem extends Component {
if (this.includeUnreadIndicator) {
this.messageBus.subscribe(this.unreadIndicatorChannel, this.onMessage);
}
schedule("afterRender", () => {
if (this.element && !this.isDestroying && !this.isDestroyed) {
const rawTopicLink = this.element.querySelector(".raw-topic-link");
rawTopicLink &&
topicTitleDecorators.forEach((cb) =>
cb(this.topic, rawTopicLink, "topic-list-item-title")
);
}
});
}
willDestroyElement() {

View File

@ -2,7 +2,6 @@ import Component from "@glimmer/component";
import { array, concat, hash } from "@ember/helper";
import { on } from "@ember/modifier";
import { action } from "@ember/object";
import didInsert from "@ember/render-modifiers/modifiers/did-insert";
import { next } from "@ember/runloop";
import { service } from "@ember/service";
import { modifier } from "ember-modifier";
@ -12,7 +11,6 @@ import PostCountOrBadges from "discourse/components/topic-list/post-count-or-bad
import TopicExcerpt from "discourse/components/topic-list/topic-excerpt";
import TopicLink from "discourse/components/topic-list/topic-link";
import TopicStatus from "discourse/components/topic-status";
import { topicTitleDecorators } from "discourse/components/topic-title";
import avatar from "discourse/helpers/avatar";
import categoryLink from "discourse/helpers/category-link";
import concatClass from "discourse/helpers/concat-class";
@ -104,17 +102,6 @@ export default class Item extends Component {
event.target.closest(".topic-list-item").classList.remove("selected");
}
@action
applyTitleDecorators(element) {
const rawTopicLink = element.querySelector(".raw-topic-link");
if (rawTopicLink) {
topicTitleDecorators?.forEach((cb) =>
cb(this.args.topic, rawTopicLink, "topic-list-item-title")
);
}
}
@action
onBulkSelectToggle(e) {
if (e.target.checked) {
@ -193,7 +180,6 @@ export default class Item extends Component {
<template>
<tr
{{! template-lint-disable no-invalid-interactive }}
{{didInsert this.applyTitleDecorators}}
{{this.highlightIfNeeded}}
{{on "keydown" this.keyDown}}
{{on "click" this.click}}

View File

@ -2,37 +2,15 @@ import Component from "@glimmer/component";
import { hash } from "@ember/helper";
import { on } from "@ember/modifier";
import { action } from "@ember/object";
import didInsert from "@ember/render-modifiers/modifiers/did-insert";
import willDestroy from "@ember/render-modifiers/modifiers/will-destroy";
import { service } from "@ember/service";
import PluginOutlet from "discourse/components/plugin-outlet";
import { isiPad } from "discourse/lib/utilities";
import observeIntersection from "discourse/modifiers/observe-intersection";
export let topicTitleDecorators = [];
export function addTopicTitleDecorator(decorator) {
topicTitleDecorators.push(decorator);
}
export function resetTopicTitleDecorators() {
topicTitleDecorators.length = 0;
}
export default class TopicTitle extends Component {
@service header;
@action
applyDecorators(element) {
const fancyTitle = element.querySelector(".fancy-title");
if (fancyTitle) {
topicTitleDecorators.forEach((cb) =>
cb(this.args.model, fancyTitle, "topic-title")
);
}
}
@action
keyDown(e) {
if (e.key === "Escape") {
@ -66,7 +44,6 @@ export default class TopicTitle extends Component {
<template>
{{! template-lint-disable no-invalid-interactive }}
<div
{{didInsert this.applyDecorators}}
{{on "keydown" this.keyDown}}
{{observeIntersection this.handleIntersectionChange}}
{{willDestroy this.handleTitleDestroy}}

View File

@ -3,7 +3,7 @@
// docs/CHANGELOG-JAVASCRIPT-PLUGIN-API.md whenever you change the version
// using the format described at https://keepachangelog.com/en/1.0.0/.
export const PLUGIN_API_VERSION = "1.39.2";
export const PLUGIN_API_VERSION = "2.0.0";
import $ from "jquery";
import { h } from "virtual-dom";
@ -41,7 +41,6 @@ import { addOnKeyUpCallback } from "discourse/components/search-menu/search-term
import { REFRESH_COUNTS_APP_EVENT_NAME as REFRESH_USER_SIDEBAR_CATEGORIES_SECTION_COUNTS_APP_EVENT_NAME } from "discourse/components/sidebar/user/categories-section";
import { addTopicParticipantClassesCallback } from "discourse/components/topic-map/topic-participant";
import { setDesktopScrollAreaHeight } from "discourse/components/topic-timeline/container";
import { addTopicTitleDecorator } from "discourse/components/topic-title";
import { setNotificationsLimit as setUserMenuNotificationsLimit } from "discourse/components/user-menu/notifications-list";
import { addUserMenuProfileTabItem } from "discourse/components/user-menu/profile-tab-content";
import { addDiscoveryQueryParam } from "discourse/controllers/discovery/list";
@ -2066,33 +2065,6 @@ class PluginApi {
setDesktopScrollAreaHeight(height);
}
/**
* Allows altering the topic title in the topic list, and in the topic view
*
* topicTitleType can be `topic-title` or `topic-list-item-title`
*
* For example, to replace the topic title:
*
* ```
* api.decorateTopicTitle((topicModel, node, topicTitleType) => {
* node.innerText = "my new topic title";
* });
* ```
*
* @deprecated because modifying an Ember-rendered DOM tree can lead to very unexpected errors. Use plugin outlet connectors instead
**/
decorateTopicTitle(callback) {
deprecated(
"decorateTopicTitle is deprecated because modifying an Ember-rendered DOM tree can lead to very unexpected errors. Use plugin outlet connectors instead",
{
id: "discourse.decorate-topic-title",
since: "3.2",
dropFrom: "3.3",
}
);
addTopicTitleDecorator(callback);
}
/**
* Allows a different limit to be set for fetching recent notifications for the user menu
*

View File

@ -6,7 +6,6 @@ import {
visit,
} from "@ember/test-helpers";
import { test } from "qunit";
import { withPluginApi } from "discourse/lib/plugin-api";
import CategoryFixtures from "discourse/tests/fixtures/category-fixtures";
import topicFixtures from "discourse/tests/fixtures/topic";
import {
@ -16,7 +15,6 @@ import {
selectText,
} from "discourse/tests/helpers/qunit-helpers";
import selectKit from "discourse/tests/helpers/select-kit-helper";
import { withSilencedDeprecations } from "discourse-common/lib/deprecated";
import { cloneJSON } from "discourse-common/lib/object";
import { i18n } from "discourse-i18n";
@ -452,34 +450,6 @@ acceptance("Topic featured links", function (needs) {
});
});
acceptance("Topic with title decorated", function (needs) {
needs.user();
needs.hooks.beforeEach(() => {
withPluginApi("0.8.40", (api) => {
withSilencedDeprecations("discourse.decorate-topic-title", () => {
api.decorateTopicTitle((topic, node, topicTitleType) => {
node.innerText = `${node.innerText}-${topic.id}-${topicTitleType}`;
});
});
});
});
test("Decorate topic title", async function (assert) {
await visit("/t/internationalization-localization/280");
assert
.dom(".fancy-title")
.hasText(/-280-topic-title$/, "decorates topic title");
assert
.dom(".raw-topic-link:nth-child(1)")
.hasText(
/-27331-topic-list-item-title$/,
"decorates topic list item title"
);
});
});
acceptance("Topic pinning/unpinning as an admin", function (needs) {
needs.user({ admin: true });

View File

@ -28,7 +28,6 @@ import { resetDecorators as resetPluginOutletDecorators } from "discourse/compon
import { resetItemSelectCallbacks } from "discourse/components/search-menu/results/assistant-item";
import { resetQuickSearchRandomTips } from "discourse/components/search-menu/results/random-quick-tip";
import { resetOnKeyUpCallbacks } from "discourse/components/search-menu/search-term";
import { resetTopicTitleDecorators } from "discourse/components/topic-title";
import { resetUserMenuProfileTabItems } from "discourse/components/user-menu/profile-tab-content";
import { resetCustomPostMessageCallbacks } from "discourse/controllers/topic";
import { clearHTMLCache } from "discourse/helpers/custom-html";
@ -208,7 +207,6 @@ export function testCleanup(container, app) {
resetDecorators();
resetPostCookedDecorators();
resetPluginOutletDecorators();
resetTopicTitleDecorators();
resetUsernameDecorators();
resetOneboxCache();
resetCustomPostMessageCallbacks();

View File

@ -7,6 +7,10 @@ in this file.
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
## [2.0.0] - 2025-01-07
- Removed `decorateTopicTitle`. This has been deprecated for more than a year, and we are not aware of any remaining uses in the ecosystem.
## [1.39.2] - 2024-12-19
- Removed the deprecation of `includePostAttributes` for now.