Home / File/ carousel-rtl.tsx — ui Source File

carousel-rtl.tsx — ui Source File

Architecture documentation for carousel-rtl.tsx, a tsx file in the ui codebase. 3 imports, 0 dependents.

File tsx DocumentationAtlas SearchAPI 3 imports 2 functions

Entity Profile

Dependency Diagram

graph LR
  1899fd32_ac2c_c271_6dc5_24ee1ef64b41["carousel-rtl.tsx"]
  32129cf4_1d7d_ebb9_b756_f6fa61def19f["card"]
  1899fd32_ac2c_c271_6dc5_24ee1ef64b41 --> 32129cf4_1d7d_ebb9_b756_f6fa61def19f
  67fa46df_26da_7a29_d5c0_c0b6ecbc4baf["carousel"]
  1899fd32_ac2c_c271_6dc5_24ee1ef64b41 --> 67fa46df_26da_7a29_d5c0_c0b6ecbc4baf
  2c1404ab_bf28_6225_f9a0_b9e29400c66c["language-selector"]
  1899fd32_ac2c_c271_6dc5_24ee1ef64b41 --> 2c1404ab_bf28_6225_f9a0_b9e29400c66c
  style 1899fd32_ac2c_c271_6dc5_24ee1ef64b41 fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

"use client"

import { Card, CardContent } from "@/examples/radix/ui-rtl/card"
import {
  Carousel,
  CarouselContent,
  CarouselItem,
  CarouselNext,
  CarouselPrevious,
} from "@/examples/radix/ui-rtl/carousel"

import {
  useTranslation,
  type Translations,
} from "@/components/language-selector"

const translations: Translations = {
  en: {
    dir: "ltr",
    values: {},
  },
  ar: {
    dir: "rtl",
    values: {},
  },
  he: {
    dir: "rtl",
    values: {},
  },
}

function toArabicNumerals(num: number): string {
  const arabicNumerals = ["٠", "١", "٢", "٣", "٤", "٥", "٦", "٧", "٨", "٩"]
  return num
    .toString()
    .split("")
    .map((digit) => arabicNumerals[parseInt(digit, 10)])
    .join("")
}

export function CarouselRtl() {
  const { dir, language } = useTranslation(translations, "ar")

  const formatNumber = (num: number): string => {
    if (language === "ar") {
      return toArabicNumerals(num)
    }
    return num.toString()
  }

  return (
    <Carousel
      dir={dir}
      className="w-full max-w-[12rem] sm:max-w-xs"
      opts={{
        direction: dir,
      }}
    >
      <CarouselContent>
        {Array.from({ length: 5 }).map((_, index) => (
          <CarouselItem key={index}>
            <div className="p-1">
              <Card dir={dir}>
                <CardContent className="flex aspect-square items-center justify-center p-6">
                  <span className="text-4xl font-semibold">
                    {formatNumber(index + 1)}
                  </span>
                </CardContent>
              </Card>
            </div>
          </CarouselItem>
        ))}
      </CarouselContent>
      <CarouselPrevious />
      <CarouselNext />
    </Carousel>
  )
}

Subdomains

Dependencies

  • card
  • carousel
  • language-selector

Frequently Asked Questions

What does carousel-rtl.tsx do?
carousel-rtl.tsx is a source file in the ui codebase, written in tsx. It belongs to the DocumentationAtlas domain, SearchAPI subdomain.
What functions are defined in carousel-rtl.tsx?
carousel-rtl.tsx defines 2 function(s): CarouselRtl, toArabicNumerals.
What does carousel-rtl.tsx depend on?
carousel-rtl.tsx imports 3 module(s): card, carousel, language-selector.
Where is carousel-rtl.tsx in the architecture?
carousel-rtl.tsx is located at apps/v4/examples/radix/carousel-rtl.tsx (domain: DocumentationAtlas, subdomain: SearchAPI, directory: apps/v4/examples/radix).

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free