tmp media stream fix
This commit is contained in:
		
							
								
								
									
										130
									
								
								src-tauri/Cargo.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										130
									
								
								src-tauri/Cargo.lock
									
									
									
										generated
									
									
									
								
							@ -332,7 +332,7 @@ checksum = "3b43422f69d8ff38f95f1b2bb76517c91589a924d1559a0e935d7c8ce0274c11"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -361,13 +361,13 @@ checksum = "fbb36e985947064623dbd357f727af08ffd077f93d696782f3c56365fa2e2799"
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
name = "async-trait"
 | 
			
		||||
version = "0.1.80"
 | 
			
		||||
version = "0.1.81"
 | 
			
		||||
source = "registry+https://github.com/rust-lang/crates.io-index"
 | 
			
		||||
checksum = "c6fa2087f2753a7da8cc1c0dbfcf89579dd57458e36769de5ac750b4671737ca"
 | 
			
		||||
checksum = "6e0c28dcc82d7c8ead5cb13beb15405b57b8546e93215673ff8ca0349a028107"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -407,7 +407,7 @@ checksum = "3c87f3f15e7794432337fc718554eaa4dc8f04c9677a950ffe366f20a162ae42"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -550,7 +550,7 @@ dependencies = [
 | 
			
		||||
 "proc-macro-crate 3.1.0",
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
 "syn_derive",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
@ -792,9 +792,9 @@ dependencies = [
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
name = "clap"
 | 
			
		||||
version = "4.5.7"
 | 
			
		||||
version = "4.5.9"
 | 
			
		||||
source = "registry+https://github.com/rust-lang/crates.io-index"
 | 
			
		||||
checksum = "5db83dced34638ad474f39f250d7fea9598bdd239eaced1bdf45d597da0f433f"
 | 
			
		||||
checksum = "64acc1846d54c1fe936a78dc189c34e28d3f5afc348403f28ecf53660b9b8462"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "clap_builder",
 | 
			
		||||
 "clap_derive",
 | 
			
		||||
@ -802,9 +802,9 @@ dependencies = [
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
name = "clap_builder"
 | 
			
		||||
version = "4.5.7"
 | 
			
		||||
version = "4.5.9"
 | 
			
		||||
source = "registry+https://github.com/rust-lang/crates.io-index"
 | 
			
		||||
checksum = "f7e204572485eb3fbf28f871612191521df159bc3e15a9f5064c66dba3a8c05f"
 | 
			
		||||
checksum = "6fb8393d67ba2e7bfaf28a23458e4e2b543cc73a99595511eb207fdb8aede942"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "anstream",
 | 
			
		||||
 "anstyle",
 | 
			
		||||
@ -816,14 +816,14 @@ dependencies = [
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
name = "clap_derive"
 | 
			
		||||
version = "4.5.5"
 | 
			
		||||
version = "4.5.8"
 | 
			
		||||
source = "registry+https://github.com/rust-lang/crates.io-index"
 | 
			
		||||
checksum = "c780290ccf4fb26629baa7a1081e68ced113f1d3ec302fa5948f1c381ebf06c6"
 | 
			
		||||
checksum = "2bac35c6dafb060fd4d275d9a4ffae97917c13a6327903a8be2153cd964f7085"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "heck 0.5.0",
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -1073,7 +1073,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
 | 
			
		||||
checksum = "13b588ba4ac1a99f7f2964d24b3d896ddc6bf847ee3855dbd4366f058cfcd331"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -1083,7 +1083,7 @@ source = "registry+https://github.com/rust-lang/crates.io-index"
 | 
			
		||||
checksum = "edb49164822f3ee45b17acd4a208cfc1251410cf0cad9a833234c9890774dd9f"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -1107,7 +1107,7 @@ dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "strsim 0.10.0",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -1118,7 +1118,7 @@ checksum = "a668eda54683121533a393014d8692171709ff57a7d61f187b6e782719f8933f"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "darling_core",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -1179,7 +1179,7 @@ checksum = "4078275de501a61ceb9e759d37bdd3d7210e654dbc167ac1a3678ef4435ed57b"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
 "synstructure",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
@ -1216,7 +1216,7 @@ dependencies = [
 | 
			
		||||
 "regex",
 | 
			
		||||
 "serde",
 | 
			
		||||
 "serde_tokenstream",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -1227,7 +1227,7 @@ checksum = "67e77553c4162a157adbf834ebae5b415acbecbeafc7a74b0e886657506a7611"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -1288,7 +1288,7 @@ checksum = "487585f4d0c6655fe74905e2504d8ad6908e4db67f744eb140876906c2f3175d"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -1320,7 +1320,7 @@ checksum = "f2b99bf03862d7f545ebc28ddd33a665b50865f4dfd84031a393823879bd4c54"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -1427,7 +1427,7 @@ checksum = "5c785274071b1b420972453b306eeca06acf4633829db4223b58a2a8c5953bc4"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -1588,7 +1588,7 @@ checksum = "1a5c6c585bc94aaf2c7b51dd4c2ba22680844aba4c687be581871a6f518c5742"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -1704,7 +1704,7 @@ checksum = "87750cf4b7a4c0625b1529e4c543c2182106e4dedc60a2a6455e00d212c489ac"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -1980,7 +1980,7 @@ dependencies = [
 | 
			
		||||
 "proc-macro-error",
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -2008,7 +2008,7 @@ dependencies = [
 | 
			
		||||
 "inflections",
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -2083,7 +2083,7 @@ dependencies = [
 | 
			
		||||
 "proc-macro-error",
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -2571,7 +2571,7 @@ dependencies = [
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
name = "kcl-lib"
 | 
			
		||||
version = "0.1.70"
 | 
			
		||||
version = "0.1.72"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "anyhow",
 | 
			
		||||
 "approx",
 | 
			
		||||
@ -3377,7 +3377,7 @@ dependencies = [
 | 
			
		||||
 "regex",
 | 
			
		||||
 "regex-syntax 0.8.3",
 | 
			
		||||
 "structmeta",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -3496,7 +3496,7 @@ dependencies = [
 | 
			
		||||
 "phf_shared 0.11.2",
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -3564,7 +3564,7 @@ checksum = "2f38a4412a78282e09a2cf38d195ea5420d15ba0602cb375210efbc877243965"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -4438,7 +4438,7 @@ dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "serde_derive_internals",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -4523,9 +4523,9 @@ dependencies = [
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
name = "serde"
 | 
			
		||||
version = "1.0.203"
 | 
			
		||||
version = "1.0.204"
 | 
			
		||||
source = "registry+https://github.com/rust-lang/crates.io-index"
 | 
			
		||||
checksum = "7253ab4de971e72fb7be983802300c30b5a7f0c2e56fab8abfc6a214307c0094"
 | 
			
		||||
checksum = "bc76f558e0cbb2a839d37354c575f1dc3fdc6546b5be373ba43d95f231bf7c12"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "serde_derive",
 | 
			
		||||
]
 | 
			
		||||
@ -4552,13 +4552,13 @@ dependencies = [
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
name = "serde_derive"
 | 
			
		||||
version = "1.0.203"
 | 
			
		||||
version = "1.0.204"
 | 
			
		||||
source = "registry+https://github.com/rust-lang/crates.io-index"
 | 
			
		||||
checksum = "500cbc0ebeb6f46627f50f3f5811ccf6bf00643be300b4c3eabc0ef55dc5b5ba"
 | 
			
		||||
checksum = "e0cd7e117be63d3c3678776753929474f3b04a43a080c744d6b0ae2a8c28e222"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -4569,7 +4569,7 @@ checksum = "330f01ce65a3a5fe59a60c82f3c9a024b573b8a6e875bd233fe5f934e71d54e3"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -4602,7 +4602,7 @@ checksum = "6c64451ba24fc7a6a2d60fc75dd9c83c90903b19028d4eff35e88fc1e86564e9"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -4623,7 +4623,7 @@ dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "serde",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -4665,7 +4665,7 @@ dependencies = [
 | 
			
		||||
 "darling",
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -4933,7 +4933,7 @@ dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "structmeta-derive",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -4944,7 +4944,7 @@ checksum = "152a0b65a590ff6c3da95cabe2353ee04e6167c896b28e3b14478c2636c922fc"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -4966,7 +4966,7 @@ dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "rustversion",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -4999,9 +4999,9 @@ dependencies = [
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
name = "syn"
 | 
			
		||||
version = "2.0.68"
 | 
			
		||||
version = "2.0.70"
 | 
			
		||||
source = "registry+https://github.com/rust-lang/crates.io-index"
 | 
			
		||||
checksum = "901fa70d88b9d6c98022e23b4136f9f3e54e4662c3bc1bd1d84a42a9a0f0c1e9"
 | 
			
		||||
checksum = "2f0209b68b3613b093e0ec905354eccaedcfe83b8cb37cbdeae64026c3064c16"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
@ -5017,7 +5017,7 @@ dependencies = [
 | 
			
		||||
 "proc-macro-error",
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -5034,7 +5034,7 @@ checksum = "c8af7666ab7b6390ab78131fb5b0fce11d6b7a6951602017c35fa82800708971"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -5251,7 +5251,7 @@ dependencies = [
 | 
			
		||||
 "serde",
 | 
			
		||||
 "serde_json",
 | 
			
		||||
 "sha2",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
 "tauri-utils",
 | 
			
		||||
 "thiserror",
 | 
			
		||||
 "time",
 | 
			
		||||
@ -5269,7 +5269,7 @@ dependencies = [
 | 
			
		||||
 "heck 0.5.0",
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
 "tauri-codegen",
 | 
			
		||||
 "tauri-utils",
 | 
			
		||||
]
 | 
			
		||||
@ -5642,7 +5642,7 @@ checksum = "46c3384250002a6d5af4d114f2845d37b57521033f30d5c3f46c4d70e1197533"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -5740,7 +5740,7 @@ checksum = "5f5ae998a069d4b5aba8ee9dad856af7d520c3699e6159b185c2acd48155d39a"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -5940,7 +5940,7 @@ checksum = "84fd902d4e0b9a4b27f2f440108dc034e1758628a9b702f8ec61ad66355422fa"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -5969,7 +5969,7 @@ checksum = "34704c8d6ebcbc939824180af020566b01a7c01f80641264eba0999f6c2b6be7"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -6099,7 +6099,7 @@ checksum = "c88cc88fd23b5a04528f3a8436024f20010a16ec18eb23c164b1242f65860130"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
 "termcolor",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
@ -6280,9 +6280,9 @@ checksum = "711b9620af191e0cdc7468a8d14e709c3dcdb115b36f838e601583af800a370a"
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
name = "uuid"
 | 
			
		||||
version = "1.9.1"
 | 
			
		||||
version = "1.10.0"
 | 
			
		||||
source = "registry+https://github.com/rust-lang/crates.io-index"
 | 
			
		||||
checksum = "5de17fd2f7da591098415cff336e12965a28061ddace43b59cb3c430179c9439"
 | 
			
		||||
checksum = "81dfa00651efa65069b0b6b651f4aaa31ba9e3c3ce0137aaad053604ee7e0314"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "getrandom 0.2.14",
 | 
			
		||||
 "serde",
 | 
			
		||||
@ -6316,7 +6316,7 @@ dependencies = [
 | 
			
		||||
 "proc-macro-error",
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -6415,7 +6415,7 @@ dependencies = [
 | 
			
		||||
 "once_cell",
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
 "wasm-bindgen-shared",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
@ -6449,7 +6449,7 @@ checksum = "e94f17b526d0a461a191c78ea52bbce64071ed5c04c9ffe424dcb38f74171bb7"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
 "wasm-bindgen-backend",
 | 
			
		||||
 "wasm-bindgen-shared",
 | 
			
		||||
]
 | 
			
		||||
@ -6590,7 +6590,7 @@ checksum = "ac1345798ecd8122468840bcdf1b95e5dc6d2206c5e4b0eafa078d061f59c9bc"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -6696,7 +6696,7 @@ checksum = "9107ddc059d5b6fbfbffdfa7a7fe3e22a226def0b2608f72e9d552763d3e1ad7"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -6707,7 +6707,7 @@ checksum = "29bee4b38ea3cde66011baa44dba677c432a78593e202392d1e9070cf2a7fca7"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
@ -7159,7 +7159,7 @@ checksum = "9ce1b18ccd8e73a9321186f97e46f9f04b778851177567b1975109d26a08d2a6"
 | 
			
		||||
dependencies = [
 | 
			
		||||
 "proc-macro2",
 | 
			
		||||
 "quote",
 | 
			
		||||
 "syn 2.0.68",
 | 
			
		||||
 "syn 2.0.70",
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
[[package]]
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										11
									
								
								src/App.tsx
									
									
									
									
									
								
							
							
						
						
									
										11
									
								
								src/App.tsx
									
									
									
									
									
								
							@ -26,6 +26,7 @@ import useHotkeyWrapper from 'lib/hotkeyWrapper'
 | 
			
		||||
import Gizmo from 'components/Gizmo'
 | 
			
		||||
import { CoreDumpManager } from 'lib/coredump'
 | 
			
		||||
import { UnitsMenu } from 'components/UnitsMenu'
 | 
			
		||||
import { useAppState } from 'AppState'
 | 
			
		||||
 | 
			
		||||
export function App() {
 | 
			
		||||
  useRefreshSettings(paths.FILE + 'SETTINGS')
 | 
			
		||||
@ -45,6 +46,8 @@ export function App() {
 | 
			
		||||
 | 
			
		||||
  useHotKeyListener()
 | 
			
		||||
  const { context } = useModelingContext()
 | 
			
		||||
  const { streamDimensions, didDragInStream, buttonDownInStream } =
 | 
			
		||||
    useAppState()
 | 
			
		||||
 | 
			
		||||
  const { auth, settings } = useSettingsAuthContext()
 | 
			
		||||
  const token = auth?.context?.token
 | 
			
		||||
@ -74,7 +77,7 @@ export function App() {
 | 
			
		||||
    (p) => p === onboardingStatus.current
 | 
			
		||||
  )
 | 
			
		||||
    ? 'opacity-20'
 | 
			
		||||
    : context.store?.didDragInStream
 | 
			
		||||
    : didDragInStream
 | 
			
		||||
    ? 'opacity-40'
 | 
			
		||||
    : ''
 | 
			
		||||
 | 
			
		||||
@ -92,11 +95,11 @@ export function App() {
 | 
			
		||||
      clientX: e.clientX,
 | 
			
		||||
      clientY: e.clientY,
 | 
			
		||||
      el: e.currentTarget,
 | 
			
		||||
      ...context.store?.streamDimensions,
 | 
			
		||||
      ...streamDimensions,
 | 
			
		||||
    })
 | 
			
		||||
 | 
			
		||||
    const newCmdId = uuidv4()
 | 
			
		||||
    if (context.store?.buttonDownInStream === undefined) {
 | 
			
		||||
    if (buttonDownInStream === undefined) {
 | 
			
		||||
      debounceSocketSend({
 | 
			
		||||
        type: 'modeling_cmd_req',
 | 
			
		||||
        cmd: {
 | 
			
		||||
@ -118,7 +121,7 @@ export function App() {
 | 
			
		||||
        className={
 | 
			
		||||
          'transition-opacity transition-duration-75 ' +
 | 
			
		||||
          paneOpacity +
 | 
			
		||||
          (context.store?.buttonDownInStream ? ' pointer-events-none' : '')
 | 
			
		||||
          (buttonDownInStream ? ' pointer-events-none' : '')
 | 
			
		||||
        }
 | 
			
		||||
        project={{ project, file }}
 | 
			
		||||
        enableMenu={true}
 | 
			
		||||
 | 
			
		||||
@ -1,4 +1,10 @@
 | 
			
		||||
import { createContext, useContext, useState, ReactNode } from 'react'
 | 
			
		||||
import {
 | 
			
		||||
  createContext,
 | 
			
		||||
  useContext,
 | 
			
		||||
  useState,
 | 
			
		||||
  ReactNode,
 | 
			
		||||
  useEffect,
 | 
			
		||||
} from 'react'
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 | 
			
		||||
@ -11,11 +17,23 @@ Please do not fill this up with junk.
 | 
			
		||||
interface AppState {
 | 
			
		||||
  isStreamReady: boolean
 | 
			
		||||
  setAppState: (newAppState: Partial<AppState>) => void
 | 
			
		||||
 | 
			
		||||
  mediaStream?: MediaStream
 | 
			
		||||
  buttonDownInStream: number | undefined
 | 
			
		||||
  didDragInStream: boolean
 | 
			
		||||
  streamDimensions: { streamWidth: number; streamHeight: number }
 | 
			
		||||
  // openPanes: SidebarType[]
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
const AppStateContext = createContext<AppState>({
 | 
			
		||||
  isStreamReady: false,
 | 
			
		||||
  setAppState: () => {},
 | 
			
		||||
 | 
			
		||||
  buttonDownInStream: undefined,
 | 
			
		||||
  didDragInStream: false,
 | 
			
		||||
  streamDimensions: { streamWidth: 1280, streamHeight: 720 },
 | 
			
		||||
  mediaStream: undefined,
 | 
			
		||||
  // openPanes: persistedContext.openPanes || ['code'],
 | 
			
		||||
})
 | 
			
		||||
 | 
			
		||||
export const useAppState = () => useContext(AppStateContext)
 | 
			
		||||
@ -24,15 +42,35 @@ export const AppStateProvider = ({ children }: { children: ReactNode }) => {
 | 
			
		||||
  const [appState, _setAppState] = useState<AppState>({
 | 
			
		||||
    isStreamReady: false,
 | 
			
		||||
    setAppState: () => {},
 | 
			
		||||
 | 
			
		||||
    buttonDownInStream: undefined,
 | 
			
		||||
    didDragInStream: false,
 | 
			
		||||
    streamDimensions: { streamWidth: 1280, streamHeight: 720 },
 | 
			
		||||
    mediaStream: undefined,
 | 
			
		||||
    // openPanes: persistedContext.openPanes || ['code'],
 | 
			
		||||
  })
 | 
			
		||||
  const setAppState = (newAppState: Partial<AppState>) =>
 | 
			
		||||
    _setAppState({ ...appState, ...newAppState })
 | 
			
		||||
  useEffect(() => {
 | 
			
		||||
    // console.log('appState change', appState)
 | 
			
		||||
  }, [appState])
 | 
			
		||||
  const setAppState = (newAppState: Partial<AppState>) => {
 | 
			
		||||
    // console.log('appstate', newAppState)
 | 
			
		||||
    _setAppState({
 | 
			
		||||
      ...appState,
 | 
			
		||||
      ...newAppState,
 | 
			
		||||
      mediaStream: newAppState.mediaStream || appState.mediaStream,
 | 
			
		||||
    })
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  return (
 | 
			
		||||
    <AppStateContext.Provider
 | 
			
		||||
      value={{
 | 
			
		||||
        isStreamReady: appState.isStreamReady,
 | 
			
		||||
        setAppState,
 | 
			
		||||
 | 
			
		||||
        mediaStream: appState.mediaStream,
 | 
			
		||||
        buttonDownInStream: appState.buttonDownInStream,
 | 
			
		||||
        didDragInStream: appState.didDragInStream,
 | 
			
		||||
        streamDimensions: appState.streamDimensions,
 | 
			
		||||
      }}
 | 
			
		||||
    >
 | 
			
		||||
      {children}
 | 
			
		||||
 | 
			
		||||
@ -49,17 +49,17 @@ const router = createBrowserRouter([
 | 
			
		||||
    /* Make sure auth is the outermost provider or else we will have
 | 
			
		||||
     * inefficient re-renders, use the react profiler to see. */
 | 
			
		||||
    element: (
 | 
			
		||||
      <CommandBarProvider>
 | 
			
		||||
        <SettingsAuthProvider>
 | 
			
		||||
          <LspProvider>
 | 
			
		||||
            <KclContextProvider>
 | 
			
		||||
              <AppStateProvider>
 | 
			
		||||
      <AppStateProvider>
 | 
			
		||||
        <CommandBarProvider>
 | 
			
		||||
          <SettingsAuthProvider>
 | 
			
		||||
            <LspProvider>
 | 
			
		||||
              <KclContextProvider>
 | 
			
		||||
                <Outlet />
 | 
			
		||||
              </AppStateProvider>
 | 
			
		||||
            </KclContextProvider>
 | 
			
		||||
          </LspProvider>
 | 
			
		||||
        </SettingsAuthProvider>
 | 
			
		||||
      </CommandBarProvider>
 | 
			
		||||
              </KclContextProvider>
 | 
			
		||||
            </LspProvider>
 | 
			
		||||
          </SettingsAuthProvider>
 | 
			
		||||
        </CommandBarProvider>
 | 
			
		||||
      </AppStateProvider>
 | 
			
		||||
    ),
 | 
			
		||||
    errorElement: <ErrorPage />,
 | 
			
		||||
    children: [
 | 
			
		||||
 | 
			
		||||
@ -1,6 +1,7 @@
 | 
			
		||||
import styles from './ModelingPane.module.css'
 | 
			
		||||
import { useSettingsAuthContext } from 'hooks/useSettingsAuthContext'
 | 
			
		||||
import { useModelingContext } from 'hooks/useModelingContext'
 | 
			
		||||
import { useAppState } from 'AppState'
 | 
			
		||||
 | 
			
		||||
export interface ModelingPaneProps
 | 
			
		||||
  extends React.PropsWithChildren,
 | 
			
		||||
@ -33,9 +34,10 @@ export const ModelingPane = ({
 | 
			
		||||
}: ModelingPaneProps) => {
 | 
			
		||||
  const { settings } = useSettingsAuthContext()
 | 
			
		||||
  const onboardingStatus = settings.context.app.onboardingStatus
 | 
			
		||||
  const { context } = useModelingContext()
 | 
			
		||||
  // const { context } = useModelingContext()
 | 
			
		||||
  const { buttonDownInStream } = useAppState()
 | 
			
		||||
  const pointerEventsCssClass =
 | 
			
		||||
    context.store?.buttonDownInStream || onboardingStatus.current === 'camera'
 | 
			
		||||
    buttonDownInStream || onboardingStatus.current === 'camera'
 | 
			
		||||
      ? 'pointer-events-none '
 | 
			
		||||
      : 'pointer-events-auto '
 | 
			
		||||
  return (
 | 
			
		||||
 | 
			
		||||
@ -15,6 +15,7 @@ import styles from './ModelingSidebar.module.css'
 | 
			
		||||
import { ModelingPane } from './ModelingPane'
 | 
			
		||||
import { isTauri } from 'lib/isTauri'
 | 
			
		||||
import { useModelingContext } from 'hooks/useModelingContext'
 | 
			
		||||
import { useAppState } from 'AppState'
 | 
			
		||||
 | 
			
		||||
interface ModelingSidebarProps {
 | 
			
		||||
  paneOpacity: '' | 'opacity-20' | 'opacity-40'
 | 
			
		||||
@ -24,8 +25,9 @@ export function ModelingSidebar({ paneOpacity }: ModelingSidebarProps) {
 | 
			
		||||
  const { settings } = useSettingsAuthContext()
 | 
			
		||||
  const onboardingStatus = settings.context.app.onboardingStatus
 | 
			
		||||
  const { context } = useModelingContext()
 | 
			
		||||
  const { buttonDownInStream } = useAppState()
 | 
			
		||||
  const pointerEventsCssClass =
 | 
			
		||||
    context.store?.buttonDownInStream ||
 | 
			
		||||
    buttonDownInStream ||
 | 
			
		||||
    onboardingStatus.current === 'camera' ||
 | 
			
		||||
    context.store?.openPanes.length === 0
 | 
			
		||||
      ? 'pointer-events-none '
 | 
			
		||||
 | 
			
		||||
@ -9,6 +9,7 @@ import { ClientSideScene } from 'clientSideScene/ClientSideSceneComp'
 | 
			
		||||
import { btnName } from 'lib/cameraControls'
 | 
			
		||||
import { sendSelectEventToEngine } from 'lib/selections'
 | 
			
		||||
import { kclManager, engineCommandManager, sceneInfra } from 'lib/singletons'
 | 
			
		||||
import { useAppState } from 'AppState'
 | 
			
		||||
 | 
			
		||||
export const Stream = () => {
 | 
			
		||||
  const [isLoading, setIsLoading] = useState(true)
 | 
			
		||||
@ -16,7 +17,10 @@ export const Stream = () => {
 | 
			
		||||
  const [clickCoords, setClickCoords] = useState<{ x: number; y: number }>()
 | 
			
		||||
  const videoRef = useRef<HTMLVideoElement>(null)
 | 
			
		||||
  const { settings } = useSettingsAuthContext()
 | 
			
		||||
  const { state, send, context } = useModelingContext()
 | 
			
		||||
  const { state, send } = useModelingContext()
 | 
			
		||||
  const { mediaStream, streamDimensions, didDragInStream, setAppState } =
 | 
			
		||||
    useAppState()
 | 
			
		||||
 | 
			
		||||
  const { overallState } = useNetworkContext()
 | 
			
		||||
  const [isFreezeFrame, setIsFreezeFrame] = useState(false)
 | 
			
		||||
 | 
			
		||||
@ -124,19 +128,26 @@ export const Stream = () => {
 | 
			
		||||
    )
 | 
			
		||||
      return
 | 
			
		||||
    if (!videoRef.current) return
 | 
			
		||||
    if (!context.store?.mediaStream) return
 | 
			
		||||
    // console.log('setting mideastrema to vi2', mediaStream, (window as any).mediaStream)
 | 
			
		||||
    const _mediaStream = mediaStream || (window as any).mediaStream
 | 
			
		||||
    if (!_mediaStream) return
 | 
			
		||||
 | 
			
		||||
    // console.log('setting mideastrema to vi')
 | 
			
		||||
    // Do not immediately play the stream!
 | 
			
		||||
    videoRef.current.srcObject = context.store.mediaStream
 | 
			
		||||
    videoRef.current.srcObject = _mediaStream
 | 
			
		||||
    videoRef.current.pause()
 | 
			
		||||
 | 
			
		||||
    // setAppState({
 | 
			
		||||
    //   mediaStream,
 | 
			
		||||
    // })
 | 
			
		||||
 | 
			
		||||
    send({
 | 
			
		||||
      type: 'Set context',
 | 
			
		||||
      data: {
 | 
			
		||||
        videoElement: videoRef.current,
 | 
			
		||||
      },
 | 
			
		||||
    })
 | 
			
		||||
  }, [context.store?.mediaStream])
 | 
			
		||||
  }, [mediaStream])
 | 
			
		||||
 | 
			
		||||
  const handleMouseDown: MouseEventHandler<HTMLDivElement> = (e) => {
 | 
			
		||||
    if (!isNetworkOkay) return
 | 
			
		||||
@ -148,44 +159,49 @@ export const Stream = () => {
 | 
			
		||||
      clientX: e.clientX,
 | 
			
		||||
      clientY: e.clientY,
 | 
			
		||||
      el: videoRef.current,
 | 
			
		||||
      ...context.store?.streamDimensions,
 | 
			
		||||
      ...streamDimensions,
 | 
			
		||||
    })
 | 
			
		||||
 | 
			
		||||
    send({
 | 
			
		||||
      type: 'Set context',
 | 
			
		||||
      data: {
 | 
			
		||||
        buttonDownInStream: e.button,
 | 
			
		||||
      },
 | 
			
		||||
    setAppState({
 | 
			
		||||
      buttonDownInStream: e.button,
 | 
			
		||||
    })
 | 
			
		||||
    // send({
 | 
			
		||||
    //   type: 'Set context',
 | 
			
		||||
    //   data: {
 | 
			
		||||
    //     buttonDownInStream: e.button,
 | 
			
		||||
    //   },
 | 
			
		||||
    // })
 | 
			
		||||
    setClickCoords({ x, y })
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  const handleMouseUp: MouseEventHandler<HTMLDivElement> = (e) => {
 | 
			
		||||
    if (!isNetworkOkay) return
 | 
			
		||||
    if (!videoRef.current) return
 | 
			
		||||
    send({
 | 
			
		||||
      type: 'Set context',
 | 
			
		||||
      data: {
 | 
			
		||||
        buttonDownInStream: undefined,
 | 
			
		||||
      },
 | 
			
		||||
    setAppState({
 | 
			
		||||
      buttonDownInStream: undefined,
 | 
			
		||||
    })
 | 
			
		||||
    // send({
 | 
			
		||||
    //   type: 'Set context',
 | 
			
		||||
    //   data: {
 | 
			
		||||
    //     buttonDownInStream: undefined,
 | 
			
		||||
    //   },
 | 
			
		||||
    // })
 | 
			
		||||
    if (state.matches('Sketch')) return
 | 
			
		||||
    if (state.matches('Sketch no face')) return
 | 
			
		||||
 | 
			
		||||
    if (!context.store?.didDragInStream && btnName(e).left) {
 | 
			
		||||
      sendSelectEventToEngine(
 | 
			
		||||
        e,
 | 
			
		||||
        videoRef.current,
 | 
			
		||||
        context.store?.streamDimensions
 | 
			
		||||
      )
 | 
			
		||||
    if (!didDragInStream && btnName(e).left) {
 | 
			
		||||
      sendSelectEventToEngine(e, videoRef.current, streamDimensions)
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    send({
 | 
			
		||||
      type: 'Set context',
 | 
			
		||||
      data: {
 | 
			
		||||
        didDragInStream: false,
 | 
			
		||||
      },
 | 
			
		||||
    setAppState({
 | 
			
		||||
      didDragInStream: false,
 | 
			
		||||
    })
 | 
			
		||||
    // send({
 | 
			
		||||
    //   type: 'Set context',
 | 
			
		||||
    //   data: {
 | 
			
		||||
    //     didDragInStream: false,
 | 
			
		||||
    //   },
 | 
			
		||||
    // })
 | 
			
		||||
    setClickCoords(undefined)
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
@ -199,13 +215,16 @@ export const Stream = () => {
 | 
			
		||||
      ((clickCoords.x - e.clientX) ** 2 + (clickCoords.y - e.clientY) ** 2) **
 | 
			
		||||
      0.5
 | 
			
		||||
 | 
			
		||||
    if (delta > 5 && !context.store?.didDragInStream) {
 | 
			
		||||
      send({
 | 
			
		||||
        type: 'Set context',
 | 
			
		||||
        data: {
 | 
			
		||||
          didDragInStream: true,
 | 
			
		||||
        },
 | 
			
		||||
    if (delta > 5 && !didDragInStream) {
 | 
			
		||||
      setAppState({
 | 
			
		||||
        didDragInStream: true,
 | 
			
		||||
      })
 | 
			
		||||
      // send({
 | 
			
		||||
      //   type: 'Set context',
 | 
			
		||||
      //   data: {
 | 
			
		||||
      //     didDragInStream: true,
 | 
			
		||||
      //   },
 | 
			
		||||
      // })
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -1,5 +1,5 @@
 | 
			
		||||
import { useLayoutEffect, useEffect, useRef } from 'react'
 | 
			
		||||
import { engineCommandManager, kclManager } from 'lib/singletons'
 | 
			
		||||
import { engineCommandManager, kclManager, sceneInfra } from 'lib/singletons'
 | 
			
		||||
import { deferExecution } from 'lib/utils'
 | 
			
		||||
import { Themes } from 'lib/theme'
 | 
			
		||||
import { makeDefaultPlanes, modifyGrid } from 'lang/wasm'
 | 
			
		||||
@ -27,7 +27,7 @@ export function useSetupEngineManager(
 | 
			
		||||
    showScaleGrid: boolean
 | 
			
		||||
  }
 | 
			
		||||
) {
 | 
			
		||||
  const { setAppState } = useAppState()
 | 
			
		||||
  const { setAppState, streamDimensions } = useAppState()
 | 
			
		||||
 | 
			
		||||
  const streamWidth = streamRef?.current?.offsetWidth
 | 
			
		||||
  const streamHeight = streamRef?.current?.offsetHeight
 | 
			
		||||
@ -47,18 +47,17 @@ export function useSetupEngineManager(
 | 
			
		||||
      streamWidth,
 | 
			
		||||
      streamHeight
 | 
			
		||||
    )
 | 
			
		||||
    if (
 | 
			
		||||
      !hasSetNonZeroDimensions.current &&
 | 
			
		||||
      quadHeight &&
 | 
			
		||||
      quadWidth &&
 | 
			
		||||
      settings.modelingSend
 | 
			
		||||
    ) {
 | 
			
		||||
    if (!hasSetNonZeroDimensions.current && quadHeight && quadWidth) {
 | 
			
		||||
      engineCommandManager.start({
 | 
			
		||||
        setMediaStream: (mediaStream) =>
 | 
			
		||||
          settings.modelingSend({
 | 
			
		||||
            type: 'Set context',
 | 
			
		||||
            data: { mediaStream },
 | 
			
		||||
          }),
 | 
			
		||||
        // setMediaStream: (mediaStream) =>
 | 
			
		||||
        //   settings.modelingSend({
 | 
			
		||||
        //     type: 'Set context',
 | 
			
		||||
        //     data: { mediaStream },
 | 
			
		||||
        //   }),
 | 
			
		||||
        setMediaStream: (mediaStream) => {
 | 
			
		||||
          ;(window as any).mediaStream = mediaStream
 | 
			
		||||
          setAppState({ mediaStream })
 | 
			
		||||
        },
 | 
			
		||||
        setIsStreamReady: (isStreamReady) => setAppState({ isStreamReady }),
 | 
			
		||||
        width: quadWidth,
 | 
			
		||||
        height: quadHeight,
 | 
			
		||||
@ -79,15 +78,22 @@ export function useSetupEngineManager(
 | 
			
		||||
          return modifyGrid(kclManager.engineCommandManager, hidden)
 | 
			
		||||
        },
 | 
			
		||||
      })
 | 
			
		||||
      settings.modelingSend({
 | 
			
		||||
        type: 'Set context',
 | 
			
		||||
        data: {
 | 
			
		||||
          streamDimensions: {
 | 
			
		||||
            streamWidth: quadWidth,
 | 
			
		||||
            streamHeight: quadHeight,
 | 
			
		||||
          },
 | 
			
		||||
        },
 | 
			
		||||
      setAppState({
 | 
			
		||||
        streamDimensions: { streamWidth: quadWidth, streamHeight: quadHeight },
 | 
			
		||||
      })
 | 
			
		||||
      sceneInfra._streamDimensions = {
 | 
			
		||||
        streamWidth: quadWidth,
 | 
			
		||||
        streamHeight: quadHeight,
 | 
			
		||||
      }
 | 
			
		||||
      // settings.modelingSend({
 | 
			
		||||
      //   type: 'Set context',
 | 
			
		||||
      //   data: {
 | 
			
		||||
      //     streamDimensions: {
 | 
			
		||||
      //       streamWidth: quadWidth,
 | 
			
		||||
      //       streamHeight: quadHeight,
 | 
			
		||||
      //     },
 | 
			
		||||
      //   },
 | 
			
		||||
      // })
 | 
			
		||||
      hasSetNonZeroDimensions.current = true
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
@ -96,6 +102,7 @@ export function useSetupEngineManager(
 | 
			
		||||
    streamRef?.current?.offsetWidth,
 | 
			
		||||
    streamRef?.current?.offsetHeight,
 | 
			
		||||
    settings.modelingSend,
 | 
			
		||||
    setAppState,
 | 
			
		||||
  ])
 | 
			
		||||
 | 
			
		||||
  useEffect(() => {
 | 
			
		||||
@ -105,22 +112,29 @@ export function useSetupEngineManager(
 | 
			
		||||
        streamRef?.current?.offsetHeight
 | 
			
		||||
      )
 | 
			
		||||
      if (
 | 
			
		||||
        settings.modelingContext.store.streamDimensions.streamWidth !== width ||
 | 
			
		||||
        settings.modelingContext.store.streamDimensions.streamHeight !== height
 | 
			
		||||
        streamDimensions.streamWidth !== width ||
 | 
			
		||||
        streamDimensions.streamHeight !== height
 | 
			
		||||
      ) {
 | 
			
		||||
        engineCommandManager.handleResize({
 | 
			
		||||
          streamWidth: width,
 | 
			
		||||
          streamHeight: height,
 | 
			
		||||
        })
 | 
			
		||||
        settings.modelingSend({
 | 
			
		||||
          type: 'Set context',
 | 
			
		||||
          data: {
 | 
			
		||||
            streamDimensions: {
 | 
			
		||||
              streamWidth: width,
 | 
			
		||||
              streamHeight: height,
 | 
			
		||||
            },
 | 
			
		||||
          },
 | 
			
		||||
        setAppState({
 | 
			
		||||
          streamDimensions: { streamWidth: width, streamHeight: height },
 | 
			
		||||
        })
 | 
			
		||||
        sceneInfra._streamDimensions = {
 | 
			
		||||
          streamWidth: width,
 | 
			
		||||
          streamHeight: height,
 | 
			
		||||
        }
 | 
			
		||||
        // settings.modelingSend({
 | 
			
		||||
        //   type: 'Set context',
 | 
			
		||||
        //   data: {
 | 
			
		||||
        //     streamDimensions: {
 | 
			
		||||
        //       streamWidth: width,
 | 
			
		||||
        //       streamHeight: height,
 | 
			
		||||
        //     },
 | 
			
		||||
        //   },
 | 
			
		||||
        // })
 | 
			
		||||
      }
 | 
			
		||||
    }, 500)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -8,9 +8,11 @@ import {
 | 
			
		||||
} from 'lib/cameraControls'
 | 
			
		||||
import { SettingsSection } from 'components/Settings/SettingsSection'
 | 
			
		||||
import { useModelingContext } from 'hooks/useModelingContext'
 | 
			
		||||
import { useAppState } from 'AppState'
 | 
			
		||||
 | 
			
		||||
export default function Units() {
 | 
			
		||||
  const { context } = useModelingContext()
 | 
			
		||||
  const { buttonDownInStream } = useAppState()
 | 
			
		||||
  const dismiss = useDismiss()
 | 
			
		||||
  const next = useNextClick(onboardingPaths.STREAMING)
 | 
			
		||||
  const {
 | 
			
		||||
@ -29,7 +31,7 @@ export default function Units() {
 | 
			
		||||
      <div
 | 
			
		||||
        className={
 | 
			
		||||
          'max-w-2xl border border-chalkboard-50 dark:border-chalkboard-80 shadow-lg flex flex-col justify-center bg-chalkboard-10 dark:bg-chalkboard-90 p-8 rounded' +
 | 
			
		||||
          (context.store?.buttonDownInStream ? '' : ' pointer-events-auto')
 | 
			
		||||
          (buttonDownInStream ? '' : ' pointer-events-auto')
 | 
			
		||||
        }
 | 
			
		||||
      >
 | 
			
		||||
        <SettingsSection
 | 
			
		||||
 | 
			
		||||
@ -2,9 +2,11 @@ import usePlatform from 'hooks/usePlatform'
 | 
			
		||||
import { OnboardingButtons, kbdClasses, useDismiss, useNextClick } from '.'
 | 
			
		||||
import { onboardingPaths } from 'routes/Onboarding/paths'
 | 
			
		||||
import { useModelingContext } from 'hooks/useModelingContext'
 | 
			
		||||
import { useAppState } from 'AppState'
 | 
			
		||||
 | 
			
		||||
export default function CmdK() {
 | 
			
		||||
  const { context } = useModelingContext()
 | 
			
		||||
  // const { context } = useModelingContext()
 | 
			
		||||
  const { buttonDownInStream } = useAppState()
 | 
			
		||||
  const dismiss = useDismiss()
 | 
			
		||||
  const next = useNextClick(onboardingPaths.USER_MENU)
 | 
			
		||||
  const platformName = usePlatform()
 | 
			
		||||
@ -14,7 +16,7 @@ export default function CmdK() {
 | 
			
		||||
      <div
 | 
			
		||||
        className={
 | 
			
		||||
          'max-w-full xl:max-w-4xl border border-chalkboard-50 dark:border-chalkboard-80 shadow-lg flex flex-col justify-center bg-chalkboard-10 dark:bg-chalkboard-90 p-8 rounded' +
 | 
			
		||||
          (context.store?.buttonDownInStream ? '' : ' pointer-events-auto')
 | 
			
		||||
          (buttonDownInStream ? '' : ' pointer-events-auto')
 | 
			
		||||
        }
 | 
			
		||||
      >
 | 
			
		||||
        <h2 className="text-2xl font-bold">Command Bar</h2>
 | 
			
		||||
 | 
			
		||||
@ -1,10 +1,12 @@
 | 
			
		||||
import { useModelingContext } from 'hooks/useModelingContext'
 | 
			
		||||
import { OnboardingButtons, useDemoCode, useDismiss, useNextClick } from '.'
 | 
			
		||||
import { onboardingPaths } from 'routes/Onboarding/paths'
 | 
			
		||||
import { useAppState } from 'AppState'
 | 
			
		||||
 | 
			
		||||
export default function OnboardingCodeEditor() {
 | 
			
		||||
  useDemoCode()
 | 
			
		||||
  const { context } = useModelingContext()
 | 
			
		||||
  const { buttonDownInStream } = useAppState()
 | 
			
		||||
  const dismiss = useDismiss()
 | 
			
		||||
  const next = useNextClick(onboardingPaths.PARAMETRIC_MODELING)
 | 
			
		||||
 | 
			
		||||
@ -13,7 +15,7 @@ export default function OnboardingCodeEditor() {
 | 
			
		||||
      <div
 | 
			
		||||
        className={
 | 
			
		||||
          'z-10 max-w-xl border border-chalkboard-50 dark:border-chalkboard-80 shadow-lg h-[75vh] flex flex-col justify-center bg-chalkboard-10 dark:bg-chalkboard-90 p-8 rounded' +
 | 
			
		||||
          (context.store?.buttonDownInStream ? '' : ' pointer-events-auto')
 | 
			
		||||
          (buttonDownInStream ? '' : ' pointer-events-auto')
 | 
			
		||||
        }
 | 
			
		||||
      >
 | 
			
		||||
        <section className="flex-1 overflow-y-auto">
 | 
			
		||||
 | 
			
		||||
@ -2,9 +2,11 @@ import { APP_NAME } from 'lib/constants'
 | 
			
		||||
import { OnboardingButtons, useDismiss, useNextClick } from '.'
 | 
			
		||||
import { onboardingPaths } from 'routes/Onboarding/paths'
 | 
			
		||||
import { useModelingContext } from 'hooks/useModelingContext'
 | 
			
		||||
import { useAppState } from 'AppState'
 | 
			
		||||
 | 
			
		||||
export default function Export() {
 | 
			
		||||
  const { context } = useModelingContext()
 | 
			
		||||
  const { buttonDownInStream } = useAppState()
 | 
			
		||||
  const dismiss = useDismiss()
 | 
			
		||||
  const next = useNextClick(onboardingPaths.SKETCHING)
 | 
			
		||||
 | 
			
		||||
@ -13,7 +15,7 @@ export default function Export() {
 | 
			
		||||
      <div
 | 
			
		||||
        className={
 | 
			
		||||
          'max-w-full xl:max-w-2xl border border-chalkboard-50 dark:border-chalkboard-80 shadow-lg flex flex-col justify-center bg-chalkboard-10 dark:bg-chalkboard-90 p-8 rounded' +
 | 
			
		||||
          (context.store?.buttonDownInStream ? '' : ' pointer-events-auto')
 | 
			
		||||
          (buttonDownInStream ? '' : ' pointer-events-auto')
 | 
			
		||||
        }
 | 
			
		||||
      >
 | 
			
		||||
        <section className="flex-1">
 | 
			
		||||
 | 
			
		||||
@ -8,10 +8,12 @@ import {
 | 
			
		||||
import { onboardingPaths } from 'routes/Onboarding/paths'
 | 
			
		||||
import { bracketWidthConstantLine } from 'lib/exampleKcl'
 | 
			
		||||
import { useModelingContext } from 'hooks/useModelingContext'
 | 
			
		||||
import { useAppState } from 'AppState'
 | 
			
		||||
 | 
			
		||||
export default function OnboardingInteractiveNumbers() {
 | 
			
		||||
  useDemoCode()
 | 
			
		||||
  const { context } = useModelingContext()
 | 
			
		||||
  const { buttonDownInStream } = useAppState()
 | 
			
		||||
  const dismiss = useDismiss()
 | 
			
		||||
  const next = useNextClick(onboardingPaths.COMMAND_K)
 | 
			
		||||
 | 
			
		||||
@ -20,7 +22,7 @@ export default function OnboardingInteractiveNumbers() {
 | 
			
		||||
      <div
 | 
			
		||||
        className={
 | 
			
		||||
          'z-10 max-w-xl border border-chalkboard-50 dark:border-chalkboard-80 shadow-lg h-[75vh] flex flex-col justify-center bg-chalkboard-10 dark:bg-chalkboard-90 p-8 rounded' +
 | 
			
		||||
          (context.store?.buttonDownInStream ? '' : ' pointer-events-auto')
 | 
			
		||||
          (buttonDownInStream ? '' : ' pointer-events-auto')
 | 
			
		||||
        }
 | 
			
		||||
      >
 | 
			
		||||
        <section className="flex-1 overflow-y-auto mb-6">
 | 
			
		||||
 | 
			
		||||
@ -4,10 +4,12 @@ import { Themes, getSystemTheme } from 'lib/theme'
 | 
			
		||||
import { useSettingsAuthContext } from 'hooks/useSettingsAuthContext'
 | 
			
		||||
import { bracketThicknessCalculationLine } from 'lib/exampleKcl'
 | 
			
		||||
import { useModelingContext } from 'hooks/useModelingContext'
 | 
			
		||||
import { useAppState } from 'AppState'
 | 
			
		||||
 | 
			
		||||
export default function OnboardingParametricModeling() {
 | 
			
		||||
  useDemoCode()
 | 
			
		||||
  const { context } = useModelingContext()
 | 
			
		||||
  const { buttonDownInStream } = useAppState()
 | 
			
		||||
  const {
 | 
			
		||||
    settings: {
 | 
			
		||||
      context: {
 | 
			
		||||
@ -30,7 +32,7 @@ export default function OnboardingParametricModeling() {
 | 
			
		||||
      <div
 | 
			
		||||
        className={
 | 
			
		||||
          'z-10 max-w-xl border border-chalkboard-50 dark:border-chalkboard-80 shadow-lg h-[75vh] flex flex-col justify-center bg-chalkboard-10 dark:bg-chalkboard-90 p-8 rounded' +
 | 
			
		||||
          (context.store?.buttonDownInStream ? '' : ' pointer-events-auto')
 | 
			
		||||
          (buttonDownInStream ? '' : ' pointer-events-auto')
 | 
			
		||||
        }
 | 
			
		||||
      >
 | 
			
		||||
        <section className="flex-1 overflow-y-auto mb-6">
 | 
			
		||||
 | 
			
		||||
@ -2,9 +2,11 @@ import { OnboardingButtons, useDismiss, useNextClick } from '.'
 | 
			
		||||
import { onboardingPaths } from 'routes/Onboarding/paths'
 | 
			
		||||
import { isTauri } from 'lib/isTauri'
 | 
			
		||||
import { useModelingContext } from 'hooks/useModelingContext'
 | 
			
		||||
import { useAppState } from 'AppState'
 | 
			
		||||
 | 
			
		||||
export default function ProjectMenu() {
 | 
			
		||||
  const { context } = useModelingContext()
 | 
			
		||||
  const { buttonDownInStream } = useAppState()
 | 
			
		||||
  const dismiss = useDismiss()
 | 
			
		||||
  const next = useNextClick(onboardingPaths.EXPORT)
 | 
			
		||||
  const tauri = isTauri()
 | 
			
		||||
@ -14,7 +16,7 @@ export default function ProjectMenu() {
 | 
			
		||||
      <div
 | 
			
		||||
        className={
 | 
			
		||||
          'max-w-xl flex flex-col border border-chalkboard-50 dark:border-chalkboard-80 shadow-lg justify-center bg-chalkboard-10 dark:bg-chalkboard-90 p-8 rounded' +
 | 
			
		||||
          (context.store?.buttonDownInStream ? '' : ' pointer-events-auto')
 | 
			
		||||
          (buttonDownInStream ? '' : ' pointer-events-auto')
 | 
			
		||||
        }
 | 
			
		||||
      >
 | 
			
		||||
        <section className="flex-1">
 | 
			
		||||
 | 
			
		||||
@ -3,9 +3,11 @@ import { onboardingPaths } from 'routes/Onboarding/paths'
 | 
			
		||||
import { useEffect } from 'react'
 | 
			
		||||
import { codeManager, kclManager } from 'lib/singletons'
 | 
			
		||||
import { useModelingContext } from 'hooks/useModelingContext'
 | 
			
		||||
import { useAppState } from 'AppState'
 | 
			
		||||
 | 
			
		||||
export default function Sketching() {
 | 
			
		||||
  const { context } = useModelingContext()
 | 
			
		||||
  const { buttonDownInStream } = useAppState()
 | 
			
		||||
  const dismiss = useDismiss()
 | 
			
		||||
  const next = useNextClick(onboardingPaths.FUTURE_WORK)
 | 
			
		||||
 | 
			
		||||
@ -23,7 +25,7 @@ export default function Sketching() {
 | 
			
		||||
      <div
 | 
			
		||||
        className={
 | 
			
		||||
          'max-w-full xl:max-w-2xl border border-chalkboard-50 dark:border-chalkboard-80 shadow-lg flex flex-col justify-center bg-chalkboard-10 dark:bg-chalkboard-90 p-8 rounded' +
 | 
			
		||||
          (context.store?.buttonDownInStream ? '' : ' pointer-events-auto')
 | 
			
		||||
          (buttonDownInStream ? '' : ' pointer-events-auto')
 | 
			
		||||
        }
 | 
			
		||||
      >
 | 
			
		||||
        <h1 className="text-2xl font-bold">Sketching</h1>
 | 
			
		||||
 | 
			
		||||
@ -1,9 +1,11 @@
 | 
			
		||||
import { useModelingContext } from 'hooks/useModelingContext'
 | 
			
		||||
import { OnboardingButtons, useDismiss, useNextClick } from '.'
 | 
			
		||||
import { onboardingPaths } from 'routes/Onboarding/paths'
 | 
			
		||||
import { useAppState } from 'AppState'
 | 
			
		||||
 | 
			
		||||
export default function Streaming() {
 | 
			
		||||
  const { context } = useModelingContext()
 | 
			
		||||
  const { buttonDownInStream } = useAppState()
 | 
			
		||||
  const dismiss = useDismiss()
 | 
			
		||||
  const next = useNextClick(onboardingPaths.EDITOR)
 | 
			
		||||
 | 
			
		||||
@ -12,7 +14,7 @@ export default function Streaming() {
 | 
			
		||||
      <div
 | 
			
		||||
        className={
 | 
			
		||||
          'max-w-xl border border-chalkboard-50 dark:border-chalkboard-80 shadow-lg h-[75vh] flex flex-col justify-center bg-chalkboard-10 dark:bg-chalkboard-90 p-8 rounded' +
 | 
			
		||||
          (context.store?.buttonDownInStream ? '' : ' pointer-events-auto')
 | 
			
		||||
          (buttonDownInStream ? '' : ' pointer-events-auto')
 | 
			
		||||
        }
 | 
			
		||||
      >
 | 
			
		||||
        <section className="flex-1 overflow-y-auto">
 | 
			
		||||
 | 
			
		||||
@ -3,9 +3,11 @@ import { onboardingPaths } from 'routes/Onboarding/paths'
 | 
			
		||||
import { useEffect, useState } from 'react'
 | 
			
		||||
import { useModelingContext } from 'hooks/useModelingContext'
 | 
			
		||||
import { useSettingsAuthContext } from 'hooks/useSettingsAuthContext'
 | 
			
		||||
import { useAppState } from 'AppState'
 | 
			
		||||
 | 
			
		||||
export default function UserMenu() {
 | 
			
		||||
  const { context } = useModelingContext()
 | 
			
		||||
  const { buttonDownInStream } = useAppState()
 | 
			
		||||
  const { auth } = useSettingsAuthContext()
 | 
			
		||||
  const dismiss = useDismiss()
 | 
			
		||||
  const next = useNextClick(onboardingPaths.PROJECT_MENU)
 | 
			
		||||
@ -36,7 +38,7 @@ export default function UserMenu() {
 | 
			
		||||
      <div
 | 
			
		||||
        className={
 | 
			
		||||
          'max-w-xl flex flex-col border border-chalkboard-50 dark:border-chalkboard-80 shadow-lg justify-center bg-chalkboard-10 dark:bg-chalkboard-90 p-8 rounded' +
 | 
			
		||||
          (context.store?.buttonDownInStream ? '' : ' pointer-events-auto')
 | 
			
		||||
          (buttonDownInStream ? '' : ' pointer-events-auto')
 | 
			
		||||
        }
 | 
			
		||||
      >
 | 
			
		||||
        <section className="flex-1">
 | 
			
		||||
 | 
			
		||||
		Reference in New Issue
	
	Block a user