mirror of
https://github.com/n8n-io/n8n.git
synced 2024-11-09 22:24:05 -08:00
feat(editor): Harmonize rendering of new-lines in RunData (#9614)
Signed-off-by: Oleg Ivaniv <me@olegivaniv.com> Co-authored-by: Giulio Andreini <g.andreini@gmail.com>
This commit is contained in:
parent
22bdb0568e
commit
bc3dcf706f
|
@ -126,6 +126,8 @@
|
||||||
--color-code-gutterBackground: var(--prim-gray-670);
|
--color-code-gutterBackground: var(--prim-gray-670);
|
||||||
--color-code-gutterForeground: var(--prim-gray-320);
|
--color-code-gutterForeground: var(--prim-gray-320);
|
||||||
--color-code-tags-comment: var(--prim-gray-200);
|
--color-code-tags-comment: var(--prim-gray-200);
|
||||||
|
--color-line-break: var(--prim-gray-420);
|
||||||
|
--color-code-line-break: var(--prim-color-secondary-tint-100);
|
||||||
|
|
||||||
// Variables
|
// Variables
|
||||||
--color-variables-usage-font: var(--prim-color-alt-a-tint-300);
|
--color-variables-usage-font: var(--prim-color-alt-a-tint-300);
|
||||||
|
|
|
@ -163,6 +163,8 @@
|
||||||
--color-code-gutterBackground: var(--prim-gray-0);
|
--color-code-gutterBackground: var(--prim-gray-0);
|
||||||
--color-code-gutterForeground: var(--prim-gray-320);
|
--color-code-gutterForeground: var(--prim-gray-320);
|
||||||
--color-code-tags-comment: var(--prim-gray-420);
|
--color-code-tags-comment: var(--prim-gray-420);
|
||||||
|
--color-line-break: var(--prim-gray-320);
|
||||||
|
--color-code-line-break: var(--prim-color-secondary-tint-200);
|
||||||
|
|
||||||
// Variables
|
// Variables
|
||||||
--color-variables-usage-font: var(--color-success);
|
--color-variables-usage-font: var(--color-success);
|
||||||
|
|
|
@ -264,6 +264,7 @@ export default defineComponent({
|
||||||
<style lang="scss">
|
<style lang="scss">
|
||||||
.vjs-tree {
|
.vjs-tree {
|
||||||
color: var(--color-json-default);
|
color: var(--color-json-default);
|
||||||
|
--color-line-break: var(--color-code-line-break);
|
||||||
}
|
}
|
||||||
|
|
||||||
.vjs-tree-node {
|
.vjs-tree-node {
|
||||||
|
|
|
@ -38,6 +38,7 @@ const key = computed((): string | undefined => {
|
||||||
const schemaName = computed(() =>
|
const schemaName = computed(() =>
|
||||||
isSchemaParentTypeArray.value ? `${props.schema.type}[${props.schema.key}]` : props.schema.key,
|
isSchemaParentTypeArray.value ? `${props.schema.type}[${props.schema.key}]` : props.schema.key,
|
||||||
);
|
);
|
||||||
|
|
||||||
const text = computed(() =>
|
const text = computed(() =>
|
||||||
Array.isArray(props.schema.value) ? '' : shorten(props.schema.value, 600, 0),
|
Array.isArray(props.schema.value) ? '' : shorten(props.schema.value, 600, 0),
|
||||||
);
|
);
|
||||||
|
@ -114,7 +115,11 @@ const getIconBySchemaType = (type: Schema['type']): string => {
|
||||||
/>
|
/>
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
<span v-if="text" :class="$style.text">{{ text }}</span>
|
<span v-if="text" :class="$style.text">
|
||||||
|
<template v-for="(line, index) in text.split('\n')" :key="`line-${index}`">
|
||||||
|
<span v-if="index > 0" :class="$style.newLine">\n</span>{{ line }}
|
||||||
|
</template>
|
||||||
|
</span>
|
||||||
<input v-if="level > 0 && isSchemaValueArray" :id="subKey" type="checkbox" checked />
|
<input v-if="level > 0 && isSchemaValueArray" :id="subKey" type="checkbox" checked />
|
||||||
<label v-if="level > 0 && isSchemaValueArray" :class="$style.toggle" :for="subKey">
|
<label v-if="level > 0 && isSchemaValueArray" :class="$style.toggle" :for="subKey">
|
||||||
<font-awesome-icon icon="angle-up" />
|
<font-awesome-icon icon="angle-up" />
|
||||||
|
@ -286,6 +291,12 @@ const getIconBySchemaType = (type: Schema['type']): string => {
|
||||||
font-size: var(--font-size-2xs);
|
font-size: var(--font-size-2xs);
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
word-break: break-word;
|
word-break: break-word;
|
||||||
|
|
||||||
|
.newLine {
|
||||||
|
font-family: var(--font-family-monospace);
|
||||||
|
color: var(--color-line-break);
|
||||||
|
padding-right: 2px;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.toggle {
|
.toggle {
|
||||||
|
|
|
@ -388,7 +388,7 @@ export default defineComponent({
|
||||||
return this.$locale.baseText('runData.emptyString');
|
return this.$locale.baseText('runData.emptyString');
|
||||||
}
|
}
|
||||||
if (typeof value === 'string') {
|
if (typeof value === 'string') {
|
||||||
return value.replaceAll('\n', '\\n');
|
return value;
|
||||||
}
|
}
|
||||||
if (Array.isArray(value) && value.length === 0) {
|
if (Array.isArray(value) && value.length === 0) {
|
||||||
return this.$locale.baseText('runData.emptyArray');
|
return this.$locale.baseText('runData.emptyArray');
|
||||||
|
|
|
@ -48,5 +48,20 @@ const parts = computed(() => {
|
||||||
<span v-else-if="part.content" :key="`span-${index}`">{{ part.content }}</span>
|
<span v-else-if="part.content" :key="`span-${index}`">{{ part.content }}</span>
|
||||||
</template>
|
</template>
|
||||||
</span>
|
</span>
|
||||||
<span v-else>{{ props.content }}</span>
|
<span v-else :class="$style.content">
|
||||||
|
<template v-if="typeof props.content === 'string'">
|
||||||
|
<span v-for="(line, index) in props.content.split('\n')" :key="`line-${index}`">
|
||||||
|
<span v-if="index > 0" :class="$style.newLine">\n</span>{{ line }}
|
||||||
|
</span>
|
||||||
|
</template>
|
||||||
|
<span v-else v-text="props.content" />
|
||||||
|
</span>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
|
<style lang="scss" module>
|
||||||
|
:root .content .newLine {
|
||||||
|
font-family: var(--font-family-monospace);
|
||||||
|
color: var(--color-line-break);
|
||||||
|
padding-right: 2px;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|
|
@ -21,7 +21,9 @@ describe('TextWithHighlights', () => {
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
expect(wrapper.html()).toEqual('<span>Test content</span>');
|
expect(wrapper.html()).toEqual(
|
||||||
|
'<span class="content"><span><!--v-if-->Test content</span></span>',
|
||||||
|
);
|
||||||
expect(wrapper.html()).not.toContain('<mark>');
|
expect(wrapper.html()).not.toContain('<mark>');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -32,18 +34,19 @@ describe('TextWithHighlights', () => {
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
expect(wrapper.html()).toEqual('<span>1</span>');
|
expect(wrapper.html()).toEqual('<span class="content"><span>1</span></span>');
|
||||||
expect(wrapper.html()).not.toContain('<mark>');
|
expect(wrapper.html()).not.toContain('<mark>');
|
||||||
});
|
});
|
||||||
|
|
||||||
it('renders correctly objects when search is not set', () => {
|
it('renders correctly objects when search is not set', async () => {
|
||||||
const wrapper = shallowMount(TextWithHighlights, {
|
const wrapper = shallowMount(TextWithHighlights, {
|
||||||
props: {
|
props: {
|
||||||
content: { hello: 'world' },
|
content: { hello: 'world' },
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
expect(wrapper.html()).toEqual(
|
||||||
expect(wrapper.html()).toEqual('<span>{\n "hello": "world"\n}</span>');
|
'<span class="content"><span>{\n "hello": "world"\n}</span></span>',
|
||||||
|
);
|
||||||
expect(wrapper.html()).not.toContain('<mark>');
|
expect(wrapper.html()).not.toContain('<mark>');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -55,7 +58,9 @@ describe('TextWithHighlights', () => {
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
expect(wrapper.html()).toEqual('<span>{\n "hello": "world"\n}</span>');
|
expect(wrapper.html()).toEqual(
|
||||||
|
'<span class="content"><span>{\n "hello": "world"\n}</span></span>',
|
||||||
|
);
|
||||||
expect(wrapper.html()).not.toContain('<mark>');
|
expect(wrapper.html()).not.toContain('<mark>');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -100,4 +105,16 @@ describe('TextWithHighlights', () => {
|
||||||
'<span><span>Test content </span><mark>()^${}[]</mark><span> world</span></span>',
|
'<span><span>Test content </span><mark>()^${}[]</mark><span> world</span></span>',
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
it('renders new lines in the content correctly', () => {
|
||||||
|
const wrapper = shallowMount(TextWithHighlights, {
|
||||||
|
props: {
|
||||||
|
content: 'Line 1\n Line 2\nLine 3',
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
expect(wrapper.html()).toContain(
|
||||||
|
'<span class="content"><span><!--v-if-->Line 1</span><span><span class="newLine">\\n</span> Line 2</span><span><span class="newLine">\\n</span>Line 3</span></span>',
|
||||||
|
);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
|
@ -86,16 +86,21 @@ exports[`RunDataJson.vue > renders json values properly 1`] = `
|
||||||
>
|
>
|
||||||
|
|
||||||
<span
|
<span
|
||||||
class="mappable"
|
class="content mappable"
|
||||||
data-depth="2"
|
data-depth="2"
|
||||||
data-name="list"
|
data-name="list"
|
||||||
data-path="[0].list"
|
data-path="[0].list"
|
||||||
data-target="mappable"
|
data-target="mappable"
|
||||||
data-value="{{ $('Set').item.json.list }}"
|
data-value="{{ $('Set').item.json.list }}"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
"list"
|
"list"
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
|
|
||||||
<span
|
<span
|
||||||
class="vjs-colon"
|
class="vjs-colon"
|
||||||
>
|
>
|
||||||
|
@ -140,17 +145,22 @@ exports[`RunDataJson.vue > renders json values properly 1`] = `
|
||||||
>
|
>
|
||||||
|
|
||||||
<span
|
<span
|
||||||
class="mappable ph-no-capture"
|
class="content mappable ph-no-capture"
|
||||||
data-depth="3"
|
data-depth="3"
|
||||||
data-name="list[0]"
|
data-name="list[0]"
|
||||||
data-path="[0].list[0]"
|
data-path="[0].list[0]"
|
||||||
data-target="mappable"
|
data-target="mappable"
|
||||||
data-value="{{ $('Set').item.json.list[0] }}"
|
data-value="{{ $('Set').item.json.list[0] }}"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
1
|
1
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
<span>
|
<span>
|
||||||
,
|
,
|
||||||
</span>
|
</span>
|
||||||
|
@ -185,17 +195,22 @@ exports[`RunDataJson.vue > renders json values properly 1`] = `
|
||||||
>
|
>
|
||||||
|
|
||||||
<span
|
<span
|
||||||
class="mappable ph-no-capture"
|
class="content mappable ph-no-capture"
|
||||||
data-depth="3"
|
data-depth="3"
|
||||||
data-name="list[1]"
|
data-name="list[1]"
|
||||||
data-path="[0].list[1]"
|
data-path="[0].list[1]"
|
||||||
data-target="mappable"
|
data-target="mappable"
|
||||||
data-value="{{ $('Set').item.json.list[1] }}"
|
data-value="{{ $('Set').item.json.list[1] }}"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
2
|
2
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
<span>
|
<span>
|
||||||
,
|
,
|
||||||
</span>
|
</span>
|
||||||
|
@ -230,17 +245,22 @@ exports[`RunDataJson.vue > renders json values properly 1`] = `
|
||||||
>
|
>
|
||||||
|
|
||||||
<span
|
<span
|
||||||
class="mappable ph-no-capture"
|
class="content mappable ph-no-capture"
|
||||||
data-depth="3"
|
data-depth="3"
|
||||||
data-name="list[2]"
|
data-name="list[2]"
|
||||||
data-path="[0].list[2]"
|
data-path="[0].list[2]"
|
||||||
data-target="mappable"
|
data-target="mappable"
|
||||||
data-value="{{ $('Set').item.json.list[2] }}"
|
data-value="{{ $('Set').item.json.list[2] }}"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
3
|
3
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
<!---->
|
<!---->
|
||||||
<!---->
|
<!---->
|
||||||
</span>
|
</span>
|
||||||
|
@ -299,16 +319,21 @@ exports[`RunDataJson.vue > renders json values properly 1`] = `
|
||||||
>
|
>
|
||||||
|
|
||||||
<span
|
<span
|
||||||
class="mappable"
|
class="content mappable"
|
||||||
data-depth="2"
|
data-depth="2"
|
||||||
data-name="record"
|
data-name="record"
|
||||||
data-path="[0].record"
|
data-path="[0].record"
|
||||||
data-target="mappable"
|
data-target="mappable"
|
||||||
data-value="{{ $('Set').item.json.record }}"
|
data-value="{{ $('Set').item.json.record }}"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
"record"
|
"record"
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
|
|
||||||
<span
|
<span
|
||||||
class="vjs-colon"
|
class="vjs-colon"
|
||||||
>
|
>
|
||||||
|
@ -351,16 +376,21 @@ exports[`RunDataJson.vue > renders json values properly 1`] = `
|
||||||
>
|
>
|
||||||
|
|
||||||
<span
|
<span
|
||||||
class="mappable"
|
class="content mappable"
|
||||||
data-depth="3"
|
data-depth="3"
|
||||||
data-name="name"
|
data-name="name"
|
||||||
data-path="[0].record.name"
|
data-path="[0].record.name"
|
||||||
data-target="mappable"
|
data-target="mappable"
|
||||||
data-value="{{ $('Set').item.json.record.name }}"
|
data-value="{{ $('Set').item.json.record.name }}"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
"name"
|
"name"
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
|
|
||||||
<span
|
<span
|
||||||
class="vjs-colon"
|
class="vjs-colon"
|
||||||
>
|
>
|
||||||
|
@ -372,11 +402,18 @@ exports[`RunDataJson.vue > renders json values properly 1`] = `
|
||||||
class="vjs-value vjs-value-string"
|
class="vjs-value vjs-value-string"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<span
|
||||||
|
class="content"
|
||||||
|
>
|
||||||
|
|
||||||
<span>
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
"Joe"
|
"Joe"
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
<!---->
|
<!---->
|
||||||
<!---->
|
<!---->
|
||||||
</span>
|
</span>
|
||||||
|
@ -435,16 +472,21 @@ exports[`RunDataJson.vue > renders json values properly 1`] = `
|
||||||
>
|
>
|
||||||
|
|
||||||
<span
|
<span
|
||||||
class="mappable"
|
class="content mappable"
|
||||||
data-depth="2"
|
data-depth="2"
|
||||||
data-name="myNumber"
|
data-name="myNumber"
|
||||||
data-path="[0].myNumber"
|
data-path="[0].myNumber"
|
||||||
data-target="mappable"
|
data-target="mappable"
|
||||||
data-value="{{ $('Set').item.json.myNumber }}"
|
data-value="{{ $('Set').item.json.myNumber }}"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
"myNumber"
|
"myNumber"
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
|
|
||||||
<span
|
<span
|
||||||
class="vjs-colon"
|
class="vjs-colon"
|
||||||
>
|
>
|
||||||
|
@ -456,11 +498,18 @@ exports[`RunDataJson.vue > renders json values properly 1`] = `
|
||||||
class="vjs-value vjs-value-number"
|
class="vjs-value vjs-value-number"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<span
|
||||||
|
class="content"
|
||||||
|
>
|
||||||
|
|
||||||
<span>
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
123
|
123
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
<span>
|
<span>
|
||||||
,
|
,
|
||||||
</span>
|
</span>
|
||||||
|
@ -490,16 +539,21 @@ exports[`RunDataJson.vue > renders json values properly 1`] = `
|
||||||
>
|
>
|
||||||
|
|
||||||
<span
|
<span
|
||||||
class="mappable"
|
class="content mappable"
|
||||||
data-depth="2"
|
data-depth="2"
|
||||||
data-name="myStringNumber"
|
data-name="myStringNumber"
|
||||||
data-path="[0].myStringNumber"
|
data-path="[0].myStringNumber"
|
||||||
data-target="mappable"
|
data-target="mappable"
|
||||||
data-value="{{ $('Set').item.json.myStringNumber }}"
|
data-value="{{ $('Set').item.json.myStringNumber }}"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
"myStringNumber"
|
"myStringNumber"
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
|
|
||||||
<span
|
<span
|
||||||
class="vjs-colon"
|
class="vjs-colon"
|
||||||
>
|
>
|
||||||
|
@ -511,11 +565,18 @@ exports[`RunDataJson.vue > renders json values properly 1`] = `
|
||||||
class="vjs-value vjs-value-string"
|
class="vjs-value vjs-value-string"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<span
|
||||||
|
class="content"
|
||||||
|
>
|
||||||
|
|
||||||
<span>
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
"456"
|
"456"
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
<span>
|
<span>
|
||||||
,
|
,
|
||||||
</span>
|
</span>
|
||||||
|
@ -545,16 +606,21 @@ exports[`RunDataJson.vue > renders json values properly 1`] = `
|
||||||
>
|
>
|
||||||
|
|
||||||
<span
|
<span
|
||||||
class="mappable"
|
class="content mappable"
|
||||||
data-depth="2"
|
data-depth="2"
|
||||||
data-name="myStringText"
|
data-name="myStringText"
|
||||||
data-path="[0].myStringText"
|
data-path="[0].myStringText"
|
||||||
data-target="mappable"
|
data-target="mappable"
|
||||||
data-value="{{ $('Set').item.json.myStringText }}"
|
data-value="{{ $('Set').item.json.myStringText }}"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
"myStringText"
|
"myStringText"
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
|
|
||||||
<span
|
<span
|
||||||
class="vjs-colon"
|
class="vjs-colon"
|
||||||
>
|
>
|
||||||
|
@ -566,11 +632,18 @@ exports[`RunDataJson.vue > renders json values properly 1`] = `
|
||||||
class="vjs-value vjs-value-string"
|
class="vjs-value vjs-value-string"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<span
|
||||||
|
class="content"
|
||||||
|
>
|
||||||
|
|
||||||
<span>
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
"abc"
|
"abc"
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
<span>
|
<span>
|
||||||
,
|
,
|
||||||
</span>
|
</span>
|
||||||
|
@ -600,16 +673,21 @@ exports[`RunDataJson.vue > renders json values properly 1`] = `
|
||||||
>
|
>
|
||||||
|
|
||||||
<span
|
<span
|
||||||
class="mappable"
|
class="content mappable"
|
||||||
data-depth="2"
|
data-depth="2"
|
||||||
data-name="nil"
|
data-name="nil"
|
||||||
data-path="[0].nil"
|
data-path="[0].nil"
|
||||||
data-target="mappable"
|
data-target="mappable"
|
||||||
data-value="{{ $('Set').item.json.nil }}"
|
data-value="{{ $('Set').item.json.nil }}"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
"nil"
|
"nil"
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
|
|
||||||
<span
|
<span
|
||||||
class="vjs-colon"
|
class="vjs-colon"
|
||||||
>
|
>
|
||||||
|
@ -621,11 +699,18 @@ exports[`RunDataJson.vue > renders json values properly 1`] = `
|
||||||
class="vjs-value vjs-value-null"
|
class="vjs-value vjs-value-null"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<span
|
||||||
|
class="content"
|
||||||
|
>
|
||||||
|
|
||||||
<span>
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
null
|
null
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
<span>
|
<span>
|
||||||
,
|
,
|
||||||
</span>
|
</span>
|
||||||
|
@ -655,16 +740,21 @@ exports[`RunDataJson.vue > renders json values properly 1`] = `
|
||||||
>
|
>
|
||||||
|
|
||||||
<span
|
<span
|
||||||
class="mappable"
|
class="content mappable"
|
||||||
data-depth="2"
|
data-depth="2"
|
||||||
data-name="d"
|
data-name="d"
|
||||||
data-path="[0].d"
|
data-path="[0].d"
|
||||||
data-target="mappable"
|
data-target="mappable"
|
||||||
data-value="{{ $('Set').item.json.d }}"
|
data-value="{{ $('Set').item.json.d }}"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
"d"
|
"d"
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
|
|
||||||
<span
|
<span
|
||||||
class="vjs-colon"
|
class="vjs-colon"
|
||||||
>
|
>
|
||||||
|
@ -676,7 +766,11 @@ exports[`RunDataJson.vue > renders json values properly 1`] = `
|
||||||
class="vjs-value vjs-value-undefined"
|
class="vjs-value vjs-value-undefined"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<span
|
||||||
|
class="content"
|
||||||
|
>
|
||||||
<span />
|
<span />
|
||||||
|
</span>
|
||||||
|
|
||||||
</span>
|
</span>
|
||||||
<!---->
|
<!---->
|
||||||
|
|
|
@ -59,16 +59,26 @@ exports[`RunDataJsonSchema.vue > renders schema for data 1`] = `
|
||||||
</svg>
|
</svg>
|
||||||
<!--v-if-->
|
<!--v-if-->
|
||||||
<span
|
<span
|
||||||
class=""
|
class="content"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
name
|
name
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
<span
|
<span
|
||||||
class="text"
|
class="text"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
|
||||||
|
<!--v-if-->
|
||||||
John
|
John
|
||||||
|
|
||||||
|
|
||||||
</span>
|
</span>
|
||||||
<!--v-if-->
|
<!--v-if-->
|
||||||
<!--v-if-->
|
<!--v-if-->
|
||||||
|
@ -109,16 +119,26 @@ exports[`RunDataJsonSchema.vue > renders schema for data 1`] = `
|
||||||
</svg>
|
</svg>
|
||||||
<!--v-if-->
|
<!--v-if-->
|
||||||
<span
|
<span
|
||||||
class=""
|
class="content"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
age
|
age
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
<span
|
<span
|
||||||
class="text"
|
class="text"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
|
||||||
|
<!--v-if-->
|
||||||
22
|
22
|
||||||
|
|
||||||
|
|
||||||
</span>
|
</span>
|
||||||
<!--v-if-->
|
<!--v-if-->
|
||||||
<!--v-if-->
|
<!--v-if-->
|
||||||
|
@ -159,10 +179,15 @@ exports[`RunDataJsonSchema.vue > renders schema for data 1`] = `
|
||||||
</svg>
|
</svg>
|
||||||
<!--v-if-->
|
<!--v-if-->
|
||||||
<span
|
<span
|
||||||
class=""
|
class="content"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
hobbies
|
hobbies
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
<!--v-if-->
|
<!--v-if-->
|
||||||
|
@ -228,20 +253,37 @@ exports[`RunDataJsonSchema.vue > renders schema for data 1`] = `
|
||||||
fill="currentColor"
|
fill="currentColor"
|
||||||
/>
|
/>
|
||||||
</svg>
|
</svg>
|
||||||
|
<span
|
||||||
|
class="content"
|
||||||
|
>
|
||||||
|
|
||||||
<span>
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
hobbies
|
hobbies
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
<span
|
<span
|
||||||
class="arrayIndex"
|
class="content arrayIndex"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
[0]
|
[0]
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
<span
|
<span
|
||||||
class="text"
|
class="text"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
|
||||||
|
<!--v-if-->
|
||||||
surfing
|
surfing
|
||||||
|
|
||||||
|
|
||||||
</span>
|
</span>
|
||||||
<!--v-if-->
|
<!--v-if-->
|
||||||
<!--v-if-->
|
<!--v-if-->
|
||||||
|
@ -280,20 +322,37 @@ exports[`RunDataJsonSchema.vue > renders schema for data 1`] = `
|
||||||
fill="currentColor"
|
fill="currentColor"
|
||||||
/>
|
/>
|
||||||
</svg>
|
</svg>
|
||||||
|
<span
|
||||||
|
class="content"
|
||||||
|
>
|
||||||
|
|
||||||
<span>
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
hobbies
|
hobbies
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
<span
|
<span
|
||||||
class="arrayIndex"
|
class="content arrayIndex"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
[1]
|
[1]
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
<span
|
<span
|
||||||
class="text"
|
class="text"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
|
||||||
|
<!--v-if-->
|
||||||
traveling
|
traveling
|
||||||
|
|
||||||
|
|
||||||
</span>
|
</span>
|
||||||
<!--v-if-->
|
<!--v-if-->
|
||||||
<!--v-if-->
|
<!--v-if-->
|
||||||
|
@ -417,10 +476,15 @@ exports[`RunDataJsonSchema.vue > renders schema with spaces and dots 1`] = `
|
||||||
</svg>
|
</svg>
|
||||||
<!--v-if-->
|
<!--v-if-->
|
||||||
<span
|
<span
|
||||||
class=""
|
class="content"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
hello world
|
hello world
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
<!--v-if-->
|
<!--v-if-->
|
||||||
|
@ -486,14 +550,26 @@ exports[`RunDataJsonSchema.vue > renders schema with spaces and dots 1`] = `
|
||||||
fill="currentColor"
|
fill="currentColor"
|
||||||
/>
|
/>
|
||||||
</svg>
|
</svg>
|
||||||
|
<span
|
||||||
|
class="content"
|
||||||
|
>
|
||||||
|
|
||||||
<span>
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
hello world
|
hello world
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
<span
|
<span
|
||||||
class="arrayIndex"
|
class="content arrayIndex"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
[0]
|
[0]
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
<!--v-if-->
|
<!--v-if-->
|
||||||
|
@ -561,10 +637,15 @@ exports[`RunDataJsonSchema.vue > renders schema with spaces and dots 1`] = `
|
||||||
</svg>
|
</svg>
|
||||||
<!--v-if-->
|
<!--v-if-->
|
||||||
<span
|
<span
|
||||||
class=""
|
class="content"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
test
|
test
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
<!--v-if-->
|
<!--v-if-->
|
||||||
|
@ -632,16 +713,26 @@ exports[`RunDataJsonSchema.vue > renders schema with spaces and dots 1`] = `
|
||||||
</svg>
|
</svg>
|
||||||
<!--v-if-->
|
<!--v-if-->
|
||||||
<span
|
<span
|
||||||
class=""
|
class="content"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
more to think about
|
more to think about
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
<span
|
<span
|
||||||
class="text"
|
class="text"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
|
||||||
|
<!--v-if-->
|
||||||
1
|
1
|
||||||
|
|
||||||
|
|
||||||
</span>
|
</span>
|
||||||
<!--v-if-->
|
<!--v-if-->
|
||||||
<!--v-if-->
|
<!--v-if-->
|
||||||
|
@ -685,16 +776,26 @@ exports[`RunDataJsonSchema.vue > renders schema with spaces and dots 1`] = `
|
||||||
</svg>
|
</svg>
|
||||||
<!--v-if-->
|
<!--v-if-->
|
||||||
<span
|
<span
|
||||||
class=""
|
class="content"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
<span>
|
||||||
|
<!--v-if-->
|
||||||
test.how
|
test.how
|
||||||
</span>
|
</span>
|
||||||
|
|
||||||
|
</span>
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
<span
|
<span
|
||||||
class="text"
|
class="text"
|
||||||
>
|
>
|
||||||
|
|
||||||
|
|
||||||
|
<!--v-if-->
|
||||||
ignore
|
ignore
|
||||||
|
|
||||||
|
|
||||||
</span>
|
</span>
|
||||||
<!--v-if-->
|
<!--v-if-->
|
||||||
<!--v-if-->
|
<!--v-if-->
|
||||||
|
|
Loading…
Reference in a new issue