-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathbuild.js
2 lines (2 loc) · 24.9 KB
/
build.js
1
2
module.exports=function(e){var t={};function r(o){if(t[o])return t[o].exports;var n=t[o]={i:o,l:!1,exports:{}};return e[o].call(n.exports,n,n.exports,r),n.l=!0,n.exports}return r.m=e,r.c=t,r.d=function(e,t,o){r.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:o})},r.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},r.t=function(e,t){if(1&t&&(e=r(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var o=Object.create(null);if(r.r(o),Object.defineProperty(o,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var n in e)r.d(o,n,function(t){return e[t]}.bind(null,n));return o},r.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return r.d(t,"a",t),t},r.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},r.p="",r(r.s=4)}([function(e,t){e.exports=require("react")},function(e,t,r){"use strict";var o=r(2);t.createRoot=o.createRoot,t.hydrateRoot=o.hydrateRoot},function(e,t){e.exports=require("react-dom")},function(e,t){function r(){var e,t=this.parentNode,r=arguments.length;if(t)for(r||t.removeChild(this);r--;)"object"!=typeof(e=arguments[r])?e=this.ownerDocument.createTextNode(e):e.parentNode&&e.parentNode.removeChild(e),r?t.insertBefore(this.previousSibling,e):t.replaceChild(e,this)}Element.prototype.replaceWith||(Element.prototype.replaceWith=r),CharacterData.prototype.replaceWith||(CharacterData.prototype.replaceWith=r),DocumentType.prototype.replaceWith||(DocumentType.prototype.replaceWith=r)},function(e,t,r){"use strict";r.r(t);var o=r(1),n=r(0),s=r.n(n),i=(r(3),s.a.createRef||function(){var e=function(t){e.current=t};return e(null),e});class c extends s.a.Component{constructor(){super(...arguments),this.ref=i()}componentDidMount(){const e=this.props.children;this.ref.current.replaceWith(...e)}render(){return s.a.createElement("div",{ref:this.ref})}}const a=(e,t,r,n)=>{class c extends s.a.PureComponent{constructor(){super(...arguments),this.state=Object.assign({},t),this.setProps=e=>this.setState(()=>e)}render(){return s.a.createElement(e,Object.assign({},this.props,this.state))}}const a=i();Object(o.createRoot)(r).render(s.a.createElement(()=>(s.a.useEffect(()=>{n(a)},[]),s.a.createElement(c,{ref:a})),null))};r.d(t,"registerAsWebComponent",(function(){return p}));const u=(e,t)=>class extends HTMLElement{constructor(){switch(super(),this.targetNode=null,this.propBridgeRef=null,this.props={},this.observer=null,this.setProps=e=>{var t,r;this.props=Object.assign(Object.assign({},this.props),e),t=this.propBridgeRef,r=this.props,t&&t.current&&t.current.setProps(r)},this._onReactMount=e=>{this.propBridgeRef=e,this.setProps(this.props)},this._onMutation=e=>{const t=e.reduce((e,t)=>{if("attributes"===t.type){const r=t.attributeName;e[r]=this.getAttribute(r)}return e},{});this.setProps(t)},this.props=(e=>{const t=e.getAttributeNames().reduce((t,r)=>(t[r]=e.getAttribute(r),t),{}),r=Array.from(e.childNodes).map(e=>e.cloneNode(!0));return t.children=s.a.createElement(c,null,r),t})(this),this.observer=new MutationObserver(this._onMutation),t){case"open":this.targetNode=this.attachShadow({mode:"open"});break;case"element":this.targetNode=this;break;default:this.targetNode=this.attachShadow({mode:"closed"})}a(e,this.props,this.targetNode,this._onReactMount)}connectedCallback(){this.observer.observe(this,{attributes:!0})}disconnectedCallback(){const{unmount:e}=Object(o.createRoot)(this.targetNode);e(),this.observer.disconnect()}},p=(e,t,r)=>{const o=u(e,r);customElements.define(t,o)}}]);
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///webpack/bootstrap","webpack:///external {\"root\":\"React\",\"commonjs2\":\"react\",\"commonjs\":\"react\",\"amd\":\"react\",\"umd\":\"react\"}","webpack:///./node_modules/react-dom/client.js","webpack:///external {\"root\":\"ReactDOM\",\"commonjs2\":\"react-dom\",\"commonjs\":\"react-dom\",\"amd\":\"react-dom\",\"umd\":\"react-dom\"}","webpack:///./node_modules/child-replace-with-polyfill/index.js","webpack:///./node_modules/react-create-ref/index.js","webpack:///./src/react-dom-child.tsx","webpack:///./src/prop-bridge.tsx","webpack:///./src/index.ts"],"names":["installedModules","__webpack_require__","moduleId","exports","module","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","require","createRoot","hydrateRoot","ReplaceWithPolyfill","currentNode","parent","this","parentNode","arguments","length","removeChild","ownerDocument","createTextNode","insertBefore","previousSibling","replaceChild","Element","replaceWith","CharacterData","DocumentType","createRef","ref","_","current","Component","childNodes","props","children","renderReact2Node","RComponent","initialProps","targetDomNode","onRender","PropBridge","PureComponent","state","setProps","setState","propBridgeRef","render","useEffect","getCustomElementFromReactComponent","HTMLElement","super","targetNode","observer","newProps","_onReactMount","_onMutation","mutationsList","reduce","mutation","type","propKey","attributeName","getAttribute","node","mappedProps","getAttributeNames","Array","from","map","e","cloneNode","getPropsFromNode","MutationObserver","attachShadow","observe","attributes","unmount","disconnect","registerAsWebComponent","component","customElementName","ReactCustomElement","customElements","define"],"mappings":"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","file":"build.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 4);\n","module.exports = require(\"react\");","'use strict';\n\nvar m = require('react-dom');\nif (process.env.NODE_ENV === 'production') {\n  exports.createRoot = m.createRoot;\n  exports.hydrateRoot = m.hydrateRoot;\n} else {\n  var i = m.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;\n  exports.createRoot = function(c, o) {\n    i.usingClientEntryPoint = true;\n    try {\n      return m.createRoot(c, o);\n    } finally {\n      i.usingClientEntryPoint = false;\n    }\n  };\n  exports.hydrateRoot = function(c, h, o) {\n    i.usingClientEntryPoint = true;\n    try {\n      return m.hydrateRoot(c, h, o);\n    } finally {\n      i.usingClientEntryPoint = false;\n    }\n  };\n}\n","module.exports = require(\"react-dom\");","// From https://developer.mozilla.org/en-US/docs/Web/API/ChildNode/replaceWith\nfunction ReplaceWithPolyfill() {\n  \"use-strict\"; // For safari, and IE > 10\n  var parent = this.parentNode,\n    i = arguments.length,\n    currentNode;\n  if (!parent) return;\n  if (!i)\n    // if there are no arguments\n    parent.removeChild(this);\n  while (i--) {\n    // i-- decrements i and returns the value of i before the decrement\n    currentNode = arguments[i];\n    if (typeof currentNode !== \"object\") {\n      currentNode = this.ownerDocument.createTextNode(currentNode);\n    } else if (currentNode.parentNode) {\n      currentNode.parentNode.removeChild(currentNode);\n    }\n    // the value of \"i\" below is after the decrement\n    if (!i)\n      // if currentNode is the first argument (currentNode === arguments[0])\n      parent.replaceChild(currentNode, this);\n    // if currentNode isn't the first\n    else parent.insertBefore(this.previousSibling, currentNode);\n  }\n}\n\nif (!Element.prototype.replaceWith)\n  Element.prototype.replaceWith = ReplaceWithPolyfill;\nif (!CharacterData.prototype.replaceWith)\n  CharacterData.prototype.replaceWith = ReplaceWithPolyfill;\nif (!DocumentType.prototype.replaceWith)\n  DocumentType.prototype.replaceWith = ReplaceWithPolyfill;\n","import React from 'react'\r\n\r\nexport default React.createRef || function createRef() {\r\n  var ref = function(_) { ref.current = _ }\r\n  ref(null)\r\n  return ref\r\n}\r\n","import React from 'react';\nimport 'child-replace-with-polyfill';\nimport createRef from 'react-create-ref';\n\n/*\n Wrapper class to wrap the raw html nodes in a \n react component before passing it down to react as children\n*/\ntype PropsWithChildren<P = unknown> = P & { children?: Node[] | undefined };\nexport class ReactDomChild extends React.Component<PropsWithChildren> {\n  ref = createRef<HTMLDivElement>();\n  componentDidMount() {\n    const childNodes: Node[] = this.props.children as Node[];\n    this.ref.current.replaceWith(...childNodes);\n  }\n  render() {\n    return <div ref={this.ref} />;\n  }\n}\n","import { createRoot } from 'react-dom/client';\nimport React from 'react';\nimport { ReactDomChild } from './react-dom-child';\nimport createRef from 'react-create-ref';\n\n/*\nPropBridge stores props passed to it via setProps in the state.\nAnd then passes those to the component as regular props\nHence when you call setProps you are calling setState\nand then passing those as props to the react component.\n*/\n\nexport const renderReact2Node = (\n  RComponent: React.ElementType,\n  initialProps: {},\n  targetDomNode: Element | DocumentFragment,\n  onRender: (ref: React.RefObject<any>) => void\n) => {\n  class PropBridge extends React.PureComponent {\n    state = { ...initialProps };\n    setProps = (props: React.RefObject<PropBridge>) =>\n      this.setState(() => props);\n    render() {\n      return <RComponent {...this.props} {...this.state} />;\n    }\n  }\n  const propBridgeRef = createRef<PropBridge>();\n\n  // support react 18\n  const PropBridgeWithCallback = () => {\n    React.useEffect(() => {\n      onRender(propBridgeRef);\n    }, []);\n    return <PropBridge ref={propBridgeRef} />;\n  }\n\n  createRoot(targetDomNode).render(<PropBridgeWithCallback />);\n\n};\n\nexport const sendPropsToReact = (\n  propBridgeRef: React.RefObject<any>,\n  props: any\n) => {\n  if (propBridgeRef && propBridgeRef.current) {\n    propBridgeRef.current.setProps(props);\n  }\n};\n\nexport const getPropsFromNode = (node: HTMLElement) => {\n  const attributeNames = node.getAttributeNames();\n  const mappedProps = attributeNames.reduce(\n    (props: { [key: string]: string | JSX.Element }, name: string) => {\n      props[name] = node.getAttribute(name);\n      return props;\n    },\n    {}\n  );\n\n  const children = Array.from(node.childNodes).map((e) => e.cloneNode(true));\n  mappedProps.children = <ReactDomChild>{children}</ReactDomChild>;\n  return mappedProps;\n};\n","import React from 'react';\nimport { createRoot } from 'react-dom/client';\nimport {\n  renderReact2Node,\n  getPropsFromNode,\n  sendPropsToReact,\n} from './prop-bridge';\n\ntype Mode = 'open' | 'element';\n\nconst getCustomElementFromReactComponent = (\n  RComponent: React.ElementType,\n  mode?: Mode\n) => {\n  return class ReactAsCustomElement extends HTMLElement {\n    targetNode: this | ShadowRoot = null;\n    propBridgeRef: any = null;\n    props = {};\n    observer: MutationObserver = null;\n\n    constructor() {\n      super();\n      this.props = getPropsFromNode(this);\n      this.observer = new MutationObserver(this._onMutation);\n\n      switch (mode) {\n        case 'open':\n          this.targetNode = this.attachShadow({ mode: 'open' });\n          break;\n        case 'element':\n          this.targetNode = this;\n          break;\n        default:\n          this.targetNode = this.attachShadow({ mode: 'closed' });\n          break;\n      }\n\n      renderReact2Node(\n        RComponent,\n        this.props,\n        this.targetNode,\n        this._onReactMount\n      );\n    }\n\n    setProps = (newProps: {}) => {\n      this.props = { ...this.props, ...newProps };\n      sendPropsToReact(this.propBridgeRef, this.props);\n    };\n\n    _onReactMount = (propBridgeRef: React.RefObject<any>) => {\n      this.propBridgeRef = propBridgeRef;\n      this.setProps(this.props);\n    };\n\n    _onMutation = (mutationsList: any[]) => {\n      const newProps = mutationsList.reduce(\n        (\n          props: { [x: string]: string },\n          mutation: { type: string; attributeName: string }\n        ) => {\n          if (mutation.type === 'attributes') {\n            const propKey = mutation.attributeName;\n            props[propKey] = this.getAttribute(propKey);\n          }\n          return props;\n        },\n        {}\n      );\n      this.setProps(newProps);\n    };\n    /*\n        No need to observe child elements here.\n        Child elements are HTMLCollection which are live by default. \n        That means when child elements change the HTMLCollection will change automatically.\n        The reference to HTMLCollection doesnt change, only the items inside it will change.\n        Hence we should just pass through the children (HTMLCollection) as is on first render to react and forget about it.\n    */\n\n    connectedCallback() {\n      this.observer.observe(this, { attributes: true });\n    }\n    disconnectedCallback() {\n      const { unmount } = createRoot(this.targetNode);\n      unmount();\n      this.observer.disconnect();\n    }\n  };\n};\n\n/* mode options:\n  - no option (default) - closed shadow DOM\n  - \"open\" - open shadow DOM\n  - \"element\" - no shadow DOM\n*/\nexport const registerAsWebComponent = (\n  component: React.ElementType,\n  customElementName: string,\n  mode?: Mode\n) => {\n  const ReactCustomElement = getCustomElementFromReactComponent(\n    component,\n    mode\n  );\n  customElements.define(customElementName, ReactCustomElement);\n};\n"],"sourceRoot":""}