woodpecker/web/src/compositions/useInjectProvide.ts

20 lines
590 B
TypeScript
Raw Normal View History

import { inject as vueInject, InjectionKey, provide as vueProvide, Ref } from 'vue';
import { Repo } from '~/lib/api/types';
export type InjectKeys = {
repo: Ref<Repo>;
};
export function inject<T extends keyof InjectKeys>(key: T): InjectKeys[T] {
const value = vueInject<InjectKeys[T]>(key);
if (value === undefined) {
throw new Error(`Please provide a value for ${key}`);
}
return value;
}
export function provide<T extends keyof InjectKeys>(key: T, value: InjectKeys[T]): void {
return vueProvide(key, value as T extends InjectionKey<infer V> ? V : InjectKeys[T]);
}