Skip to content

Commit

Permalink
LinkControl: refined the display of the link preview title and url wh…
Browse files Browse the repository at this point in the history
…en both are same (WordPress#61819)

* Add removeProtocol function to URL package

* Fix redundant link preview display when link text includes protocol in LinkControl.

* Changed regex for stripDomainPrefixes to handle all protocols

* Add unit tests for stripDomainPrefixes function

* Refactor URL filtering logic

* Change variable name

* Moved filterTitleForDisplay outside of component

* Adds test cases for the updated regex

* Fix typos and remove redundant tests for filterURLForDisplay

* Fix isUrlRedundant check in LinkPreview component

* Add test case for empty or falsy URL in filterURLForDisplay function

Co-authored-by: amitraj2203 <[email protected]>
Co-authored-by: afercia <[email protected]>
Co-authored-by: tyxla <[email protected]>
  • Loading branch information
4 people authored Jun 10, 2024
1 parent 5a1031b commit bd6e764
Show file tree
Hide file tree
Showing 3 changed files with 37 additions and 2 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,20 @@ import { ViewerSlot } from './viewer-slot';

import useRichUrlData from './use-rich-url-data';

/**
* Filters the title for display. Removes the protocol and www prefix.
*
* @param {string} title The title to be filtered.
*
* @return {string} The filtered title.
*/
function filterTitleForDisplay( title ) {
// Derived from `filterURLForDisplay` in `@wordpress/url`.
return title
.replace( /^[a-z\-.\+]+[0-9]*:(\/\/)?/i, '' )
.replace( /^www\./i, '' );
}

export default function LinkPreview( {
value,
onEditClick,
Expand Down Expand Up @@ -59,6 +73,9 @@ export default function LinkPreview( {
! isEmptyURL &&
stripHTML( richData?.title || value?.title || displayURL );

const isUrlRedundant =
! value?.url || filterTitleForDisplay( displayTitle ) === displayURL;

let icon;

if ( richData?.icon ) {
Expand Down Expand Up @@ -112,7 +129,7 @@ export default function LinkPreview( {
{ displayTitle }
</Truncate>
</ExternalLink>
{ value?.url && displayTitle !== displayURL && (
{ ! isUrlRedundant && (
<span className="block-editor-link-control__search-item-info">
<Truncate numberOfLines={ 1 }>
{ displayURL }
Expand Down
8 changes: 7 additions & 1 deletion packages/url/src/filter-url-for-display.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,8 +13,14 @@
* @return {string} Displayed URL.
*/
export function filterURLForDisplay( url, maxLength = null ) {
if ( ! url ) {
return '';
}

// Remove protocol and www prefixes.
let filteredURL = url.replace( /^(?:https?:)\/\/(?:www\.)?/, '' );
let filteredURL = url
.replace( /^[a-z\-.\+]+[0-9]*:(\/\/)?/i, '' )
.replace( /^www\./i, '' );

// Ends with / and only has that single slash, strip it.
if ( filteredURL.match( /^[^\/]+\/$/ ) ) {
Expand Down
12 changes: 12 additions & 0 deletions packages/url/src/test/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -992,11 +992,23 @@ describe( 'safeDecodeURI', () => {
} );

describe( 'filterURLForDisplay', () => {
it( 'should return an empty string if the url is empty or falsy', () => {
let url = filterURLForDisplay( '' );
expect( url ).toBe( '' );
url = filterURLForDisplay( null );
expect( url ).toBe( '' );
} );
it( 'should remove protocol', () => {
let url = filterURLForDisplay( 'http://wordpress.org' );
expect( url ).toBe( 'wordpress.org' );
url = filterURLForDisplay( 'https://wordpress.org' );
expect( url ).toBe( 'wordpress.org' );
url = filterURLForDisplay( 'file:///folder/file.txt' );
expect( url ).toBe( '/folder/file.txt' );
url = filterURLForDisplay( 'tel:0123456789' );
expect( url ).toBe( '0123456789' );
url = filterURLForDisplay( 'blob:data' );
expect( url ).toBe( 'data' );
} );
it( 'should remove www subdomain', () => {
const url = filterURLForDisplay( 'http://www.wordpress.org' );
Expand Down

0 comments on commit bd6e764

Please sign in to comment.