Compare commits

...

4 Commits

41 changed files with 2091 additions and 1329 deletions

View File

@ -43,6 +43,7 @@
"@vant/auto-import-resolver": "^1.2.1", "@vant/auto-import-resolver": "^1.2.1",
"@vitejs/plugin-legacy": "^5.3.0", "@vitejs/plugin-legacy": "^5.3.0",
"@vitejs/plugin-vue": "^5.0.5", "@vitejs/plugin-vue": "^5.0.5",
"@vitejs/plugin-vue-jsx": "^5.1.1",
"@vueuse/core": "^10.11.0", "@vueuse/core": "^10.11.0",
"autoprefixer": "^10.4.20", "autoprefixer": "^10.4.20",
"babel-plugin-transform-react-jsx": "^6.24.1", "babel-plugin-transform-react-jsx": "^6.24.1",

View File

@ -99,6 +99,9 @@ importers:
'@vitejs/plugin-vue': '@vitejs/plugin-vue':
specifier: ^5.0.5 specifier: ^5.0.5
version: 5.1.2(vite@5.3.5(@types/node@22.13.10)(sass@1.77.8)(terser@5.31.3))(vue@3.4.35) version: 5.1.2(vite@5.3.5(@types/node@22.13.10)(sass@1.77.8)(terser@5.31.3))(vue@3.4.35)
'@vitejs/plugin-vue-jsx':
specifier: ^5.1.1
version: 5.1.1(vite@5.3.5(@types/node@22.13.10)(sass@1.77.8)(terser@5.31.3))(vue@3.4.35)
'@vueuse/core': '@vueuse/core':
specifier: ^10.11.0 specifier: ^10.11.0
version: 10.11.0(vue@3.4.35) version: 10.11.0(vue@3.4.35)
@ -122,7 +125,7 @@ importers:
version: 0.18.2(@vueuse/core@10.11.0(vue@3.4.35))(rollup@4.20.0) version: 0.18.2(@vueuse/core@10.11.0(vue@3.4.35))(rollup@4.20.0)
unplugin-vue-components: unplugin-vue-components:
specifier: ^0.27.3 specifier: ^0.27.3
version: 0.27.3(@babel/parser@7.27.2)(rollup@4.20.0)(vue@3.4.35) version: 0.27.3(@babel/parser@7.28.4)(rollup@4.20.0)(vue@3.4.35)
vite: vite:
specifier: ^5.3.4 specifier: ^5.3.4
version: 5.3.5(@types/node@22.13.10)(sass@1.77.8)(terser@5.31.3) version: 5.3.5(@types/node@22.13.10)(sass@1.77.8)(terser@5.31.3)
@ -157,10 +160,18 @@ packages:
resolution: {integrity: sha512-bYcppcpKBvX4znYaPEeFau03bp89ShqNMLs+rmdptMw+heSZh9+z84d2YG+K7cYLbWwzdjtDoW/uqZmPjulClQ==} resolution: {integrity: sha512-bYcppcpKBvX4znYaPEeFau03bp89ShqNMLs+rmdptMw+heSZh9+z84d2YG+K7cYLbWwzdjtDoW/uqZmPjulClQ==}
engines: {node: '>=6.9.0'} engines: {node: '>=6.9.0'}
'@babel/compat-data@7.28.4':
resolution: {integrity: sha512-YsmSKC29MJwf0gF8Rjjrg5LQCmyh+j/nD8/eP7f+BeoQTKYqs9RoWbjGOdy0+1Ekr68RJZMUOPVQaQisnIo4Rw==}
engines: {node: '>=6.9.0'}
'@babel/core@7.25.2': '@babel/core@7.25.2':
resolution: {integrity: sha512-BBt3opiCOxUr9euZ5/ro/Xv8/V7yJ5bjYMqG/C1YAo8MIKAnumZalCN+msbci3Pigy4lIQfPUpfMM27HMGaYEA==} resolution: {integrity: sha512-BBt3opiCOxUr9euZ5/ro/Xv8/V7yJ5bjYMqG/C1YAo8MIKAnumZalCN+msbci3Pigy4lIQfPUpfMM27HMGaYEA==}
engines: {node: '>=6.9.0'} engines: {node: '>=6.9.0'}
'@babel/core@7.28.4':
resolution: {integrity: sha512-2BCOP7TN8M+gVDj7/ht3hsaO/B/n5oDbiAyyvnRlNOs+u1o+JWNYTQrmpuNp1/Wq2gcFrI01JAW+paEKDMx/CA==}
engines: {node: '>=6.9.0'}
'@babel/generator@7.25.0': '@babel/generator@7.25.0':
resolution: {integrity: sha512-3LEEcj3PVW8pW2R1SR1M89g/qrYk/m/mB/tLqn7dn4sbBUQyTqnlod+II2U4dqiGtUmkcnAmkMDralTFZttRiw==} resolution: {integrity: sha512-3LEEcj3PVW8pW2R1SR1M89g/qrYk/m/mB/tLqn7dn4sbBUQyTqnlod+II2U4dqiGtUmkcnAmkMDralTFZttRiw==}
engines: {node: '>=6.9.0'} engines: {node: '>=6.9.0'}
@ -169,6 +180,10 @@ packages:
resolution: {integrity: sha512-UnJfnIpc/+JO0/+KRVQNGU+y5taA5vCbwN8+azkX6beii/ZF+enZJSOKo11ZSzGJjlNfJHfQtmQT8H+9TXPG2w==} resolution: {integrity: sha512-UnJfnIpc/+JO0/+KRVQNGU+y5taA5vCbwN8+azkX6beii/ZF+enZJSOKo11ZSzGJjlNfJHfQtmQT8H+9TXPG2w==}
engines: {node: '>=6.9.0'} engines: {node: '>=6.9.0'}
'@babel/generator@7.28.3':
resolution: {integrity: sha512-3lSpxGgvnmZznmBkCRnVREPUFJv2wrv9iAoFDvADJc0ypmdOxdUtcLeBgBJ6zE0PMeTKnxeQzyk0xTBq4Ep7zw==}
engines: {node: '>=6.9.0'}
'@babel/helper-annotate-as-pure@7.24.7': '@babel/helper-annotate-as-pure@7.24.7':
resolution: {integrity: sha512-BaDeOonYvhdKw+JoMVkAixAAJzG2jVPIwWoKBPdYuY9b452e2rPuI9QPYh3KpofZ3pW2akOmwZLOiOsHMiqRAg==} resolution: {integrity: sha512-BaDeOonYvhdKw+JoMVkAixAAJzG2jVPIwWoKBPdYuY9b452e2rPuI9QPYh3KpofZ3pW2akOmwZLOiOsHMiqRAg==}
engines: {node: '>=6.9.0'} engines: {node: '>=6.9.0'}
@ -177,6 +192,10 @@ packages:
resolution: {integrity: sha512-WnuuDILl9oOBbKnb4L+DyODx7iC47XfzmNCpTttFsSp6hTG7XZxu60+4IO+2/hPfcGOoKbFiwoI/+zwARbNQow==} resolution: {integrity: sha512-WnuuDILl9oOBbKnb4L+DyODx7iC47XfzmNCpTttFsSp6hTG7XZxu60+4IO+2/hPfcGOoKbFiwoI/+zwARbNQow==}
engines: {node: '>=6.9.0'} engines: {node: '>=6.9.0'}
'@babel/helper-annotate-as-pure@7.27.3':
resolution: {integrity: sha512-fXSwMQqitTGeHLBC08Eq5yXz2m37E4pJX1qAU1+2cNedz/ifv/bVXft90VeSav5nFO61EcNgwr0aJxbyPaWBPg==}
engines: {node: '>=6.9.0'}
'@babel/helper-builder-binary-assignment-operator-visitor@7.24.7': '@babel/helper-builder-binary-assignment-operator-visitor@7.24.7':
resolution: {integrity: sha512-xZeCVVdwb4MsDBkkyZ64tReWYrLRHlMN72vP7Bdm3OUOuyFZExhsHUUnuWnm2/XOlAJzR0LfPpB56WXZn0X/lA==} resolution: {integrity: sha512-xZeCVVdwb4MsDBkkyZ64tReWYrLRHlMN72vP7Bdm3OUOuyFZExhsHUUnuWnm2/XOlAJzR0LfPpB56WXZn0X/lA==}
engines: {node: '>=6.9.0'} engines: {node: '>=6.9.0'}
@ -185,6 +204,10 @@ packages:
resolution: {integrity: sha512-U2U5LsSaZ7TAt3cfaymQ8WHh0pxvdHoEk6HVpaexxixjyEquMh0L0YNJNM6CTGKMXV1iksi0iZkGw4AcFkPaaw==} resolution: {integrity: sha512-U2U5LsSaZ7TAt3cfaymQ8WHh0pxvdHoEk6HVpaexxixjyEquMh0L0YNJNM6CTGKMXV1iksi0iZkGw4AcFkPaaw==}
engines: {node: '>=6.9.0'} engines: {node: '>=6.9.0'}
'@babel/helper-compilation-targets@7.27.2':
resolution: {integrity: sha512-2+1thGUUWWjLTYTHZWK1n8Yga0ijBz1XAhUXcKy81rd5g6yh7hGqMp45v7cadSbEHc9G3OTv45SyneRN3ps4DQ==}
engines: {node: '>=6.9.0'}
'@babel/helper-create-class-features-plugin@7.25.0': '@babel/helper-create-class-features-plugin@7.25.0':
resolution: {integrity: sha512-GYM6BxeQsETc9mnct+nIIpf63SAyzvyYN7UB/IlTyd+MBg06afFGp0mIeUqGyWgS2mxad6vqbMrHVlaL3m70sQ==} resolution: {integrity: sha512-GYM6BxeQsETc9mnct+nIIpf63SAyzvyYN7UB/IlTyd+MBg06afFGp0mIeUqGyWgS2mxad6vqbMrHVlaL3m70sQ==}
engines: {node: '>=6.9.0'} engines: {node: '>=6.9.0'}
@ -208,6 +231,10 @@ packages:
peerDependencies: peerDependencies:
'@babel/core': ^7.4.0 || ^8.0.0-0 <8.0.0 '@babel/core': ^7.4.0 || ^8.0.0-0 <8.0.0
'@babel/helper-globals@7.28.0':
resolution: {integrity: sha512-+W6cISkXFa1jXsDEdYA8HeevQT/FULhxzR99pxphltZcVaugps53THCeiWA8SguxxpSp3gKPiuYfSWopkLQ4hw==}
engines: {node: '>=6.9.0'}
'@babel/helper-member-expression-to-functions@7.24.8': '@babel/helper-member-expression-to-functions@7.24.8':
resolution: {integrity: sha512-LABppdt+Lp/RlBxqrh4qgf1oEH/WxdzQNDJIu5gC/W1GyvPVrOBiItmmM8wan2fm4oYqFuFfkXmlGpLQhPY8CA==} resolution: {integrity: sha512-LABppdt+Lp/RlBxqrh4qgf1oEH/WxdzQNDJIu5gC/W1GyvPVrOBiItmmM8wan2fm4oYqFuFfkXmlGpLQhPY8CA==}
engines: {node: '>=6.9.0'} engines: {node: '>=6.9.0'}
@ -230,6 +257,12 @@ packages:
peerDependencies: peerDependencies:
'@babel/core': ^7.0.0 '@babel/core': ^7.0.0
'@babel/helper-module-transforms@7.28.3':
resolution: {integrity: sha512-gytXUbs8k2sXS9PnQptz5o0QnpLL51SwASIORY6XaBKF88nsOT0Zw9szLqlSGQDP/4TljBAD5y98p2U1fqkdsw==}
engines: {node: '>=6.9.0'}
peerDependencies:
'@babel/core': ^7.0.0
'@babel/helper-optimise-call-expression@7.24.7': '@babel/helper-optimise-call-expression@7.24.7':
resolution: {integrity: sha512-jKiTsW2xmWwxT1ixIdfXUZp+P5yURx2suzLZr5Hi64rURpDYdMW0pv+Uf17EYk2Rd428Lx4tLsnjGJzYKDM/6A==} resolution: {integrity: sha512-jKiTsW2xmWwxT1ixIdfXUZp+P5yURx2suzLZr5Hi64rURpDYdMW0pv+Uf17EYk2Rd428Lx4tLsnjGJzYKDM/6A==}
engines: {node: '>=6.9.0'} engines: {node: '>=6.9.0'}
@ -296,6 +329,10 @@ packages:
resolution: {integrity: sha512-xb8t9tD1MHLungh/AIoWYN+gVHaB9kwlu8gffXGSt3FFEIT7RjS+xWbc2vUD1UTZdIpKj/ab3rdqJ7ufngyi2Q==} resolution: {integrity: sha512-xb8t9tD1MHLungh/AIoWYN+gVHaB9kwlu8gffXGSt3FFEIT7RjS+xWbc2vUD1UTZdIpKj/ab3rdqJ7ufngyi2Q==}
engines: {node: '>=6.9.0'} engines: {node: '>=6.9.0'}
'@babel/helper-validator-option@7.27.1':
resolution: {integrity: sha512-YvjJow9FxbhFFKDSuFnVCe2WxXk1zWc22fFePVNEaWJEu8IrZVlda6N0uHwzZrUM1il7NC9Mlp4MaJYbYd9JSg==}
engines: {node: '>=6.9.0'}
'@babel/helper-wrap-function@7.25.0': '@babel/helper-wrap-function@7.25.0':
resolution: {integrity: sha512-s6Q1ebqutSiZnEjaofc/UKDyC4SbzV5n5SrA2Gq8UawLycr3i04f1dX4OzoQVnexm6aOCh37SQNYlJ/8Ku+PMQ==} resolution: {integrity: sha512-s6Q1ebqutSiZnEjaofc/UKDyC4SbzV5n5SrA2Gq8UawLycr3i04f1dX4OzoQVnexm6aOCh37SQNYlJ/8Ku+PMQ==}
engines: {node: '>=6.9.0'} engines: {node: '>=6.9.0'}
@ -304,6 +341,10 @@ packages:
resolution: {integrity: sha512-MjgLZ42aCm0oGjJj8CtSM3DB8NOOf8h2l7DCTePJs29u+v7yO/RBX9nShlKMgFnRks/Q4tBAe7Hxnov9VkGwLw==} resolution: {integrity: sha512-MjgLZ42aCm0oGjJj8CtSM3DB8NOOf8h2l7DCTePJs29u+v7yO/RBX9nShlKMgFnRks/Q4tBAe7Hxnov9VkGwLw==}
engines: {node: '>=6.9.0'} engines: {node: '>=6.9.0'}
'@babel/helpers@7.28.4':
resolution: {integrity: sha512-HFN59MmQXGHVyYadKLVumYsA9dBFun/ldYxipEjzA4196jpLZd8UjEEBLkbEkvfYreDqJhZxYAWFPtrfhNpj4w==}
engines: {node: '>=6.9.0'}
'@babel/highlight@7.24.7': '@babel/highlight@7.24.7':
resolution: {integrity: sha512-EStJpq4OuY8xYfhGVXngigBJRWxftKX9ksiGDnmlY3o7B/V7KIAc9X4oiK87uPJSc/vs5L869bem5fhZa8caZw==} resolution: {integrity: sha512-EStJpq4OuY8xYfhGVXngigBJRWxftKX9ksiGDnmlY3o7B/V7KIAc9X4oiK87uPJSc/vs5L869bem5fhZa8caZw==}
engines: {node: '>=6.9.0'} engines: {node: '>=6.9.0'}
@ -318,6 +359,11 @@ packages:
engines: {node: '>=6.0.0'} engines: {node: '>=6.0.0'}
hasBin: true hasBin: true
'@babel/parser@7.28.4':
resolution: {integrity: sha512-yZbBqeM6TkpP9du/I2pUZnJsRMGGvOuIrhjzC1AwHwW+6he4mni6Bp/m8ijn0iOuZuPI2BfkCoSRunpyjnrQKg==}
engines: {node: '>=6.0.0'}
hasBin: true
'@babel/plugin-bugfix-firefox-class-in-computed-class-key@7.25.3': '@babel/plugin-bugfix-firefox-class-in-computed-class-key@7.25.3':
resolution: {integrity: sha512-wUrcsxZg6rqBXG05HG1FPYgsP6EvwF4WpBbxIpWIIYnH8wG0gzx3yZY3dtEHas4sTAOGkbTsc9EGPxwff8lRoA==} resolution: {integrity: sha512-wUrcsxZg6rqBXG05HG1FPYgsP6EvwF4WpBbxIpWIIYnH8wG0gzx3yZY3dtEHas4sTAOGkbTsc9EGPxwff8lRoA==}
engines: {node: '>=6.9.0'} engines: {node: '>=6.9.0'}
@ -474,6 +520,12 @@ packages:
peerDependencies: peerDependencies:
'@babel/core': ^7.0.0-0 '@babel/core': ^7.0.0-0
'@babel/plugin-syntax-typescript@7.27.1':
resolution: {integrity: sha512-xfYCBMxveHrRMnAWl1ZlPXOZjzkN82THFvLhQhFXFt81Z5HnN+EtUkZhv/zcKpmT3fzmWZB0ywiBrbC3vogbwQ==}
engines: {node: '>=6.9.0'}
peerDependencies:
'@babel/core': ^7.0.0-0
'@babel/plugin-syntax-unicode-sets-regex@7.18.6': '@babel/plugin-syntax-unicode-sets-regex@7.18.6':
resolution: {integrity: sha512-727YkEAPwSIQTv5im8QHz3upqp92JTWhidIC81Tdx4VJYIte/VndKf1qKrfnnhPLiPghStWfvC/iFaMCQu7Nqg==} resolution: {integrity: sha512-727YkEAPwSIQTv5im8QHz3upqp92JTWhidIC81Tdx4VJYIte/VndKf1qKrfnnhPLiPghStWfvC/iFaMCQu7Nqg==}
engines: {node: '>=6.9.0'} engines: {node: '>=6.9.0'}
@ -756,6 +808,12 @@ packages:
peerDependencies: peerDependencies:
'@babel/core': ^7.0.0-0 '@babel/core': ^7.0.0-0
'@babel/plugin-transform-typescript@7.28.0':
resolution: {integrity: sha512-4AEiDEBPIZvLQaWlc9liCavE0xRM0dNca41WtBeM3jgFptfUOSG9z0uteLhq6+3rq+WB6jIvUwKDTpXEHPJ2Vg==}
engines: {node: '>=6.9.0'}
peerDependencies:
'@babel/core': ^7.0.0-0
'@babel/plugin-transform-unicode-escapes@7.24.7': '@babel/plugin-transform-unicode-escapes@7.24.7':
resolution: {integrity: sha512-U3ap1gm5+4edc2Q/P+9VrBNhGkfnf+8ZqppY71Bo/pzZmXhhLdqgaUl6cuB07O1+AQJtCLfaOmswiNbSQ9ivhw==} resolution: {integrity: sha512-U3ap1gm5+4edc2Q/P+9VrBNhGkfnf+8ZqppY71Bo/pzZmXhhLdqgaUl6cuB07O1+AQJtCLfaOmswiNbSQ9ivhw==}
engines: {node: '>=6.9.0'} engines: {node: '>=6.9.0'}
@ -820,6 +878,10 @@ packages:
resolution: {integrity: sha512-ZCYtZciz1IWJB4U61UPu4KEaqyfj+r5T1Q5mqPo+IBpcG9kHv30Z0aD8LXPgC1trYa6rK0orRyAhqUgk4MjmEg==} resolution: {integrity: sha512-ZCYtZciz1IWJB4U61UPu4KEaqyfj+r5T1Q5mqPo+IBpcG9kHv30Z0aD8LXPgC1trYa6rK0orRyAhqUgk4MjmEg==}
engines: {node: '>=6.9.0'} engines: {node: '>=6.9.0'}
'@babel/traverse@7.28.4':
resolution: {integrity: sha512-YEzuboP2qvQavAcjgQNVgsvHIDv6ZpwXvcvjmyySP2DIMuByS/6ioU5G9pYrWHM6T2YDfc7xga9iNzYOs12CFQ==}
engines: {node: '>=6.9.0'}
'@babel/types@7.25.2': '@babel/types@7.25.2':
resolution: {integrity: sha512-YTnYtra7W9e6/oAZEHj0bJehPRUlLH9/fbpT5LfB0NhQXyALCRkRs3zH9v07IYhkgpqX6Z78FnuccZr/l4Fs4Q==} resolution: {integrity: sha512-YTnYtra7W9e6/oAZEHj0bJehPRUlLH9/fbpT5LfB0NhQXyALCRkRs3zH9v07IYhkgpqX6Z78FnuccZr/l4Fs4Q==}
engines: {node: '>=6.9.0'} engines: {node: '>=6.9.0'}
@ -828,6 +890,10 @@ packages:
resolution: {integrity: sha512-+EzkxvLNfiUeKMgy/3luqfsCWFRXLb7U6wNQTk60tovuckwB15B191tJWvpp4HjiQWdJkCxO3Wbvc6jlk3Xb2Q==} resolution: {integrity: sha512-+EzkxvLNfiUeKMgy/3luqfsCWFRXLb7U6wNQTk60tovuckwB15B191tJWvpp4HjiQWdJkCxO3Wbvc6jlk3Xb2Q==}
engines: {node: '>=6.9.0'} engines: {node: '>=6.9.0'}
'@babel/types@7.28.4':
resolution: {integrity: sha512-bkFqkLhh3pMBUQQkpVgWDWq/lqzc2678eUyDlTBhRqhCHFguYYGM0Efga7tYk4TogG/3x0EEl66/OQ+WGbWB/Q==}
engines: {node: '>=6.9.0'}
'@css-render/plugin-bem@0.15.14': '@css-render/plugin-bem@0.15.14':
resolution: {integrity: sha512-QK513CJ7yEQxm/P3EwsI+d+ha8kSOcjGvD6SevM41neEMxdULE+18iuQK6tEChAWMOQNQPLG/Rw3Khb69r5neg==} resolution: {integrity: sha512-QK513CJ7yEQxm/P3EwsI+d+ha8kSOcjGvD6SevM41neEMxdULE+18iuQK6tEChAWMOQNQPLG/Rw3Khb69r5neg==}
peerDependencies: peerDependencies:
@ -1246,10 +1312,16 @@ packages:
resolution: {integrity: sha512-8tR1xe7ZEbkabTuE/tNhzpolygUn9OaYp9yuYAF4MgDNZg06C3Qny80bes2/e9/Wm3aVkPUlCw6WgU7mQd0yEg==} resolution: {integrity: sha512-8tR1xe7ZEbkabTuE/tNhzpolygUn9OaYp9yuYAF4MgDNZg06C3Qny80bes2/e9/Wm3aVkPUlCw6WgU7mQd0yEg==}
engines: {node: '>= 16'} engines: {node: '>= 16'}
'@jridgewell/gen-mapping@0.3.13':
resolution: {integrity: sha512-2kkt/7niJ6MgEPxF0bYdQ6etZaA+fQvDcLKckhy1yIQOzaoKjBBjSj63/aLVjYE3qhRt5dvM+uUyfCg6UKCBbA==}
'@jridgewell/gen-mapping@0.3.5': '@jridgewell/gen-mapping@0.3.5':
resolution: {integrity: sha512-IzL8ZoEDIBRWEzlCcRhOaCupYyN5gdIK+Q6fbFdPDg6HqX6jpkItn7DFIpW9LQzXG6Df9sA7+OKnq0qlz/GaQg==} resolution: {integrity: sha512-IzL8ZoEDIBRWEzlCcRhOaCupYyN5gdIK+Q6fbFdPDg6HqX6jpkItn7DFIpW9LQzXG6Df9sA7+OKnq0qlz/GaQg==}
engines: {node: '>=6.0.0'} engines: {node: '>=6.0.0'}
'@jridgewell/remapping@2.3.5':
resolution: {integrity: sha512-LI9u/+laYG4Ds1TDKSJW2YPrIlcVYOwi2fUC6xB43lueCjgxV4lffOCZCtYFiH6TNOX+tQKXx97T4IKHbhyHEQ==}
'@jridgewell/resolve-uri@3.1.2': '@jridgewell/resolve-uri@3.1.2':
resolution: {integrity: sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==} resolution: {integrity: sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==}
engines: {node: '>=6.0.0'} engines: {node: '>=6.0.0'}
@ -1264,9 +1336,15 @@ packages:
'@jridgewell/sourcemap-codec@1.5.0': '@jridgewell/sourcemap-codec@1.5.0':
resolution: {integrity: sha512-gv3ZRaISU3fjPAgNsriBRqGWQL6quFx04YMPW/zD8XMLsU32mhCCbfbO6KZFLjvYpCZ8zyDEgqsgf+PwPaM7GQ==} resolution: {integrity: sha512-gv3ZRaISU3fjPAgNsriBRqGWQL6quFx04YMPW/zD8XMLsU32mhCCbfbO6KZFLjvYpCZ8zyDEgqsgf+PwPaM7GQ==}
'@jridgewell/sourcemap-codec@1.5.5':
resolution: {integrity: sha512-cYQ9310grqxueWbl+WuIUIaiUaDcj7WOq5fVhEljNVgRfOUhY9fy2zTvfoqWsnebh8Sl70VScFbICvJnLKB0Og==}
'@jridgewell/trace-mapping@0.3.25': '@jridgewell/trace-mapping@0.3.25':
resolution: {integrity: sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==} resolution: {integrity: sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==}
'@jridgewell/trace-mapping@0.3.31':
resolution: {integrity: sha512-zzNR+SdQSDJzc8joaeP8QQoCQr8NuYx2dIIytl1QeBEZHJ9uW6hebsrYgbz8hJwUQao3TWCMtmfV8Nu1twOLAw==}
'@juggle/resize-observer@3.4.0': '@juggle/resize-observer@3.4.0':
resolution: {integrity: sha512-dfLbk+PwWvFzSxwk3n5ySL0hfBog779o8h68wK/7/APo/7cgyWp5jcXockbxdk5kFRkbeXWm4Fbi9FrdN381sA==} resolution: {integrity: sha512-dfLbk+PwWvFzSxwk3n5ySL0hfBog779o8h68wK/7/APo/7cgyWp5jcXockbxdk5kFRkbeXWm4Fbi9FrdN381sA==}
@ -1290,6 +1368,9 @@ packages:
'@polka/url@1.0.0-next.25': '@polka/url@1.0.0-next.25':
resolution: {integrity: sha512-j7P6Rgr3mmtdkeDGTe0E/aYyWEWVtc5yFXtHCRHs28/jptDEWfaVOc5T7cblqy1XKPPfCxJc/8DwQ5YgLOZOVQ==} resolution: {integrity: sha512-j7P6Rgr3mmtdkeDGTe0E/aYyWEWVtc5yFXtHCRHs28/jptDEWfaVOc5T7cblqy1XKPPfCxJc/8DwQ5YgLOZOVQ==}
'@rolldown/pluginutils@1.0.0-beta.43':
resolution: {integrity: sha512-5Uxg7fQUCmfhax7FJke2+8B6cqgeUJUD9o2uXIKXhD+mG0mL6NObmVoi9wXEU1tY89mZKgAYA6fTbftx3q2ZPQ==}
'@rollup/plugin-babel@6.0.4': '@rollup/plugin-babel@6.0.4':
resolution: {integrity: sha512-YF7Y52kFdFT/xVSuVdjkV5ZdX/3YtmX0QulG+x0taQOtJdHYzVU61aSSkAgVJ7NOv6qPkIYiJSgSWWN/DM5sGw==} resolution: {integrity: sha512-YF7Y52kFdFT/xVSuVdjkV5ZdX/3YtmX0QulG+x0taQOtJdHYzVU61aSSkAgVJ7NOv6qPkIYiJSgSWWN/DM5sGw==}
engines: {node: '>=14.0.0'} engines: {node: '>=14.0.0'}
@ -1594,6 +1675,13 @@ packages:
terser: ^5.4.0 terser: ^5.4.0
vite: ^5.0.0 vite: ^5.0.0
'@vitejs/plugin-vue-jsx@5.1.1':
resolution: {integrity: sha512-uQkfxzlF8SGHJJVH966lFTdjM/lGcwJGzwAHpVqAPDD/QcsqoUGa+q31ox1BrUfi+FLP2ChVp7uLXE3DkHyDdQ==}
engines: {node: ^20.19.0 || >=22.12.0}
peerDependencies:
vite: ^5.0.0 || ^6.0.0 || ^7.0.0
vue: ^3.0.0
'@vitejs/plugin-vue@5.1.2': '@vitejs/plugin-vue@5.1.2':
resolution: {integrity: sha512-nY9IwH12qeiJqumTCLJLE7IiNx7HZ39cbHaysEUd+Myvbz9KAqd2yq+U01Kab1R/H1BmiyM2ShTYlNH32Fzo3A==} resolution: {integrity: sha512-nY9IwH12qeiJqumTCLJLE7IiNx7HZ39cbHaysEUd+Myvbz9KAqd2yq+U01Kab1R/H1BmiyM2ShTYlNH32Fzo3A==}
engines: {node: ^18.0.0 || >=20.0.0} engines: {node: ^18.0.0 || >=20.0.0}
@ -1604,6 +1692,9 @@ packages:
'@vue/babel-helper-vue-transform-on@1.4.0': '@vue/babel-helper-vue-transform-on@1.4.0':
resolution: {integrity: sha512-mCokbouEQ/ocRce/FpKCRItGo+013tHg7tixg3DUNS+6bmIchPt66012kBMm476vyEIJPafrvOf4E5OYj3shSw==} resolution: {integrity: sha512-mCokbouEQ/ocRce/FpKCRItGo+013tHg7tixg3DUNS+6bmIchPt66012kBMm476vyEIJPafrvOf4E5OYj3shSw==}
'@vue/babel-helper-vue-transform-on@1.5.0':
resolution: {integrity: sha512-0dAYkerNhhHutHZ34JtTl2czVQHUNWv6xEbkdF5W+Yrv5pCWsqjeORdOgbtW2I9gWlt+wBmVn+ttqN9ZxR5tzA==}
'@vue/babel-plugin-jsx@1.4.0': '@vue/babel-plugin-jsx@1.4.0':
resolution: {integrity: sha512-9zAHmwgMWlaN6qRKdrg1uKsBKHvnUU+Py+MOCTuYZBoZsopa90Di10QRjB+YPnVss0BZbG/H5XFwJY1fTxJWhA==} resolution: {integrity: sha512-9zAHmwgMWlaN6qRKdrg1uKsBKHvnUU+Py+MOCTuYZBoZsopa90Di10QRjB+YPnVss0BZbG/H5XFwJY1fTxJWhA==}
peerDependencies: peerDependencies:
@ -1612,35 +1703,60 @@ packages:
'@babel/core': '@babel/core':
optional: true optional: true
'@vue/babel-plugin-jsx@1.5.0':
resolution: {integrity: sha512-mneBhw1oOqCd2247O0Yw/mRwC9jIGACAJUlawkmMBiNmL4dGA2eMzuNZVNqOUfYTa6vqmND4CtOPzmEEEqLKFw==}
peerDependencies:
'@babel/core': ^7.0.0-0
peerDependenciesMeta:
'@babel/core':
optional: true
'@vue/babel-plugin-resolve-type@1.4.0': '@vue/babel-plugin-resolve-type@1.4.0':
resolution: {integrity: sha512-4xqDRRbQQEWHQyjlYSgZsWj44KfiF6D+ktCuXyZ8EnVDYV3pztmXJDf1HveAjUAXxAnR8daCQT51RneWWxtTyQ==} resolution: {integrity: sha512-4xqDRRbQQEWHQyjlYSgZsWj44KfiF6D+ktCuXyZ8EnVDYV3pztmXJDf1HveAjUAXxAnR8daCQT51RneWWxtTyQ==}
peerDependencies: peerDependencies:
'@babel/core': ^7.0.0-0 '@babel/core': ^7.0.0-0
'@vue/babel-plugin-resolve-type@1.5.0':
resolution: {integrity: sha512-Wm/60o+53JwJODm4Knz47dxJnLDJ9FnKnGZJbUUf8nQRAtt6P+undLUAVU3Ha33LxOJe6IPoifRQ6F/0RrU31w==}
peerDependencies:
'@babel/core': ^7.0.0-0
'@vue/compiler-core@3.4.35': '@vue/compiler-core@3.4.35':
resolution: {integrity: sha512-gKp0zGoLnMYtw4uS/SJRRO7rsVggLjvot3mcctlMXunYNsX+aRJDqqw/lV5/gHK91nvaAAlWFgdVl020AW1Prg==} resolution: {integrity: sha512-gKp0zGoLnMYtw4uS/SJRRO7rsVggLjvot3mcctlMXunYNsX+aRJDqqw/lV5/gHK91nvaAAlWFgdVl020AW1Prg==}
'@vue/compiler-core@3.5.14': '@vue/compiler-core@3.5.14':
resolution: {integrity: sha512-k7qMHMbKvoCXIxPhquKQVw3Twid3Kg4s7+oYURxLGRd56LiuHJVrvFKI4fm2AM3c8apqODPfVJGoh8nePbXMRA==} resolution: {integrity: sha512-k7qMHMbKvoCXIxPhquKQVw3Twid3Kg4s7+oYURxLGRd56LiuHJVrvFKI4fm2AM3c8apqODPfVJGoh8nePbXMRA==}
'@vue/compiler-core@3.5.22':
resolution: {integrity: sha512-jQ0pFPmZwTEiRNSb+i9Ow/I/cHv2tXYqsnHKKyCQ08irI2kdF5qmYedmF8si8mA7zepUFmJ2hqzS8CQmNOWOkQ==}
'@vue/compiler-dom@3.4.35': '@vue/compiler-dom@3.4.35':
resolution: {integrity: sha512-pWIZRL76/oE/VMhdv/ovZfmuooEni6JPG1BFe7oLk5DZRo/ImydXijoZl/4kh2406boRQ7lxTYzbZEEXEhj9NQ==} resolution: {integrity: sha512-pWIZRL76/oE/VMhdv/ovZfmuooEni6JPG1BFe7oLk5DZRo/ImydXijoZl/4kh2406boRQ7lxTYzbZEEXEhj9NQ==}
'@vue/compiler-dom@3.5.14': '@vue/compiler-dom@3.5.14':
resolution: {integrity: sha512-1aOCSqxGOea5I80U2hQJvXYpPm/aXo95xL/m/mMhgyPUsKe9jhjwWpziNAw7tYRnbz1I61rd9Mld4W9KmmRoug==} resolution: {integrity: sha512-1aOCSqxGOea5I80U2hQJvXYpPm/aXo95xL/m/mMhgyPUsKe9jhjwWpziNAw7tYRnbz1I61rd9Mld4W9KmmRoug==}
'@vue/compiler-dom@3.5.22':
resolution: {integrity: sha512-W8RknzUM1BLkypvdz10OVsGxnMAuSIZs9Wdx1vzA3mL5fNMN15rhrSCLiTm6blWeACwUwizzPVqGJgOGBEN/hA==}
'@vue/compiler-sfc@3.4.35': '@vue/compiler-sfc@3.4.35':
resolution: {integrity: sha512-xacnRS/h/FCsjsMfxBkzjoNxyxEyKyZfBch/P4vkLRvYJwe5ChXmZZrj8Dsed/752H2Q3JE8kYu9Uyha9J6PgA==} resolution: {integrity: sha512-xacnRS/h/FCsjsMfxBkzjoNxyxEyKyZfBch/P4vkLRvYJwe5ChXmZZrj8Dsed/752H2Q3JE8kYu9Uyha9J6PgA==}
'@vue/compiler-sfc@3.5.14': '@vue/compiler-sfc@3.5.14':
resolution: {integrity: sha512-9T6m/9mMr81Lj58JpzsiSIjBgv2LiVoWjIVa7kuXHICUi8LiDSIotMpPRXYJsXKqyARrzjT24NAwttrMnMaCXA==} resolution: {integrity: sha512-9T6m/9mMr81Lj58JpzsiSIjBgv2LiVoWjIVa7kuXHICUi8LiDSIotMpPRXYJsXKqyARrzjT24NAwttrMnMaCXA==}
'@vue/compiler-sfc@3.5.22':
resolution: {integrity: sha512-tbTR1zKGce4Lj+JLzFXDq36K4vcSZbJ1RBu8FxcDv1IGRz//Dh2EBqksyGVypz3kXpshIfWKGOCcqpSbyGWRJQ==}
'@vue/compiler-ssr@3.4.35': '@vue/compiler-ssr@3.4.35':
resolution: {integrity: sha512-7iynB+0KB1AAJKk/biENTV5cRGHRdbdaD7Mx3nWcm1W8bVD6QmnH3B4AHhQQ1qZHhqFwzEzMwiytXm3PX1e60A==} resolution: {integrity: sha512-7iynB+0KB1AAJKk/biENTV5cRGHRdbdaD7Mx3nWcm1W8bVD6QmnH3B4AHhQQ1qZHhqFwzEzMwiytXm3PX1e60A==}
'@vue/compiler-ssr@3.5.14': '@vue/compiler-ssr@3.5.14':
resolution: {integrity: sha512-Y0G7PcBxr1yllnHuS/NxNCSPWnRGH4Ogrp0tsLA5QemDZuJLs99YjAKQ7KqkHE0vCg4QTKlQzXLKCMF7WPSl7Q==} resolution: {integrity: sha512-Y0G7PcBxr1yllnHuS/NxNCSPWnRGH4Ogrp0tsLA5QemDZuJLs99YjAKQ7KqkHE0vCg4QTKlQzXLKCMF7WPSl7Q==}
'@vue/compiler-ssr@3.5.22':
resolution: {integrity: sha512-GdgyLvg4R+7T8Nk2Mlighx7XGxq/fJf9jaVofc3IL0EPesTE86cP/8DD1lT3h1JeZr2ySBvyqKQJgbS54IX1Ww==}
'@vue/devtools-api@6.6.3': '@vue/devtools-api@6.6.3':
resolution: {integrity: sha512-0MiMsFma/HqA6g3KLKn+AGpL1kgKhFWszC9U29NfpWK5LE7bjeXxySWJrOJ77hBz+TBrBQ7o4QJqbPbqbs8rJw==} resolution: {integrity: sha512-0MiMsFma/HqA6g3KLKn+AGpL1kgKhFWszC9U29NfpWK5LE7bjeXxySWJrOJ77hBz+TBrBQ7o4QJqbPbqbs8rJw==}
@ -1675,6 +1791,9 @@ packages:
'@vue/shared@3.5.14': '@vue/shared@3.5.14':
resolution: {integrity: sha512-oXTwNxVfc9EtP1zzXAlSlgARLXNC84frFYkS0HHz0h3E4WZSP9sywqjqzGCP9Y34M8ipNmd380pVgmMuwELDyQ==} resolution: {integrity: sha512-oXTwNxVfc9EtP1zzXAlSlgARLXNC84frFYkS0HHz0h3E4WZSP9sywqjqzGCP9Y34M8ipNmd380pVgmMuwELDyQ==}
'@vue/shared@3.5.22':
resolution: {integrity: sha512-F4yc6palwq3TT0u+FYf0Ns4Tfl9GRFURDN2gWG7L1ecIaS/4fCIuFOjMTnCyjsu/OK6vaDKLCrGAa+KvvH+h4w==}
'@vueuse/core@10.11.0': '@vueuse/core@10.11.0':
resolution: {integrity: sha512-x3sD4Mkm7PJ+pcq3HX8PLPBadXCAlSDR/waK87dz0gQE+qJnaaFhc/dZVfJz+IUYzTMVGum2QlR7ImiJQN4s6g==} resolution: {integrity: sha512-x3sD4Mkm7PJ+pcq3HX8PLPBadXCAlSDR/waK87dz0gQE+qJnaaFhc/dZVfJz+IUYzTMVGum2QlR7ImiJQN4s6g==}
@ -1783,6 +1902,10 @@ packages:
base64-js@1.5.1: base64-js@1.5.1:
resolution: {integrity: sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==} resolution: {integrity: sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==}
baseline-browser-mapping@2.8.17:
resolution: {integrity: sha512-j5zJcx6golJYTG6c05LUZ3Z8Gi+M62zRT/ycz4Xq4iCOdpcxwg7ngEYD4KA0eWZC7U17qh/Smq8bYbACJ0ipBA==}
hasBin: true
bin-build@3.0.0: bin-build@3.0.0:
resolution: {integrity: sha512-jcUOof71/TNAI2uM5uoUaDq2ePcVBQ3R/qhxAz1rX7UfvduAL/RXD3jXzvn8cVcDJdGVkiR1shal3OH0ImpuhA==} resolution: {integrity: sha512-jcUOof71/TNAI2uM5uoUaDq2ePcVBQ3R/qhxAz1rX7UfvduAL/RXD3jXzvn8cVcDJdGVkiR1shal3OH0ImpuhA==}
engines: {node: '>=4'} engines: {node: '>=4'}
@ -1838,6 +1961,11 @@ packages:
engines: {node: ^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7} engines: {node: ^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7}
hasBin: true hasBin: true
browserslist@4.26.3:
resolution: {integrity: sha512-lAUU+02RFBuCKQPj/P6NgjlbCnLBMp4UtgTx7vNHd3XSIJF87s9a5rA3aH2yw3GS9DqZAUbOtZdCCiZeVRqt0w==}
engines: {node: ^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7}
hasBin: true
buffer-alloc-unsafe@1.1.0: buffer-alloc-unsafe@1.1.0:
resolution: {integrity: sha512-TEM2iMIEQdJ2yjPJoSIsldnleVaAk1oW3DBVUykyOLsEsFmEc9kn+SFFPz+gl54KQNxlDnAwCXosOS9Okx2xAg==} resolution: {integrity: sha512-TEM2iMIEQdJ2yjPJoSIsldnleVaAk1oW3DBVUykyOLsEsFmEc9kn+SFFPz+gl54KQNxlDnAwCXosOS9Okx2xAg==}
@ -1884,6 +2012,9 @@ packages:
caniuse-lite@1.0.30001649: caniuse-lite@1.0.30001649:
resolution: {integrity: sha512-fJegqZZ0ZX8HOWr6rcafGr72+xcgJKI9oWfDW5DrD7ExUtgZC7a7R7ZYmZqplh7XDocFdGeIFn7roAxhOeYrPQ==} resolution: {integrity: sha512-fJegqZZ0ZX8HOWr6rcafGr72+xcgJKI9oWfDW5DrD7ExUtgZC7a7R7ZYmZqplh7XDocFdGeIFn7roAxhOeYrPQ==}
caniuse-lite@1.0.30001751:
resolution: {integrity: sha512-A0QJhug0Ly64Ii3eIqHu5X51ebln3k4yTUkY1j8drqpWHVreg/VLijN48cZ1bYPiqOQuqpkIKnzr/Ul8V+p6Cw==}
caw@2.0.1: caw@2.0.1:
resolution: {integrity: sha512-Cg8/ZSBEa8ZVY9HspcGUYaK63d/bN7rqS3CYCzEGUxuYv6UlmcjzDUz2fCFFHyTvUW5Pk0I+3hkA3iXlIj6guA==} resolution: {integrity: sha512-Cg8/ZSBEa8ZVY9HspcGUYaK63d/bN7rqS3CYCzEGUxuYv6UlmcjzDUz2fCFFHyTvUW5Pk0I+3hkA3iXlIj6guA==}
engines: {node: '>=4'} engines: {node: '>=4'}
@ -2191,6 +2322,9 @@ packages:
echarts@5.6.0: echarts@5.6.0:
resolution: {integrity: sha512-oTbVTsXfKuEhxftHqL5xprgLoc0k7uScAwtryCgWF6hPYFLRwOUHiFmHGCBKP5NPFNkDVopOieyUqYGH8Fa3kA==} resolution: {integrity: sha512-oTbVTsXfKuEhxftHqL5xprgLoc0k7uScAwtryCgWF6hPYFLRwOUHiFmHGCBKP5NPFNkDVopOieyUqYGH8Fa3kA==}
electron-to-chromium@1.5.237:
resolution: {integrity: sha512-icUt1NvfhGLar5lSWH3tHNzablaA5js3HVHacQimfP8ViEBOQv+L7DKEuHdbTZ0SKCO1ogTJTIL1Gwk9S6Qvcg==}
electron-to-chromium@1.5.4: electron-to-chromium@1.5.4:
resolution: {integrity: sha512-orzA81VqLyIGUEA77YkVA1D+N+nNfl2isJVjjmOyrlxuooZ19ynb+dOlaDTqd/idKRS9lDCSBmtzM+kyCsMnkA==} resolution: {integrity: sha512-orzA81VqLyIGUEA77YkVA1D+N+nNfl2isJVjjmOyrlxuooZ19ynb+dOlaDTqd/idKRS9lDCSBmtzM+kyCsMnkA==}
@ -2344,6 +2478,10 @@ packages:
resolution: {integrity: sha512-ErCHMCae19vR8vQGe50xIsVomy19rg6gFu3+r3jkEO46suLMWBksvVyoGgQV+jOfl84ZSOSlmv6Gxa89PmTGmA==} resolution: {integrity: sha512-ErCHMCae19vR8vQGe50xIsVomy19rg6gFu3+r3jkEO46suLMWBksvVyoGgQV+jOfl84ZSOSlmv6Gxa89PmTGmA==}
engines: {node: '>=6'} engines: {node: '>=6'}
escalade@3.2.0:
resolution: {integrity: sha512-WUj2qlxaQtO4g6Pq5c29GTcWGDyd8itL8zTlipgECz3JesAiiOKotd8JU6otB3PACgG6xkJUyVhboMS+bje/jA==}
engines: {node: '>=6'}
escape-string-regexp@1.0.5: escape-string-regexp@1.0.5:
resolution: {integrity: sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==} resolution: {integrity: sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==}
engines: {node: '>=0.8.0'} engines: {node: '>=0.8.0'}
@ -2968,6 +3106,9 @@ packages:
magic-string@0.30.17: magic-string@0.30.17:
resolution: {integrity: sha512-sNPKHvyjVf7gyjwS4xGTaW/mCnF8wnjtifKBEhxfZ7E/S8tQ0rssrwGNn6q8JH/ohItJfSQp9mBtQYuTlH5QnA==} resolution: {integrity: sha512-sNPKHvyjVf7gyjwS4xGTaW/mCnF8wnjtifKBEhxfZ7E/S8tQ0rssrwGNn6q8JH/ohItJfSQp9mBtQYuTlH5QnA==}
magic-string@0.30.19:
resolution: {integrity: sha512-2N21sPY9Ws53PZvsEpVtNuSW+ScYbQdp4b9qUaL+9QkHUrGFKo56Lg9Emg5s9V/qrtNBmiR01sYhUOwu3H+VOw==}
make-dir@1.3.0: make-dir@1.3.0:
resolution: {integrity: sha512-2w31R7SJtieJJnQtGc7RVL2StM2vGYVfqUOvUDxH6bC6aJTxPxTF0GnIgCyu7tjockiUWAYQRbxa7vKn34s5sQ==} resolution: {integrity: sha512-2w31R7SJtieJJnQtGc7RVL2StM2vGYVfqUOvUDxH6bC6aJTxPxTF0GnIgCyu7tjockiUWAYQRbxa7vKn34s5sQ==}
engines: {node: '>=4'} engines: {node: '>=4'}
@ -3084,6 +3225,9 @@ packages:
node-releases@2.0.18: node-releases@2.0.18:
resolution: {integrity: sha512-d9VeXT4SJ7ZeOqGX6R5EM022wpL+eWPooLI+5UpWn2jCT1aosUQEhQP214x33Wkwx3JQMvIm+tIoVOdodFS40g==} resolution: {integrity: sha512-d9VeXT4SJ7ZeOqGX6R5EM022wpL+eWPooLI+5UpWn2jCT1aosUQEhQP214x33Wkwx3JQMvIm+tIoVOdodFS40g==}
node-releases@2.0.25:
resolution: {integrity: sha512-4auku8B/vw5psvTiiN9j1dAOsXvMoGqJuKJcR+dTdqiXEK20mMTk1UEo3HS16LeGQsVG6+qKTPM9u/qQ2LqATA==}
normalize-package-data@2.5.0: normalize-package-data@2.5.0:
resolution: {integrity: sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==} resolution: {integrity: sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==}
@ -3493,6 +3637,10 @@ packages:
resolution: {integrity: sha512-dle9A3yYxlBSrt8Fu+IpjGT8SY8hN0mlaA6GY8t0P5PjIOZemULz/E2Bnm/2dcUOena75OTNkHI76uZBNUUq3A==} resolution: {integrity: sha512-dle9A3yYxlBSrt8Fu+IpjGT8SY8hN0mlaA6GY8t0P5PjIOZemULz/E2Bnm/2dcUOena75OTNkHI76uZBNUUq3A==}
engines: {node: ^10 || ^12 || >=14} engines: {node: ^10 || ^12 || >=14}
postcss@8.5.6:
resolution: {integrity: sha512-3Ybi1tAuwAP9s0r1UQ2J4n5Y0G05bJkpUIO0/bI9MhwmD70S5aTWbXGBwxHrelT+XM1k6dM0pk+SwNkpTRN7Pg==}
engines: {node: ^10 || ^12 || >=14}
prepend-http@1.0.4: prepend-http@1.0.4:
resolution: {integrity: sha512-PhmXi5XmoyKw1Un4E+opM2KcsJInDvKyuOumcjjw3waw86ZNjHwVUOOWLc4bCzLdcKNaWBH9e99sbWzDQsVaYg==} resolution: {integrity: sha512-PhmXi5XmoyKw1Un4E+opM2KcsJInDvKyuOumcjjw3waw86ZNjHwVUOOWLc4bCzLdcKNaWBH9e99sbWzDQsVaYg==}
engines: {node: '>=0.10.0'} engines: {node: '>=0.10.0'}
@ -4011,6 +4159,12 @@ packages:
peerDependencies: peerDependencies:
browserslist: '>= 4.21.0' browserslist: '>= 4.21.0'
update-browserslist-db@1.1.3:
resolution: {integrity: sha512-UxhIZQ+QInVdunkDAaiazvvT/+fXL5Osr0JZlJulepYu6Jd7qJtDZjlur0emRlT71EN3ScPoE7gvsuIKKNavKw==}
hasBin: true
peerDependencies:
browserslist: '>= 4.21.0'
url-parse-lax@1.0.0: url-parse-lax@1.0.0:
resolution: {integrity: sha512-BVA4lR5PIviy2PMseNd2jbFQ+jwSwQGdJejf5ctd1rEXt0Ypd7yanUK9+lYechVlN5VaTJGsu2U/3MDDu6KgBA==} resolution: {integrity: sha512-BVA4lR5PIviy2PMseNd2jbFQ+jwSwQGdJejf5ctd1rEXt0Ypd7yanUK9+lYechVlN5VaTJGsu2U/3MDDu6KgBA==}
engines: {node: '>=0.10.0'} engines: {node: '>=0.10.0'}
@ -4261,6 +4415,8 @@ snapshots:
'@babel/compat-data@7.25.2': {} '@babel/compat-data@7.25.2': {}
'@babel/compat-data@7.28.4': {}
'@babel/core@7.25.2': '@babel/core@7.25.2':
dependencies: dependencies:
'@ampproject/remapping': 2.3.0 '@ampproject/remapping': 2.3.0
@ -4281,6 +4437,26 @@ snapshots:
transitivePeerDependencies: transitivePeerDependencies:
- supports-color - supports-color
'@babel/core@7.28.4':
dependencies:
'@babel/code-frame': 7.27.1
'@babel/generator': 7.28.3
'@babel/helper-compilation-targets': 7.27.2
'@babel/helper-module-transforms': 7.28.3(@babel/core@7.28.4)
'@babel/helpers': 7.28.4
'@babel/parser': 7.28.4
'@babel/template': 7.27.2
'@babel/traverse': 7.28.4
'@babel/types': 7.28.4
'@jridgewell/remapping': 2.3.5
convert-source-map: 2.0.0
debug: 4.4.1
gensync: 1.0.0-beta.2
json5: 2.2.3
semver: 6.3.1
transitivePeerDependencies:
- supports-color
'@babel/generator@7.25.0': '@babel/generator@7.25.0':
dependencies: dependencies:
'@babel/types': 7.25.2 '@babel/types': 7.25.2
@ -4296,6 +4472,14 @@ snapshots:
'@jridgewell/trace-mapping': 0.3.25 '@jridgewell/trace-mapping': 0.3.25
jsesc: 3.1.0 jsesc: 3.1.0
'@babel/generator@7.28.3':
dependencies:
'@babel/parser': 7.28.4
'@babel/types': 7.28.4
'@jridgewell/gen-mapping': 0.3.13
'@jridgewell/trace-mapping': 0.3.31
jsesc: 3.1.0
'@babel/helper-annotate-as-pure@7.24.7': '@babel/helper-annotate-as-pure@7.24.7':
dependencies: dependencies:
'@babel/types': 7.25.2 '@babel/types': 7.25.2
@ -4304,6 +4488,10 @@ snapshots:
dependencies: dependencies:
'@babel/types': 7.27.1 '@babel/types': 7.27.1
'@babel/helper-annotate-as-pure@7.27.3':
dependencies:
'@babel/types': 7.28.4
'@babel/helper-builder-binary-assignment-operator-visitor@7.24.7': '@babel/helper-builder-binary-assignment-operator-visitor@7.24.7':
dependencies: dependencies:
'@babel/traverse': 7.25.3 '@babel/traverse': 7.25.3
@ -4319,6 +4507,14 @@ snapshots:
lru-cache: 5.1.1 lru-cache: 5.1.1
semver: 6.3.1 semver: 6.3.1
'@babel/helper-compilation-targets@7.27.2':
dependencies:
'@babel/compat-data': 7.28.4
'@babel/helper-validator-option': 7.27.1
browserslist: 4.26.3
lru-cache: 5.1.1
semver: 6.3.1
'@babel/helper-create-class-features-plugin@7.25.0(@babel/core@7.25.2)': '@babel/helper-create-class-features-plugin@7.25.0(@babel/core@7.25.2)':
dependencies: dependencies:
'@babel/core': 7.25.2 '@babel/core': 7.25.2
@ -4345,6 +4541,19 @@ snapshots:
transitivePeerDependencies: transitivePeerDependencies:
- supports-color - supports-color
'@babel/helper-create-class-features-plugin@7.27.1(@babel/core@7.28.4)':
dependencies:
'@babel/core': 7.28.4
'@babel/helper-annotate-as-pure': 7.27.1
'@babel/helper-member-expression-to-functions': 7.27.1
'@babel/helper-optimise-call-expression': 7.27.1
'@babel/helper-replace-supers': 7.27.1(@babel/core@7.28.4)
'@babel/helper-skip-transparent-expression-wrappers': 7.27.1
'@babel/traverse': 7.27.1
semver: 6.3.1
transitivePeerDependencies:
- supports-color
'@babel/helper-create-regexp-features-plugin@7.25.2(@babel/core@7.25.2)': '@babel/helper-create-regexp-features-plugin@7.25.2(@babel/core@7.25.2)':
dependencies: dependencies:
'@babel/core': 7.25.2 '@babel/core': 7.25.2
@ -4363,6 +4572,8 @@ snapshots:
transitivePeerDependencies: transitivePeerDependencies:
- supports-color - supports-color
'@babel/helper-globals@7.28.0': {}
'@babel/helper-member-expression-to-functions@7.24.8': '@babel/helper-member-expression-to-functions@7.24.8':
dependencies: dependencies:
'@babel/traverse': 7.25.3 '@babel/traverse': 7.25.3
@ -4386,8 +4597,8 @@ snapshots:
'@babel/helper-module-imports@7.27.1': '@babel/helper-module-imports@7.27.1':
dependencies: dependencies:
'@babel/traverse': 7.27.1 '@babel/traverse': 7.28.4
'@babel/types': 7.27.1 '@babel/types': 7.28.4
transitivePeerDependencies: transitivePeerDependencies:
- supports-color - supports-color
@ -4401,6 +4612,15 @@ snapshots:
transitivePeerDependencies: transitivePeerDependencies:
- supports-color - supports-color
'@babel/helper-module-transforms@7.28.3(@babel/core@7.28.4)':
dependencies:
'@babel/core': 7.28.4
'@babel/helper-module-imports': 7.27.1
'@babel/helper-validator-identifier': 7.27.1
'@babel/traverse': 7.28.4
transitivePeerDependencies:
- supports-color
'@babel/helper-optimise-call-expression@7.24.7': '@babel/helper-optimise-call-expression@7.24.7':
dependencies: dependencies:
'@babel/types': 7.25.2 '@babel/types': 7.25.2
@ -4440,6 +4660,15 @@ snapshots:
transitivePeerDependencies: transitivePeerDependencies:
- supports-color - supports-color
'@babel/helper-replace-supers@7.27.1(@babel/core@7.28.4)':
dependencies:
'@babel/core': 7.28.4
'@babel/helper-member-expression-to-functions': 7.27.1
'@babel/helper-optimise-call-expression': 7.27.1
'@babel/traverse': 7.27.1
transitivePeerDependencies:
- supports-color
'@babel/helper-simple-access@7.24.7': '@babel/helper-simple-access@7.24.7':
dependencies: dependencies:
'@babel/traverse': 7.25.3 '@babel/traverse': 7.25.3
@ -4471,6 +4700,8 @@ snapshots:
'@babel/helper-validator-option@7.24.8': {} '@babel/helper-validator-option@7.24.8': {}
'@babel/helper-validator-option@7.27.1': {}
'@babel/helper-wrap-function@7.25.0': '@babel/helper-wrap-function@7.25.0':
dependencies: dependencies:
'@babel/template': 7.25.0 '@babel/template': 7.25.0
@ -4484,6 +4715,11 @@ snapshots:
'@babel/template': 7.25.0 '@babel/template': 7.25.0
'@babel/types': 7.25.2 '@babel/types': 7.25.2
'@babel/helpers@7.28.4':
dependencies:
'@babel/template': 7.27.2
'@babel/types': 7.28.4
'@babel/highlight@7.24.7': '@babel/highlight@7.24.7':
dependencies: dependencies:
'@babel/helper-validator-identifier': 7.24.7 '@babel/helper-validator-identifier': 7.24.7
@ -4499,6 +4735,10 @@ snapshots:
dependencies: dependencies:
'@babel/types': 7.27.1 '@babel/types': 7.27.1
'@babel/parser@7.28.4':
dependencies:
'@babel/types': 7.28.4
'@babel/plugin-bugfix-firefox-class-in-computed-class-key@7.25.3(@babel/core@7.25.2)': '@babel/plugin-bugfix-firefox-class-in-computed-class-key@7.25.3(@babel/core@7.25.2)':
dependencies: dependencies:
'@babel/core': 7.25.2 '@babel/core': 7.25.2
@ -4607,6 +4847,11 @@ snapshots:
'@babel/core': 7.25.2 '@babel/core': 7.25.2
'@babel/helper-plugin-utils': 7.27.1 '@babel/helper-plugin-utils': 7.27.1
'@babel/plugin-syntax-jsx@7.27.1(@babel/core@7.28.4)':
dependencies:
'@babel/core': 7.28.4
'@babel/helper-plugin-utils': 7.27.1
'@babel/plugin-syntax-logical-assignment-operators@7.10.4(@babel/core@7.25.2)': '@babel/plugin-syntax-logical-assignment-operators@7.10.4(@babel/core@7.25.2)':
dependencies: dependencies:
'@babel/core': 7.25.2 '@babel/core': 7.25.2
@ -4650,7 +4895,12 @@ snapshots:
'@babel/plugin-syntax-typescript@7.24.7(@babel/core@7.25.2)': '@babel/plugin-syntax-typescript@7.24.7(@babel/core@7.25.2)':
dependencies: dependencies:
'@babel/core': 7.25.2 '@babel/core': 7.25.2
'@babel/helper-plugin-utils': 7.24.8 '@babel/helper-plugin-utils': 7.27.1
'@babel/plugin-syntax-typescript@7.27.1(@babel/core@7.28.4)':
dependencies:
'@babel/core': 7.28.4
'@babel/helper-plugin-utils': 7.27.1
'@babel/plugin-syntax-unicode-sets-regex@7.18.6(@babel/core@7.25.2)': '@babel/plugin-syntax-unicode-sets-regex@7.18.6(@babel/core@7.25.2)':
dependencies: dependencies:
@ -4975,6 +5225,17 @@ snapshots:
transitivePeerDependencies: transitivePeerDependencies:
- supports-color - supports-color
'@babel/plugin-transform-typescript@7.28.0(@babel/core@7.28.4)':
dependencies:
'@babel/core': 7.28.4
'@babel/helper-annotate-as-pure': 7.27.3
'@babel/helper-create-class-features-plugin': 7.27.1(@babel/core@7.28.4)
'@babel/helper-plugin-utils': 7.27.1
'@babel/helper-skip-transparent-expression-wrappers': 7.27.1
'@babel/plugin-syntax-typescript': 7.27.1(@babel/core@7.28.4)
transitivePeerDependencies:
- supports-color
'@babel/plugin-transform-unicode-escapes@7.24.7(@babel/core@7.25.2)': '@babel/plugin-transform-unicode-escapes@7.24.7(@babel/core@7.25.2)':
dependencies: dependencies:
'@babel/core': 7.25.2 '@babel/core': 7.25.2
@ -5121,7 +5382,7 @@ snapshots:
dependencies: dependencies:
'@babel/code-frame': 7.27.1 '@babel/code-frame': 7.27.1
'@babel/parser': 7.27.2 '@babel/parser': 7.27.2
'@babel/types': 7.27.1 '@babel/types': 7.28.4
'@babel/traverse@7.25.3': '@babel/traverse@7.25.3':
dependencies: dependencies:
@ -5147,6 +5408,18 @@ snapshots:
transitivePeerDependencies: transitivePeerDependencies:
- supports-color - supports-color
'@babel/traverse@7.28.4':
dependencies:
'@babel/code-frame': 7.27.1
'@babel/generator': 7.28.3
'@babel/helper-globals': 7.28.0
'@babel/parser': 7.28.4
'@babel/template': 7.27.2
'@babel/types': 7.28.4
debug: 4.4.1
transitivePeerDependencies:
- supports-color
'@babel/types@7.25.2': '@babel/types@7.25.2':
dependencies: dependencies:
'@babel/helper-string-parser': 7.24.8 '@babel/helper-string-parser': 7.24.8
@ -5158,6 +5431,11 @@ snapshots:
'@babel/helper-string-parser': 7.27.1 '@babel/helper-string-parser': 7.27.1
'@babel/helper-validator-identifier': 7.27.1 '@babel/helper-validator-identifier': 7.27.1
'@babel/types@7.28.4':
dependencies:
'@babel/helper-string-parser': 7.27.1
'@babel/helper-validator-identifier': 7.27.1
'@css-render/plugin-bem@0.15.14(css-render@0.15.14)': '@css-render/plugin-bem@0.15.14(css-render@0.15.14)':
dependencies: dependencies:
css-render: 0.15.14 css-render: 0.15.14
@ -5508,12 +5786,22 @@ snapshots:
'@intlify/shared@11.0.0-rc.1': {} '@intlify/shared@11.0.0-rc.1': {}
'@jridgewell/gen-mapping@0.3.13':
dependencies:
'@jridgewell/sourcemap-codec': 1.5.0
'@jridgewell/trace-mapping': 0.3.31
'@jridgewell/gen-mapping@0.3.5': '@jridgewell/gen-mapping@0.3.5':
dependencies: dependencies:
'@jridgewell/set-array': 1.2.1 '@jridgewell/set-array': 1.2.1
'@jridgewell/sourcemap-codec': 1.5.0 '@jridgewell/sourcemap-codec': 1.5.0
'@jridgewell/trace-mapping': 0.3.25 '@jridgewell/trace-mapping': 0.3.25
'@jridgewell/remapping@2.3.5':
dependencies:
'@jridgewell/gen-mapping': 0.3.5
'@jridgewell/trace-mapping': 0.3.25
'@jridgewell/resolve-uri@3.1.2': {} '@jridgewell/resolve-uri@3.1.2': {}
'@jridgewell/set-array@1.2.1': {} '@jridgewell/set-array@1.2.1': {}
@ -5525,11 +5813,18 @@ snapshots:
'@jridgewell/sourcemap-codec@1.5.0': {} '@jridgewell/sourcemap-codec@1.5.0': {}
'@jridgewell/sourcemap-codec@1.5.5': {}
'@jridgewell/trace-mapping@0.3.25': '@jridgewell/trace-mapping@0.3.25':
dependencies: dependencies:
'@jridgewell/resolve-uri': 3.1.2 '@jridgewell/resolve-uri': 3.1.2
'@jridgewell/sourcemap-codec': 1.5.0 '@jridgewell/sourcemap-codec': 1.5.0
'@jridgewell/trace-mapping@0.3.31':
dependencies:
'@jridgewell/resolve-uri': 3.1.2
'@jridgewell/sourcemap-codec': 1.5.0
'@juggle/resize-observer@3.4.0': {} '@juggle/resize-observer@3.4.0': {}
'@nodelib/fs.scandir@2.1.5': '@nodelib/fs.scandir@2.1.5':
@ -5551,6 +5846,8 @@ snapshots:
'@polka/url@1.0.0-next.25': {} '@polka/url@1.0.0-next.25': {}
'@rolldown/pluginutils@1.0.0-beta.43': {}
'@rollup/plugin-babel@6.0.4(@babel/core@7.25.2)(rollup@4.20.0)': '@rollup/plugin-babel@6.0.4(@babel/core@7.25.2)(rollup@4.20.0)':
dependencies: dependencies:
'@babel/core': 7.25.2 '@babel/core': 7.25.2
@ -5889,6 +6186,18 @@ snapshots:
transitivePeerDependencies: transitivePeerDependencies:
- supports-color - supports-color
'@vitejs/plugin-vue-jsx@5.1.1(vite@5.3.5(@types/node@22.13.10)(sass@1.77.8)(terser@5.31.3))(vue@3.4.35)':
dependencies:
'@babel/core': 7.28.4
'@babel/plugin-syntax-typescript': 7.27.1(@babel/core@7.28.4)
'@babel/plugin-transform-typescript': 7.28.0(@babel/core@7.28.4)
'@rolldown/pluginutils': 1.0.0-beta.43
'@vue/babel-plugin-jsx': 1.5.0(@babel/core@7.28.4)
vite: 5.3.5(@types/node@22.13.10)(sass@1.77.8)(terser@5.31.3)
vue: 3.4.35
transitivePeerDependencies:
- supports-color
'@vitejs/plugin-vue@5.1.2(vite@5.3.5(@types/node@22.13.10)(sass@1.77.8)(terser@5.31.3))(vue@3.4.35)': '@vitejs/plugin-vue@5.1.2(vite@5.3.5(@types/node@22.13.10)(sass@1.77.8)(terser@5.31.3))(vue@3.4.35)':
dependencies: dependencies:
vite: 5.3.5(@types/node@22.13.10)(sass@1.77.8)(terser@5.31.3) vite: 5.3.5(@types/node@22.13.10)(sass@1.77.8)(terser@5.31.3)
@ -5896,6 +6205,8 @@ snapshots:
'@vue/babel-helper-vue-transform-on@1.4.0': {} '@vue/babel-helper-vue-transform-on@1.4.0': {}
'@vue/babel-helper-vue-transform-on@1.5.0': {}
'@vue/babel-plugin-jsx@1.4.0(@babel/core@7.25.2)': '@vue/babel-plugin-jsx@1.4.0(@babel/core@7.25.2)':
dependencies: dependencies:
'@babel/helper-module-imports': 7.27.1 '@babel/helper-module-imports': 7.27.1
@ -5912,6 +6223,22 @@ snapshots:
transitivePeerDependencies: transitivePeerDependencies:
- supports-color - supports-color
'@vue/babel-plugin-jsx@1.5.0(@babel/core@7.28.4)':
dependencies:
'@babel/helper-module-imports': 7.27.1
'@babel/helper-plugin-utils': 7.27.1
'@babel/plugin-syntax-jsx': 7.27.1(@babel/core@7.28.4)
'@babel/template': 7.27.2
'@babel/traverse': 7.28.4
'@babel/types': 7.28.4
'@vue/babel-helper-vue-transform-on': 1.5.0
'@vue/babel-plugin-resolve-type': 1.5.0(@babel/core@7.28.4)
'@vue/shared': 3.5.22
optionalDependencies:
'@babel/core': 7.28.4
transitivePeerDependencies:
- supports-color
'@vue/babel-plugin-resolve-type@1.4.0(@babel/core@7.25.2)': '@vue/babel-plugin-resolve-type@1.4.0(@babel/core@7.25.2)':
dependencies: dependencies:
'@babel/code-frame': 7.27.1 '@babel/code-frame': 7.27.1
@ -5923,6 +6250,17 @@ snapshots:
transitivePeerDependencies: transitivePeerDependencies:
- supports-color - supports-color
'@vue/babel-plugin-resolve-type@1.5.0(@babel/core@7.28.4)':
dependencies:
'@babel/code-frame': 7.27.1
'@babel/core': 7.28.4
'@babel/helper-module-imports': 7.27.1
'@babel/helper-plugin-utils': 7.27.1
'@babel/parser': 7.28.4
'@vue/compiler-sfc': 3.5.22
transitivePeerDependencies:
- supports-color
'@vue/compiler-core@3.4.35': '@vue/compiler-core@3.4.35':
dependencies: dependencies:
'@babel/parser': 7.25.3 '@babel/parser': 7.25.3
@ -5939,6 +6277,14 @@ snapshots:
estree-walker: 2.0.2 estree-walker: 2.0.2
source-map-js: 1.2.1 source-map-js: 1.2.1
'@vue/compiler-core@3.5.22':
dependencies:
'@babel/parser': 7.28.4
'@vue/shared': 3.5.22
entities: 4.5.0
estree-walker: 2.0.2
source-map-js: 1.2.1
'@vue/compiler-dom@3.4.35': '@vue/compiler-dom@3.4.35':
dependencies: dependencies:
'@vue/compiler-core': 3.4.35 '@vue/compiler-core': 3.4.35
@ -5949,6 +6295,11 @@ snapshots:
'@vue/compiler-core': 3.5.14 '@vue/compiler-core': 3.5.14
'@vue/shared': 3.5.14 '@vue/shared': 3.5.14
'@vue/compiler-dom@3.5.22':
dependencies:
'@vue/compiler-core': 3.5.22
'@vue/shared': 3.5.22
'@vue/compiler-sfc@3.4.35': '@vue/compiler-sfc@3.4.35':
dependencies: dependencies:
'@babel/parser': 7.25.3 '@babel/parser': 7.25.3
@ -5973,6 +6324,18 @@ snapshots:
postcss: 8.5.3 postcss: 8.5.3
source-map-js: 1.2.1 source-map-js: 1.2.1
'@vue/compiler-sfc@3.5.22':
dependencies:
'@babel/parser': 7.28.4
'@vue/compiler-core': 3.5.22
'@vue/compiler-dom': 3.5.22
'@vue/compiler-ssr': 3.5.22
'@vue/shared': 3.5.22
estree-walker: 2.0.2
magic-string: 0.30.19
postcss: 8.5.6
source-map-js: 1.2.1
'@vue/compiler-ssr@3.4.35': '@vue/compiler-ssr@3.4.35':
dependencies: dependencies:
'@vue/compiler-dom': 3.4.35 '@vue/compiler-dom': 3.4.35
@ -5983,6 +6346,11 @@ snapshots:
'@vue/compiler-dom': 3.5.14 '@vue/compiler-dom': 3.5.14
'@vue/shared': 3.5.14 '@vue/shared': 3.5.14
'@vue/compiler-ssr@3.5.22':
dependencies:
'@vue/compiler-dom': 3.5.22
'@vue/shared': 3.5.22
'@vue/devtools-api@6.6.3': {} '@vue/devtools-api@6.6.3': {}
'@vue/devtools-core@7.7.6(vite@5.3.5(@types/node@22.13.10)(sass@1.77.8)(terser@5.31.3))(vue@3.4.35)': '@vue/devtools-core@7.7.6(vite@5.3.5(@types/node@22.13.10)(sass@1.77.8)(terser@5.31.3))(vue@3.4.35)':
@ -6037,6 +6405,8 @@ snapshots:
'@vue/shared@3.5.14': {} '@vue/shared@3.5.14': {}
'@vue/shared@3.5.22': {}
'@vueuse/core@10.11.0(vue@3.4.35)': '@vueuse/core@10.11.0(vue@3.4.35)':
dependencies: dependencies:
'@types/web-bluetooth': 0.0.20 '@types/web-bluetooth': 0.0.20
@ -6171,6 +6541,8 @@ snapshots:
base64-js@1.5.1: {} base64-js@1.5.1: {}
baseline-browser-mapping@2.8.17: {}
bin-build@3.0.0: bin-build@3.0.0:
dependencies: dependencies:
decompress: 4.2.1 decompress: 4.2.1
@ -6240,6 +6612,14 @@ snapshots:
node-releases: 2.0.18 node-releases: 2.0.18
update-browserslist-db: 1.1.0(browserslist@4.23.3) update-browserslist-db: 1.1.0(browserslist@4.23.3)
browserslist@4.26.3:
dependencies:
baseline-browser-mapping: 2.8.17
caniuse-lite: 1.0.30001751
electron-to-chromium: 1.5.237
node-releases: 2.0.25
update-browserslist-db: 1.1.3(browserslist@4.26.3)
buffer-alloc-unsafe@1.1.0: {} buffer-alloc-unsafe@1.1.0: {}
buffer-alloc@1.2.0: buffer-alloc@1.2.0:
@ -6288,6 +6668,8 @@ snapshots:
caniuse-lite@1.0.30001649: {} caniuse-lite@1.0.30001649: {}
caniuse-lite@1.0.30001751: {}
caw@2.0.1: caw@2.0.1:
dependencies: dependencies:
get-proxy: 2.1.0 get-proxy: 2.1.0
@ -6630,6 +7012,8 @@ snapshots:
tslib: 2.3.0 tslib: 2.3.0
zrender: 5.6.1 zrender: 5.6.1
electron-to-chromium@1.5.237: {}
electron-to-chromium@1.5.4: {} electron-to-chromium@1.5.4: {}
end-of-stream@1.4.4: end-of-stream@1.4.4:
@ -6758,6 +7142,8 @@ snapshots:
escalade@3.1.2: {} escalade@3.1.2: {}
escalade@3.2.0: {}
escape-string-regexp@1.0.5: {} escape-string-regexp@1.0.5: {}
escape-string-regexp@5.0.0: {} escape-string-regexp@5.0.0: {}
@ -7434,6 +7820,10 @@ snapshots:
dependencies: dependencies:
'@jridgewell/sourcemap-codec': 1.5.0 '@jridgewell/sourcemap-codec': 1.5.0
magic-string@0.30.19:
dependencies:
'@jridgewell/sourcemap-codec': 1.5.5
make-dir@1.3.0: make-dir@1.3.0:
dependencies: dependencies:
pify: 3.0.0 pify: 3.0.0
@ -7549,6 +7939,8 @@ snapshots:
node-releases@2.0.18: {} node-releases@2.0.18: {}
node-releases@2.0.25: {}
normalize-package-data@2.5.0: normalize-package-data@2.5.0:
dependencies: dependencies:
hosted-git-info: 2.8.9 hosted-git-info: 2.8.9
@ -7995,6 +8387,12 @@ snapshots:
picocolors: 1.1.1 picocolors: 1.1.1
source-map-js: 1.2.1 source-map-js: 1.2.1
postcss@8.5.6:
dependencies:
nanoid: 3.3.11
picocolors: 1.1.1
source-map-js: 1.2.1
prepend-http@1.0.4: {} prepend-http@1.0.4: {}
prepend-http@2.0.0: {} prepend-http@2.0.0: {}
@ -8500,7 +8898,7 @@ snapshots:
transitivePeerDependencies: transitivePeerDependencies:
- rollup - rollup
unplugin-vue-components@0.27.3(@babel/parser@7.27.2)(rollup@4.20.0)(vue@3.4.35): unplugin-vue-components@0.27.3(@babel/parser@7.28.4)(rollup@4.20.0)(vue@3.4.35):
dependencies: dependencies:
'@antfu/utils': 0.7.10 '@antfu/utils': 0.7.10
'@rollup/pluginutils': 5.1.0(rollup@4.20.0) '@rollup/pluginutils': 5.1.0(rollup@4.20.0)
@ -8514,7 +8912,7 @@ snapshots:
unplugin: 1.12.0 unplugin: 1.12.0
vue: 3.4.35 vue: 3.4.35
optionalDependencies: optionalDependencies:
'@babel/parser': 7.27.2 '@babel/parser': 7.28.4
transitivePeerDependencies: transitivePeerDependencies:
- rollup - rollup
- supports-color - supports-color
@ -8532,6 +8930,12 @@ snapshots:
escalade: 3.1.2 escalade: 3.1.2
picocolors: 1.0.1 picocolors: 1.0.1
update-browserslist-db@1.1.3(browserslist@4.26.3):
dependencies:
browserslist: 4.26.3
escalade: 3.2.0
picocolors: 1.1.1
url-parse-lax@1.0.0: url-parse-lax@1.0.0:
dependencies: dependencies:
prepend-http: 1.0.4 prepend-http: 1.0.4

Binary file not shown.

After

Width:  |  Height:  |  Size: 132 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 18 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 8.0 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 33 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 10 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 99 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 10 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 26 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 132 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 11 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 19 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 149 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 59 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.1 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 146 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 28 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.3 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.5 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.7 KiB

View File

@ -1,48 +1,61 @@
<template> <template>
<div class="home-page"> <div class="home-page relative bg-[#ffffff]">
<div class="business-page"> <div class="fixed h-[100vh] left-[50%] translate-x-[-50%] z-1"
style="width: 920px; pointer-events: none; mix-blend-mode: multiply">
<img src="@/assets/image/content/line.png" class="w-[100%]" alt="" />
</div>
<div class="w-[100%] h-[600PX] z-[] top-0 absolute">
<div class="relative w-[100%] h-[100%]">
<img src="@/assets/image/content/bg_12.png" alt="" class="w-[100vw] h-[570PX] absolute" />
<img src="@/assets/image/content/bg_13.png" alt="" class="w-[100vw] h-[80PX] absolute bottom-0 lef-0 right-0 z-99" />
</div>
</div>
<div class="business-page relative z-99">
<!-- 渐变背景标题区 - 增加层次感 --> <!-- 渐变背景标题区 - 增加层次感 -->
<section class="hero-section"> <section class="hero-section">
<div class="container"> <div class="container">
<h1 style="font-size: 40px" class="hero-title"> <h2 class="hero-title">
{{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.TITLE") }} {{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.TITLE") }}
</h1> </h2>
<div style="font-size: 18px" class="hero-description"> <div style="font-size: 16px" class="hero-description">
{{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.CONTENT") }} {{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.CONTENT") }}
</div> </div>
</div> </div>
</section> </section>
<!-- 业务核心解决方案 --> <!-- 业务核心解决方案 -->
<main style="margin-top: 40px" class="container"> <main style="margin-top: 380px" class="container">
<section> <section>
<h1 class="hero-title" style="font-size: 22px"> <h1 style="font-size: 40px" class="hero-title hero-title1">
{{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.CONTENTTWO") }} {{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.CONTENTTWO") }}
</h1> </h1>
</section> </section>
<div class="solution-grid"> <div class="flex justify-between w-[100%] my-[50PX]">
<img src="@/assets/image/content/profile_1.png" alt="" class="w-[201PX] h-[201PX]" />
<img src="@/assets/image/content/profile_2.png" alt="" class="w-[201PX] h-[201PX]" />
<img src="@/assets/image/content/profile_3.png" alt="" class="w-[201PX] h-[201PX]" />
<img src="@/assets/image/content/profile_4.png" alt="" class="w-[201PX] h-[201PX]" />
</div>
<section>
</section>
<div class="solution-grid grid grid-cols-2 gap-4">
<!-- 统一使用弹性列布局通过媒体查询控制排列方式 --> <!-- 统一使用弹性列布局通过媒体查询控制排列方式 -->
<div <div v-for="(solution, sIndex) in solutions" :key="sIndex" class="featured-solution mt-[20PX]">
v-for="(solution, sIndex) in solutions" <img v-if="sIndex === 0" src="@/assets/image/content/first.png" alt="">
:key="sIndex" <img v-else-if="sIndex === 1" src="@/assets/image/content/second.png" alt="">
class="featured-solution" <img v-else-if="sIndex === 2" src="@/assets/image/content/third.png" alt="">
> <img v-else src="@/assets/image/content/fourth.png" alt="">
<div <div class="solution-card" :style="{ '--delay': `${sIndex * 0.2}s` }">
class="solution-card"
:style="{ '--delay': `${sIndex * 0.2}s` }"
>
<div class="card-header"> <div class="card-header">
<div class="decorative-line"></div> <!-- <div class="decorative-line"></div> -->
<h2 class="card-title">{{ solution.title }}</h2> <h2 class="card-title">{{ solution.title }}</h2>
</div> </div>
<ul class="card-content"> <ul class="card-content">
<li <li v-for="(point, pIndex) in solution.points" :key="pIndex" class="content-point">
v-for="(point, pIndex) in solution.points"
:key="pIndex"
class="content-point"
>
<div class="point-icon"></div> <div class="point-icon"></div>
<div style="font-size: 18px" class="point-text"> <div style="font-size: 16px" class="point-text">
{{ point }} {{ point }}
</div> </div>
</li> </li>
@ -103,13 +116,25 @@ const solutions = computed(() => [
color: black; color: black;
margin-bottom: 2rem; margin-bottom: 2rem;
animation: slideIn 1s ease; animation: slideIn 1s ease;
position: relative;
}
.hero-title1::before {
content: "";
position: absolute;
top: -10px;
bottom: 0;
left: 0;
width: 60px;
height: 4px;
background-color: #ff7bac;
border-radius: 2px;
} }
.hero-description { .hero-description {
margin: 0 auto; margin: 0 auto;
font-size: 1.1rem; font-size: 1.1rem;
line-height: 1.8; line-height: 1.8;
color: black; color: #455363;
} }
:root { :root {
@ -129,15 +154,16 @@ const solutions = computed(() => [
} }
.container { .container {
max-width: 1280px; max-width: 900PX;
margin: 0 auto; margin: 0 auto;
padding: 0 2rem; /* padding: 0 2rem; */
} }
/* 标题区 - 紫色渐变 */ /* 标题区 - 紫色渐变 */
.hero-section { .hero-section {
background: var(--primary-gradient); background: var(--primary-gradient);
padding: 5rem 0 0rem; /* padding: 5rem 0 0rem; */
padding-top: 120PX;
position: relative; position: relative;
overflow: hidden; overflow: hidden;
color: white; color: white;
@ -205,12 +231,12 @@ const solutions = computed(() => [
/* 卡片公共样式 */ /* 卡片公共样式 */
.solution-card { .solution-card {
border-radius: 16px; border-radius: 16px;
padding: 2.5rem; /* padding: 2.5rem; */
transform: translateY(20px); /* transform: translateY(20px); */
opacity: 0; /* opacity: 0; */
animation: cardEnter 0.6s ease forwards; /* animation: cardEnter 0.6s ease forwards; */
border: 1px solid #fdc8dd; /* border: 1px solid #fdc8dd; */
background: #fff8fb; /* background: #fff8fb; */
} }
.card-header { .card-header {
@ -231,27 +257,46 @@ const solutions = computed(() => [
.card-title { .card-title {
font-size: 1.3rem; font-size: 1.3rem;
color: #e53073; /* color: #e53073; */
font-weight: 600; font-weight: 600;
position: relative;
/* transform: translateX(15px); */
} }
.card-title::before {
content: "";
position: absolute;
top: 10PX;
bottom: 0;
left: -10PX;
width: 1PX;
height: 15PX;
background-color: #ff7bac;
border-radius: 2px;
}
.content-point { .content-point {
display: flex; display: flex;
gap: 1rem; justify-content: flex-start;
padding: 1rem 0; /* gap: 1rem; */
border-bottom: 1px solid #fdc8dc; /* padding: 1rem 0; */
/* border-bottom: 1px solid #fdc8dc; */
} }
.point-icon { .point-icon {
color: #e53073; color: #455363;
font-size: 1.2rem; font-size: 1.2rem;
flex-shrink: 0; flex-shrink: 0;
margin-right: 5PX;
} }
.point-text { .point-text {
color: #e53073; /* color: #e53073; */
line-height: 1.6; line-height: 1.6;
font-size: 18px; font-size: 18px;
color: #455363;
} }
@keyframes cardEnter { @keyframes cardEnter {

View File

@ -1,26 +1,16 @@
<template> <template>
<div class="home-page relative bg-[#ffffff]"> <div class="home-page relative bg-[#ffffff]">
<div <div class="fixed h-[100vh] left-[50%] translate-x-[-50%] z-1"
class="fixed h-[100vh] left-[50%] translate-x-[-50%] z-1" style="width: 920px; pointer-events: none; mix-blend-mode: multiply">
style="width: 920px; pointer-events: none; mix-blend-mode: multiply"
>
<img src="@/assets/image/content/line.png" class="w-[100%]" alt="" /> <img src="@/assets/image/content/line.png" class="w-[100%]" alt="" />
</div> </div>
<div class="w-[100%] h-[916px] z-[] top-0 absolute"> <div class="w-[100%] h-[600PX] z-[] top-0 absolute">
<div class="relative w-[100%] h-[100%]"> <div class="relative w-[100%] h-[100%]">
<img <img src="@/assets/image/content/bg_12.png" alt="" class="w-[100vw] h-[570PX] absolute" />
src="@/assets/image/content/bg_1.png" <img src="@/assets/image/content/bg_13.png" alt="" class="w-[100vw] h-[80PX] absolute bottom-0 lef-0 right-0 z-99" />
alt=""
class="w-[100vw] absolute top-[-90px]"
/>
<img
src="@/assets/image/content/bg_2.png"
alt=""
class="w-[100vw] absolute bottom-0 lef-0 right-0 z-99"
/>
</div> </div>
</div> </div>
<div class="business-page"> <div class="business-page relative z-99">
<!-- 渐变背景标题区 - 增加层次感 --> <!-- 渐变背景标题区 - 增加层次感 -->
<section class="hero-section"> <section class="hero-section">
<div class="container"> <div class="container">
@ -33,36 +23,39 @@
</div> </div>
</section> </section>
<!-- 业务核心解决方案 --> <!-- 业务核心解决方案 -->
<main style="margin-top: 40px" class="container"> <main style="margin-top: 380px" class="container">
<section> <section>
<h1 style="font-size: 30px" class="hero-title"> <h1 style="font-size: 40px" class="hero-title hero-title1">
{{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.CONTENTTWO") }} {{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.CONTENTTWO") }}
</h1> </h1>
</section> </section>
<div class="solution-grid"> <div class="flex justify-between w-[100%] my-[50PX]">
<img src="@/assets/image/content/profile_1.png" alt="" class="w-[201PX] h-[201PX]" />
<img src="@/assets/image/content/profile_2.png" alt="" class="w-[201PX] h-[201PX]" />
<img src="@/assets/image/content/profile_3.png" alt="" class="w-[201PX] h-[201PX]" />
<img src="@/assets/image/content/profile_4.png" alt="" class="w-[201PX] h-[201PX]" />
</div>
<section>
</section>
<div class="solution-grid grid grid-cols-2 gap-4">
<!-- 统一使用弹性列布局通过媒体查询控制排列方式 --> <!-- 统一使用弹性列布局通过媒体查询控制排列方式 -->
<div <div v-for="(solution, sIndex) in solutions" :key="sIndex" class="featured-solution mt-[20PX]">
v-for="(solution, sIndex) in solutions" <img v-if="sIndex === 0" src="@/assets/image/content/first.png" alt="">
:key="sIndex" <img v-else-if="sIndex === 1" src="@/assets/image/content/second.png" alt="">
class="featured-solution" <img v-else-if="sIndex === 2" src="@/assets/image/content/third.png" alt="">
> <img v-else src="@/assets/image/content/fourth.png" alt="">
<div <div class="solution-card" :style="{ '--delay': `${sIndex * 0.2}s` }">
class="solution-card"
:style="{ '--delay': `${sIndex * 0.2}s` }"
>
<div class="card-header"> <div class="card-header">
<div class="decorative-line"></div> <!-- <div class="decorative-line"></div> -->
<h2 class="card-title">{{ solution.title }}</h2> <h2 class="card-title">{{ solution.title }}</h2>
</div> </div>
<ul class="card-content"> <ul class="card-content">
<li <li v-for="(point, pIndex) in solution.points" :key="pIndex" class="content-point">
v-for="(point, pIndex) in solution.points"
:key="pIndex"
class="content-point"
>
<div class="point-icon"></div> <div class="point-icon"></div>
<div style="font-size: 18px" class="point-text"> <div style="font-size: 16px" class="point-text">
{{ point }} {{ point }}
</div> </div>
</li> </li>
@ -123,6 +116,18 @@ const solutions = computed(() => [
color: black; color: black;
margin-bottom: 2rem; margin-bottom: 2rem;
animation: slideIn 1s ease; animation: slideIn 1s ease;
position: relative;
}
.hero-title1::before {
content: "";
position: absolute;
top: -10px;
bottom: 0;
left: 0;
width: 60px;
height: 4px;
background-color: #ff7bac;
border-radius: 2px;
} }
.hero-description { .hero-description {
@ -149,15 +154,16 @@ const solutions = computed(() => [
} }
.container { .container {
max-width: 1280px; max-width: 900PX;
margin: 0 auto; margin: 0 auto;
padding: 0 2rem; /* padding: 0 2rem; */
} }
/* 标题区 - 紫色渐变 */ /* 标题区 - 紫色渐变 */
.hero-section { .hero-section {
background: var(--primary-gradient); background: var(--primary-gradient);
padding: 5rem 0 0rem; /* padding: 5rem 0 0rem; */
padding-top: 120PX;
position: relative; position: relative;
overflow: hidden; overflow: hidden;
color: white; color: white;
@ -225,12 +231,12 @@ const solutions = computed(() => [
/* 卡片公共样式 */ /* 卡片公共样式 */
.solution-card { .solution-card {
border-radius: 16px; border-radius: 16px;
padding: 2.5rem; /* padding: 2.5rem; */
transform: translateY(20px); /* transform: translateY(20px); */
opacity: 0; /* opacity: 0; */
animation: cardEnter 0.6s ease forwards; /* animation: cardEnter 0.6s ease forwards; */
border: 1px solid #fdc8dd; /* border: 1px solid #fdc8dd; */
background: #fff8fb; /* background: #fff8fb; */
} }
.card-header { .card-header {
@ -251,27 +257,46 @@ const solutions = computed(() => [
.card-title { .card-title {
font-size: 1.3rem; font-size: 1.3rem;
color: #e53073; /* color: #e53073; */
font-weight: 600; font-weight: 600;
position: relative;
/* transform: translateX(15px); */
} }
.card-title::before {
content: "";
position: absolute;
top: 10px;
bottom: 0;
left: -10PX;
width: 1PX;
height: 15PX;
background-color: #ff7bac;
border-radius: 2px;
}
.content-point { .content-point {
display: flex; display: flex;
gap: 1rem; justify-content: flex-start;
padding: 1rem 0; /* gap: 1rem; */
border-bottom: 1px solid #fdc8dc; /* padding: 1rem 0; */
/* border-bottom: 1px solid #fdc8dc; */
} }
.point-icon { .point-icon {
color: #e53073; color: #455363;
font-size: 1.2rem; font-size: 1.2rem;
flex-shrink: 0; flex-shrink: 0;
margin-right: 5PX;
} }
.point-text { .point-text {
color: #e53073; /* color: #e53073; */
line-height: 1.6; line-height: 1.6;
font-size: 18px; font-size: 18px;
color: #455363;
} }
@keyframes cardEnter { @keyframes cardEnter {

View File

@ -1,49 +1,72 @@
<template> <template>
<div class="home-page"> <div class="home-page relative bg-[#ffffff]">
<div class="business-page"> <div class="fixed h-[100vh] left-[50%] translate-x-[-50%] z-1"
<!-- 渐变背景标题区 --> style="width: 332px; pointer-events: none; mix-blend-mode: multiply">
<img src="@/assets/image/content/line.png" class="w-[100%]" alt="" />
</div>
<div class="w-[100%] h-[711PX] z-[] top-0 absolute">
<div class="relative w-[100%] h-[100%]">
<img src="@/assets/image/content/bg_20.png" alt="" class="w-[100vw] h-[711PX] absolute" />
<img src="@/assets/image/content/bg_13.png" alt=""
class="w-[100vw] h-[80PX] absolute bottom-0 lef-0 right-0 z-99" />
</div>
</div>
<div class="business-page relative z-99">
<!-- 渐变背景标题区 - 增加层次感 -->
<section class="hero-section"> <section class="hero-section">
<div class="container"> <div class="container">
<h1 style="font-size: 40px" class="hero-title"> <h2 class="hero-title">
{{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.TITLE") }} {{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.TITLE") }}
</h1> </h2>
<div style="font-size: 18px" class="hero-description"> <div style="font-size: 16px" class="hero-description">
{{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.CONTENT") }} {{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.CONTENT") }}
</div> </div>
</div> </div>
</section> </section>
<!-- 业务核心解决方案 --> <!-- 业务核心解决方案 -->
<main style="margin-top: 40px" class="container"> <main style="margin-top: 250px" class="container">
<section> <section>
<h1 style="font-size: 40px" class="hero-title"> <h1 style="font-size: 20px" class="hero-title hero-title1">
{{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.CONTENTTWO") }} {{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.CONTENTTWO") }}
</h1> </h1>
</section> </section>
<!-- 解决方案网格 - 响应式弹性布局 --> <section>
<div class="solution-grid">
</section>
<div class="solution-grid grid grid-cols-1 gap-4">
<!-- 统一使用弹性列布局通过媒体查询控制排列方式 --> <!-- 统一使用弹性列布局通过媒体查询控制排列方式 -->
<div <div v-for="(solution, sIndex) in solutions" :key="sIndex" class="featured-solution">
v-for="(solution, sIndex) in solutions" <template v-if="sIndex === 0">
:key="sIndex" <img src="@/assets/image/content/profile_1.png" alt="" class="w-[201PX] h-[201PX]" />
class="featured-solution" <br />
> <img src="@/assets/image/content/first.png" alt="">
<div </template>
class="solution-card" <template v-else-if="sIndex === 1">
:style="{ '--delay': `${sIndex * 0.2}s` }" <img src="@/assets/image/content/profile_2.png" alt="" class="w-[201PX] h-[201PX]" />
> <br />
<img src="@/assets/image/content/second.png" alt="">
</template>
<template v-else-if="sIndex === 2">
<img src="@/assets/image/content/profile_3.png" alt="" class="w-[201PX] h-[201PX]" />
<br />
<img src="@/assets/image/content/third.png" alt="">
</template>
<template v-else>
<img src="@/assets/image/content/profile_4.png" alt="" class="w-[201PX] h-[201PX]" />
<br />
<img src="@/assets/image/content/fourth.png" alt="">
</template>
<div class="solution-card" :style="{ '--delay': `${sIndex * 0.2}s` }">
<div class="card-header"> <div class="card-header">
<div class="decorative-line"></div> <!-- <div class="decorative-line"></div> -->
<h2 class="card-title">{{ solution.title }}</h2> <h2 class="card-title">{{ solution.title }}</h2>
</div> </div>
<ul class="card-content"> <ul class="card-content">
<li <li v-for="(point, pIndex) in solution.points" :key="pIndex" class="content-point">
v-for="(point, pIndex) in solution.points"
:key="pIndex"
class="content-point"
>
<div class="point-icon"></div> <div class="point-icon"></div>
<div style="font-size: 18px" class="point-text"> <div style="font-size: 16px" class="point-text">
{{ point }} {{ point }}
</div> </div>
</li> </li>
@ -97,32 +120,32 @@ const solutions = computed(() => [
</script> </script>
<style scoped> <style scoped>
.container { /* 基础样式 */
margin: 0 auto;
padding: 0 2rem;
}
/* 标题区 - 紫色渐变 */
.hero-section {
background: var(--primary-gradient);
padding: 5rem 0 0rem;
position: relative;
overflow: hidden;
color: white;
}
.hero-title { .hero-title {
font-size: 40px; font-size: 40px;
color: black; color: black;
margin-bottom: 2rem; margin-bottom: 2rem;
animation: slideIn 1s ease; animation: slideIn 1s ease;
position: relative;
}
.hero-title1::before {
content: "";
position: absolute;
top: -10PX;
bottom: 0;
left: 0;
width: 60PX;
height: 6PX;
background-color: #ff7bac;
border-radius: 2px;
} }
.hero-description { .hero-description {
margin: 0 auto; margin: 0 auto;
font-size: 1.1rem; font-size: 1.1rem;
line-height: 1.8; line-height: 1.8;
color: black; color: #455363;
} }
:root { :root {
@ -135,63 +158,96 @@ const solutions = computed(() => [
var(--primary-color) 100% var(--primary-color) 100%
); );
} }
.home-page { .home-page {
background-size: 100% 100%; background-size: 100% 100%;
background-position: center; background-position: center;
background-repeat: no-repeat; background-repeat: no-repeat;
} }
/* 解决方案网格 - 响应式布局 */ .container {
.solution-grid { max-width: 311PX;
padding: 0rem 0 4rem; margin: 0 auto;
display: grid; /* padding: 0 2rem; */
grid-template-columns: 1fr; /* 默认单列(移动端) */
gap: 3rem;
} }
/* 中等屏幕768px-1439px - 单列布局 */ /* 标题区 - 紫色渐变 */
@media (min-width: 768px) and (max-width: 1439px) { .hero-section {
.solution-grid { background: var(--primary-gradient);
grid-template-columns: 1fr; /* padding: 5rem 0 0rem; */
} padding-top: 180PX;
}
/* 大屏幕≥1440px - 双列布局 */
@media (min-width: 1440px) {
.solution-grid {
grid-template-columns: 1fr 1fr;
}
}
/* 卡片样式 */
.solution-card {
background: #fff8fb;
border-radius: 16px;
padding: 2.5rem;
box-shadow: 0 10px 40px rgba(255, 123, 172, 0.1);
transform: translateY(20px);
opacity: 0;
animation: cardEnter 0.6s ease forwards;
position: relative; position: relative;
overflow: hidden; overflow: hidden;
border: 1px solid #fdc8dd; color: white;
transition: all 0.3s ease;
} }
.solution-card::before { .title-decoration {
content: "";
position: absolute; position: absolute;
top: 0; bottom: -15px;
left: 0; left: 0;
width: 100%; width: 80%;
height: 4px; height: 4px;
background: var(--primary-gradient); background: rgba(255, 255, 255, 0.5);
border-radius: 2px;
} }
.solution-card:hover { .solution-group {
transform: translateY(-8px); display: flex;
box-shadow: 0 15px 50px rgba(255, 123, 172, 0.2); flex-direction: column;
gap: 3rem;
margin-bottom: 4rem;
}
/* 桌面端布局(>=768px */
@media (min-width: 768px) {
.solution-group {
flex-direction: row;
gap: 4rem;
}
.featured-solution {
flex: 1;
margin-top: 20px;
}
}
/* 移动端布局(<768px */
@media (max-width: 767px) {
.home-page {
}
.hero-title {
font-size: 1.8rem;
}
.solution-group {
flex-direction: column;
gap: 2rem;
}
.featured-solution {
width: 100% !important; /* 强制占满容器 */
margin-bottom: 2rem;
}
.solution-card {
/* padding: 2rem; */
height: auto;
}
.content-point {
padding: 5px 0;
}
}
/* 卡片公共样式 */
.solution-card {
border-radius: 16px;
/* padding: 2.5rem; */
/* transform: translateY(20px); */
/* opacity: 0; */
/* animation: cardEnter 0.6s ease forwards; */
/* border: 1px solid #fdc8dd; */
/* background: #fff8fb; */
} }
.card-header { .card-header {
@ -204,7 +260,6 @@ const solutions = computed(() => [
background: var(--primary-gradient); background: var(--primary-gradient);
margin-bottom: 1rem; margin-bottom: 1rem;
border-radius: 3px; border-radius: 3px;
transition: width 0.3s ease;
} }
.solution-card:hover .decorative-line { .solution-card:hover .decorative-line {
@ -213,31 +268,46 @@ const solutions = computed(() => [
.card-title { .card-title {
font-size: 1.3rem; font-size: 1.3rem;
color: #e53073; /* color: #e53073; */
font-weight: 600; font-weight: 600;
position: relative;
/* transform: translateX(15px); */
} }
.card-title::before {
content: "";
position: absolute;
top: 10PX;
bottom: 0;
left: -10PX;
width: 1PX;
height: 15PX;
background-color: #ff7bac;
border-radius: 2px;
}
.content-point { .content-point {
display: flex; display: flex;
gap: 1rem; justify-content: flex-start;
padding: 1rem 0; /* gap: 1rem; */
border-bottom: 1px solid #fdc8dc; /* padding: 1rem 0; */
} /* border-bottom: 1px solid #fdc8dc; */
.content-point:last-child {
border-bottom: none;
} }
.point-icon { .point-icon {
color: #e53073; color: #455363;
font-size: 1.2rem; font-size: 1.2rem;
flex-shrink: 0; flex-shrink: 0;
margin-right: 5PX;
} }
.point-text { .point-text {
color: #e53073; /* color: #e53073; */
line-height: 1.6; line-height: 1.6;
font-size: 1rem; font-size: 18px;
color: #455363;
} }
@keyframes cardEnter { @keyframes cardEnter {

View File

@ -1,49 +1,72 @@
<template> <template>
<div class="home-page"> <div class="home-page relative bg-[#ffffff]">
<div class="business-page"> <div class="fixed h-[100vh] left-[50%] translate-x-[-50%] z-1"
<!-- 渐变背景标题区 --> style="width: 635px; pointer-events: none; mix-blend-mode: multiply">
<img src="@/assets/image/content/line.png" class="w-[100%]" alt="" />
</div>
<div class="w-[100%] h-[600PX] z-[] top-0 absolute">
<div class="relative w-[100%] h-[100%]">
<img src="@/assets/image/content/bg_14.png" alt="" class="w-[100vw] h-[570PX] absolute" />
<img src="@/assets/image/content/bg_13.png" alt=""
class="w-[100vw] h-[80PX] absolute bottom-0 lef-0 right-0 z-99" />
</div>
</div>
<div class="business-page relative z-99">
<!-- 渐变背景标题区 - 增加层次感 -->
<section class="hero-section"> <section class="hero-section">
<div class="container"> <div class="container">
<h1 style="font-size: 40px" class="hero-title"> <h2 class="hero-title">
{{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.TITLE") }} {{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.TITLE") }}
</h1> </h2>
<div style="font-size: 18px" class="hero-description"> <div style="font-size: 16px" class="hero-description">
{{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.CONTENT") }} {{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.CONTENT") }}
</div> </div>
</div> </div>
</section> </section>
<!-- 业务核心解决方案 --> <!-- 业务核心解决方案 -->
<main style="margin-top: 40px" class="container"> <main style="margin-top: 380px" class="container">
<section> <section>
<h1 style="font-size: 40px" class="hero-title"> <h1 style="font-size: 40px" class="hero-title hero-title1">
{{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.CONTENTTWO") }} {{ $t("BusinessiIntroduction.CONTAIN.TITLEONE.CONTENTTWO") }}
</h1> </h1>
</section> </section>
<!-- 解决方案网格 - 响应式弹性布局 --> <section>
<div class="solution-grid">
</section>
<div class="solution-grid grid grid-cols-1 gap-4">
<!-- 统一使用弹性列布局通过媒体查询控制排列方式 --> <!-- 统一使用弹性列布局通过媒体查询控制排列方式 -->
<div <div v-for="(solution, sIndex) in solutions" :key="sIndex" class="featured-solution mt-[20PX]">
v-for="(solution, sIndex) in solutions" <template v-if="sIndex === 0">
:key="sIndex" <img src="@/assets/image/content/profile_1.png" alt="" class="w-[201PX] h-[201PX]" />
class="featured-solution" <br />
> <img src="@/assets/image/content/first.png" alt="">
<div </template>
class="solution-card" <template v-else-if="sIndex === 1">
:style="{ '--delay': `${sIndex * 0.2}s` }" <img src="@/assets/image/content/profile_2.png" alt="" class="w-[201PX] h-[201PX]" />
> <br />
<img src="@/assets/image/content/second.png" alt="">
</template>
<template v-else-if="sIndex === 2">
<img src="@/assets/image/content/profile_3.png" alt="" class="w-[201PX] h-[201PX]" />
<br />
<img src="@/assets/image/content/third.png" alt="">
</template>
<template v-else>
<img src="@/assets/image/content/profile_4.png" alt="" class="w-[201PX] h-[201PX]" />
<br />
<img src="@/assets/image/content/fourth.png" alt="">
</template>
<div class="solution-card" :style="{ '--delay': `${sIndex * 0.2}s` }">
<div class="card-header"> <div class="card-header">
<div class="decorative-line"></div> <!-- <div class="decorative-line"></div> -->
<h2 class="card-title">{{ solution.title }}</h2> <h2 class="card-title">{{ solution.title }}</h2>
</div> </div>
<ul class="card-content"> <ul class="card-content">
<li <li v-for="(point, pIndex) in solution.points" :key="pIndex" class="content-point">
v-for="(point, pIndex) in solution.points"
:key="pIndex"
class="content-point"
>
<div class="point-icon"></div> <div class="point-icon"></div>
<div style="font-size: 18px" class="point-text"> <div style="font-size: 16px" class="point-text">
{{ point }} {{ point }}
</div> </div>
</li> </li>
@ -97,33 +120,32 @@ const solutions = computed(() => [
</script> </script>
<style scoped> <style scoped>
.container { /* 基础样式 */
max-width: 1280px;
margin: 0 auto;
padding: 0 2rem;
}
/* 标题区 - 紫色渐变 */
.hero-section {
background: var(--primary-gradient);
padding: 5rem 0 0rem;
position: relative;
overflow: hidden;
color: white;
}
.hero-title { .hero-title {
font-size: 40px; font-size: 40px;
color: black; color: black;
margin-bottom: 2rem; margin-bottom: 2rem;
animation: slideIn 1s ease; animation: slideIn 1s ease;
position: relative;
}
.hero-title1::before {
content: "";
position: absolute;
top: -10px;
bottom: 0;
left: 0;
width: 60PX;
height: 6PX;
background-color: #ff7bac;
border-radius: 2px;
} }
.hero-description { .hero-description {
margin: 0 auto; margin: 0 auto;
font-size: 1.1rem; font-size: 1.1rem;
line-height: 1.8; line-height: 1.8;
color: black; color: #455363;
} }
:root { :root {
@ -136,63 +158,96 @@ const solutions = computed(() => [
var(--primary-color) 100% var(--primary-color) 100%
); );
} }
.home-page { .home-page {
background-size: 100% 100%; background-size: 100% 100%;
background-position: center; background-position: center;
background-repeat: no-repeat; background-repeat: no-repeat;
} }
/* 解决方案网格 - 响应式布局 */ .container {
.solution-grid { max-width: 618PX;
padding: 0rem 0 4rem; margin: 0 auto;
display: grid; /* padding: 0 2rem; */
grid-template-columns: 1fr; /* 默认单列(移动端) */
gap: 3rem;
} }
/* 中等屏幕768px-1439px - 单列布局 */ /* 标题区 - 紫色渐变 */
@media (min-width: 768px) and (max-width: 1439px) { .hero-section {
.solution-grid { background: var(--primary-gradient);
grid-template-columns: 1fr; /* padding: 5rem 0 0rem; */
} padding-top: 120PX;
}
/* 大屏幕≥1440px - 双列布局 */
@media (min-width: 1440px) {
.solution-grid {
grid-template-columns: 1fr 1fr;
}
}
/* 卡片样式 */
.solution-card {
background: #fff8fb;
border-radius: 16px;
padding: 2.5rem;
box-shadow: 0 10px 40px rgba(255, 123, 172, 0.1);
transform: translateY(20px);
opacity: 0;
animation: cardEnter 0.6s ease forwards;
position: relative; position: relative;
overflow: hidden; overflow: hidden;
border: 1px solid #fdc8dd; color: white;
transition: all 0.3s ease;
} }
.solution-card::before { .title-decoration {
content: "";
position: absolute; position: absolute;
top: 0; bottom: -15px;
left: 0; left: 0;
width: 100%; width: 80%;
height: 4px; height: 4px;
background: var(--primary-gradient); background: rgba(255, 255, 255, 0.5);
border-radius: 2px;
} }
.solution-card:hover { .solution-group {
transform: translateY(-8px); display: flex;
box-shadow: 0 15px 50px rgba(255, 123, 172, 0.2); flex-direction: column;
gap: 3rem;
margin-bottom: 4rem;
}
/* 桌面端布局(>=768px */
@media (min-width: 768px) {
.solution-group {
flex-direction: row;
gap: 4rem;
}
.featured-solution {
flex: 1;
margin-top: 20px;
}
}
/* 移动端布局(<768px */
@media (max-width: 767px) {
.home-page {
}
.hero-title {
font-size: 1.8rem;
}
.solution-group {
flex-direction: column;
gap: 2rem;
}
.featured-solution {
width: 100% !important; /* 强制占满容器 */
margin-bottom: 2rem;
}
.solution-card {
/* padding: 2rem; */
height: auto;
}
.content-point {
padding: 1rem 0;
}
}
/* 卡片公共样式 */
.solution-card {
border-radius: 16px;
/* padding: 2.5rem; */
/* transform: translateY(20px); */
/* opacity: 0; */
/* animation: cardEnter 0.6s ease forwards; */
/* border: 1px solid #fdc8dd; */
/* background: #fff8fb; */
} }
.card-header { .card-header {
@ -205,7 +260,6 @@ const solutions = computed(() => [
background: var(--primary-gradient); background: var(--primary-gradient);
margin-bottom: 1rem; margin-bottom: 1rem;
border-radius: 3px; border-radius: 3px;
transition: width 0.3s ease;
} }
.solution-card:hover .decorative-line { .solution-card:hover .decorative-line {
@ -214,31 +268,46 @@ const solutions = computed(() => [
.card-title { .card-title {
font-size: 1.3rem; font-size: 1.3rem;
color: #e53073; /* color: #e53073; */
font-weight: 600; font-weight: 600;
position: relative;
/* transform: translateX(15px); */
} }
.card-title::before {
content: "";
position: absolute;
top: 10PX;
bottom: 0;
left: -10PX;
width: 1PX;
height: 15PX;
background-color: #ff7bac;
border-radius: 2px;
}
.content-point { .content-point {
display: flex; display: flex;
gap: 1rem; justify-content: flex-start;
padding: 1rem 0; /* gap: 1rem; */
border-bottom: 1px solid #fdc8dc; /* padding: 1rem 0; */
} /* border-bottom: 1px solid #fdc8dc; */
.content-point:last-child {
border-bottom: none;
} }
.point-icon { .point-icon {
color: #e53073; color: #455363;
font-size: 1.2rem; font-size: 1.2rem;
flex-shrink: 0; flex-shrink: 0;
margin-right: 5PX;
} }
.point-text { .point-text {
color: #e53073; /* color: #e53073; */
line-height: 1.6; line-height: 1.6;
font-size: 1rem; font-size: 18px;
color: #455363;
} }
@keyframes cardEnter { @keyframes cardEnter {

View File

@ -4,6 +4,9 @@
<div class="title mb-[50px] text-center"> <div class="title mb-[50px] text-center">
<h1 style="font-size: 40px; margin-top: 60px">Committee Composition</h1> <h1 style="font-size: 40px; margin-top: 60px">Committee Composition</h1>
</div> </div>
<div class="w-[900PX] mx-auto">
<n-data-table :columns="columns" :data="data" virtual-scroll-y />
</div>
<!-- 委员会表格 --> <!-- 委员会表格 -->
<div class="container"> <div class="container">
@ -110,7 +113,57 @@
</div> </div>
</template> </template>
<script setup> <script setup lang="jsx">
import { NDataTable } from "naive-ui";
const columns = [
{
title: "",
key: "name",
minWidth: 200,
fixed: "left",
},
{
// title: "Audit Committee",
key: "age",
minWidth: 200,
title(){
return <h3>Audit Committee</h3>;
}
},
{
title(){
return <h3>Compensation Committee</h3>;
},
key: "age",
minWidth: 200,
},
{
title(){
return <h3>Nominating and Corporate Governance Committee</h3>;
},
key: "age",
minWidth: 200,
},
];
let scrollX = 0;
const data = [
{
name: "Cao Yu",
age: 32,
address: "London, Park Lane no. 1",
},
{
name: "Cao Yu",
age: 32,
address: "London, Park Lane no. 1",
},
];
const heightForRow = () => 48;
const otherDirectors = [ const otherDirectors = [
// { // {
// name: "Cao Yu", // name: "Cao Yu",
@ -148,7 +201,16 @@ const getCommitteeRole = (name, committee) => {
}; };
</script> </script>
<style>
th {
/* background: pink !important; */
}
</style>
<style scoped> <style scoped>
:deep(.n-data-table-th) {
background: #FFF0F5 !important;
}
/* 紫色主题变量 */ /* 紫色主题变量 */
.role-badge.chair { .role-badge.chair {
color: #00baff; color: #00baff;

View File

@ -1,332 +1,45 @@
<template> <template>
<div class="board-members-page"> <n-data-table
<!-- 页面头部 --> :columns="columns"
<div class="title mb-[50px] text-center"> :data="data"
<h1 style="font-size: 40px; margin-top: 60px">Committee Composition</h1> :max-height="250"
</div> virtual-scroll
<!-- 移动端视图 --> virtual-scroll-x
<div class="container"> :scroll-x="scrollX"
<div :min-row-height="48"
class="director-card" :height-for-row="heightForRow"
v-for="(director, index) in otherDirectors" virtual-scroll-header
:key="director.name" :header-height="48"
:style="{ '--delay': index * 0.1 + 's' }" />
>
<div class="card-header">
<div class="director-info">
<div class="avatar">
<span class="initials">{{ getInitials(director.name) }}</span>
</div>
<div>
<router-link
:to="`/boarddirectors/${director.name}`"
class="director-name"
>
{{ director.name }}
</router-link>
<!-- <p class="director-title">{{ director.title }}</p> -->
</div>
</div>
</div>
<div class="committee-groups">
<!-- 委员会职位 -->
<div
class="committee-group"
v-if="getCommittees(director.name).length > 0"
>
<div class="role-badges">
<template
v-for="(committee, idx) in getCommittees(director.name)"
:key="idx"
>
<div class="committee-position">
<div
class="role-badge"
:class="
getCommitteeRole(director.name, committee).toLowerCase()
"
>
<span>{{ getCommitteeShortName(committee) }}</span>
</div>
<div style="font-size: 16px" class="role-title">
{{ getCommitteeRole(director.name, committee) }}
</div>
</div>
</template>
</div>
</div>
</div>
</div>
</div>
</div>
</template> </template>
<script setup> <script setup>
import { ref, computed } from "vue"; import { NDataTable } from "naive-ui";
//
const otherDirectors = [
// {
// name: "Cao Yu",
// title: "Chief Financial Officer, Secretary, Treasurer and Director",
// },
// { name: "David Lazar", title: "Director" },
{ name: "Hu Bin", title: "Director" },
{ name: "David Natan", title: "Director" },
{ name: "Chan Oi Fat", title: "Director" },
];
// - (Chair/Member) const columns = [];
const committeeRoles = {
"Cao Yu": {},
"David Lazar": {},
"Hu Bin": {
Audit: "Member",
Compensation: "Member",
Governance: "Member",
},
"David Natan": {
Audit: "Chair",
Compensation: "Member",
Governance: "Member",
},
"Chan Oi Fat": {
Audit: "Member",
Compensation: "Chair",
Governance: "Chair",
},
};
// let scrollX = 0;
const committeeFullNames = {
Audit: "Audit Committee",
Compensation: "Compensation Committee",
Governance: "Nominating and Corporate Governance Committee",
};
// for (let i = 0; i < 1e3; ++i) {
const getCommittees = (name) => { scrollX += 100;
return Object.keys(committeeRoles[name] || {}); columns.push({
}; title: `Col ${i}`,
width: 100,
key: i,
fixed: i <= 1 ? "" : i > 997 ? "" : void 0,
render(_, rowIndex) {
return `${i}-${rowIndex}`;
}
});
}
// (Chair/Member) const data = Array.from({ length: 1e3 }).map((_, index) => ({
const getCommitteeRole = (name, committee) => { key: index,
return committeeRoles[name]?.[committee] || ""; name: `Edward King ${index}`,
}; age: 32,
address: `London, Park Lane no. ${index}`
}));
// const heightForRow = () => 48;
const getCommitteeShortName = (committee) => {
const names = {
Audit: "Audit",
Compensation: "Comp.",
Governance: "Governance",
};
return names[committee] || committee;
};
//
const getInitials = (name) => {
return name
.split(" ")
.map((word) => word[0])
.join("")
.toUpperCase();
};
</script> </script>
<style scoped>
/* 添加这些样式来显示职位类型 */
.committee-position {
display: flex;
flex-direction: column;
align-items: center;
margin-bottom: 8px;
}
.role-title {
font-size: 12px;
color: #666;
margin-top: 4px;
text-transform: capitalize;
}
/* 保持原有的角色徽章样式 */
.role-badge {
padding: 6px 12px;
border-radius: 20px;
font-size: 14px;
font-weight: 500;
display: inline-flex;
align-items: center;
}
.role-badge.member {
background-color: #f0f0f0;
color: #555;
}
.title h1 {
position: relative;
&::after {
content: "";
position: absolute;
bottom: -14px;
left: 50%;
transform: translateX(-50%);
width: 80px;
height: 3px;
background: #ff7bac;
border-radius: 3px;
transition: width 0.3s ease;
}
&:hover::after {
width: 120px;
}
}
/* 基础变量 */
:root {
--primary: #895bff;
--primary-light: #a07cff;
--primary-dark: #6a11cb;
--text-primary: #333;
--text-secondary: #666;
--bg-light: #f9f6ff;
--border-radius: 12px;
}
/* 页面样式 */
.board-members-page {
background-size: 100% 100%;
background-position: center;
background-repeat: no-repeat;
min-height: 100vh;
}
.container {
padding: 0 16px;
margin: 0 auto;
}
/* 头部样式 */
.hero-section {
background: linear-gradient(
135deg,
var(--primary-light) 0%,
var(--primary) 100%
);
padding: 3rem 1rem;
text-align: center;
color: #895bff;
margin-bottom: 2rem;
}
.page-title {
font-size: clamp(1.75rem, 5vw, 2.25rem);
margin-bottom: 0.5rem;
font-weight: 600;
}
.page-subtitle {
font-size: clamp(1rem, 3vw, 1.25rem);
opacity: 0.9;
}
/* 董事卡片 */
.director-card {
background: white;
border-radius: var(--border-radius);
margin-bottom: 1.5rem;
box-shadow: 0 5px 20px rgba(255, 123, 172, 0.08);
overflow: hidden;
transform: translateY(20px);
opacity: 0;
animation: fadeIn 0.5s ease forwards;
animation-delay: var(--delay);
}
@keyframes fadeIn {
to {
opacity: 1;
transform: translateY(0);
}
}
.card-header {
color: #ff7bac;
padding: 1.25rem;
background: var(--bg-light);
border-bottom: 1px solid #f0f0f0;
}
.director-info {
display: flex;
align-items: center;
gap: 1rem;
}
.avatar {
width: 56px;
height: 56px;
background: var(--primary-transparent);
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
}
.initials {
font-size: 1.25rem;
font-weight: bold;
color: var(--primary);
}
.director-name {
color: var(--text-primary);
text-decoration: none;
font-size: 1.2rem;
font-weight: 500;
display: block;
margin-bottom: 0.25rem;
}
.director-title {
font-size: 0.9rem;
color: var(--text-secondary);
line-height: 1.3;
}
/* 委员会职位 */
.committee-groups {
padding: 1.25rem;
}
.role-badges {
display: flex;
flex-wrap: wrap;
gap: 0.5rem;
}
.role-badge {
padding: 0.35rem 0.75rem;
border-radius: 16px;
font-size: 0.8rem;
font-weight: 500;
display: inline-flex;
align-items: center;
gap: 0.35rem;
background: rgba(255, 123, 172, 0.08);
color: var(--primary);
}
.role-badge.chair {
background-color: #fcecf2;
color: #ff7bac;
}
.committee-name {
font-size: 0.75rem;
opacity: 0.8;
}
</style>

View File

@ -1,14 +1,29 @@
<script setup> <script setup>
import size1920 from "@/views/boarddirectors/size1920/index.vue"; import size1920 from "@/views/boarddirectors/size1920/index.vue";
import size375 from "@/views/boarddirectors/size375/index.vue"; import size375 from "@/views/boarddirectors/size375/index.vue";
import size768 from "@/views/boarddirectors/size768/index.vue";
import size1440 from "@/views/boarddirectors/size1440/index.vue";
import { computed } from "vue"; import { computed } from "vue";
import { useWindowSize } from "@vueuse/core"; import { useWindowSize } from "@vueuse/core";
const { width } = useWindowSize(); const { width } = useWindowSize();
// const viewComponent = computed(() => {
// const viewWidth = width.value;
// if (viewWidth <= 450) {
// return size375;
// } else if (viewWidth <= 1920 || viewWidth > 1920) {
// return size1920;
// }
// });
const viewComponent = computed(() => { const viewComponent = computed(() => {
const viewWidth = width.value; const viewWidth = width.value;
if (viewWidth <= 450) { if (viewWidth <= 450) {
return size375; return size375;
} else if (viewWidth <= 1100) {
return size768;
} else if (viewWidth <= 1500) {
return size1440;
} else if (viewWidth <= 1920 || viewWidth > 1920) { } else if (viewWidth <= 1920 || viewWidth > 1920) {
return size1920; return size1920;
} }
@ -19,4 +34,8 @@ const viewComponent = computed(() => {
<component :is="viewComponent" /> <component :is="viewComponent" />
</template> </template>
<style scoped lang="scss"></style> <style>
.n-layout-header{
z-index: 999;
}
</style>

View File

@ -1,8 +1,21 @@
<template> <template>
<div class="home-page"> <div class="fixed top-0 bottom-0 z-[10] bg-[#ffffff]">
<div class="directors-page"> <img
src="@/assets/image/content/bg_25.png"
class="w-[100vw] h-[611PX] relative"
alt=""
/>
</div>
<div class="home-page relative overflow-hidden z-[11] bg-[]">
<div
class="fixed h-[100vh] left-[50%] translate-x-[-50%] z-[-12]"
style="width: 920px; pointer-events: none; mix-blend-mode: multiply"
>
<img src="@/assets/image/content/line.png" class="w-[100%]" alt="" />
</div>
<div class="directors-page relative z-[-15]" style="width: 900px">
<h1 class="page-title">Board of Directors</h1> <h1 class="page-title">Board of Directors</h1>
<n-divider />
<div class="directors-list"> <div class="directors-list">
<div <div
@ -10,13 +23,8 @@
:key="index" :key="index"
class="director-item" class="director-item"
> >
<n-h2 style="font-size: 18px" class="director-name">{{ <n-h2 class="director-name">{{ director.name }}</n-h2>
director.name <n-text class="director-title">{{ director.title }}</n-text>
}}</n-h2>
<n-text style="font-size: 16px" class="director-title">{{
director.title
}}</n-text>
<n-divider class="divider" />
<n-p class="director-bio">{{ director.contain }}</n-p> <n-p class="director-bio">{{ director.contain }}</n-p>
</div> </div>
</div> </div>
@ -67,15 +75,25 @@ const otherDirectors = [
background-repeat: no-repeat; background-repeat: no-repeat;
} }
.directors-page { .directors-page {
max-width: 900px; /* max-width: 900px; */
margin: 0 auto; margin: 0 auto;
padding: 60px 24px; /* padding: 60px 24px; */
} }
.page-title { .page-title {
font-size: 2.5rem; /* 18px */ font-size: 2.5rem; /* 18px */
margin-bottom: 30px; margin-bottom: 30px;
color: #333; color: #333;
position: relative;
}
.page-title::after {
content: "";
position: absolute;
left: 0;
width: 60px;
height: 4PX;
background: #ff7bac;
transform: translateY(-15px);
} }
.directors-list { .directors-list {
@ -86,8 +104,8 @@ const otherDirectors = [
} }
.director-item { .director-item {
padding-bottom: 48px; /* padding-bottom: 48px; */
border-bottom: 1px solid #f0f0f0; /* border-bottom: 1px solid #f0f0f0; */
} }
.director-item:last-child { .director-item:last-child {
@ -97,14 +115,27 @@ const otherDirectors = [
.director-name { .director-name {
margin-bottom: 8px; margin-bottom: 8px;
font-size: 28px; font-size: 28PX;
font-weight: 500; font-weight: 500;
color: #1a1a1a; color: #1a1a1a;
position: relative;
}
.director-name::after {
content: "";
position: absolute;
width: 2px;
height: 20PX;
background: #ff7bac;
left: -10PX;
top: 50%;
transform: translateY(-50%);
} }
.director-title { .director-title {
font-size: 18px; font-size: 18PX;
color: #666; color: #ff7bac;
display: block; display: block;
margin-bottom: 24px; margin-bottom: 24px;
} }
@ -117,20 +148,20 @@ const otherDirectors = [
.director-bio { .director-bio {
line-height: 1.8; line-height: 1.8;
color: #4a4a4a; color: #4a4a4a;
font-size: 16px; font-size: 16PX;
} }
@media (min-width: 768px) { @media (min-width: 768px) {
.directors-page { .directors-page {
padding: 80px 40px; /* padding: 80px 40px; */
} }
.director-name { .director-name {
font-size: 32px; /* font-size: 32px; */
} }
.director-title { .director-title {
font-size: 20px; /* font-size: 20px; */
} }
} }
</style> </style>

View File

@ -1,8 +1,21 @@
<template> <template>
<div class="home-page"> <div class="fixed top-0 bottom-0 z-[10] bg-[#ffffff]">
<div class="directors-page"> <img
src="@/assets/image/content/bg_25.png"
class="w-[100vw] h-[611PX] relative"
alt=""
/>
</div>
<div class="home-page relative overflow-hidden z-[11] bg-[]">
<div
class="fixed h-[100vh] left-[50%] translate-x-[-50%] z-[-12]"
style="width: 920px; pointer-events: none; mix-blend-mode: multiply"
>
<img src="@/assets/image/content/line.png" class="w-[100%]" alt="" />
</div>
<div class="directors-page relative z-[-15]" style="width: 900px">
<h1 class="page-title">Board of Directors</h1> <h1 class="page-title">Board of Directors</h1>
<n-divider />
<div class="directors-list"> <div class="directors-list">
<div <div
@ -12,7 +25,6 @@
> >
<n-h2 class="director-name">{{ director.name }}</n-h2> <n-h2 class="director-name">{{ director.name }}</n-h2>
<n-text class="director-title">{{ director.title }}</n-text> <n-text class="director-title">{{ director.title }}</n-text>
<n-divider class="divider" />
<n-p class="director-bio">{{ director.contain }}</n-p> <n-p class="director-bio">{{ director.contain }}</n-p>
</div> </div>
</div> </div>
@ -63,15 +75,25 @@ const otherDirectors = [
background-repeat: no-repeat; background-repeat: no-repeat;
} }
.directors-page { .directors-page {
max-width: 900px; /* max-width: 900px; */
margin: 0 auto; margin: 0 auto;
padding: 60px 24px; /* padding: 60px 24px; */
} }
.page-title { .page-title {
font-size: 2.5rem; /* 18px */ font-size: 2.5rem; /* 18px */
margin-bottom: 30px; margin-bottom: 30px;
color: #333; color: #333;
position: relative;
}
.page-title::after {
content: "";
position: absolute;
left: 0;
width: 60px;
height: 4PX;
background: #ff7bac;
transform: translateY(-15px);
} }
.directors-list { .directors-list {
@ -82,8 +104,8 @@ const otherDirectors = [
} }
.director-item { .director-item {
padding-bottom: 48px; /* padding-bottom: 48px; */
border-bottom: 1px solid #f0f0f0; /* border-bottom: 1px solid #f0f0f0; */
} }
.director-item:last-child { .director-item:last-child {
@ -93,14 +115,27 @@ const otherDirectors = [
.director-name { .director-name {
margin-bottom: 8px; margin-bottom: 8px;
font-size: 28px; font-size: 28PX;
font-weight: 500; font-weight: 500;
color: #1a1a1a; color: #1a1a1a;
position: relative;
}
.director-name::after {
content: "";
position: absolute;
width: 2px;
height: 20PX;
background: #ff7bac;
left: -10PX;
top: 50%;
transform: translateY(-50%);
} }
.director-title { .director-title {
font-size: 18px; font-size: 18PX;
color: #666; color: #ff7bac;
display: block; display: block;
margin-bottom: 24px; margin-bottom: 24px;
} }
@ -113,20 +148,20 @@ const otherDirectors = [
.director-bio { .director-bio {
line-height: 1.8; line-height: 1.8;
color: #4a4a4a; color: #4a4a4a;
font-size: 16px; font-size: 16PX;
} }
@media (min-width: 768px) { @media (min-width: 768px) {
.directors-page { .directors-page {
padding: 80px 40px; /* padding: 80px 40px; */
} }
.director-name { .director-name {
font-size: 32px; /* font-size: 32px; */
} }
.director-title { .director-title {
font-size: 20px; /* font-size: 20px; */
} }
} }
</style> </style>

View File

@ -1,8 +1,21 @@
<template> <template>
<div class="home-page"> <div class="fixed top-0 bottom-0 z-[10] bg-[#ffffff]">
<div class="directors-page"> <img
<n-h1 class="page-title">Board of Directors</n-h1> src="@/assets/image/content/bg_26.png"
<n-divider /> class="w-[100vw] h-[340PX] relative"
alt=""
/>
</div>
<div class="home-page relative overflow-hidden z-[11] bg-[]">
<div
class="fixed h-[100vh] left-[50%] translate-x-[-50%] z-[-12]"
style="width: 331px; pointer-events: none; mix-blend-mode: multiply"
>
<img src="@/assets/image/content/line.png" class="w-[100%]" alt="" />
</div>
<div class="directors-page relative z-[-15]" style="width: 311px">
<h1 class="page-title">Board of Directors</h1>
<div class="directors-list"> <div class="directors-list">
<div <div
@ -12,7 +25,6 @@
> >
<n-h2 class="director-name">{{ director.name }}</n-h2> <n-h2 class="director-name">{{ director.name }}</n-h2>
<n-text class="director-title">{{ director.title }}</n-text> <n-text class="director-title">{{ director.title }}</n-text>
<n-divider class="divider" />
<n-p class="director-bio">{{ director.contain }}</n-p> <n-p class="director-bio">{{ director.contain }}</n-p>
</div> </div>
</div> </div>
@ -57,43 +69,43 @@ const otherDirectors = [
</script> </script>
<style scoped> <style scoped>
:root {
--primary-color: #333;
--secondary-color: #666;
--divider-color: #f0f0f0;
--mobile-padding: 16px;
--tablet-padding: 24px;
}
.home-page { .home-page {
background-size: cover; background-size: 100% 100%;
background-position: center; background-position: center;
background-repeat: no-repeat; background-repeat: no-repeat;
} }
.directors-page { .directors-page {
max-width: 1200px; /* max-width: 900px; */
margin: 0 auto; margin: 0 auto;
padding: clamp(2rem, 5vw, 4rem) /* padding: 60px 24px; */
clamp(var(--mobile-padding), 4vw, var(--tablet-padding));
} }
.page-title { .page-title {
font-size: clamp(1.75rem, 4vw, 2.5rem); font-size: 24PX; /* 18px */
margin-bottom: clamp(1.5rem, 3vw, 2rem); margin-bottom: 30px;
color: var(--primary-color); color: #333;
position: relative;
}
.page-title::after {
content: "";
position: absolute;
left: 0;
width: 60PX;
height: 4PX;
background: #ff7bac;
transform: translateY(-15px);
} }
.directors-list { .directors-list {
display: flex; display: flex;
flex-direction: column; flex-direction: column;
gap: clamp(2rem, 4vw, 3rem); gap: 48px;
margin-top: clamp(1.5rem, 3vw, 2.5rem); margin-top: 40px;
} }
.director-item { .director-item {
padding-bottom: clamp(2rem, 4vw, 3rem); /* padding-bottom: 48px; */
border-bottom: 1px solid var(--divider-color); /* border-bottom: 1px solid #f0f0f0; */
} }
.director-item:last-child { .director-item:last-child {
@ -102,43 +114,54 @@ const otherDirectors = [
} }
.director-name { .director-name {
margin-bottom: clamp(0.5rem, 1vw, 0.75rem); margin-bottom: 8px;
font-size: clamp(1.25rem, 3vw, 1.75rem); font-size: 20PX;
font-weight: 500; font-weight: 500;
color: var(--primary-color); color: #1a1a1a;
position: relative;
}
.director-name::after {
content: "";
position: absolute;
width: 2px;
height: 20PX;
background: #ff7bac;
left: -10PX;
top: 50%;
transform: translateY(-50%);
} }
.director-title { .director-title {
font-size: clamp(1rem, 2vw, 1.25rem); font-size: 14PX;
color: var(--secondary-color); color: #ff7bac;
display: block; display: block;
margin-bottom: clamp(1rem, 2vw, 1.5rem); margin-bottom: 24px;
line-height: 1.5;
} }
.divider { .divider {
margin: clamp(1rem, 2vw, 1.5rem) 0; margin: 16px 0;
background-color: var(--divider-color); background-color: #f0f0f0;
} }
.director-bio { .director-bio {
line-height: 1.8; line-height: 1.8;
color: #4a4a4a; color: #4a4a4a;
font-size: clamp(0.9rem, 1.8vw, 1rem); font-size: 14PX;
} }
/* 针对超小屏幕的优化 */ @media (min-width: 768px) {
@media (max-width: 375px) {
.directors-page { .directors-page {
padding: clamp(1.5rem, 5vw, 2rem) clamp(12px, 4vw, 16px); /* padding: 80px 40px; */
} }
.director-name { .director-name {
font-size: 1.25rem; /* font-size: 32px; */
} }
.director-title { .director-title {
font-size: 1rem; /* font-size: 20px; */
} }
} }
</style> </style>

View File

@ -1,8 +1,21 @@
<template> <template>
<div class="home-page"> <div class="fixed top-0 bottom-0 z-[10] bg-[#ffffff]">
<div class="directors-page"> <img
src="@/assets/image/content/bg_25.png"
class="w-[100vw] h-[611PX] relative"
alt=""
/>
</div>
<div class="home-page relative overflow-hidden z-[11] bg-[]">
<div
class="fixed h-[100vh] left-[50%] translate-x-[-50%] z-[-12]"
style="width: 620px; pointer-events: none; mix-blend-mode: multiply"
>
<img src="@/assets/image/content/line.png" class="w-[100%]" alt="" />
</div>
<div class="directors-page relative z-[-15]" style="width: 600px">
<h1 class="page-title">Board of Directors</h1> <h1 class="page-title">Board of Directors</h1>
<n-divider />
<div class="directors-list"> <div class="directors-list">
<div <div
@ -10,13 +23,8 @@
:key="index" :key="index"
class="director-item" class="director-item"
> >
<n-h2 style="font-size: 18px" class="director-name">{{ <n-h2 class="director-name">{{ director.name }}</n-h2>
director.name <n-text class="director-title">{{ director.title }}</n-text>
}}</n-h2>
<n-text style="font-size: 16px" class="director-title">{{
director.title
}}</n-text>
<n-divider class="divider" />
<n-p class="director-bio">{{ director.contain }}</n-p> <n-p class="director-bio">{{ director.contain }}</n-p>
</div> </div>
</div> </div>
@ -67,15 +75,25 @@ const otherDirectors = [
background-repeat: no-repeat; background-repeat: no-repeat;
} }
.directors-page { .directors-page {
max-width: 900px; /* max-width: 900px; */
margin: 0 auto; margin: 0 auto;
padding: 60px 24px; /* padding: 60px 24px; */
} }
.page-title { .page-title {
font-size: 2.5rem; /* 18px */ font-size: 2.5rem; /* 18px */
margin-bottom: 30px; margin-bottom: 30px;
color: #333; color: #333;
position: relative;
}
.page-title::after {
content: "";
position: absolute;
left: 0;
width: 60PX;
height: 4PX;
background: #ff7bac;
transform: translateY(-15px);
} }
.directors-list { .directors-list {
@ -86,8 +104,8 @@ const otherDirectors = [
} }
.director-item { .director-item {
padding-bottom: 48px; /* padding-bottom: 48px; */
border-bottom: 1px solid #f0f0f0; /* border-bottom: 1px solid #f0f0f0; */
} }
.director-item:last-child { .director-item:last-child {
@ -97,14 +115,27 @@ const otherDirectors = [
.director-name { .director-name {
margin-bottom: 8px; margin-bottom: 8px;
font-size: 28px; font-size: 28PX;
font-weight: 500; font-weight: 500;
color: #1a1a1a; color: #1a1a1a;
position: relative;
}
.director-name::after {
content: "";
position: absolute;
width: 2px;
height: 20PX;
background: #ff7bac;
left: -10PX;
top: 50%;
transform: translateY(-50%);
} }
.director-title { .director-title {
font-size: 18px; font-size: 18PX;
color: #666; color: #ff7bac;
display: block; display: block;
margin-bottom: 24px; margin-bottom: 24px;
} }
@ -117,20 +148,20 @@ const otherDirectors = [
.director-bio { .director-bio {
line-height: 1.8; line-height: 1.8;
color: #4a4a4a; color: #4a4a4a;
font-size: 16px; font-size: 16PX;
} }
@media (min-width: 768px) { @media (min-width: 768px) {
.directors-page { .directors-page {
padding: 80px 40px; /* padding: 80px 40px; */
} }
.director-name { .director-name {
font-size: 32px; /* font-size: 32px; */
} }
.director-title { .director-title {
font-size: 20px; /* font-size: 20px; */
} }
} }
</style> </style>

View File

@ -1,16 +1,37 @@
<template> <template>
<div class="home-page"> <div class="home-page relative overflow-hidden z-99 bg-[#ffffff]">
<div
class="fixed h-[100vh] left-[50%] translate-x-[-50%] z-1"
style="width: 343px; pointer-events: none; mix-blend-mode: multiply"
>
<img src="@/assets/image/content/line.png" class="w-[100%]" alt="" />
</div>
<div class="w-[100%] h-[950PX] z-[] top-0 absolute">
<div class="relative w-[100%] h-[100%]">
<img
src="@/assets/image/content/bg_17.png"
alt=""
class="w-[100vw] absolute h-[720PX] top-[-90px]"
/>
<img
src="@/assets/image/content/bg_19.png"
alt=""
class="w-[100vw] h-[270PX] absolute bottom-0 lef-0 right-0 z-1"
/>
</div>
</div>
<div class="company-overview"> <div class="company-overview">
<!-- 公司概况 --> <!-- 公司概况 -->
<section <section
class="company-overview" class="company-overview"
style="max-width: 1200px; margin: 60px auto" style="max-width: 311px; margin: 200px auto;margin-bottom: 180px;"
> >
<h1 class="section-title"> <h1 class="text-[20PX]">
{{ $t("COMPANYOVERVIEW.TITLETWO.TITLE") }} {{ $t("COMPANYOVERVIEW.TITLETWO.TITLE") }}
</h1> </h1>
<div class="content-block"> <div class="content-block">
<div style="font-size: 18px"> <div style="font-size: 14px; color: #455363">
{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENT") }} {{ $t("COMPANYOVERVIEW.TITLETWO.CONTENT") }}
</div> </div>
<!-- <p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENTTWO") }}</p> <!-- <p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENTTWO") }}</p>
@ -20,14 +41,17 @@
<!-- 使命愿景卡片 --> <!-- 使命愿景卡片 -->
<section class="mission-section"> <section class="mission-section">
<!-- <h1 class="section-title">
{{ $t("COMPANYOVERVIEW.TITLETHREE.TITLE") }}
</h1> -->
<div class="mission-cards"> <div class="mission-cards">
<n-card hoverable class="mission-card" v-motion-pop> <n-card hoverable class="mission-card" v-motion-pop>
<h1 class="section-title"> <div>
{{ $t("COMPANYOVERVIEW.TITLETHREE.TITLE") }} <h1 class="mt-0">
</h1> {{ $t("COMPANYOVERVIEW.TITLETHREE.TITLE") }}
<br /> </h1>
</div>
<n-p style="font-size: 18px" class="card-content">{{ <n-p style="font-size: 16px; color: #455363" class="card-content">{{
$t("COMPANYOVERVIEW.TITLETHREE.CONTENTTWO") $t("COMPANYOVERVIEW.TITLETHREE.CONTENTTWO")
}}</n-p> }}</n-p>
</n-card> </n-card>
@ -36,17 +60,20 @@
<!-- 里程碑时间轴 --> <!-- 里程碑时间轴 -->
<!-- 里程碑时间轴 --> <!-- 里程碑时间轴 -->
<section class="section timeline-section"> <section class="section timeline-section mt-[70PX]">
<n-h2 class="section-title">{{ <h1 class="section-title ml-[10PX]">
$t("COMPANYOVERVIEW.TITLEFOUR.TITLE") {{ $t("COMPANYOVERVIEW.TITLEFOUR.TITLE") }}
}}</n-h2> </h1>
<div class="timeline"> <div class="timeline">
<!-- 1977-2015 --> <!-- 1977-2015 -->
<div class="timeline-item" v-motion-slide-visible-once-bottom> <div class="timeline-item" v-motion-slide-visible-once-bottom>
<div class="timeline-dot"></div> <div class="timeline-dot"></div>
<div class="timeline-content"> <div class="timeline-content">
<div class="text-[#FF7BAC] text-[16PX]">
{{ $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADING").split(":")[0] }}
</div>
<n-h3 class="timeline-year">{{ <n-h3 class="timeline-year">{{
$t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADING") $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADING").split(":")[1]
}}</n-h3> }}</n-h3>
<br /> <br />
<n-p style="font-size: 18px" class="timeline-desc">{{ <n-p style="font-size: 18px" class="timeline-desc">{{
@ -64,8 +91,13 @@
<div class="timeline-item" v-motion-slide-visible-once-bottom> <div class="timeline-item" v-motion-slide-visible-once-bottom>
<div class="timeline-dot"></div> <div class="timeline-dot"></div>
<div class="timeline-content"> <div class="timeline-content">
<div class="text-[#FF7BAC] text-[16PX]">
{{
$t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGTWO").split(":")[0]
}}
</div>
<n-h3 class="timeline-year">{{ <n-h3 class="timeline-year">{{
$t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGTWO") $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGTWO").split(":")[1]
}}</n-h3> }}</n-h3>
<br /> <br />
@ -84,8 +116,13 @@
<div class="timeline-item" v-motion-slide-visible-once-bottom> <div class="timeline-item" v-motion-slide-visible-once-bottom>
<div class="timeline-dot"></div> <div class="timeline-dot"></div>
<div class="timeline-content"> <div class="timeline-content">
<div class="text-[#FF7BAC] text-[16PX]">
{{
$t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGTHREE").split(":")[0]
}}
</div>
<n-h3 class="timeline-year">{{ <n-h3 class="timeline-year">{{
$t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGTHREE") $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGTHREE").split(":")[1]
}}</n-h3> }}</n-h3>
<br /> <br />
@ -104,8 +141,13 @@
<div class="timeline-item" v-motion-slide-visible-once-bottom> <div class="timeline-item" v-motion-slide-visible-once-bottom>
<div class="timeline-dot"></div> <div class="timeline-dot"></div>
<div class="timeline-content"> <div class="timeline-content">
<div class="text-[#FF7BAC] text-[16PX]">
{{
$t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGFOREFF").split(":")[0]
}}
</div>
<n-h3 class="timeline-year">{{ <n-h3 class="timeline-year">{{
$t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGFOREFF") $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGFOREFF").split(":")[1]
}}</n-h3> }}</n-h3>
<br /> <br />
@ -124,8 +166,13 @@
<div class="timeline-item" v-motion-slide-visible-once-bottom> <div class="timeline-item" v-motion-slide-visible-once-bottom>
<div class="timeline-dot"></div> <div class="timeline-dot"></div>
<div class="timeline-content"> <div class="timeline-content">
<div class="text-[#FF7BAC] text-[16PX]">
{{
$t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGFIVE").split(":")[0]
}}
</div>
<n-h3 class="timeline-year">{{ <n-h3 class="timeline-year">{{
$t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGFIVE") $t("COMPANYOVERVIEW.TITLEFOUR.SUBHEADINGFIVE").split(":")[1]
}}</n-h3> }}</n-h3>
<br /> <br />
@ -156,21 +203,71 @@
</div> </div>
</div> </div>
</section> </section>
</div>
<!-- 成就部分 -->
<!-- 成就部分 --> <section
<section class="mission-section"> class="mission-section overflow-hidden relative z-99"
<h1 class="section-title"> style="
width: 100vw;
/* padding: 0 40px; */
/* margin-top: 40px; */
background: linear-gradient(180deg, #e5ffff 0%, #fff8fb 100%);
"
>
<div
style="height: 200px; width: 311px"
class="m-[auto] my-[64px] flex flex-col items-center text-center"
>
<h1 class="text-[22PX]">
{{ $t("COMPANYOVERVIEW.TITLEFIVE.TITLE") }} {{ $t("COMPANYOVERVIEW.TITLEFIVE.TITLE") }}
</h1> </h1>
<div class="mission-cards"> <!-- <div class="mission-cards">
<n-card hoverable class="mission-card" v-motion-pop> <n-card hoverable class="mission-card" v-motion-pop>
<n-p style="font-size: 18px" class="card-content">{{ <n-p style="font-size: 18px" class="card-content">{{
$t("COMPANYOVERVIEW.TITLEFIVE.CONTENT") $t("COMPANYOVERVIEW.TITLEFIVE.CONTENT")
}}</n-p> }}</n-p>
</n-card> </n-card>
</div> -->
<div class="w-100% flex items-center justify-between">
<!-- <div class="flex items-center">
<div
class="bg-[#ffffff] rounded-[50%] flex justify-center items-center mr-[8px]"
>
<img
src="@/assets/image/content/left.png"
alt=""
class="w-[94PX] h-[94PX]"
/>
</div>
<img
src="@/assets/image/content/arrowhead_left.png"
alt=""
class="w-[95px]"
/>
</div> -->
<p style="font-size: 14px;" class="my-0 text-[#455363]">
{{ $t("COMPANYOVERVIEW.TITLEFIVE.CONTENT").replace("•", "") }}
</p>
<!-- <div class="flex items-center">
<img
src="@/assets/image/content/arrowhead_right.png"
alt=""
class="w-[95px]"
/>
<div
class="bg-[#ffffff] rounded-[50%] flex justify-center items-center ml-[8px]"
>
<img
src="@/assets/image/content/right.png"
alt=""
class="w-[94PX] h-[94PX]"
/>
</div>
</div> -->
</div> </div>
</section> </div>
</div> </section>
</div> </div>
</template> </template>
@ -187,15 +284,19 @@ const stats = ref([
]); ]);
</script> </script>
<style scoped> <style scoped lang="scss">
.home-page { .home-page {
background-size: 100% 100%; background-size: 100% 100%;
background-position: center; background-position: center;
background-repeat: no-repeat; background-repeat: no-repeat;
} }
.company-overview { .company-overview {
width: 343PX;
margin: 0 auto; margin: 0 auto;
padding: 0 20px; padding: 0 10px;
z-index: 99;
position: relative;
/* padding: 0 20px; */
} }
/* 顶部大图区域 */ /* 顶部大图区域 */
@ -223,24 +324,26 @@ const stats = ref([
/* 通用部分样式 */ /* 通用部分样式 */
.section { .section {
margin-bottom: 80px; margin-bottom: 30px;
} }
.section-title { .section-title {
font-size: 2.5rem; font-size: 1.9rem;
margin-bottom: 30px; margin-bottom: 30px;
position: relative; position: relative;
display: inline-block; display: inline-block;
} }
.section-title:after { .section-title::before {
content: ""; content: "";
position: absolute; position: absolute;
bottom: -10px; top: -10px;
bottom: 0;
left: 0; left: 0;
width: 60px; width: 60PX;
height: 4px; height: 4PX;
background: linear-gradient(to right, #00ffff, #ff7bac); // background: linear-gradient(to right, #00ffff, #ff7bac);
background-color: #ff7bac;
border-radius: 2px; border-radius: 2px;
} }
@ -253,7 +356,8 @@ const stats = ref([
/* 使命愿景卡片 */ /* 使命愿景卡片 */
.mission-section { .mission-section {
margin: 80px 0; // margin: 80px 0;
// margin-top: 160px;
} }
.mission-cards { .mission-cards {
@ -265,7 +369,7 @@ const stats = ref([
.mission-card { .mission-card {
background: white; background: white;
padding: 40px 30px; padding: 40px 30px;
border-radius: 12px; border-radius: 12PX;
box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08); box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
transition: transform 0.3s ease, box-shadow 0.3s ease; transition: transform 0.3s ease, box-shadow 0.3s ease;
} }
@ -291,16 +395,18 @@ const stats = ref([
position: relative; position: relative;
padding-left: 50px; padding-left: 50px;
margin-top: 50px; margin-top: 50px;
transform: translateX(-20px);
} }
.timeline:before { .timeline:before {
content: ""; content: "";
position: absolute; position: absolute;
top: 0; top: 2%;
left: 20px; left: 10px;
height: 100%; height: 100%;
width: 4px; width: 2px;
background: linear-gradient(to bottom, #00ffff, #ff7bac); /* background: linear-gradient(to bottom, #00ffff, #ff7bac); */
background: #ff7bac;
} }
.timeline-item { .timeline-item {
@ -308,12 +414,25 @@ const stats = ref([
margin-bottom: 50px; margin-bottom: 50px;
} }
.timeline-item {
&:last-child:before {
content: "";
position: absolute;
top: 2%;
left: -40px;
height: 110%;
width: 2px;
/* background: linear-gradient(to bottom, #00ffff, #ff7bac); */
background: #E6EAEE;
}
}
.timeline-dot { .timeline-dot {
position: absolute; position: absolute;
left: -50px; left: -17PX;
top: 5px; top: 5PX;
width: 40px; width: 15PX;
height: 40px; height: 15PX;
border-radius: 50%; border-radius: 50%;
background: #ff7bac; background: #ff7bac;
display: flex; display: flex;
@ -321,18 +440,21 @@ const stats = ref([
justify-content: center; justify-content: center;
color: white; color: white;
font-weight: bold; font-weight: bold;
box-shadow: 0 0 0 6px rgba(255, 123, 172, 0.2); box-shadow: 0 0 0 7px rgba(255, 123, 172, 0.2);
} }
.timeline-year { .timeline-year {
font-size: 1.4rem; font-size: 1.4rem;
margin-bottom: 15px; margin-bottom: 15px;
color: #1a2a6c; color: #000;
font-weight: 500;
} }
.timeline-desc { .timeline-desc {
font-size: 1.05rem; font-size: 16PX !important;
line-height: 1.7; line-height: 1.7;
color: #455363;
margin-bottom: 10px; margin-bottom: 10px;
} }
@ -390,30 +512,30 @@ const stats = ref([
/* 响应式设计 */ /* 响应式设计 */
@media (max-width: 768px) { @media (max-width: 768px) {
.hero-title { // .hero-title {
font-size: 2.5rem; // font-size: 2.5rem;
} // }
.hero-subtitle { // .hero-subtitle {
font-size: 1.2rem; // font-size: 1.2rem;
} // }
.section-title { // .section-title {
font-size: 1.8rem; // font-size: 1.8rem;
} // }
.timeline { // .timeline {
padding-left: 30px; // padding-left: 30px;
} // }
.timeline-dot { // .timeline-dot {
left: -30px; // left: -30px;
width: 30px; // // width: 30px;
height: 30px; // // height: 30px;
} // }
.achievement-section { // .achievement-section {
padding: 40px 20px; // padding: 40px 20px;
} // }
} }
</style> </style>

View File

@ -11,7 +11,7 @@
<img <img
src="@/assets/image/content/bg_10.png" src="@/assets/image/content/bg_10.png"
alt="" alt=""
class="w-[100vw] absolute top-[-90px]" class="w-[100vw] absolute h-[720PX] top-[-90px]"
/> />
<img <img
src="@/assets/image/content/bg_11.png" src="@/assets/image/content/bg_11.png"

View File

@ -1,42 +1,72 @@
<template> <template>
<div class="home-page"> <div class="home-page relative overflow-hidden z-10 bg-[#ffffff]">
<div class=""> <div
class="fixed h-[100vh] left-[50%] translate-x-[-50%] z-1"
style="width: 920px; pointer-events: none; mix-blend-mode: multiply"
>
<img src="@/assets/image/content/line.png" class="w-[100%]" alt="" />
</div>
<div class="w-[100%] h-[570PX] z-[] top-0 absolute">
<div class="relative w-[100%] h-[100%]">
<img
src="@/assets/image/content/bg_21.png"
alt=""
class="w-[100vw] h-[570PX] absolute"
/>
<img
src="@/assets/image/content/flower.png"
alt=""
class="w-[1174PX] h-[446PX] absolute z-10 left-[50%] translate-x-[-50%]"
/>
<img
src="@/assets/image/content/bg_22.png"
alt=""
class="w-[100vw] h-[80PX] absolute bottom-0 lef-0 right-0 z-10"
/>
</div>
</div>
<div class="relative z-10">
<!-- 标题区 --> <!-- 标题区 -->
<div class="company-overview"> <div class="company-overview w-[900PX] pb-[130PX] !mt-[50PX]">
<div class="hero-section"> <div class="hero-section">
<transition name="fade-up" appear> <!-- <transition name="fade-up" appear> -->
<n-h1 class="hero-title" <n-h1 class="hero-title text-[40PX] min-h-[168PX]"
>FiEE, Inc. has a team of capable senior management with extensive >FiEE, Inc. has a team of capable senior management with extensive
professional experience</n-h1 professional experience</n-h1
> >
</transition> <!-- </transition> -->
</div> </div>
</div> </div>
<!-- 管理团队列表 --> <!-- 管理团队列表 -->
<main class="container"> <main class="container w-[900PX] relative z-11">
<div class="leadership-grid"> <div class="leadership-grid">
<!-- 每个高管卡片 --> <!-- 每个高管卡片 -->
<div <div
v-for="(leader, index) in leadershipTeam" v-for="(leader, index) in leadershipTeam"
:key="index" :key="index"
class="leader-card" class="leader-card mt-[20PX]"
:style="{ '--delay': index * 0.2 + 's' }" :style="{ '--delay': index * 0.2 + 's' }"
> >
<!-- 卡片上半部 --> <div>
<div class="card-profile"> <div class="flex items-center">
<div class="avatar-wrapper"> <div
<div class="decorative-dot"></div> class="w-[58PX] h-[58PX] rounded-[50%] bg-[#FF7BAC] text-[#fff] flex justify-center items-center text-[20PX] font-600"
<div class="initials">{{ getInitials(leader.name) }}</div> >
</div> {{ getInitials(leader.name) }}
<div class="profile-info"> </div>
<h2 class="leader-name">{{ leader.name }}</h2> <div class="flex flex-col justify-between ml-[12PX]">
<p class="leader-position">{{ leader.position }}</p> <h2 class="my-0">{{ leader.name }}</h2>
<div class="text-[#FF7BAC] text-[16PX]">
{{ leader.position }}
</div>
</div>
</div> </div>
</div> </div>
<!-- 卡片下半部 --> <!-- 卡片下半部 -->
<div class="card-content"> <div>
<div <div
class="content-section" class="content-section"
v-for="(content, cIndex) in leader.content" v-for="(content, cIndex) in leader.content"
@ -90,19 +120,19 @@ const getInitials = (name) => {
background-repeat: no-repeat; background-repeat: no-repeat;
} }
.company-overview { .company-overview {
max-width: 1200px; /* width: 900PX; */
margin: 0 auto; margin: 0 auto;
padding: 0 20px; /* padding: 0 20px; */
color: var(--text-color); color: var(--text-color);
} }
/* 顶部大图区域 */ /* 顶部大图区域 */
.hero-section { .hero-section {
background: linear-gradient(135deg, #00ffff, #b21f1f, #ff7bac); /* background: linear-gradient(135deg, #00ffff, #b21f1f, #ff7bac); */
background-size: 400% 400%; background-size: 400% 400%;
animation: gradientBG 15s ease infinite; /* animation: gradientBG 15s ease infinite; */
color: white; color: #000;
padding: 120px 0; padding: 120PX 0;
text-align: center; text-align: center;
border-radius: 8px; border-radius: 8px;
} }
@ -119,7 +149,7 @@ const getInitials = (name) => {
} }
} }
.hero-title { .hero-title {
font-size: 40px; /* font-size: 40px; */
margin-bottom: 20px; margin-bottom: 20px;
font-weight: 700; font-weight: 700;
} }
@ -130,9 +160,9 @@ const getInitials = (name) => {
} }
/* 基础样式 */ /* 基础样式 */
.container { .container {
max-width: 1200px; /* max-width: 1200px; */
margin: 0 auto; margin: 0 auto;
padding: 0 2rem; /* padding: 0 2rem; */
} }
/* 标题区 */ /* 标题区 */
@ -155,17 +185,17 @@ const getInitials = (name) => {
/* 管理团队网格 */ /* 管理团队网格 */
.leadership-grid { .leadership-grid {
display: grid; /* display: grid;
grid-template-columns: repeat(auto-fit, minmax(350px, 1fr)); grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
gap: 2rem; gap: 2rem;
padding: 4rem 0; padding: 4rem 0; */
} }
/* 高管卡片 */ /* 高管卡片 */
.leader-card { .leader-card {
background: white; /* background: white; */
border-radius: 20px; border-radius: 20px;
box-shadow: 0 12px 24px rgba(0, 0, 0, 0.06); /* box-shadow: 0 12px 24px rgba(0, 0, 0, 0.06); */
overflow: hidden; overflow: hidden;
transform: translateY(20px); transform: translateY(20px);
opacity: 0; opacity: 0;
@ -236,11 +266,11 @@ const getInitials = (name) => {
/* 内容区 */ /* 内容区 */
.card-content { .card-content {
padding: 2rem; /* padding: 2rem; */
} }
.content-section { .content-section {
margin-bottom: 1.5rem; /* margin-bottom: 1.5rem; */
} }
.content-section p { .content-section p {

View File

@ -1,42 +1,72 @@
<template> <template>
<div class="home-page"> <div class="home-page relative overflow-hidden z-10 bg-[#ffffff]">
<div class=""> <div
class="fixed h-[100vh] left-[50%] translate-x-[-50%] z-1"
style="width: 920px; pointer-events: none; mix-blend-mode: multiply"
>
<img src="@/assets/image/content/line.png" class="w-[100%]" alt="" />
</div>
<div class="w-[100%] h-[570PX] z-[] top-0 absolute">
<div class="relative w-[100%] h-[100%]">
<img
src="@/assets/image/content/bg_21.png"
alt=""
class="w-[100vw] h-[570PX] absolute"
/>
<img
src="@/assets/image/content/flower.png"
alt=""
class="w-[1174PX] h-[446PX] absolute z-10 left-[50%] translate-x-[-50%]"
/>
<img
src="@/assets/image/content/bg_22.png"
alt=""
class="w-[100vw] h-[80PX] absolute bottom-0 lef-0 right-0 z-10"
/>
</div>
</div>
<div class="relative z-10">
<!-- 标题区 --> <!-- 标题区 -->
<div class="company-overview"> <div class="company-overview w-[900PX] pb-[130PX] !mt-[50PX]">
<div class="hero-section"> <div class="hero-section">
<transition name="fade-up" appear> <!-- <transition name="fade-up" appear> -->
<n-h1 class="hero-title" <n-h1 class="hero-title text-[40PX] min-h-[168PX]"
>FiEE, Inc. has a team of capable senior management with extensive >FiEE, Inc. has a team of capable senior management with extensive
professional experience</n-h1 professional experience</n-h1
> >
</transition> <!-- </transition> -->
</div> </div>
</div> </div>
<!-- 管理团队列表 --> <!-- 管理团队列表 -->
<main class="container"> <main class="container w-[900PX] relative z-11">
<div class="leadership-grid"> <div class="leadership-grid">
<!-- 每个高管卡片 --> <!-- 每个高管卡片 -->
<div <div
v-for="(leader, index) in leadershipTeam" v-for="(leader, index) in leadershipTeam"
:key="index" :key="index"
class="leader-card" class="leader-card mt-[20PX]"
:style="{ '--delay': index * 0.2 + 's' }" :style="{ '--delay': index * 0.2 + 's' }"
> >
<!-- 卡片上半部 --> <div>
<div class="card-profile"> <div class="flex items-center">
<div class="avatar-wrapper"> <div
<div class="decorative-dot"></div> class="w-[58PX] h-[58PX] rounded-[50%] bg-[#FF7BAC] text-[#fff] flex justify-center items-center text-[20PX] font-600"
<div class="initials">{{ getInitials(leader.name) }}</div> >
</div> {{ getInitials(leader.name) }}
<div class="profile-info"> </div>
<h2 class="leader-name">{{ leader.name }}</h2> <div class="flex flex-col justify-between ml-[12PX]">
<p class="leader-position">{{ leader.position }}</p> <h2 class="my-0">{{ leader.name }}</h2>
<div class="text-[#FF7BAC] text-[16PX]">
{{ leader.position }}
</div>
</div>
</div> </div>
</div> </div>
<!-- 卡片下半部 --> <!-- 卡片下半部 -->
<div class="card-content"> <div>
<div <div
class="content-section" class="content-section"
v-for="(content, cIndex) in leader.content" v-for="(content, cIndex) in leader.content"
@ -90,19 +120,19 @@ const getInitials = (name) => {
background-repeat: no-repeat; background-repeat: no-repeat;
} }
.company-overview { .company-overview {
max-width: 1200px; /* width: 900PX; */
margin: 0 auto; margin: 0 auto;
padding: 0 20px; /* padding: 0 20px; */
color: var(--text-color); color: var(--text-color);
} }
/* 顶部大图区域 */ /* 顶部大图区域 */
.hero-section { .hero-section {
background: linear-gradient(135deg, #00ffff, #b21f1f, #ff7bac); /* background: linear-gradient(135deg, #00ffff, #b21f1f, #ff7bac); */
background-size: 400% 400%; background-size: 400% 400%;
animation: gradientBG 15s ease infinite; /* animation: gradientBG 15s ease infinite; */
color: white; color: #000;
padding: 120px 0; padding: 120PX 0;
text-align: center; text-align: center;
border-radius: 8px; border-radius: 8px;
} }
@ -119,7 +149,7 @@ const getInitials = (name) => {
} }
} }
.hero-title { .hero-title {
font-size: 40px; /* font-size: 40px; */
margin-bottom: 20px; margin-bottom: 20px;
font-weight: 700; font-weight: 700;
} }
@ -130,9 +160,9 @@ const getInitials = (name) => {
} }
/* 基础样式 */ /* 基础样式 */
.container { .container {
max-width: 1200px; /* max-width: 1200px; */
margin: 0 auto; margin: 0 auto;
padding: 0 2rem; /* padding: 0 2rem; */
} }
/* 标题区 */ /* 标题区 */
@ -155,17 +185,17 @@ const getInitials = (name) => {
/* 管理团队网格 */ /* 管理团队网格 */
.leadership-grid { .leadership-grid {
display: grid; /* display: grid;
grid-template-columns: repeat(auto-fit, minmax(350px, 1fr)); grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
gap: 2rem; gap: 2rem;
padding: 4rem 0; padding: 4rem 0; */
} }
/* 高管卡片 */ /* 高管卡片 */
.leader-card { .leader-card {
background: white; /* background: white; */
border-radius: 20px; border-radius: 20px;
box-shadow: 0 12px 24px rgba(0, 0, 0, 0.06); /* box-shadow: 0 12px 24px rgba(0, 0, 0, 0.06); */
overflow: hidden; overflow: hidden;
transform: translateY(20px); transform: translateY(20px);
opacity: 0; opacity: 0;
@ -236,11 +266,11 @@ const getInitials = (name) => {
/* 内容区 */ /* 内容区 */
.card-content { .card-content {
padding: 2rem; /* padding: 2rem; */
} }
.content-section { .content-section {
margin-bottom: 1.5rem; /* margin-bottom: 1.5rem; */
} }
.content-section p { .content-section p {

View File

@ -1,38 +1,72 @@
<template> <template>
<div class="home-page"> <div class="home-page relative overflow-hidden z-10 bg-[#ffffff]">
<div class=""> <div
class="fixed h-[100vh] left-[50%] translate-x-[-50%] z-1"
style="width: 320px; pointer-events: none; mix-blend-mode: multiply"
>
<img src="@/assets/image/content/line.png" class="w-[100%]" alt="" />
</div>
<div class="w-[100%] h-[680PX] z-[] top-0 absolute">
<div class="relative w-[100%] h-[100%]">
<img
src="@/assets/image/content/bg_23.png"
alt=""
class="w-[100vw] h-[711PX] absolute top-[-50PX]"
/>
<img
src="@/assets/image/content/flower375.png"
alt=""
class="w-[374PX] h-[142PX] absolute z-10 left-[50%] translate-x-[-50%] top-[50%] translate-y-[-50%]"
/>
<img
src="@/assets/image/content/bg_22.png"
alt=""
class="w-[100vw] h-[80PX] absolute bottom-0 lef-0 right-0 z-10"
/>
</div>
</div>
<div class="relative z-10">
<!-- 标题区 --> <!-- 标题区 -->
<div class="company-overview"> <div class="company-overview w-[311PX] pb-[160PX] !mt-[150PX]">
<div class="hero-section"> <div class="hero-section">
<transition name="fade-up" appear> <!-- <transition name="fade-up" appear> -->
<n-h1 class="hero-title" <n-h1 class="hero-title text-[24PX] min-h-[168PX]"
>FiEE, Inc. has a team of capable senior management with extensive >FiEE, Inc. has a team of capable senior management with extensive
professional experience</n-h1 professional experience</n-h1
> >
</transition> <!-- </transition> -->
</div> </div>
</div> </div>
<!-- 管理团队列表 --> <!-- 管理团队列表 -->
<main class="container"> <main class="container w-[311PX] relative z-11">
<div class="leadership-grid"> <div class="leadership-grid">
<!-- 每个高管卡片 --> <!-- 每个高管卡片 -->
<div <div
v-for="(leader, index) in leadershipTeam" v-for="(leader, index) in leadershipTeam"
:key="index" :key="index"
class="leader-card" class="leader-card mt-[20PX]"
:style="{ '--delay': index * 0.2 + 's' }" :style="{ '--delay': index * 0.2 + 's' }"
> >
<!-- 卡片上半部 --> <div>
<div class="card-profile"> <div class="flex items-center">
<div class="profile-info"> <div
<h2 class="leader-name">{{ leader.name }}</h2> class="w-[58PX] h-[58PX] rounded-[50%] bg-[#FF7BAC] text-[#fff] flex justify-center items-center text-[20PX] font-600 flex-shrink-0"
<p class="leader-position">{{ leader.position }}</p> >
{{ getInitials(leader.name) }}
</div>
<div class="flex flex-col justify-between ml-[12PX]">
<h2 class="my-0">{{ leader.name }}</h2>
<div class="text-[#FF7BAC] text-[16PX]">
{{ leader.position }}
</div>
</div>
</div> </div>
</div> </div>
<!-- 卡片下半部 --> <!-- 卡片下半部 -->
<div class="card-content"> <div>
<div <div
class="content-section" class="content-section"
v-for="(content, cIndex) in leader.content" v-for="(content, cIndex) in leader.content"
@ -80,36 +114,28 @@ const getInitials = (name) => {
</script> </script>
<style scoped> <style scoped>
:root {
--text-color: #333;
--primary-color: #895bff;
}
.home-page { .home-page {
background-size: cover; background-size: 100% 100%;
background-position: center; background-position: center;
background-repeat: no-repeat; background-repeat: no-repeat;
} }
.company-overview { .company-overview {
max-width: 100%; /* width: 900PX; */
margin: 0 auto; margin: 0 auto;
padding: 0 1rem; /* padding: 0 20px; */
color: var(--text-color); color: var(--text-color);
} }
/* 顶部大图区域 */ /* 顶部大图区域 */
.hero-section { .hero-section {
background: linear-gradient(135deg, #00ffff, #b21f1f, #ff7bac); /* background: linear-gradient(135deg, #00ffff, #b21f1f, #ff7bac); */
background-size: 400% 400%; background-size: 400% 400%;
animation: gradientBG 15s ease infinite; /* animation: gradientBG 15s ease infinite; */
color: white; color: #000;
padding: 80px 20px; padding: 120PX 0;
text-align: center; text-align: center;
margin: 2rem 0 3rem;
border-radius: 8px; border-radius: 8px;
} }
/* 动画 */ /* 动画 */
@keyframes gradientBG { @keyframes gradientBG {
0% { 0% {
@ -122,45 +148,60 @@ const getInitials = (name) => {
background-position: 0% 50%; background-position: 0% 50%;
} }
} }
.hero-title { .hero-title {
font-size: clamp(1.5rem, 4vw, 2.5rem); /* font-size: 40px; */
margin-bottom: 1rem; margin-bottom: 20px;
font-weight: 700; font-weight: 700;
line-height: 1.3;
} }
.hero-subtitle { .hero-subtitle {
font-size: clamp(1rem, 2vw, 1.5rem); font-size: 1.5rem;
opacity: 0.9; opacity: 0.9;
} }
/* 基础样式 */ /* 基础样式 */
.container { .container {
/* max-width: 1200px; */
margin: 0 auto; margin: 0 auto;
padding: 0 1rem; /* padding: 0 2rem; */
}
/* 标题区 */
.leadership-header {
background: linear-gradient(135deg, #f9fbfe 0%, #e8f2ff 100%);
padding: 6rem 0 4rem;
text-align: center;
}
.page-title {
font-size: 2.5rem;
color: #2c3e50;
margin-bottom: 1rem;
}
.page-subtitle {
color: #6b7c93;
font-size: 1.1rem;
} }
/* 管理团队网格 */ /* 管理团队网格 */
.leadership-grid { .leadership-grid {
display: grid; /* display: grid;
grid-template-columns: 1fr; grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
gap: 1.5rem; gap: 2rem;
padding: 2rem 0; padding: 4rem 0; */
} }
/* 高管卡片 */ /* 高管卡片 */
.leader-card { .leader-card {
background: white; /* background: white; */
border-radius: 16px; border-radius: 20px;
box-shadow: 0 8px 20px rgba(0, 0, 0, 0.08); /* box-shadow: 0 12px 24px rgba(0, 0, 0, 0.06); */
overflow: hidden; overflow: hidden;
transform: translateY(20px); transform: translateY(20px);
opacity: 0; opacity: 0;
animation: cardEnter 0.6s ease forwards; animation: cardEnter 0.6s ease forwards;
animation-delay: var(--delay); animation-delay: var(--delay);
transition: transform 0.3s ease; transition: transform 0.3s ease;
margin: 0;
} }
.leader-card:hover { .leader-card:hover {
@ -169,7 +210,7 @@ const getInitials = (name) => {
/* 个人资料区 */ /* 个人资料区 */
.card-profile { .card-profile {
padding: 1.5rem; padding: 2rem;
/* background: linear-gradient( /* background: linear-gradient(
135deg, 135deg,
#7a4dff 0%, #7a4dff 0%,
@ -181,19 +222,19 @@ const getInitials = (name) => {
.avatar-wrapper { .avatar-wrapper {
position: relative; position: relative;
width: 60px; width: 80px;
height: 60px; height: 80px;
margin-bottom: 1rem; margin-bottom: 1.5rem;
} }
.decorative-dot { .decorative-dot {
position: absolute; position: absolute;
width: 16px; width: 20px;
height: 16px; height: 20px;
background: #ffbfd7; background: #ffbfd7;
border-radius: 50%; border-radius: 50%;
top: -8px; top: -10px;
right: -8px; right: -10px;
} }
.initials { .initials {
@ -204,7 +245,7 @@ const getInitials = (name) => {
display: flex; display: flex;
align-items: center; align-items: center;
justify-content: center; justify-content: center;
font-size: 1.5rem; font-size: 1.8rem;
font-weight: bold; font-weight: bold;
color: #ff7bac; color: #ff7bac;
} }
@ -214,28 +255,28 @@ const getInitials = (name) => {
} }
.leader-name { .leader-name {
font-size: 1.3rem; font-size: 1.6rem;
margin-bottom: 0.3rem; margin-bottom: 0.5rem;
} }
.leader-position { .leader-position {
font-size: 0.9rem; font-size: 1rem;
opacity: 0.9; opacity: 0.9;
} }
/* 内容区 */ /* 内容区 */
.card-content { .card-content {
padding: 1.5rem; /* padding: 2rem; */
} }
.content-section { .content-section {
margin-bottom: 1rem; /* margin-bottom: 1.5rem; */
} }
.content-section p { .content-section p {
color: #5a6d80; color: #5a6d80;
line-height: 1.6; line-height: 1.7;
font-size: 0.9rem; font-size: 0.95rem;
} }
/* 动画 */ /* 动画 */
@ -246,77 +287,15 @@ const getInitials = (name) => {
} }
} }
/* 响应式设计 - 中屏幕 */ /* 响应式 */
@media (min-width: 768px) { @media (max-width: 768px) {
.company-overview {
padding: 0 2rem;
}
.hero-section {
padding: 100px 0;
margin: 3rem 0 4rem;
}
.hero-title {
font-size: 2.5rem;
}
.leadership-grid { .leadership-grid {
grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); grid-template-columns: 1fr;
gap: 2rem;
padding: 3rem 0;
} }
.leader-card { .leader-card {
border-radius: 20px; margin: 0 1rem;
}
.card-profile {
padding: 2rem;
}
.avatar-wrapper {
width: 80px;
height: 80px;
margin-bottom: 1.5rem;
}
.decorative-dot {
width: 20px;
height: 20px;
top: -10px;
right: -10px;
}
.initials {
font-size: 1.8rem;
}
.leader-name {
font-size: 1.6rem;
}
.leader-position {
font-size: 1rem;
}
.card-content {
padding: 2rem;
}
.content-section {
margin-bottom: 1.5rem;
}
.content-section p {
font-size: 0.95rem;
}
}
/* 响应式设计 - 大屏幕 */
@media (min-width: 1024px) {
.leadership-grid {
grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
} }
} }
</style> </style>

View File

@ -1,42 +1,72 @@
<template> <template>
<div class="home-page"> <div class="home-page relative overflow-hidden z-10 bg-[#ffffff]">
<div class=""> <div
class="fixed h-[100vh] left-[50%] translate-x-[-50%] z-1"
style="width: 620px; pointer-events: none; mix-blend-mode: multiply"
>
<img src="@/assets/image/content/line.png" class="w-[100%]" alt="" />
</div>
<div class="w-[100%] h-[550PX] z-[] top-0 absolute">
<div class="relative w-[100%] h-[100%]">
<img
src="@/assets/image/content/bg_24.png"
alt=""
class="w-[100vw] h-[570PX] absolute top-[-50PX]"
/>
<img
src="@/assets/image/content/flower.png"
alt=""
class="w-[1174PX] h-[446PX] absolute z-10 left-[50%] translate-x-[-50%]"
/>
<img
src="@/assets/image/content/bg_22.png"
alt=""
class="w-[100vw] h-[80PX] absolute bottom-0 lef-0 right-0 z-10"
/>
</div>
</div>
<div class="relative z-10">
<!-- 标题区 --> <!-- 标题区 -->
<div class="company-overview"> <div class="company-overview w-[600PX] pb-[160PX] !mt-[50PX]">
<div class="hero-section"> <div class="hero-section">
<transition name="fade-up" appear> <!-- <transition name="fade-up" appear> -->
<n-h1 class="hero-title" <n-h1 class="hero-title text-[32PX] min-h-[168PX]"
>FiEE, Inc. has a team of capable senior management with extensive >FiEE, Inc. has a team of capable senior management with extensive
professional experience</n-h1 professional experience</n-h1
> >
</transition> <!-- </transition> -->
</div> </div>
</div> </div>
<!-- 管理团队列表 --> <!-- 管理团队列表 -->
<main class="container"> <main class="container w-[600PX] relative z-11">
<div class="leadership-grid"> <div class="leadership-grid">
<!-- 每个高管卡片 --> <!-- 每个高管卡片 -->
<div <div
v-for="(leader, index) in leadershipTeam" v-for="(leader, index) in leadershipTeam"
:key="index" :key="index"
class="leader-card" class="leader-card mt-[20PX]"
:style="{ '--delay': index * 0.2 + 's' }" :style="{ '--delay': index * 0.2 + 's' }"
> >
<!-- 卡片上半部 --> <div>
<div class="card-profile"> <div class="flex items-center">
<div class="avatar-wrapper"> <div
<div class="decorative-dot"></div> class="w-[58PX] h-[58PX] rounded-[50%] bg-[#FF7BAC] text-[#fff] flex justify-center items-center text-[20PX] font-600"
<div class="initials">{{ getInitials(leader.name) }}</div> >
</div> {{ getInitials(leader.name) }}
<div class="profile-info"> </div>
<h2 class="leader-name">{{ leader.name }}</h2> <div class="flex flex-col justify-between ml-[12PX]">
<p class="leader-position">{{ leader.position }}</p> <h2 class="my-0">{{ leader.name }}</h2>
<div class="text-[#FF7BAC] text-[16PX]">
{{ leader.position }}
</div>
</div>
</div> </div>
</div> </div>
<!-- 卡片下半部 --> <!-- 卡片下半部 -->
<div class="card-content"> <div>
<div <div
class="content-section" class="content-section"
v-for="(content, cIndex) in leader.content" v-for="(content, cIndex) in leader.content"
@ -84,36 +114,28 @@ const getInitials = (name) => {
</script> </script>
<style scoped> <style scoped>
:root {
--text-color: #333;
--primary-color: #895bff;
}
.home-page { .home-page {
background-size: cover; background-size: 100% 100%;
background-position: center; background-position: center;
background-repeat: no-repeat; background-repeat: no-repeat;
} }
.company-overview { .company-overview {
max-width: 100%; /* width: 900PX; */
margin: 0 auto; margin: 0 auto;
padding: 0 1rem; /* padding: 0 20px; */
color: var(--text-color); color: var(--text-color);
} }
/* 顶部大图区域 */ /* 顶部大图区域 */
.hero-section { .hero-section {
background: linear-gradient(135deg, #00ffff, #b21f1f, #ff7bac); /* background: linear-gradient(135deg, #00ffff, #b21f1f, #ff7bac); */
background-size: 400% 400%; background-size: 400% 400%;
animation: gradientBG 15s ease infinite; /* animation: gradientBG 15s ease infinite; */
color: white; color: #000;
padding: 80px 20px; padding: 120PX 0;
text-align: center; text-align: center;
margin: 2rem 0 3rem;
border-radius: 8px; border-radius: 8px;
} }
/* 动画 */ /* 动画 */
@keyframes gradientBG { @keyframes gradientBG {
0% { 0% {
@ -126,56 +148,69 @@ const getInitials = (name) => {
background-position: 0% 50%; background-position: 0% 50%;
} }
} }
.hero-title { .hero-title {
font-size: clamp(1.5rem, 4vw, 2.5rem); /* font-size: 40px; */
margin-bottom: 1rem; margin-bottom: 20px;
font-weight: 700; font-weight: 700;
line-height: 1.3;
} }
.hero-subtitle { .hero-subtitle {
font-size: clamp(1rem, 2vw, 1.5rem); font-size: 1.5rem;
opacity: 0.9; opacity: 0.9;
} }
/* 基础样式 */ /* 基础样式 */
.container { .container {
max-width: 1200px; /* max-width: 1200px; */
margin: 0 auto; margin: 0 auto;
padding: 0 1rem; /* padding: 0 2rem; */
}
/* 标题区 */
.leadership-header {
background: linear-gradient(135deg, #f9fbfe 0%, #e8f2ff 100%);
padding: 6rem 0 4rem;
text-align: center;
}
.page-title {
font-size: 2.5rem;
color: #2c3e50;
margin-bottom: 1rem;
}
.page-subtitle {
color: #6b7c93;
font-size: 1.1rem;
} }
/* 管理团队网格 */ /* 管理团队网格 */
.leadership-grid { .leadership-grid {
display: grid; /* display: grid;
grid-template-columns: 1fr; grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
gap: 1.5rem; gap: 2rem;
padding: 2rem 0; padding: 4rem 0; */
} }
/* 高管卡片 */ /* 高管卡片 */
.leader-card { .leader-card {
background: white; /* background: white; */
border-radius: 16px; border-radius: 20px;
box-shadow: 0 8px 20px rgba(0, 0, 0, 0.08); /* box-shadow: 0 12px 24px rgba(0, 0, 0, 0.06); */
overflow: hidden; overflow: hidden;
transform: translateY(20px); transform: translateY(20px);
opacity: 0; opacity: 0;
animation: cardEnter 0.6s ease forwards; animation: cardEnter 0.6s ease forwards;
animation-delay: var(--delay); animation-delay: var(--delay);
transition: transform 0.3s ease; transition: transform 0.3s ease;
margin: 0;
} }
.leader-card:hover { .leader-card:hover {
transform: translateY(-5px); transform: translateY(-5px);
} }
/* 个人资料区 */
/* 个人资料区 */ /* 个人资料区 */
.card-profile { .card-profile {
padding: 1.5rem; padding: 2rem;
/* background: linear-gradient( /* background: linear-gradient(
135deg, 135deg,
#7a4dff 0%, #7a4dff 0%,
@ -187,19 +222,19 @@ const getInitials = (name) => {
.avatar-wrapper { .avatar-wrapper {
position: relative; position: relative;
width: 60px; width: 80px;
height: 60px; height: 80px;
margin-bottom: 1rem; margin-bottom: 1.5rem;
} }
.decorative-dot { .decorative-dot {
position: absolute; position: absolute;
width: 16px; width: 20px;
height: 16px; height: 20px;
background: #ffbfd7; background: #ffbfd7;
border-radius: 50%; border-radius: 50%;
top: -8px; top: -10px;
right: -8px; right: -10px;
} }
.initials { .initials {
@ -210,7 +245,7 @@ const getInitials = (name) => {
display: flex; display: flex;
align-items: center; align-items: center;
justify-content: center; justify-content: center;
font-size: 1.5rem; font-size: 1.8rem;
font-weight: bold; font-weight: bold;
color: #ff7bac; color: #ff7bac;
} }
@ -220,28 +255,28 @@ const getInitials = (name) => {
} }
.leader-name { .leader-name {
font-size: 1.3rem; font-size: 1.6rem;
margin-bottom: 0.3rem; margin-bottom: 0.5rem;
} }
.leader-position { .leader-position {
font-size: 0.9rem; font-size: 1rem;
opacity: 0.9; opacity: 0.9;
} }
/* 内容区 */ /* 内容区 */
.card-content { .card-content {
padding: 1.5rem; /* padding: 2rem; */
} }
.content-section { .content-section {
margin-bottom: 1rem; /* margin-bottom: 1.5rem; */
} }
.content-section p { .content-section p {
color: #5a6d80; color: #5a6d80;
line-height: 1.6; line-height: 1.7;
font-size: 0.9rem; font-size: 0.95rem;
} }
/* 动画 */ /* 动画 */
@ -252,77 +287,14 @@ const getInitials = (name) => {
} }
} }
/* 响应式设计 - 中屏幕 */ /* 响应式 */
@media (min-width: 768px) { @media (max-width: 768px) {
.company-overview {
padding: 0 2rem;
}
.hero-section {
padding: 100px 0;
margin: 3rem 0 4rem;
}
.hero-title {
font-size: 2.5rem;
}
.leadership-grid { .leadership-grid {
grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); grid-template-columns: 1fr;
gap: 2rem;
padding: 3rem 0;
} }
.leader-card { .leader-card {
border-radius: 20px; margin: 0 1rem;
}
.card-profile {
padding: 2rem;
}
.avatar-wrapper {
width: 80px;
height: 80px;
margin-bottom: 1.5rem;
}
.decorative-dot {
width: 20px;
height: 20px;
top: -10px;
right: -10px;
}
.initials {
font-size: 1.8rem;
}
.leader-name {
font-size: 1.6rem;
}
.leader-position {
font-size: 1rem;
}
.card-content {
padding: 2rem;
}
.content-section {
margin-bottom: 1.5rem;
}
.content-section p {
font-size: 0.95rem;
}
}
/* 响应式设计 - 大屏幕 */
@media (min-width: 1024px) {
.leadership-grid {
grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
} }
} }
</style> </style>

View File

@ -6,7 +6,7 @@
> >
<img src="@/assets/image/content/line.png" class="w-[100%]" alt="" /> <img src="@/assets/image/content/line.png" class="w-[100%]" alt="" />
</div> </div>
<div class="w-[100%] h-[916px] z-[] top-0 absolute"> <div class="w-[100%] h-[916PX] z-[] top-0 absolute">
<div class="relative w-[100%] h-[100%]"> <div class="relative w-[100%] h-[100%]">
<img <img
src="@/assets/image/content/bg_1.png" src="@/assets/image/content/bg_1.png"
@ -22,7 +22,7 @@
</div> </div>
<section <section
class="company-overview h-[916px]" class="company-overview h-[916px]"
style="max-width: 900px; margin: 0 auto; padding: 0; padding-top: 190px" style="width: 900px; margin: 0 auto; padding: 0; padding-top: 190px"
> >
<div class="hero-section"> <div class="hero-section">
<transition name="fade-up" appear> <transition name="fade-up" appear>
@ -43,7 +43,7 @@
<!-- 公司概况 --> <!-- 公司概况 -->
<section <section
class="company-overview" class="company-overview"
style="max-width: 900px; margin: 0 auto; padding: 0" style="width: 900px; margin: 0 auto; padding: 0"
> >
<h3 class="section-title">{{ $t("COMPANYOVERVIEW.TITLETWO.TITLE") }}</h3> <h3 class="section-title">{{ $t("COMPANYOVERVIEW.TITLETWO.TITLE") }}</h3>
<h1 class="section-titles">Company Profile</h1> <h1 class="section-titles">Company Profile</h1>

View File

@ -1,17 +1,29 @@
<template> <template>
<div class="home-page"> <div class="home-page relative overflow-hidden z-10 bg-[#ffffff]">
<section <div class="fixed h-[100vh] left-[50%] translate-x-[-50%] z-1"
class="company-overview" style="width: 343px; pointer-events: none; mix-blend-mode: multiply">
style="max-width: 1200px; margin: 60px auto; padding: 0 40px" <img src="@/assets/image/content/line.png" class="w-[100%]" alt="" />
> </div>
<div class="w-[100%] h-[800PX] z-[] top-0 absolute">
<div class="relative w-[100%] h-[100%]">
<img src="@/assets/image/content/bg_15.png" alt="" class="w-[100vw] h-[813PX] absolute" />
<img src="@/assets/image/content/bg_4.png" alt=""
class="w-[204PX] h-[140PX] absolute top-[189PX] left-[50%] translate-x-[-50%]" />
<img src="@/assets/image/content/bg_5.png" alt=""
class="w-[100vw] absolute bottom-[-80PX] lef-0 right-0 z-99" />
</div>
</div>
<section class="company-overview" style="
max-width: 311px;
margin: 0 auto;
padding: 0;
padding-top: 320px;
height: 790px;
">
<div class="hero-section"> <div class="hero-section">
<transition name="fade-up" appear> <transition name="fade-up" appear>
<n-h1 class="hero-title"> <n-h1 class="hero-title">
<div <div class="content-blocks" :class="{ 'slide-in': isInView }" ref="contentRef">
class="content-blocks"
:class="{ 'slide-in': isInView }"
ref="contentRef"
>
<text>{{ $t("HOME.CONTAIN.TITLEONE.CONTENT") }}</text> <text>{{ $t("HOME.CONTAIN.TITLEONE.CONTENT") }}</text>
<p>{{ $t("HOME.CONTAIN.TITLEONE.CONTENTTWO") }}</p> <p>{{ $t("HOME.CONTAIN.TITLEONE.CONTENTTWO") }}</p>
</div> </div>
@ -21,218 +33,164 @@
</section> </section>
<!-- 公司概况 --> <!-- 公司概况 -->
<section <section class="company-overview" style="max-width: 311px; margin: 0 auto; padding: 0;margin-top: 100px;">
class="company-overview"
style="max-width: 1200px; margin: 60px auto; padding: 0 40px"
>
<h1 class="section-titles">Company Profile</h1>
<h3 class="section-title">{{ $t("COMPANYOVERVIEW.TITLETWO.TITLE") }}</h3> <h3 class="section-title">{{ $t("COMPANYOVERVIEW.TITLETWO.TITLE") }}</h3>
<div class="content-block"> <h1 class="section-titles">Company Profile</h1>
<div class="content-block text-[#455363]">
<p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENT") }}</p> <p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENT") }}</p>
<p> <p>
<text style="color: black">{{ <text class="text-[#455363]">{{
$t("COMPANYOVERVIEW.TITLETWO.CONTENTTWOTITLE") $t("COMPANYOVERVIEW.TITLETWO.CONTENTTWOTITLE")
}}</text> }}</text>
{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENTTWO") }} {{ $t("COMPANYOVERVIEW.TITLETWO.CONTENTTWO") }}
</p> </p>
<p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENTTHREE") }}</p> <p>{{ $t("COMPANYOVERVIEW.TITLETWO.CONTENTTHREE") }}</p>
</div> </div>
<n-carousel autoplay>
<img src="@/assets/image/content/profile_1.png" alt="" class="w-[201PX] h-[201PX] mx-auto" />
<img src="@/assets/image/content/profile_2.png" alt="" class="w-[201PX] h-[201PX] mx-auto" />
<img src="@/assets/image/content/profile_3.png" alt="" class="w-[201PX] h-[201PX] mx-auto" />
<img src="@/assets/image/content/profile_4.png" alt="" class="w-[201PX] h-[201PX] mx-auto" />
<template #dots="{ total, currentIndex, to }">
<ul class="custom-dots">
<li v-for="index of total" :key="index" :class="{ ['is-active']: currentIndex === index - 1 }"
@click="to(index - 1)" />
</ul>
</template>
</n-carousel>
</section> </section>
<!-- 突出成就 --> <!-- 突出成就 -->
<section <section class="achievements overflow-hidden z-99 relative" style="
class="achievements" width: 100vw;
style="
max-width: 1200px;
margin: 60px auto;
padding: 0 40px; padding: 0 40px;
background: #fff; margin-top: 40px;
" background: linear-gradient(180deg, #e5ffff 0%, #fff8fb 100%);
> ">
<h2 class="section-titles"> <div style="max-width: 311px; height: 306px; padding: 64px 0"
{{ $t("COMPANYOVERVIEW.TITLEFIVE.TITLE") }} class="m-[auto] flex flex-col items-center text-center">
</h2> <h2 class="section-titles">
<p style="font-size: 18px"> {{ $t("COMPANYOVERVIEW.TITLEFIVE.TITLE") }}
{{ $t("COMPANYOVERVIEW.TITLEFIVE.CONTENT").replace("•", "") }} </h2>
</p> <div class="w-100% flex items-center justify-between">
</section> <p style="font-size: 14px" class="my-0 text-[#455363]">
<!-- 新闻模块 --> {{ $t("COMPANYOVERVIEW.TITLEFIVE.CONTENT").replace("•", "") }}
<section </p>
class="news-section"
style="max-width: 1200px; margin: 60px auto; padding: 0 40px"
>
<h2 class="section-titles">{{ $t("HOME.CONTAINY.NEWS.TITLE") }}</h2>
<div class="news-card">
<div style="margin-bottom: 20px" v-for="(item, index) in newList">
<div
style="
display: flex;
align-items: center;
justify-content: space-between;
"
>
<div>
<div style="font-size: 18px">{{ item.time }}</div>
<n-tooltip
trigger="click"
:disabled="!item.showTooltip"
width="trigger"
>
<template #trigger>
<div
:ref="(el) => setTitleRef(el, index)"
style="
font-size: 18px;
word-break: break-word;
display: -webkit-box;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;
overflow: hidden;
text-overflow: ellipsis;
"
>
{{ item.title }}
</div>
</template>
<div slot="content">
{{ item.title }}
</div>
</n-tooltip>
</div>
<div
style="font-size: 18px; flex-shrink: 0; margin: 0 0 0 0.6rem"
class="cursor-pointer"
@click="handleLink(item)"
>
View Press Release<img
class="ml-[10px]"
src="@/assets/image/icon/icon-new.png"
alt=""
style="width: 20px; height: 20px"
/>
</div>
</div>
</div>
<div
v-if="newList.length === 0"
class="flex justify-center items-center"
>
<img
src="@/assets/image/icon/default-empty.png"
alt="empty"
style="width: 109px; height: 60px"
/>
</div> </div>
</div> </div>
</section> </section>
<!-- 新闻模块 -->
<section class="news-section relative z-99" style="width: 311px; margin: 60px auto">
<div class="flex justify-between mb-[10PX]">
<h2 class="section-titles section-titles1">
{{ $t("HOME.CONTAINY.NEWS.TITLE") }}
</h2>
<div v-if="totalPages > 1">
<!-- 左右切换按钮 -->
<img v-if="currentPage === 0" disabled class="w-[38PX] h-[38PX]" src="@/assets/image/content/switch_right.png"
alt="" />
<img v-else @click="prevPage" src="@/assets/image/content/switch_left.png"
class="transform rotate-180 w-[38PX] h-[38PX] cursor-pointer" alt="" />
<img v-if="currentPage >= totalPages - 1" class="transform rotate-180 w-[38PX] h-[38PX] ml-[20PX]" disabled
src="@/assets/image/content/switch_right.png" alt="" />
<img v-else @click="nextPage" class="w-[38PX] h-[38PX] ml-[20PX] cursor-pointer"
src="@/assets/image/content/switch_left.png" alt="" />
</div>
</div>
<!-- Grid 布局容器 -->
<div class="grid grid-cols-1 gap-4">
<template v-for="(item, index) in pages" :key="index">
<div style="height: 232px" class="news-card flex flex-col justify-between">
<div class="text-[24PX] font-600">{{ item.time }}</div>
<n-tooltip trigger="hover" :disabled="!item.showTooltip" width="trigger">
<template #trigger>
<div :ref="(el) => setTitleRef(el, index)" style="
word-break: break-word;
display: -webkit-box;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;
overflow: hidden;
text-overflow: ellipsis;
" class="text-[16PX] text-[#455363]">
{{ item.title }}
</div>
</template>
<div slot="content" class="text-[16PX] text-[#455363]">
{{ item.title }}
</div>
</n-tooltip>
<div class="text-[16PX] text-[#FF7BAC] font-500 flex items-center cursor-pointer"
@click="handleLink(item)">
View Press Release
<img src="@/assets/image/content/vector.png" alt="" class="ml-[10PX] w-[6.5PX] h-[13PX]" />
</div>
</div>
</template>
</div>
</section>
<!-- 新增股票信息与活动预告双栏模块 --> <!-- 新增股票信息与活动预告双栏模块 -->
<section <section class="dual-column-section bg-[url('@/assets/image/content/bg_16.png')]" style="
class="dual-column-section" width: 100vw;
style="max-width: 1200px; margin: 60px auto; padding: 0 40px" height: 570px;
> margin: 60px auto;
<div class="grid-container"> background-size: 100% 100%;
border-radius: 15PX 15PX 0 0;
background-color: #e7407e;
">
<div style="width: 343px" class="m-auto">
<!-- 股票信息卡片 --> <!-- 股票信息卡片 -->
<div class="info-card stock-card"> <div class="">
<h2 class="card-title">{{ $t("HOME.CONTAINY.STOCK_INFO.TITLE") }}</h2> <h2 class="card-title mx-[15PX]">{{ $t("HOME.CONTAINY.STOCK_INFO.TITLE") }}</h2>
<div class="stock-data"> <div class="stock-data">
<div class="data-row"> <div class="data-row">
<span style="font-size: 18px" class="data-label"> Time </span> <span class="data-label"> Time </span>
<span style="font-size: 18px" class="data-value">{{ <span class="data-value">{{ sampleDate }}</span>
formatted
}}</span>
</div> </div>
<div class="data-row"> <div class="data-row">
<span style="font-size: 18px" class="data-label">{{ <span class="data-label">{{
$t("HOME.CONTAINY.STOCK_INFO.LAST_PRICE") $t("HOME.CONTAINY.STOCK_INFO.LAST_PRICE")
}}</span> }}</span>
<span style="font-size: 18px" class="data-value" <span class="data-value">${{ stockQuote.price }}</span>
>${{ stockQuote.price }}</span
>
</div> </div>
<div class="data-row"> <div class="data-row">
<span style="font-size: 18px" class="data-label">{{ <span class="data-label">{{
$t("HOME.CONTAINY.STOCK_INFO.CHANGE") $t("HOME.CONTAINY.STOCK_INFO.CHANGE")
}}</span> }}</span>
<span <span class="data-value">{{ stockQuote.change || "--" }}</span>
style="font-size: 18px"
class="data-value"
:class="
stockQuote.change?.includes('-')
? 'text-green-500'
: 'text-red-500'
"
>{{ stockQuote.change || "--" }}</span
>
</div> </div>
<div class="data-row"> <div class="data-row">
<span style="font-size: 18px" class="data-label">{{ <span class="data-label">{{
$t("HOME.CONTAINY.STOCK_INFO.STOCK_CODE") $t("HOME.CONTAINY.STOCK_INFO.STOCK_CODE")
}}</span> }}</span>
<span style="font-size: 18px" class="data-value" <span class="data-value">NASDAQ: FIEE</span>
>NASDAQ: FIEE</span
>
</div> </div>
<div class="data-row"> <div class="data-row">
<span style="font-size: 18px" class="data-label">{{ <span class="data-label">{{
$t("HOME.CONTAINY.STOCK_INFO.VOLUME") $t("HOME.CONTAINY.STOCK_INFO.VOLUME")
}}</span> }}</span>
<span style="font-size: 18px" class="data-value">{{ <span class="data-value">{{ stockQuote.volume }}</span>
stockQuote.volume
}}</span>
</div> </div>
<div class="data-row"> <div class="data-row">
<span style="font-size: 18px" class="data-label">{{ <span class="data-label">{{
$t("HOME.CONTAINY.STOCK_INFO.MARKET_CAP") $t("HOME.CONTAINY.STOCK_INFO.MARKET_CAP")
}}</span> }}</span>
<span style="font-size: 18px" class="data-value" <span class="data-value">${{ stockQuote.marketCap }}</span>
>${{ stockQuote.marketCap }}</span
>
</div> </div>
</div> </div>
</div> </div>
</div>
<!-- 活动预告卡片 --> </section>
<div class="info-card events-card"> <section class="dual-column-section" style="width: 100vw; height: 300px; margin: 60px auto; padding: 0 40px">
<h2 class="card-title"> <div class="w-[311PX] m-auto">
<div class="">
<h2 class="card-title1">
{{ $t("HOME.CONTAINY.UPCOMING_EVENTS.TITLE") }} {{ $t("HOME.CONTAINY.UPCOMING_EVENTS.TITLE") }}
</h2> </h2>
<div class="event-item"> <div class="event-item">
<!-- <h3 class="event-name"> <img src="@/assets/image/content/empty.png" alt="" class="w-[100%] h-[151PX]" />
{{ $t("HOME.CONTAINY.UPCOMING_EVENTS.EVENT_NAME") }}
</h3> -->
<!-- <div class="event-detail">
<div class="detail-row">
<i class="icon-calendar"></i>
<span
>{{ $t("HOME.CONTAINY.UPCOMING_EVENTS.DATE") }}:
2025年8月12日()-2025年8月14日</span
>
</div>
<div class="detail-row">
<i class="icon-location"></i>
<span
>{{ $t("HOME.CONTAINY.UPCOMING_EVENTS.VENUE") }}:
6号馆B厅</span
>
</div>
<div class="detail-row">
<i class="icon-area"></i>
<span
>{{ $t("HOME.CONTAINY.UPCOMING_EVENTS.AREA") }}:
约10,000</span
>
</div>
<div class="detail-row">
<i class="icon-booth"></i>
<span
>{{ $t("HOME.CONTAINY.UPCOMING_EVENTS.BOOTHS") }}:
约500个标准展位</span
>
</div>
</div> -->
</div> </div>
</div> </div>
</div> </div>
@ -247,11 +205,48 @@ import { useI18n } from "vue-i18n";
import { useStockQuote } from "@/store/stock-quote/index.js"; import { useStockQuote } from "@/store/stock-quote/index.js";
import axios from "axios"; import axios from "axios";
const { getStockQuate, stockQuote, formatted } = useStockQuote(); const { getStockQuate, stockQuote, formatted } = useStockQuote();
import { NCarousel, NDivider, NMarquee, NPopselect } from "naive-ui";
import { ArrowBack, ArrowForward } from '@vicons/ionicons5'
// - 26
const itemsPerPage = 6;
//
const currentPage = ref(0);
//
const totalPages = computed(() => {
return Math.ceil(newList.value.length / itemsPerPage);
});
// 6
const pages = computed(() => {
// 使slice6
const limitedItems = newList.value.slice(
currentPage.value * itemsPerPage,
(currentPage.value + 1) * itemsPerPage
);
return limitedItems;
});
//
const prevPage = () => {
if (currentPage.value > 0) {
currentPage.value--;
}
};
//
const nextPage = () => {
if (currentPage.value < totalPages.value - 1) {
currentPage.value++;
}
};
getStockQuate(); getStockQuate();
const { t: $t } = useI18n(); //
const contentRef = ref(null); const sampleDate = ref(formatted);
const isInView = ref(false);
let observer = null;
const newList = ref([ const newList = ref([
// { // {
// time: "June 3, 2025", // time: "June 3, 2025",
@ -291,6 +286,10 @@ const getPressReleasesDisplay = () => {
}); });
}; };
const { t: $t } = useI18n();
const contentRef = ref(null);
const isInView = ref(false);
let observer = null;
onMounted(() => { onMounted(() => {
if (contentRef.value && "IntersectionObserver" in window) { if (contentRef.value && "IntersectionObserver" in window) {
observer = new IntersectionObserver( observer = new IntersectionObserver(
@ -367,7 +366,73 @@ const handleLink = (item) => {
}; };
</script> </script>
<style scoped> <style scoped lang="scss">
.carousel-img {
width: 100%;
height: 240px;
object-fit: cover;
}
.custom-arrow {
display: flex;
position: absolute;
bottom: 25px;
right: 10px;
}
.custom-arrow button {
display: inline-flex;
align-items: center;
justify-content: center;
width: 28px;
height: 28px;
margin-right: 12px;
color: #fff;
background-color: rgba(255, 255, 255, 0.1);
border-width: 0;
border-radius: 8px;
transition: background-color 0.3s cubic-bezier(0.4, 0, 0.2, 1);
cursor: pointer;
}
.custom-arrow button:hover {
background-color: rgba(255, 255, 255, 0.2);
}
.custom-arrow button:active {
transform: scale(0.95);
transform-origin: center;
}
.custom-dots {
display: flex;
margin: 0;
padding: 0;
position: absolute;
bottom: 20px;
left: 50%;
transform: translateX(-50%);
}
.custom-dots li {
display: inline-block;
width: 8PX;
height: 8PX;
margin: 0 12px;
border-radius: 50%;
background-color: #EFEFEF;
transition:
width 0.3s,
background-color 0.3s cubic-bezier(0.4, 0, 0.2, 1);
cursor: pointer;
}
.custom-dots li.is-active {
border-radius: 20PX;
width: 40PX;
background: #DDDDDD;
}
.home-page { .home-page {
background-size: 100% 100%; background-size: 100% 100%;
background-position: center; background-position: center;
@ -381,11 +446,11 @@ const handleLink = (item) => {
} }
/* 顶部大图区域 */ /* 顶部大图区域 */
.hero-section { .hero-section {
background: linear-gradient(135deg, #00ffff, #b21f1f, #ff7bac); /* background: linear-gradient(135deg, #00ffff, #b21f1f, #ff7bac); */
background-size: 400% 400%; background-size: 400% 400%;
animation: gradientBG 15s ease infinite; /* animation: gradientBG 15s ease infinite; */
color: white; color: #000;
padding: 40px 20px; padding: 40px 0px;
text-align: left; text-align: left;
margin-bottom: 60px; margin-bottom: 60px;
border-radius: 8px; border-radius: 8px;
@ -404,7 +469,7 @@ const handleLink = (item) => {
} }
.banner-content { .banner-content {
text-align: center; text-align: center;
color: white; color: #000;
padding: 20px; padding: 20px;
background: rgba(0, 0, 0, 0.3); background: rgba(0, 0, 0, 0.3);
border-radius: 8px; border-radius: 8px;
@ -431,24 +496,34 @@ const handleLink = (item) => {
.section-title { .section-title {
font-size: 1.5rem; /* 18px */ font-size: 1.5rem; /* 18px */
margin-bottom: 30px; margin-bottom: 0;
color: #ff7bac; color: #ff7bac;
} }
.section-titles { .section-titles {
font-size: 2.5rem; font-size: 22PX;
margin-bottom: 30px; margin-bottom: 15px;
margin-top: 0;
color: black; color: black;
position: relative;
}
.section-titles1::after {
content: "";
position: absolute;
left: 0;
width: 60PX;
height: 4PX;
background: #ff7bac;
transform: translateY(-20px);
} }
.content-block { .content-block {
font-size: 1.1rem; font-size: 0.9rem;
line-height: 1.8; line-height: 1.8;
} }
.content-blocks { .content-blocks {
font-size: 2rem; font-size: 1.4rem;
color: #fff; color: #000;
font-weight: bold; font-weight: bold;
opacity: 0; opacity: 0;
transform: translateX(-200px); transform: translateX(-200px);
transition: opacity 0.6s ease-out, transform 0.6s ease-out; transition: opacity 0.6s ease-out, transform 0.6s ease-out;
@ -519,21 +594,39 @@ const handleLink = (item) => {
} }
.card-title { .card-title {
font-size: 2.5rem; font-size: 2rem;
margin-bottom: 25px; padding-top: 88px;
color: #333; color: #ffffff;
position: relative; position: relative;
padding-bottom: 10px; margin-bottom: 0;
} }
.card-title::after { .card-title::after {
content: ""; content: "";
position: absolute; position: absolute;
bottom: 0;
left: 0; left: 0;
width: 60px; width: 60PX;
height: 3px; height: 4PX;
background: linear-gradient(90deg, #121212, #232330); background: #ffffff;
transform: translateY(-20px);
}
.card-title1 {
font-size: 2rem;
padding-top: 88px;
color: #000;
position: relative;
margin-bottom: 0;
}
.card-title1::after {
content: "";
position: absolute;
left: 0;
width: 60PX;
height: 4PX;
background: #ff7bac;
transform: translateY(-20px);
} }
/* 股票信息卡片样式 */ /* 股票信息卡片样式 */
@ -547,20 +640,25 @@ const handleLink = (item) => {
.data-row { .data-row {
display: flex; display: flex;
justify-content: space-between; /* justify-content: space-between; */
padding: 12px 0; margin: 10PX;
border-bottom: 1px solid #f0f0f0; border-left: 2PX solid #00ffff;
transform: translateX(-10PX);
padding-left: 10PX;
font-size: 12PX;
color: #fff;
} }
.data-label { .data-label {
color: #666; // font-weight: 500;
font-weight: 500; width: 150PX;
font-size: 18px;
} }
.data-value { .data-value {
font-weight: 600; // font-weight: 600;
font-size: 18px; font-family: "PingFang SC";
letter-spacing: 0.48px;
} }
.positive { .positive {
@ -638,10 +736,10 @@ const handleLink = (item) => {
.news-card { .news-card {
background: white; background: white;
border-radius: 12px; border-radius: 12PX;
padding: 30px; padding: 30PX;
box-shadow: 0 5px 20px rgba(0, 0, 0, 0.05); box-shadow: 0 5px 20px rgba(0, 0, 0, 0.05);
border-left: 4px solid #ff7bac; border-top: 14PX solid #ff7bac;
} }
.news-date { .news-date {

View File

@ -1,5 +1,6 @@
import {defineConfig} from 'vite' import {defineConfig} from 'vite'
import vue from '@vitejs/plugin-vue' import vue from '@vitejs/plugin-vue'
import vueJsx from '@vitejs/plugin-vue-jsx'
import {resolve} from "path" import {resolve} from "path"
import AutoImport from 'unplugin-auto-import/vite'; import AutoImport from 'unplugin-auto-import/vite';
import Components from 'unplugin-vue-components/vite'; import Components from 'unplugin-vue-components/vite';
@ -39,6 +40,8 @@ export default defineConfig({
Components({ Components({
resolvers: [VantResolver()], resolvers: [VantResolver()],
}), }),
vueJsx(),
viteImagemin({ viteImagemin({
// 无损压缩配置 // 无损压缩配置
optipng: { optipng: {