-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathoptions.tsx
91 lines (82 loc) · 2.08 KB
/
options.tsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
import {
domToReact,
Element,
type DOMNode,
type HTMLReactParserOptions,
} from 'html-react-parser';
import {
getImageSizeFromAttributes,
getStyleObjectFromString,
} from '@snapwp/core';
import Image from '@/components/image';
import Link from '@/components/link';
export const defaultOptions: HTMLReactParserOptions = {
/**
* Replaces anchor tags with Next.js Link components.
*
* @param {DOMNode} domNode The DOM node being processed.
*
* @return A React element if the node is an anchor tag, otherwise undefined.
*/
replace: ( domNode ) => {
if ( domNode instanceof Element ) {
const { attribs, children, name, type } = domNode;
const { class: className, style, ...attributes } = attribs;
const { href } = attribs;
const styleObject = style
? getStyleObjectFromString( style )
: undefined;
if ( type === 'tag' && name === 'a' ) {
return (
<Link
{ ...attributes }
href={ href }
style={ styleObject }
className={ className }
>
{ domToReact( children as DOMNode[], defaultOptions ) }
</Link>
);
} else if ( type === 'tag' && name === 'img' ) {
const { width, height } = getImageSizeFromAttributes( attribs );
const imageAttributes = {
id: attribs[ 'id' ],
mediaDetails: {
width,
height,
},
};
const shouldFill =
! width &&
! height &&
undefined !== width &&
undefined !== height;
// srcset should be srcSet
if ( attributes[ 'srcset' ] ) {
attributes[ 'srcSet' ] = attributes[ 'srcset' ];
delete attributes[ 'srcset' ];
}
if ( attributes[ 'fetchpriority' ] ) {
attributes[ 'fetchPriority' ] =
attributes[ 'fetchpriority' ];
delete attributes[ 'fetchpriority' ];
}
return (
<Image
{ ...attributes }
src={ attribs[ 'src' ] }
alt={ attribs[ 'alt' ] }
height={ height }
width={ width }
className={ className }
fill={ shouldFill }
style={ styleObject }
image={ imageAttributes }
/>
);
}
return undefined;
}
return undefined;
},
};