updated the ui v315

This commit is contained in:
philipcheung 2025-03-17 16:13:28 +08:00
parent f32a2dd307
commit 8dcbc0fc57
17 changed files with 136 additions and 48 deletions

BIN
public/images/asking.jpg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 167 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 142 KiB

After

Width:  |  Height:  |  Size: 561 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 83 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 52 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 17 KiB

After

Width:  |  Height:  |  Size: 47 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 381 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 372 KiB

BIN
public/images/peoples.webp Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 128 KiB

View File

@ -12,7 +12,7 @@ function Bestoil() {
const cook = useBreakpointValue({ const cook = useBreakpointValue({
base: "/images/cook_mb.webp", base: "/images/cook_mb.webp",
sm: "/images/cook_mb.webp", sm: "/images/cook_mb.webp",
md: "/images/cook_pc.webp", md: "/images/goldandhealthytext.webp",
}); });
// Create refs for elements we want to animate // Create refs for elements we want to animate
@ -62,16 +62,27 @@ function Bestoil() {
> >
<Flex <Flex
w='100%' w='100%'
gap={0}
justify={"center"} justify={"center"}
align={"center"} align={"center"}
direction={{ base: "column", sm: "column", md: "row" }} direction={{ base: "column", sm: "column", md: "row" }}
> >
<Stack
w={{ base: "70%", sm: "80%", md: '350px', lg: '500px' }}
align={"center"}
mr={{ base: 0, sm: 0, md: '-80px' }}
>
<Image src="/images/best5.webp" <Image src="/images/best5.webp"
fit='contain' fit='contain'
w={{ base: "70%", sm: "80%", md: '350px', lg: '500px' }}
/> />
<Image src='/images/cookmethods.webp'
w={'70%'}
display={{ base: "none", sm: "none", md: "flex" }}
fit='contain'
/>
</Stack>

View File

@ -1,15 +1,35 @@
import { Box, Stack, Image, Flex, SimpleGrid } from '@chakra-ui/react' import { Box, Stack, Image, Flex, SimpleGrid, Text } from '@chakra-ui/react'
import { useRef } from 'react'; import { useRef } from 'react';
import { motion } from 'framer-motion'; import { motion } from 'framer-motion';
import { colors } from '../colors';
// Create motion versions of Chakra components // Create motion versions of Chakra components
const MotionImage = motion(Image); const MotionImage = motion(Image);
const statement = `*營萃護心油成分含世界衛生組織建議之人體每日脂肪酸攝取比例其Omega-3比例較一般花生油、粟米油高特別有助平衡外出用餐多的都市人其身體脂肪酸比例增加抗發炎、抗氧化的能力維持心血管健康。
^Omega-6
`
function Compare() { function Compare() {
const compareRef = useRef(null); const compareRef = useRef(null);
const formatText = (text: string) => {
return text.split('\n').map((line, i) => (
<Box key={i}
color={colors.textColor}
fontSize='10px'
mx={5}
className='font-noto-sans font-regular'
>
{line.split('\t').map((segment, j) => (
j === 0 ? segment : <Text as="span" ml={4} key={j}>{segment}</Text>
))}
{i < text.split('\n').length - 1 && <br />}
</Box>
));
};
return ( return (
<Box <Box
ref={compareRef} ref={compareRef}
@ -18,7 +38,7 @@ function Compare() {
> >
<SimpleGrid columns={2} <SimpleGrid columns={2}
maxW="full" maxW="full"
h={{ base: '140vw', sm: '140vw', md: '120vw', lg: '50vw', xl: '55vw' }} h={{ base: '200vw', sm: '170vw', md: '145vw', lg: '61vw', xl: '61w' }}
mb="20px" // Add 20px bottom margin mb="20px" // Add 20px bottom margin
position="relative" position="relative"
zIndex="1" zIndex="1"
@ -61,7 +81,25 @@ function Compare() {
viewport={{ once: true }} viewport={{ once: true }}
transition={{ duration: 1.5 }} transition={{ duration: 1.5 }}
/> />
<Box
width={'full'}
justifyItems={'center'}
position="absolute"
bottom="17%"
left="50%"
transform="translateX(-51%)"
zIndex="1"
>
<Box
w='auto'
h='auto'>
{formatText(statement)}
</Box>
</Box>
</Stack> </Stack>
</SimpleGrid> </SimpleGrid>
{/* Use a larger negative margin to pull the flex up into the grid area */} {/* Use a larger negative margin to pull the flex up into the grid area */}

View File

@ -16,25 +16,37 @@ function Footer() {
</Text> </Text>
<Flex alignItems={'center'} justifyContent={'center'} direction="column"> <Flex alignItems={'center'} justifyContent={'center'} direction="column">
<Image src="/images/headerlogo.webp" alt="Logo" width="150px" /> <Image src="/images/headerlogo.webp" alt="Logo" width="150px" />
<Text textAlign={'center'} marginLeft={3} marginTop={2} className="font-melle font-medium" color={'#075C39'}>
{"【積極求變 健康向前】"}
</Text>
</Flex> </Flex>
<Flex <Flex
alignItems={'flex-end'} alignItems={'flex-end'}
w={{ base: '100%', sm: '100%', md: '60%', lg: '55%', xl: '55%' }} w={{ base: '100%', sm: '100%', md: '60%', lg: '55%', xl: '55%' }}
h='60px' h='60px'
>
<Stack gap={0}
position={'absolute'}
bottom={1}
> >
<Text <Text
className='font-noto-sans font-regular' className='font-noto-sans font-regular'
color={colors.textColor} color={colors.textColor}
fontSize={{ base: 'xs', sm: 'sm', md: 'md', lg: 'md', xl: 'md' }} fontSize={'8px'}
mt={5} mt={5}
ml={2} ml={2}
> >
{`Copyright © ${currentYear}合興食油(香港)有限公司 版權所有,不得轉載。`} {`Copyright © ${currentYear}合興食油(香港)有限公司 版權所有,不得轉載。`}
</Text> </Text>
<Text
className='font-noto-sans font-regular'
color={colors.textColor}
fontSize={'8px'}
ml={2}
>
{`參考資料 | 台灣營養師張益堯在節目《奕起聊健康》上分享關於「油脂」的健康 https://bit.ly/3FmZkCo https://bit.ly/4htQ9gt`}
</Text>
</Stack>
</Flex> </Flex>
</Stack> </Stack>
); );

View File

@ -1,4 +1,4 @@
import { Box, Flex, Image, Text, } from '@chakra-ui/react'; import { Box, Flex, Image, } from '@chakra-ui/react';
import {colors} from '../colors'; import {colors} from '../colors';
function Header() { function Header() {
@ -6,9 +6,6 @@ function Header() {
<Box bg={colors.topBarColor} py={4} w="full"> <Box bg={colors.topBarColor} py={4} w="full">
<Flex alignItems={'center'} justifyContent={'center'} direction="column"> <Flex alignItems={'center'} justifyContent={'center'} direction="column">
<Image src="/images/headerlogo.webp" alt="Logo" width="150px" /> <Image src="/images/headerlogo.webp" alt="Logo" width="150px" />
<Text textAlign={'center'} marginLeft={3} marginTop={2} className="font-melle font-medium" color={'#075C39'}>
{"【積極求變 健康向前】"}
</Text>
</Flex> </Flex>
</Box> </Box>
); );

View File

@ -4,8 +4,8 @@ import { motion } from 'framer-motion'
function Hero1() { function Hero1() {
const MotionImage = motion(ChakraImage); const MotionImage = motion(ChakraImage);
const oilImage = useBreakpointValue({ const oilImage = useBreakpointValue({
base: "/images/oilmobile.webp", base: "/images/lionglobe_product_mobile.webp",
sm: "/images/oil.webp", sm: "/images/lionglobe_product_pc.webp",
}); });
return ( return (
@ -82,7 +82,7 @@ function Hero1() {
justifyContent={{ base: "center", sm: "flex-start", md: "flex-start", lg: "flex-start", xl: "flex-start" }} justifyContent={{ base: "center", sm: "flex-start", md: "flex-start", lg: "flex-start", xl: "flex-start" }}
> >
<MotionImage <MotionImage
src="/images/people2.webp" src="/images/peoples.webp"
h={{ base: "120vw", sm: "70vw", md: "50vw", lg: "50vw", xl: "50vw" }} h={{ base: "120vw", sm: "70vw", md: "50vw", lg: "50vw", xl: "50vw" }}
// maxH={"50%"} // maxH={"50%"}
marginRight={{ base: "-30%", sm: "0", md: "0", lg: "0", xl: "0" }} marginRight={{ base: "-30%", sm: "0", md: "0", lg: "0", xl: "0" }}

View File

@ -92,7 +92,7 @@ function Hero2() {
h={"auto"} h={"auto"}
> >
<Image <Image
src="/images/oldman.jpg" src="/images/asking.jpg"
rounded="4xl" rounded="4xl"
marginTop={'10px'} marginTop={'10px'}
height={{ md: "100%", lg: "85%", xl: "65%" }} height={{ md: "100%", lg: "85%", xl: "65%" }}
@ -143,7 +143,7 @@ function Hero2() {
</MotionText> </MotionText>
</Flex> </Flex>
<MotionImage <MotionImage
src="/images/oldman.jpg" src="/images/asking.jpg"
rounded="4xl" rounded="4xl"
marginTop={'3px'} marginTop={'3px'}
h={{ md: "90%", lg: "65%", xl: "65%" }} h={{ md: "90%", lg: "65%", xl: "65%" }}
@ -163,7 +163,7 @@ function Hero2() {
<MotionText <MotionText
color={colors.textColor} color={colors.textColor}
className="font-noto-sans font-bold" className="font-noto-sans font-regular"
lineHeight={2} lineHeight={2}
variants={{ variants={{
hidden: { y: 20, opacity: 0 }, hidden: { y: 20, opacity: 0 },

View File

@ -146,6 +146,7 @@ function Oil_info() {
<Flex <Flex
w={{ base: '80%', sm: '80%', md: "100%" }} w={{ base: '80%', sm: '80%', md: "100%" }}
justify={{ base: 'flex-start', sm: 'flex-start', md: 'center' }} justify={{ base: 'flex-start', sm: 'flex-start', md: 'center' }}
display={{ base: 'flex', sm: 'flex', md: 'none' }}
> >
<Image src={oilinfotitle} <Image src={oilinfotitle}
w='400px' w='400px'
@ -173,6 +174,15 @@ function Oil_info() {
^調25%`)} ^調25%`)}
</Stack> </Stack>
<Stack
display={{ base: 'none', sm: 'none', md: 'flex' }}
>
<Image src='/images/mboilinfotitle.webp'
w='400px'
/>
</Stack>
<Text <Text
color='white' color='white'
className='NotoSansCJKtc font-medium' className='NotoSansCJKtc font-medium'
@ -183,7 +193,7 @@ function Oil_info() {
<Box as="span" className='NotoSansCJKtc font-xbold' display="inline"></Box> <Box as="span" className='NotoSansCJKtc font-xbold' display="inline"></Box>
{"人體應攝取良好的脂肪酸比例,這可由食油中攝取,從而調節膽固醇,保護心血管健康。"} {"人體應攝取良好的脂肪酸比例,這可由食油中攝取,從而調節膽固醇,保護心血管健康。"}
</Text> </Text>
<Text {/* <Text
color='white' color='white'
className='NotoSansCJKtc font-medium' className='NotoSansCJKtc font-medium'
mb={10} mb={10}
@ -191,7 +201,7 @@ function Oil_info() {
fontSize={'lg'} fontSize={'lg'}
> >
{"獅球嘜「營萃護心油」採用黃金比例調配,讓每一滴都成為心血管的隱形防護網。"} {"獅球嘜「營萃護心油」採用黃金比例調配,讓每一滴都成為心血管的隱形防護網。"}
</Text> </Text> */}
<Stack <Stack
display={{ base: 'none', sm: 'none', md: 'flex' }} display={{ base: 'none', sm: 'none', md: 'flex' }}
mt={-5}> mt={-5}>

View File

@ -22,11 +22,11 @@ const questions = [
{ {
image: '/images/q4.png', image: '/images/q4.png',
question: "貴價油 = 健康油?", question: "貴價油 = 健康油?",
answer: `健康關鍵在於「脂肪酸比例」,而非價格! answer: `錯!健康關鍵在於「脂肪酸比例」,而非價格!
\t MUFA / Omega-9 - MUFA / Omega-9 -
\t PUFA / Omega-36 - Omega-6 PUFA / Omega-36 - Omega-6
\t SFA - ` SFA - `
}, },
{ {
image: '/images/q5.png', image: '/images/q5.png',
@ -41,20 +41,38 @@ const questions = [
function Qa() { function Qa() {
const formatText = (text: string) => { const formatText = (text: string) => {
return text.split('\n').map((line, i) => ( // Define all the phrases that should have the bold styling
const boldPhrases = ["錯!", "未必!", "• 單元不飽和脂肪酸", "• 多元不飽和脂肪酸", "• 飽和脂肪", "看煙點:", "看脂肪酸比例:", "看認證:"];
return text.split('\n').map((line, i) => {
// Check if the line starts with any of the bold phrases
const matchingPhrase = boldPhrases.find(phrase => line.startsWith(phrase));
const hasBoldPhrase = !!matchingPhrase;
const boldPart = hasBoldPhrase ? matchingPhrase : "";
const restOfLine = hasBoldPhrase ? line.substring(matchingPhrase.length) : line;
return (
<Box key={i} <Box key={i}
color={colors.textColor} color={colors.textColor}
fontSize='lg' fontSize='lg'
ml={1} ml={1}
className='font-noto-sans font-regular' className='font-noto-sans font-regular'
> >
{line.split('\t').map((segment, j) => ( {hasBoldPhrase && (
<Text as="span" className='font-noto-sans font-black'>
{boldPart}
</Text>
)}
{restOfLine.split('\t').map((segment, j) => (
j === 0 ? segment : <Text as="span" ml={4} key={j}>{segment}</Text> j === 0 ? segment : <Text as="span" ml={4} key={j}>{segment}</Text>
))} ))}
{i < text.split('\n').length - 1 && <br />} {i < text.split('\n').length - 1 && <br />}
</Box> </Box>
)); );
});
}; };
return ( return (
<Box <Box
w="100%" w="100%"

View File

@ -89,6 +89,8 @@ function Salespoint() {
gap={12} gap={12}
direction={{ base: 'column', sm: 'column', md: 'row' }} direction={{ base: 'column', sm: 'column', md: 'row' }}
justify="center" justify="center"
align={'flex-end'}
> >
{shopImages.map((image, index) => ( {shopImages.map((image, index) => (
<motion.div <motion.div