Skip to content

Commit

Permalink
fix(linkify): add tests and improve regexp
Browse files Browse the repository at this point in the history
  • Loading branch information
tkohr committed Nov 28, 2023
1 parent 70c3a51 commit a44eb0f
Show file tree
Hide file tree
Showing 2 changed files with 75 additions and 18 deletions.
91 changes: 74 additions & 17 deletions libs/ui/elements/src/lib/metadata-info/linkify.directive.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,61 @@ import { Component, DebugElement } from '@angular/core'
import { By } from '@angular/platform-browser'
import { GnUiLinkifyDirective } from './linkify.directive'

const testingUrls = [
['First link http://bla.org no slash', 'http://bla.org'],

['Second link http://bla.org/ with slash', 'http://bla.org/'],
[
'Third link https://www.bla.org/hello no slash',
'https://www.bla.org/hello',
],
[
'Forth link https://www.bla.org/hello/ with slash',
'https://www.bla.org/hello/',
],
[
'Fifth link https://www.bla.org/hello/file.png file with extension',
'https://www.bla.org/hello/file.png',
],
[
'Sixth link https://www.bla.org/hello/file.png?aa=bb query parameters',
'https://www.bla.org/hello/file.png?aa=bb',
],
[
'Seventh link https://www.bla.org/hello/file.png?aa=%20/bb&cc=d query parameters',
'https://www.bla.org/hello/file.png?aa=%20/bb&cc=d',
],
[
'Eighth link https://www.bla.org/hello/file.png?aa= empty query parameter',
'https://www.bla.org/hello/file.png?aa=',
],
[
'Nineth link http://foo.com/more_(than)_one_(parens) with parentheses',
'http://foo.com/more_(than)_one_(parens)',
],
[
'Tenth link http://foo.com/blah_(wikipedia)#cite-1 with anchor',
'http://foo.com/blah_(wikipedia)#cite-1',
],
[
'Eleventh link http://foo.com/blah_(wikipedia)_blah#cite-1 with anchor',
'http://foo.com/blah_(wikipedia)_blah#cite-1',
],
[
'Twelveth link http://foo.com/unicode_(✪)_in_parens unicode',
'http://foo.com/unicode_(✪)_in_parens',
],
[
'Thirteenth link http://foo.com/(something)?after=parens query params',
'http://foo.com/(something)?after=parens',
],
]
@Component({
template: `<div [gnUiLinkify]>Click this link https://www.example.com/</div>`,
template: `<div [gnUiLinkify]>{{ text }}</div>`,
})
class TestComponent {}
class TestComponent {
text = ''
}

describe('GnUiLinkifyDirective', () => {
let fixture: ComponentFixture<TestComponent>
Expand All @@ -20,26 +71,32 @@ describe('GnUiLinkifyDirective', () => {

fixture = TestBed.createComponent(TestComponent)
component = fixture.componentInstance
debugElement = fixture.debugElement.query(
By.directive(GnUiLinkifyDirective)
)

fixture.detectChanges()
}))

it('should create an anchor element with the correct href', () => {
fixture.detectChanges()
const anchorElement = debugElement.query(By.css('a'))

const href = anchorElement.nativeElement.getAttribute('href')
expect(href).toBe('https://www.example.com/')
describe('should create an anchor element with the correct href', () => {
test.each(testingUrls)(
'for %p it should create href %p',
async (input, output) => {
component.text = input
fixture.detectChanges()
await fixture.whenStable()
const href = getAnchorElement().nativeElement.getAttribute('href')
expect(href).toBe(output)
}
)
})

it('should have the target attribute set to "_blank"', () => {
it('should have the target attribute set to "_blank"', async () => {
component.text = 'Click this link https://www.example.com/'
fixture.detectChanges()
const anchorElement = debugElement.query(By.css('a'))

const target = anchorElement.nativeElement.getAttribute('target')
await fixture.whenStable()
const target = getAnchorElement().nativeElement.getAttribute('target')
expect(target).toBe('_blank')
})
function getAnchorElement() {
debugElement = fixture.debugElement.query(
By.directive(GnUiLinkifyDirective)
)
return debugElement.query(By.css('a'))
}
})
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ export class GnUiLinkifyDirective implements OnInit {
}

private linkifyText(text: string): string {
return text.replace(/(\bhttps?:\/\/\S+\b\/?)/g, (match) => {
return text.replace(/(\bhttps?:\/\/\S+\b[=)/]?)/g, (match) => {
return `<a href="${match}" target="_blank"
class="text-primary cursor-pointer hover:underline">${match} <mat-icon class="material-symbols-outlined !w-[12px] !h-[14px] !text-[14px] opacity-75">open_in_new</mat-icon></a>`
})
Expand Down

0 comments on commit a44eb0f

Please sign in to comment.