shadcn slider
This commit is contained in:
		
							
								
								
									
										34
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										34
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							@@ -12,6 +12,7 @@
 | 
			
		||||
        "@radix-ui/react-accordion": "^1.2.8",
 | 
			
		||||
        "@radix-ui/react-label": "^2.1.4",
 | 
			
		||||
        "@radix-ui/react-select": "^2.2.2",
 | 
			
		||||
        "@radix-ui/react-slider": "^1.3.2",
 | 
			
		||||
        "@radix-ui/react-slot": "^1.2.0",
 | 
			
		||||
        "@t3-oss/env-nextjs": "^0.12.0",
 | 
			
		||||
        "class-variance-authority": "^0.7.1",
 | 
			
		||||
@@ -1358,6 +1359,39 @@
 | 
			
		||||
        }
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/@radix-ui/react-slider": {
 | 
			
		||||
      "version": "1.3.2",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@radix-ui/react-slider/-/react-slider-1.3.2.tgz",
 | 
			
		||||
      "integrity": "sha512-oQnqfgSiYkxZ1MrF6672jw2/zZvpB+PJsrIc3Zm1zof1JHf/kj7WhmROw7JahLfOwYQ5/+Ip0rFORgF1tjSiaQ==",
 | 
			
		||||
      "license": "MIT",
 | 
			
		||||
      "dependencies": {
 | 
			
		||||
        "@radix-ui/number": "1.1.1",
 | 
			
		||||
        "@radix-ui/primitive": "1.1.2",
 | 
			
		||||
        "@radix-ui/react-collection": "1.1.4",
 | 
			
		||||
        "@radix-ui/react-compose-refs": "1.1.2",
 | 
			
		||||
        "@radix-ui/react-context": "1.1.2",
 | 
			
		||||
        "@radix-ui/react-direction": "1.1.1",
 | 
			
		||||
        "@radix-ui/react-primitive": "2.1.0",
 | 
			
		||||
        "@radix-ui/react-use-controllable-state": "1.2.2",
 | 
			
		||||
        "@radix-ui/react-use-layout-effect": "1.1.1",
 | 
			
		||||
        "@radix-ui/react-use-previous": "1.1.1",
 | 
			
		||||
        "@radix-ui/react-use-size": "1.1.1"
 | 
			
		||||
      },
 | 
			
		||||
      "peerDependencies": {
 | 
			
		||||
        "@types/react": "*",
 | 
			
		||||
        "@types/react-dom": "*",
 | 
			
		||||
        "react": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc",
 | 
			
		||||
        "react-dom": "^16.8 || ^17.0 || ^18.0 || ^19.0 || ^19.0.0-rc"
 | 
			
		||||
      },
 | 
			
		||||
      "peerDependenciesMeta": {
 | 
			
		||||
        "@types/react": {
 | 
			
		||||
          "optional": true
 | 
			
		||||
        },
 | 
			
		||||
        "@types/react-dom": {
 | 
			
		||||
          "optional": true
 | 
			
		||||
        }
 | 
			
		||||
      }
 | 
			
		||||
    },
 | 
			
		||||
    "node_modules/@radix-ui/react-slot": {
 | 
			
		||||
      "version": "1.2.0",
 | 
			
		||||
      "resolved": "https://registry.npmjs.org/@radix-ui/react-slot/-/react-slot-1.2.0.tgz",
 | 
			
		||||
 
 | 
			
		||||
@@ -20,6 +20,7 @@
 | 
			
		||||
    "@radix-ui/react-accordion": "^1.2.8",
 | 
			
		||||
    "@radix-ui/react-label": "^2.1.4",
 | 
			
		||||
    "@radix-ui/react-select": "^2.2.2",
 | 
			
		||||
    "@radix-ui/react-slider": "^1.3.2",
 | 
			
		||||
    "@radix-ui/react-slot": "^1.2.0",
 | 
			
		||||
    "@t3-oss/env-nextjs": "^0.12.0",
 | 
			
		||||
    "class-variance-authority": "^0.7.1",
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										63
									
								
								src/components/ui/slider.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										63
									
								
								src/components/ui/slider.tsx
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,63 @@
 | 
			
		||||
"use client";
 | 
			
		||||
 | 
			
		||||
import * as React from "react";
 | 
			
		||||
import * as SliderPrimitive from "@radix-ui/react-slider";
 | 
			
		||||
 | 
			
		||||
import { cn } from "@/lib/utils";
 | 
			
		||||
 | 
			
		||||
function Slider({
 | 
			
		||||
  className,
 | 
			
		||||
  defaultValue,
 | 
			
		||||
  value,
 | 
			
		||||
  min = 0,
 | 
			
		||||
  max = 100,
 | 
			
		||||
  ...props
 | 
			
		||||
}: React.ComponentProps<typeof SliderPrimitive.Root>) {
 | 
			
		||||
  const _values = React.useMemo(
 | 
			
		||||
    () =>
 | 
			
		||||
      Array.isArray(value)
 | 
			
		||||
        ? value
 | 
			
		||||
        : Array.isArray(defaultValue)
 | 
			
		||||
          ? defaultValue
 | 
			
		||||
          : [min, max],
 | 
			
		||||
    [value, defaultValue, min, max],
 | 
			
		||||
  );
 | 
			
		||||
 | 
			
		||||
  return (
 | 
			
		||||
    <SliderPrimitive.Root
 | 
			
		||||
      data-slot="slider"
 | 
			
		||||
      defaultValue={defaultValue}
 | 
			
		||||
      value={value}
 | 
			
		||||
      min={min}
 | 
			
		||||
      max={max}
 | 
			
		||||
      className={cn(
 | 
			
		||||
        "relative flex w-full touch-none items-center select-none data-[disabled]:opacity-50 data-[orientation=vertical]:h-full data-[orientation=vertical]:min-h-44 data-[orientation=vertical]:w-auto data-[orientation=vertical]:flex-col",
 | 
			
		||||
        className,
 | 
			
		||||
      )}
 | 
			
		||||
      {...props}
 | 
			
		||||
    >
 | 
			
		||||
      <SliderPrimitive.Track
 | 
			
		||||
        data-slot="slider-track"
 | 
			
		||||
        className={cn(
 | 
			
		||||
          "bg-muted relative grow overflow-hidden rounded-full data-[orientation=horizontal]:h-1.5 data-[orientation=horizontal]:w-full data-[orientation=vertical]:h-full data-[orientation=vertical]:w-1.5",
 | 
			
		||||
        )}
 | 
			
		||||
      >
 | 
			
		||||
        <SliderPrimitive.Range
 | 
			
		||||
          data-slot="slider-range"
 | 
			
		||||
          className={cn(
 | 
			
		||||
            "bg-primary absolute data-[orientation=horizontal]:h-full data-[orientation=vertical]:w-full",
 | 
			
		||||
          )}
 | 
			
		||||
        />
 | 
			
		||||
      </SliderPrimitive.Track>
 | 
			
		||||
      {Array.from({ length: _values.length }, (_, index) => (
 | 
			
		||||
        <SliderPrimitive.Thumb
 | 
			
		||||
          data-slot="slider-thumb"
 | 
			
		||||
          key={index}
 | 
			
		||||
          className="border-primary bg-background ring-ring/50 block size-4 shrink-0 rounded-full border shadow-sm transition-[color,box-shadow] hover:ring-4 focus-visible:ring-4 focus-visible:outline-hidden disabled:pointer-events-none disabled:opacity-50"
 | 
			
		||||
        />
 | 
			
		||||
      ))}
 | 
			
		||||
    </SliderPrimitive.Root>
 | 
			
		||||
  );
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
export { Slider };
 | 
			
		||||
		Reference in New Issue
	
	Block a user