2020-11-20 16:04:47 +00:00
|
|
|
import linkReplacement from './linkReplacement';
|
2023-02-17 05:13:28 -08:00
|
|
|
import { describe, test, expect } from '@jest/globals';
|
2020-11-20 16:04:47 +00:00
|
|
|
|
|
|
|
describe('linkReplacement', () => {
|
|
|
|
|
|
|
|
test('should handle non-resource links', () => {
|
2020-12-09 21:30:51 +00:00
|
|
|
const r = linkReplacement('https://example.com/test').html;
|
2023-06-14 17:45:13 +01:00
|
|
|
expect(r).toBe('<a data-from-md href=\'https://example.com/test\' onclick=\'postMessage("https://example.com/test", { resourceId: "" }); return false;\'>');
|
2020-11-20 16:04:47 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
test('should handle non-resource links - simple rendering', () => {
|
2020-12-09 21:30:51 +00:00
|
|
|
const r = linkReplacement('https://example.com/test', { linkRenderingType: 2 }).html;
|
2020-11-20 16:04:47 +00:00
|
|
|
expect(r).toBe('<a data-from-md href=\'https://example.com/test\'>');
|
|
|
|
});
|
|
|
|
|
2021-11-08 15:38:44 +00:00
|
|
|
test('should handle non-resource links with single quotes in it', () => {
|
|
|
|
// Handles a link such as:
|
|
|
|
// [Google](https://www.goo'onclick=javascript:alert(/1/);f=')
|
|
|
|
const r = linkReplacement('https://www.goo\'onclick=javascript:alert(/1/);f=\'', { linkRenderingType: 1 }).html;
|
2023-06-14 17:45:13 +01:00
|
|
|
expect(r).toBe('<a data-from-md href=\'https://www.goo'onclick=javascript:alert(/1/);f='\' onclick=\'postMessage("https://www.goo%27onclick=javascript:alert(/1/);f=%27", { resourceId: "" }); return false;\'>');
|
2021-11-08 15:38:44 +00:00
|
|
|
});
|
|
|
|
|
2020-11-20 16:04:47 +00:00
|
|
|
test('should handle resource links - downloaded status', () => {
|
|
|
|
const resourceId = 'f6afba55bdf74568ac94f8d1e3578d2c';
|
|
|
|
|
|
|
|
const r = linkReplacement(`:/${resourceId}`, {
|
|
|
|
ResourceModel: {},
|
|
|
|
resources: {
|
|
|
|
[resourceId]: {
|
|
|
|
item: {},
|
|
|
|
localState: {
|
|
|
|
fetch_status: 2, // FETCH_STATUS_DONE
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2020-12-09 21:30:51 +00:00
|
|
|
}).html;
|
2020-11-20 16:04:47 +00:00
|
|
|
|
2023-06-14 17:45:13 +01:00
|
|
|
expect(r).toBe(`<a data-from-md data-resource-id='${resourceId}' href='#' onclick='postMessage("joplin://${resourceId}", { resourceId: "${resourceId}" }); return false;'><span class="resource-icon fa-joplin"></span>`);
|
2020-11-20 16:04:47 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
test('should handle resource links - idle status', () => {
|
|
|
|
const resourceId = 'f6afba55bdf74568ac94f8d1e3578d2c';
|
|
|
|
|
|
|
|
const r = linkReplacement(`:/${resourceId}`, {
|
|
|
|
ResourceModel: {},
|
|
|
|
resources: {
|
|
|
|
[resourceId]: {
|
|
|
|
item: {},
|
|
|
|
localState: {
|
|
|
|
fetch_status: 0, // FETCH_STATUS_IDLE
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2020-12-09 21:30:51 +00:00
|
|
|
}).html;
|
2020-11-20 16:04:47 +00:00
|
|
|
|
|
|
|
// Since the icon is embedded as SVG, we only check for the prefix
|
|
|
|
const expectedPrefix = `<a class="not-loaded-resource resource-status-notDownloaded" data-resource-id="${resourceId}"><img src="data:image/svg+xml;utf8`;
|
|
|
|
expect(r.indexOf(expectedPrefix)).toBe(0);
|
|
|
|
});
|
|
|
|
|
2023-02-17 05:13:28 -08:00
|
|
|
test('should create ontouch listeners to handle longpress', () => {
|
|
|
|
const resourceId = 'e6afba55bdf74568ac94f8d1e3578d2c';
|
|
|
|
|
|
|
|
const linkHtml = linkReplacement(`:/${resourceId}`, {
|
|
|
|
ResourceModel: {},
|
|
|
|
resources: {
|
|
|
|
[resourceId]: {
|
|
|
|
item: {},
|
|
|
|
localState: {
|
|
|
|
fetch_status: 2, // FETCH_STATUS_DONE
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
enableLongPress: true,
|
|
|
|
}).html;
|
|
|
|
|
|
|
|
expect(linkHtml).toContain('ontouchstart');
|
|
|
|
expect(linkHtml).toContain('ontouchend');
|
|
|
|
expect(linkHtml).toContain('ontouchcancel');
|
|
|
|
});
|
2020-11-20 16:04:47 +00:00
|
|
|
});
|