refactor(editor): Migrate tags.store to use composition API (no-changelog) (#9891)

This commit is contained in:
Ricardo Espinoza 2024-07-02 14:15:20 -04:00 committed by GitHub
parent 873b7e59dc
commit 8debac755e
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
6 changed files with 107 additions and 98 deletions

View file

@ -30,7 +30,7 @@ const initialState = {
areTagsEnabled: true, areTagsEnabled: true,
}, },
[STORES.TAGS]: { [STORES.TAGS]: {
tags: { tagsById: {
1: { 1: {
id: '1', id: '1',
name: 'tag1', name: 'tag1',

View file

@ -413,7 +413,7 @@ async function onWorkflowMenuSelect(action: WORKFLOW_MENU_ACTIONS): Promise<void
instanceId: rootStore.instanceId, instanceId: rootStore.instanceId,
}, },
tags: (tags ?? []).map((tagId) => { tags: (tags ?? []).map((tagId) => {
const { usageCount, ...tag } = tagsStore.getTagById(tagId); const { usageCount, ...tag } = tagsStore.tagsById[tagId];
return tag; return tag;
}), }),

View file

@ -103,7 +103,7 @@ export default defineComponent({
}, },
tags() { tags() {
const tags = this.tagIds const tags = this.tagIds
.map((tagId: string) => this.tagsStore.getTagById(tagId)) .map((tagId: string) => this.tagsStore.tagsById[tagId])
.filter(Boolean); // if tag has been deleted from store .filter(Boolean); // if tag has been deleted from store
let toDisplay: TagEl[] = this.limit ? tags.slice(0, this.limit) : tags; let toDisplay: TagEl[] = this.limit ? tags.slice(0, this.limit) : tags;

View file

@ -130,7 +130,7 @@ export default defineComponent({
}); });
const appliedTags = computed<string[]>(() => { const appliedTags = computed<string[]>(() => {
return props.modelValue.filter((id: string) => tagsStore.getTagById(id)); return props.modelValue.filter((id: string) => tagsStore.tagsById[id]);
}); });
watch( watch(

View file

@ -72,7 +72,7 @@ export default defineComponent({
return this.tagsStore.isLoading; return this.tagsStore.isLoading;
}, },
tags(): ITag[] { tags(): ITag[] {
return this.tagIds.map((tagId: string) => this.tagsStore.getTagById(tagId)).filter(Boolean); // if tag is deleted from store return this.tagIds.map((tagId: string) => this.tagsStore.tagsById[tagId]).filter(Boolean); // if tag is deleted from store
}, },
hasTags(): boolean { hasTags(): boolean {
return this.tags.length > 0; return this.tags.length > 0;
@ -110,7 +110,7 @@ export default defineComponent({
}, },
async onUpdate(id: string, name: string, cb: (tag: boolean, error?: Error) => void) { async onUpdate(id: string, name: string, cb: (tag: boolean, error?: Error) => void) {
const tag = this.tagsStore.getTagById(id); const tag = this.tagsStore.tagsById[id];
const oldName = tag.name; const oldName = tag.name;
try { try {
@ -144,11 +144,11 @@ export default defineComponent({
}, },
async onDelete(id: string, cb: (deleted: boolean, error?: Error) => void) { async onDelete(id: string, cb: (deleted: boolean, error?: Error) => void) {
const tag = this.tagsStore.getTagById(id); const tag = this.tagsStore.tagsById[id];
const name = tag.name; const name = tag.name;
try { try {
const deleted = await this.tagsStore.delete(id); const deleted = await this.tagsStore.deleteTagById(id);
if (!deleted) { if (!deleted) {
throw new Error(this.$locale.baseText('tagsManager.couldNotDeleteTag')); throw new Error(this.$locale.baseText('tagsManager.couldNotDeleteTag'));
} }

View file

@ -1,105 +1,114 @@
import { createTag, deleteTag, getTags, updateTag } from '@/api/tags'; import * as tagsApi from '@/api/tags';
import { STORES } from '@/constants'; import { STORES } from '@/constants';
import type { ITag, ITagsState } from '@/Interface'; import type { ITag } from '@/Interface';
import { defineStore } from 'pinia'; import { defineStore } from 'pinia';
import { useRootStore } from './root.store'; import { useRootStore } from './root.store';
import { computed, ref } from 'vue';
import { useWorkflowsStore } from './workflows.store'; import { useWorkflowsStore } from './workflows.store';
export const useTagsStore = defineStore(STORES.TAGS, { export const useTagsStore = defineStore(STORES.TAGS, () => {
state: (): ITagsState => ({ const tagsById = ref<Record<string, ITag>>({});
tags: {}, const loading = ref(false);
loading: false, const fetchedAll = ref(false);
fetchedAll: false, const fetchedUsageCount = ref(false);
fetchedUsageCount: false,
}), const rootStore = useRootStore();
getters: { const workflowsStore = useWorkflowsStore();
allTags(): ITag[] {
return Object.values(this.tags).sort((a, b) => a.name.localeCompare(b.name)); // Computed
},
isLoading(): boolean { const allTags = computed(() => {
return this.loading; return Object.values(tagsById.value).sort((a, b) => a.name.localeCompare(b.name));
}, });
hasTags(): boolean {
return Object.keys(this.tags).length > 0; const isLoading = computed(() => loading.value);
},
getTagById() { const hasTags = computed(() => Object.keys(tagsById.value).length > 0);
return (id: string) => this.tags[id];
}, // Methods
},
actions: { const setAllTags = (loadedTags: ITag[]) => {
setAllTags(tags: ITag[]): void { tagsById.value = loadedTags.reduce((accu: { [id: string]: ITag }, tag: ITag) => {
this.tags = tags.reduce((accu: { [id: string]: ITag }, tag: ITag) => {
accu[tag.id] = tag; accu[tag.id] = tag;
return accu; return accu;
}, {}); }, {});
this.fetchedAll = true; fetchedAll.value = true;
}, };
upsertTags(tags: ITag[]): void {
tags.forEach((tag) => { const upsertTags = (toUpsertTags: ITag[]) => {
const tagId = tag.id; toUpsertTags.forEach((toUpsertTag) => {
const currentTag = this.tags[tagId]; const tagId = toUpsertTag.id;
const currentTag = tagsById.value[tagId];
if (currentTag) { if (currentTag) {
const newTag = { const newTag = {
...currentTag, ...currentTag,
...tag, ...toUpsertTag,
}; };
this.tags = { tagsById.value = {
...this.tags, ...tagsById.value,
[tagId]: newTag, [tagId]: newTag,
}; };
} else { } else {
this.tags = { tagsById.value = {
...this.tags, ...tagsById.value,
[tagId]: tag, [tagId]: toUpsertTag,
}; };
} }
}); });
}, };
deleteTag(id: string): void {
const { [id]: deleted, ...rest } = this.tags;
this.tags = rest;
},
async fetchAll(params?: { force?: boolean; withUsageCount?: boolean }): Promise<ITag[]> { const deleteTag = (id: string) => {
const { [id]: deleted, ...rest } = tagsById.value;
tagsById.value = rest;
};
const fetchAll = async (params?: { force?: boolean; withUsageCount?: boolean }) => {
const { force = false, withUsageCount = false } = params || {}; const { force = false, withUsageCount = false } = params || {};
if (!force && this.fetchedAll && this.fetchedUsageCount === withUsageCount) { if (!force && fetchedAll.value && fetchedUsageCount.value === withUsageCount) {
return Object.values(this.tags); return Object.values(tagsById.value);
} }
this.loading = true; loading.value = true;
const rootStore = useRootStore(); const retrievedTags = await tagsApi.getTags(rootStore.restApiContext, Boolean(withUsageCount));
const tags = await getTags(rootStore.restApiContext, Boolean(withUsageCount)); setAllTags(retrievedTags);
this.setAllTags(tags); loading.value = false;
this.loading = false; return retrievedTags;
};
return tags; const create = async (name: string) => {
}, const createdTag = await tagsApi.createTag(rootStore.restApiContext, { name });
async create(name: string): Promise<ITag> { upsertTags([createdTag]);
const rootStore = useRootStore(); return createdTag;
const tag = await createTag(rootStore.restApiContext, { name }); };
this.upsertTags([tag]);
return tag; const rename = async ({ id, name }: { id: string; name: string }) => {
}, const updatedTag = await tagsApi.updateTag(rootStore.restApiContext, id, { name });
async rename({ id, name }: { id: string; name: string }) { upsertTags([updatedTag]);
const rootStore = useRootStore(); return updatedTag;
const tag = await updateTag(rootStore.restApiContext, id, { name }); };
this.upsertTags([tag]);
return tag; const deleteTagById = async (id: string) => {
}, const deleted = await tagsApi.deleteTag(rootStore.restApiContext, id);
async delete(id: string) {
const rootStore = useRootStore();
const deleted = await deleteTag(rootStore.restApiContext, id);
if (deleted) { if (deleted) {
this.deleteTag(id); deleteTag(id);
const workflowsStore = useWorkflowsStore();
workflowsStore.removeWorkflowTagId(id); workflowsStore.removeWorkflowTagId(id);
} }
return deleted; return deleted;
}, };
},
return {
allTags,
isLoading,
hasTags,
tagsById,
fetchAll,
create,
rename,
deleteTagById,
upsertTags,
deleteTag,
};
}); });