- stringifying elements with props containing circular references (#660) (f203060)
- deps: update dependency is-plain-object to v3.0.1 (4974512)
- Handle multiple words before trailing space (#572) (e0c082e)
- deps: pin dependency @base2/pretty-print-object to 1.0.0 (07f19f9)
- formatting: fix the anonymous functional component detection after babel upgrade (7a1b93e)
- typescript: Add TypeScript declaration file. (#475) (f9ea4e5)
- deps: Remove dependency stringify-object (6dc6d8d)
- deps: Replace dependency stringify-object with pretty-print-object (940a413)
- deps: update dependency is-plain-object to v3 (#361) (b58cbbd)
- Rework the propNameSorter to be less dependents of node sort internals (a9ee312)
- deps: update dependency stringify-object to v3.3.0 (bfe9a9f)
- formatting: Make the props "key" and "ref" order predictibale (#340) (3853463)
- deps: update jest monorepo to v23 (major) (#305) (aef55a2)
- deps: If you use the
showFunctions: true
option, the function are now always inlined in the output by default. Before it was not always the case (depending one the engine, platform or babel versions)
You could get back to the previous behavior by using the preserveFunctionLineBreak
function export as a value of the option functionValue
.
- test(smoke): Adapt the CommonJS bundle import
- formatting: Fix JSX element in prop object recursive loop (#309) (fd4f53b)
- functionValue: handle nested datastructures (94d1aeb)
- browser: build a dedicated version for the browser (#242) (574d850)
browser: This PR change of the internal directory structure of the exported code. The previous code has move from the dist/
into the dist/esm
directory (but remender that we do not avice you to do use internals code 🤓)
fix(bunble): do not bundle peer dependencies
qa(ci): Avoid duplicate runs of checks on CI
qa(dependencies): Upgrade to latest rollup versions
qa(test): Allow to run the smoke tests aggaint all builded versions
- deps: update dependency stringify-object to v3.2.2 (b1a4c5e)
- formatting: Date/RegExp values output by formatComplexDataStructure (#250) (0387b72)
- react: Fix warning about access to PropTypes using React 15.5+ (fixes #213) (2dcfd10)
- test: Fix usage of yarn instead of npm in test script (0db5aa4)
- deps: update dependency stringify-object to v3.2.1 (539ea56)
- formatting: symbol description are now quoted (2747f1b), closes #134
- formatting: trailing space (2a07d5e), closes #135
- formatting: Trailing are now preserved. In some rare case,
react-element-to-jsx-string
failed to respect the JSX specs for the trailing space. Event is the space were in the final output. There were silentrly ignored by JSX parser. This commit fix this bug by protecting the trailing space in the output.
If we take the JSX:
<div>
foo <strong>bar</strong> baz
</div>
Before it was converted to (the trailing space are replace by *
for the readability):
<div>
foo*
<strong>
bar
</strong>
*baz
</div>
Now there are preserved:
<div>
foo{' '}
<strong>
bar
</strong>
{' '}baz
</div>
- formatting: Symbol description are now correctly quoted. This change the output if you use Symbol in your code
- flow: export flow definitions in the released bundle and fix the npm ignore too restrictive (#115) (c4f91b9)
- formatting: Children with multiline string are now correctly indented (d18809e)
- formatting: Fix JSX delimiters escaping in string (6e0eea3)
- release: revert change made by error in commit 86697517 (903fd5c)
- travis: manually install yarn on Travis CI (b8a4c1a)
- formatting: Improve string escaping of string that contains JSX delimiters (
{
,}
,<
,>
)
Before:
console.log(reactElementToJsxString(<div>{`Mustache :{`}</div>);
// <div>Mustache :{</div>
Now:
console.log(reactElementToJsxString(<div>{`Mustache :{`}</div>);
// <div>{`Mustache :{`}</div>
- formatting: fix an edge case where number and string childrens are not correctly merged (47572e0)
- release: Missing
mversion
package in dev dependencies (0f82ee7)
- escaping: Complete lib refactor to handle more escaping cases (9f3c671)
- Fix escaping issue with quotes (in props value or in children of type string)
- Handle props value of
Date
type: <div foo={new Date("2017-01-01T11:00:00.000Z")} />
- Escape brace chars (
{}
) in a children string: <script type="application/json+ld">{ hello: 'world' }</script>
- sortProps: add option to remove sorting of props (66e8307)
- functionValue: format functions output the way you want (460e0cc)
- React: support 15.5+ (1a99024)
- inline attributes: Allow formatting attribute on the same line (da72176)
- build: switch to stringify-object@3 (e9a5c7f)
- build: You need an ES2015 env to use
react-element-to-jsx-string now
You can use the Babel polyfill to do so.
- deps: remove direct dep on react-addons-test-utils (06d2588), closes #56
- pretty: prettify objects, arrays, nested (864b9db)
- pretty: objects and arrays are now prettified by default following #50
If this is a concern to you, open a PR that adds an option to inline parts or the whole output like before
- stateless comps: add No Display Name as default component name (dc0f65c), closes #11
- handle
{123}
(609ac78), closes #8
- lodash: just use plain lodash and import (062b3fe)
- whitespace: handle {true} {false} (eaca1a2), closes #6 #7
- whitespace: stop rendering it differently in SOME cases (128aa95)
- merge plain strings props replacements (7c2bf27)
- tagName: fixed an edge-case with decorated component name (9169ac7)
- handle arrays the right way (597a910)
- children: ensure the array of children is well handled (36b462a)
- deep: handle deeply set functions (ad21917)
- deep: handle deeply set React elements (a06f329)
- deep: functions are now stringified to
function noRefCheck()
{}
instead of function () {code;}
. For various reasons AND to be
specific about the fact that we do not represent the function in a
realistic way.
- handle null and undefined prop values (9a57a10), closes #1
- whitespace: remove unwanted whitespace in output (3e2e7b8)
- sort object keys in a deterministic way (c1ce8a6)