mirror of
https://github.com/Comfy-Org/ComfyUI_frontend.git
synced 2026-04-20 14:30:41 +00:00
## Summary Add SVG-based brand loading indicators (LogoCFillLoader, LogoComfyWaveLoader) and use the wave loader as the app loading screen. ## Changes - **What**: New `LogoCFillLoader` (bottom-to-top fill, plays once) and `LogoComfyWaveLoader` (wave water-fill animation) components with `size`, `color`, `bordered`, and `disableAnimation` props. Move all loaders from `components/common/` to `components/loader/`. Use `LogoComfyWaveLoader` in `App.vue` and `WorkspaceAuthGate.vue`. Render loader above BlockUI overlay (z-1200) to prevent dim wash-out. - **Dependencies**: None ## Review Focus - SVG mask-based animation approach using `currentColor` for flexible theming - z-index layering: loader at z-1200 renders above PrimeVue BlockUI's z-1100 modal overlay - `disableAnimation` prop used in WorkspaceAuthGate to show static logo outline during auth loading ## Screenshots (if applicable) [loading_record.webm](https://github.com/user-attachments/assets/b34f7296-9904-4a42-9273-a7d5fda49d15) Storybook stories added for both components under `Components/Loader/`. ┆Issue is synchronized with this [Notion page](https://www.notion.so/PR-9433-feat-add-Logo-C-fill-and-Comfy-wave-loading-indicator-components-31a6d73d3650811cacfdcf867b1f835f) by [Unito](https://www.unito.io) --------- Co-authored-by: GitHub Action <action@github.com>
51 lines
1.1 KiB
TypeScript
51 lines
1.1 KiB
TypeScript
import type { Meta, StoryObj } from '@storybook/vue3-vite'
|
|
|
|
import Loader from './Loader.vue'
|
|
|
|
const meta: Meta<typeof Loader> = {
|
|
title: 'Components/Loader/Loader',
|
|
component: Loader,
|
|
tags: ['autodocs'],
|
|
parameters: {
|
|
layout: 'centered'
|
|
},
|
|
argTypes: {
|
|
size: {
|
|
control: 'select',
|
|
options: ['sm', 'md', 'lg'],
|
|
description: 'Spinner size: sm (16px), md (32px), lg (48px)'
|
|
}
|
|
}
|
|
}
|
|
|
|
export default meta
|
|
type Story = StoryObj<typeof meta>
|
|
|
|
export const Default: Story = {}
|
|
|
|
export const Small: Story = {
|
|
args: { size: 'sm' }
|
|
}
|
|
|
|
export const Medium: Story = {
|
|
args: { size: 'md' }
|
|
}
|
|
|
|
export const Large: Story = {
|
|
args: { size: 'lg' }
|
|
}
|
|
|
|
export const CustomColor: Story = {
|
|
render: (args) => ({
|
|
components: { Loader },
|
|
setup() {
|
|
return { args }
|
|
},
|
|
template:
|
|
'<div class="flex gap-4 items-center"><Loader size="lg" class="text-white" /><Loader size="md" class="text-muted-foreground" /><Loader size="sm" class="text-base-foreground" /></div>'
|
|
}),
|
|
parameters: {
|
|
backgrounds: { default: 'dark' }
|
|
}
|
|
}
|