-
-
Notifications
You must be signed in to change notification settings - Fork 1.5k
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
Bugs and bugs around react-docgen #240
Comments
I was able to apply custom config via docrc: modifyBundlerConfig: config => {
const jsxPluginIndex = config.plugins.findIndex(plugin => plugin.config.id === 'jsx');
const { loaders } = config.plugins[jsxPluginIndex].config;
const docGenLoaderIndex = loaders.findIndex(loader => /react-docgen-typescript-loader/.test(loader.loader));
const docGenLoader = loaders[docGenLoaderIndex];
docGenLoader.options = {
tsconfigPath: './tsconfig.json'
};
return config;
} That's good, but unfortunately it's only working with Would you consider updating |
I chose to leave only this issue since it is related to the configuration of the react docgen. The idea is don't use plugins/loaders anymore and put all process related to docgen in the |
I am also being affected by this issue when using an external library of react components (same issue as #253 @itReverie). Is there any quick solution available? 🙏 |
@tadeuszwojcik Great find! By passing my own tsconfig I'm now getting the propstable rendered with the latest version of Docz as well! @pedronauck Might be a 'simple' fix now to get this working again? Seems like the quick solutions for now would be to make an easy option to pass a custom config to React Docgen (instead of the 5 lines of ugly JS in the config), and we're good to go? |
@JeroenReumkens react-docgen-typescript-loader has released v3.0.0. when I change
to
It works as described in the document |
@BoostIO funded this issue with $40. See it on IssueHunt |
I'm looking for this feature as well. I'm retrofitting Docz into an existing TS project (hoping to merge our old docs site and Styleguidist together) and PropsTable is showing up empty. Definitely not able to migrate yet. Hopefully soon! |
The solution given above seems to be broken in the latest release of Docz. @pedronauck Do you remember changing anything related to the way docgen is added to the webpack config? |
Hey guys I had the same problem with the modifyBundlerConfig: config => ({
...config,
module: {
...config.module,
rules: config.module.rules.map(rule => ({
...rule,
use: rule.use.map(ruleUse =>
ruleUse.loader.includes('react-docgen-typescript-loader')
? {
...ruleUse,
options: {
propFilter: prop => {
if (prop.parent == null) return true
return !prop.parent.fileName.includes('node_modules')
},
},
}
: ruleUse,
),
})),
},
}), |
Hey guys, I put the @guilhermedecampo solution inside docz, see if is good now 🙏 |
Hey @pedronauck You mean Docz should do this by itself now? If so, can you tell me in what version I can find the fix? The solution given above doesn't look that easy a first glance. So if that is the way forward, I'll try to implement it in my project to see if it works. But if it does work, I'll try to make the above code a bit more simple / readable. |
@pedronauck has submitted a pull request. See it on IssueHunt |
@pedronauck has rewarded $28.00 to @pedronauck. See it on IssueHunt
|
In the next release (v0.14) I'll introduce a new way to parse props using react-docgen. Instead of using a babel plugin for prop-types and a loader for typescript, everything now is centralized in a process using data server: https://github.com/pedronauck/docz/blob/v0.14/core/docz-core/src/states/props.ts With these changes, I think that we will improve a lot the performance since all props extracting logic will not belong to webpack anymore. I'll finish the v0.14 that will have some other improvements, then I came back here to test and close this issue 🙏 |
@pedronauck Hi when do you think you will be releasing v0.14? |
Is this in v1? I just tried out v1 and Props are still not working with Styled Components. |
Can the Props component accept something besides a static prop-types object? I have a function that generates props types for my component, that I reuse across many components, and if it's not a exact prop-types object it won't render in the Props component. |
@rfoel that doesn't work either. Even if it did, this is still an issue, you shouldn't have to change the way you create your styled components just for documentation to work. |
@glockjt That I agree. I'm having a hard time trying to make the props work. |
Ran into similar issues. Trying to get
I kept a bunch of notes on my brute-force search of webpack/babel configuration space for docz@1, since I am webpack-illiterate: https://github.com/100ideas/remirror/blob/doczv1/support/docz-v1-WIP-notes/NOTES-docz-v1.0.0-experiments.md will update if we make any progress. What's hard is figuring out how to get docz working not just with |
I'm releasing some new release candidate today @100ideas, one of your problems I think that is fixed! |
woot rc5! will try hopefully later today. |
Are there plans to allow the // utils.js
export const color = () => {
// ...
}
color.propTypes = {
color: PropTypes.oneOfType([
PropTypes.string,
PropTypes.arrayOf(PropTypes.string)
]),
};
// Button.js
import React from 'react';
import PropTypes from 'prop-types';
import { color } from '../path/to/utils';
export const Button = props => {
// ...
};
Button.propTypes = {
...color.propTypes, // <- it would be awesome if this showed up in the props table
};
export default Button; It seems like there was some attempt to get it working here? |
@pedronauck do you have an update about the comment above? Working on this would help a lot. |
This handler should fix this issue @rfoel, but since the newest version of |
I'll close this issue since most cases were fixed. |
@pedronauck I agree that the handler you linked is pretty outdated, but it seems like other, newer packages have tried to solve the same problem, like Was there an issue when you tried using it before? |
@pedronauck is there any update on this potential solution or how to get I'm having a similar issue in our TS monorepo where the props being imported from another component or Does the changes to
|
Question
How to pass custom config to react-docgen-typescript-loader ?
Description
Hi,
First of all, I love the project, much nicer experience than with styleguidist!
I'm trying to use it with typescript, which is working fine except
PropsTable
which renders empty.I had similar issue when working with styleguidist, and solution for that was to pass my custom tsconfig.json to do react-docgen-typescript . Unfortunately I don't know how to do that with docz, I made changes locally inside docz code so
react-docgen-typescript-loader
reads my config and it works perfectly, but it's not a solution :) Is there a way to do that viamodifyBundlerConfig
?Thanks!
The text was updated successfully, but these errors were encountered: