Skip to content

Commit

Permalink
type: fix ref readonly
Browse files Browse the repository at this point in the history
  • Loading branch information
NelsonYong committed Apr 27, 2024
1 parent c9d217d commit d300afa
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 19 deletions.
13 changes: 9 additions & 4 deletions packages/hooks/src/useFetchs/demo/demo.vue
Original file line number Diff line number Diff line change
Expand Up @@ -2,20 +2,22 @@
<div>
<div v-for="item in datas" :key="item.key" class="item">
{{ item.loading ? 'loading' : '' }}
{{ item.data }}
{{ item.data?.desc }}
</div>
</div>
</template>

<script lang="ts" setup>
import { computed, watchEffect } from 'vue'
import { computed, watchEffect, ref } from 'vue'
import { useFetchs } from 'vue-hooks-plus'
async function getUsername(params: { desc: string }): Promise<string> {
async function getUsername(params: { desc: string }): Promise<{ desc: string }> {
return new Promise(resolve => {
setTimeout(
() => {
resolve(`VueHooks Plus ${params.desc}`)
resolve({
desc: `VueHooks Plus ${params.desc}`,
})
},
params.desc === 'SSS' ? 4000 : 2000,
)
Expand All @@ -34,6 +36,9 @@
},
)
const name = ref()
name.value = fetchs?.value?.[0]?.data?.desc
watchEffect(() => {
arr.forEach(item => {
fetchRun({ desc: item })
Expand Down
27 changes: 12 additions & 15 deletions packages/hooks/src/useFetchs/index.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { createApp, defineComponent, readonly, ref, UnwrapRef, watch, watchEffect } from 'vue'
import { createApp, defineComponent, ref, UnwrapRef, watch, watchEffect } from 'vue'
import { UseRequestService, UseRequestOptions } from '../useRequest/types'
import useRequest from '../useRequest'

Expand All @@ -20,7 +20,7 @@ const DEFAULT_KEY = 'VUE_HOOKS_PLUS_USE_REQUEST_DEFAULT_KEY'
type FetchType<TData, TParams> = Record<
string | number,
{
data: TData | undefined
data: Readonly<TData> | undefined
params: TParams
loading: boolean
key: string | number
Expand Down Expand Up @@ -49,7 +49,6 @@ function useFetchs<TData, TParams>(
const newFetchs = ref<Fetchs>({})

const setFetchs = (fetchs_: Fetchs) => {
// @ts-ignore
newFetchs.value = fetchs_
}

Expand All @@ -68,10 +67,9 @@ function useFetchs<TData, TParams>(
watchEffect(() => {
fetchs.value[cacheKey as string] = {
key: cacheKey,
data: data?.value,
// @ts-ignore
data: data?.value as UnwrapRef<TData>,
// @ts-ignore
params: params.value as UnwrapRef<TParams>,
params: params.value,
loading: loading.value as UnwrapRef<boolean>,
}
setFetchs(fetchs.value as Fetchs)
Expand All @@ -85,25 +83,24 @@ function useFetchs<TData, TParams>(
newParams = undefined,
newLoading = false,
key = DEFAULT_KEY,
] = curr
] = curr;

const fetchKey = keyIsStringOrNumber(key) ? key : DEFAULT_KEY
const fetchKey = keyIsStringOrNumber(key) ? key : DEFAULT_KEY;

fetchs.value[fetchKey] = {
key: fetchKey,
data: newData,
// @ts-ignore
data: newData as UnwrapRef<TData>,
// @ts-ignore
params: newParams as UnwrapRef<TParams>,
loading: newLoading as UnwrapRef<boolean>,
}
setFetchs(fetchs.value as Fetchs)
params: newParams,
loading: newLoading,
};
setFetchs(fetchs.value);
})
})
}

return {
fetchs: readonly(newFetchs),
fetchs: newFetchs,
fetchRun,
}
}
Expand Down

0 comments on commit d300afa

Please sign in to comment.