Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Enhancement] Colorize OpenAPI HTTP Status Codes based on Status Code #1164

Closed
Twinki14 opened this issue Dec 16, 2024 · 1 comment
Closed
Labels
enhancement New feature or request PR welcome Feature Request approved

Comments

@Twinki14
Copy link
Contributor

What problem will this feature address?

HTTP Status Codes could use a little bit of color to add some "pop"

firefox_cra4eX6pIG

Describe the solution you'd like

Add some color to HTTP Status Codes by re-using some of the CSS classes we already have

1xx - text-blue & bg-blue #2563eb #2563eb
2xx - text-green & bg-green #16a34a #16a34a
3xx - text-orange & bg-orange #ea580c #ea580c
4xx - text-red & bg-red #dc2626 #dc2626
5xx - text-red & bg-red #dc2626 #dc2626

Describe alternatives you've considered

None

Additional context

No response

@Twinki14 Twinki14 added the enhancement New feature or request label Dec 16, 2024
@fuma-nama fuma-nama added the PR welcome Feature Request approved label Dec 16, 2024
@fuma-nama
Copy link
Owner

fuma-nama commented Jan 4, 2025

I think now it's great enough to have this on playground's result display:

image

You can also replace/style the tabs with renderer (make sure to include lib/source.ts in Tailwind CSS config!):

import { createOpenAPI } from 'fumadocs-openapi/server';
import { Tabs, TabsTrigger, TabsList } from 'fumadocs-ui/components/ui/tabs';
import { cn } from '@/lib/cn';

export const openapi = createOpenAPI({
  renderer: {
    Responses: ({ items, ...props }) => (
      <Tabs defaultValue={items[0]} {...props}>
        <TabsList>
          {items.map((item) => (
            <TabsTrigger
              key={item}
              value={item}
              className={cn(
                item.startsWith('2') &&
                  'data-[state=active]:border-green-400 data-[state=active]:text-green-400',
                (item.startsWith('4') || item.startsWith('5')) &&
                  'data-[state=active]:border-red-400 data-[state=active]:text-red-400',
              )}
            >
              {item}
            </TabsTrigger>
          ))}
        </TabsList>
        {props.children}
      </Tabs>
    ),
  },
});

@fuma-nama fuma-nama closed this as not planned Won't fix, can't repro, duplicate, stale Jan 4, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request PR welcome Feature Request approved
Projects
None yet
Development

No branches or pull requests

2 participants