mediawiki-extensions-Cite/modules/ext.cite.highlighting.js
thiemowmde 202c0d3636 Drop unused …_suffix and …_key_with_num messages
The three messages cite_reference_link_key_with_num,
cite_reference_link_suffix, and cite_references_link_suffix are not
used for anything.

According to CodeSearch:
https://codesearch.wmcloud.org/search/?i=1&q=cite_references?_link_(key|suffix)

According to GlobalSearch:
https://global-search.toolforge.org/?q=.&regex=1&namespaces=8&title=Cite.references?.link.(key|suffix).*
For comparison:
https://global-search.toolforge.org/?q=.&regex=1&namespaces=8&title=Cite.references?.link.prefix.*

They are not meant to be localized, as noted in qqq.json. As many
messages in Cite the idea is that individual wikis can customize the
generated HTML (!) via such messages. These particular ones apparently
have been introduced just because it's technically possible, but never
been used for anything. They exist since the very first commit from
2005: https://phabricator.wikimedia.org/rECITb714bf09

Note how these messages aren't even visible anywhere, except in the
browser's address bar as part of a #… fragment.

This obviously doesn't solve T321217 but helps minimizing the
surface.

Bug: T321217
Change-Id: Icfa82155e3b02df39bb6e924bc472f6edc565d5f
2023-12-08 09:26:05 +01:00

115 lines
3.3 KiB
JavaScript

'use strict';
/**
* @author Thiemo Kreuz
*/
( function () {
/**
* Checks if the ID uses a composite format that does not only consist of a sequential number.
*
* @param {string} id
* @return {boolean}
*/
function isNamedReference( id ) {
const prefix = mw.msg( 'cite_reference_link_prefix' );
// Note: This assumes IDs start with the prefix; this is guaranteed by the parser function
return /\D/.test( id.slice( prefix.length ) );
}
/**
* @param {string} id
* @param {jQuery} $content
* @return {boolean}
*/
function isReusedNamedReference( id, $content ) {
if ( !isNamedReference( id ) ) {
return false;
}
// Either the ID is already a reuse, or at least one reuse exists somewhere else on the page
return id.slice( -2 ) !== '-0' ||
$content.find( '.references a[href="#' + $.escapeSelector( id.slice( 0, -1 ) ) + '1"]' ).length;
}
/**
* @param {jQuery} $backlinkWrapper
* @return {jQuery}
*/
function makeUpArrowLink( $backlinkWrapper ) {
let textNode = $backlinkWrapper[ 0 ].firstChild;
const accessibilityLabel = mw.msg( 'cite_references_link_accessibility_back_label' );
const $upArrowLink = $( '<a>' )
.addClass( 'mw-cite-up-arrow-backlink' )
.attr( 'aria-label', accessibilityLabel )
.attr( 'title', accessibilityLabel );
if ( !textNode ) {
return $upArrowLink;
}
// Skip additional, custom HTML wrappers, if any.
while ( textNode.firstChild ) {
textNode = textNode.firstChild;
}
if ( textNode.nodeType !== Node.TEXT_NODE || textNode.data.trim() === '' ) {
return $upArrowLink;
}
const upArrow = textNode.data.trim();
// The text node typically contains "↑ ", and we need to keep the space.
textNode.data = textNode.data.replace( upArrow, '' );
// Create a plain text and a clickable "↑". CSS :target selectors make sure only
// one is visible at a time.
$backlinkWrapper.prepend(
$( '<span>' )
.addClass( 'mw-cite-up-arrow' )
.text( upArrow ),
$upArrowLink
.text( upArrow )
);
return $upArrowLink;
}
/**
* @param {jQuery} $backlink
*/
function updateUpArrowLink( $backlink ) {
// It's convenient to stop at the class name, but it's not guaranteed to be there.
const $backlinkWrapper = $backlink.closest( '.mw-cite-backlink, li' );
let $upArrowLink = $backlinkWrapper.find( '.mw-cite-up-arrow-backlink' );
if ( !$upArrowLink.length && $backlinkWrapper.length ) {
$upArrowLink = makeUpArrowLink( $backlinkWrapper );
}
$upArrowLink.attr( 'href', $backlink.attr( 'href' ) );
}
mw.hook( 'wikipage.content' ).add( function ( $content ) {
// We are going to use the ID in the code below, so better be sure one is there.
$content.find( '.reference[id] > a' ).on( 'click', function () {
const id = $( this ).parent().attr( 'id' );
$content.find( '.mw-cite-targeted-backlink' ).removeClass( 'mw-cite-targeted-backlink' );
// Bail out if there is not at least a second backlink ("cite_references_link_many").
if ( !isReusedNamedReference( id, $content ) ) {
return;
}
// The :not() skips the duplicate link created below. Relevant when double clicking.
const $backlink = $content.find( '.references a[href="#' + $.escapeSelector( id ) + '"]:not(.mw-cite-up-arrow-backlink)' )
.first()
.addClass( 'mw-cite-targeted-backlink' );
if ( $backlink.length ) {
updateUpArrowLink( $backlink );
}
} );
} );
}() );