Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

bug: stencil dev mode with React component wrappers #6083

Open
3 tasks done
MarcHbb opened this issue Dec 18, 2024 · 7 comments
Open
3 tasks done

bug: stencil dev mode with React component wrappers #6083

MarcHbb opened this issue Dec 18, 2024 · 7 comments
Labels
ionitron: needs reproduction This PR or Issue does not have a reproduction case URL

Comments

@MarcHbb
Copy link

MarcHbb commented Dec 18, 2024

Prerequisites

Stencil Version

4.23

Current Behavior

I've followed the guidelines from documentation and succeed to have my stencil component created in react-library, which is imported in my next app. It works !

But when trying to run stencil start command (--dev --watch) to have live update while updating components.
I had an import error saying @react-library/dist/my-component does not exists

Expected Behavior

Having my next app udpated with my stencil component updated when editing it

System Info

No response

Steps to Reproduce

Follow the documentation about integrating stencil component in react environnement
Then run pnpm start in /stencil folder

Code Reproduction URL

private

Additional Information

In dev mode I figure out that in the output react wrappers, it was still looking for in /dist/components/my-component.js in my stencil package

but in dev mode, component are served in /www folder and only types are exported in /dist

Tried to add type: "www" in reactOutputTarget, my react wrappers was still looking for /dist/components/my-component.js

Tried to add a condition in stencil config :

{
	type: "dist-custom-elements",
	externalRuntime: false,
	dir: isDevMode ? "www/build" : "dist/components",
}

The output is my react wrapper update perfectly and now instead of having /dist/components/my-component.js I have
/build/www/my-component.js

@ionitron-bot ionitron-bot bot added the triage label Dec 18, 2024
@johnjenkins
Copy link
Contributor

johnjenkins commented Dec 18, 2024

Hey! 👋
can you try with https://stenciljs.com/docs/config#builddist ?

@MarcHbb
Copy link
Author

MarcHbb commented Dec 18, 2024

Hello ! Thanks for your answer
Not sure If i get it right, but when building with buildDist set to false, the output in my react wrapper still importing from stencil /dist folder.

stencil config :

import type { Config } from "@stencil/core";
import { reactOutputTarget } from "@stencil/react-output-target";

// const isDevMode = process.argv.includes("--dev");

export const config: Config = {
	namespace: "stencil",
	buildDist: false,
	outputTargets: [
		reactOutputTarget({
			// Relative path to where the React components will be generated
			outDir: "../react-library/lib/components/stencil-generated/",
		}),
		{
			type: "www", // Serve your components during development
			serviceWorker: null, // Disable service workers
		},
		// dist-custom-elements output target is required for the React output target
		{
			type: "dist-custom-elements",
			externalRuntime: false,
		},
	],
	devServer: {
		openBrowser: false, // Don't open the browser by default
	},
};

output (in react-library/lib) :

'use client';

/**
 * This file was automatically generated by the Stencil React Output Target.
 * Changes to this file may cause incorrect behavior and will be lost if the code is regenerated.
 */

/* eslint-disable */

import { CustomButton as CustomButtonElement, defineCustomElement as defineCustomButton } from "@stencil-custom/dist/components/custom-button.js";
import { MyComponent as MyComponentElement, defineCustomElement as defineMyComponent } from "@stencil-custom/dist/components/my-component.js";
import type { StencilReactComponent } from '@stencil/react-output-target/runtime';
import { createComponent } from '@stencil/react-output-target/runtime';
import React from 'react';

type CustomButtonEvents = NonNullable<unknown>;

export const CustomButton: StencilReactComponent<CustomButtonElement, CustomButtonEvents> = /*@__PURE__*/ createComponent<CustomButtonElement, CustomButtonEvents>({
    tagName: 'custom-button',
    elementClass: CustomButtonElement,
    // @ts-ignore - React type of Stencil Output Target may differ from the React version used in the Nuxt.js project, this can be ignored.
    react: React,
    events: {} as CustomButtonEvents,
    defineCustomElement: defineCustomButton
});

type MyComponentEvents = NonNullable<unknown>;

export const MyComponent: StencilReactComponent<MyComponentElement, MyComponentEvents> = /*@__PURE__*/ createComponent<MyComponentElement, MyComponentEvents>({
    tagName: 'my-component',
    elementClass: MyComponentElement,
    // @ts-ignore - React type of Stencil Output Target may differ from the React version used in the Nuxt.js project, this can be ignored.
    react: React,
    events: {} as MyComponentEvents,
    defineCustomElement: defineMyComponent
});

As you can see, we still importing from @stencil-custom/dist/components/custom-button.js but there's only .d.ts files in dev mode in /dist folder

This is my /dist folder :
Capture d’écran 2024-12-18 à 18 42 25

@johnjenkins
Copy link
Contributor

I believe buildDist should be set to true 🙂

@MarcHbb
Copy link
Author

MarcHbb commented Dec 18, 2024

For development ?
From the doc

default: true (prod), false (dev)
Defaults to false when building for development and true when building for production

Anyway I've tested with buildDist set to true and it still import from /dist folder on development mode ...

@MarcHbb
Copy link
Author

MarcHbb commented Dec 18, 2024

I've tried to remove the --dev from the command line.
====> stencil build --watch --serve
So this way, it's always importing from /dist folder, and when I make an update, it live updated in the output dir. That is working fine (I dont know all the the cons of using prod build for development but I have no choice)

But still this is another issue.... My next app is not importing from stencil but from react-library. So even if the output is live updated in my react-library (/lib folder), the /dist folder in react-library is not updated, so my next app still not have the update.
I don't know if it is clear, but when using stencil build --watch --serve, i need also to update (build) my react-library /dist folder to have the live update in my next app. I don't know how to do that

@christian-bromann
Copy link
Member

But when trying to run stencil start command (--dev --watch) to have live update while updating components. I had an import error saying @react-library/dist/my-component does not exists

Can you share an example for this?

@christian-bromann christian-bromann added ionitron: needs reproduction This PR or Issue does not have a reproduction case URL and removed triage labels Jan 23, 2025
Copy link

ionitron-bot bot commented Jan 23, 2025

Thanks for the issue! This issue has been labeled as needs reproduction. This label is added to issues that need a code reproduction.

Please reproduce this issue in an Stencil starter component library and provide a way for us to access it (GitHub repo, StackBlitz, etc). Without a reliable code reproduction, it is unlikely we will be able to resolve the issue, leading to it being closed.

If you have already provided a code snippet and are seeing this message, it is likely that the code snippet was not enough for our team to reproduce the issue.

For a guide on how to create a good reproduction, see our Contributing Guide.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
ionitron: needs reproduction This PR or Issue does not have a reproduction case URL
Projects
None yet
Development

No branches or pull requests

3 participants