Skip to content

Commit

Permalink
[FIXUP] passing wrong object for transforming refs (#1546)
Browse files Browse the repository at this point in the history
* [FIXUP] passing wrong object for transforming refs

* adding changeset and test cases

* Removed additional testcases lit-ref.raw.tsx

---------

Co-authored-by: raghul.kumar <[email protected]>
  • Loading branch information
newbie95 and raghul-kumar-5580 authored Oct 15, 2024
1 parent 1ead36c commit d13e693
Show file tree
Hide file tree
Showing 3 changed files with 51 additions and 45 deletions.
6 changes: 6 additions & 0 deletions .changeset/gentle-chefs-type.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
---
'@builder.io/mitosis': patch
---

[LIT] Bug: Passing wrong object for transforming ref(Element ref) result in breakage

88 changes: 44 additions & 44 deletions packages/core/src/__tests__/__snapshots__/lit.test.ts.snap
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ export default class MyBasicRefComponent extends LitElement {

onBlur = function onBlur() {
// Maintain focus
inputRef.focus();
this.inputRef.focus();
};
lowerCaseName = function lowerCaseName() {
return this.name.toLowerCase();
Expand Down Expand Up @@ -428,7 +428,7 @@ export default class MyBasicRefComponent extends LitElement {

onBlur = function onBlur() {
// Maintain focus
inputRef.focus();
this.inputRef.focus();
};
lowerCaseName = function lowerCaseName() {
return this.name.toLowerCase();
Expand Down Expand Up @@ -476,8 +476,8 @@ export default class MyBasicRefAssignmentComponent extends LitElement {

handlerClick = function handlerClick(event) {
event.preventDefault();
console.log(\\"current value\\", holdValueRef);
holdValueRef = holdValueRef + \\"JS\\";
console.log(\\"current value\\", this.holdValueRef);
this.holdValueRef = this.holdValueRef + \\"JS\\";
};

render() {
Expand Down Expand Up @@ -517,7 +517,7 @@ export default class MyPreviousComponent extends LitElement {
@state() count = 0;

updated() {
prevCount = this.count;
this.prevCount = this.count;
}

render() {
Expand All @@ -527,7 +527,7 @@ export default class MyPreviousComponent extends LitElement {
Now:
\${this.count}
, before:
\${prevCount}</h1>
\${this.prevCount}</h1>
<button @click=\${(event) =>
(this.count += 1)} >Increment</button></div>
\`;
Expand Down Expand Up @@ -756,9 +756,9 @@ export default class CustomCode extends LitElement {

findAndRunScripts() {
// TODO: Move this function to standalone one in '@builder.io/utils'
if (elem && typeof window !== \\"undefined\\") {
if (this.elem && typeof window !== \\"undefined\\") {
/** @type {HTMLScriptElement[]} */
const scripts = elem.getElementsByTagName(\\"script\\");
const scripts = this.elem.getElementsByTagName(\\"script\\");

for (let i = 0; i < scripts.length; i++) {
const script = scripts[i];
Expand Down Expand Up @@ -831,9 +831,9 @@ export default class CustomCode extends LitElement {

findAndRunScripts() {
// TODO: Move this function to standalone one in '@builder.io/utils'
if (elem && typeof window !== \\"undefined\\") {
if (this.elem && typeof window !== \\"undefined\\") {
/** @type {HTMLScriptElement[]} */
const scripts = elem.getElementsByTagName(\\"script\\");
const scripts = this.elem.getElementsByTagName(\\"script\\");

for (let i = 0; i < scripts.length; i++) {
const script = scripts[i];
Expand Down Expand Up @@ -1041,8 +1041,8 @@ export default class FormComponent extends LitElement {
},
});

if (formRef) {
formRef.dispatchEvent(presubmitEvent);
if (this.formRef) {
this.formRef.dispatchEvent(presubmitEvent);

if (presubmitEvent.defaultPrevented) {
return;
Expand Down Expand Up @@ -1100,28 +1100,28 @@ export default class FormComponent extends LitElement {
},
});

if (formRef) {
formRef.dispatchEvent(submitSuccessEvent);
if (this.formRef) {
this.formRef.dispatchEvent(submitSuccessEvent);

if (submitSuccessEvent.defaultPrevented) {
return;
}
/* TODO: option to turn this on/off? */

if (this.resetFormOnSubmit !== false) {
formRef.reset();
this.formRef.reset();
}
}
/* TODO: client side route event first that can be preventDefaulted */

if (this.successUrl) {
if (formRef) {
if (this.formRef) {
const event = new CustomEvent(\\"route\\", {
detail: {
url: this.successUrl,
},
});
formRef.dispatchEvent(event);
this.formRef.dispatchEvent(event);

if (!event.defaultPrevented) {
location.href = this.successUrl;
Expand All @@ -1139,8 +1139,8 @@ export default class FormComponent extends LitElement {
},
});

if (formRef) {
formRef.dispatchEvent(submitErrorEvent);
if (this.formRef) {
this.formRef.dispatchEvent(submitErrorEvent);

if (submitErrorEvent.defaultPrevented) {
return;
Expand Down Expand Up @@ -1241,8 +1241,8 @@ export default class Image extends LitElement {
if (this.useLazyLoading()) {
// throttled scroll capture listener
const listener = () => {
if (pictureRef) {
const rect = pictureRef.getBoundingClientRect();
if (this.pictureRef) {
const rect = this.pictureRef.getBoundingClientRect();
const buffer = window.innerHeight / 2;

if (rect.top < window.innerHeight + buffer) {
Expand Down Expand Up @@ -2779,7 +2779,7 @@ export default class Embed extends LitElement {
}

connectedCallback() {
elem.dispatchEvent(new CustomEvent(\\"initEditingBldr\\"));
this.elem.dispatchEvent(new CustomEvent(\\"initEditingBldr\\"));
}

render() {
Expand Down Expand Up @@ -4267,7 +4267,7 @@ export default class MyBasicRefComponent extends LitElement {

onBlur = function onBlur() {
// Maintain focus
inputRef.focus();
this.inputRef.focus();
};
lowerCaseName = function lowerCaseName() {
return this.name.toLowerCase();
Expand Down Expand Up @@ -4691,7 +4691,7 @@ export default class MyBasicRefComponent extends LitElement {

onBlur = function onBlur() {
// Maintain focus
inputRef.focus();
this.inputRef.focus();
};
lowerCaseName = function lowerCaseName() {
return this.name.toLowerCase();
Expand Down Expand Up @@ -4743,8 +4743,8 @@ export default class MyBasicRefAssignmentComponent extends LitElement {

handlerClick = function handlerClick(event: Event) {
event.preventDefault();
console.log(\\"current value\\", holdValueRef);
holdValueRef = holdValueRef + \\"JS\\";
console.log(\\"current value\\", this.holdValueRef);
this.holdValueRef = this.holdValueRef + \\"JS\\";
};

render() {
Expand Down Expand Up @@ -4788,7 +4788,7 @@ export default class MyPreviousComponent extends LitElement {
@state() count = 0;

updated() {
prevCount = this.count;
this.prevCount = this.count;
}

render() {
Expand All @@ -4798,7 +4798,7 @@ export default class MyPreviousComponent extends LitElement {
Now:
\${this.count}
, before:
\${prevCount}</h1>
\${this.prevCount}</h1>
<button @click=\${(event) =>
(this.count += 1)} >Increment</button></div>
\`;
Expand Down Expand Up @@ -5067,9 +5067,9 @@ export default class CustomCode extends LitElement {

findAndRunScripts() {
// TODO: Move this function to standalone one in '@builder.io/utils'
if (elem && typeof window !== \\"undefined\\") {
if (this.elem && typeof window !== \\"undefined\\") {
/** @type {HTMLScriptElement[]} */
const scripts = elem.getElementsByTagName(\\"script\\");
const scripts = this.elem.getElementsByTagName(\\"script\\");

for (let i = 0; i < scripts.length; i++) {
const script = scripts[i];
Expand Down Expand Up @@ -5147,9 +5147,9 @@ export default class CustomCode extends LitElement {

findAndRunScripts() {
// TODO: Move this function to standalone one in '@builder.io/utils'
if (elem && typeof window !== \\"undefined\\") {
if (this.elem && typeof window !== \\"undefined\\") {
/** @type {HTMLScriptElement[]} */
const scripts = elem.getElementsByTagName(\\"script\\");
const scripts = this.elem.getElementsByTagName(\\"script\\");

for (let i = 0; i < scripts.length; i++) {
const script = scripts[i];
Expand Down Expand Up @@ -5388,8 +5388,8 @@ export default class FormComponent extends LitElement {
},
});

if (formRef) {
formRef.dispatchEvent(presubmitEvent);
if (this.formRef) {
this.formRef.dispatchEvent(presubmitEvent);

if (presubmitEvent.defaultPrevented) {
return;
Expand Down Expand Up @@ -5447,28 +5447,28 @@ export default class FormComponent extends LitElement {
},
});

if (formRef) {
formRef.dispatchEvent(submitSuccessEvent);
if (this.formRef) {
this.formRef.dispatchEvent(submitSuccessEvent);

if (submitSuccessEvent.defaultPrevented) {
return;
}
/* TODO: option to turn this on/off? */

if (this.resetFormOnSubmit !== false) {
formRef.reset();
this.formRef.reset();
}
}
/* TODO: client side route event first that can be preventDefaulted */

if (this.successUrl) {
if (formRef) {
if (this.formRef) {
const event = new CustomEvent(\\"route\\", {
detail: {
url: this.successUrl,
},
});
formRef.dispatchEvent(event);
this.formRef.dispatchEvent(event);

if (!event.defaultPrevented) {
location.href = this.successUrl;
Expand All @@ -5486,8 +5486,8 @@ export default class FormComponent extends LitElement {
},
});

if (formRef) {
formRef.dispatchEvent(submitErrorEvent);
if (this.formRef) {
this.formRef.dispatchEvent(submitErrorEvent);

if (submitErrorEvent.defaultPrevented) {
return;
Expand Down Expand Up @@ -5610,8 +5610,8 @@ export default class Image extends LitElement {
if (this.useLazyLoading()) {
// throttled scroll capture listener
const listener = () => {
if (pictureRef) {
const rect = pictureRef.getBoundingClientRect();
if (this.pictureRef) {
const rect = this.pictureRef.getBoundingClientRect();
const buffer = window.innerHeight / 2;

if (rect.top < window.innerHeight + buffer) {
Expand Down Expand Up @@ -7335,7 +7335,7 @@ export default class Embed extends LitElement {
}

connectedCallback() {
elem.dispatchEvent(new CustomEvent(\\"initEditingBldr\\"));
this.elem.dispatchEvent(new CustomEvent(\\"initEditingBldr\\"));
}

render() {
Expand Down
2 changes: 1 addition & 1 deletion packages/core/src/generators/lit/generate.ts
Original file line number Diff line number Diff line change
Expand Up @@ -138,7 +138,7 @@ export const componentToLit: TranspilerGenerator<ToLitOptions> =
let css = collectCss(json);

const domRefs = getRefs(json);
mapRefs(component, (refName) => `this.${camelCase(refName)}`);
mapRefs(json, (refName) => `this.${camelCase(refName)}`);

if (options.plugins) {
json = runPostJsonPlugins({ json, plugins: options.plugins });
Expand Down

0 comments on commit d13e693

Please sign in to comment.