feat: Update cube box quantity input to use plus/minus buttons and default to 1
All checks were successful
Build and Deploy / build (push) Successful in 1m18s
All checks were successful
Build and Deploy / build (push) Successful in 1m18s
This commit is contained in:
@@ -1,5 +1,5 @@
|
|||||||
import React, { useState, useRef, useEffect } from 'react';
|
import React, { useState, useRef, useEffect } from 'react';
|
||||||
import { Layers, RotateCcw, Box, Check, Loader2, Upload, LayoutGrid, List, Sliders, Settings, Users, Download, Copy, FileDown, Trash2, Search, X, PlayCircle } from 'lucide-react';
|
import { Layers, RotateCcw, Box, Check, Loader2, Upload, LayoutGrid, List, Sliders, Settings, Users, Download, Copy, FileDown, Trash2, Search, X, PlayCircle, Plus, Minus } from 'lucide-react';
|
||||||
import { ScryfallCard, ScryfallSet } from '../../services/ScryfallService';
|
import { ScryfallCard, ScryfallSet } from '../../services/ScryfallService';
|
||||||
import { PackGeneratorService, ProcessedPools, SetsMap, Pack, PackGenerationSettings } from '../../services/PackGeneratorService';
|
import { PackGeneratorService, ProcessedPools, SetsMap, Pack, PackGenerationSettings } from '../../services/PackGeneratorService';
|
||||||
import { PackCard } from '../../components/PackCard';
|
import { PackCard } from '../../components/PackCard';
|
||||||
@@ -107,7 +107,7 @@ export const CubeManager: React.FC<CubeManagerProps> = ({ packs, setPacks, avail
|
|||||||
});
|
});
|
||||||
const [numBoxes, setNumBoxes] = useState<number>(() => {
|
const [numBoxes, setNumBoxes] = useState<number>(() => {
|
||||||
const saved = localStorage.getItem('cube_numBoxes');
|
const saved = localStorage.getItem('cube_numBoxes');
|
||||||
return saved ? parseInt(saved) : 3;
|
return saved ? parseInt(saved) : 1;
|
||||||
});
|
});
|
||||||
|
|
||||||
const [cardWidth, setCardWidth] = useState(() => {
|
const [cardWidth, setCardWidth] = useState(() => {
|
||||||
@@ -697,17 +697,27 @@ export const CubeManager: React.FC<CubeManagerProps> = ({ packs, setPacks, avail
|
|||||||
{sourceMode === 'set' && (
|
{sourceMode === 'set' && (
|
||||||
<div className="mb-4">
|
<div className="mb-4">
|
||||||
<label className="text-xs font-bold text-slate-400 uppercase mb-1 block">Quantity</label>
|
<label className="text-xs font-bold text-slate-400 uppercase mb-1 block">Quantity</label>
|
||||||
<div className="flex items-center gap-2 bg-slate-800 p-2 rounded border border-slate-700">
|
<div className="flex items-center gap-3 bg-slate-800 p-2 rounded border border-slate-700">
|
||||||
<input
|
<div className="flex items-center gap-1">
|
||||||
type="number"
|
<button
|
||||||
min={1}
|
onClick={() => setNumBoxes(prev => Math.max(1, prev - 1))}
|
||||||
max={10}
|
disabled={numBoxes <= 1 || loading}
|
||||||
value={numBoxes}
|
className="p-1.5 rounded bg-slate-700 hover:bg-slate-600 disabled:opacity-50 disabled:cursor-not-allowed transition-colors text-white"
|
||||||
onChange={(e) => setNumBoxes(parseInt(e.target.value))}
|
>
|
||||||
className="w-16 bg-slate-700 border-none rounded p-1 text-center text-white font-mono"
|
<Minus className="w-4 h-4" />
|
||||||
disabled={loading}
|
</button>
|
||||||
/>
|
<span className="w-8 text-center font-mono font-bold text-white text-lg">{numBoxes}</span>
|
||||||
<span className="text-slate-300 text-xs">Boxes ({numBoxes * 36} Packs)</span>
|
<button
|
||||||
|
onClick={() => setNumBoxes(prev => Math.min(10, prev + 1))}
|
||||||
|
disabled={numBoxes >= 10 || loading}
|
||||||
|
className="p-1.5 rounded bg-slate-700 hover:bg-slate-600 disabled:opacity-50 disabled:cursor-not-allowed transition-colors text-white"
|
||||||
|
>
|
||||||
|
<Plus className="w-4 h-4" />
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
<span className="text-slate-400 text-xs font-medium border-l border-slate-700 pl-3">
|
||||||
|
<span className="text-white font-bold">{numBoxes * 36}</span> Packs
|
||||||
|
</span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
)}
|
)}
|
||||||
|
|||||||
Reference in New Issue
Block a user