Skip to content

Commit

Permalink
transition anys
Browse files Browse the repository at this point in the history
  • Loading branch information
staylor committed Nov 8, 2023
1 parent 9442cbd commit 375127e
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 12 deletions.
4 changes: 3 additions & 1 deletion __tests__/window.ts
Original file line number Diff line number Diff line change
@@ -1,12 +1,14 @@
import { JSDOM } from 'jsdom';
import type { DOMWindow } from 'jsdom';

const jsdom = new JSDOM('<!doctype html><html><body><div id="mount"></div></body></html>', {
url: 'https://nytimes.com',
});
const { window } = jsdom;

function copyProps(src: any, target: any) {
function copyProps(src: DOMWindow, target: typeof globalThis) {
const props = Object.getOwnPropertyNames(src)
// @ts-ignore
.filter(prop => typeof target[prop] === 'undefined')
.reduce(
(result, prop) => ({
Expand Down
29 changes: 18 additions & 11 deletions src/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,8 @@ export * from './types';
export { default as HelmetData } from './HelmetData';
export { default as HelmetProvider } from './Provider';

type Props = { [key: string]: any };

export class Helmet extends Component<PropsWithChildren<HelmetProps>> {
static defaultProps = {
defer: true,
Expand Down Expand Up @@ -52,10 +54,10 @@ export class Helmet extends Component<PropsWithChildren<HelmetProps>> {
}

flattenArrayTypeChildren(
child: any,
arrayTypeChildren: any,
newChildProps: any,
nestedChildren: any
child: JSX.Element,
arrayTypeChildren: { [key: string]: JSX.Element[] },
newChildProps: Props,
nestedChildren: ReactNode
) {
return {
...arrayTypeChildren,
Expand All @@ -69,7 +71,12 @@ export class Helmet extends Component<PropsWithChildren<HelmetProps>> {
};
}

mapObjectTypeChildren(child: any, newProps: any, newChildProps: any, nestedChildren: any) {
mapObjectTypeChildren(
child: JSX.Element,
newProps: Props,
newChildProps: Props,
nestedChildren: ReactNode
) {
switch (child.type) {
case TAG_NAMES.TITLE:
return {
Expand Down Expand Up @@ -97,7 +104,7 @@ export class Helmet extends Component<PropsWithChildren<HelmetProps>> {
}
}

mapArrayTypeChildrenToProps(arrayTypeChildren: any, newProps: any) {
mapArrayTypeChildrenToProps(arrayTypeChildren: { [key: string]: JSX.Element }, newProps: Props) {
let newFlattenedProps = { ...newProps };

Object.keys(arrayTypeChildren).forEach(arrayChildName => {
Expand All @@ -110,7 +117,7 @@ export class Helmet extends Component<PropsWithChildren<HelmetProps>> {
return newFlattenedProps;
}

warnOnInvalidChildren(child: any, nestedChildren: any) {
warnOnInvalidChildren(child: JSX.Element, nestedChildren: ReactNode) {
invariant(
VALID_TAG_NAMES.some(name => child.type === name),
typeof child.type === 'function'
Expand All @@ -133,24 +140,24 @@ export class Helmet extends Component<PropsWithChildren<HelmetProps>> {
return true;
}

mapChildrenToProps(children: any, newProps: any) {
mapChildrenToProps(children: ReactNode, newProps: Props) {
let arrayTypeChildren = {};

React.Children.forEach(children, child => {
React.Children.forEach(children as JSX.Element, (child: ReactElement) => {
if (!child || !child.props) {
return;
}

const { children: nestedChildren, ...childProps } = child.props;
// convert React props to HTML attributes
const newChildProps = Object.keys(childProps).reduce((obj: any, key) => {
const newChildProps = Object.keys(childProps).reduce((obj: Props, key) => {
obj[HTML_TAG_MAP[key] || key] = childProps[key];
return obj;
}, {});

let { type } = child;
if (typeof type === 'symbol') {
type = type.toString();
type = (type as 'symbol').toString();
} else {
this.warnOnInvalidChildren(child, nestedChildren);
}
Expand Down

0 comments on commit 375127e

Please sign in to comment.