Skip to content

Commit

Permalink
Vue3: Try reactivity without invoking args as props
Browse files Browse the repository at this point in the history
  • Loading branch information
kasperpeulen committed Apr 25, 2023
1 parent ff3c8c3 commit 8a50224
Show file tree
Hide file tree
Showing 6 changed files with 10 additions and 71 deletions.
17 changes: 6 additions & 11 deletions code/renderers/vue3/src/decorateStory.ts
Original file line number Diff line number Diff line change
@@ -1,9 +1,7 @@
import type { ConcreteComponent, Component, ComponentOptions } from 'vue';
import type { Component, ComponentOptions, ConcreteComponent } from 'vue';
import { h } from 'vue';
import type { DecoratorFunction, StoryContext, LegacyStoryFn, Args } from '@storybook/types';
import type { DecoratorFunction, LegacyStoryFn, StoryContext } from '@storybook/types';
import { sanitizeStoryContextUpdate } from '@storybook/preview-api';
// eslint-disable-next-line import/no-extraneous-dependencies
import { looseEqual } from '@vue/shared';
import type { VueRenderer } from './types';

/*
Expand Down Expand Up @@ -45,7 +43,6 @@ export function decorateStory(
storyFn: LegacyStoryFn<VueRenderer>,
decorators: DecoratorFunction<VueRenderer>[]
): LegacyStoryFn<VueRenderer> {
let updatedArgs: Args;
return decorators.reduce(
(decorated: LegacyStoryFn<VueRenderer>, decorator) => (context: StoryContext<VueRenderer>) => {
let story: VueRenderer['storyResult'] | undefined;
Expand All @@ -55,22 +52,20 @@ export function decorateStory(
...context,
...sanitizeStoryContextUpdate(update),
});

if (update && update.args && !looseEqual(update.args, context.args))
updatedArgs ??= update.args;
return story;
}, context);

context.args = updatedArgs ?? context.args;
if (!story) story = decorated(context);

if (decoratedStory === story) {
return story;
}

const innerStory = () => h(story!, context.args);
const innerStory = () => h(story!);
return prepare(decoratedStory, innerStory) as VueRenderer['storyResult'];
},
(context) => prepare(storyFn(context)) as LegacyStoryFn<VueRenderer>
(context) => {
return prepare(storyFn(context)) as LegacyStoryFn<VueRenderer>;
}
);
}
6 changes: 4 additions & 2 deletions code/renderers/vue3/src/render.ts
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ export const render: ArgsStoryFn<VueRenderer> = (props, context) => {
);
}

return h(Component, props, createOrUpdateSlots(context));
return () => h(Component, props, createOrUpdateSlots(context));
};

let setupFunction = (_app: any) => {};
Expand Down Expand Up @@ -73,7 +73,9 @@ export function renderToCanvas(
map.set(canvasElement, appState);

return () => {
return h(rootElement, appState.reactiveArgs);
// not passing args here as props
// treat the rootElement as a component without props
return h(rootElement);
};
},
});
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,8 +27,6 @@ export {
NoDecorators,
DecoratorFunctionalComponent,
DecoratorFunctionalComponentArgsFromContext,
DecoratorFunctionalComponentArgsFromProps,
DecoratorComponentOptions,
DecoratorComponentOptionsArgsFromData,
DecoratorComponentOptionsArgsFromProps,
} from './ReactiveDecorators.stories';
Original file line number Diff line number Diff line change
Expand Up @@ -40,8 +40,6 @@ export {
NoDecorators,
DecoratorFunctionalComponent,
DecoratorFunctionalComponentArgsFromContext,
DecoratorFunctionalComponentArgsFromProps,
DecoratorComponentOptions,
DecoratorComponentOptionsArgsFromData,
DecoratorComponentOptionsArgsFromProps,
} from './ReactiveDecorators.stories';
Original file line number Diff line number Diff line change
@@ -1,33 +0,0 @@
import type { Meta } from '@storybook/vue3';
import { defineComponent } from 'vue';
import Reactivity from './Reactivity.vue';
import * as ReactiveDecorators from './ReactiveDecorators.stories';

const meta = {
...ReactiveDecorators.default,
component: Reactivity,
render: (args, { argTypes }) => {
return defineComponent({
props: Object.keys(argTypes),
components: { Reactivity },
template: `<div>Custom render uses options api and binds args to props: <Reactivity v-bind="$props">
<template #header="{title}"><h3>{{ header }} - Title: {{ title }}</h3></template>
{{ $props.default }}
<template #footer>{{ footer }}</template>
</Reactivity>
</div>`,
});
},
} satisfies Meta<typeof Reactivity>;

export default meta;

export {
NoDecorators,
DecoratorFunctionalComponent,
DecoratorFunctionalComponentArgsFromContext,
DecoratorFunctionalComponentArgsFromProps,
DecoratorComponentOptions,
DecoratorComponentOptionsArgsFromData,
DecoratorComponentOptionsArgsFromProps,
} from './ReactiveDecorators.stories';
Original file line number Diff line number Diff line change
Expand Up @@ -69,16 +69,6 @@ export const DecoratorFunctionalComponentArgsFromContext: Story = {
],
};

export const DecoratorFunctionalComponentArgsFromProps: Story = {
decorators: [
(storyFn, context) => {
const story = storyFn();
return (args) =>
h('div', [h('h2', `Decorator using args.label: ${args.label}`), h(story, context.args)]);
},
],
};

export const DecoratorComponentOptions: Story = {
decorators: [
(storyFn, context) => {
Expand All @@ -99,14 +89,3 @@ export const DecoratorComponentOptionsArgsFromData: Story = {
},
],
};

export const DecoratorComponentOptionsArgsFromProps: Story = {
decorators: [
(storyFn, context) => {
return {
props: ['label'],
template: '<div><h2>Decorator using label: {{label}}</h2><story /></div>',
};
},
],
};

0 comments on commit 8a50224

Please sign in to comment.