Skip to content

Commit

Permalink
fix(helper): update vue3 helper logic
Browse files Browse the repository at this point in the history
  • Loading branch information
BibiSebi authored and eunjae-lee committed Sep 8, 2023
1 parent b602eac commit dc1cb16
Show file tree
Hide file tree
Showing 5 changed files with 55 additions and 34 deletions.
8 changes: 1 addition & 7 deletions packages/cli/templates/vue3/src/App.vue
Original file line number Diff line number Diff line change
@@ -1,14 +1,8 @@
<script setup lang="ts">
import FieldPlugin from './components/FieldPlugin.vue'
import FieldPluginExample from './components/FieldPluginExample/index.vue'
import { FieldPluginProvider } from '@storyblok/field-plugin/vue3'
</script>

<template>
<FieldPluginProvider>
<template v-slot:loading><span>Loading...</span></template>
<template v-slot:error><span>Error</span></template>

<FieldPluginExample />
</FieldPluginProvider>
<FieldPluginExample />
</template>
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,10 @@
import { computed } from 'vue'
import { useFieldPlugin } from '@storyblok/field-plugin/vue3'
const plugin = useFieldPlugin()
const plugin = useFieldPlugin({
parseContent: (content: unknown) =>
typeof content === 'number' ? content : 0,
})
const handleIncrement = () => {
const content = plugin.data.content
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,15 +5,20 @@ import Counter from './Counter.vue'
import AssetSelector from './AssetSelector.vue'
import { useFieldPlugin } from '@storyblok/field-plugin/vue3'
const plugin = useFieldPlugin()
const plugin = useFieldPlugin({
parseContent: (content: unknown) =>
typeof content === 'number' ? content : 0,
})
function closeModal() {
plugin.actions.setModalOpen(false)
}
</script>

<template>
<div>
<div v-if="plugin.type === 'loaded'">
<pre>{{ plugin }}</pre>

<button
v-if="plugin.data.isModalOpen"
type="button"
Expand All @@ -35,11 +40,11 @@ function closeModal() {
<span class="sr-only">Close Modal</span>
</button>
<div class="container">
<Counter />
<hr />
<ModalToggle />
<hr />
<AssetSelector />
<!-- <Counter />-->
<!-- <hr />-->
<!-- <ModalToggle />-->
<!-- <hr />-->
<!-- <AssetSelector />-->
</div>
</div>
</template>
1 change: 0 additions & 1 deletion packages/field-plugin/helpers/vue3/src/index.ts
Original file line number Diff line number Diff line change
@@ -1,2 +1 @@
export * from './useFieldPlugin.ts'
export { default as FieldPluginProvider } from './FieldPluginProvider.vue'
56 changes: 38 additions & 18 deletions packages/field-plugin/helpers/vue3/src/useFieldPlugin.ts
Original file line number Diff line number Diff line change
@@ -1,23 +1,43 @@
import { inject } from 'vue'
import { type FieldPluginResponse } from '@storyblok/field-plugin'
import {
createFieldPlugin,
CreateFieldPluginOptions,
FieldPluginResponse,
} from '@storyblok/field-plugin'
import { onMounted, reactive, UnwrapRef } from 'vue'

export const useFieldPlugin = () => {
const plugin = inject<FieldPluginResponse<unknown>>(
'field-plugin',
() => {
throw new Error(
`You need to wrap your app with \`<FieldPluginProvider>\` component.`,
)
},
true,
)
export const useFieldPlugin = <Content>({
parseContent,
}: Omit<CreateFieldPluginOptions<Content>, 'onUpdateState'>): UnwrapRef<
FieldPluginResponse<Content>
> => {
const plugin = reactive<FieldPluginResponse<Content>>({
type: 'loading',
})

console.log(plugin)
if (plugin.type !== 'loaded') {
throw new Error(
'The plugin is not loaded, yet `useFieldPlugin()` was invoked. Ensure that the component that invoked `useFieldPlugin()` is wrapped within `<FieldPluginProvider>`, and that it is placed within the default slot.',
)
}
onMounted(() => {
createFieldPlugin<Content>({
onUpdateState: (state) => {
if (state.type === 'error') {
// plugin.type = 'error'
// plugin.error = state.error
Object.assign(plugin, {
type: 'error',
error: state.error,
})
} else if (state.type === 'loaded') {
Object.assign(plugin, {
type: 'loaded',
data: state.data,
actions: state.actions,
})
// plugin.type = 'loaded'
// plugin.data = state.data
// plugin.actions = state.actions
}
},
parseContent,
})
})

return plugin
}

0 comments on commit dc1cb16

Please sign in to comment.