mirror of
https://github.com/mountain-loop/yaak.git
synced 2026-03-22 01:19:13 +01:00
Add .oxfmtignore to skip generated bindings and wasm-pack output. Add npm format script, update DEVELOPMENT.md for Vite+ toolchain, and format all non-generated files with oxfmt. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
32 lines
929 B
TypeScript
32 lines
929 B
TypeScript
import { useMemo } from "react";
|
|
import { CountBadge } from "../components/core/CountBadge";
|
|
import type { TabItem } from "../components/core/Tabs/Tabs";
|
|
import type { HeaderModel } from "./useInheritedHeaders";
|
|
import { useInheritedHeaders } from "./useInheritedHeaders";
|
|
|
|
export function useHeadersTab<T extends string>(
|
|
tabValue: T,
|
|
model: HeaderModel | null,
|
|
label?: string,
|
|
) {
|
|
const inheritedHeaders = useInheritedHeaders(model);
|
|
|
|
return useMemo<TabItem[]>(() => {
|
|
if (model == null) return [];
|
|
|
|
const allHeaders = [
|
|
...inheritedHeaders,
|
|
...(model.model === "grpc_request" ? model.metadata : model.headers),
|
|
];
|
|
const numHeaders = allHeaders.filter((h) => h.name).length;
|
|
|
|
const tab: TabItem = {
|
|
value: tabValue,
|
|
label: label ?? "Headers",
|
|
rightSlot: <CountBadge count={numHeaders} />,
|
|
};
|
|
|
|
return [tab];
|
|
}, [inheritedHeaders, label, model, tabValue]);
|
|
}
|