mirror of
				https://github.com/Vomitblood/stort.git
				synced 2025-10-30 10:17:22 +08:00 
			
		
		
		
	added background image functionality
This commit is contained in:
		
							parent
							
								
									cb13e299c9
								
							
						
					
					
						commit
						d3c0919473
					
				
							
								
								
									
										
											BIN
										
									
								
								public/images/background.jpg
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								public/images/background.jpg
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 15 MiB | 
|  | @ -17,7 +17,7 @@ tauri-build = { version = "1.5.3", features = [] } | ||||||
| [dependencies] | [dependencies] | ||||||
| serde_json = "1.0" | serde_json = "1.0" | ||||||
| serde = { version = "1.0", features = ["derive"] } | serde = { version = "1.0", features = ["derive"] } | ||||||
| tauri = { version = "1.7.0", features = [ "fs-all", "path-all", "window-all", "process-all", "notification-all", "dialog-all"] } | tauri = { version = "1.7.0", features = [ "protocol-all", "fs-all", "path-all", "window-all", "process-all", "notification-all", "dialog-all"] } | ||||||
| 
 | 
 | ||||||
| [features] | [features] | ||||||
| # this feature is used for production builds or when `devPath` points to the filesystem and the built-in dev server is disabled. | # this feature is used for production builds or when `devPath` points to the filesystem and the built-in dev server is disabled. | ||||||
|  |  | ||||||
|  | @ -23,6 +23,9 @@ | ||||||
|       "fs": { |       "fs": { | ||||||
|         "all": true, |         "all": true, | ||||||
|         "scope": [ |         "scope": [ | ||||||
|  |           "**", | ||||||
|  |           "**/*", | ||||||
|  |           "/**/*", | ||||||
|           "$CONFIG/stort/", |           "$CONFIG/stort/", | ||||||
|           "$CONFIG/stort/**" |           "$CONFIG/stort/**" | ||||||
|         ] |         ] | ||||||
|  | @ -36,6 +39,15 @@ | ||||||
|       "process": { |       "process": { | ||||||
|         "all": true |         "all": true | ||||||
|       }, |       }, | ||||||
|  |       "protocol": { | ||||||
|  |         "all": true, | ||||||
|  |         "asset": true, | ||||||
|  |         "assetScope": [ | ||||||
|  |           "**", | ||||||
|  |           "**/*", | ||||||
|  |           "/**/*" | ||||||
|  |         ] | ||||||
|  |       }, | ||||||
|       "window": { |       "window": { | ||||||
|         "all": true |         "all": true | ||||||
|       } |       } | ||||||
|  | @ -65,7 +77,7 @@ | ||||||
|       ] |       ] | ||||||
|     }, |     }, | ||||||
|     "security": { |     "security": { | ||||||
|       "csp": null |       "csp": "default-src 'self'; img-src 'self' asset: https://asset.localhost" | ||||||
|     }, |     }, | ||||||
|     "updater": { |     "updater": { | ||||||
|       "active": false |       "active": false | ||||||
|  |  | ||||||
|  | @ -1,12 +1,25 @@ | ||||||
| import { Box } from "@mui/material"; | import { Box, Button } from "@mui/material"; | ||||||
|  | import { convertFileSrc } from "@tauri-apps/api/tauri"; | ||||||
|  | import { useState } from "react"; | ||||||
| import { FooterBar } from "../FooterBar"; | import { FooterBar } from "../FooterBar"; | ||||||
| import { HeaderBar } from "../HeaderBar/HeaderBar"; | import { HeaderBar } from "../HeaderBar/HeaderBar"; | ||||||
| 
 | 
 | ||||||
| export const Layout = () => { | export const Layout = () => { | ||||||
|  |   const [imageUrl, setImageUrl] = useState<string | null>(null); | ||||||
|  | 
 | ||||||
|  |   const setBackground = async () => { | ||||||
|  |     const assetUrl = convertFileSrc("/home/vomitblood/build/stort/public/images/background.jpg"); | ||||||
|  |     setImageUrl(assetUrl); | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|   return ( |   return ( | ||||||
|     <Box |     <Box | ||||||
|       sx={{ |       sx={{ | ||||||
|         // backgroundColor: "#8ab4f8",
 |         // Use the URL function for background images
 | ||||||
|  |         backgroundImage: `url(${imageUrl})`, | ||||||
|  |         backgroundSize: "cover", // Cover the entire area
 | ||||||
|  |         backgroundPosition: "center", // Center the image
 | ||||||
|  |         backgroundRepeat: "no-repeat", // Do not repeat the image
 | ||||||
|         display: "flex", |         display: "flex", | ||||||
|         flexDirection: "column", |         flexDirection: "column", | ||||||
|         height: "100vh", |         height: "100vh", | ||||||
|  | @ -20,38 +33,15 @@ export const Layout = () => { | ||||||
|           overflow: "auto", |           overflow: "auto", | ||||||
|         }} |         }} | ||||||
|       > |       > | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |         <Box> | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |           <Button | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |             onClick={() => { | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |               setBackground(); | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |             }} | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |           > | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |             set background | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |           </Button> | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |         </Box> | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |  | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |  | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |  | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |  | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |  | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |  | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |  | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |  | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |  | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |  | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |  | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |  | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |  | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |  | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |  | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |  | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |  | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |  | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |  | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |  | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |  | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |  | ||||||
|         kdfjdlfjdkfjdlfldkfj <br /> |  | ||||||
|       </Box> |       </Box> | ||||||
|       <FooterBar /> |       <FooterBar /> | ||||||
|     </Box> |     </Box> | ||||||
|  |  | ||||||
|  | @ -9,6 +9,7 @@ export const defaultSettings = { | ||||||
|     background_image_size: "cover" as string, |     background_image_size: "cover" as string, | ||||||
|     background_image_position: "center" as string, |     background_image_position: "center" as string, | ||||||
|     background_image_repeat: "no-repeat" as string, |     background_image_repeat: "no-repeat" as string, | ||||||
|  |     footer_background_color: "#8ab4f8" as string, | ||||||
|   }, |   }, | ||||||
|   style: { |   style: { | ||||||
|     accent_color: "#8ab4f8" as string, |     accent_color: "#8ab4f8" as string, | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue