All files / app/detail/components NutritionInputPrompt.tsx

100% Statements 5/5
100% Branches 0/0
100% Functions 3/3
100% Lines 5/5

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100                              3x 1x             3x 1x           3x                                                                                                                                          
/**
 * 营养信息录入提示 - 引导用户补充缺失的营养数据
 */
import { router } from 'expo-router';
import { Card, Text, XStack, YStack } from 'tamagui';
import { IconSymbol } from '@/src/components/ui/IconSymbol';
import { primaryScale, neutralScale } from '@/src/design-system/tokens';
 
interface NutritionInputPromptProps {
  catfoodId: number;
  catfoodName: string;
}
 
export function NutritionInputPrompt({ catfoodId, catfoodName }: NutritionInputPromptProps) {
  // 跳转到扫描页录入配料表
  const handleScanIngredients = () => {
    router.push({
      pathname: '/(tabs)/scanner',
      params: { catfoodId: String(catfoodId), catfoodName, scanType: 'ingredients' },
    });
  };
 
  // 跳转到扫描页录入条形码
  const handleScanBarcode = () => {
    router.push({
      pathname: '/(tabs)/scanner',
      params: { catfoodId: String(catfoodId), catfoodName, scanType: 'barcode' },
    });
  };
 
  return (
    <Card
      size="$2"
      bordered
      backgroundColor={neutralScale.neutral1}
      borderColor={neutralScale.neutral4}
      marginHorizontal="$3"
      marginBottom="$3"
      paddingVertical="$2.5"
      paddingHorizontal="$3"
      borderRadius="$4"
    >
      <YStack gap="$2">
        <XStack alignItems="center" gap="$2">
          <IconSymbol name="info.circle" size={16} color={neutralScale.neutral9} />
          <Text fontSize="$2" color={neutralScale.neutral10} fontWeight="500">
            暂无营养成分信息,帮助完善数据
          </Text>
        </XStack>
 
        <XStack gap="$2" flexWrap="wrap">
          {/* 录入配料表 */}
          <XStack
            flex={1}
            minWidth={140}
            paddingVertical="$2"
            paddingHorizontal="$3"
            backgroundColor="white"
            borderRadius="$3"
            borderWidth={1.5}
            borderColor={primaryScale.primary4}
            alignItems="center"
            justifyContent="center"
            gap="$1.5"
            pressStyle={{ opacity: 0.7, scale: 0.98 }}
            onPress={handleScanIngredients}
          >
            <IconSymbol name="camera.fill" size={16} color={primaryScale.primary7} />
            <Text fontSize="$2" color={primaryScale.primary7} fontWeight="600">
              拍摄配料表
            </Text>
          </XStack>
 
          {/* 扫描条形码 */}
          <XStack
            flex={1}
            minWidth={140}
            paddingVertical="$2"
            paddingHorizontal="$3"
            backgroundColor="white"
            borderRadius="$3"
            borderWidth={1.5}
            borderColor={neutralScale.neutral6}
            alignItems="center"
            justifyContent="center"
            gap="$1.5"
            pressStyle={{ opacity: 0.7, scale: 0.98 }}
            onPress={handleScanBarcode}
          >
            <IconSymbol name="barcode.viewfinder" size={16} color={neutralScale.neutral10} />
            <Text fontSize="$2" color={neutralScale.neutral10} fontWeight="600">
              扫描条形码
            </Text>
          </XStack>
        </XStack>
      </YStack>
    </Card>
  );
}