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-accordion": "^1.2.8",
 | 
				
			||||||
        "@radix-ui/react-label": "^2.1.4",
 | 
					        "@radix-ui/react-label": "^2.1.4",
 | 
				
			||||||
        "@radix-ui/react-select": "^2.2.2",
 | 
					        "@radix-ui/react-select": "^2.2.2",
 | 
				
			||||||
 | 
					        "@radix-ui/react-slider": "^1.3.2",
 | 
				
			||||||
        "@radix-ui/react-slot": "^1.2.0",
 | 
					        "@radix-ui/react-slot": "^1.2.0",
 | 
				
			||||||
        "@t3-oss/env-nextjs": "^0.12.0",
 | 
					        "@t3-oss/env-nextjs": "^0.12.0",
 | 
				
			||||||
        "class-variance-authority": "^0.7.1",
 | 
					        "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": {
 | 
					    "node_modules/@radix-ui/react-slot": {
 | 
				
			||||||
      "version": "1.2.0",
 | 
					      "version": "1.2.0",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@radix-ui/react-slot/-/react-slot-1.2.0.tgz",
 | 
					      "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-accordion": "^1.2.8",
 | 
				
			||||||
    "@radix-ui/react-label": "^2.1.4",
 | 
					    "@radix-ui/react-label": "^2.1.4",
 | 
				
			||||||
    "@radix-ui/react-select": "^2.2.2",
 | 
					    "@radix-ui/react-select": "^2.2.2",
 | 
				
			||||||
 | 
					    "@radix-ui/react-slider": "^1.3.2",
 | 
				
			||||||
    "@radix-ui/react-slot": "^1.2.0",
 | 
					    "@radix-ui/react-slot": "^1.2.0",
 | 
				
			||||||
    "@t3-oss/env-nextjs": "^0.12.0",
 | 
					    "@t3-oss/env-nextjs": "^0.12.0",
 | 
				
			||||||
    "class-variance-authority": "^0.7.1",
 | 
					    "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