chore: rename api folder to composition

This commit is contained in:
chenjiahan
2020-08-26 15:32:30 +08:00
parent 216d326158
commit 2ec101f07b
22 changed files with 30 additions and 20 deletions

View File

@@ -0,0 +1,27 @@
import { inject, computed, onUnmounted } from 'vue';
export type Parent<T = unknown> = null | {
children: T[];
};
export function useParent<T = unknown>(key: string, child: T = {} as T) {
const parent = inject<Parent<T>>(key, null);
if (parent) {
const { children } = parent;
const index = computed(() => children.indexOf(child));
children.push(child);
onUnmounted(() => {
children.splice(index.value, 1);
});
return {
index,
parent,
};
}
return {};
}