diff --git a/client/src/components/Panels/Buttons/FavoritesButton.vue b/client/src/components/Panels/Buttons/FavoritesButton.vue index 190e8d23fdb3..79941f3395f7 100644 --- a/client/src/components/Panels/Buttons/FavoritesButton.vue +++ b/client/src/components/Panels/Buttons/FavoritesButton.vue @@ -14,13 +14,12 @@ library.add(faStar, faRegStar); interface Props { value?: boolean; - modelValue?: boolean; query?: string; } const props = defineProps(); -const currentValue = computed(() => props.value ?? props.modelValue ?? false); +const currentValue = computed(() => props.value ?? false); const toggle = ref(false); watchImmediate( @@ -30,7 +29,7 @@ watchImmediate( const emit = defineEmits<{ (e: "change", toggled: boolean): void; - (e: "update:modelValue", toggled: boolean): void; + (e: "input", toggled: boolean): void; }>(); const { isAnonymous } = storeToRefs(useUserStore()); @@ -58,7 +57,7 @@ watch( function toggleFavorites() { toggle.value = !toggle.value; - emit("update:modelValue", toggle.value); + emit("input", toggle.value); emit("change", toggle.value); } diff --git a/client/src/components/Workflow/List/WorkflowCard.vue b/client/src/components/Workflow/List/WorkflowCard.vue index f06481a74d2e..fc52c07a030b 100644 --- a/client/src/components/Workflow/List/WorkflowCard.vue +++ b/client/src/components/Workflow/List/WorkflowCard.vue @@ -3,7 +3,7 @@ import { faEdit, faPen, faUpload } from "@fortawesome/free-solid-svg-icons"; import { FontAwesomeIcon } from "@fortawesome/vue-fontawesome"; import { BButton, BLink } from "bootstrap-vue"; import { storeToRefs } from "pinia"; -import { computed, ref } from "vue"; +import { computed } from "vue"; import { copyWorkflow, updateWorkflow } from "@/components/Workflow/workflows.services"; import { Toast } from "@/composables/toast"; @@ -15,8 +15,6 @@ import StatelessTags from "@/components/TagsMultiselect/StatelessTags.vue"; import WorkflowActions from "@/components/Workflow/List/WorkflowActions.vue"; import WorkflowActionsExtend from "@/components/Workflow/List/WorkflowActionsExtend.vue"; import WorkflowIndicators from "@/components/Workflow/List/WorkflowIndicators.vue"; -import WorkflowRename from "@/components/Workflow/List/WorkflowRename.vue"; -import WorkflowPublished from "@/components/Workflow/Published/WorkflowPublished.vue"; import WorkflowInvocationsCount from "@/components/Workflow/WorkflowInvocationsCount.vue"; import WorkflowRunButton from "@/components/Workflow/WorkflowRunButton.vue"; @@ -37,17 +35,16 @@ const props = withDefaults(defineProps(), { const emit = defineEmits<{ (e: "tagClick", tag: string): void; - (e: "refreshList", overlayLoading?: boolean, b?: boolean): void; + (e: "refreshList", overlayLoading?: boolean, silent?: boolean): void; (e: "updateFilter", key: string, value: any): void; + (e: "rename", id: string, name: string): void; + (e: "preview", id: string): void; }>(); const userStore = useUserStore(); const { isAnonymous } = storeToRefs(userStore); -const showRename = ref(false); -const showPreview = ref(false); - const workflow = computed(() => props.workflow); const shared = computed(() => { @@ -96,15 +93,6 @@ async function onImport() { Toast.success("Workflow imported successfully"); } -function onRenameClose() { - showRename.value = false; - emit("refreshList", true); -} - -function toggleShowPreview(val: boolean = false) { - showPreview.value = val; -} - async function onTagsUpdate(tags: string[]) { workflow.value.tags = tags; await updateWorkflow(workflow.value.id, { tags }); @@ -139,8 +127,7 @@ async function onTagClick(tag: string) { + @refreshList="emit('refreshList', true)" /> @@ -148,9 +135,9 @@ async function onTagClick(tag: string) { v-b-tooltip.hover.noninteractive class="workflow-name-preview" title="Preview Workflow" - @click.stop.prevent="toggleShowPreview(true)" - >{{ workflow.name }} + @click.stop.prevent="emit('preview', props.workflow.id)"> + {{ workflow.name }} + + @click="emit('rename', props.workflow.id, props.workflow.name)"> @@ -221,37 +208,10 @@ async function onTagClick(tag: string) { - - - - - - - - + + diff --git a/client/src/components/Workflow/List/WorkflowList.vue b/client/src/components/Workflow/List/WorkflowList.vue index 93b77dc1d8b4..a41768fbe4ba 100644 --- a/client/src/components/Workflow/List/WorkflowList.vue +++ b/client/src/components/Workflow/List/WorkflowList.vue @@ -13,12 +13,12 @@ import { Toast } from "@/composables/toast"; import { useUserStore } from "@/stores/userStore"; import { rethrowSimple } from "@/utils/simple-error"; +import WorkflowCardList from "./WorkflowCardList.vue"; import FilterMenu from "@/components/Common/FilterMenu.vue"; import Heading from "@/components/Common/Heading.vue"; import ListHeader from "@/components/Common/ListHeader.vue"; import LoginRequired from "@/components/Common/LoginRequired.vue"; import LoadingSpan from "@/components/LoadingSpan.vue"; -import WorkflowCard from "@/components/Workflow/List/WorkflowCard.vue"; import WorkflowListActions from "@/components/Workflow/List/WorkflowListActions.vue"; library.add(faStar, faTrash); @@ -317,20 +317,11 @@ onMounted(() => { - - + @@ -370,32 +361,13 @@ onMounted(() => { } .cards-list { - container: card-list / inline-size; scroll-behavior: smooth; min-height: 150px; + display: flex; + flex-direction: column; overflow-y: auto; overflow-x: hidden; - - .list-view { - width: 100%; - } - - .grid-view { - width: calc(100% / 3); - } - - @container card-list (max-width: #{$breakpoint-xl}) { - .grid-view { - width: calc(100% / 2); - } - } - - @container card-list (max-width: #{$breakpoint-sm}) { - .grid-view { - width: 100%; - } - } } }