-
Notifications
You must be signed in to change notification settings - Fork 83
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
Using Scale with SolidJs #615
Comments
Hi @W1ckh3ad thank you for rising this issue. |
Hi @W1ckh3ad is my privat Account. I will add the answers from the Discord below, but they didn't help me at all ^^ I appreciate your help. |
RyanSolid answered this on my question how to use Webcomponents in Solid "Solid supports Web Components as is without any wrapper generally although we do follow a few conventions which hopefully are compatible with Stencil. Generally we pass all props for web components as properties, converting dash-case to camelCase. If you have specific attributes or properties you want to set that don't follow this convention you can use attr: and prop: namespace on the props." This doesn't help me, but maybe it wil help you. |
@W1ckh3ad Thanks for sharing the answer. Where exactly did you fail? Do you have a repository showing your project's setup you can share? |
Hey @reld, thanks for your help and time I started After that I installed the I added the styles and the polyfills to the index.tsx when I am trying to use the webcomponent in JSX, is vscode telling me I am kinda mad, that I can't it done. My repos here |
Hey @W1ckh3ad I got two examples working on Codesandbox though. and the other without Both work. The only difference is that the Typescript version is yelling about the missing types. ( but still works ) I'll get back to you as soon as I know more. Cheers and make yourself a wonderful day |
Hey @reld OMG, You too! |
now we know it's a TypeScript issue with custom elements in JSX. I've seen this solved somewhere, we'll come back :) |
@acstll is this what you ment? |
Hey, I tried to get this work, but I didn't |
hey @W1ckh3ad I'm taking a look at this again today… thanks for trying that out 🙏 |
Hey @christopherGdynia I'm sorry we haven't been able to solve this one yet! Yes, ionic-team/stencil#1636 is exactly the problem. You can see there's no official solution from Stencil. But it's definitely something we need to address at some point. Is this blocking you now or can we put it in the backlog and close? |
Hi @acstll, My goal is it to test if we can use SolidJS instead of ReactJs |
Hello guys, I have found something :D, ionic-team/stencil-ds-output-targets#213 can you implement the output wrapper? :D |
Hey @W1ckh3ad that looks quite interesting. Thanks for sharing! That Solid plugin is not yet merged, so we couldn't implement it right away unless we use a fork. I would be hesitant to add yet another output wrapper since we want to actually deprecate/remove the current ones (probably except for React), and encourage devs to use the components directly, as long as support for web components is good (which is the case for almost all frameworks except for React, which in turn is also improving). Apart from fixing the JSX/TS issue described above, are there any other benefits in using this wrappers with Solid? EDIT 20220124: I updated the comment to make it clear that the React wrapper is not being deprecated. The benefits still outweigh the drawbacks. |
Hey @acstll, I understand your point, I am trying to get to know some other Frameworks and SolidJS seems like a nice alternative to React. It is quite easy to transform from React to Solid js. But if I cant get it running the packages I am using, it's not a alternative. Additionally, I don't have the expertise about Stencil, Webcomponents and Frameworkbuilding to get it fixed myself. It is quiete new and there is not much content about it concerning these topics. EDIT: It's not that I didn't try several times to get it up and running with typescript, but I didn't manage to do it. :( |
Oh, maybe my question was not well formulated, sorry. I was not asking for the benefits of using the Solid framework itself. This is a personal choice. Our job is to try and make Scale work well with every framework. That's not a problem (I really like Solid by the way!) 🙂 I was asking specifically about the benefits of a possible wrapper package, like We currently have the issue you described above (the I'm guessing the wrapper package would solve this issue. So I was wondering what other benefits would a |
I am hoping that it will finally work with this helper package, I forked and cloned booth of @reld examples and they didn't work on my pcs (private and work). I have added Scale to the solidjs hello world template, it works in codesandbox, I am kinda loosing my mind about it. |
@christopherGdynia I'm working on this, there's something else in your repo causing trouble I think. Will write again later today! Thanks for the feedback. |
I found the cause of an error in your repo here: https://github.com/W1ckh3ad/solidjs/blob/master/src/index.tsx#L7 The To work around this. You can import the library via script tag. You can add this in the index.html template in your Solid project. <script type="module" src="https://unpkg.com/@telekom/scale-components/dist/scale-components/scale-components.esm.js"></script> The CSS loading part can stay the same. I was able to get Solid working with this setup (screenshot below). However, I do get TS complaining about We're gonna try and find a solution for this before even considering adding a new wrapper package. I believe it's a matter of extending
Would you know how to create/generate such a declarations file? Thanks for the patience. |
Thank you very much. About the I will tell him about the problem, maybe they will add it to their documentation. Thank you very much! |
I have got an solution, the members from the solid discord are quite insane :D solid-js.d.ts import "solid-js"
declare module "solid-js" {
namespace JSX {
interface IntrinsicElements {
"scale-button": any;
}
}
} If we want intellisence, we need to import the right The BTW: Some properties aren't optional like import { JSX } from "solid-js";
import { Components } from "@telekom/scale-components";
interface MyElementProps {
children?: JSX.Element;
}
interface ScaleButton {
/**
* (optional) If `true`, the button is disabled
*/
disabled?: boolean;
/**
* (optional) Name of a file to be downloaded
*/
download?: string;
/**
* (optional) When present, an <a> tag will be used
*/
href?: string;
/**
* (optional) Set to `true` when the button contains only an icon
*/
iconOnly?: boolean;
/**
* (optional) Icon position related to the label
*/
iconPosition?: "before" | "after";
/**
* (optional) Set `tabindex` in the inner button or link element
*/
innerTabindex?: number;
setFocus?: () => Promise<void>;
/**
* (optional) The size of the button
*/
size?: "small" | "large";
/**
* (optional) Injected CSS styles
*/
styles?: string;
/**
* (optional) The target attribute for the <a> tag
*/
target?: string;
/**
* (optional) Button type
*/
type?: "reset" | "submit" | "button";
/**
* (optional) Button variant
*/
variant?: string;
}
declare module "solid-js" {
namespace JSX {
interface IntrinsicElements {
"scale-button": ScaleButton & MyElementProps & ButtonHTMLAttributes<HTMLButtonElement>;
}
}
} |
That's amazing, I'm glad to hear. I wonder if there's a way to provide this in a generic way, so people can use it with different frameworks. We're adding this to the backlog (figure out a way to provide either generic or specific JSX declarations). We're also looking into the optional props (that's important I think otherwise you get annoying by the linter as well). Thanks again! |
I'm closing but we can of course keep the exchange going. |
Yeah that seems reasonable to find a solution for this. I will check every component for not having an optional flag and create a pr for this :) Let's keep in touch, this will be important for deprecating the proxy packages! |
Thanks a bunch @christopherGdynia 🙏 |
@acstll Concerning the JSX typescript issue, do we want to open another issue |
Nevermind I got it working for React and SolidJS ReactJS//react-app-env.d.ts import { HTMLAttributes, RefAttributes } from 'react';
import { JSX as LocalJSX } from '@telekom/scale-components/loader';
type StencilToReact<T> = {
[P in keyof T]?: T[P] &
Omit<HTMLAttributes<Element>, 'className'> & {
class?: string;
} & RefAttributes<T[P]>;
};
declare global {
export namespace JSX {
export interface IntrinsicElements extends StencilToReact<LocalJSX.IntrinsicElements> {}
}
} SolidJSdeclarations.d.ts import { JSX as SolidJSX } from "solid-js";
import { JSX as ScaleJSX } from "@telekom/scale-components/loader";
interface MyElementProps {
children?: SolidJSX.Element;
}
type StencilToSolid<T> = {
[P in keyof T]?: T[P] &
MyElementProps &
Omit<SolidJSX.HTMLAttributes<Element>, "className"> & {
class?: string;
};
};
declare module "solid-js" {
namespace JSX {
interface IntrinsicElements extends StencilToSolid<ScaleJSX.IntrinsicElements> {
}
}
} |
thanks @christopherGdynia. I was having some issues with a similar |
Is this what you mean @filipjnc? -@Prop() variant?: string = 'primary';
+@Prop() variant?: 'primary' | 'secondary' | 'ghost' = 'primary'; https://github.com/telekom/scale/blob/main/packages/components/src/components/button/button.tsx#L42 |
Exactly. |
@christopherGdynia How did you fix the types for camel-cased props that need to be appended with the <scale-app-shell
claimLang="de"
prop:mainNavigation={mainNavigation}
prop:activeRouteId={activeRouteId || '/'}
prop:addonNavigation={addonNavigation}
prop:iconNavigation={iconNavigation}
prop:userNavigation={userNavigation}
class={styles.shell}
> Without adding |
@filipjnc you may find this comment interesting; in particular: [K in keyof T as `prop:${string & K}`]?: T[K]; |
Thanks, Alex, you got me on the right path. The following type declaration allows me now to use all the props also with the import { JSX as SolidJSX } from 'solid-js'
import { JSX as ScaleJSX } from '@telekom/scale-components/loader'
interface MyElementProps {
children?: SolidJSX.Element
}
declare module 'solid-js' {
namespace JSX {
type ElementProps<T> = {
// Add both the element's prefixed properties and the attributes
[K in keyof T]: Props<T[K]> & HTMLAttributes<T[K]> & MyElementProps
}
// Prefixes all properties with `prop:` to match Solid's property setting syntax
type Props<T> = {
[K in keyof T as `prop:${string & K}`]?: T[K]
} & {
[K in keyof T]?: T[K]
}
interface IntrinsicElements extends ElementProps<ScaleJSX.IntrinsicElements & MyElementProps> {}
}
} Still not ideal that I have to prefix the camel-cased props, but that's on SolidJS to address. |
Hello @filipjnc, @AlexErrant, I was on vacation and didn't read my emails. Thanks for your contribution @AlexErrant. |
Hello there,
I discovered SolidJs a couple of weeks ago and I decided to try it out as an alternative to react. I started with trying to use Scale components, but I failed.
I used the Solid typescript template, I didn't find the right template in CodeSandBox, but this is close.
JSX doesn't know the 'standard' Webcomponents.
I don't know if you had/have the time to check this or take a look at SolidJs.
I wrote on the SolidJs discord, if anyone of them can help me setting up using StencilJs components in SolidJs.
I will post the updates from them here.
I am grateful for every help.
The text was updated successfully, but these errors were encountered: