UNPKG

@tarojs/components

Version:
74 lines (71 loc) 3.59 kB
import { __rest } from '../node_modules/.pnpm/@rollup_plugin-typescript@11.1.6_rollup@4.18.0_tslib@2.6.2_typescript@5.4.5/node_modules/tslib/tslib.es6.js'; import React, { createElement } from 'react'; import { mergeRefs, createForwardRef } from './utils/index.js'; import { dashToPascalCase, camelToDashCase } from './utils/case.js'; import { applyUnControlledDefaultValue, attachProps, isCoveredByReact } from './utils/attachProps.js'; const createReactComponent = (tagName, ReactComponentContext, manipulatePropsFunction, defineCustomElement) => { if (!DEPRECATED_ADAPTER_COMPONENT && defineCustomElement !== undefined) { defineCustomElement(); } const displayName = dashToPascalCase(tagName); const ReactComponent = class extends React.Component { // eslint-disable-next-line no-useless-constructor constructor(props) { super(props); this.setComponentElRef = (element) => { this.componentEl = element; }; } componentDidMount() { applyUnControlledDefaultValue(this.componentEl, this.props); this.componentDidUpdate(this.props); } componentDidUpdate(prevProps) { attachProps(this.componentEl, this.props, prevProps); } render() { // eslint-disable-next-line @typescript-eslint/no-unused-vars const _a = this.props, { children, forwardedRef, className, ref, style } = _a, cProps = __rest(_a, ["children", "forwardedRef", "className", "ref", "style"]); let propsToPass = Object.keys(cProps).reduce((acc, name) => { const value = cProps[name]; if (name.indexOf('on') === 0 && name[2] === name[2].toUpperCase()) { const eventName = name.substring(2).toLowerCase(); if (typeof document !== 'undefined' && isCoveredByReact(eventName)) { acc[name] = value; } } else { // we should only render strings, booleans, and numbers as attrs in html. // objects, functions, arrays etc get synced via properties on mount. const type = typeof value; if (['string', 'boolean', 'number'].includes(type)) { acc[camelToDashCase(name)] = value; } } return acc; }, {}); if (manipulatePropsFunction) { propsToPass = manipulatePropsFunction(this.props, propsToPass); } const newProps = Object.assign(Object.assign({}, propsToPass), { ref: mergeRefs(forwardedRef, this.setComponentElRef) }); /** * We use createElement here instead of * React.createElement to work around a * bug in Vite (https://github.com/vitejs/vite/issues/6104). * React.createElement causes all elements to be rendered * as <tagname> instead of the actual Web Component. */ return createElement(tagName, newProps, children); } static get displayName() { return displayName; } }; // If context was passed to createReactComponent then conditionally add it to the Component Class if (ReactComponentContext) { ReactComponent.contextType = ReactComponentContext; } return createForwardRef(ReactComponent, displayName); }; export { createReactComponent }; //# sourceMappingURL=createComponent.js.map