mirror of
				https://github.com/zadam/trilium.git
				synced 2025-10-27 00:06:30 +01:00 
			
		
		
		
	Compare commits
	
		
			1288 Commits
		
	
	
		
			feat/add-w
			...
			v0.99.0
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | 27e6d1b00b | ||
|  | 73ea0cce32 | ||
|  | a1741b8634 | ||
|  | a0f1a63fb6 | ||
|  | 7c13373f16 | ||
|  | 239b7b810d | ||
|  | e753924c4b | ||
|  | 8080d3b8a7 | ||
|  | 1f4dd04ef0 | ||
|  | 348432bd5b | ||
|  | d2962b060e | ||
|  | fae66e555e | ||
|  | aeb9bfc1fd | ||
|  | 5a15024e59 | ||
|  | 23c2acaab7 | ||
|  | 4cc55b02ab | ||
|  | 71ce9c459e | ||
|  | 97b5ea0798 | ||
|  | 5fd0f79d44 | ||
|  | 2a090c7014 | ||
|  | 126030f17e | ||
|  | f22fd1d454 | ||
|  | 8d4c656a6f | ||
|  | 3c5a053a2c | ||
|  | 664b7e45e7 | ||
|  | 13e9fcbfba | ||
|  | 5249911ddb | ||
|  | 59fe1299b2 | ||
|  | 1c9f1ba82c | ||
|  | 311f4aded8 | ||
|  | ed8df51216 | ||
|  | 5e4d403556 | ||
|  | f3a9c718ad | ||
|  | f3733eb341 | ||
|  | 3b06845a71 | ||
|  | 94e20c44e5 | ||
|  | 1638fd8590 | ||
|  | effe0a4f51 | ||
|  | bb3ac277f4 | ||
|  | 68aacfea6f | ||
|  | e0056a457e | ||
|  | 4d6c2fd8cb | ||
|  | f63b8cef2d | ||
|  | f19da292c1 | ||
|  | 36003b76e9 | ||
|  | 1c627dec05 | ||
|  | 2dcb67b099 | ||
|  | de8a090410 | ||
|  | fc09a41ba0 | ||
|  | 12f461d0ea | ||
|  | 1256338ab5 | ||
|  | 43c761328d | ||
|  | 6f565afd44 | ||
|  | 5c27e96960 | ||
|  | c0337befa7 | ||
|  | 3bda10caf0 | ||
|  | a25e376f85 | ||
|  | 1b238a98de | ||
|  | 38659e501e | ||
|  | 113af940c1 | ||
|  | 089ca7fd29 | ||
|  | 529523dd4e | ||
|  | 89417f15dc | ||
|  | 51692aabd5 | ||
|  | 9cde4c26d9 | ||
|  | c7bce91b67 | ||
|  | 91b6910a9c | ||
|  | 9fb37968f8 | ||
|  | 6cfc6509f6 | ||
|  | fd054693d9 | ||
|  | 8b65de2442 | ||
|  | 25905ebff7 | ||
|  | e88b59009a | ||
|  | 3aee1c8546 | ||
|  | 2dd554a8be | ||
|  | f4fae04327 | ||
|  | 21032d1bb8 | ||
|  | 6745b887fb | ||
|  | d0d166e426 | ||
|  | 754b95876e | ||
|  | 0bb10cf3ee | ||
|  | d276cdf519 | ||
|  | 2768b76278 | ||
|  | d244803501 | ||
|  | 158ca2acf2 | ||
|  | 3ef44febd8 | ||
|  | 5be41ee669 | ||
|  | b887d4a7d2 | ||
|  | be1de86a42 | ||
|  | 345d098e5f | ||
|  | fae5421516 | ||
|  | 934f144bf9 | ||
|  | 5affb837a6 | ||
|  | 188319d2d9 | ||
|  | fe762577b1 | ||
|  | f30da3d13b | ||
|  | 053a84483c | ||
|  | 34338a795f | ||
|  | 012aceb7f2 | ||
|  | a92604e92f | ||
|  | 9a9edf16c4 | ||
|  | daba190e74 | ||
|  | 8877eded9b | ||
|  | 0b05f597dc | ||
|  | b26803b627 | ||
|  | 17e87278eb | ||
|  | 79718c7e6e | ||
|  | 0917c25bce | ||
|  | 45c3f6d44a | ||
|  | 90337016e7 | ||
|  | c0c1c8a9c2 | ||
|  | 42a082f11b | ||
|  | 891e6b9751 | ||
|  | 2be9d71659 | ||
|  | 3f562332c7 | ||
|  | edd7e43b41 | ||
|  | 6ea1e31350 | ||
|  | 770648619e | ||
|  | 08c3e97a46 | ||
|  | 9a08b864ee | ||
|  | 039d6e6a4e | ||
|  | 36692a5ad7 | ||
|  | 67c7d7575d | ||
|  | bb51eed0bc | ||
|  | adce041b02 | ||
|  | 183d11ff72 | ||
|  | a9f5b44fac | ||
|  | c4560c2bc8 | ||
|  | ba740eff9b | ||
|  | 9dcf46cbb3 | ||
|  | 7782b11186 | ||
|  | e1b8f973d5 | ||
|  | a51e475095 | ||
|  | 13685d2688 | ||
|  | 8bef36c6c7 | ||
|  | 207807e0c2 | ||
|  | b5c82af464 | ||
|  | 3fa95d4fee | ||
|  | ee43b21b0c | ||
|  | 29e091461f | ||
|  | 5b6a2b1f5d | ||
|  | d657303f2f | ||
|  | a4d541ae1c | ||
|  | b38631b04b | ||
|  | fe0f8ad83d | ||
|  | 46950cbceb | ||
|  | 9893de4642 | ||
|  | b9055c6810 | ||
|  | f068b335f5 | ||
|  | 7c750811cc | ||
|  | 2edce23a29 | ||
|  | 3efe628eb7 | ||
|  | fdbb88ccd1 | ||
|  | c44395887b | ||
|  | 1ae81abf0a | ||
|  | 74b89098c5 | ||
|  | ae46798d1d | ||
|  | b502e999de | ||
|  | 57004ab848 | ||
|  | fbd47025d6 | ||
|  | f87d270caa | ||
|  | 2ccaf5f97c | ||
|  | 641c6f4595 | ||
|  | eb1039d9f7 | ||
|  | 349d946e6f | ||
|  | 170e271bb4 | ||
|  | adca755598 | ||
|  | f58cbc64bb | ||
|  | 8d5e8c7ea8 | ||
|  | 411d61d251 | ||
|  | e7556f7dfa | ||
|  | 3e0f07aa48 | ||
|  | e5a90662eb | ||
|  | 9886376738 | ||
|  | 73603f6593 | ||
|  | 88bc6739ca | ||
|  | a4e8e62452 | ||
|  | 78e45d095b | ||
|  | 834c67aeff | ||
|  | 23b798e392 | ||
|  | bd374bf617 | ||
|  | 87d8bcdde5 | ||
|  | a840d91379 | ||
|  | 0fcff6639f | ||
|  | f607c9793d | ||
|  | 06254442c9 | ||
|  | c5725a5850 | ||
|  | dbad13c4e2 | ||
|  | a274da80b7 | ||
|  | 66c05619df | ||
|  | 67c99dea2d | ||
|  | c77b7f8c74 | ||
|  | cc51fbe77e | ||
|  | 2e510f9dbb | ||
|  | e12df98d12 | ||
|  | d8402755ee | ||
|  | 614b704702 | ||
|  | fb6e87b0a5 | ||
|  | 80baa31221 | ||
|  | e2f1f56e06 | ||
|  | 8ed6aeb278 | ||
|  | 7123dc305f | ||
|  | 43cb632528 | ||
|  | 74c5b12a33 | ||
|  | acebed10b0 | ||
|  | 21f5c36c05 | ||
|  | 35c297e0d1 | ||
|  | e672890bd4 | ||
|  | a3f2dc5e76 | ||
|  | a19db4fd2d | ||
|  | 982d136151 | ||
|  | 377de59df9 | ||
|  | b394fb1e86 | ||
|  | a5171ce093 | ||
|  | c5dbaccea8 | ||
|  | 0c9d1e91bb | ||
|  | a1ee0cb5d0 | ||
|  | a2d41247fe | ||
|  | 97bb38e4f3 | ||
|  | 8e8ae26828 | ||
|  | e241e91a84 | ||
|  | ea277cf972 | ||
|  | 046e7ac4c3 | ||
|  | beea8d9edf | ||
|  | 1c928bb139 | ||
|  | 987e6ad4c6 | ||
|  | b7732e53c6 | ||
|  | bfb34cf236 | ||
|  | 50b9bebf98 | ||
|  | e21624ed52 | ||
|  | 86a8085239 | ||
|  | 19c756a971 | ||
|  | b76c6ed444 | ||
|  | bd07342689 | ||
|  | be1d7309fd | ||
|  | 9471fad7bb | ||
|  | 642bf60f45 | ||
|  | 7245e32876 | ||
|  | dcc1a2dc51 | ||
|  | 2b3874d8e9 | ||
|  | 29f9c311d2 | ||
|  | adae78e747 | ||
|  | 5b5f3233d8 | ||
|  | e6889798ff | ||
|  | a5ae6f7013 | ||
|  | 0ac2df8102 | ||
|  | ec5e7607f0 | ||
|  | 7588026640 | ||
|  | ad366ee928 | ||
|  | 1fc38e941e | ||
|  | b80c4ed921 | ||
|  | 1de9634c44 | ||
|  | d8386bfbe8 | ||
|  | 3a02ad7836 | ||
|  | d36716bdb6 | ||
|  | 970f4b028d | ||
|  | 6077da0df8 | ||
|  | e77e0c54f0 | ||
|  | 4040f8ba89 | ||
|  | 3ac0dfb2ad | ||
|  | b8e4947adb | ||
|  | d1f2dfca05 | ||
|  | c6a9b48aa0 | ||
|  | fd690592ba | ||
|  | 8a66ee7565 | ||
|  | f42d375cc7 | ||
|  | 68beb0d419 | ||
|  | 50d2814044 | ||
|  | 8ddd27c258 | ||
|  | ac78eada0a | ||
|  | 6b0395dec8 | ||
|  | 5bb1432450 | ||
|  | dc854cbd10 | ||
|  | 3128f2dace | ||
|  | 6ba494999c | ||
|  | 050ff5d8cd | ||
|  | 9c8b0611ea | ||
|  | 777d5ab3b7 | ||
|  | 39fecb3ffe | ||
|  | 4cd0702cbb | ||
|  | 998688573d | ||
|  | a6833f5a6f | ||
|  | a162d697da | ||
|  | f281e9691d | ||
|  | cbc2ee3cd1 | ||
|  | 4f469d0d3c | ||
|  | e77a49ace6 | ||
|  | 8bde2092c6 | ||
|  | 7edfaad04e | ||
|  | ae5576f2a3 | ||
|  | b934b2b6ca | ||
|  | 87648f340b | ||
|  | 679abc6e3e | ||
|  | dd930261bf | ||
|  | 92a0faf475 | ||
|  | 3ce6b43018 | ||
|  | 220858926f | ||
|  | d908a1b0d2 | ||
|  | b361cc0630 | ||
|  | cd3663e041 | ||
|  | c53e927a55 | ||
|  | 7bbb15a535 | ||
|  | 0dddcbcfa1 | ||
|  | 3175b75192 | ||
|  | 6703b78457 | ||
|  | 7a61bbc297 | ||
|  | dd6003172d | ||
|  | 338f3d536f | ||
|  | 27804384db | ||
|  | 7e5069c7d1 | ||
|  | 0a813f9b53 | ||
|  | c79c21e965 | ||
|  | 0c0bcb87f9 | ||
|  | f537852469 | ||
|  | ff422d112b | ||
|  | bf92280ed9 | ||
|  | d1e57e85b6 | ||
|  | f300b6c8a2 | ||
|  | 4c0addd929 | ||
|  | a08bc79ae4 | ||
|  | 8ad00084e1 | ||
|  | 0d275b3259 | ||
|  | ede4b99bcd | ||
|  | e99748e45f | ||
|  | 114fdd6f91 | ||
|  | 245675d409 | ||
|  | e156f0a2e8 | ||
|  | 519d76d809 | ||
|  | b4fa70d1d5 | ||
|  | 3825fb24f4 | ||
|  | 79e51b543a | ||
|  | 54fe9dde70 | ||
|  | d224ffd6d3 | ||
|  | 1e1a458add | ||
|  | 0844f60343 | ||
|  | c8f9d6e6df | ||
|  | 95a392ccfa | ||
|  | 2972a23f19 | ||
|  | f55a39eab6 | ||
|  | 8611328a03 | ||
|  | 08dc05c504 | ||
|  | 174f796b56 | ||
|  | 85949a0464 | ||
|  | 1b711e2c08 | ||
|  | 60ea415361 | ||
|  | 01613da38f | ||
|  | d6e6e78acc | ||
|  | 0e5e439f69 | ||
|  | fc78f68fa7 | ||
|  | 2f6d81ce2c | ||
|  | 08a600167a | ||
|  | 9779e706c5 | ||
|  | b8e9d853e5 | ||
|  | 4041746240 | ||
|  | c96a65b21d | ||
|  | d67018b6d7 | ||
|  | f7e47b5120 | ||
|  | 5bc28b63a6 | ||
|  | 62452b61b1 | ||
|  | cb84e4c7b6 | ||
|  | 60ef816f0c | ||
|  | d367cf9972 | ||
|  | 05973672e4 | ||
|  | c4398e92e1 | ||
|  | 68b8ba691f | ||
|  | d52cf455a9 | ||
|  | fee822c689 | ||
|  | 228a1ad0da | ||
|  | 1ce42d1301 | ||
|  | 3d2a4d8c38 | ||
|  | 803164791f | ||
|  | 2b452a18df | ||
|  | efcdac75e4 | ||
|  | c30c9a7360 | ||
|  | ce0da3fb80 | ||
|  | 728c20c184 | ||
|  | e10475679b | ||
|  | d9af0461ef | ||
|  | 2e4791d377 | ||
|  | d1244e02db | ||
|  | 867d1841e9 | ||
|  | 3232900bdc | ||
|  | 077de9f539 | ||
|  | b37f4bf0df | ||
|  | 64dd83e8fb | ||
|  | 5a615970c2 | ||
|  | 2a5cb85199 | ||
|  | 5f1f27a4f9 | ||
|  | 0d9f398de2 | ||
|  | b0e84952c8 | ||
|  | 3df8cf3c13 | ||
|  | 975e5a89af | ||
|  | 7102615eaa | ||
|  | 68fa273c75 | ||
|  | f8ecf0ec0b | ||
|  | 888aba0b04 | ||
|  | 2216136de3 | ||
|  | 4163c5534a | ||
|  | 3ddcaddd79 | ||
|  | b029e0d790 | ||
|  | 6f2d51f3ff | ||
|  | ecf8c4ffbe | ||
|  | 4b769da90b | ||
|  | 4247c8fdc6 | ||
|  | 7777cd5238 | ||
|  | cb959e93f2 | ||
|  | 30979b460b | ||
|  | 901d1ecf4a | ||
|  | c84a38f2b2 | ||
|  | ed461bc22f | ||
|  | 28368e6e12 | ||
|  | 8247855330 | ||
|  | 7cd6237f16 | ||
|  | ca9bdc337a | ||
|  | e6d2394d54 | ||
|  | 3d43665603 | ||
|  | f135ffbe49 | ||
|  | 3d99bc7166 | ||
|  | 3789edf53a | ||
|  | 4d57134aa2 | ||
|  | e3d9a120cb | ||
|  | 043791fc91 | ||
|  | 33a37be378 | ||
|  | 32ce6e7a08 | ||
|  | 3046cfd6ee | ||
|  | 9758632bf0 | ||
|  | 0c7f926421 | ||
|  | ab6fc9303b | ||
|  | 4e37a5f08e | ||
|  | 426b4dde54 | ||
|  | d3cc79a28c | ||
|  | b0a826aaca | ||
|  | 9c0e678e50 | ||
|  | bbb2571215 | ||
|  | d2a0d75906 | ||
|  | e16dc941d2 | ||
|  | fa61e7bacb | ||
|  | 439a182103 | ||
|  | 7eb478cc6a | ||
|  | 4341c1fbc8 | ||
|  | e8039715e7 | ||
|  | 3cacfdfd6f | ||
|  | 7b2cd20cff | ||
|  | 79a5fab39e | ||
|  | b03d687f75 | ||
|  | 61ec341c27 | ||
|  | 22835108be | ||
|  | 1e654fbcd6 | ||
|  | 49c4776dbd | ||
|  | 41c4bc69cc | ||
|  | 6eea921820 | ||
|  | 3d97b317f2 | ||
|  | 7ba24968d8 | ||
|  | 57046d714b | ||
|  | 0526445d3c | ||
|  | b62d1a303c | ||
|  | e25c5cc6c7 | ||
|  | e761cd7c27 | ||
|  | 617548f6b6 | ||
|  | 2f93af4d6f | ||
|  | c2504bb6db | ||
|  | 145f89eded | ||
|  | 6c0e4b6a48 | ||
|  | 87d1eefc86 | ||
|  | a87ec6f2e7 | ||
|  | a9d5478bcd | ||
|  | 5eae51a1b4 | ||
|  | ac94ab6914 | ||
|  | 38673a85c9 | ||
|  | d75951c869 | ||
|  | 67d36a9e28 | ||
|  | de8e8915ff | ||
|  | 2161816ef4 | ||
|  | d046bdec65 | ||
|  | cddd7d1562 | ||
|  | 15a3104904 | ||
|  | e1ca6eca0f | ||
|  | cc0137bdc9 | ||
|  | 86a620bc08 | ||
|  | 3ba9c3b4a8 | ||
|  | 8dc5ada553 | ||
|  | 9fe744c545 | ||
|  | cc29eb0f9b | ||
|  | 901edde634 | ||
|  | 44dd6d499d | ||
|  | 375f09cbaf | ||
|  | d4e5a31de4 | ||
|  | f3fa3864b2 | ||
|  | 1c978c2497 | ||
|  | 0f4ec2b3e2 | ||
|  | e30b1abaa4 | ||
|  | 16cbee1fb2 | ||
|  | 56932f2b56 | ||
|  | 6a8f6b8370 | ||
|  | 7fa8e65015 | ||
|  | 4f50b8c7d5 | ||
|  | eca85d9978 | ||
|  | f0ea2eb39b | ||
|  | 4c5b229680 | ||
|  | 83251cbc43 | ||
|  | c2f20cce32 | ||
|  | ec5ab44519 | ||
|  | ed6d21a05a | ||
|  | a2f3913fe5 | ||
|  | d66c0ef308 | ||
|  | 0f9f6746ed | ||
|  | 9b534a0dc1 | ||
|  | 1ce73c1238 | ||
|  | 3b5b7ca01d | ||
|  | ce64a7816d | ||
|  | 37e095a93c | ||
|  | 300f6a103f | ||
|  | e7cb5a6b92 | ||
|  | 67296fabf7 | ||
|  | d868f7fb26 | ||
|  | 1555d98f7d | ||
|  | 3a02941b38 | ||
|  | f25de1ffbe | ||
|  | 008e90324f | ||
|  | 73dcc2eb26 | ||
|  | eae2540a31 | ||
|  | 2a7fc8edb6 | ||
|  | cd67299b1d | ||
|  | ff38008207 | ||
|  | 76e903a782 | ||
|  | 25698f5d9b | ||
|  | c729731c7e | ||
|  | 9d877ec97a | ||
|  | b4cead757d | ||
|  | dcc2f28079 | ||
|  | 97aa00e18b | ||
|  | f076581bed | ||
|  | 5d8f789791 | ||
|  | 4faabb7770 | ||
|  | 1cffff77bf | ||
|  | 8f9b3df681 | ||
|  | 449575e0f7 | ||
|  | b7d47779d6 | ||
|  | fe443c8a89 | ||
|  | f01a772d8d | ||
|  | 76d068aa23 | ||
|  | b151db0843 | ||
|  | 5a3f432d89 | ||
|  | 8dcef5ea9f | ||
|  | 05299952a9 | ||
|  | 5966b9ff23 | ||
|  | 1917c04baf | ||
|  | 4c20ac0b1c | ||
|  | 6bd548cc22 | ||
|  | 3e7f0ad0a8 | ||
|  | 785f72ecd6 | ||
|  | 62cdb1a797 | ||
|  | 24e17c4e4f | ||
|  | d664c0166d | ||
|  | 05ebe821f2 | ||
|  | 6c4ac347db | ||
|  | e8024ce341 | ||
|  | afc17f41f6 | ||
|  | 49c80f0e0b | ||
|  | 10a6a3056a | ||
|  | 69af62cde0 | ||
|  | 0cc8b5def0 | ||
|  | fc52e73153 | ||
|  | ce67e460c6 | ||
|  | 85e5f4d2c0 | ||
|  | 6237afe3cd | ||
|  | cfddb6f04e | ||
|  | 3bf1a77381 | ||
|  | c4d430c62d | ||
|  | d583ee2de3 | ||
|  | 406a381ef4 | ||
|  | 1d82308c43 | ||
|  | 5c1595b1fd | ||
|  | 667cfb999b | ||
|  | f0b5954c54 | ||
|  | 9b0e817635 | ||
|  | b93d9a6b6e | ||
|  | 5bb9117fde | ||
|  | 84d35c1a37 | ||
|  | ba42e90502 | ||
|  | 10d1ec1bb2 | ||
|  | d6ccd106e6 | ||
|  | 7f7eaea2b1 | ||
|  | d33b1eb394 | ||
|  | feb984649f | ||
|  | aada49e548 | ||
|  | 7f3c34178b | ||
|  | c79dd43105 | ||
|  | cb53ff880d | ||
|  | 3d88b3c74b | ||
|  | d3c66714c2 | ||
|  | e8ca443697 | ||
|  | 94089113ef | ||
|  | 1847fc2060 | ||
|  | 7ca21b52a0 | ||
|  | 444beb4908 | ||
|  | 791869ca9e | ||
|  | 33c8406b8a | ||
|  | b6212c4e98 | ||
|  | fcd2409ee3 | ||
|  | dad060d0c9 | ||
|  | 9444195de7 | ||
|  | b25f3094b7 | ||
|  | ec378a8fc5 | ||
|  | 9adf9a841c | ||
|  | 8bb8e011f3 | ||
|  | 3b66522a5e | ||
|  | dd2b718974 | ||
|  | 50121153dd | ||
|  | 189b7e20db | ||
|  | 5e572a8c6a | ||
|  | dd654fcd8d | ||
|  | 0f9a529647 | ||
|  | 5854adb806 | ||
|  | c60c738c7e | ||
|  | ec40d20e6a | ||
|  | 3e2b777c30 | ||
|  | 4a02981c09 | ||
|  | 3382ccc7bf | ||
|  | 581303c923 | ||
|  | 63dd79e23c | ||
|  | 2346230d36 | ||
|  | 1c451fb98a | ||
|  | 7eeb43a83b | ||
|  | fa2188f087 | ||
|  | df1b87e3ac | ||
|  | 62a0a44049 | ||
|  | 0ae25d2212 | ||
|  | 620e6012da | ||
|  | 330b17bff8 | ||
|  | 1969ce562a | ||
|  | 5ea15cc7eb | ||
|  | 88aa76bcab | ||
|  | 401120fa28 | ||
|  | 534113b303 | ||
|  | 53df7835d3 | ||
|  | ee9afb7fa0 | ||
|  | 6163ab8c42 | ||
|  | e73724a576 | ||
|  | e71284d887 | ||
|  | 11d95b89e1 | ||
|  | ee7052ebc2 | ||
|  | 9059642738 | ||
|  | fe8e3b4489 | ||
|  | 4e00e5b995 | ||
|  | 05ae0ca9d7 | ||
|  | ac0116109b | ||
|  | 710ed9dd0e | ||
|  | c75d2435fa | ||
|  | 050aa40e20 | ||
|  | cb6d87302d | ||
|  | f9e725bcf8 | ||
|  | a56d622df7 | ||
|  | 267f5105b2 | ||
|  | 4e2ffad70d | ||
|  | 7db3bde933 | ||
|  | a9564f8f38 | ||
|  | 9c5a130ab4 | ||
|  | c40398df5d | ||
|  | 27fdd9e715 | ||
|  | 59697095b1 | ||
|  | a16f5f5505 | ||
|  | 922d484a33 | ||
|  | f63f24ac9d | ||
|  | e7521fe30c | ||
|  | f6579ac434 | ||
|  | e1b4a0b720 | ||
|  | 9c43d661be | ||
|  | d2d8bff9f7 | ||
|  | a1beb13094 | ||
|  | 37d66848d6 | ||
|  | 991399fe4f | ||
|  | 27855456a0 | ||
|  | 0687ed9ec4 | ||
|  | 632976e71f | ||
|  | 98addef614 | ||
|  | c72c9934b5 | ||
|  | 6362f24ae9 | ||
|  | dc2d2fe25b | ||
|  | bbc007e6cf | ||
|  | 3dfd195630 | ||
|  | e3f72baab3 | ||
|  | 1bb19d0d9e | ||
|  | bc1b69a836 | ||
|  | 26c7f0b017 | ||
|  | d058dbe9af | ||
|  | c1c237402a | ||
|  | bb20de6c24 | ||
|  | 8d7af7b01d | ||
|  | fd1c122cd4 | ||
|  | 3925ba3eef | ||
|  | 4306072ca7 | ||
|  | 15fba23ad7 | ||
|  | 04753226e5 | ||
|  | 3fda97a9bd | ||
|  | 26afdd105f | ||
|  | 7c50251c37 | ||
|  | 3de9d07769 | ||
|  | d60899e362 | ||
|  | 7c8019ac5b | ||
|  | 1258d0cf7d | ||
|  | 2264369e9e | ||
|  | e18a8556c1 | ||
|  | 5436011f8e | ||
|  | ce0fd3cec2 | ||
|  | bd349f5abc | ||
|  | 7fdea613ff | ||
|  | 16beeb2e88 | ||
|  | ae74f8ea83 | ||
|  | 88b748e67b | ||
|  | 3254069999 | ||
|  | 0bfa9f0c58 | ||
|  | 498ffa806d | ||
|  | 9bfed2a80d | ||
|  | ec902c5762 | ||
|  | bb1d31f877 | ||
|  | 09f938fb72 | ||
|  | a3e9192998 | ||
|  | 80b7c0b4c9 | ||
|  | f01d6938f3 | ||
|  | ab95d707a3 | ||
|  | 6475b4029a | ||
|  | f646b3dc5c | ||
|  | bcef0802e4 | ||
|  | 47099cc77b | ||
|  | 793102f3ad | ||
|  | 6f29bdf355 | ||
|  | edf53c8a0f | ||
|  | 24859e33c1 | ||
|  | ebcf4315f7 | ||
|  | 135e2bb10e | ||
|  | 72a256eccf | ||
|  | 1e991c0526 | ||
|  | 978e6b9dde | ||
|  | a2acb3cbb7 | ||
|  | 623fcce3d1 | ||
|  | c99ef4a549 | ||
|  | c629ce6ef8 | ||
|  | 35743de0df | ||
|  | 5cf182cf98 | ||
|  | 01022546e8 | ||
|  | 83be42f4ea | ||
|  | ab9fec0186 | ||
|  | c6dd32ea7b | ||
|  | 1d4cd538ac | ||
|  | dc99f725f9 | ||
|  | 2f804f3eac | ||
|  | 4b9688af04 | ||
|  | 897b896c11 | ||
|  | 3600b46824 | ||
|  | 9266fe63b9 | ||
|  | a3ea52968f | ||
|  | a06f2aeb8b | ||
|  | f4a56d4e19 | ||
|  | f3f7ff5622 | ||
|  | dbf016adaf | ||
|  | 0e5108bd08 | ||
|  | cf1180faa9 | ||
|  | 1b25275b2e | ||
|  | 886c694db7 | ||
|  | 3d38a2aa14 | ||
|  | 51d879ba6f | ||
|  | 91ae9d75f7 | ||
|  | 42559364e4 | ||
|  | 9d6bb306e7 | ||
|  | c92860ae49 | ||
|  | b012624b67 | ||
|  | 5f1d2f02ee | ||
|  | 46cb869237 | ||
|  | 054c497678 | ||
|  | 8362424976 | ||
|  | f7a0dc00e8 | ||
|  | e49c4655a6 | ||
|  | 1dcb3b1529 | ||
|  | cc474f39d8 | ||
|  | 113d36f5dd | ||
|  | 63c0841c32 | ||
|  | 4739e2e3b2 | ||
|  | aa316091e6 | ||
|  | 2297721228 | ||
|  | 03ab912495 | ||
|  | d12dfabd0b | ||
|  | ed748bbebd | ||
|  | e85858d22d | ||
|  | 0afa9717e5 | ||
|  | 1e2e3498c6 | ||
|  | 59a01b816c | ||
|  | 508f46af42 | ||
|  | 1af865a577 | ||
|  | 74834af222 | ||
|  | f55e33f303 | ||
|  | 5b8394d685 | ||
|  | 34fc30b8db | ||
|  | 6e575df40b | ||
|  | 2689b22674 | ||
|  | 5570f3bdcf | ||
|  | cc7edbe3a7 | ||
|  | fcb77360e1 | ||
|  | c49e84efc6 | ||
|  | 98a4a8d8c6 | ||
|  | 5f73532d62 | ||
|  | d52f9f2a92 | ||
|  | 1cee01a22a | ||
|  | 68dff71512 | ||
|  | 3d285e105e | ||
|  | f92948d65c | ||
|  | c4d771f2c6 | ||
|  | 566ffbdde2 | ||
|  | 5cf18ae17c | ||
|  | 4891721cc0 | ||
|  | 49b189e7a9 | ||
|  | a9c5a3105f | ||
|  | c13f5a9b04 | ||
|  | 12f805c020 | ||
|  | c2a5f437fd | ||
|  | 1c986e2bf6 | ||
|  | 09fd1c7628 | ||
|  | ecf44deecf | ||
|  | 5fb843268f | ||
|  | ffb90c2b4b | ||
|  | bb55544f25 | ||
|  | 2e9e9a60bf | ||
|  | f7e77cd6cb | ||
|  | a7a94789e6 | ||
|  | 864ac1a270 | ||
|  | fbec6d8873 | ||
|  | 5f647a932d | ||
|  | 6e5046c0d4 | ||
|  | 3c9a8e38d3 | ||
|  | b3a3196136 | ||
|  | 3229b7d106 | ||
|  | 4213c377f8 | ||
|  | 86365ebd44 | ||
|  | 20cf685174 | ||
|  | aeb5a7b251 | ||
|  | 47a50bb449 | ||
|  | a2a5b67496 | ||
|  | a94cc5bdab | ||
|  | 526c5a6dd8 | ||
|  | 3f5239706f | ||
|  | d2761abd04 | ||
|  | 57983b54d2 | ||
|  | 703cf8434a | ||
|  | aa4375e25f | ||
|  | 7d3a672b55 | ||
|  | c08b30a060 | ||
|  | d579e39b40 | ||
|  | b147d4bdeb | ||
|  | 48faa8a813 | ||
|  | ec646809dd | ||
|  | ab48a28635 | ||
|  | 3fd7afbb57 | ||
|  | 4074929c6b | ||
|  | d73e84ea6c | ||
|  | 753f1dc7b6 | ||
|  | 9464667323 | ||
|  | 4d82f2f22d | ||
|  | e3d28e703f | ||
|  | 5f39a314b5 | ||
|  | 43caadc472 | ||
|  | f2ce8b9f3c | ||
|  | 735e91e636 | ||
|  | 4df94d1f20 | ||
|  | 70440520e1 | ||
|  | e49e2d5093 | ||
|  | f0ac301417 | ||
|  | 168ff90e38 | ||
|  | 5e4f529b26 | ||
|  | 0d1bd3e298 | ||
|  | 70f826b737 | ||
|  | 8bd5af3fd2 | ||
|  | dbbae87cd3 | ||
|  | 83fd42aff2 | ||
|  | 93c9383a92 | ||
|  | 7c490d8b72 | ||
|  | b4b5e86a14 | ||
|  | e166b97b8f | ||
|  | 829f382726 | ||
|  | 4ef103063d | ||
|  | fa66e50193 | ||
|  | 255ad96c8b | ||
|  | a12fa1177b | ||
|  | 6fa7cc8201 | ||
|  | 2fff5418a9 | ||
|  | 2e805cd5a3 | ||
|  | 61eaa89de6 | ||
|  | aa0c021f8b | ||
|  | 4fd02db079 | ||
|  | 88bbc7e8c1 | ||
|  | af0ba32dd9 | ||
|  | 938d295bf3 | ||
|  | f82667066f | ||
|  | 03a7fe1282 | ||
|  | 0c0504ffd1 | ||
|  | e4900ce87b | ||
|  | 04de87722b | ||
|  | a95e28c085 | ||
|  | 9fbcfb0f0f | ||
|  | f24a3442fb | ||
|  | 918a945e3b | ||
|  | 3b96b5779b | ||
|  | a93b20428e | ||
|  | 0522024f6d | ||
|  | f27f135a61 | ||
|  | 6a76136878 | ||
|  | 1766d28fc2 | ||
|  | f51d944bb3 | ||
|  | cabe240e7e | ||
|  | e72fb39c4d | ||
|  | 0ca30e0e87 | ||
|  | cc362393be | ||
|  | 40bfd827d2 | ||
|  | a4046fbf6e | ||
|  | 28605f2687 | ||
|  | 2085d1bbba | ||
|  | 08db03800e | ||
|  | 04b7e0cde9 | ||
|  | 401260d3ca | ||
|  | 53e0c05290 | ||
|  | cdbb89482e | ||
|  | e290635ba5 | ||
|  | e340e6f5e3 | ||
|  | 2d950e8f3a | ||
|  | 4c70d72ba2 | ||
|  | 80edc4c4e0 | ||
|  | 4d07a1aab6 | ||
|  | e2cd357319 | ||
|  | 620b57bfa6 | ||
|  | 934c9d3df8 | ||
|  | f034e8bb37 | ||
|  | 93f80c6837 | ||
|  | a54177fee0 | ||
|  | 0e6ad42923 | ||
|  | b0beb74011 | ||
|  | 4857fecc41 | ||
|  | 8405d960be | ||
|  | b9101c9fb2 | ||
|  | e457e6a2f2 | ||
|  | f3416fa03e | ||
|  | 3e5ab2b1e1 | ||
|  | 5c0bc9a7c2 | ||
|  | 2adfa55acd | ||
|  | 8125e8afcd | ||
|  | e328f18558 | ||
|  | cbdfa9079c | ||
|  | e08c4515a7 | ||
|  | 650aa16b89 | ||
|  | 11d908218b | ||
|  | 3627a7dc93 | ||
|  | 1e1c8cc4ff | ||
|  | d616bc09c9 | ||
|  | f1cef44d5d | ||
|  | 3795be4750 | ||
|  | 2bb66a7526 | ||
|  | 28a472782f | ||
|  | a4da002352 | ||
|  | 94fdc2beee | ||
|  | dd4a01d9f8 | ||
|  | a2a6c67350 | ||
|  | 2152ca7ba6 | ||
|  | 40e4d236f4 | ||
|  | 0450cd080d | ||
|  | 1eaac79d63 | ||
|  | 19c0305ed9 | ||
|  | f0d14a966a | ||
|  | 37e6ccdc1a | ||
|  | 06cea99b40 | ||
|  | 1851336862 | ||
|  | 461eb273d9 | ||
|  | 470edc4d70 | ||
|  | 26132a2a56 | ||
|  | d92bd16042 | ||
|  | 1c7dfa6c91 | ||
|  | 3a3fed4314 | ||
|  | 82bdb76d75 | ||
|  | 066f3ea078 | ||
|  | 9d760a21d5 | ||
|  | 976c795ac6 | ||
|  | ed320e4e24 | ||
|  | 3111738700 | ||
|  | 1fa0bada23 | ||
|  | 11eca7e58b | ||
|  | 4b50e2f14d | ||
|  | 63faba9603 | ||
|  | 3e213699e0 | ||
|  | c88ff07691 | ||
|  | b53aa5cf6e | ||
|  | 2641b9b3fe | ||
|  | 3a2a73992c | ||
|  | b82b17a701 | ||
|  | a6202edcd1 | ||
|  | 6eac0cb75d | ||
|  | 83672d6138 | ||
|  | 51dadf72d0 | ||
|  | 0cbf61acb3 | ||
|  | 399c7435ac | ||
|  | d51fae7878 | ||
|  | 9750e25ad5 | ||
|  | 2f9b2f0e8f | ||
|  | 8deaf22544 | ||
|  | b192f43187 | ||
|  | 8cb8d1303c | ||
|  | 5237348975 | ||
|  | 72e2f6757e | ||
|  | cf059e7f86 | ||
|  | 44d69216b6 | ||
|  | c38bf09af0 | ||
|  | 9373d47e86 | ||
|  | 29350628c3 | ||
|  | 83d1a68879 | ||
|  | f188408099 | ||
|  | 449ab3a798 | ||
|  | 21504d1417 | ||
|  | 3060b496e3 | ||
|  | bd35539fa1 | ||
|  | df6447e3ad | ||
|  | 24fd898f0d | ||
|  | 1aa6238288 | ||
|  | c16c4788da | ||
|  | 0c35daab85 | ||
|  | 4a19639e92 | ||
|  | 36cceea677 | ||
|  | 4dbc76790a | ||
|  | b32a344a21 | ||
|  | 3896ab822f | ||
|  | cfa4ba57d4 | ||
|  | da051e0269 | ||
|  | 3eda77a91f | ||
|  | 5c2f4be5dd | ||
|  | 435b501db9 | ||
|  | 5a27ffef5f | ||
|  | 02256d9a45 | ||
|  | 7e069009d6 | ||
|  | 3c25cda4c0 | ||
|  | 70d7ad0b1a | ||
|  | e793b2f661 | ||
|  | 917ea3e401 | ||
|  | 5a54dd666f | ||
|  | 733ec2c145 | ||
|  | e386b03b90 | ||
|  | 25d5d51085 | ||
|  | 50c4301a34 | ||
|  | 0f60c0696b | ||
|  | 3ec2947c4f | ||
|  | e89162838e | ||
|  | 72181090a5 | ||
|  | 72b2a5cc0d | ||
|  | 1eaeec8100 | ||
|  | 660db3b3ab | ||
|  | 89d2fcb81e | ||
|  | ccda623840 | ||
|  | a6e7dff61e | ||
|  | 86d1bbe8ff | ||
|  | a10cb06f14 | ||
|  | dd9a62818b | ||
|  | c0e936675c | ||
|  | b0b788b7dc | ||
|  | 18f0f3ecac | ||
|  | e7d745ac94 | ||
|  | 24abf7f0ed | ||
|  | 36fb097d1d | ||
|  | 35ef5fd0d3 | ||
|  | 9a08f6534b | ||
|  | 885dd2053b | ||
|  | 6f6f280bdd | ||
|  | a3e8fd374f | ||
|  | f91c1f4180 | ||
|  | d85746c1b9 | ||
|  | 5a17075eef | ||
|  | 6cab47fb55 | ||
|  | 93c5413790 | ||
|  | f2db7baeba | ||
|  | a507991808 | ||
|  | 7c86f90ac6 | ||
|  | 1e9b772692 | ||
|  | 096ab52216 | ||
|  | 88c3cd5cdd | ||
|  | 99a911a220 | ||
|  | 3218ab971b | ||
|  | 274e3c1f7f | ||
|  | f8916a6e35 | ||
|  | 73f20d01e4 | ||
|  | 2fd3a875b6 | ||
|  | 68cba8d3b2 | ||
|  | 6b28fd405e | ||
|  | 3bccbabe53 | ||
|  | c97c66ed8a | ||
|  | 4b212232c8 | ||
|  | ac3a8edf2b | ||
|  | b581025bbe | ||
|  | 7bc5331747 | ||
|  | 2415976475 | ||
|  | 8d0d0f0449 | ||
|  | 16b00ed160 | ||
|  | df73a420f9 | ||
|  | 1e4d57f275 | ||
|  | 19a238c8d3 | ||
|  | 5ffd8a79eb | ||
|  | 04fbc82d7c | ||
|  | 3f105f7b8b | ||
|  | b9193a5562 | ||
|  | e1fa188244 | ||
|  | 80ad87671a | ||
|  | b6d5a6ec2e | ||
|  | 759398d804 | ||
|  | c1b30db3d1 | ||
|  | 0c8bfc39ef | ||
|  | 3815fddb27 | ||
|  | b585a64a38 | ||
|  | 58e58c192f | ||
|  | 5939344378 | ||
|  | ad85ee3531 | ||
|  | 349f19fef7 | ||
|  | d5777a024e | ||
|  | b7f4ee6171 | ||
|  | a83c4e3970 | ||
|  | 5a767dae34 | ||
|  | 9f93d30b99 | ||
|  | dff525edc6 | ||
|  | 26da431320 | ||
|  | cde4622693 | ||
|  | 5ede7ecc69 | ||
|  | b607d1e628 | ||
|  | d7e36bdf93 | ||
|  | 2b8b185b5b | ||
|  | 927ebcbec9 | ||
|  | ea1397de63 | ||
|  | ce1f5c6204 | ||
|  | 652114c7b5 | ||
|  | 17cd2128fd | ||
|  | bc4378cb3e | ||
|  | 513878dfef | ||
|  | 753d5529b2 | ||
|  | 9f217b88e4 | ||
|  | d53faa8c01 | ||
|  | a934760960 | ||
|  | 82914fc2aa | ||
|  | db687197de | ||
|  | efd713dc61 | ||
|  | 3f3c7cfe88 | ||
|  | 73ca285b7a | ||
|  | 168d25c020 | ||
|  | e8ae5486c8 | ||
|  | f049b8b915 | ||
|  | 4e755dc537 | ||
|  | 5351310a38 | ||
|  | 211ca43a82 | ||
|  | e5235e7f22 | ||
|  | e72298f0b4 | ||
|  | 3abf5c65c6 | ||
|  | 268acb0b88 | ||
|  | 196b3b873f | ||
|  | 4d9801a372 | ||
|  | bd710ba665 | ||
|  | afe369c876 | ||
|  | 206007bbce | ||
|  | 8ad05b92c0 | ||
|  | 735da2a855 | ||
|  | 980077f559 | ||
|  | 12053e75bb | ||
|  | 62372ed4c5 | ||
|  | e5caf37697 | ||
|  | befc5a9530 | ||
|  | 1e00407864 | ||
|  | 73038efccf | ||
|  | 6d37e19b40 | ||
|  | 2c33ef2b0d | ||
|  | 6c30e0836f | ||
|  | 5f77ca31bd | ||
|  | f7c82d6b09 | ||
|  | 86dd9aa42a | ||
|  | 5daca270e4 | ||
|  | e18813a4bf | ||
|  | 4aa7e211f3 | ||
|  | 419dc7edfb | ||
|  | eaa84a6b39 | ||
|  | 1d0503d0e4 | ||
|  | f7f98aa9a3 | ||
|  | 575d14261a | ||
|  | 9aab606deb | ||
|  | 2e11681b52 | ||
|  | 8cca6637f7 | ||
|  | 82e076378c | ||
|  | 94ddad3c49 | ||
|  | d35dbca18b | ||
|  | 7468d6147a | ||
|  | 7c78d749de | ||
|  | 85dd99a3c4 | ||
|  | 0a9c0234e2 | ||
|  | fad77ba5a0 | ||
|  | 12723f3216 | ||
|  | a43140515f | ||
|  | 3e3cc8c541 | ||
|  | a85141ace2 | ||
|  | c33280bbb2 | ||
|  | df3aa04787 | ||
|  | 4bd25a0d4a | ||
|  | 7fadf4c6e1 | ||
|  | d1538508e8 | ||
|  | b24d786933 | ||
|  | 8f69b87dd1 | ||
|  | 9b1da8c311 | ||
|  | 8287063aab | ||
|  | e4a8258acf | ||
|  | 5e88043c7b | ||
|  | bedf9112fb | ||
|  | 03681d23c5 | ||
|  | 21683db0b8 | ||
|  | 978d829150 | ||
|  | cc05572a35 | ||
|  | c5bb310613 | ||
|  | 77551b1fed | ||
|  | 70728c274e | ||
|  | cee4714665 | ||
|  | c3eca3b626 | ||
|  | 01e4cd2e78 | ||
|  | b99d01ad7b | ||
|  | bf0213907e | ||
|  | eff5b6459d | ||
|  | 8e29b5eed6 | ||
|  | c91748da15 | ||
|  | f04f9dc262 | ||
|  | e873cdab7e | ||
|  | f9b6fd6ac5 | ||
|  | aa191e110c | ||
|  | dd09907925 | ||
|  | da4810672d | ||
|  | f772f59d7c | ||
|  | 1964fb90d5 | ||
|  | 5945f2860a | ||
|  | f45da049b9 | ||
|  | c0beab8a5d | ||
|  | cabeb13adb | ||
|  | e2e9721d5f | ||
|  | 4e9deab605 | ||
|  | 9bb048fb01 | ||
|  | 6849f80506 | ||
|  | 5597f4e2e0 | ||
|  | 35e9508bde | ||
|  | 45fbcec805 | ||
|  | 4c8da70ef3 | ||
|  | ed5da5cd4a | ||
|  | dc5fccdbcd | ||
|  | 91aea333c7 | ||
|  | a0de01cff1 | ||
|  | a41ed34193 | ||
|  | 49e8811c18 | ||
|  | 488563a82e | ||
|  | d76d50f30e | ||
|  | 4685aef88d | ||
|  | a106510924 | ||
|  | 9d54503ef7 | ||
|  | b1449eebf3 | ||
|  | b213453062 | ||
|  | 076c0321cf | ||
|  | 4d71b73f38 | ||
|  | b20ffdf7db | ||
|  | ef018e22d6 | ||
|  | 3fa290a257 | ||
|  | cdde530b60 | ||
|  | aa608510d0 | ||
|  | 009fd63ce9 | ||
|  | bea352855a | ||
|  | 51e8a80ca3 | ||
|  | 8a543d4513 | ||
|  | 945e180a6f | ||
|  | b93fa332d3 | ||
|  | 9e947f742d | ||
|  | 033e90f8b7 | ||
|  | be576176c5 | ||
|  | 4da3e8a4d8 | ||
|  | db2bf537ea | ||
|  | 9a4fdcaef2 | ||
|  | ca40360f7d | ||
|  | 799e705ff8 | ||
|  | a1b18c7f97 | ||
|  | 9958a6e1bf | ||
|  | 1fc6d8aca7 | ||
|  | 3e9ec2d943 | ||
|  | 1420def1c3 | ||
|  | 3b4184e765 | ||
|  | 4ce9102f93 | ||
|  | eb27ec2234 | ||
|  | b70e25d348 | ||
|  | 772c0bbe1a | ||
|  | 144021c053 | ||
|  | 59486cd55d | ||
|  | afe3904ea3 | 
| @@ -1,6 +1,6 @@ | ||||
| root = true | ||||
|  | ||||
| [*.{js,ts}] | ||||
| [*.{js,ts,tsx}] | ||||
| charset = utf-8 | ||||
| end_of_line = lf | ||||
| indent_size = 4 | ||||
|   | ||||
							
								
								
									
										5
									
								
								.github/actions/build-electron/action.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								.github/actions/build-electron/action.yml
									
									
									
									
										vendored
									
									
								
							| @@ -74,7 +74,7 @@ runs: | ||||
|  | ||||
|   - name: Update build info | ||||
|     shell: ${{ inputs.shell }} | ||||
|     run: npm run chore:update-build-info | ||||
|     run: pnpm run chore:update-build-info | ||||
|  | ||||
|   # Critical debugging configuration | ||||
|   - name: Run electron-forge build with enhanced logging | ||||
| @@ -86,7 +86,8 @@ runs: | ||||
|       APPLE_ID_PASSWORD: ${{ env.APPLE_ID_PASSWORD }} | ||||
|       WINDOWS_SIGN_EXECUTABLE: ${{ env.WINDOWS_SIGN_EXECUTABLE }} | ||||
|       TRILIUM_ARTIFACT_NAME_HINT: TriliumNotes-${{ github.ref_name }}-${{ inputs.os }}-${{ inputs.arch }} | ||||
|     run: pnpm nx --project=desktop electron-forge:make -- --arch=${{ inputs.arch }} --platform=${{ inputs.forge_platform }} | ||||
|       TARGET_ARCH: ${{ inputs.arch }} | ||||
|     run: pnpm run --filter desktop electron-forge:make --arch=${{ inputs.arch }} --platform=${{ inputs.forge_platform }} | ||||
|  | ||||
|   # Add DMG signing step | ||||
|   - name: Sign DMG | ||||
|   | ||||
							
								
								
									
										4
									
								
								.github/actions/build-server/action.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/actions/build-server/action.yml
									
									
									
									
										vendored
									
									
								
							| @@ -10,7 +10,7 @@ runs: | ||||
|   steps: | ||||
|   - uses: pnpm/action-setup@v4 | ||||
|   - name: Set up node & dependencies | ||||
|     uses: actions/setup-node@v4 | ||||
|     uses: actions/setup-node@v5 | ||||
|     with: | ||||
|       node-version: 22 | ||||
|       cache: "pnpm" | ||||
| @@ -23,7 +23,7 @@ runs: | ||||
|     shell: bash | ||||
|     run: | | ||||
|       pnpm run chore:update-build-info | ||||
|       pnpm nx --project=server package | ||||
|       pnpm run --filter server package | ||||
|   - name: Prepare artifacts | ||||
|     shell: bash | ||||
|     run: | | ||||
|   | ||||
							
								
								
									
										40
									
								
								.github/instructions/nx.instructions.md
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										40
									
								
								.github/instructions/nx.instructions.md
									
									
									
									
										vendored
									
									
								
							| @@ -1,40 +0,0 @@ | ||||
| --- | ||||
| applyTo: '**' | ||||
| --- | ||||
|  | ||||
| // This file is automatically generated by Nx Console | ||||
|  | ||||
| You are in an nx workspace using Nx 21.3.9 and pnpm as the package manager. | ||||
|  | ||||
| You have access to the Nx MCP server and the tools it provides. Use them. Follow these guidelines in order to best help the user: | ||||
|  | ||||
| # General Guidelines | ||||
| - When answering questions, use the nx_workspace tool first to gain an understanding of the workspace architecture | ||||
| - For questions around nx configuration, best practices or if you're unsure, use the nx_docs tool to get relevant, up-to-date docs!! Always use this instead of assuming things about nx configuration | ||||
| - If the user needs help with an Nx configuration or project graph error, use the 'nx_workspace' tool to get any errors | ||||
| - To help answer questions about the workspace structure or simply help with demonstrating how tasks depend on each other, use the 'nx_visualize_graph' tool | ||||
|  | ||||
| # Generation Guidelines | ||||
| If the user wants to generate something, use the following flow: | ||||
|  | ||||
| - learn about the nx workspace and any specifics the user needs by using the 'nx_workspace' tool and the 'nx_project_details' tool if applicable | ||||
| - get the available generators using the 'nx_generators' tool | ||||
| - decide which generator to use. If no generators seem relevant, check the 'nx_available_plugins' tool to see if the user could install a plugin to help them | ||||
| - get generator details using the 'nx_generator_schema' tool | ||||
| - you may use the 'nx_docs' tool to learn more about a specific generator or technology if you're unsure | ||||
| - decide which options to provide in order to best complete the user's request. Don't make any assumptions and keep the options minimalistic | ||||
| - open the generator UI using the 'nx_open_generate_ui' tool | ||||
| - wait for the user to finish the generator | ||||
| - read the generator log file using the 'nx_read_generator_log' tool | ||||
| - use the information provided in the log file to answer the user's question or continue with what they were doing | ||||
|  | ||||
| # Running Tasks Guidelines | ||||
| If the user wants help with tasks or commands (which include keywords like "test", "build", "lint", or other similar actions), use the following flow: | ||||
| - Use the 'nx_current_running_tasks_details' tool to get the list of tasks (this can include tasks that were completed, stopped or failed). | ||||
| - If there are any tasks, ask the user if they would like help with a specific task then use the 'nx_current_running_task_output' tool to get the terminal output for that task/command | ||||
| - Use the terminal output from 'nx_current_running_task_output' to see what's wrong and help the user fix their problem. Use the appropriate tools if necessary | ||||
| - If the user would like to rerun the task or command, always use `nx run <taskId>` to rerun in the terminal. This will ensure that the task will run in the nx context and will be run the same way it originally executed | ||||
| - If the task was marked as "continuous" do not offer to rerun the task. This task is already running and the user can see the output in the terminal. You can use 'nx_current_running_task_output' to get the output of the task to verify the output.  | ||||
|  | ||||
|  | ||||
|  | ||||
							
								
								
									
										188
									
								
								.github/workflows/deploy-docs.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										188
									
								
								.github/workflows/deploy-docs.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,188 @@ | ||||
| # GitHub Actions workflow for deploying MkDocs documentation to Cloudflare Pages | ||||
| # This workflow builds and deploys your MkDocs site when changes are pushed to main | ||||
| name: Deploy MkDocs Documentation | ||||
|  | ||||
| on: | ||||
|   # Trigger on push to main branch | ||||
|   push: | ||||
|     branches: | ||||
|       - main | ||||
|       - master  # Also support master branch | ||||
|     # Only run when docs files change | ||||
|     paths: | ||||
|       - 'docs/**' | ||||
|       - 'README.md'  # README is synced to docs/index.md | ||||
|       - 'mkdocs.yml' | ||||
|       - 'requirements-docs.txt' | ||||
|       - '.github/workflows/deploy-docs.yml' | ||||
|       - 'scripts/fix-mkdocs-structure.ts' | ||||
|    | ||||
|   # Allow manual triggering from Actions tab | ||||
|   workflow_dispatch: | ||||
|    | ||||
|   # Run on pull requests for preview deployments | ||||
|   pull_request: | ||||
|     branches: | ||||
|       - main | ||||
|       - master | ||||
|     paths: | ||||
|       - 'docs/**' | ||||
|       - 'README.md'  # README is synced to docs/index.md | ||||
|       - 'mkdocs.yml' | ||||
|       - 'requirements-docs.txt' | ||||
|       - '.github/workflows/deploy-docs.yml' | ||||
|       - 'scripts/fix-mkdocs-structure.ts' | ||||
|  | ||||
| jobs: | ||||
|   build-and-deploy: | ||||
|     name: Build and Deploy MkDocs | ||||
|     runs-on: ubuntu-latest | ||||
|     timeout-minutes: 10 | ||||
|      | ||||
|     # Required permissions for deployment | ||||
|     permissions: | ||||
|       contents: read | ||||
|       deployments: write | ||||
|       pull-requests: write # For PR preview comments | ||||
|       id-token: write # For OIDC authentication (if needed) | ||||
|      | ||||
|     steps: | ||||
|       - name: Checkout Repository | ||||
|         uses: actions/checkout@v5 | ||||
|         with: | ||||
|           fetch-depth: 0 # Fetch all history for git info and mkdocs-git-revision-date plugin | ||||
|        | ||||
|       - name: Setup Python | ||||
|         uses: actions/setup-python@v6 | ||||
|         with: | ||||
|           python-version: '3.13' | ||||
|           cache: 'pip' | ||||
|           cache-dependency-path: 'requirements-docs.txt' | ||||
|        | ||||
|       - name: Install MkDocs and Dependencies | ||||
|         run: | | ||||
|           pip install --upgrade pip | ||||
|           pip install -r requirements-docs.txt | ||||
|         env: | ||||
|           PIP_DISABLE_PIP_VERSION_CHECK: 1 | ||||
|        | ||||
|       # Setup pnpm before fixing docs structure | ||||
|       - name: Setup pnpm | ||||
|         uses: pnpm/action-setup@v4 | ||||
|        | ||||
|       # Setup Node.js with pnpm | ||||
|       - name: Setup Node.js | ||||
|         uses: actions/setup-node@v5 | ||||
|         with: | ||||
|           node-version: '22' | ||||
|           cache: 'pnpm' | ||||
|        | ||||
|       # Install Node.js dependencies for the TypeScript script | ||||
|       - name: Install Dependencies | ||||
|         run: | | ||||
|           pnpm install --frozen-lockfile | ||||
|        | ||||
|       - name: Fix Documentation Structure | ||||
|         run: | | ||||
|           # Fix duplicate navigation entries by moving overview pages to index.md | ||||
|           pnpm run chore:fix-mkdocs-structure | ||||
|        | ||||
|       - name: Build MkDocs Site | ||||
|         run: | | ||||
|           # Build with strict mode but allow expected warnings | ||||
|           mkdocs build --verbose || { | ||||
|             EXIT_CODE=$? | ||||
|             # Check if the only issue is expected warnings | ||||
|             if mkdocs build 2>&1 | grep -E "WARNING.*(README|not found)" && \ | ||||
|                [ $(mkdocs build 2>&1 | grep -c "ERROR") -eq 0 ]; then | ||||
|               echo "✅ Build succeeded with expected warnings" | ||||
|               mkdocs build --verbose | ||||
|             else | ||||
|               echo "❌ Build failed with unexpected errors" | ||||
|               exit $EXIT_CODE | ||||
|             fi | ||||
|           } | ||||
|  | ||||
|       - name: Fix HTML Links | ||||
|         run: | | ||||
|           # Remove .md extensions from links in generated HTML | ||||
|           pnpm tsx ./scripts/fix-html-links.ts site | ||||
|  | ||||
|       - name: Validate Built Site | ||||
|         run: | | ||||
|           # Basic validation that important files exist | ||||
|           test -f site/index.html || (echo "ERROR: site/index.html not found" && exit 1) | ||||
|           test -f site/sitemap.xml || (echo "ERROR: site/sitemap.xml not found" && exit 1) | ||||
|           test -d site/assets || (echo "ERROR: site/assets directory not found" && exit 1) | ||||
|           echo "✅ Site validation passed" | ||||
|        | ||||
|       # Install wrangler globally to avoid workspace issues | ||||
|       - name: Install Wrangler | ||||
|         run: | | ||||
|           npm install -g wrangler | ||||
|        | ||||
|       # Deploy using Wrangler (use pre-installed wrangler) | ||||
|       - name: Deploy to Cloudflare Pages | ||||
|         id: deploy | ||||
|         if: github.event_name == 'push' || github.event_name == 'workflow_dispatch' | ||||
|         uses: cloudflare/wrangler-action@v3 | ||||
|         with: | ||||
|           apiToken: ${{ secrets.CLOUDFLARE_API_TOKEN }} | ||||
|           accountId: ${{ secrets.CLOUDFLARE_ACCOUNT_ID }} | ||||
|           command: pages deploy site --project-name=trilium-docs --branch=${{ github.ref_name }} | ||||
|           wranglerVersion: ''  # Use pre-installed version | ||||
|        | ||||
|       # Deploy preview for PRs | ||||
|       - name: Deploy Preview to Cloudflare Pages | ||||
|         id: preview-deployment | ||||
|         if: github.event_name == 'pull_request' | ||||
|         uses: cloudflare/wrangler-action@v3 | ||||
|         with: | ||||
|           apiToken: ${{ secrets.CLOUDFLARE_API_TOKEN }} | ||||
|           accountId: ${{ secrets.CLOUDFLARE_ACCOUNT_ID }} | ||||
|           command: pages deploy site --project-name=trilium-docs --branch=pr-${{ github.event.pull_request.number }} | ||||
|           wranglerVersion: ''  # Use pre-installed version | ||||
|        | ||||
|       # Post deployment URL as PR comment | ||||
|       - name: Comment PR with Preview URL | ||||
|         if: github.event_name == 'pull_request' | ||||
|         uses: actions/github-script@v8 | ||||
|         with: | ||||
|           github-token: ${{ secrets.GITHUB_TOKEN }} | ||||
|           script: | | ||||
|             const prNumber = context.issue.number; | ||||
|             // Construct preview URL based on Cloudflare Pages pattern | ||||
|             const previewUrl = `https://pr-${prNumber}.trilium-docs.pages.dev`; | ||||
|             const mainUrl = 'https://docs.triliumnotes.org'; | ||||
|              | ||||
|             // Check if we already commented | ||||
|             const comments = await github.rest.issues.listComments({ | ||||
|               owner: context.repo.owner, | ||||
|               repo: context.repo.repo, | ||||
|               issue_number: prNumber | ||||
|             }); | ||||
|              | ||||
|             const botComment = comments.data.find(comment =>  | ||||
|               comment.user.type === 'Bot' &&  | ||||
|               comment.body.includes('Documentation preview is ready') | ||||
|             ); | ||||
|              | ||||
|             const commentBody = `📚 Documentation preview is ready!\n\n🔗 Preview URL: ${previewUrl}\n📖 Production URL: ${mainUrl}\n\n✅ All checks passed\n\n_This preview will be updated automatically with new commits._`; | ||||
|              | ||||
|             if (botComment) { | ||||
|               // Update existing comment | ||||
|               await github.rest.issues.updateComment({ | ||||
|                 owner: context.repo.owner, | ||||
|                 repo: context.repo.repo, | ||||
|                 comment_id: botComment.id, | ||||
|                 body: commentBody | ||||
|               }); | ||||
|             } else { | ||||
|               // Create new comment | ||||
|               await github.rest.issues.createComment({ | ||||
|                 issue_number: prNumber, | ||||
|                 owner: context.repo.owner, | ||||
|                 repo: context.repo.repo, | ||||
|                 body: commentBody | ||||
|               }); | ||||
|             } | ||||
							
								
								
									
										37
									
								
								.github/workflows/dev.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										37
									
								
								.github/workflows/dev.yml
									
									
									
									
										vendored
									
									
								
							| @@ -19,45 +19,24 @@ permissions: | ||||
|   pull-requests: write  # for PR comments | ||||
|  | ||||
| jobs: | ||||
|   check-affected: | ||||
|     name: Check affected jobs (NX) | ||||
|     runs-on: ubuntu-latest | ||||
|     steps: | ||||
|       - name: Checkout the repository | ||||
|         uses: actions/checkout@v5 | ||||
|         with: | ||||
|           fetch-depth: 0  # needed for https://github.com/marketplace/actions/nx-set-shas | ||||
|  | ||||
|       - uses: pnpm/action-setup@v4 | ||||
|       - name: Set up node & dependencies | ||||
|         uses: actions/setup-node@v4 | ||||
|         with: | ||||
|           node-version: 22 | ||||
|           cache: 'pnpm' | ||||
|       - name: Install dependencies | ||||
|         run: pnpm install --frozen-lockfile | ||||
|  | ||||
|       - uses: nrwl/nx-set-shas@v4 | ||||
|       - name: Check affected | ||||
|         run: pnpm nx affected --verbose -t typecheck build rebuild-deps test-build | ||||
|  | ||||
|   test_dev: | ||||
|     name: Test development | ||||
|     runs-on: ubuntu-latest | ||||
|     needs: | ||||
|       - check-affected | ||||
|     steps: | ||||
|       - name: Checkout the repository | ||||
|         uses: actions/checkout@v5 | ||||
|  | ||||
|       - uses: pnpm/action-setup@v4 | ||||
|       - name: Set up node & dependencies | ||||
|         uses: actions/setup-node@v4 | ||||
|         uses: actions/setup-node@v5 | ||||
|         with: | ||||
|           node-version: 22 | ||||
|           cache: "pnpm" | ||||
|       - run: pnpm install --frozen-lockfile | ||||
|  | ||||
|       - name: Typecheck | ||||
|         run: pnpm typecheck | ||||
|  | ||||
|       - name: Run the unit tests | ||||
|         run: pnpm run test:all | ||||
|  | ||||
| @@ -66,7 +45,6 @@ jobs: | ||||
|     runs-on: ubuntu-latest | ||||
|     needs: | ||||
|       - test_dev | ||||
|       - check-affected | ||||
|     steps: | ||||
|       - uses: actions/checkout@v5 | ||||
|       - uses: pnpm/action-setup@v4 | ||||
| @@ -75,7 +53,7 @@ jobs: | ||||
|       - name: Update build info | ||||
|         run: pnpm run chore:update-build-info | ||||
|       - name: Trigger client build | ||||
|         run: pnpm nx run client:build | ||||
|         run: pnpm client:build | ||||
|       - name: Send client bundle stats to RelativeCI | ||||
|         if: false | ||||
|         uses: relative-ci/agent-action@v3 | ||||
| @@ -83,7 +61,7 @@ jobs: | ||||
|           webpackStatsFile: ./apps/client/dist/webpack-stats.json | ||||
|           key: ${{ secrets.RELATIVE_CI_CLIENT_KEY }} | ||||
|       - name: Trigger server build | ||||
|         run: pnpm nx run server:build | ||||
|         run: pnpm run server:build | ||||
|       - uses: docker/setup-buildx-action@v3 | ||||
|       - uses: docker/build-push-action@v6 | ||||
|         with: | ||||
| @@ -95,7 +73,6 @@ jobs: | ||||
|     runs-on: ubuntu-latest | ||||
|     needs: | ||||
|       - build_docker | ||||
|       - check-affected | ||||
|     strategy: | ||||
|       matrix: | ||||
|         include: | ||||
| @@ -112,7 +89,7 @@ jobs: | ||||
|       - name: Update build info | ||||
|         run: pnpm run chore:update-build-info | ||||
|       - name: Trigger build | ||||
|         run: pnpm nx run server:build | ||||
|         run: pnpm server:build | ||||
|  | ||||
|       - name: Set IMAGE_NAME to lowercase | ||||
|         run: echo "IMAGE_NAME=${IMAGE_NAME,,}" >> $GITHUB_ENV | ||||
|   | ||||
							
								
								
									
										14
									
								
								.github/workflows/main-docker.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										14
									
								
								.github/workflows/main-docker.yml
									
									
									
									
										vendored
									
									
								
							| @@ -44,7 +44,7 @@ jobs: | ||||
|  | ||||
|       - uses: pnpm/action-setup@v4 | ||||
|       - name: Set up node & dependencies | ||||
|         uses: actions/setup-node@v4 | ||||
|         uses: actions/setup-node@v5 | ||||
|         with: | ||||
|           node-version: 22 | ||||
|           cache: "pnpm" | ||||
| @@ -82,7 +82,7 @@ jobs: | ||||
|           require-healthy: true | ||||
|  | ||||
|       - name: Run Playwright tests | ||||
|         run: TRILIUM_DOCKER=1 TRILIUM_PORT=8082 pnpm exec nx run server-e2e:e2e | ||||
|         run: TRILIUM_DOCKER=1 TRILIUM_PORT=8082 pnpm --filter=server-e2e e2e | ||||
|  | ||||
|       - name: Upload Playwright trace | ||||
|         if: failure() | ||||
| @@ -144,7 +144,7 @@ jobs: | ||||
|         uses: actions/checkout@v5 | ||||
|       - uses: pnpm/action-setup@v4 | ||||
|       - name: Set up node & dependencies | ||||
|         uses: actions/setup-node@v4 | ||||
|         uses: actions/setup-node@v5 | ||||
|         with: | ||||
|           node-version: 22 | ||||
|           cache: 'pnpm' | ||||
| @@ -152,12 +152,12 @@ jobs: | ||||
|       - name: Install dependencies | ||||
|         run: pnpm install --frozen-lockfile | ||||
|  | ||||
|       - name: Run the TypeScript build | ||||
|         run: pnpm run server:build | ||||
|  | ||||
|       - name: Update build info | ||||
|         run: pnpm run chore:update-build-info | ||||
|  | ||||
|       - name: Run the TypeScript build | ||||
|         run: pnpm run server:build | ||||
|  | ||||
|       - name: Docker meta | ||||
|         id: meta | ||||
|         uses: docker/metadata-action@v5 | ||||
| @@ -211,7 +211,7 @@ jobs: | ||||
|       - name: Upload digest | ||||
|         uses: actions/upload-artifact@v4 | ||||
|         with: | ||||
|           name: digests-${{ env.PLATFORM_PAIR }} | ||||
|           name: digests-${{ env.PLATFORM_PAIR }}-${{ matrix.dockerfile }} | ||||
|           path: /tmp/digests/* | ||||
|           if-no-files-found: error | ||||
|           retention-days: 1 | ||||
|   | ||||
							
								
								
									
										7
									
								
								.github/workflows/nightly.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								.github/workflows/nightly.yml
									
									
									
									
										vendored
									
									
								
							| @@ -51,13 +51,12 @@ jobs: | ||||
|       - uses: actions/checkout@v5 | ||||
|       - uses: pnpm/action-setup@v4 | ||||
|       - name: Set up node & dependencies | ||||
|         uses: actions/setup-node@v4 | ||||
|         uses: actions/setup-node@v5 | ||||
|         with: | ||||
|           node-version: 22 | ||||
|           cache: 'pnpm' | ||||
|       - name: Install dependencies | ||||
|         run: pnpm install --frozen-lockfile | ||||
|       - uses: nrwl/nx-set-shas@v4 | ||||
|       - name: Update nightly version | ||||
|         run: npm run chore:ci-update-nightly-version | ||||
|       - name: Run the build | ||||
| @@ -79,7 +78,7 @@ jobs: | ||||
|           GPG_SIGNING_KEY: ${{ secrets.GPG_SIGN_KEY }} | ||||
|  | ||||
|       - name: Publish release | ||||
|         uses: softprops/action-gh-release@v2.3.2 | ||||
|         uses: softprops/action-gh-release@v2.3.3 | ||||
|         if: ${{ github.event_name != 'pull_request' }} | ||||
|         with: | ||||
|           make_latest: false | ||||
| @@ -120,7 +119,7 @@ jobs: | ||||
|           arch: ${{ matrix.arch }} | ||||
|  | ||||
|       - name: Publish release | ||||
|         uses: softprops/action-gh-release@v2.3.2 | ||||
|         uses: softprops/action-gh-release@v2.3.3 | ||||
|         if: ${{ github.event_name != 'pull_request' }} | ||||
|         with: | ||||
|           make_latest: false | ||||
|   | ||||
							
								
								
									
										22
									
								
								.github/workflows/playwright.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										22
									
								
								.github/workflows/playwright.yml
									
									
									
									
										vendored
									
									
								
							| @@ -19,14 +19,8 @@ jobs: | ||||
|           filter: tree:0 | ||||
|           fetch-depth: 0 | ||||
|  | ||||
|       # This enables task distribution via Nx Cloud | ||||
|       # Run this command as early as possible, before dependencies are installed | ||||
|       # Learn more at https://nx.dev/ci/reference/nx-cloud-cli#npx-nxcloud-startcirun | ||||
|       # Connect your workspace by running "nx connect" and uncomment this line to enable task distribution | ||||
|       # - run: npx nx-cloud start-ci-run --distribute-on="3 linux-medium-js" --stop-agents-after="e2e-ci" | ||||
|  | ||||
|       - uses: pnpm/action-setup@v4 | ||||
|       - uses: actions/setup-node@v4 | ||||
|       - uses: actions/setup-node@v5 | ||||
|         with: | ||||
|           node-version: 22 | ||||
|           cache: 'pnpm' | ||||
| @@ -34,10 +28,12 @@ jobs: | ||||
|       - name: Install dependencies | ||||
|         run: pnpm install --frozen-lockfile | ||||
|       - run: pnpm exec playwright install --with-deps | ||||
|       - uses: nrwl/nx-set-shas@v4 | ||||
|  | ||||
|       # Prepend any command with "nx-cloud record --" to record its logs to Nx Cloud | ||||
|       # - run: npx nx-cloud record -- echo Hello World | ||||
|       # Nx Affected runs only tasks affected by the changes in this PR/commit. Learn more: https://nx.dev/ci/features/affected | ||||
|       # When you enable task distribution, run the e2e-ci task instead of e2e | ||||
|       - run: pnpm exec nx affected -t e2e --exclude desktop-e2e | ||||
|       - run: pnpm --filter server-e2e e2e | ||||
|  | ||||
|       - name: Upload test report | ||||
|         if: failure() | ||||
|         uses: actions/upload-artifact@v4 | ||||
|         with: | ||||
|           name: e2e report | ||||
|           path: apps/server-e2e/test-output | ||||
|   | ||||
							
								
								
									
										18
									
								
								.github/workflows/release.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										18
									
								
								.github/workflows/release.yml
									
									
									
									
										vendored
									
									
								
							| @@ -30,18 +30,30 @@ jobs: | ||||
|             image: win-signing | ||||
|             shell: cmd | ||||
|             forge_platform: win32 | ||||
|         # Exclude ARM64 Linux from default matrix to use native runner | ||||
|         exclude: | ||||
|           - arch: arm64 | ||||
|             os: | ||||
|               name: linux | ||||
|         # Add ARM64 Linux with native ubuntu-24.04-arm runner for better-sqlite3 compatibility | ||||
|         include: | ||||
|           - arch: arm64 | ||||
|             os: | ||||
|               name: linux | ||||
|               image: ubuntu-24.04-arm | ||||
|               shell: bash | ||||
|               forge_platform: linux | ||||
|     runs-on: ${{ matrix.os.image }} | ||||
|     steps: | ||||
|       - uses: actions/checkout@v5 | ||||
|       - uses: pnpm/action-setup@v4 | ||||
|       - name: Set up node & dependencies | ||||
|         uses: actions/setup-node@v4 | ||||
|         uses: actions/setup-node@v5 | ||||
|         with: | ||||
|           node-version: 22 | ||||
|           cache: 'pnpm' | ||||
|       - name: Install dependencies | ||||
|         run: pnpm install --frozen-lockfile | ||||
|       - uses: nrwl/nx-set-shas@v4 | ||||
|       - name: Run the build | ||||
|         uses: ./.github/actions/build-electron | ||||
|         with: | ||||
| @@ -115,7 +127,7 @@ jobs: | ||||
|           path: upload | ||||
|  | ||||
|       - name: Publish stable release | ||||
|         uses: softprops/action-gh-release@v2.3.2 | ||||
|         uses: softprops/action-gh-release@v2.3.3 | ||||
|         with: | ||||
|           draft: false | ||||
|           body_path: docs/Release Notes/Release Notes/${{ github.ref_name }}.md | ||||
|   | ||||
							
								
								
									
										11
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										11
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -1,4 +1,5 @@ | ||||
| # See https://docs.github.com/en/get-started/getting-started-with-git/ignoring-files for more about ignoring files. | ||||
| /.cache | ||||
|  | ||||
| # compiled output | ||||
| dist | ||||
| @@ -32,14 +33,11 @@ testem.log | ||||
| .DS_Store | ||||
| Thumbs.db | ||||
|  | ||||
| .nx/cache | ||||
| .nx/workspace-data | ||||
|  | ||||
| vite.config.*.timestamp* | ||||
| vitest.config.*.timestamp* | ||||
| test-output | ||||
|  | ||||
| apps/*/data | ||||
| apps/*/data* | ||||
| apps/*/out | ||||
| upload | ||||
|  | ||||
| @@ -47,4 +45,7 @@ upload | ||||
| *.tsbuildinfo | ||||
|  | ||||
| /result | ||||
| .svelte-kit | ||||
| .svelte-kit | ||||
|  | ||||
| # docs | ||||
| site/ | ||||
|   | ||||
							
								
								
									
										1
									
								
								.vscode/extensions.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.vscode/extensions.json
									
									
									
									
										vendored
									
									
								
							| @@ -5,7 +5,6 @@ | ||||
|     "lokalise.i18n-ally", | ||||
|     "ms-azuretools.vscode-docker", | ||||
|     "ms-playwright.playwright", | ||||
|     "nrwl.angular-console", | ||||
|     "redhat.vscode-yaml", | ||||
|     "tobermory.es6-string-html", | ||||
|     "vitest.explorer", | ||||
|   | ||||
							
								
								
									
										8
									
								
								.vscode/mcp.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								.vscode/mcp.json
									
									
									
									
										vendored
									
									
								
							| @@ -1,8 +0,0 @@ | ||||
| { | ||||
|   "servers": { | ||||
|     "nx-mcp": { | ||||
|       "type": "http", | ||||
|       "url": "http://localhost:9461/mcp" | ||||
|     } | ||||
|   } | ||||
| } | ||||
							
								
								
									
										3
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.vscode/settings.json
									
									
									
									
										vendored
									
									
								
							| @@ -35,6 +35,5 @@ | ||||
|         "docs/**/*.png": true, | ||||
|         "apps/server/src/assets/doc_notes/**": true, | ||||
|         "apps/edit-docs/demo/**": true | ||||
|     }, | ||||
|     "nxConsole.generateAiAgentRules": true | ||||
|     } | ||||
| } | ||||
							
								
								
									
										5
									
								
								.vscode/snippets.code-snippets
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								.vscode/snippets.code-snippets
									
									
									
									
										vendored
									
									
								
							| @@ -20,5 +20,10 @@ | ||||
|         "scope": "typescript", | ||||
|         "prefix": "jqf", | ||||
|         "body": ["private $${1:name}!: JQuery<HTMLElement>;"] | ||||
|     }, | ||||
|     "region": { | ||||
|         "scope": "css", | ||||
|         "prefix": "region", | ||||
|         "body": ["/* #region ${1:name} */\n$0\n/* #endregion */"] | ||||
|     } | ||||
| } | ||||
|   | ||||
							
								
								
									
										13
									
								
								CLAUDE.md
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								CLAUDE.md
									
									
									
									
									
								
							| @@ -4,7 +4,7 @@ This file provides guidance to Claude Code (claude.ai/code) when working with co | ||||
|  | ||||
| ## Overview | ||||
|  | ||||
| Trilium Notes is a hierarchical note-taking application with advanced features like synchronization, scripting, and rich text editing. It's built as a TypeScript monorepo using NX, with multiple applications and shared packages. | ||||
| Trilium Notes is a hierarchical note-taking application with advanced features like synchronization, scripting, and rich text editing. It's built as a TypeScript monorepo using pnpm, with multiple applications and shared packages. | ||||
|  | ||||
| ## Development Commands | ||||
|  | ||||
| @@ -14,12 +14,9 @@ Trilium Notes is a hierarchical note-taking application with advanced features l | ||||
|  | ||||
| ### Running Applications | ||||
| - `pnpm run server:start` - Start development server (http://localhost:8080) | ||||
| - `pnpm nx run server:serve` - Alternative server start command | ||||
| - `pnpm nx run desktop:serve` - Run desktop Electron app | ||||
| - `pnpm run server:start-prod` - Run server in production mode | ||||
|  | ||||
| ### Building | ||||
| - `pnpm nx build <project>` - Build specific project (server, client, desktop, etc.) | ||||
| - `pnpm run client:build` - Build client application | ||||
| - `pnpm run server:build` - Build server application | ||||
| - `pnpm run electron:build` - Build desktop application | ||||
| @@ -28,13 +25,8 @@ Trilium Notes is a hierarchical note-taking application with advanced features l | ||||
| - `pnpm test:all` - Run all tests (parallel + sequential) | ||||
| - `pnpm test:parallel` - Run tests that can run in parallel | ||||
| - `pnpm test:sequential` - Run tests that must run sequentially (server, ckeditor5-mermaid, ckeditor5-math) | ||||
| - `pnpm nx test <project>` - Run tests for specific project | ||||
| - `pnpm coverage` - Generate coverage reports | ||||
|  | ||||
| ### Linting & Type Checking | ||||
| - `pnpm nx run <project>:lint` - Lint specific project | ||||
| - `pnpm nx run <project>:typecheck` - Type check specific project | ||||
|  | ||||
| ## Architecture Overview | ||||
|  | ||||
| ### Monorepo Structure | ||||
| @@ -94,7 +86,6 @@ Frontend uses a widget system (`apps/client/src/widgets/`): | ||||
|    - `apps/server/src/assets/db/schema.sql` - Core database structure | ||||
|  | ||||
| 4. **Configuration**: | ||||
|    - `nx.json` - NX workspace configuration | ||||
|    - `package.json` - Project dependencies and scripts | ||||
|  | ||||
| ## Note Types and Features | ||||
| @@ -154,7 +145,7 @@ Trilium provides powerful user scripting capabilities: | ||||
| - Update schema in `apps/server/src/assets/db/schema.sql` | ||||
|  | ||||
| ## Build System Notes | ||||
| - Uses NX for monorepo management with build caching | ||||
| - Uses pnpm for monorepo management | ||||
| - Vite for fast development builds | ||||
| - ESBuild for production optimization | ||||
| - pnpm workspaces for dependency management | ||||
|   | ||||
							
								
								
									
										34
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										34
									
								
								README.md
									
									
									
									
									
								
							| @@ -13,6 +13,23 @@ See [screenshots](https://triliumnext.github.io/Docs/Wiki/screenshot-tour) for q | ||||
|  | ||||
| <a href="https://triliumnext.github.io/Docs/Wiki/screenshot-tour"><img src="./docs/app.png" alt="Trilium Screenshot" width="1000"></a> | ||||
|  | ||||
| ## 📚 Documentation | ||||
|  | ||||
| **Visit our comprehensive documentation at [docs.triliumnotes.org](https://docs.triliumnotes.org/)** | ||||
|  | ||||
| Our documentation is available in multiple formats: | ||||
| - **Online Documentation**: Browse the full documentation at [docs.triliumnotes.org](https://docs.triliumnotes.org/) | ||||
| - **In-App Help**: Press `F1` within Trilium to access the same documentation directly in the application | ||||
| - **GitHub**: Navigate through the [User Guide](./docs/User%20Guide/User%20Guide/) in this repository | ||||
|  | ||||
| ### Quick Links | ||||
| - [Getting Started Guide](https://docs.triliumnotes.org/) | ||||
| - [Installation Instructions](./docs/User%20Guide/User%20Guide/Installation%20&%20Setup/Server%20Installation.md) | ||||
| - [Docker Setup](./docs/User%20Guide/User%20Guide/Installation%20&%20Setup/Server%20Installation/1.%20Installing%20the%20server/Using%20Docker.md) | ||||
| - [Upgrading TriliumNext](./docs/User%20Guide/User%20Guide/Installation%20%26%20Setup/Upgrading%20TriliumNext.md) | ||||
| - [Basic Concepts and Features](./docs/User%20Guide/User%20Guide/Basic%20Concepts%20and%20Features/Notes.md) | ||||
| - [Patterns of Personal Knowledge Base](https://triliumnext.github.io/Docs/Wiki/patterns-of-personal-knowledge) | ||||
|  | ||||
| ## 🎁 Features | ||||
|  | ||||
| * Notes can be arranged into arbitrarily deep tree. Single note can be placed into multiple places in the tree (see [cloning](https://triliumnext.github.io/Docs/Wiki/cloning-notes)) | ||||
| @@ -56,19 +73,6 @@ There are no special migration steps to migrate from a zadam/Trilium instance to | ||||
|  | ||||
| Versions up to and including [v0.90.4](https://github.com/TriliumNext/Trilium/releases/tag/v0.90.4) are compatible with the latest zadam/trilium version of [v0.63.7](https://github.com/zadam/trilium/releases/tag/v0.63.7). Any later versions of TriliumNext/Trilium have their sync versions incremented which prevents direct migration. | ||||
|  | ||||
| ## 📖 Documentation | ||||
|  | ||||
| We're currently in the progress of moving the documentation to in-app (hit the `F1` key within Trilium). As a result, there may be some missing parts until we've completed the migration. If you'd prefer to navigate through the documentation within GitHub, you can navigate the [User Guide](./docs/User%20Guide/User%20Guide/) documentation.  | ||||
|  | ||||
| Below are some quick links for your convenience to navigate the documentation: | ||||
| - [Server installation](./docs/User%20Guide/User%20Guide/Installation%20&%20Setup/Server%20Installation.md) | ||||
|   - [Docker installation](./docs/User%20Guide/User%20Guide/Installation%20&%20Setup/Server%20Installation/1.%20Installing%20the%20server/Using%20Docker.md) | ||||
| - [Upgrading TriliumNext](./docs/User%20Guide/User%20Guide/Installation%20%26%20Setup/Upgrading%20TriliumNext.md) | ||||
| - [Concepts and Features - Note](./docs/User%20Guide/User%20Guide/Basic%20Concepts%20and%20Features/Notes.md) | ||||
| - [Patterns of personal knowledge base](https://triliumnext.github.io/Docs/Wiki/patterns-of-personal-knowledge) | ||||
|  | ||||
| Until we finish reorganizing the documentation, you may also want to [browse the old documentation](https://triliumnext.github.io/Docs). | ||||
|  | ||||
| ## 💬 Discuss with us | ||||
|  | ||||
| Feel free to join our official conversations. We would love to hear what features, suggestions, or issues you may have! | ||||
| @@ -142,7 +146,7 @@ Download the repository, install dependencies using `pnpm` and then run the envi | ||||
| git clone https://github.com/TriliumNext/Trilium.git | ||||
| cd Trilium | ||||
| pnpm install | ||||
| pnpm nx run edit-docs:edit-docs | ||||
| pnpm edit-docs:edit-docs | ||||
| ``` | ||||
|  | ||||
| ### Building the Executable | ||||
| @@ -151,7 +155,7 @@ Download the repository, install dependencies using `pnpm` and then build the de | ||||
| git clone https://github.com/TriliumNext/Trilium.git | ||||
| cd Trilium | ||||
| pnpm install | ||||
| pnpm nx --project=desktop electron-forge:make -- --arch=x64 --platform=win32 | ||||
| pnpm run --filter desktop electron-forge:make --arch=x64 --platform=win32 | ||||
| ``` | ||||
|  | ||||
| For more details, see the [development docs](https://github.com/TriliumNext/Trilium/tree/main/docs/Developer%20Guide/Developer%20Guide). | ||||
|   | ||||
| @@ -35,13 +35,13 @@ | ||||
|     "chore:generate-openapi": "tsx bin/generate-openapi.js" | ||||
|   }, | ||||
|   "devDependencies": {     | ||||
|     "@playwright/test": "1.54.2", | ||||
|     "@stylistic/eslint-plugin": "5.2.3",         | ||||
|     "@playwright/test": "1.55.0", | ||||
|     "@stylistic/eslint-plugin": "5.4.0",         | ||||
|     "@types/express": "5.0.3",     | ||||
|     "@types/node": "22.17.2",     | ||||
|     "@types/node": "22.18.6",     | ||||
|     "@types/yargs": "17.0.33", | ||||
|     "@vitest/coverage-v8": "3.2.4", | ||||
|     "eslint": "9.33.0", | ||||
|     "eslint": "9.36.0", | ||||
|     "eslint-plugin-simple-import-sort": "12.1.1", | ||||
|     "esm": "3.2.25", | ||||
|     "jsdoc": "4.0.4", | ||||
| @@ -49,7 +49,7 @@ | ||||
|     "rcedit": "4.0.1", | ||||
|     "rimraf": "6.0.1",     | ||||
|     "tslib": "2.8.1",     | ||||
|     "typedoc": "0.28.10", | ||||
|     "typedoc": "0.28.13", | ||||
|     "typedoc-plugin-missing-exports": "4.1.0" | ||||
|   }, | ||||
|   "optionalDependencies": { | ||||
|   | ||||
| @@ -1,5 +1,4 @@ | ||||
| # The development license key for premium CKEditor features. | ||||
| # Note: This key must only be used for the Trilium Notes project. | ||||
| # Expires on: 2025-09-13 | ||||
| VITE_CKEDITOR_KEY=eyJhbGciOiJFUzI1NiJ9.eyJleHAiOjE3NTc3MjE1OTksImp0aSI6ImFiN2E0NjZmLWJlZGMtNDNiYy1iMzU4LTk0NGQ0YWJhY2I3ZiIsImRpc3RyaWJ1dGlvbkNoYW5uZWwiOlsic2giLCJkcnVwYWwiXSwid2hpdGVMYWJlbCI6dHJ1ZSwiZmVhdHVyZXMiOlsiRFJVUCIsIkNNVCIsIkRPIiwiRlAiLCJTQyIsIlRPQyIsIlRQTCIsIlBPRSIsIkNDIiwiTUYiLCJTRUUiLCJFQ0giLCJFSVMiXSwidmMiOiI1MzlkOWY5YyJ9.2rvKPql4hmukyXhEtWPZ8MLxKvzPIwzCdykO653g7IxRRZy2QJpeRszElZx9DakKYZKXekVRAwQKgHxwkgbE_w | ||||
| VITE_CKEDITOR_KEY=eyJhbGciOiJFUzI1NiJ9.eyJleHAiOjE3ODcyNzA0MDAsImp0aSI6IjkyMWE1MWNlLTliNDMtNGRlMC1iOTQwLTc5ZjM2MDBkYjg1NyIsImRpc3RyaWJ1dGlvbkNoYW5uZWwiOiJ0cmlsaXVtIiwiZmVhdHVyZXMiOlsiVFJJTElVTSJdLCJ2YyI6ImU4YzRhMjBkIn0.hny77p-U4-jTkoqbwPytrEar5ylGCWBN7Ez3SlB8i6_mJCBIeCSTOlVQk_JMiOEq3AGykUMHzWXzjdMFwgniOw | ||||
| VITE_CKEDITOR_ENABLE_INSPECTOR=false | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|   "name": "@triliumnext/client", | ||||
|   "version": "0.98.0", | ||||
|   "version": "0.99.0", | ||||
|   "description": "JQuery-based client for TriliumNext, used for both web and desktop (via Electron)", | ||||
|   "private": true, | ||||
|   "license": "AGPL-3.0-only", | ||||
| @@ -9,8 +9,13 @@ | ||||
|     "email": "contact@eliandoran.me", | ||||
|     "url": "https://github.com/TriliumNext/Notes" | ||||
|   }, | ||||
|   "scripts": { | ||||
|     "build": "cross-env NODE_OPTIONS=--max-old-space-size=4096 vite build", | ||||
|     "test": "vitest", | ||||
|     "circular-deps": "dpdm -T src/**/*.ts --tree=false --warning=false --skip-dynamic-imports=circular" | ||||
|   }, | ||||
|   "dependencies": { | ||||
|     "@eslint/js": "9.33.0", | ||||
|     "@eslint/js": "9.36.0", | ||||
|     "@excalidraw/excalidraw": "0.18.0", | ||||
|     "@fullcalendar/core": "6.1.19", | ||||
|     "@fullcalendar/daygrid": "6.1.19", | ||||
| @@ -19,7 +24,7 @@ | ||||
|     "@fullcalendar/multimonth": "6.1.19", | ||||
|     "@fullcalendar/timegrid": "6.1.19", | ||||
|     "@maplibre/maplibre-gl-leaflet": "0.1.3", | ||||
|     "@mermaid-js/layout-elk": "0.1.9", | ||||
|     "@mermaid-js/layout-elk": "0.2.0", | ||||
|     "@mind-elixir/node-menu": "5.0.0", | ||||
|     "@popperjs/core": "2.11.8", | ||||
|     "@triliumnext/ckeditor5": "workspace:*", | ||||
| @@ -28,15 +33,15 @@ | ||||
|     "@triliumnext/highlightjs": "workspace:*", | ||||
|     "@triliumnext/share-theme": "workspace:*", | ||||
|     "autocomplete.js": "0.38.1", | ||||
|     "bootstrap": "5.3.7", | ||||
|     "bootstrap": "5.3.8", | ||||
|     "boxicons": "2.1.4", | ||||
|     "dayjs": "1.11.13", | ||||
|     "dayjs": "1.11.18", | ||||
|     "dayjs-plugin-utc": "0.1.2", | ||||
|     "debounce": "2.2.0", | ||||
|     "draggabilly": "3.0.0", | ||||
|     "force-graph": "1.50.1", | ||||
|     "globals": "16.3.0", | ||||
|     "i18next": "25.3.6", | ||||
|     "force-graph": "1.51.0", | ||||
|     "globals": "16.4.0", | ||||
|     "i18next": "25.5.2", | ||||
|     "i18next-http-backend": "3.0.2", | ||||
|     "jquery": "3.7.1", | ||||
|     "jquery.fancytree": "2.38.5", | ||||
| @@ -46,13 +51,13 @@ | ||||
|     "leaflet": "1.9.4", | ||||
|     "leaflet-gpx": "2.2.0", | ||||
|     "mark.js": "8.11.1", | ||||
|     "marked": "16.2.0", | ||||
|     "mermaid": "11.10.0", | ||||
|     "mind-elixir": "5.0.6", | ||||
|     "marked": "16.3.0", | ||||
|     "mermaid": "11.12.0", | ||||
|     "mind-elixir": "5.2.0", | ||||
|     "normalize.css": "8.0.1", | ||||
|     "panzoom": "9.4.3", | ||||
|     "preact": "10.27.1", | ||||
|     "react-i18next": "15.6.1", | ||||
|     "preact": "10.27.2", | ||||
|     "react-i18next": "15.7.3", | ||||
|     "split.js": "1.6.5", | ||||
|     "svg-pan-zoom": "3.6.2", | ||||
|     "tabulator-tables": "6.3.1", | ||||
| @@ -62,27 +67,14 @@ | ||||
|     "@ckeditor/ckeditor5-inspector": "5.0.0", | ||||
|     "@preact/preset-vite": "2.10.2", | ||||
|     "@types/bootstrap": "5.2.10", | ||||
|     "@types/jquery": "3.5.32", | ||||
|     "@types/jquery": "3.5.33", | ||||
|     "@types/leaflet": "1.9.20", | ||||
|     "@types/leaflet-gpx": "1.3.7", | ||||
|     "@types/leaflet-gpx": "1.3.8", | ||||
|     "@types/mark.js": "8.11.12", | ||||
|     "@types/tabulator-tables": "6.2.10", | ||||
|     "@types/tabulator-tables": "6.2.11", | ||||
|     "copy-webpack-plugin": "13.0.1", | ||||
|     "happy-dom": "18.0.1", | ||||
|     "script-loader": "0.7.2", | ||||
|     "vite-plugin-static-copy": "3.1.1" | ||||
|   }, | ||||
|   "nx": { | ||||
|     "name": "client", | ||||
|     "targets": { | ||||
|       "serve": { | ||||
|         "dependsOn": [ | ||||
|           "^build" | ||||
|         ] | ||||
|       }, | ||||
|       "circular-deps": { | ||||
|         "command": "pnpx dpdm -T {projectRoot}/src/**/*.ts --tree=false --warning=false --skip-dynamic-imports=circular" | ||||
|       } | ||||
|     } | ||||
|     "vite-plugin-static-copy": "3.1.2" | ||||
|   } | ||||
| } | ||||
| @@ -7,6 +7,9 @@ | ||||
|     "display": "standalone", | ||||
|     "scope": "/", | ||||
|     "start_url": "/", | ||||
|     "display_override": [ | ||||
|         "window-controls-overlay" | ||||
|     ], | ||||
|     "icons": [ | ||||
|         { | ||||
|             "src": "icon.png", | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| import froca from "../services/froca.js"; | ||||
| import RootCommandExecutor from "./root_command_executor.js"; | ||||
| import Entrypoints, { type SqlExecuteResults } from "./entrypoints.js"; | ||||
| import Entrypoints from "./entrypoints.js"; | ||||
| import options from "../services/options.js"; | ||||
| import utils, { hasTouchBar } from "../services/utils.js"; | ||||
| import zoomComponent from "./zoom.js"; | ||||
| @@ -31,16 +31,14 @@ import { StartupChecks } from "./startup_checks.js"; | ||||
| import type { CreateNoteOpts } from "../services/note_create.js"; | ||||
| import { ColumnComponent } from "tabulator-tables"; | ||||
| import { ChooseNoteTypeCallback } from "../widgets/dialogs/note_type_chooser.jsx"; | ||||
| import type RootContainer from "../widgets/containers/root_container.js"; | ||||
| import { SqlExecuteResults } from "@triliumnext/commons"; | ||||
|  | ||||
| interface Layout { | ||||
|     getRootWidget: (appContext: AppContext) => RootWidget; | ||||
|     getRootWidget: (appContext: AppContext) => RootContainer; | ||||
| } | ||||
|  | ||||
| interface RootWidget extends Component { | ||||
|     render: () => JQuery<HTMLElement>; | ||||
| } | ||||
|  | ||||
| interface BeforeUploadListener extends Component { | ||||
| export interface BeforeUploadListener extends Component { | ||||
|     beforeUnloadEvent(): boolean; | ||||
| } | ||||
|  | ||||
| @@ -85,7 +83,6 @@ export type CommandMappings = { | ||||
|     focusTree: CommandData; | ||||
|     focusOnTitle: CommandData; | ||||
|     focusOnDetail: CommandData; | ||||
|     focusOnSearchDefinition: Required<CommandData>; | ||||
|     searchNotes: CommandData & { | ||||
|         searchString?: string; | ||||
|         ancestorNoteId?: string | null; | ||||
| @@ -93,6 +90,11 @@ export type CommandMappings = { | ||||
|     closeTocCommand: CommandData; | ||||
|     closeHlt: CommandData; | ||||
|     showLaunchBarSubtree: CommandData; | ||||
|     showHiddenSubtree: CommandData; | ||||
|     showSQLConsoleHistory: CommandData; | ||||
|     logout: CommandData; | ||||
|     switchToMobileVersion: CommandData; | ||||
|     switchToDesktopVersion: CommandData; | ||||
|     showRevisions: CommandData & { | ||||
|         noteId?: string | null; | ||||
|     }; | ||||
| @@ -114,7 +116,7 @@ export type CommandMappings = { | ||||
|     openedFileUpdated: CommandData & { | ||||
|         entityType: string; | ||||
|         entityId: string; | ||||
|         lastModifiedMs: number; | ||||
|         lastModifiedMs?: number; | ||||
|         filePath: string; | ||||
|     }; | ||||
|     focusAndSelectTitle: CommandData & { | ||||
| @@ -138,6 +140,7 @@ export type CommandMappings = { | ||||
|     showLeftPane: CommandData; | ||||
|     showAttachments: CommandData; | ||||
|     showSearchHistory: CommandData; | ||||
|     showShareSubtree: CommandData; | ||||
|     hoistNote: CommandData & { noteId: string }; | ||||
|     leaveProtectedSession: CommandData; | ||||
|     enterProtectedSession: CommandData; | ||||
| @@ -323,6 +326,7 @@ export type CommandMappings = { | ||||
|     printActiveNote: CommandData; | ||||
|     exportAsPdf: CommandData; | ||||
|     openNoteExternally: CommandData; | ||||
|     openNoteCustom: CommandData; | ||||
|     renderActiveNote: CommandData; | ||||
|     unhoist: CommandData; | ||||
|     reloadFrontendApp: CommandData; | ||||
| @@ -526,7 +530,7 @@ export type FilteredCommandNames<T extends CommandData> = keyof Pick<CommandMapp | ||||
| export class AppContext extends Component { | ||||
|     isMainWindow: boolean; | ||||
|     components: Component[]; | ||||
|     beforeUnloadListeners: WeakRef<BeforeUploadListener>[]; | ||||
|     beforeUnloadListeners: (WeakRef<BeforeUploadListener> | (() => boolean))[]; | ||||
|     tabManager!: TabManager; | ||||
|     layout?: Layout; | ||||
|     noteTreeWidget?: NoteTreeWidget; | ||||
| @@ -619,7 +623,7 @@ export class AppContext extends Component { | ||||
|             component.triggerCommand(commandName, { $el: $(this) }); | ||||
|         }); | ||||
|  | ||||
|         this.child(rootWidget); | ||||
|         this.child(rootWidget as Component); | ||||
|  | ||||
|         this.triggerEvent("initialRenderComplete", {}); | ||||
|     } | ||||
| @@ -646,16 +650,20 @@ export class AppContext extends Component { | ||||
|     } | ||||
|  | ||||
|     getComponentByEl(el: HTMLElement) { | ||||
|         return $(el).closest(".component").prop("component"); | ||||
|         return $(el).closest("[data-component-id]").prop("component"); | ||||
|     } | ||||
|  | ||||
|     addBeforeUnloadListener(obj: BeforeUploadListener) { | ||||
|     addBeforeUnloadListener(obj: BeforeUploadListener | (() => boolean)) { | ||||
|         if (typeof WeakRef !== "function") { | ||||
|             // older browsers don't support WeakRef | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         this.beforeUnloadListeners.push(new WeakRef<BeforeUploadListener>(obj)); | ||||
|         if (typeof obj === "object") { | ||||
|             this.beforeUnloadListeners.push(new WeakRef<BeforeUploadListener>(obj)); | ||||
|         } else { | ||||
|             this.beforeUnloadListeners.push(obj); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| @@ -665,25 +673,29 @@ const appContext = new AppContext(window.glob.isMainWindow); | ||||
| $(window).on("beforeunload", () => { | ||||
|     let allSaved = true; | ||||
|  | ||||
|     appContext.beforeUnloadListeners = appContext.beforeUnloadListeners.filter((wr) => !!wr.deref()); | ||||
|     appContext.beforeUnloadListeners = appContext.beforeUnloadListeners.filter((wr) => typeof wr === "function" || !!wr.deref()); | ||||
|  | ||||
|     for (const weakRef of appContext.beforeUnloadListeners) { | ||||
|         const component = weakRef.deref(); | ||||
|     for (const listener of appContext.beforeUnloadListeners) { | ||||
|         if (typeof listener === "object") { | ||||
|             const component = listener.deref(); | ||||
|  | ||||
|         if (!component) { | ||||
|             continue; | ||||
|         } | ||||
|             if (!component) { | ||||
|                 continue; | ||||
|             } | ||||
|  | ||||
|         if (!component.beforeUnloadEvent()) { | ||||
|             console.log(`Component ${component.componentId} is not finished saving its state.`); | ||||
|  | ||||
|             toast.showMessage(t("app_context.please_wait_for_save"), 10000); | ||||
|  | ||||
|             allSaved = false; | ||||
|             if (!component.beforeUnloadEvent()) { | ||||
|                 console.log(`Component ${component.componentId} is not finished saving its state.`); | ||||
|                 allSaved = false; | ||||
|             } | ||||
|         } else { | ||||
|             if (!listener()) { | ||||
|                 allSaved = false; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     if (!allSaved) { | ||||
|         toast.showMessage(t("app_context.please_wait_for_save"), 10000); | ||||
|         return "some string"; | ||||
|     } | ||||
| }); | ||||
|   | ||||
| @@ -1,6 +1,8 @@ | ||||
| import utils from "../services/utils.js"; | ||||
| import type { CommandMappings, CommandNames, EventData, EventNames } from "./app_context.js"; | ||||
|  | ||||
| type EventHandler = ((data: any) => void); | ||||
|  | ||||
| /** | ||||
|  * Abstract class for all components in the Trilium's frontend. | ||||
|  * | ||||
| @@ -19,6 +21,7 @@ export class TypedComponent<ChildT extends TypedComponent<ChildT>> { | ||||
|     initialized: Promise<void> | null; | ||||
|     parent?: TypedComponent<any>; | ||||
|     _position!: number; | ||||
|     private listeners: Record<string, EventHandler[]> | null = {}; | ||||
|  | ||||
|     constructor() { | ||||
|         this.componentId = `${this.sanitizedClassName}-${utils.randomString(8)}`; | ||||
| @@ -76,6 +79,14 @@ export class TypedComponent<ChildT extends TypedComponent<ChildT>> { | ||||
|     handleEventInChildren<T extends EventNames>(name: T, data: EventData<T>): Promise<unknown[] | unknown> | null { | ||||
|         const promises: Promise<unknown>[] = []; | ||||
|  | ||||
|         // Handle React children. | ||||
|         if (this.listeners?.[name]) { | ||||
|             for (const listener of this.listeners[name]) { | ||||
|                 listener(data); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         // Handle legacy children. | ||||
|         for (const child of this.children) { | ||||
|             const ret = child.handleEvent(name, data) as Promise<void>; | ||||
|  | ||||
| @@ -120,6 +131,35 @@ export class TypedComponent<ChildT extends TypedComponent<ChildT>> { | ||||
|  | ||||
|         return promise; | ||||
|     } | ||||
|  | ||||
|     registerHandler<T extends EventNames>(name: T, handler: EventHandler) { | ||||
|         if (!this.listeners) { | ||||
|             this.listeners = {}; | ||||
|         } | ||||
|  | ||||
|         if (!this.listeners[name]) { | ||||
|             this.listeners[name] = []; | ||||
|         } | ||||
|  | ||||
|         if (this.listeners[name].includes(handler)) { | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         this.listeners[name].push(handler); | ||||
|     } | ||||
|  | ||||
|     removeHandler<T extends EventNames>(name: T, handler: EventHandler) { | ||||
|         if (!this.listeners?.[name]?.includes(handler)) { | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         this.listeners[name] = this.listeners[name] | ||||
|             .filter(listener => listener !== handler); | ||||
|  | ||||
|         if (!this.listeners[name].length) { | ||||
|             delete this.listeners[name]; | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| export default class Component extends TypedComponent<Component> {} | ||||
|   | ||||
| @@ -10,22 +10,7 @@ import bundleService from "../services/bundle.js"; | ||||
| import froca from "../services/froca.js"; | ||||
| import linkService from "../services/link.js"; | ||||
| import { t } from "../services/i18n.js"; | ||||
| import type FNote from "../entities/fnote.js"; | ||||
|  | ||||
| // TODO: Move somewhere else nicer. | ||||
| export type SqlExecuteResults = string[][][]; | ||||
|  | ||||
| // TODO: Deduplicate with server. | ||||
| interface SqlExecuteResponse { | ||||
|     success: boolean; | ||||
|     error?: string; | ||||
|     results: SqlExecuteResults; | ||||
| } | ||||
|  | ||||
| // TODO: Deduplicate with server. | ||||
| interface CreateChildrenResponse { | ||||
|     note: FNote; | ||||
| } | ||||
| import { CreateChildrenResponse, SqlExecuteResponse } from "@triliumnext/commons"; | ||||
|  | ||||
| export default class Entrypoints extends Component { | ||||
|     constructor() { | ||||
| @@ -34,7 +19,7 @@ export default class Entrypoints extends Component { | ||||
|  | ||||
|     openDevToolsCommand() { | ||||
|         if (utils.isElectron()) { | ||||
|             utils.dynamicRequire("@electron/remote").getCurrentWindow().toggleDevTools(); | ||||
|             utils.dynamicRequire("@electron/remote").getCurrentWindow().webContents.toggleDevTools(); | ||||
|         } | ||||
|     } | ||||
|  | ||||
| @@ -124,7 +109,7 @@ export default class Entrypoints extends Component { | ||||
|         if (utils.isElectron()) { | ||||
|             // standard JS version does not work completely correctly in electron | ||||
|             const webContents = utils.dynamicRequire("@electron/remote").getCurrentWebContents(); | ||||
|             const activeIndex = parseInt(webContents.navigationHistory.getActiveIndex()); | ||||
|             const activeIndex = webContents.navigationHistory.getActiveIndex(); | ||||
|  | ||||
|             webContents.goToIndex(activeIndex - 1); | ||||
|         } else { | ||||
| @@ -136,7 +121,7 @@ export default class Entrypoints extends Component { | ||||
|         if (utils.isElectron()) { | ||||
|             // standard JS version does not work completely correctly in electron | ||||
|             const webContents = utils.dynamicRequire("@electron/remote").getCurrentWebContents(); | ||||
|             const activeIndex = parseInt(webContents.navigationHistory.getActiveIndex()); | ||||
|             const activeIndex = webContents.navigationHistory.getActiveIndex(); | ||||
|  | ||||
|             webContents.goToIndex(activeIndex + 1); | ||||
|         } else { | ||||
|   | ||||
| @@ -43,8 +43,6 @@ export default class RootCommandExecutor extends Component { | ||||
|         const noteContext = await appContext.tabManager.openTabWithNoteWithHoisting(searchNote.noteId, { | ||||
|             activate: true | ||||
|         }); | ||||
|  | ||||
|         appContext.triggerCommand("focusOnSearchDefinition", { ntxId: noteContext.ntxId }); | ||||
|     } | ||||
|  | ||||
|     async searchInSubtreeCommand({ notePath }: CommandListenerData<"searchInSubtree">) { | ||||
|   | ||||
| @@ -433,6 +433,9 @@ export default class TabManager extends Component { | ||||
|                 $autocompleteEl.autocomplete("close"); | ||||
|             } | ||||
|  | ||||
|             // close dangling tooltips | ||||
|             $("body > div.tooltip").remove(); | ||||
|  | ||||
|             const noteContextsToRemove = noteContextToRemove.getSubContexts(); | ||||
|             const ntxIdsToRemove = noteContextsToRemove.map((nc) => nc.ntxId); | ||||
|  | ||||
| @@ -600,18 +603,18 @@ export default class TabManager extends Component { | ||||
|     } | ||||
|  | ||||
|     async moveTabToNewWindowCommand({ ntxId }: { ntxId: string }) { | ||||
|         const { notePath, hoistedNoteId } = this.getNoteContextById(ntxId); | ||||
|         const { notePath, hoistedNoteId, viewScope } = this.getNoteContextById(ntxId); | ||||
|  | ||||
|         const removed = await this.removeNoteContext(ntxId); | ||||
|  | ||||
|         if (removed) { | ||||
|             this.triggerCommand("openInWindow", { notePath, hoistedNoteId }); | ||||
|             this.triggerCommand("openInWindow", { notePath, hoistedNoteId, viewScope }); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     async copyTabToNewWindowCommand({ ntxId }: { ntxId: string }) { | ||||
|         const { notePath, hoistedNoteId } = this.getNoteContextById(ntxId); | ||||
|         this.triggerCommand("openInWindow", { notePath, hoistedNoteId }); | ||||
|         const { notePath, hoistedNoteId, viewScope } = this.getNoteContextById(ntxId); | ||||
|         this.triggerCommand("openInWindow", { notePath, hoistedNoteId, viewScope }); | ||||
|     } | ||||
|  | ||||
|     async reopenLastTabCommand() { | ||||
|   | ||||
| @@ -23,11 +23,11 @@ export default class TouchBarComponent extends Component { | ||||
|         this.$widget = $("<div>"); | ||||
|  | ||||
|         $(window).on("focusin", async (e) => { | ||||
|             const $target = $(e.target); | ||||
|             const focusedEl = e.target as unknown as HTMLElement; | ||||
|             const $target = $(focusedEl); | ||||
|  | ||||
|             this.$activeModal = $target.closest(".modal-dialog"); | ||||
|             const parentComponentEl = $target.closest(".component"); | ||||
|             this.lastFocusedComponent = appContext.getComponentByEl(parentComponentEl[0]); | ||||
|             this.lastFocusedComponent = appContext.getComponentByEl(focusedEl); | ||||
|             this.#refreshTouchBar(); | ||||
|         }); | ||||
|     } | ||||
|   | ||||
| @@ -8,10 +8,9 @@ import electronContextMenu from "./menus/electron_context_menu.js"; | ||||
| import glob from "./services/glob.js"; | ||||
| import { t } from "./services/i18n.js"; | ||||
| import options from "./services/options.js"; | ||||
| import server from "./services/server.js"; | ||||
| import type ElectronRemote from "@electron/remote"; | ||||
| import type Electron from "electron"; | ||||
| import "./stylesheets/bootstrap.scss"; | ||||
| import "bootstrap/dist/css/bootstrap.min.css"; | ||||
| import "boxicons/css/boxicons.min.css"; | ||||
| import "autocomplete.js/index_jquery.js"; | ||||
|  | ||||
| @@ -46,6 +45,10 @@ if (utils.isElectron()) { | ||||
|     electronContextMenu.setupContextMenu(); | ||||
| } | ||||
|  | ||||
| if (utils.isPWA()) { | ||||
|     initPWATopbarColor(); | ||||
| } | ||||
|  | ||||
| function initOnElectron() { | ||||
|     const electron: typeof Electron = utils.dynamicRequire("electron"); | ||||
|     electron.ipcRenderer.on("globalShortcut", async (event, actionName) => appContext.triggerCommand(actionName)); | ||||
| @@ -114,3 +117,20 @@ function initDarkOrLightMode(style: CSSStyleDeclaration) { | ||||
|     const { nativeTheme } = utils.dynamicRequire("@electron/remote") as typeof ElectronRemote; | ||||
|     nativeTheme.themeSource = themeSource; | ||||
| } | ||||
|  | ||||
| function initPWATopbarColor() { | ||||
|     const tracker = $("#background-color-tracker"); | ||||
|  | ||||
|     if (tracker.length) { | ||||
|         const applyThemeColor = () => { | ||||
|             let meta = $("meta[name='theme-color']"); | ||||
|             if (!meta.length) { | ||||
|                 meta = $(`<meta name="theme-color">`).appendTo($("head")); | ||||
|             } | ||||
|             meta.attr("content", tracker.css("color")); | ||||
|         }; | ||||
|  | ||||
|         tracker.on("transitionend", applyThemeColor); | ||||
|         applyThemeColor(); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -64,7 +64,7 @@ export interface NoteMetaData { | ||||
| /** | ||||
|  * Note is the main node and concept in Trilium. | ||||
|  */ | ||||
| class FNote { | ||||
| export default class FNote { | ||||
|     private froca: Froca; | ||||
|  | ||||
|     noteId!: string; | ||||
| @@ -256,18 +256,20 @@ class FNote { | ||||
|         return this.children; | ||||
|     } | ||||
|  | ||||
|     async getSubtreeNoteIds() { | ||||
|     async getSubtreeNoteIds(includeArchived = false) { | ||||
|         let noteIds: (string | string[])[] = []; | ||||
|         for (const child of await this.getChildNotes()) { | ||||
|             if (child.isArchived && !includeArchived) continue; | ||||
|  | ||||
|             noteIds.push(child.noteId); | ||||
|             noteIds.push(await child.getSubtreeNoteIds()); | ||||
|             noteIds.push(await child.getSubtreeNoteIds(includeArchived)); | ||||
|         } | ||||
|         return noteIds.flat(); | ||||
|     } | ||||
|  | ||||
|     async getSubtreeNotes() { | ||||
|         const noteIds = await this.getSubtreeNoteIds(); | ||||
|         return this.froca.getNotes(noteIds); | ||||
|         return (await this.froca.getNotes(noteIds)); | ||||
|     } | ||||
|  | ||||
|     async getChildNotes() { | ||||
| @@ -905,8 +907,8 @@ class FNote { | ||||
|         return this.getBlob(); | ||||
|     } | ||||
|  | ||||
|     async getBlob() { | ||||
|         return await this.froca.getBlob("notes", this.noteId); | ||||
|     getBlob() { | ||||
|         return this.froca.getBlob("notes", this.noteId); | ||||
|     } | ||||
|  | ||||
|     toString() { | ||||
| @@ -1020,6 +1022,14 @@ class FNote { | ||||
|         return this.noteId.startsWith("_options"); | ||||
|     } | ||||
|  | ||||
|     isTriliumSqlite() { | ||||
|         return this.mime === "text/x-sqlite;schema=trilium"; | ||||
|     } | ||||
|  | ||||
|     isTriliumScript() { | ||||
|         return this.mime.startsWith("application/javascript"); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Provides note's date metadata. | ||||
|      */ | ||||
| @@ -1027,5 +1037,3 @@ class FNote { | ||||
|         return await server.get<NoteMetaData>(`notes/${this.noteId}/metadata`); | ||||
|     } | ||||
| } | ||||
|  | ||||
| export default FNote; | ||||
|   | ||||
| @@ -1,78 +1,47 @@ | ||||
| import FlexContainer from "../widgets/containers/flex_container.js"; | ||||
| import GlobalMenuWidget from "../widgets/buttons/global_menu.js"; | ||||
| import TabRowWidget from "../widgets/tab_row.js"; | ||||
| import TitleBarButtonsWidget from "../widgets/title_bar_buttons.js"; | ||||
| import LeftPaneContainer from "../widgets/containers/left_pane_container.js"; | ||||
| import NoteTreeWidget from "../widgets/note_tree.js"; | ||||
| import NoteTitleWidget from "../widgets/note_title.js"; | ||||
| import OwnedAttributeListWidget from "../widgets/ribbon_widgets/owned_attribute_list.js"; | ||||
| import NoteActionsWidget from "../widgets/buttons/note_actions.js"; | ||||
| import NoteTitleWidget from "../widgets/note_title.jsx"; | ||||
| import NoteDetailWidget from "../widgets/note_detail.js"; | ||||
| import RibbonContainer from "../widgets/containers/ribbon_container.js"; | ||||
| import PromotedAttributesWidget from "../widgets/ribbon_widgets/promoted_attributes.js"; | ||||
| import InheritedAttributesWidget from "../widgets/ribbon_widgets/inherited_attribute_list.js"; | ||||
| import NoteListWidget from "../widgets/note_list.js"; | ||||
| import SearchDefinitionWidget from "../widgets/ribbon_widgets/search_definition.js"; | ||||
| import SqlResultWidget from "../widgets/sql_result.js"; | ||||
| import SqlTableSchemasWidget from "../widgets/sql_table_schemas.js"; | ||||
| import FilePropertiesWidget from "../widgets/ribbon_widgets/file_properties.js"; | ||||
| import ImagePropertiesWidget from "../widgets/ribbon_widgets/image_properties.js"; | ||||
| import NotePropertiesWidget from "../widgets/ribbon_widgets/note_properties.js"; | ||||
| import NoteIconWidget from "../widgets/note_icon.js"; | ||||
| import SearchResultWidget from "../widgets/search_result.js"; | ||||
| import PromotedAttributesWidget from "../widgets/promoted_attributes.js"; | ||||
| import NoteIconWidget from "../widgets/note_icon.jsx"; | ||||
| import ScrollingContainer from "../widgets/containers/scrolling_container.js"; | ||||
| import RootContainer from "../widgets/containers/root_container.js"; | ||||
| import WatchedFileUpdateStatusWidget from "../widgets/watched_file_update_status.js"; | ||||
| import SpacerWidget from "../widgets/spacer.js"; | ||||
| import QuickSearchWidget from "../widgets/quick_search.js"; | ||||
| import SplitNoteContainer from "../widgets/containers/split_note_container.js"; | ||||
| import LeftPaneToggleWidget from "../widgets/buttons/left_pane_toggle.js"; | ||||
| import CreatePaneButton from "../widgets/buttons/create_pane_button.js"; | ||||
| import ClosePaneButton from "../widgets/buttons/close_pane_button.js"; | ||||
| import BasicPropertiesWidget from "../widgets/ribbon_widgets/basic_properties.js"; | ||||
| import NoteInfoWidget from "../widgets/ribbon_widgets/note_info_widget.js"; | ||||
| import BookPropertiesWidget from "../widgets/ribbon_widgets/book_properties.js"; | ||||
| import NoteMapRibbonWidget from "../widgets/ribbon_widgets/note_map.js"; | ||||
| import NotePathsWidget from "../widgets/ribbon_widgets/note_paths.js"; | ||||
| import SimilarNotesWidget from "../widgets/ribbon_widgets/similar_notes.js"; | ||||
| import RightPaneContainer from "../widgets/containers/right_pane_container.js"; | ||||
| import EditButton from "../widgets/floating_buttons/edit_button.js"; | ||||
| import EditedNotesWidget from "../widgets/ribbon_widgets/edited_notes.js"; | ||||
| import ShowTocWidgetButton from "../widgets/buttons/show_toc_widget_button.js"; | ||||
| import ShowHighlightsListWidgetButton from "../widgets/buttons/show_highlights_list_widget_button.js"; | ||||
| import NoteWrapperWidget from "../widgets/note_wrapper.js"; | ||||
| import BacklinksWidget from "../widgets/floating_buttons/zpetne_odkazy.js"; | ||||
| import SharedInfoWidget from "../widgets/shared_info.js"; | ||||
| import FindWidget from "../widgets/find.js"; | ||||
| import TocWidget from "../widgets/toc.js"; | ||||
| import HighlightsListWidget from "../widgets/highlights_list.js"; | ||||
| import PasswordNoteSetDialog from "../widgets/dialogs/password_not_set.js"; | ||||
| import FloatingButtons from "../widgets/floating_buttons/floating_buttons.js"; | ||||
| import RelationMapButtons from "../widgets/floating_buttons/relation_map_buttons.js"; | ||||
| import SvgExportButton from "../widgets/floating_buttons/svg_export_button.js"; | ||||
| import LauncherContainer from "../widgets/containers/launcher_container.js"; | ||||
| import RevisionsButton from "../widgets/buttons/revisions_button.js"; | ||||
| import CodeButtonsWidget from "../widgets/floating_buttons/code_buttons.js"; | ||||
| import ApiLogWidget from "../widgets/api_log.js"; | ||||
| import HideFloatingButtonsButton from "../widgets/floating_buttons/hide_floating_buttons_button.js"; | ||||
| import ScriptExecutorWidget from "../widgets/ribbon_widgets/script_executor.js"; | ||||
| import MovePaneButton from "../widgets/buttons/move_pane_button.js"; | ||||
| import UploadAttachmentsDialog from "../widgets/dialogs/upload_attachments.js"; | ||||
| import CopyImageReferenceButton from "../widgets/floating_buttons/copy_image_reference_button.js"; | ||||
| import ScrollPaddingWidget from "../widgets/scroll_padding.js"; | ||||
| import ClassicEditorToolbar from "../widgets/ribbon_widgets/classic_editor_toolbar.js"; | ||||
| import ScrollPadding from "../widgets/scroll_padding.js"; | ||||
| import options from "../services/options.js"; | ||||
| import utils from "../services/utils.js"; | ||||
| import GeoMapButtons from "../widgets/floating_buttons/geo_map_button.js"; | ||||
| import ContextualHelpButton from "../widgets/floating_buttons/help_button.js"; | ||||
| import CloseZenButton from "../widgets/close_zen_button.js"; | ||||
| import type { AppContext } from "../components/app_context.js"; | ||||
| import type { WidgetsByParent } from "../services/bundle.js"; | ||||
| import SwitchSplitOrientationButton from "../widgets/floating_buttons/switch_layout_button.js"; | ||||
| import ToggleReadOnlyButton from "../widgets/floating_buttons/toggle_read_only_button.js"; | ||||
| import PngExportButton from "../widgets/floating_buttons/png_export_button.js"; | ||||
| import RefreshButton from "../widgets/floating_buttons/refresh_button.js"; | ||||
| import { applyModals } from "./layout_commons.js"; | ||||
| import Ribbon from "../widgets/ribbon/Ribbon.jsx"; | ||||
| import FloatingButtons from "../widgets/FloatingButtons.jsx"; | ||||
| import { DESKTOP_FLOATING_BUTTONS } from "../widgets/FloatingButtonsDefinitions.jsx"; | ||||
| import SearchResult from "../widgets/search_result.jsx"; | ||||
| import GlobalMenu from "../widgets/buttons/global_menu.jsx"; | ||||
| import SqlResults from "../widgets/sql_result.js"; | ||||
| import SqlTableSchemas from "../widgets/sql_table_schemas.js"; | ||||
| import TitleBarButtons from "../widgets/title_bar_buttons.jsx"; | ||||
| import LeftPaneToggle from "../widgets/buttons/left_pane_toggle.js"; | ||||
| import ApiLog from "../widgets/api_log.jsx"; | ||||
| import CloseZenModeButton from "../widgets/close_zen_button.jsx"; | ||||
| import SharedInfo from "../widgets/shared_info.jsx"; | ||||
| import NoteList from "../widgets/collections/NoteList.jsx"; | ||||
| 
 | ||||
| export default class DesktopLayout { | ||||
| 
 | ||||
| @@ -107,9 +76,9 @@ export default class DesktopLayout { | ||||
|                 new FlexContainer("row") | ||||
|                     .class("tab-row-container") | ||||
|                     .child(new FlexContainer("row").id("tab-row-left-spacer")) | ||||
|                     .optChild(launcherPaneIsHorizontal, new LeftPaneToggleWidget(true)) | ||||
|                     .optChild(launcherPaneIsHorizontal, <LeftPaneToggle isHorizontalLayout={true} />) | ||||
|                     .child(new TabRowWidget().class("full-width")) | ||||
|                     .optChild(customTitleBarButtons, new TitleBarButtonsWidget()) | ||||
|                     .optChild(customTitleBarButtons, <TitleBarButtons />) | ||||
|                     .css("height", "40px") | ||||
|                     .css("background-color", "var(--launcher-pane-background-color)") | ||||
|                     .setParent(appContext) | ||||
| @@ -130,7 +99,7 @@ export default class DesktopLayout { | ||||
|                         new FlexContainer("column") | ||||
|                             .id("rest-pane") | ||||
|                             .css("flex-grow", "1") | ||||
|                             .optChild(!fullWidthTabBar, new FlexContainer("row").child(new TabRowWidget()).optChild(customTitleBarButtons, new TitleBarButtonsWidget()).css("height", "40px")) | ||||
|                             .optChild(!fullWidthTabBar, new FlexContainer("row").child(new TabRowWidget()).optChild(customTitleBarButtons, <TitleBarButtons />).css("height", "40px")) | ||||
|                             .child( | ||||
|                                 new FlexContainer("row") | ||||
|                                     .filling() | ||||
| @@ -151,69 +120,30 @@ export default class DesktopLayout { | ||||
|                                                                 .css("min-height", "50px") | ||||
|                                                                 .css("align-items", "center") | ||||
|                                                                 .cssBlock(".title-row > * { margin: 5px; }") | ||||
|                                                                 .child(new NoteIconWidget()) | ||||
|                                                                 .child(new NoteTitleWidget()) | ||||
|                                                                 .child(<NoteIconWidget />) | ||||
|                                                                 .child(<NoteTitleWidget />) | ||||
|                                                                 .child(new SpacerWidget(0, 1)) | ||||
|                                                                 .child(new MovePaneButton(true)) | ||||
|                                                                 .child(new MovePaneButton(false)) | ||||
|                                                                 .child(new ClosePaneButton()) | ||||
|                                                                 .child(new CreatePaneButton()) | ||||
|                                                                 .child(<MovePaneButton direction="left" />) | ||||
|                                                                 .child(<MovePaneButton direction="right" />) | ||||
|                                                                 .child(<ClosePaneButton />) | ||||
|                                                                 .child(<CreatePaneButton />) | ||||
|                                                         ) | ||||
|                                                         .child( | ||||
|                                                             new RibbonContainer() | ||||
|                                                                 // the order of the widgets matter. Some of these want to "activate" themselves
 | ||||
|                                                                 // when visible. When this happens to multiple of them, the first one "wins".
 | ||||
|                                                                 // promoted attributes should always win.
 | ||||
|                                                                 .ribbon(new ClassicEditorToolbar()) | ||||
|                                                                 .ribbon(new ScriptExecutorWidget()) | ||||
|                                                                 .ribbon(new SearchDefinitionWidget()) | ||||
|                                                                 .ribbon(new EditedNotesWidget()) | ||||
|                                                                 .ribbon(new BookPropertiesWidget()) | ||||
|                                                                 .ribbon(new NotePropertiesWidget()) | ||||
|                                                                 .ribbon(new FilePropertiesWidget()) | ||||
|                                                                 .ribbon(new ImagePropertiesWidget()) | ||||
|                                                                 .ribbon(new BasicPropertiesWidget()) | ||||
|                                                                 .ribbon(new OwnedAttributeListWidget()) | ||||
|                                                                 .ribbon(new InheritedAttributesWidget()) | ||||
|                                                                 .ribbon(new NotePathsWidget()) | ||||
|                                                                 .ribbon(new NoteMapRibbonWidget()) | ||||
|                                                                 .ribbon(new SimilarNotesWidget()) | ||||
|                                                                 .ribbon(new NoteInfoWidget()) | ||||
|                                                                 .button(new RevisionsButton()) | ||||
|                                                                 .button(new NoteActionsWidget()) | ||||
|                                                         ) | ||||
|                                                         .child(new SharedInfoWidget()) | ||||
|                                                         .child(<Ribbon />) | ||||
|                                                         .child(<SharedInfo />) | ||||
|                                                         .child(new WatchedFileUpdateStatusWidget()) | ||||
|                                                         .child( | ||||
|                                                             new FloatingButtons() | ||||
|                                                                 .child(new RefreshButton()) | ||||
|                                                                 .child(new SwitchSplitOrientationButton()) | ||||
|                                                                 .child(new ToggleReadOnlyButton()) | ||||
|                                                                 .child(new EditButton()) | ||||
|                                                                 .child(new ShowTocWidgetButton()) | ||||
|                                                                 .child(new ShowHighlightsListWidgetButton()) | ||||
|                                                                 .child(new CodeButtonsWidget()) | ||||
|                                                                 .child(new RelationMapButtons()) | ||||
|                                                                 .child(new GeoMapButtons()) | ||||
|                                                                 .child(new CopyImageReferenceButton()) | ||||
|                                                                 .child(new SvgExportButton()) | ||||
|                                                                 .child(new PngExportButton()) | ||||
|                                                                 .child(new BacklinksWidget()) | ||||
|                                                                 .child(new ContextualHelpButton()) | ||||
|                                                                 .child(new HideFloatingButtonsButton()) | ||||
|                                                         ) | ||||
|                                                         .child(<FloatingButtons items={DESKTOP_FLOATING_BUTTONS} />) | ||||
|                                                         .child( | ||||
|                                                             new ScrollingContainer() | ||||
|                                                                 .filling() | ||||
|                                                                 .child(new PromotedAttributesWidget()) | ||||
|                                                                 .child(new SqlTableSchemasWidget()) | ||||
|                                                                 .child(<SqlTableSchemas />) | ||||
|                                                                 .child(new NoteDetailWidget()) | ||||
|                                                                 .child(new NoteListWidget(false)) | ||||
|                                                                 .child(new SearchResultWidget()) | ||||
|                                                                 .child(new SqlResultWidget()) | ||||
|                                                                 .child(new ScrollPaddingWidget()) | ||||
|                                                                 .child(<NoteList />) | ||||
|                                                                 .child(<SearchResult />) | ||||
|                                                                 .child(<SqlResults />) | ||||
|                                                                 .child(<ScrollPadding />) | ||||
|                                                         ) | ||||
|                                                         .child(new ApiLogWidget()) | ||||
|                                                         .child(<ApiLog />) | ||||
|                                                         .child(new FindWidget()) | ||||
|                                                         .child( | ||||
|                                                             ...this.customWidgets.get("node-detail-pane"), // typo, let's keep it for a while as BC
 | ||||
| @@ -232,11 +162,11 @@ export default class DesktopLayout { | ||||
|                             ) | ||||
|                     ) | ||||
|             ) | ||||
|             .child(new CloseZenButton()) | ||||
|             .child(<CloseZenModeButton />) | ||||
| 
 | ||||
|             // Desktop-specific dialogs.
 | ||||
|             .child(new PasswordNoteSetDialog()) | ||||
|             .child(new UploadAttachmentsDialog()); | ||||
|             .child(<PasswordNoteSetDialog />) | ||||
|             .child(<UploadAttachmentsDialog />); | ||||
| 
 | ||||
|         applyModals(rootContainer); | ||||
|         return rootContainer; | ||||
| @@ -246,14 +176,18 @@ export default class DesktopLayout { | ||||
|         let launcherPane; | ||||
| 
 | ||||
|         if (isHorizontal) { | ||||
|             launcherPane = new FlexContainer("row").css("height", "53px").class("horizontal").child(new LauncherContainer(true)).child(new GlobalMenuWidget(true)); | ||||
|             launcherPane = new FlexContainer("row") | ||||
|                 .css("height", "53px") | ||||
|                 .class("horizontal") | ||||
|                 .child(new LauncherContainer(true)) | ||||
|                 .child(<GlobalMenu isHorizontalLayout={true} />); | ||||
|         } else { | ||||
|             launcherPane = new FlexContainer("column") | ||||
|                 .css("width", "53px") | ||||
|                 .class("vertical") | ||||
|                 .child(new GlobalMenuWidget(false)) | ||||
|                 .child(<GlobalMenu isHorizontalLayout={false} />) | ||||
|                 .child(new LauncherContainer(false)) | ||||
|                 .child(new LeftPaneToggleWidget(false)); | ||||
|                 .child(<LeftPaneToggle isHorizontalLayout={false} />); | ||||
|         } | ||||
| 
 | ||||
|         launcherPane.id("launcher-pane"); | ||||
| @@ -24,48 +24,48 @@ import InfoDialog from "../widgets/dialogs/info.js"; | ||||
| import IncorrectCpuArchDialog from "../widgets/dialogs/incorrect_cpu_arch.js"; | ||||
| import PopupEditorDialog from "../widgets/dialogs/popup_editor.js"; | ||||
| import FlexContainer from "../widgets/containers/flex_container.js"; | ||||
| import NoteIconWidget from "../widgets/note_icon.js"; | ||||
| import NoteTitleWidget from "../widgets/note_title.js"; | ||||
| import ClassicEditorToolbar from "../widgets/ribbon_widgets/classic_editor_toolbar.js"; | ||||
| import PromotedAttributesWidget from "../widgets/ribbon_widgets/promoted_attributes.js"; | ||||
| import NoteIconWidget from "../widgets/note_icon"; | ||||
| import PromotedAttributesWidget from "../widgets/promoted_attributes.js"; | ||||
| import NoteDetailWidget from "../widgets/note_detail.js"; | ||||
| import NoteListWidget from "../widgets/note_list.js"; | ||||
| import { CallToActionDialog } from "../widgets/dialogs/call_to_action.jsx"; | ||||
| import CallToActionDialog from "../widgets/dialogs/call_to_action.jsx"; | ||||
| import NoteTitleWidget from "../widgets/note_title.jsx"; | ||||
| import { PopupEditorFormattingToolbar } from "../widgets/ribbon/FormattingToolbar.js"; | ||||
| import NoteList from "../widgets/collections/NoteList.jsx"; | ||||
| 
 | ||||
| export function applyModals(rootContainer: RootContainer) { | ||||
|     rootContainer | ||||
|         .child(new BulkActionsDialog()) | ||||
|         .child(new AboutDialog()) | ||||
|         .child(new HelpDialog()) | ||||
|         .child(new RecentChangesDialog()) | ||||
|         .child(new BranchPrefixDialog()) | ||||
|         .child(new SortChildNotesDialog()) | ||||
|         .child(new IncludeNoteDialog()) | ||||
|         .child(new NoteTypeChooserDialog()) | ||||
|         .child(new JumpToNoteDialog()) | ||||
|         .child(new AddLinkDialog()) | ||||
|         .child(new CloneToDialog()) | ||||
|         .child(new MoveToDialog()) | ||||
|         .child(new ImportDialog()) | ||||
|         .child(new ExportDialog()) | ||||
|         .child(new MarkdownImportDialog()) | ||||
|         .child(new ProtectedSessionPasswordDialog()) | ||||
|         .child(new RevisionsDialog()) | ||||
|         .child(new DeleteNotesDialog()) | ||||
|         .child(new InfoDialog()) | ||||
|         .child(new ConfirmDialog()) | ||||
|         .child(new PromptDialog()) | ||||
|         .child(new IncorrectCpuArchDialog()) | ||||
|         .child(<BulkActionsDialog />) | ||||
|         .child(<AboutDialog />) | ||||
|         .child(<HelpDialog />) | ||||
|         .child(<RecentChangesDialog />) | ||||
|         .child(<BranchPrefixDialog />) | ||||
|         .child(<SortChildNotesDialog />) | ||||
|         .child(<IncludeNoteDialog />) | ||||
|         .child(<NoteTypeChooserDialog />) | ||||
|         .child(<JumpToNoteDialog />) | ||||
|         .child(<AddLinkDialog />) | ||||
|         .child(<CloneToDialog />) | ||||
|         .child(<MoveToDialog />) | ||||
|         .child(<ImportDialog />) | ||||
|         .child(<ExportDialog />) | ||||
|         .child(<MarkdownImportDialog />) | ||||
|         .child(<ProtectedSessionPasswordDialog />) | ||||
|         .child(<RevisionsDialog />) | ||||
|         .child(<DeleteNotesDialog />) | ||||
|         .child(<InfoDialog />) | ||||
|         .child(<ConfirmDialog />) | ||||
|         .child(<PromptDialog />) | ||||
|         .child(<IncorrectCpuArchDialog />) | ||||
|         .child(new PopupEditorDialog() | ||||
|                 .child(new FlexContainer("row") | ||||
|                     .class("title-row") | ||||
|                     .css("align-items", "center") | ||||
|                     .cssBlock(".title-row > * { margin: 5px; }") | ||||
|                     .child(new NoteIconWidget()) | ||||
|                     .child(new NoteTitleWidget())) | ||||
|                 .child(new ClassicEditorToolbar()) | ||||
|                     .child(<NoteIconWidget />) | ||||
|                     .child(<NoteTitleWidget />)) | ||||
|                 .child(<PopupEditorFormattingToolbar />) | ||||
|                 .child(new PromotedAttributesWidget()) | ||||
|                 .child(new NoteDetailWidget()) | ||||
|                 .child(new NoteListWidget(true))) | ||||
|         .child(new CallToActionDialog()); | ||||
|                 .child(<NoteList displayOnlyCollections />)) | ||||
|         .child(<CallToActionDialog />); | ||||
| } | ||||
| @@ -3,30 +3,27 @@ import NoteTitleWidget from "../widgets/note_title.js"; | ||||
| import NoteDetailWidget from "../widgets/note_detail.js"; | ||||
| import QuickSearchWidget from "../widgets/quick_search.js"; | ||||
| import NoteTreeWidget from "../widgets/note_tree.js"; | ||||
| import ToggleSidebarButtonWidget from "../widgets/mobile_widgets/toggle_sidebar_button.js"; | ||||
| import MobileDetailMenuWidget from "../widgets/mobile_widgets/mobile_detail_menu.js"; | ||||
| import ScreenContainer from "../widgets/mobile_widgets/screen_container.js"; | ||||
| import ScrollingContainer from "../widgets/containers/scrolling_container.js"; | ||||
| import FilePropertiesWidget from "../widgets/ribbon_widgets/file_properties.js"; | ||||
| import FloatingButtons from "../widgets/floating_buttons/floating_buttons.js"; | ||||
| import EditButton from "../widgets/floating_buttons/edit_button.js"; | ||||
| import RelationMapButtons from "../widgets/floating_buttons/relation_map_buttons.js"; | ||||
| import SvgExportButton from "../widgets/floating_buttons/svg_export_button.js"; | ||||
| import BacklinksWidget from "../widgets/floating_buttons/zpetne_odkazy.js"; | ||||
| import HideFloatingButtonsButton from "../widgets/floating_buttons/hide_floating_buttons_button.js"; | ||||
| import NoteListWidget from "../widgets/note_list.js"; | ||||
| import GlobalMenuWidget from "../widgets/buttons/global_menu.js"; | ||||
| import LauncherContainer from "../widgets/containers/launcher_container.js"; | ||||
| import RootContainer from "../widgets/containers/root_container.js"; | ||||
| import SharedInfoWidget from "../widgets/shared_info.js"; | ||||
| import PromotedAttributesWidget from "../widgets/ribbon_widgets/promoted_attributes.js"; | ||||
| import PromotedAttributesWidget from "../widgets/promoted_attributes.js"; | ||||
| import SidebarContainer from "../widgets/mobile_widgets/sidebar_container.js"; | ||||
| import type AppContext from "../components/app_context.js"; | ||||
| import TabRowWidget from "../widgets/tab_row.js"; | ||||
| import RefreshButton from "../widgets/floating_buttons/refresh_button.js"; | ||||
| import MobileEditorToolbar from "../widgets/ribbon_widgets/mobile_editor_toolbar.js"; | ||||
| import MobileEditorToolbar from "../widgets/type_widgets/ckeditor/mobile_editor_toolbar.js"; | ||||
| import { applyModals } from "./layout_commons.js"; | ||||
| import CloseZenButton from "../widgets/close_zen_button.js"; | ||||
| import FilePropertiesTab from "../widgets/ribbon/FilePropertiesTab.jsx"; | ||||
| import { useNoteContext } from "../widgets/react/hooks.jsx"; | ||||
| import FloatingButtons from "../widgets/FloatingButtons.jsx"; | ||||
| import { MOBILE_FLOATING_BUTTONS } from "../widgets/FloatingButtonsDefinitions.jsx"; | ||||
| import ToggleSidebarButton from "../widgets/mobile_widgets/toggle_sidebar_button.jsx"; | ||||
| import CloseZenModeButton from "../widgets/close_zen_button.js"; | ||||
| import NoteWrapperWidget from "../widgets/note_wrapper.js"; | ||||
| import MobileDetailMenu from "../widgets/mobile_widgets/mobile_detail_menu.js"; | ||||
| import NoteList from "../widgets/collections/NoteList.jsx"; | ||||
| 
 | ||||
| const MOBILE_CSS = ` | ||||
| <style> | ||||
| @@ -135,38 +132,33 @@ export default class MobileLayout { | ||||
|                             .child(new FlexContainer("column").filling().id("mobile-sidebar-wrapper").child(new QuickSearchWidget()).child(new NoteTreeWidget().cssBlock(FANCYTREE_CSS))) | ||||
|                     ) | ||||
|                     .child( | ||||
|                         new ScreenContainer("detail", "column") | ||||
|                         new ScreenContainer("detail", "row") | ||||
|                             .id("detail-container") | ||||
|                             .class("d-sm-flex d-md-flex d-lg-flex d-xl-flex col-12 col-sm-7 col-md-8 col-lg-9") | ||||
|                             .child( | ||||
|                                 new FlexContainer("row") | ||||
|                                     .contentSized() | ||||
|                                     .css("font-size", "larger") | ||||
|                                     .css("align-items", "center") | ||||
|                                     .child(new ToggleSidebarButtonWidget().contentSized()) | ||||
|                                     .child(new NoteTitleWidget().contentSized().css("position", "relative").css("padding-left", "0.5em")) | ||||
|                                     .child(new MobileDetailMenuWidget(true).contentSized()) | ||||
|                                 new NoteWrapperWidget() | ||||
|                                     .child( | ||||
|                                         new FlexContainer("row") | ||||
|                                             .contentSized() | ||||
|                                             .css("font-size", "larger") | ||||
|                                             .css("align-items", "center") | ||||
|                                             .child(<ToggleSidebarButton />) | ||||
|                                             .child(<NoteTitleWidget />) | ||||
|                                             .child(<MobileDetailMenu />) | ||||
|                                     ) | ||||
|                                     .child(<SharedInfoWidget />) | ||||
|                                     .child(<FloatingButtons items={MOBILE_FLOATING_BUTTONS} />) | ||||
|                                     .child(new PromotedAttributesWidget()) | ||||
|                                     .child( | ||||
|                                         new ScrollingContainer() | ||||
|                                             .filling() | ||||
|                                             .contentSized() | ||||
|                                             .child(new NoteDetailWidget()) | ||||
|                                             .child(<NoteList />) | ||||
|                                             .child(<FilePropertiesWrapper />) | ||||
|                                     ) | ||||
|                                     .child(<MobileEditorToolbar />) | ||||
|                             ) | ||||
|                             .child(new SharedInfoWidget()) | ||||
|                             .child( | ||||
|                                 new FloatingButtons() | ||||
|                                     .child(new RefreshButton()) | ||||
|                                     .child(new EditButton()) | ||||
|                                     .child(new RelationMapButtons()) | ||||
|                                     .child(new SvgExportButton()) | ||||
|                                     .child(new BacklinksWidget()) | ||||
|                                     .child(new HideFloatingButtonsButton()) | ||||
|                             ) | ||||
|                             .child(new PromotedAttributesWidget()) | ||||
|                             .child( | ||||
|                                 new ScrollingContainer() | ||||
|                                     .filling() | ||||
|                                     .contentSized() | ||||
|                                     .child(new NoteDetailWidget()) | ||||
|                                     .child(new NoteListWidget(false)) | ||||
|                                     .child(new FilePropertiesWidget().css("font-size", "smaller")) | ||||
|                             ) | ||||
|                             .child(new MobileEditorToolbar()) | ||||
|                     ) | ||||
|             ) | ||||
|             .child( | ||||
| @@ -174,10 +166,25 @@ export default class MobileLayout { | ||||
|                     .contentSized() | ||||
|                     .id("mobile-bottom-bar") | ||||
|                     .child(new TabRowWidget().css("height", "40px")) | ||||
|                     .child(new FlexContainer("row").class("horizontal").css("height", "53px").child(new LauncherContainer(true)).child(new GlobalMenuWidget(true)).id("launcher-pane")) | ||||
|                     .child(new FlexContainer("row") | ||||
|                         .class("horizontal") | ||||
|                         .css("height", "53px") | ||||
|                         .child(new LauncherContainer(true)) | ||||
|                         .child(<GlobalMenuWidget isHorizontalLayout />) | ||||
|                         .id("launcher-pane")) | ||||
|             ) | ||||
|             .child(new CloseZenButton()); | ||||
|             .child(<CloseZenModeButton />); | ||||
|         applyModals(rootContainer); | ||||
|         return rootContainer; | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| function FilePropertiesWrapper() { | ||||
|     const { note } = useNoteContext(); | ||||
| 
 | ||||
|     return ( | ||||
|         <div> | ||||
|             {note?.type === "file" && <FilePropertiesTab note={note} />} | ||||
|         </div> | ||||
|     ); | ||||
| } | ||||
| @@ -1,4 +1,4 @@ | ||||
| import "./stylesheets/bootstrap.scss"; | ||||
| import "bootstrap/dist/css/bootstrap.min.css"; | ||||
|  | ||||
| // @ts-ignore - module = undefined | ||||
| // Required for correct loading of scripts in Electron | ||||
|   | ||||
| @@ -1,6 +1,8 @@ | ||||
| import keyboardActionService from "../services/keyboard_actions.js"; | ||||
| import { KeyboardActionNames } from "@triliumnext/commons"; | ||||
| import keyboardActionService, { getActionSync } from "../services/keyboard_actions.js"; | ||||
| import note_tooltip from "../services/note_tooltip.js"; | ||||
| import utils from "../services/utils.js"; | ||||
| import { should } from "vitest"; | ||||
|  | ||||
| export interface ContextMenuOptions<T> { | ||||
|     x: number; | ||||
| @@ -13,8 +15,13 @@ export interface ContextMenuOptions<T> { | ||||
|     onHide?: () => void; | ||||
| } | ||||
|  | ||||
| interface MenuSeparatorItem { | ||||
|     title: "----"; | ||||
| export interface MenuSeparatorItem { | ||||
|     kind: "separator"; | ||||
| } | ||||
|  | ||||
| export interface MenuHeader { | ||||
|     title: string; | ||||
|     kind: "header"; | ||||
| } | ||||
|  | ||||
| export interface MenuItemBadge { | ||||
| @@ -38,12 +45,13 @@ export interface MenuCommandItem<T> { | ||||
|     handler?: MenuHandler<T>; | ||||
|     items?: MenuItem<T>[] | null; | ||||
|     shortcut?: string; | ||||
|     keyboardShortcut?: KeyboardActionNames; | ||||
|     spellingSuggestion?: string; | ||||
|     checked?: boolean; | ||||
|     columns?: number; | ||||
| } | ||||
|  | ||||
| export type MenuItem<T> = MenuCommandItem<T> | MenuSeparatorItem; | ||||
| export type MenuItem<T> = MenuCommandItem<T> | MenuSeparatorItem | MenuHeader; | ||||
| export type MenuHandler<T> = (item: MenuCommandItem<T>, e: JQuery.MouseDownEvent<HTMLElement, undefined, HTMLElement, HTMLElement>) => void; | ||||
| export type ContextMenuEvent = PointerEvent | MouseEvent | JQuery.ContextMenuEvent; | ||||
|  | ||||
| @@ -148,14 +156,51 @@ class ContextMenu { | ||||
|             .addClass("show"); | ||||
|     } | ||||
|  | ||||
|     addItems($parent: JQuery<HTMLElement>, items: MenuItem<any>[]) { | ||||
|         for (const item of items) { | ||||
|     addItems($parent: JQuery<HTMLElement>, items: MenuItem<any>[], multicolumn = false) { | ||||
|         let $group = $parent; // The current group or parent element to which items are being appended | ||||
|         let shouldStartNewGroup = false; // If true, the next item will start a new group | ||||
|         let shouldResetGroup = false; // If true, the next item will be the last one from the group | ||||
|  | ||||
|         for (let index = 0; index < items.length; index++) { | ||||
|             const item = items[index]; | ||||
|             if (!item) { | ||||
|                 continue; | ||||
|             } | ||||
|  | ||||
|             if (item.title === "----") { | ||||
|                 $parent.append($("<div>").addClass("dropdown-divider")); | ||||
|             // If the current item is a header, start a new group. This group will contain the | ||||
|             // header and the next item that follows the header. | ||||
|             if ("kind" in item && item.kind === "header") { | ||||
|                 if (multicolumn && !shouldResetGroup) { | ||||
|                     shouldStartNewGroup = true; | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             // If the next item is a separator, start a new group. This group will contain the | ||||
|             // current item, the separator, and the next item after the separator. | ||||
|             const nextItem = (index < items.length - 1) ? items[index + 1] : null; | ||||
|             if (multicolumn && nextItem && "kind" in nextItem && nextItem.kind === "separator") { | ||||
|                 if (!shouldResetGroup) { | ||||
|                     shouldStartNewGroup = true; | ||||
|                 } else { | ||||
|                     shouldResetGroup = true; // Continue the current group | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             // Create a new group to avoid column breaks before and after the seaparator / header. | ||||
|             // This is a workaround for Firefox not supporting break-before / break-after: avoid  | ||||
|             // for columns. | ||||
|             if (shouldStartNewGroup) { | ||||
|                 $group = $("<div class='dropdown-no-break'>"); | ||||
|                 $parent.append($group); | ||||
|                 shouldStartNewGroup = false; | ||||
|             } | ||||
|  | ||||
|             if ("kind" in item && item.kind === "separator") { | ||||
|                 $group.append($("<div>").addClass("dropdown-divider")); | ||||
|                 shouldResetGroup = true; // End the group after the next item | ||||
|             } else if ("kind" in item && item.kind === "header") { | ||||
|                 $group.append($("<h6>").addClass("dropdown-header").text(item.title)); | ||||
|                 shouldResetGroup = true; | ||||
|             } else { | ||||
|                 const $icon = $("<span>"); | ||||
|  | ||||
| @@ -185,7 +230,23 @@ class ContextMenu { | ||||
|                     } | ||||
|                 } | ||||
|  | ||||
|                 if ("shortcut" in item && item.shortcut) { | ||||
|                 if ("keyboardShortcut" in item && item.keyboardShortcut) { | ||||
|                     const shortcuts = getActionSync(item.keyboardShortcut).effectiveShortcuts; | ||||
|                     if (shortcuts) { | ||||
|                         const allShortcuts: string[] = []; | ||||
|                         for (const effectiveShortcut of shortcuts) { | ||||
|                             allShortcuts.push(effectiveShortcut.split("+") | ||||
|                                 .map(key => `<kbd>${key}</kbd>`) | ||||
|                                 .join("+")); | ||||
|                         } | ||||
|  | ||||
|                         if (allShortcuts.length) { | ||||
|                             const container = $("<span>").addClass("keyboard-shortcut"); | ||||
|                             container.append($(allShortcuts.join(","))); | ||||
|                             $link.append(container); | ||||
|                         } | ||||
|                     } | ||||
|                 } else if ("shortcut" in item && item.shortcut) { | ||||
|                     $link.append($("<kbd>").text(item.shortcut)); | ||||
|                 } | ||||
|  | ||||
| @@ -241,16 +302,24 @@ class ContextMenu { | ||||
|                     $link.addClass("dropdown-toggle"); | ||||
|  | ||||
|                     const $subMenu = $("<ul>").addClass("dropdown-menu"); | ||||
|                     if (!this.isMobile && item.columns) { | ||||
|                         $subMenu.css("column-count", item.columns); | ||||
|                     const hasColumns = !!item.columns && item.columns > 1; | ||||
|                     if (!this.isMobile && hasColumns) { | ||||
|                         $subMenu.css("column-count", item.columns!); | ||||
|                     } | ||||
|  | ||||
|                     this.addItems($subMenu, item.items); | ||||
|                     this.addItems($subMenu, item.items, hasColumns); | ||||
|  | ||||
|                     $item.append($subMenu); | ||||
|                 } | ||||
|  | ||||
|                 $parent.append($item); | ||||
|                 $group.append($item); | ||||
|                  | ||||
|                 // After adding a menu item, if the previous item was a separator or header, | ||||
|                 // reset the group so that the next item will be appended directly to the parent. | ||||
|                 if (shouldResetGroup) { | ||||
|                     $group = $parent; | ||||
|                     shouldResetGroup = false; | ||||
|                 }; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|   | ||||
| @@ -37,7 +37,7 @@ function setupContextMenu() { | ||||
|                 handler: () => webContents.session.addWordToSpellCheckerDictionary(params.misspelledWord) | ||||
|             }); | ||||
|  | ||||
|             items.push({ title: `----` }); | ||||
|             items.push({ kind: "separator" }); | ||||
|         } | ||||
|  | ||||
|         if (params.isEditable) { | ||||
| @@ -112,7 +112,7 @@ function setupContextMenu() { | ||||
|             // Replace the placeholder with the real search keyword. | ||||
|             let searchUrl = searchEngineUrl.replace("{keyword}", encodeURIComponent(params.selectionText)); | ||||
|  | ||||
|             items.push({ title: "----" }); | ||||
|             items.push({ kind: "separator" }); | ||||
|  | ||||
|             items.push({ | ||||
|                 title: t("electron_context_menu.search_online", { term: shortenedSelection, searchEngine: searchEngineName }), | ||||
|   | ||||
| @@ -45,16 +45,16 @@ export default class LauncherContextMenu implements SelectMenuItemEventListener< | ||||
|             isVisibleRoot || isAvailableRoot ? { title: t("launcher_context_menu.add-script-launcher"), command: "addScriptLauncher", uiIcon: "bx bx-code-curly" } : null, | ||||
|             isVisibleRoot || isAvailableRoot ? { title: t("launcher_context_menu.add-custom-widget"), command: "addWidgetLauncher", uiIcon: "bx bx-customize" } : null, | ||||
|             isVisibleRoot || isAvailableRoot ? { title: t("launcher_context_menu.add-spacer"), command: "addSpacerLauncher", uiIcon: "bx bx-dots-horizontal" } : null, | ||||
|             isVisibleRoot || isAvailableRoot ? { title: "----" } : null, | ||||
|             isVisibleRoot || isAvailableRoot ? { kind: "separator" } : null, | ||||
|  | ||||
|             isAvailableItem ? { title: t("launcher_context_menu.move-to-visible-launchers"), command: "moveLauncherToVisible", uiIcon: "bx bx-show", enabled: true } : null, | ||||
|             isVisibleItem ? { title: t("launcher_context_menu.move-to-available-launchers"), command: "moveLauncherToAvailable", uiIcon: "bx bx-hide", enabled: true } : null, | ||||
|             isVisibleItem || isAvailableItem ? { title: "----" } : null, | ||||
|             isVisibleItem || isAvailableItem ? { kind: "separator" } : null, | ||||
|  | ||||
|             { title: `${t("launcher_context_menu.duplicate-launcher")}`, command: "duplicateSubtree", uiIcon: "bx bx-outline", enabled: isItem }, | ||||
|             { title: `${t("launcher_context_menu.delete")}`, command: "deleteNotes", uiIcon: "bx bx-trash destructive-action-icon", enabled: canBeDeleted }, | ||||
|  | ||||
|             { title: "----" }, | ||||
|             { kind: "separator" }, | ||||
|  | ||||
|             { title: t("launcher_context_menu.reset"), command: "resetLauncher", uiIcon: "bx bx-reset destructive-action-icon", enabled: canBeReset } | ||||
|         ]; | ||||
|   | ||||
| @@ -13,6 +13,8 @@ import type NoteTreeWidget from "../widgets/note_tree.js"; | ||||
| import type FAttachment from "../entities/fattachment.js"; | ||||
| import type { SelectMenuItemEventListener } from "../components/events.js"; | ||||
| import utils from "../services/utils.js"; | ||||
| import attributes from "../services/attributes.js"; | ||||
| import { executeBulkActions } from "../services/bulk_action.js"; | ||||
|  | ||||
| // TODO: Deduplicate once client/server is well split. | ||||
| interface ConvertToAttachmentResponse { | ||||
| @@ -61,6 +63,11 @@ export default class TreeContextMenu implements SelectMenuItemEventListener<Tree | ||||
|         // the only exception is when the only selected note is the one that was right-clicked, then | ||||
|         // it's clear what the user meant to do. | ||||
|         const selNodes = this.treeWidget.getSelectedNodes(); | ||||
|         const selectedNotes = await froca.getNotes(selNodes.map(node => node.data.noteId)); | ||||
|         if (note && !selectedNotes.includes(note)) selectedNotes.push(note); | ||||
|         const isArchived = selectedNotes.every(note => note.isArchived); | ||||
|         const canToggleArchived = !selectedNotes.some(note => note.isArchived !== isArchived); | ||||
|  | ||||
|         const noSelectedNotes = selNodes.length === 0 || (selNodes.length === 1 && selNodes[0] === this.node); | ||||
|  | ||||
|         const notSearch = note?.type !== "search"; | ||||
| @@ -69,27 +76,29 @@ export default class TreeContextMenu implements SelectMenuItemEventListener<Tree | ||||
|         const insertNoteAfterEnabled = isNotRoot && !isHoisted && parentNotSearch; | ||||
|  | ||||
|         const items: (MenuItem<TreeCommandNames> | null)[] = [ | ||||
|             { title: `${t("tree-context-menu.open-in-a-new-tab")}`, command: "openInTab", uiIcon: "bx bx-link-external", enabled: noSelectedNotes }, | ||||
|             { title: t("tree-context-menu.open-in-a-new-tab"), command: "openInTab", shortcut: "Ctrl+Click", uiIcon: "bx bx-link-external", enabled: noSelectedNotes }, | ||||
|             { title: t("tree-context-menu.open-in-a-new-split"), command: "openNoteInSplit", uiIcon: "bx bx-dock-right", enabled: noSelectedNotes }, | ||||
|             { title: t("tree-context-menu.open-in-popup"), command: "openNoteInPopup", uiIcon: "bx bx-edit", enabled: noSelectedNotes }, | ||||
|  | ||||
|             isHoisted | ||||
|                 ? null | ||||
|                 : { | ||||
|                       title: `${t("tree-context-menu.hoist-note")} <kbd data-command="toggleNoteHoisting"></kbd>`, | ||||
|                       title: `${t("tree-context-menu.hoist-note")}`, | ||||
|                       command: "toggleNoteHoisting", | ||||
|                       keyboardShortcut: "toggleNoteHoisting", | ||||
|                       uiIcon: "bx bxs-chevrons-up", | ||||
|                       enabled: noSelectedNotes && notSearch | ||||
|                   }, | ||||
|             !isHoisted || !isNotRoot | ||||
|                 ? null | ||||
|                 : { title: `${t("tree-context-menu.unhoist-note")} <kbd data-command="toggleNoteHoisting"></kbd>`, command: "toggleNoteHoisting", uiIcon: "bx bx-door-open" }, | ||||
|                 : { title: t("tree-context-menu.unhoist-note"), command: "toggleNoteHoisting", keyboardShortcut: "toggleNoteHoisting", uiIcon: "bx bx-door-open" }, | ||||
|  | ||||
|             { title: "----" }, | ||||
|             { kind: "separator" }, | ||||
|  | ||||
|             { | ||||
|                 title: `${t("tree-context-menu.insert-note-after")}<kbd data-command="createNoteAfter"></kbd>`, | ||||
|                 title: t("tree-context-menu.insert-note-after"), | ||||
|                 command: "insertNoteAfter", | ||||
|                 keyboardShortcut: "createNoteAfter", | ||||
|                 uiIcon: "bx bx-plus", | ||||
|                 items: insertNoteAfterEnabled ? await noteTypesService.getNoteTypeItems("insertNoteAfter") : null, | ||||
|                 enabled: insertNoteAfterEnabled && noSelectedNotes && notOptionsOrHelp, | ||||
| @@ -97,21 +106,22 @@ export default class TreeContextMenu implements SelectMenuItemEventListener<Tree | ||||
|             }, | ||||
|  | ||||
|             { | ||||
|                 title: `${t("tree-context-menu.insert-child-note")}<kbd data-command="createNoteInto"></kbd>`, | ||||
|                 title: t("tree-context-menu.insert-child-note"), | ||||
|                 command: "insertChildNote", | ||||
|                 keyboardShortcut: "createNoteInto", | ||||
|                 uiIcon: "bx bx-plus", | ||||
|                 items: notSearch ? await noteTypesService.getNoteTypeItems("insertChildNote") : null, | ||||
|                 enabled: notSearch && noSelectedNotes && notOptionsOrHelp, | ||||
|                 columns: 2 | ||||
|             }, | ||||
|  | ||||
|             { title: "----" }, | ||||
|             { kind: "separator" }, | ||||
|  | ||||
|             { title: t("tree-context-menu.protect-subtree"), command: "protectSubtree", uiIcon: "bx bx-check-shield", enabled: noSelectedNotes }, | ||||
|  | ||||
|             { title: t("tree-context-menu.unprotect-subtree"), command: "unprotectSubtree", uiIcon: "bx bx-shield", enabled: noSelectedNotes }, | ||||
|  | ||||
|             { title: "----" }, | ||||
|             { kind: "separator" }, | ||||
|  | ||||
|             { | ||||
|                 title: t("tree-context-menu.advanced"), | ||||
| @@ -120,48 +130,52 @@ export default class TreeContextMenu implements SelectMenuItemEventListener<Tree | ||||
|                 items: [ | ||||
|                     { title: t("tree-context-menu.apply-bulk-actions"), command: "openBulkActionsDialog", uiIcon: "bx bx-list-plus", enabled: true }, | ||||
|  | ||||
|                     { title: "----" }, | ||||
|                     { kind: "separator" }, | ||||
|  | ||||
|                     { | ||||
|                         title: `${t("tree-context-menu.edit-branch-prefix")} <kbd data-command="editBranchPrefix"></kbd>`, | ||||
|                         title: t("tree-context-menu.edit-branch-prefix"), | ||||
|                         command: "editBranchPrefix", | ||||
|                         keyboardShortcut: "editBranchPrefix", | ||||
|                         uiIcon: "bx bx-rename", | ||||
|                         enabled: isNotRoot && parentNotSearch && noSelectedNotes && notOptionsOrHelp | ||||
|                     }, | ||||
|                     { title: t("tree-context-menu.convert-to-attachment"), command: "convertNoteToAttachment", uiIcon: "bx bx-paperclip", enabled: isNotRoot && !isHoisted && notOptionsOrHelp }, | ||||
|  | ||||
|                     { title: "----" }, | ||||
|                     { kind: "separator" }, | ||||
|  | ||||
|                     { title: `${t("tree-context-menu.expand-subtree")} <kbd data-command="expandSubtree"></kbd>`, command: "expandSubtree", uiIcon: "bx bx-expand", enabled: noSelectedNotes }, | ||||
|                     { title: `${t("tree-context-menu.collapse-subtree")} <kbd data-command="collapseSubtree"></kbd>`, command: "collapseSubtree", uiIcon: "bx bx-collapse", enabled: noSelectedNotes }, | ||||
|                     { title: t("tree-context-menu.expand-subtree"), command: "expandSubtree", keyboardShortcut: "expandSubtree", uiIcon: "bx bx-expand", enabled: noSelectedNotes }, | ||||
|                     { title: t("tree-context-menu.collapse-subtree"), command: "collapseSubtree", keyboardShortcut: "collapseSubtree", uiIcon: "bx bx-collapse", enabled: noSelectedNotes }, | ||||
|                     { | ||||
|                         title: `${t("tree-context-menu.sort-by")} <kbd data-command="sortChildNotes"></kbd>`, | ||||
|                         title: t("tree-context-menu.sort-by"), | ||||
|                         command: "sortChildNotes", | ||||
|                         keyboardShortcut: "sortChildNotes", | ||||
|                         uiIcon: "bx bx-sort-down", | ||||
|                         enabled: noSelectedNotes && notSearch | ||||
|                     }, | ||||
|  | ||||
|                     { title: "----" }, | ||||
|                     { kind: "separator" }, | ||||
|  | ||||
|                     { title: t("tree-context-menu.copy-note-path-to-clipboard"), command: "copyNotePathToClipboard", uiIcon: "bx bx-directions", enabled: true }, | ||||
|                     { title: t("tree-context-menu.recent-changes-in-subtree"), command: "recentChangesInSubtree", uiIcon: "bx bx-history", enabled: noSelectedNotes && notOptionsOrHelp } | ||||
|                 ] | ||||
|             }, | ||||
|  | ||||
|             { title: "----" }, | ||||
|             { kind: "separator" }, | ||||
|  | ||||
|             { | ||||
|                 title: `${t("tree-context-menu.cut")} <kbd data-command="cutNotesToClipboard"></kbd>`, | ||||
|                 title: t("tree-context-menu.cut"), | ||||
|                 command: "cutNotesToClipboard", | ||||
|                 keyboardShortcut: "cutNotesToClipboard", | ||||
|                 uiIcon: "bx bx-cut", | ||||
|                 enabled: isNotRoot && !isHoisted && parentNotSearch | ||||
|             }, | ||||
|  | ||||
|             { title: `${t("tree-context-menu.copy-clone")} <kbd data-command="copyNotesToClipboard"></kbd>`, command: "copyNotesToClipboard", uiIcon: "bx bx-copy", enabled: isNotRoot && !isHoisted }, | ||||
|             { title: t("tree-context-menu.copy-clone"), command: "copyNotesToClipboard", keyboardShortcut: "copyNotesToClipboard", uiIcon: "bx bx-copy", enabled: isNotRoot && !isHoisted }, | ||||
|  | ||||
|             { | ||||
|                 title: `${t("tree-context-menu.paste-into")} <kbd data-command="pasteNotesFromClipboard"></kbd>`, | ||||
|                 title: t("tree-context-menu.paste-into"), | ||||
|                 command: "pasteNotesFromClipboard", | ||||
|                 keyboardShortcut: "pasteNotesFromClipboard", | ||||
|                 uiIcon: "bx bx-paste", | ||||
|                 enabled: !clipboard.isClipboardEmpty() && notSearch && noSelectedNotes | ||||
|             }, | ||||
| @@ -174,39 +188,71 @@ export default class TreeContextMenu implements SelectMenuItemEventListener<Tree | ||||
|             }, | ||||
|  | ||||
|             { | ||||
|                 title: `${t("tree-context-menu.move-to")} <kbd data-command="moveNotesTo"></kbd>`, | ||||
|                 title: t("tree-context-menu.move-to"), | ||||
|                 command: "moveNotesTo", | ||||
|                 keyboardShortcut: "moveNotesTo", | ||||
|                 uiIcon: "bx bx-transfer", | ||||
|                 enabled: isNotRoot && !isHoisted && parentNotSearch | ||||
|             }, | ||||
|  | ||||
|             { title: `${t("tree-context-menu.clone-to")} <kbd data-command="cloneNotesTo"></kbd>`, command: "cloneNotesTo", uiIcon: "bx bx-duplicate", enabled: isNotRoot && !isHoisted }, | ||||
|             { title: t("tree-context-menu.clone-to"), command: "cloneNotesTo", keyboardShortcut: "cloneNotesTo", uiIcon: "bx bx-duplicate", enabled: isNotRoot && !isHoisted }, | ||||
|  | ||||
|             { | ||||
|                 title: `${t("tree-context-menu.duplicate")} <kbd data-command="duplicateSubtree">`, | ||||
|                 title: t("tree-context-menu.duplicate"), | ||||
|                 command: "duplicateSubtree", | ||||
|                 keyboardShortcut: "duplicateSubtree", | ||||
|                 uiIcon: "bx bx-outline", | ||||
|                 enabled: parentNotSearch && isNotRoot && !isHoisted && notOptionsOrHelp | ||||
|             }, | ||||
|  | ||||
|             { | ||||
|                 title: `${t("tree-context-menu.delete")} <kbd data-command="deleteNotes"></kbd>`, | ||||
|                 title: !isArchived ? t("tree-context-menu.archive") : t("tree-context-menu.unarchive"), | ||||
|                 uiIcon: !isArchived ? "bx bx-archive" : "bx bx-archive-out", | ||||
|                 enabled: canToggleArchived, | ||||
|                 handler: () => { | ||||
|                     if (!selectedNotes.length) return; | ||||
|  | ||||
|                     if (selectedNotes.length == 1) { | ||||
|                         const note = selectedNotes[0]; | ||||
|                         if (!isArchived) { | ||||
|                             attributes.addLabel(note.noteId, "archived"); | ||||
|                         } else { | ||||
|                             attributes.removeOwnedLabelByName(note, "archived"); | ||||
|                         } | ||||
|                     } else { | ||||
|                         const noteIds = selectedNotes.map(note => note.noteId); | ||||
|                         if (!isArchived) { | ||||
|                             executeBulkActions(noteIds, [{ | ||||
|                                 name: "addLabel", labelName: "archived" | ||||
|                             }]); | ||||
|                         } else { | ||||
|                             executeBulkActions(noteIds, [{ | ||||
|                                 name: "deleteLabel", labelName: "archived" | ||||
|                             }]); | ||||
|                         } | ||||
|                     } | ||||
|                 } | ||||
|             }, | ||||
|             { | ||||
|                 title: t("tree-context-menu.delete"), | ||||
|                 command: "deleteNotes", | ||||
|                 keyboardShortcut: "deleteNotes", | ||||
|                 uiIcon: "bx bx-trash destructive-action-icon", | ||||
|                 enabled: isNotRoot && !isHoisted && parentNotSearch && notOptionsOrHelp | ||||
|             }, | ||||
|  | ||||
|             { title: "----" }, | ||||
|             { kind: "separator" }, | ||||
|  | ||||
|             { title: t("tree-context-menu.import-into-note"), command: "importIntoNote", uiIcon: "bx bx-import", enabled: notSearch && noSelectedNotes && notOptionsOrHelp }, | ||||
|  | ||||
|             { title: t("tree-context-menu.export"), command: "exportNote", uiIcon: "bx bx-export", enabled: notSearch && noSelectedNotes && notOptionsOrHelp }, | ||||
|  | ||||
|             { title: "----" }, | ||||
|             { kind: "separator" }, | ||||
|  | ||||
|             { | ||||
|                 title: `${t("tree-context-menu.search-in-subtree")} <kbd data-command="searchInSubtree"></kbd>`, | ||||
|                 title: t("tree-context-menu.search-in-subtree"), | ||||
|                 command: "searchInSubtree", | ||||
|                 keyboardShortcut: "searchInSubtree", | ||||
|                 uiIcon: "bx bx-search", | ||||
|                 enabled: notSearch && noSelectedNotes | ||||
|             } | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| import appContext from "./components/app_context.js"; | ||||
| import noteAutocompleteService from "./services/note_autocomplete.js"; | ||||
| import glob from "./services/glob.js"; | ||||
| import "./stylesheets/bootstrap.scss"; | ||||
| import "bootstrap/dist/css/bootstrap.min.css"; | ||||
| import "boxicons/css/boxicons.min.css"; | ||||
| import "autocomplete.js/index_jquery.js"; | ||||
|  | ||||
|   | ||||
| @@ -2,6 +2,7 @@ import server from "./server.js"; | ||||
| import froca from "./froca.js"; | ||||
| import type FNote from "../entities/fnote.js"; | ||||
| import type { AttributeRow } from "./load_results.js"; | ||||
| import { AttributeType } from "@triliumnext/commons"; | ||||
|  | ||||
| async function addLabel(noteId: string, name: string, value: string = "", isInheritable = false) { | ||||
|     await server.put(`notes/${noteId}/attribute`, { | ||||
| @@ -25,6 +26,14 @@ async function removeAttributeById(noteId: string, attributeId: string) { | ||||
|     await server.remove(`notes/${noteId}/attributes/${attributeId}`); | ||||
| } | ||||
|  | ||||
| export async function removeOwnedAttributesByNameOrType(note: FNote, type: AttributeType, name: string) { | ||||
|     for (const attr of note.getOwnedAttributes()) { | ||||
|         if (attr.type === type && attr.name === name) { | ||||
|             await server.remove(`notes/${note.noteId}/attributes/${attr.attributeId}`); | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Removes a label identified by its name from the given note, if it exists. Note that the label must be owned, i.e. | ||||
|  * it will not remove inherited attributes. | ||||
| @@ -52,7 +61,7 @@ function removeOwnedLabelByName(note: FNote, labelName: string) { | ||||
|  * @param value the value of the attribute to set. | ||||
|  */ | ||||
| export async function setAttribute(note: FNote, type: "label" | "relation", name: string, value: string | null | undefined) { | ||||
|     if (value) { | ||||
|     if (value !== null && value !== undefined) { | ||||
|         // Create or update the attribute. | ||||
|         await server.put(`notes/${note.noteId}/set-attribute`, { type, name, value }); | ||||
|     } else { | ||||
|   | ||||
| @@ -210,7 +210,7 @@ function makeToast(id: string, message: string): ToastOptions { | ||||
| } | ||||
|  | ||||
| ws.subscribeToMessages(async (message) => { | ||||
|     if (message.taskType !== "deleteNotes") { | ||||
|     if (!("taskType" in message) || message.taskType !== "deleteNotes") { | ||||
|         return; | ||||
|     } | ||||
|  | ||||
| @@ -228,7 +228,7 @@ ws.subscribeToMessages(async (message) => { | ||||
| }); | ||||
|  | ||||
| ws.subscribeToMessages(async (message) => { | ||||
|     if (message.taskType !== "undeleteNotes") { | ||||
|     if (!("taskType" in message) || message.taskType !== "undeleteNotes") { | ||||
|         return; | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -18,7 +18,7 @@ import type FNote from "../entities/fnote.js"; | ||||
| import toast from "./toast.js"; | ||||
| import { BulkAction } from "@triliumnext/commons"; | ||||
|  | ||||
| const ACTION_GROUPS = [ | ||||
| export const ACTION_GROUPS = [ | ||||
|     { | ||||
|         title: t("bulk_actions.labels"), | ||||
|         actions: [AddLabelBulkAction, UpdateLabelValueBulkAction, RenameLabelBulkAction, DeleteLabelBulkAction] | ||||
|   | ||||
| @@ -256,8 +256,19 @@ function renderFile(entity: FNote | FAttachment, type: string, $renderedContent: | ||||
|             </button> | ||||
|         `); | ||||
|  | ||||
|         $downloadButton.on("click", () => openService.downloadFileNote(entity.noteId)); | ||||
|         $openButton.on("click", () => openService.openNoteExternally(entity.noteId, entity.mime)); | ||||
|         $downloadButton.on("click", (e) => { | ||||
|             e.stopPropagation(); | ||||
|             openService.downloadFileNote(entity.noteId) | ||||
|         }); | ||||
|         $openButton.on("click", async (e) => { | ||||
|             const iconEl = $openButton.find("> .bx"); | ||||
|             iconEl.removeClass("bx bx-link-external"); | ||||
|             iconEl.addClass("bx bx-loader spin"); | ||||
|             e.stopPropagation(); | ||||
|             await openService.openNoteExternally(entity.noteId, entity.mime) | ||||
|             iconEl.removeClass("bx bx-loader spin"); | ||||
|             iconEl.addClass("bx bx-link-external"); | ||||
|         }); | ||||
|         // open doesn't work for protected notes since it works through a browser which isn't in protected session | ||||
|         $openButton.toggle(!entity.isProtected); | ||||
|  | ||||
|   | ||||
| @@ -60,7 +60,7 @@ async function confirmDeleteNoteBoxWithNote(title: string) { | ||||
|     return new Promise<ConfirmDialogResult | undefined>((res) => appContext.triggerCommand("showConfirmDeleteNoteBoxWithNoteDialog", { title, callback: res })); | ||||
| } | ||||
|  | ||||
| async function prompt(props: PromptDialogOptions) { | ||||
| export async function prompt(props: PromptDialogOptions) { | ||||
|     return new Promise<string | null>((res) => appContext.triggerCommand("showPromptDialog", { ...props, callback: res })); | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -48,6 +48,6 @@ function getUrl(docNameValue: string, language: string) { | ||||
|     // Cannot have spaces in the URL due to how JQuery.load works. | ||||
|     docNameValue = docNameValue.replaceAll(" ", "%20"); | ||||
|  | ||||
|     const basePath = window.glob.isDev ? new URL(window.glob.assetPath).pathname : window.glob.assetPath; | ||||
|     const basePath = window.glob.isDev ? window.glob.assetPath + "/.." : window.glob.assetPath; | ||||
|     return `${basePath}/doc_notes/${language}/${docNameValue}.html`; | ||||
| } | ||||
|   | ||||
| @@ -1,16 +1,8 @@ | ||||
| import ws from "./ws.js"; | ||||
| import appContext from "../components/app_context.js"; | ||||
| import { OpenedFileUpdateStatus } from "@triliumnext/commons"; | ||||
|  | ||||
| // TODO: Deduplicate | ||||
| interface Message { | ||||
|     type: string; | ||||
|     entityType: string; | ||||
|     entityId: string; | ||||
|     lastModifiedMs: number; | ||||
|     filePath: string; | ||||
| } | ||||
|  | ||||
| const fileModificationStatus: Record<string, Record<string, Message>> = { | ||||
| const fileModificationStatus: Record<string, Record<string, OpenedFileUpdateStatus>> = { | ||||
|     notes: {}, | ||||
|     attachments: {} | ||||
| }; | ||||
| @@ -39,7 +31,7 @@ function ignoreModification(entityType: string, entityId: string) { | ||||
|     delete fileModificationStatus[entityType][entityId]; | ||||
| } | ||||
|  | ||||
| ws.subscribeToMessages(async (message: Message) => { | ||||
| ws.subscribeToMessages(async message => { | ||||
|     if (message.type !== "openedFileUpdated") { | ||||
|         return; | ||||
|     } | ||||
|   | ||||
| @@ -8,6 +8,7 @@ import FAttribute, { type FAttributeRow } from "../entities/fattribute.js"; | ||||
| import FAttachment, { type FAttachmentRow } from "../entities/fattachment.js"; | ||||
| import type { default as FNote, FNoteRow } from "../entities/fnote.js"; | ||||
| import type { EntityChange } from "../server_types.js"; | ||||
| import type { OptionNames } from "@triliumnext/commons"; | ||||
|  | ||||
| async function processEntityChanges(entityChanges: EntityChange[]) { | ||||
|     const loadResults = new LoadResults(entityChanges); | ||||
| @@ -30,9 +31,8 @@ async function processEntityChanges(entityChanges: EntityChange[]) { | ||||
|                     continue; // only noise | ||||
|                 } | ||||
|  | ||||
|                 options.set(attributeEntity.name, attributeEntity.value); | ||||
|  | ||||
|                 loadResults.addOption(attributeEntity.name); | ||||
|                 options.set(attributeEntity.name as OptionNames, attributeEntity.value); | ||||
|                 loadResults.addOption(attributeEntity.name as OptionNames); | ||||
|             } else if (ec.entityName === "attachments") { | ||||
|                 processAttachment(loadResults, ec); | ||||
|             } else if (ec.entityName === "blobs") { | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| import { t } from "./i18n.js"; | ||||
| import toastService, { showError } from "./toast.js"; | ||||
|  | ||||
| function copyImageReferenceToClipboard($imageWrapper: JQuery<HTMLElement>) { | ||||
| export function copyImageReferenceToClipboard($imageWrapper: JQuery<HTMLElement>) { | ||||
|     try { | ||||
|         $imageWrapper.attr("contenteditable", "true"); | ||||
|         selectImage($imageWrapper.get(0)); | ||||
|   | ||||
| @@ -4,6 +4,7 @@ import ws from "./ws.js"; | ||||
| import utils from "./utils.js"; | ||||
| import appContext from "../components/app_context.js"; | ||||
| import { t } from "./i18n.js"; | ||||
| import { WebSocketMessage } from "@triliumnext/commons"; | ||||
|  | ||||
| type BooleanLike = boolean | "true" | "false"; | ||||
|  | ||||
| @@ -66,7 +67,7 @@ function makeToast(id: string, message: string): ToastOptions { | ||||
| } | ||||
|  | ||||
| ws.subscribeToMessages(async (message) => { | ||||
|     if (message.taskType !== "importNotes") { | ||||
|     if (!("taskType" in message) || message.taskType !== "importNotes") { | ||||
|         return; | ||||
|     } | ||||
|  | ||||
| @@ -87,8 +88,8 @@ ws.subscribeToMessages(async (message) => { | ||||
|     } | ||||
| }); | ||||
|  | ||||
| ws.subscribeToMessages(async (message) => { | ||||
|     if (message.taskType !== "importAttachments") { | ||||
| ws.subscribeToMessages(async (message: WebSocketMessage) => { | ||||
|     if (!("taskType" in message) || message.taskType !== "importAttachments") { | ||||
|         return; | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| import { describe, expect, it } from "vitest"; | ||||
| import { byBookType, byNoteType } from "./help_button.js"; | ||||
| import { byBookType, byNoteType } from "./in_app_help.js"; | ||||
| import fs from "fs"; | ||||
| import type { HiddenSubtreeItem } from "@triliumnext/commons"; | ||||
| import path from "path"; | ||||
| @@ -25,7 +25,7 @@ describe("Help button", () => { | ||||
|             ...Object.values(byBookType) | ||||
|         ].filter((noteId) => noteId) as string[]; | ||||
| 
 | ||||
|         const metaPath = path.resolve(path.join(__dirname, "../../../../server/src/assets/doc_notes/en/User Guide/!!!meta.json")); | ||||
|         const metaPath = path.resolve(path.join(__dirname, "../../../server/src/assets/doc_notes/en/User Guide/!!!meta.json")); | ||||
|         const meta: HiddenSubtreeItem[] = JSON.parse(fs.readFileSync(metaPath, "utf-8")); | ||||
|         const allNoteIds = new Set(getNoteIds(meta)); | ||||
| 
 | ||||
							
								
								
									
										43
									
								
								apps/client/src/services/in_app_help.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								apps/client/src/services/in_app_help.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,43 @@ | ||||
| import { NoteType } from "@triliumnext/commons"; | ||||
| import FNote from "../entities/fnote"; | ||||
| import { ViewTypeOptions } from "../widgets/collections/interface"; | ||||
|  | ||||
| export const byNoteType: Record<Exclude<NoteType, "book">, string | null> = { | ||||
|     canvas: null, | ||||
|     code: null, | ||||
|     contentWidget: null, | ||||
|     doc: null, | ||||
|     file: null, | ||||
|     image: null, | ||||
|     launcher: null, | ||||
|     mermaid: null, | ||||
|     mindMap: null, | ||||
|     noteMap: null, | ||||
|     relationMap: null, | ||||
|     render: null, | ||||
|     search: null, | ||||
|     text: null, | ||||
|     webView: null, | ||||
|     aiChat: null | ||||
| }; | ||||
|  | ||||
| export const byBookType: Record<ViewTypeOptions, string | null> = { | ||||
|     list: "mULW0Q3VojwY", | ||||
|     grid: "8QqnMzx393bx", | ||||
|     calendar: "xWbu3jpNWapp", | ||||
|     table: "2FvYrpmOXm29", | ||||
|     geoMap: "81SGnPGMk7Xc", | ||||
|     board: "CtBQqbwXDx1w" | ||||
| }; | ||||
|  | ||||
| export function getHelpUrlForNote(note: FNote | null | undefined) { | ||||
|     if (note && note.type !== "book" && byNoteType[note.type]) { | ||||
|         return byNoteType[note.type]; | ||||
|     } else if (note?.hasLabel("calendarRoot")) { | ||||
|         return "l0tKav7yLHGF"; | ||||
|     } else if (note?.hasLabel("textSnippet")) { | ||||
|         return "pwc194wlRzcH"; | ||||
|     } else if (note && note.type === "book") { | ||||
|         return byBookType[note.getAttributeValue("label", "viewType") as ViewTypeOptions ?? ""] | ||||
|     } | ||||
| } | ||||
| @@ -62,6 +62,10 @@ async function getAction(actionName: string, silent = false) { | ||||
|     return action; | ||||
| } | ||||
|  | ||||
| export function getActionSync(actionName: string) { | ||||
|     return keyboardActionRepo[actionName]; | ||||
| } | ||||
|  | ||||
| function updateDisplayedShortcuts($container: JQuery<HTMLElement>) { | ||||
|     //@ts-ignore | ||||
|     //TODO: each() does not support async callbacks. | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| import type { AttachmentRow, EtapiTokenRow } from "@triliumnext/commons"; | ||||
| import type { AttachmentRow, EtapiTokenRow, OptionNames } from "@triliumnext/commons"; | ||||
| import type { AttributeType } from "../entities/fattribute.js"; | ||||
| import type { EntityChange } from "../server_types.js"; | ||||
|  | ||||
| @@ -67,7 +67,7 @@ export default class LoadResults { | ||||
|     private revisionRows: RevisionRow[]; | ||||
|     private noteReorderings: string[]; | ||||
|     private contentNoteIdToComponentId: ContentNoteIdToComponentIdRow[]; | ||||
|     private optionNames: string[]; | ||||
|     private optionNames: OptionNames[]; | ||||
|     private attachmentRows: AttachmentRow[]; | ||||
|     public hasEtapiTokenChanges: boolean = false; | ||||
|  | ||||
| @@ -180,11 +180,11 @@ export default class LoadResults { | ||||
|         return this.contentNoteIdToComponentId.find((l) => l.noteId === noteId && l.componentId !== componentId); | ||||
|     } | ||||
|  | ||||
|     addOption(name: string) { | ||||
|     addOption(name: OptionNames) { | ||||
|         this.optionNames.push(name); | ||||
|     } | ||||
|  | ||||
|     isOptionReloaded(name: string) { | ||||
|     isOptionReloaded(name: OptionNames) { | ||||
|         return this.optionNames.includes(name); | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -36,6 +36,8 @@ export interface Suggestion { | ||||
|     commandId?: string; | ||||
|     commandDescription?: string; | ||||
|     commandShortcut?: string; | ||||
|     attributeSnippet?: string; | ||||
|     highlightedAttributeSnippet?: string; | ||||
| } | ||||
|  | ||||
| export interface Options { | ||||
| @@ -323,7 +325,33 @@ function initNoteAutocomplete($el: JQuery<HTMLElement>, options?: Options) { | ||||
|                             html += '</div>'; | ||||
|                             return html; | ||||
|                         } | ||||
|                         return `<span class="${suggestion.icon ?? "bx bx-note"}"></span> ${suggestion.highlightedNotePathTitle}`; | ||||
|                         // Add special class for search-notes action | ||||
|                         const actionClass = suggestion.action === "search-notes" ? "search-notes-action" : ""; | ||||
|  | ||||
|                         // Choose appropriate icon based on action | ||||
|                         let iconClass = suggestion.icon ?? "bx bx-note"; | ||||
|                         if (suggestion.action === "search-notes") { | ||||
|                             iconClass = "bx bx-search"; | ||||
|                         } else if (suggestion.action === "create-note") { | ||||
|                             iconClass = "bx bx-plus"; | ||||
|                         } else if (suggestion.action === "external-link") { | ||||
|                             iconClass = "bx bx-link-external"; | ||||
|                         } | ||||
|  | ||||
|                         // Simplified HTML structure without nested divs | ||||
|                         let html = `<div class="note-suggestion ${actionClass}">`; | ||||
|                         html += `<span class="icon ${iconClass}"></span>`; | ||||
|                         html += `<span class="text">`; | ||||
|                         html += `<span class="search-result-title">${suggestion.highlightedNotePathTitle}</span>`; | ||||
|  | ||||
|                         // Add attribute snippet inline if available | ||||
|                         if (suggestion.highlightedAttributeSnippet) { | ||||
|                             html += `<span class="search-result-attributes">${suggestion.highlightedAttributeSnippet}</span>`; | ||||
|                         } | ||||
|  | ||||
|                         html += `</span>`; | ||||
|                         html += `</div>`; | ||||
|                         return html; | ||||
|                     } | ||||
|                 }, | ||||
|                 // we can't cache identical searches because notes can be created / renamed, new recent notes can be added | ||||
|   | ||||
| @@ -1,71 +0,0 @@ | ||||
| import type FNote from "../entities/fnote.js"; | ||||
| import BoardView from "../widgets/view_widgets/board_view/index.js"; | ||||
| import CalendarView from "../widgets/view_widgets/calendar_view.js"; | ||||
| import GeoView from "../widgets/view_widgets/geo_view/index.js"; | ||||
| import ListOrGridView from "../widgets/view_widgets/list_or_grid_view.js"; | ||||
| import TableView from "../widgets/view_widgets/table_view/index.js"; | ||||
| import type { ViewModeArgs } from "../widgets/view_widgets/view_mode.js"; | ||||
| import type ViewMode from "../widgets/view_widgets/view_mode.js"; | ||||
|  | ||||
| const allViewTypes = ["list", "grid", "calendar", "table", "geoMap", "board"] as const; | ||||
| export type ArgsWithoutNoteId = Omit<ViewModeArgs, "noteIds">; | ||||
| export type ViewTypeOptions = typeof allViewTypes[number]; | ||||
|  | ||||
| export default class NoteListRenderer { | ||||
|  | ||||
|     private viewType: ViewTypeOptions; | ||||
|     private args: ArgsWithoutNoteId; | ||||
|     public viewMode?: ViewMode<any>; | ||||
|  | ||||
|     constructor(args: ArgsWithoutNoteId) { | ||||
|         this.args = args; | ||||
|         this.viewType = this.#getViewType(args.parentNote); | ||||
|     } | ||||
|  | ||||
|     #getViewType(parentNote: FNote): ViewTypeOptions { | ||||
|         const viewType = parentNote.getLabelValue("viewType"); | ||||
|  | ||||
|         if (!(allViewTypes as readonly string[]).includes(viewType || "")) { | ||||
|             // when not explicitly set, decide based on the note type | ||||
|             return parentNote.type === "search" ? "list" : "grid"; | ||||
|         } else { | ||||
|             return viewType as ViewTypeOptions; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     get isFullHeight() { | ||||
|         switch (this.viewType) { | ||||
|             case "list": | ||||
|             case "grid": | ||||
|                 return false; | ||||
|             default: | ||||
|                 return true; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     async renderList() { | ||||
|         const args = this.args; | ||||
|         const viewMode = this.#buildViewMode(args); | ||||
|         this.viewMode = viewMode; | ||||
|         await viewMode.beforeRender(); | ||||
|         return await viewMode.renderList(); | ||||
|     } | ||||
|  | ||||
|     #buildViewMode(args: ViewModeArgs) { | ||||
|         switch (this.viewType) { | ||||
|             case "calendar": | ||||
|                 return new CalendarView(args); | ||||
|             case "table": | ||||
|                 return new TableView(args); | ||||
|             case "geoMap": | ||||
|                 return new GeoView(args); | ||||
|             case "board": | ||||
|                 return new BoardView(args); | ||||
|             case "list": | ||||
|             case "grid": | ||||
|             default: | ||||
|                 return new ListOrGridView(this.viewType, args); | ||||
|         } | ||||
|     } | ||||
|  | ||||
| } | ||||
| @@ -1,7 +1,7 @@ | ||||
| import { t } from "./i18n.js"; | ||||
| import froca from "./froca.js"; | ||||
| import server from "./server.js"; | ||||
| import type { MenuCommandItem, MenuItem, MenuItemBadge } from "../menus/context_menu.js"; | ||||
| import type { MenuCommandItem, MenuItem, MenuItemBadge, MenuSeparatorItem } from "../menus/context_menu.js"; | ||||
| import type { NoteType } from "../entities/fnote.js"; | ||||
| import type { TreeCommandNames } from "../menus/tree_context_menu.js"; | ||||
|  | ||||
| @@ -73,7 +73,7 @@ const BETA_BADGE = { | ||||
|     title: t("note_types.beta-feature") | ||||
| }; | ||||
|  | ||||
| const SEPARATOR = { title: "----" }; | ||||
| const SEPARATOR: MenuSeparatorItem = { kind: "separator" }; | ||||
|  | ||||
| const creationDateCache = new Map<string, Date>(); | ||||
| let rootCreationDate: Date | undefined; | ||||
| @@ -81,8 +81,8 @@ let rootCreationDate: Date | undefined; | ||||
| async function getNoteTypeItems(command?: TreeCommandNames) { | ||||
|     const items: MenuItem<TreeCommandNames>[] = [ | ||||
|         ...getBlankNoteTypes(command), | ||||
|         ...await getBuiltInTemplates(t("note_types.collections"), command, true), | ||||
|         ...await getBuiltInTemplates(null, command, false), | ||||
|         ...await getBuiltInTemplates(t("note_types.collections"), command, true), | ||||
|         ...await getUserTemplates(command) | ||||
|     ]; | ||||
|  | ||||
| @@ -121,7 +121,10 @@ async function getUserTemplates(command?: TreeCommandNames) { | ||||
|     } | ||||
|  | ||||
|     const items: MenuItem<TreeCommandNames>[] = [ | ||||
|         SEPARATOR | ||||
|         { | ||||
|             title: t("note_type_chooser.templates"), | ||||
|             kind: "header" | ||||
|         } | ||||
|     ]; | ||||
|  | ||||
|     for (const templateNote of templateNotes) { | ||||
| @@ -158,8 +161,7 @@ async function getBuiltInTemplates(title: string | null, command: TreeCommandNam | ||||
|     if (title) { | ||||
|         items.push({ | ||||
|             title: title, | ||||
|             enabled: false, | ||||
|             uiIcon: "bx bx-empty" | ||||
|             kind: "header" | ||||
|         }); | ||||
|     } else { | ||||
|         items.push(SEPARATOR); | ||||
|   | ||||
| @@ -35,7 +35,7 @@ function download(url: string) { | ||||
|     } | ||||
| } | ||||
|  | ||||
| function downloadFileNote(noteId: string) { | ||||
| export function downloadFileNote(noteId: string) { | ||||
|     const url = `${getFileUrl("notes", noteId)}?${Date.now()}`; // don't use cache | ||||
|  | ||||
|     download(url); | ||||
| @@ -163,7 +163,7 @@ async function openExternally(type: string, entityId: string, mime: string) { | ||||
|     } | ||||
| } | ||||
|  | ||||
| const openNoteExternally = async (noteId: string, mime: string) => await openExternally("notes", noteId, mime); | ||||
| export const openNoteExternally = async (noteId: string, mime: string) => await openExternally("notes", noteId, mime); | ||||
| const openAttachmentExternally = async (attachmentId: string, mime: string) => await openExternally("attachments", attachmentId, mime); | ||||
|  | ||||
| function getHost() { | ||||
|   | ||||
| @@ -20,7 +20,7 @@ class Options { | ||||
|         this.arr = arr; | ||||
|     } | ||||
|  | ||||
|     get(key: string) { | ||||
|     get(key: OptionNames) { | ||||
|         return this.arr?.[key] as string; | ||||
|     } | ||||
|  | ||||
| @@ -40,7 +40,7 @@ class Options { | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     getInt(key: string) { | ||||
|     getInt(key: OptionNames) { | ||||
|         const value = this.arr?.[key]; | ||||
|         if (typeof value === "number") { | ||||
|             return value; | ||||
| @@ -52,7 +52,7 @@ class Options { | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     getFloat(key: string) { | ||||
|     getFloat(key: OptionNames) { | ||||
|         const value = this.arr?.[key]; | ||||
|         if (typeof value !== "string") { | ||||
|             return null; | ||||
| @@ -60,15 +60,15 @@ class Options { | ||||
|         return parseFloat(value); | ||||
|     } | ||||
|  | ||||
|     is(key: string) { | ||||
|     is(key: OptionNames) { | ||||
|         return this.arr[key] === "true"; | ||||
|     } | ||||
|  | ||||
|     set(key: string, value: OptionValue) { | ||||
|     set(key: OptionNames, value: OptionValue) { | ||||
|         this.arr[key] = value; | ||||
|     } | ||||
|  | ||||
|     async save(key: string, value: OptionValue) { | ||||
|     async save(key: OptionNames, value: OptionValue) { | ||||
|         this.set(key, value); | ||||
|  | ||||
|         const payload: Record<string, OptionValue> = {}; | ||||
| @@ -85,7 +85,7 @@ class Options { | ||||
|         await server.put<void>("options", newValues); | ||||
|     } | ||||
|  | ||||
|     async toggle(key: string) { | ||||
|     async toggle(key: OptionNames) { | ||||
|         await this.save(key, (!this.is(key)).toString()); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -107,11 +107,11 @@ function makeToast(message: Message, title: string, text: string): ToastOptions | ||||
| } | ||||
|  | ||||
| ws.subscribeToMessages(async (message) => { | ||||
|     if (message.taskType !== "protectNotes") { | ||||
|     if (!("taskType" in message) || message.taskType !== "protectNotes") { | ||||
|         return; | ||||
|     } | ||||
|  | ||||
|     const isProtecting = message.data.protect; | ||||
|     const isProtecting = message.data?.protect; | ||||
|     const title = isProtecting ? t("protected_session.protecting-title") : t("protected_session.unprotecting-title"); | ||||
|  | ||||
|     if (message.type === "taskError") { | ||||
|   | ||||
| @@ -10,6 +10,10 @@ let leftInstance: ReturnType<typeof Split> | null; | ||||
| let rightPaneWidth: number; | ||||
| let rightInstance: ReturnType<typeof Split> | null; | ||||
|  | ||||
| const noteSplitMap = new Map<string[], ReturnType<typeof Split> | undefined>(); // key: a group of ntxIds, value: the corresponding Split instance | ||||
| const noteSplitRafMap = new Map<string[], number>(); | ||||
| let splitNoteContainer: HTMLElement | undefined; | ||||
|  | ||||
| function setupLeftPaneResizer(leftPaneVisible: boolean) { | ||||
|     if (leftInstance) { | ||||
|         leftInstance.destroy(); | ||||
| @@ -83,7 +87,86 @@ function setupRightPaneResizer() { | ||||
|     } | ||||
| } | ||||
|  | ||||
| function findKeyByNtxId(ntxId: string): string[] | undefined { | ||||
|     // Find the corresponding key in noteSplitMap based on ntxId | ||||
|     for (const key of noteSplitMap.keys()) { | ||||
|         if (key.includes(ntxId)) return key; | ||||
|     } | ||||
|     return undefined; | ||||
| } | ||||
|  | ||||
| function setupNoteSplitResizer(ntxIds: string[]) { | ||||
|     let targetNtxIds: string[] | undefined; | ||||
|     for (const ntxId of ntxIds) { | ||||
|         targetNtxIds = findKeyByNtxId(ntxId); | ||||
|         if (targetNtxIds) break;  | ||||
|     } | ||||
|  | ||||
|     if (targetNtxIds) { | ||||
|         noteSplitMap.get(targetNtxIds)?.destroy(); | ||||
|         for (const id of ntxIds) { | ||||
|             if (!targetNtxIds.includes(id)) { | ||||
|                 targetNtxIds.push(id) | ||||
|             }; | ||||
|         } | ||||
|     } else { | ||||
|         targetNtxIds = [...ntxIds]; | ||||
|     } | ||||
|     noteSplitMap.set(targetNtxIds, undefined); | ||||
|     createSplitInstance(targetNtxIds); | ||||
| } | ||||
|  | ||||
|  | ||||
| function delNoteSplitResizer(ntxIds: string[]) { | ||||
|     let targetNtxIds = findKeyByNtxId(ntxIds[0]); | ||||
|     if (!targetNtxIds) { | ||||
|         return; | ||||
|     } | ||||
|  | ||||
|     noteSplitMap.get(targetNtxIds)?.destroy(); | ||||
|     noteSplitMap.delete(targetNtxIds); | ||||
|     targetNtxIds = targetNtxIds.filter(id => !ntxIds.includes(id)); | ||||
|  | ||||
|     if (targetNtxIds.length >= 2) { | ||||
|         noteSplitMap.set(targetNtxIds, undefined); | ||||
|         createSplitInstance(targetNtxIds); | ||||
|     } | ||||
| } | ||||
|  | ||||
| function moveNoteSplitResizer(ntxId: string) { | ||||
|     const targetNtxIds = findKeyByNtxId(ntxId); | ||||
|     if (!targetNtxIds) { | ||||
|         return; | ||||
|     } | ||||
|     noteSplitMap.get(targetNtxIds)?.destroy(); | ||||
|     noteSplitMap.set(targetNtxIds, undefined); | ||||
|     createSplitInstance(targetNtxIds); | ||||
| } | ||||
|  | ||||
| function createSplitInstance(targetNtxIds: string[]) { | ||||
|     const prevRafId = noteSplitRafMap.get(targetNtxIds); | ||||
|     if (prevRafId) { | ||||
|         cancelAnimationFrame(prevRafId); | ||||
|     } | ||||
|  | ||||
|     const rafId = requestAnimationFrame(() => { | ||||
|         splitNoteContainer = splitNoteContainer ?? $("#center-pane").find(".split-note-container-widget")[0]; | ||||
|         const splitPanels = [...splitNoteContainer.querySelectorAll<HTMLElement>(':scope > .note-split')] | ||||
|             .filter(el => targetNtxIds.includes(el.getAttribute('data-ntx-id') ?? "")); | ||||
|         const splitInstance = Split(splitPanels, { | ||||
|             gutterSize: DEFAULT_GUTTER_SIZE, | ||||
|             minSize: 150, | ||||
|         }); | ||||
|         noteSplitMap.set(targetNtxIds, splitInstance); | ||||
|         noteSplitRafMap.delete(targetNtxIds); | ||||
|     }); | ||||
|     noteSplitRafMap.set(targetNtxIds, rafId); | ||||
| } | ||||
|  | ||||
| export default { | ||||
|     setupLeftPaneResizer, | ||||
|     setupRightPaneResizer | ||||
|     setupRightPaneResizer, | ||||
|     setupNoteSplitResizer, | ||||
|     delNoteSplitResizer, | ||||
|     moveNoteSplitResizer | ||||
| }; | ||||
|   | ||||
| @@ -218,7 +218,7 @@ function ajax(url: string, method: string, data: unknown, headers: Headers, sile | ||||
| if (utils.isElectron()) { | ||||
|     const ipc = utils.dynamicRequire("electron").ipcRenderer; | ||||
|  | ||||
|     ipc.on("server-response", async (event: string, arg: Arg) => { | ||||
|     ipc.on("server-response", async (_, arg: Arg) => { | ||||
|         if (arg.statusCode >= 200 && arg.statusCode < 300) { | ||||
|             handleSuccessfulResponse(arg); | ||||
|         } else { | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| import { describe, expect, it, vi, beforeEach, afterEach } from "vitest"; | ||||
| import shortcuts, { keyMatches, matchesShortcut } from "./shortcuts.js"; | ||||
| import shortcuts, { keyMatches, matchesShortcut, isIMEComposing } from "./shortcuts.js"; | ||||
|  | ||||
| // Mock utils module | ||||
| vi.mock("./utils.js", () => ({ | ||||
| @@ -320,4 +320,36 @@ describe("shortcuts", () => { | ||||
|             expect(event.preventDefault).not.toHaveBeenCalled(); | ||||
|         }); | ||||
|     }); | ||||
|  | ||||
|     describe('isIMEComposing', () => { | ||||
|         it('should return true when event.isComposing is true', () => { | ||||
|             const event = { isComposing: true, keyCode: 65 } as KeyboardEvent; | ||||
|             expect(isIMEComposing(event)).toBe(true); | ||||
|         }); | ||||
|  | ||||
|         it('should return true when keyCode is 229', () => { | ||||
|             const event = { isComposing: false, keyCode: 229 } as KeyboardEvent; | ||||
|             expect(isIMEComposing(event)).toBe(true); | ||||
|         }); | ||||
|  | ||||
|         it('should return true when both isComposing is true and keyCode is 229', () => { | ||||
|             const event = { isComposing: true, keyCode: 229 } as KeyboardEvent; | ||||
|             expect(isIMEComposing(event)).toBe(true); | ||||
|         }); | ||||
|  | ||||
|         it('should return false for normal keys', () => { | ||||
|             const event = { isComposing: false, keyCode: 65 } as KeyboardEvent; | ||||
|             expect(isIMEComposing(event)).toBe(false); | ||||
|         }); | ||||
|  | ||||
|         it('should return false when isComposing is undefined and keyCode is not 229', () => { | ||||
|             const event = { keyCode: 13 } as KeyboardEvent; | ||||
|             expect(isIMEComposing(event)).toBe(false); | ||||
|         }); | ||||
|  | ||||
|         it('should handle null/undefined events gracefully', () => { | ||||
|             expect(isIMEComposing(null as any)).toBe(false); | ||||
|             expect(isIMEComposing(undefined as any)).toBe(false); | ||||
|         }); | ||||
|     }); | ||||
| }); | ||||
|   | ||||
| @@ -40,6 +40,24 @@ for (let i = 1; i <= 19; i++) { | ||||
|     keyMap[`f${i}`] = [`F${i}`]; | ||||
| } | ||||
|  | ||||
| /** | ||||
|  * Check if IME (Input Method Editor) is composing | ||||
|  * This is used to prevent keyboard shortcuts from firing during IME composition | ||||
|  * @param e - The keyboard event to check | ||||
|  * @returns true if IME is currently composing, false otherwise | ||||
|  */ | ||||
| export function isIMEComposing(e: KeyboardEvent): boolean { | ||||
|     // Handle null/undefined events gracefully | ||||
|     if (!e) { | ||||
|         return false; | ||||
|     } | ||||
|      | ||||
|     // Standard check for composition state | ||||
|     // e.isComposing is true when IME is actively composing | ||||
|     // e.keyCode === 229 is a fallback for older browsers where 229 indicates IME processing | ||||
|     return e.isComposing || e.keyCode === 229; | ||||
| } | ||||
|  | ||||
| function removeGlobalShortcut(namespace: string) { | ||||
|     bindGlobalShortcut("", null, namespace); | ||||
| } | ||||
| @@ -68,6 +86,13 @@ function bindElShortcut($el: JQuery<ElementType | Element>, keyboardShortcut: st | ||||
|                 } | ||||
|  | ||||
|                 const e = evt as KeyboardEvent; | ||||
|                  | ||||
|                 // Skip processing if IME is composing to prevent shortcuts from | ||||
|                 // interfering with text input in CJK languages | ||||
|                 if (isIMEComposing(e)) { | ||||
|                     return; | ||||
|                 } | ||||
|                  | ||||
|                 if (matchesShortcut(e, keyboardShortcut)) { | ||||
|                     e.preventDefault(); | ||||
|                     e.stopPropagation(); | ||||
|   | ||||
| @@ -1,5 +1,6 @@ | ||||
| import dayjs from "dayjs"; | ||||
| import type { ViewScope } from "./link.js"; | ||||
| import FNote from "../entities/fnote"; | ||||
|  | ||||
| const SVG_MIME = "image/svg+xml"; | ||||
|  | ||||
| @@ -46,27 +47,6 @@ function parseDate(str: string) { | ||||
|     } | ||||
| } | ||||
|  | ||||
| // Source: https://stackoverflow.com/a/30465299/4898894 | ||||
| function getMonthsInDateRange(startDate: string, endDate: string) { | ||||
|     const start = startDate.split("-"); | ||||
|     const end = endDate.split("-"); | ||||
|     const startYear = parseInt(start[0]); | ||||
|     const endYear = parseInt(end[0]); | ||||
|     const dates: string[] = []; | ||||
|  | ||||
|     for (let i = startYear; i <= endYear; i++) { | ||||
|         const endMonth = i != endYear ? 11 : parseInt(end[1]) - 1; | ||||
|         const startMon = i === startYear ? parseInt(start[1]) - 1 : 0; | ||||
|  | ||||
|         for (let j = startMon; j <= endMonth; j = j > 12 ? j % 12 || 11 : j + 1) { | ||||
|             const month = j + 1; | ||||
|             const displayMonth = month < 10 ? "0" + month : month; | ||||
|             dates.push([i, displayMonth].join("-")); | ||||
|         } | ||||
|     } | ||||
|     return dates; | ||||
| } | ||||
|  | ||||
| function padNum(num: number) { | ||||
|     return `${num <= 9 ? "0" : ""}${num}`; | ||||
| } | ||||
| @@ -148,7 +128,19 @@ export function isElectron() { | ||||
|     return !!(window && window.process && window.process.type); | ||||
| } | ||||
|  | ||||
| function isMac() { | ||||
| /** | ||||
|  * Returns `true` if the client is running as a PWA, otherwise `false`. | ||||
|  */ | ||||
| export function isPWA() { | ||||
|     return ( | ||||
|         window.matchMedia('(display-mode: standalone)').matches | ||||
|         || window.matchMedia('(display-mode: window-controls-overlay)').matches | ||||
|         || window.navigator.standalone | ||||
|         || window.navigator.windowControlsOverlay | ||||
|     ); | ||||
| } | ||||
|  | ||||
| export function isMac() { | ||||
|     return navigator.platform.indexOf("Mac") > -1; | ||||
| } | ||||
|  | ||||
| @@ -185,7 +177,11 @@ export function escapeQuotes(value: string) { | ||||
|     return value.replaceAll('"', """); | ||||
| } | ||||
|  | ||||
| function formatSize(size: number) { | ||||
| export function formatSize(size: number | null | undefined) { | ||||
|     if (size === null || size === undefined) { | ||||
|         return ""; | ||||
|     } | ||||
|  | ||||
|     size = Math.max(Math.round(size / 1024), 1); | ||||
|  | ||||
|     if (size < 1024) { | ||||
| @@ -292,7 +288,55 @@ function isHtmlEmpty(html: string) { | ||||
|     ); | ||||
| } | ||||
|  | ||||
| async function clearBrowserCache() { | ||||
| function formatHtml(html: string) { | ||||
|     let indent = "\n"; | ||||
|     const tab = "\t"; | ||||
|     let i = 0; | ||||
|     let pre: { indent: string; tag: string }[] = []; | ||||
|  | ||||
|     html = html | ||||
|         .replace(new RegExp("<pre>([\\s\\S]+?)?</pre>"), function (x) { | ||||
|             pre.push({ indent: "", tag: x }); | ||||
|             return "<--TEMPPRE" + i++ + "/-->"; | ||||
|         }) | ||||
|         .replace(new RegExp("<[^<>]+>[^<]?", "g"), function (x) { | ||||
|             let ret; | ||||
|             const tagRegEx = /<\/?([^\s/>]+)/.exec(x); | ||||
|             let tag = tagRegEx ? tagRegEx[1] : ""; | ||||
|             let p = new RegExp("<--TEMPPRE(\\d+)/-->").exec(x); | ||||
|  | ||||
|             if (p) { | ||||
|                 const pInd = parseInt(p[1]); | ||||
|                 pre[pInd].indent = indent; | ||||
|             } | ||||
|  | ||||
|             if (["area", "base", "br", "col", "command", "embed", "hr", "img", "input", "keygen", "link", "menuitem", "meta", "param", "source", "track", "wbr"].indexOf(tag) >= 0) { | ||||
|                 // self closing tag | ||||
|                 ret = indent + x; | ||||
|             } else { | ||||
|                 if (x.indexOf("</") < 0) { | ||||
|                     //open tag | ||||
|                     if (x.charAt(x.length - 1) !== ">") ret = indent + x.substr(0, x.length - 1) + indent + tab + x.substr(x.length - 1, x.length); | ||||
|                     else ret = indent + x; | ||||
|                     !p && (indent += tab); | ||||
|                 } else { | ||||
|                     //close tag | ||||
|                     indent = indent.substr(0, indent.length - 1); | ||||
|                     if (x.charAt(x.length - 1) !== ">") ret = indent + x.substr(0, x.length - 1) + indent + x.substr(x.length - 1, x.length); | ||||
|                     else ret = indent + x; | ||||
|                 } | ||||
|             } | ||||
|             return ret; | ||||
|         }); | ||||
|  | ||||
|     for (i = pre.length; i--;) { | ||||
|         html = html.replace("<--TEMPPRE" + i + "/-->", pre[i].tag.replace("<pre>", "<pre>\n").replace("</pre>", pre[i].indent + "</pre>")); | ||||
|     } | ||||
|  | ||||
|     return html.charAt(0) === "\n" ? html.substr(1, html.length - 1) : html; | ||||
| } | ||||
|  | ||||
| export async function clearBrowserCache() { | ||||
|     if (isElectron()) { | ||||
|         const win = dynamicRequire("@electron/remote").getCurrentWindow(); | ||||
|         await win.webContents.session.clearCache(); | ||||
| @@ -306,7 +350,13 @@ function copySelectionToClipboard() { | ||||
|     } | ||||
| } | ||||
|  | ||||
| export function dynamicRequire(moduleName: string) { | ||||
| type dynamicRequireMappings = { | ||||
|     "@electron/remote": typeof import("@electron/remote"), | ||||
|     "electron": typeof import("electron"), | ||||
|     "child_process": typeof import("child_process") | ||||
| }; | ||||
|  | ||||
| export function dynamicRequire<T extends keyof dynamicRequireMappings>(moduleName: T): Awaited<dynamicRequireMappings[T]>{ | ||||
|     if (typeof __non_webpack_require__ !== "undefined") { | ||||
|         return __non_webpack_require__(moduleName); | ||||
|     } else { | ||||
| @@ -437,7 +487,7 @@ function sleep(time_ms: number) { | ||||
|     }); | ||||
| } | ||||
|  | ||||
| function escapeRegExp(str: string) { | ||||
| export function escapeRegExp(str: string) { | ||||
|     return str.replace(/([.*+?^=!:${}()|\[\]\/\\])/g, "\\$1"); | ||||
| } | ||||
|  | ||||
| @@ -570,8 +620,7 @@ function copyHtmlToClipboard(content: string) { | ||||
|     document.removeEventListener("copy", listener); | ||||
| } | ||||
|  | ||||
| // TODO: Set to FNote once the file is ported. | ||||
| function createImageSrcUrl(note: { noteId: string; title: string }) { | ||||
| export function createImageSrcUrl(note: FNote) { | ||||
|     return `api/images/${note.noteId}/${encodeURIComponent(note.title)}?timestamp=${Date.now()}`; | ||||
| } | ||||
|  | ||||
| @@ -740,7 +789,7 @@ function isUpdateAvailable(latestVersion: string | null | undefined, currentVers | ||||
|     return compareVersions(latestVersion, currentVersion) > 0; | ||||
| } | ||||
|  | ||||
| function isLaunchBarConfig(noteId: string) { | ||||
| export function isLaunchBarConfig(noteId: string) { | ||||
|     return ["_lbRoot", "_lbAvailableLaunchers", "_lbVisibleLaunchers", "_lbMobileRoot", "_lbMobileAvailableLaunchers", "_lbMobileVisibleLaunchers"].includes(noteId); | ||||
| } | ||||
|  | ||||
| @@ -788,12 +837,43 @@ export function arrayEqual<T>(a: T[], b: T[]) { | ||||
|     return true; | ||||
| } | ||||
|  | ||||
| type Indexed<T extends object> = T & { index: number }; | ||||
|  | ||||
| /** | ||||
|  * Given an object array, alters every object in the array to have an index field assigned to it. | ||||
|  * | ||||
|  * @param items the objects to be numbered. | ||||
|  * @returns the same object for convenience, with the type changed to indicate the new index field. | ||||
|  */ | ||||
| export function numberObjectsInPlace<T extends object>(items: T[]): Indexed<T>[] { | ||||
|     let index = 0; | ||||
|     for (const item of items) { | ||||
|         (item as Indexed<T>).index = index++; | ||||
|     } | ||||
|     return items as Indexed<T>[]; | ||||
| } | ||||
|  | ||||
| export function mapToKeyValueArray<K extends string | number | symbol, V>(map: Record<K, V>) { | ||||
|     const values: { key: K, value: V }[] = []; | ||||
|     for (const [ key, value ] of Object.entries(map)) { | ||||
|         values.push({ key: key as K, value: value as V }); | ||||
|     } | ||||
|     return values; | ||||
| } | ||||
|  | ||||
| export function getErrorMessage(e: unknown) { | ||||
|     if (e && typeof e === "object" && "message" in e && typeof e.message === "string") { | ||||
|         return e.message; | ||||
|     } else { | ||||
|         return "Unknown error"; | ||||
|     } | ||||
| } | ||||
|  | ||||
| export default { | ||||
|     reloadFrontendApp, | ||||
|     restartDesktopApp, | ||||
|     reloadTray, | ||||
|     parseDate, | ||||
|     getMonthsInDateRange, | ||||
|     formatDateISO, | ||||
|     formatDateTime, | ||||
|     formatTimeInterval, | ||||
| @@ -801,6 +881,7 @@ export default { | ||||
|     localNowDateTime, | ||||
|     now, | ||||
|     isElectron, | ||||
|     isPWA, | ||||
|     isMac, | ||||
|     isCtrlKey, | ||||
|     assertArguments, | ||||
| @@ -813,6 +894,7 @@ export default { | ||||
|     getNoteTypeClass, | ||||
|     getMimeTypeClass, | ||||
|     isHtmlEmpty, | ||||
|     formatHtml, | ||||
|     clearBrowserCache, | ||||
|     copySelectionToClipboard, | ||||
|     dynamicRequire, | ||||
|   | ||||
| @@ -6,9 +6,10 @@ import frocaUpdater from "./froca_updater.js"; | ||||
| import appContext from "../components/app_context.js"; | ||||
| import { t } from "./i18n.js"; | ||||
| import type { EntityChange } from "../server_types.js"; | ||||
| import { WebSocketMessage } from "@triliumnext/commons"; | ||||
|  | ||||
| type MessageHandler = (message: any) => void; | ||||
| const messageHandlers: MessageHandler[] = []; | ||||
| type MessageHandler = (message: WebSocketMessage) => void; | ||||
| let messageHandlers: MessageHandler[] = []; | ||||
|  | ||||
| let ws: WebSocket; | ||||
| let lastAcceptedEntityChangeId = window.glob.maxEntityChangeIdAtLoad; | ||||
| @@ -47,10 +48,14 @@ function logInfo(message: string) { | ||||
| window.logError = logError; | ||||
| window.logInfo = logInfo; | ||||
|  | ||||
| function subscribeToMessages(messageHandler: MessageHandler) { | ||||
| export function subscribeToMessages(messageHandler: MessageHandler) { | ||||
|     messageHandlers.push(messageHandler); | ||||
| } | ||||
|  | ||||
| export function unsubscribeToMessage(messageHandler: MessageHandler) { | ||||
|     messageHandlers = messageHandlers.filter(handler => handler !== messageHandler); | ||||
| } | ||||
|  | ||||
| // used to serialize frontend update operations | ||||
| let consumeQueuePromise: Promise<void> | null = null; | ||||
|  | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| import "./stylesheets/bootstrap.scss"; | ||||
| import "bootstrap/dist/css/bootstrap.min.css"; | ||||
| import "./stylesheets/auth.css"; | ||||
|  | ||||
| // @TriliumNextTODO: is this even needed anymore? | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| import "jquery"; | ||||
| import utils from "./services/utils.js"; | ||||
| import ko from "knockout"; | ||||
| import "./stylesheets/bootstrap.scss"; | ||||
| import "bootstrap/dist/css/bootstrap.min.css"; | ||||
|  | ||||
| // TriliumNextTODO: properly make use of below types | ||||
| // type SetupModelSetupType = "new-document" | "sync-from-desktop" | "sync-from-server" | ""; | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| import "normalize.css"; | ||||
| import "boxicons/css/boxicons.min.css"; | ||||
| import "@triliumnext/ckeditor5/content.css"; | ||||
| import "@triliumnext/ckeditor5/src/theme/ck-content.css"; | ||||
| import "@triliumnext/share-theme/styles/index.css"; | ||||
| import "@triliumnext/share-theme/scripts/index.js"; | ||||
|  | ||||
|   | ||||
							
								
								
									
										2
									
								
								apps/client/src/stylesheets/bootstrap.scss
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								apps/client/src/stylesheets/bootstrap.scss
									
									
									
									
										vendored
									
									
								
							| @@ -1,2 +0,0 @@ | ||||
| /* Import all of Bootstrap's CSS */ | ||||
| @use "bootstrap/scss/bootstrap"; | ||||
| @@ -28,6 +28,28 @@ | ||||
|     --ck-mention-list-max-height: 500px; | ||||
| } | ||||
|  | ||||
| body#trilium-app.motion-disabled *, | ||||
| body#trilium-app.motion-disabled *::before, | ||||
| body#trilium-app.motion-disabled *::after { | ||||
|     /* Disable transitions and animations */ | ||||
|     transition: none !important; | ||||
|     animation: none !important; | ||||
| } | ||||
|  | ||||
| body#trilium-app.shadows-disabled *, | ||||
| body#trilium-app.shadows-disabled *::before, | ||||
| body#trilium-app.shadows-disabled *::after { | ||||
|     /* Disable shadows */ | ||||
|     box-shadow: none !important; | ||||
| } | ||||
|  | ||||
| body#trilium-app.backdrop-effects-disabled *, | ||||
| body#trilium-app.backdrop-effects-disabled *::before, | ||||
| body#trilium-app.backdrop-effects-disabled *::after { | ||||
|     /* Disable backdrop effects */ | ||||
|     backdrop-filter: none !important; | ||||
| } | ||||
|  | ||||
| .table { | ||||
|     --bs-table-bg: transparent !important; | ||||
| } | ||||
| @@ -139,7 +161,8 @@ textarea, | ||||
|     color: var(--muted-text-color); | ||||
| } | ||||
|  | ||||
| .form-group.disabled { | ||||
| .form-group.disabled, | ||||
| .form-checkbox.disabled { | ||||
|     opacity: 0.5; | ||||
|     pointer-events: none; | ||||
| } | ||||
| @@ -154,6 +177,11 @@ label.tn-checkbox + label.tn-checkbox { | ||||
|     margin-left: 12px; | ||||
| } | ||||
|  | ||||
| label.tn-radio input[type="radio"], | ||||
| label.tn-checkbox input[type="checkbox"] { | ||||
|     margin-right: .5em; | ||||
| } | ||||
|  | ||||
| #left-pane input, | ||||
| #left-pane select, | ||||
| #left-pane textarea { | ||||
| @@ -224,10 +252,6 @@ button.close:hover { | ||||
|     color: var(--main-text-color) !important; | ||||
| } | ||||
|  | ||||
| .note-title[readonly] { | ||||
|     background: inherit; | ||||
| } | ||||
|  | ||||
| .tdialog { | ||||
|     display: none; | ||||
| } | ||||
| @@ -266,6 +290,11 @@ button.close:hover { | ||||
|     pointer-events: none; | ||||
| } | ||||
|  | ||||
| .icon-action.btn { | ||||
|     padding: 0 8px; | ||||
|     min-width: unset !important; | ||||
| } | ||||
|  | ||||
| .ui-widget-content a:not(.ui-tabs-anchor) { | ||||
|     color: #337ab7 !important; | ||||
| } | ||||
| @@ -334,28 +363,24 @@ button kbd { | ||||
| .tabulator-popup-container { | ||||
|     color: var(--menu-text-color) !important; | ||||
|     font-size: inherit; | ||||
|     background-color: var(--menu-background-color) !important; | ||||
|     background: var(--menu-background-color) !important; | ||||
|     user-select: none; | ||||
|     -webkit-user-select: none; | ||||
|     --bs-dropdown-zindex: 999; | ||||
|     --bs-dropdown-link-active-bg: var(--active-item-background-color) !important; | ||||
| } | ||||
|  | ||||
| .dropdown-menu .dropdown-divider { | ||||
|     break-before: avoid; | ||||
|     break-after: avoid; | ||||
| } | ||||
|  | ||||
| body.desktop .dropdown-menu, | ||||
| body.desktop .tabulator-popup-container { | ||||
|     border: 1px solid var(--dropdown-border-color); | ||||
|     column-rule: 1px solid var(--dropdown-border-color); | ||||
|     box-shadow: 0px 10px 20px rgba(0, 0, 0, var(--dropdown-shadow-opacity)); | ||||
|     animation: dropdown-menu-opening 100ms ease-in; | ||||
| } | ||||
|  | ||||
| @supports (animation-fill-mode: forwards) { | ||||
|     /* Delay the opening of submenus */ | ||||
|     body.desktop .dropdown-submenu .dropdown-menu { | ||||
|     body.desktop:not(.motion-disabled) .dropdown-submenu .dropdown-menu { | ||||
|         opacity: 0; | ||||
|         animation-fill-mode: forwards; | ||||
|         animation-delay: var(--submenu-opening-delay); | ||||
| @@ -390,7 +415,7 @@ body.desktop .tabulator-popup-container { | ||||
| } | ||||
|  | ||||
| .dropdown-menu a:hover:not(.disabled), | ||||
| .dropdown-item:hover:not(.disabled, .dropdown-item-container), | ||||
| .dropdown-item:hover:not(.disabled, .dropdown-container-item), | ||||
| .tabulator-menu-item:hover { | ||||
|     color: var(--hover-item-text-color) !important; | ||||
|     background-color: var(--hover-item-background-color) !important; | ||||
| @@ -398,9 +423,9 @@ body.desktop .tabulator-popup-container { | ||||
|     cursor: pointer; | ||||
| } | ||||
|  | ||||
| .dropdown-item-container, | ||||
| .dropdown-item-container:hover, | ||||
| .dropdown-item-container:active { | ||||
| .dropdown-container-item, | ||||
| .dropdown-item.dropdown-container-item:hover, | ||||
| .dropdown-container-item:active { | ||||
|     background: transparent; | ||||
|     cursor: default; | ||||
| } | ||||
| @@ -415,14 +440,20 @@ body #context-menu-container .dropdown-item > span { | ||||
|     align-items: center; | ||||
| } | ||||
|  | ||||
| .dropdown-menu kbd { | ||||
| .dropdown-item span.keyboard-shortcut, | ||||
| .dropdown-item *:not(.keyboard-shortcut) > kbd { | ||||
|     flex-grow: 1; | ||||
|     text-align: right; | ||||
|     padding-inline-start: 12px; | ||||
| } | ||||
|  | ||||
| .dropdown-menu kbd {     | ||||
|     color: var(--muted-text-color); | ||||
|     border: none; | ||||
|     background-color: transparent; | ||||
|     box-shadow: none; | ||||
|     padding-bottom: 0; | ||||
|     padding: 0; | ||||
| } | ||||
|  | ||||
| .dropdown-item, | ||||
| @@ -431,6 +462,12 @@ body #context-menu-container .dropdown-item > span { | ||||
|     border: 1px solid transparent !important; | ||||
| } | ||||
|  | ||||
| /*  This is a workaround for Firefox not supporting break-before / break-after: avoid on columns.  | ||||
|  *  It usually wraps a menu item followed by a separator / header and another menu item. */ | ||||
| .dropdown-no-break { | ||||
|     break-inside: avoid; | ||||
| } | ||||
|  | ||||
| .dropdown-item.disabled, | ||||
| .dropdown-item.disabled kbd { | ||||
|     color: #aaa !important; | ||||
| @@ -438,9 +475,9 @@ body #context-menu-container .dropdown-item > span { | ||||
|  | ||||
| .dropdown-item.active, | ||||
| .dropdown-item:focus { | ||||
|     color: var(--active-item-text-color) !important; | ||||
|     background-color: var(--active-item-background-color) !important; | ||||
|     border-color: var(--active-item-border-color) !important; | ||||
|     color: var(--active-item-text-color); | ||||
|     background-color: var(--active-item-background-color); | ||||
|     border-color: var(--active-item-border-color); | ||||
|     outline: none; | ||||
| } | ||||
|  | ||||
| @@ -840,10 +877,34 @@ table.promoted-attributes-in-tooltip th { | ||||
|  | ||||
| .aa-dropdown-menu .aa-suggestion { | ||||
|     cursor: pointer; | ||||
|     padding: 5px; | ||||
|     padding: 6px 16px; | ||||
|     margin: 0; | ||||
| } | ||||
|  | ||||
| .aa-dropdown-menu .aa-suggestion .icon { | ||||
|     display: inline-block; | ||||
|     line-height: inherit; | ||||
|     vertical-align: top; | ||||
| } | ||||
|  | ||||
| .aa-dropdown-menu .aa-suggestion .text { | ||||
|     display: inline-block; | ||||
|     width: calc(100% - 20px); | ||||
|     padding-left: 4px; | ||||
| } | ||||
|  | ||||
| .aa-dropdown-menu .aa-suggestion .search-result-title { | ||||
|     display: block; | ||||
| } | ||||
|  | ||||
| .aa-dropdown-menu .aa-suggestion .search-result-attributes { | ||||
|     display: block; | ||||
|     font-size: 0.8em; | ||||
|     color: var(--muted-text-color); | ||||
|     opacity: 0.6; | ||||
|     line-height: 1; | ||||
| } | ||||
|  | ||||
| .aa-dropdown-menu .aa-suggestion p { | ||||
|     padding: 0; | ||||
|     margin: 0; | ||||
| @@ -931,6 +992,11 @@ div[data-notify="container"] { | ||||
|     font-family: var(--monospace-font-family); | ||||
| } | ||||
|  | ||||
| svg.ck-icon .note-icon { | ||||
|     color: var(--main-text-color); | ||||
|     font-size: 20px; | ||||
| } | ||||
|  | ||||
| .ck-content { | ||||
|     --ck-content-font-family: var(--detail-font-family); | ||||
|     --ck-content-font-size: 1.1em; | ||||
| @@ -1072,6 +1138,7 @@ a.external:not(.no-arrow):after, a[href^="http://"]:not(.no-arrow):after, a[href | ||||
|  | ||||
| .toast-body { | ||||
|     white-space: preserve-breaks; | ||||
|     overflow: hidden; | ||||
| } | ||||
|  | ||||
| .ck-mentions .ck-button { | ||||
| @@ -1180,6 +1247,10 @@ a.external:not(.no-arrow):after, a[href^="http://"]:not(.no-arrow):after, a[href | ||||
|     cursor: row-resize; | ||||
| } | ||||
|  | ||||
| .hidden-ext.note-split + .gutter { | ||||
|     display: none; | ||||
| } | ||||
|  | ||||
| #context-menu-cover.show { | ||||
|     position: fixed; | ||||
|     top: 0; | ||||
| @@ -1401,7 +1472,7 @@ body:not(.mobile) #launcher-pane.horizontal .dropdown-submenu > .dropdown-menu { | ||||
|     cursor: pointer; | ||||
|     border: none; | ||||
|     color: var(--launcher-pane-text-color); | ||||
|     background-color: var(--launcher-pane-background-color); | ||||
|     background: transparent; | ||||
|     flex-shrink: 0; | ||||
| } | ||||
|  | ||||
| @@ -1709,7 +1780,6 @@ body:not(.mobile) #launcher-pane.horizontal .dropdown-submenu > .dropdown-menu { | ||||
| } | ||||
|  | ||||
| .note-split { | ||||
|     flex-basis: 0; /* so that each split has same width */ | ||||
|     margin-left: auto; | ||||
|     margin-right: auto; | ||||
| } | ||||
| @@ -1773,20 +1843,37 @@ textarea { | ||||
|     font-size: 1em; | ||||
| } | ||||
|  | ||||
| .jump-to-note-dialog .modal-dialog { | ||||
|     max-width: 900px; | ||||
|     width: 90%; | ||||
| } | ||||
|  | ||||
| .jump-to-note-dialog .modal-header { | ||||
|     align-items: center; | ||||
| } | ||||
|  | ||||
| .jump-to-note-dialog .modal-body { | ||||
|     padding: 0; | ||||
|     min-height: 200px; | ||||
| } | ||||
|  | ||||
| .jump-to-note-results .aa-dropdown-menu { | ||||
|     max-height: 40vh; | ||||
|     max-height: calc(80vh - 200px); | ||||
|     width: 100%; | ||||
|     max-width: none; | ||||
|     overflow-y: auto; | ||||
|     overflow-x: hidden; | ||||
|     text-overflow: ellipsis; | ||||
|     box-shadow: none; | ||||
| } | ||||
|  | ||||
| .jump-to-note-results { | ||||
|     width: 100%; | ||||
| } | ||||
|  | ||||
| .jump-to-note-results .aa-suggestions { | ||||
|     padding: 1rem; | ||||
|     padding: 0; | ||||
|     width: 100%; | ||||
| } | ||||
|  | ||||
| /* Command palette styling */ | ||||
| @@ -1804,8 +1891,24 @@ textarea { | ||||
|  | ||||
| .jump-to-note-dialog .aa-cursor .command-suggestion, | ||||
| .jump-to-note-dialog .aa-suggestion:hover .command-suggestion { | ||||
|     border-left-color: var(--link-color); | ||||
|     background-color: var(--hover-background-color); | ||||
|     background-color: transparent; | ||||
| } | ||||
|  | ||||
| .jump-to-note-dialog .show-in-full-search, | ||||
| .jump-to-note-results .show-in-full-search { | ||||
|     border-top: 1px solid var(--main-border-color); | ||||
|     padding-top: 12px; | ||||
|     margin-top: 12px; | ||||
| } | ||||
|  | ||||
| .jump-to-note-results .aa-suggestion .search-notes-action { | ||||
|     border-top: 1px solid var(--main-border-color); | ||||
|     margin-top: 8px; | ||||
|     padding-top: 8px; | ||||
| } | ||||
|  | ||||
| .jump-to-note-results .aa-suggestion:has(.search-notes-action)::after { | ||||
|     display: none; | ||||
| } | ||||
|  | ||||
| .jump-to-note-dialog .command-icon { | ||||
| @@ -2260,16 +2363,27 @@ footer.webview-footer button { | ||||
|     padding: 1px 10px 1px 10px; | ||||
| } | ||||
|  | ||||
| /* Search result highlighting */ | ||||
| .search-result-title b, | ||||
| .search-result-content b { | ||||
|     font-weight: 900; | ||||
|     color: var(--admonition-warning-accent-color); | ||||
| } | ||||
|  | ||||
| /* Customized icons */ | ||||
|  | ||||
| .bx-tn-toc::before { | ||||
|     content: "\ec24"; | ||||
|     transform: rotate(180deg); | ||||
| } | ||||
|  | ||||
| /* CK Edito */ | ||||
|  | ||||
| /* Insert text snippet: limit the width of the listed items to avoid overly long names */ | ||||
| :root body.desktop div.ck-template-form li.ck-list__item .ck-template-form__text-part > span { | ||||
|     max-width: 25vw; | ||||
|     overflow: hidden; | ||||
|     text-overflow: ellipsis; | ||||
| } | ||||
|  | ||||
| .revision-diff-added { | ||||
|     background: rgba(100, 200, 100, 0.5); | ||||
| } | ||||
|  | ||||
| .revision-diff-removed { | ||||
|     background: rgba(255, 100, 100, 0.5); | ||||
|     text-decoration: line-through; | ||||
| } | ||||
| @@ -1,16 +1,16 @@ | ||||
| :root { | ||||
|     --theme-style: dark; | ||||
|  | ||||
|     --main-font-family: Montserrat; | ||||
|     --main-font-family: Montserrat, sans-serif; | ||||
|     --main-font-size: normal; | ||||
|  | ||||
|     --tree-font-family: Montserrat; | ||||
|     --tree-font-family: Montserrat, sans-serif; | ||||
|     --tree-font-size: normal; | ||||
|  | ||||
|     --detail-font-family: Montserrat; | ||||
|     --detail-font-family: Montserrat, sans-serif; | ||||
|     --detail-font-size: normal; | ||||
|  | ||||
|     --monospace-font-family: JetBrainsLight; | ||||
|     --monospace-font-family: JetBrainsLight, monospace; | ||||
|     --monospace-font-size: normal; | ||||
|  | ||||
|     --main-background-color: #333; | ||||
|   | ||||
| @@ -5,16 +5,16 @@ html { | ||||
|     /* either light or dark, colored theme with darker tones are also dark, used e.g. for note map node colors */ | ||||
|     --theme-style: light; | ||||
|  | ||||
|     --main-font-family: Montserrat; | ||||
|     --main-font-family: Montserrat, sans-serif; | ||||
|     --main-font-size: normal; | ||||
|  | ||||
|     --tree-font-family: Montserrat; | ||||
|     --tree-font-family: Montserrat, sans-serif; | ||||
|     --tree-font-size: normal; | ||||
|  | ||||
|     --detail-font-family: Montserrat; | ||||
|     --detail-font-family: Montserrat, sans-serif; | ||||
|     --detail-font-size: normal; | ||||
|  | ||||
|     --monospace-font-family: JetBrainsLight; | ||||
|     --monospace-font-family: JetBrainsLight, monospace; | ||||
|     --monospace-font-size: normal; | ||||
|  | ||||
|     --main-background-color: white; | ||||
|   | ||||
| @@ -13,12 +13,13 @@ | ||||
|  | ||||
|     --theme-style: dark; | ||||
|     --native-titlebar-background: #00000000; | ||||
|     --window-background-color-bgfx: transparent; /* When background effects enabled */ | ||||
|  | ||||
|     --main-background-color: #272727; | ||||
|     --main-text-color: #ccc; | ||||
|     --main-border-color: #454545; | ||||
|     --subtle-border-color: #313131; | ||||
|     --dropdown-border-color: #292929; | ||||
|     --dropdown-border-color: #404040; | ||||
|     --dropdown-shadow-opacity: 0.6; | ||||
|     --dropdown-item-icon-destructive-color: #de6e5b; | ||||
|     --disabled-tooltip-icon-color: #7fd2ef; | ||||
| @@ -89,6 +90,7 @@ | ||||
|  | ||||
|     --menu-text-color: #e3e3e3; | ||||
|     --menu-background-color: #222222d9; | ||||
|     --menu-background-color-no-backdrop: #1b1b1b; | ||||
|     --menu-item-icon-color: #8c8c8c; | ||||
|     --menu-item-disabled-opacity: 0.5; | ||||
|     --menu-item-keyboard-shortcut-color: #ffffff8f; | ||||
| @@ -120,6 +122,8 @@ | ||||
|     --quick-search-focus-border: #80808095; | ||||
|     --quick-search-focus-background: #ffffff1f; | ||||
|     --quick-search-focus-color: white; | ||||
|     --quick-search-result-content-background: #0000004d; | ||||
|     --quick-search-result-highlight-color: #a4d995; | ||||
|  | ||||
|     --left-pane-collapsed-border-color: #0009; | ||||
|     --left-pane-background-color: #1f1f1f; | ||||
| @@ -144,14 +148,17 @@ | ||||
|     --launcher-pane-vert-button-hover-background: #ffffff1c; | ||||
|     --launcher-pane-vert-button-hover-shadow: 4px 4px 4px rgba(0, 0, 0, 0.2); | ||||
|     --launcher-pane-vert-button-focus-outline-color: var(--input-focus-outline-color); | ||||
|     --launcher-pane-vert-background-color-bgfx: #00000026; /* When background effects enabled */ | ||||
|  | ||||
|     --launcher-pane-horiz-border-color: rgb(22, 22, 22); | ||||
|     --launcher-pane-horiz-background-color: #282828; | ||||
|     --launcher-pane-horiz-text-color: #909090; | ||||
|     --launcher-pane-horiz-text-color: #b8b8b8; | ||||
|     --launcher-pane-horiz-button-hover-color: #ffffff; | ||||
|     --launcher-pane-horiz-button-hover-background: #ffffff1c; | ||||
|     --launcher-pane-horiz-button-hover-shadow: unset; | ||||
|     --launcher-pane-horiz-button-focus-outline-color: var(--input-focus-outline-color); | ||||
|     --launcher-pane-horiz-background-color-bgfx: #ffffff17; /* When background effects enabled */ | ||||
|     --launcher-pane-horiz-border-color-bgfx: #00000080; /* When background effects enabled */ | ||||
|  | ||||
|     --protected-session-active-icon-color: #8edd8e; | ||||
|     --sync-status-error-pulse-color: #f47871; | ||||
| @@ -165,9 +172,10 @@ | ||||
|  | ||||
|     --tab-close-button-hover-background: #a45353; | ||||
|     --tab-close-button-hover-color: white; | ||||
|  | ||||
|      | ||||
|     --active-tab-background-color: #ffffff1c; | ||||
|     --active-tab-hover-background-color: var(--active-tab-background-color); | ||||
|     --active-tab-icon-color: #a9a9a9; | ||||
|     --active-tab-text-color: #ffffffcd; | ||||
|     --active-tab-shadow: 3px 3px 6px rgba(0, 0, 0, 0.2), -1px -1px 3px rgba(0, 0, 0, 0.4); | ||||
|     --active-tab-dragging-shadow: var(--active-tab-shadow), 0 0 20px rgba(0, 0, 0, 0.4); | ||||
|   | ||||
| @@ -13,6 +13,7 @@ | ||||
|  | ||||
|     --theme-style: light; | ||||
|     --native-titlebar-background: #ffffff00; | ||||
|     --window-background-color-bgfx: transparent; /* When background effects enabled */ | ||||
|  | ||||
|     --main-background-color: white; | ||||
|     --main-text-color: black; | ||||
| @@ -83,6 +84,7 @@ | ||||
|  | ||||
|     --menu-text-color: #272727; | ||||
|     --menu-background-color: #ffffffd9; | ||||
|     --menu-background-color-no-backdrop: #fdfdfd; | ||||
|     --menu-item-icon-color: #727272; | ||||
|     --menu-item-disabled-opacity: 0.6; | ||||
|     --menu-item-keyboard-shortcut-color: #666666a8; | ||||
| @@ -114,15 +116,17 @@ | ||||
|     --quick-search-focus-border: #00000029; | ||||
|     --quick-search-focus-background: #ffffff80; | ||||
|     --quick-search-focus-color: #000; | ||||
|     --quick-search-result-content-background: #0000000f; | ||||
|     --quick-search-result-highlight-color: #c65050; | ||||
|  | ||||
|     --left-pane-collapsed-border-color: #0000000d; | ||||
|     --left-pane-background-color: #f2f2f2; | ||||
|     --left-pane-text-color: #383838; | ||||
|     --left-pane-item-hover-background: #eaeaea; | ||||
|     --left-pane-item-hover-background: rgba(0, 0, 0, 0.032); | ||||
|     --left-pane-item-selected-background: white; | ||||
|     --left-pane-item-selected-color: black; | ||||
|     --left-pane-item-selected-shadow: 1px 1px 2px rgba(0, 0, 0, 0.2); | ||||
|     --left-pane-item-action-button-background: #d7d7d7; | ||||
|     --left-pane-item-action-button-background: rgba(0, 0, 0, 0.11); | ||||
|     --left-pane-item-action-button-color: inherit; | ||||
|     --left-pane-item-action-button-hover-background: white; | ||||
|     --left-pane-item-action-button-hover-shadow: 2px 2px 3px rgba(0, 0, 0, 0.15); | ||||
| @@ -138,6 +142,7 @@ | ||||
|     --launcher-pane-vert-button-hover-background: white; | ||||
|     --launcher-pane-vert-button-hover-shadow: 4px 4px 4px rgba(0, 0, 0, 0.075); | ||||
|     --launcher-pane-vert-button-focus-outline-color: var(--input-focus-outline-color); | ||||
|     --launcher-pane-vert-background-color-bgfx: #00000009; /* When background effects enabled */ | ||||
|  | ||||
|     --launcher-pane-horiz-border-color: rgba(0, 0, 0, 0.1); | ||||
|     --launcher-pane-horiz-background-color: #fafafa; | ||||
| @@ -145,6 +150,8 @@ | ||||
|     --launcher-pane-horiz-button-hover-background: var(--icon-button-hover-background); | ||||
|     --launcher-pane-horiz-button-hover-shadow: unset; | ||||
|     --launcher-pane-horiz-button-focus-outline-color: var(--input-focus-outline-color); | ||||
|     --launcher-pane-horiz-background-color-bgfx: #ffffffb3; /* When background effects enabled */ | ||||
|     --launcher-pane-horiz-border-color-bgfx: #00000026; /* When background effects enabled */ | ||||
|  | ||||
|     --protected-session-active-icon-color: #16b516; | ||||
|     --sync-status-error-pulse-color: #ff5528; | ||||
| @@ -158,9 +165,10 @@ | ||||
|  | ||||
|     --tab-close-button-hover-background: #c95a5a; | ||||
|     --tab-close-button-hover-color: white; | ||||
|  | ||||
|      | ||||
|     --active-tab-background-color: white; | ||||
|     --active-tab-hover-background-color: var(--active-tab-background-color); | ||||
|     --active-tab-icon-color: gray; | ||||
|     --active-tab-text-color: black; | ||||
|     --active-tab-shadow: 3px 3px 6px rgba(0, 0, 0, 0.1), -1px -1px 3px rgba(0, 0, 0, 0.05); | ||||
|     --active-tab-dragging-shadow: var(--active-tab-shadow), 0 0 20px rgba(0, 0, 0, 0.1); | ||||
|   | ||||
| @@ -26,7 +26,7 @@ | ||||
|     --detail-font-family: var(--main-font-family); | ||||
|     --detail-font-size: normal; | ||||
|  | ||||
|     --monospace-font-family: JetBrainsLight; | ||||
|     --monospace-font-family: JetBrainsLight, monospace; | ||||
|     --monospace-font-size: normal; | ||||
|  | ||||
|     --left-pane-item-selected-shadow-size: 2px; | ||||
| @@ -83,6 +83,12 @@ | ||||
|     --tab-note-icons: true; | ||||
| } | ||||
|  | ||||
| body.backdrop-effects-disabled { | ||||
|     /* Backdrop effects are disabled, replace the menu background color with the | ||||
|      * no-backdrop fallback color */ | ||||
|     --menu-background-color: var(--menu-background-color-no-backdrop); | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * MENUS | ||||
|  * | ||||
| @@ -96,10 +102,6 @@ | ||||
|     font-size: 0.9rem !important; | ||||
| } | ||||
|  | ||||
| .dropdown-menu { | ||||
|     --scrollbar-background-color: var(--menu-background-color); | ||||
| } | ||||
|  | ||||
| body.mobile .dropdown-menu { | ||||
|     backdrop-filter: var(--dropdown-backdrop-filter); | ||||
|     border-radius: var(--dropdown-border-radius); | ||||
| @@ -148,12 +150,22 @@ body.desktop .dropdown-submenu .dropdown-menu { | ||||
| .dropdown-item, | ||||
| body.mobile .dropdown-submenu .dropdown-toggle { | ||||
|     padding: 2px 2px 2px 8px !important; | ||||
|     padding-inline-end: 16px !important; | ||||
|     padding-inline-end: 22px !important; | ||||
|     /* Note: the right padding should also accommodate the submenu arrow. */ | ||||
|     border-radius: 6px; | ||||
|     cursor: default !important; | ||||
| } | ||||
|  | ||||
| :root .dropdown-item:focus-visible { | ||||
|     outline: 2px solid var(--input-focus-outline-color) !important; | ||||
|     background-color: transparent; | ||||
|     color: unset; | ||||
| } | ||||
|  | ||||
| :root .dropdown-item:active { | ||||
|     background: unset; | ||||
| } | ||||
|  | ||||
| body.mobile .dropdown-submenu { | ||||
|     padding: 0 !important; | ||||
| } | ||||
| @@ -191,13 +203,17 @@ html body .dropdown-item[disabled] { | ||||
|  | ||||
| /* Menu item keyboard shortcut */ | ||||
| .dropdown-item kbd { | ||||
|     margin-left: 16px; | ||||
|     font-family: unset !important; | ||||
|     font-size: unset !important; | ||||
|     color: var(--menu-item-keyboard-shortcut-color) !important; | ||||
|     padding-top: 0; | ||||
| } | ||||
|  | ||||
| .dropdown-item span.keyboard-shortcut { | ||||
|     color: var(--menu-item-keyboard-shortcut-color) !important; | ||||
|     margin-left: 16px; | ||||
| } | ||||
|  | ||||
| .dropdown-divider { | ||||
|     position: relative; | ||||
|     border-color: transparent !important; | ||||
| @@ -279,6 +295,20 @@ body.mobile .dropdown-menu .dropdown-item.submenu-open .dropdown-toggle::after { | ||||
|     transform: rotate(270deg); | ||||
| } | ||||
|  | ||||
| /* Dropdown item button (used in zoom buttons in global menu) */ | ||||
|  | ||||
| li.dropdown-item a.dropdown-item-button { | ||||
|     border: unset; | ||||
| } | ||||
|  | ||||
| li.dropdown-item a.dropdown-item-button.bx { | ||||
|     color: var(--menu-text-color) !important; | ||||
| } | ||||
|  | ||||
| li.dropdown-item a.dropdown-item-button:focus-visible { | ||||
|     outline: 2px solid var(--input-focus-outline-color) !important; | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * TOASTS | ||||
|  */ | ||||
| @@ -319,6 +349,8 @@ body.mobile .dropdown-menu .dropdown-item.submenu-open .dropdown-toggle::after { | ||||
|  | ||||
| #toast-container .toast .toast-body { | ||||
|     flex-grow: 1; | ||||
|     overflow: hidden; | ||||
|     text-overflow: ellipsis; | ||||
| } | ||||
|  | ||||
| /* | ||||
| @@ -530,10 +562,9 @@ body.mobile .dropdown-menu .dropdown-item.submenu-open .dropdown-toggle::after { | ||||
| } | ||||
|  | ||||
| /* List item */ | ||||
| .jump-to-note-dialog .aa-suggestions div, | ||||
| .note-detail-empty .aa-suggestions div { | ||||
| .jump-to-note-dialog .aa-suggestion, | ||||
| .note-detail-empty .aa-suggestion { | ||||
|     border-radius: 6px; | ||||
|     padding: 6px 12px; | ||||
|     color: var(--menu-text-color); | ||||
|     cursor: default; | ||||
| } | ||||
|   | ||||
| @@ -5,7 +5,8 @@ | ||||
| button.btn.btn-primary, | ||||
| button.btn.btn-secondary, | ||||
| button.btn.btn-sm:not(.select-button), | ||||
| button.btn.btn-success { | ||||
| button.btn.btn-success, | ||||
| button.ck.ck-button:is(.ck-button-action, .ck-button-save, .ck-button-cancel, .ck-button-replaceall, .ck-button-replace).ck-button_with-text { | ||||
|     display: inline-flex; | ||||
|     align-items: center; | ||||
|     justify-content: center; | ||||
| @@ -21,7 +22,8 @@ button.btn.btn-success { | ||||
| button.btn.btn-primary:hover, | ||||
| button.btn.btn-secondary:hover, | ||||
| button.btn.btn-sm:not(.select-button):hover, | ||||
| button.btn.btn-success:hover { | ||||
| button.btn.btn-success:hover, | ||||
| button.ck.ck-button:is(.ck-button-action, .ck-button-save, .ck-button-cancel, .ck-button-replaceall, .ck-button-replace).ck-button_with-text:not(.ck-disabled):hover { | ||||
|     background: var(--cmd-button-hover-background-color); | ||||
|     color: var(--cmd-button-hover-text-color); | ||||
| } | ||||
| @@ -29,7 +31,8 @@ button.btn.btn-success:hover { | ||||
| button.btn.btn-primary:active, | ||||
| button.btn.btn-secondary:active, | ||||
| button.btn.btn-sm:not(.select-button):active, | ||||
| button.btn.btn-success:active { | ||||
| button.btn.btn-success:active, | ||||
| button.ck.ck-button:is(.ck-button-action, .ck-button-save, .ck-button-cancel, .ck-button-replaceall, .ck-button-replace).ck-button_with-text:not(.ck-disabled):active { | ||||
|     opacity: 0.85; | ||||
|     box-shadow: unset; | ||||
|     background: var(--cmd-button-background-color) !important; | ||||
| @@ -40,14 +43,16 @@ button.btn.btn-success:active { | ||||
| button.btn.btn-primary:disabled, | ||||
| button.btn.btn-secondary:disabled, | ||||
| button.btn.btn-sm:not(.select-button):disabled, | ||||
| button.btn.btn-success:disabled { | ||||
| button.btn.btn-success:disabled, | ||||
| button.ck.ck-button:is(.ck-button-action, .ck-button-save, .ck-button-cancel, .ck-button-replaceall, .ck-button-replace).ck-button_with-text.ck-disabled { | ||||
|     opacity: var(--cmd-button-disabled-opacity); | ||||
| } | ||||
|  | ||||
| button.btn.btn-primary:focus-visible, | ||||
| button.btn.btn-secondary:focus-visible, | ||||
| button.btn.btn-sm:not(.select-button):focus-visible, | ||||
| button.btn.btn-success:focus-visible { | ||||
| button.btn.btn-success:focus-visible, | ||||
| button.ck.ck-button:is(.ck-button-action, .ck-button-save, .ck-button-cancel, .ck-button-replaceall, .ck-button-replace).ck-button_with-text:not(.ck-disabled):focus-visible { | ||||
|     outline: 2px solid var(--input-focus-outline-color); | ||||
| } | ||||
|  | ||||
| @@ -79,7 +84,7 @@ button.btn.btn-success kbd { | ||||
|  */ | ||||
|  | ||||
| :root .icon-action:not(.global-menu-button), | ||||
| :root .btn.tn-tool-button, | ||||
| :root .tn-tool-button, | ||||
| :root .btn-group .tn-tool-button:not(:last-child), | ||||
| :root .btn-group .tn-tool-button:last-child { | ||||
|     width: var(--icon-button-size); | ||||
| @@ -91,6 +96,11 @@ button.btn.btn-success kbd { | ||||
|     color: var(--icon-button-color); | ||||
| } | ||||
|  | ||||
| :root .btn-group .icon-action:last-child { | ||||
|     border-top-left-radius: unset !important; | ||||
|     border-bottom-left-radius: unset !important; | ||||
| } | ||||
|  | ||||
| .btn-group .tn-tool-button + .tn-tool-button { | ||||
|     margin-left: 4px !important; | ||||
| } | ||||
| @@ -149,8 +159,11 @@ input[type="password"], | ||||
| input[type="date"], | ||||
| input[type="time"], | ||||
| input[type="datetime-local"], | ||||
| :root input.ck.ck-input-text, | ||||
| :root input.ck.ck-input-number, | ||||
| textarea.form-control, | ||||
| textarea, | ||||
| :root textarea.ck.ck-textarea, | ||||
| .tn-input-field { | ||||
|     outline: 3px solid transparent; | ||||
|     outline-offset: 6px; | ||||
| @@ -167,8 +180,11 @@ input[type="password"]:hover, | ||||
| input[type="date"]:hover, | ||||
| input[type="time"]:hover, | ||||
| input[type="datetime-local"]:hover, | ||||
| :root input.ck.ck-input-text:not([readonly="true"]):hover, | ||||
| :root input.ck.ck-input-number:not([readonly="true"]):hover, | ||||
| textarea.form-control:hover, | ||||
| textarea:hover, | ||||
| :root textarea.ck.ck-textarea:hover, | ||||
| .tn-input-field:hover { | ||||
|     background: var(--input-hover-background); | ||||
|     color: var(--input-hover-color); | ||||
| @@ -181,8 +197,11 @@ input[type="password"]:focus, | ||||
| input[type="date"]:focus, | ||||
| input[type="time"]:focus, | ||||
| input[type="datetime-local"]:focus, | ||||
| :root input.ck.ck-input-text:not([readonly="true"]):focus, | ||||
| :root input.ck.ck-input-number:not([readonly="true"]):focus, | ||||
| textarea.form-control:focus, | ||||
| textarea:focus, | ||||
| :root textarea.ck.ck-textarea:focus, | ||||
| .tn-input-field:focus, | ||||
| .tn-input-field:focus-within { | ||||
|     box-shadow: unset; | ||||
| @@ -455,6 +474,7 @@ optgroup { | ||||
|         left: 0; | ||||
|         width: var(--box-size); | ||||
|         height: 100%; | ||||
|         margin: unset; | ||||
|         opacity: 0 !important; | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -4,6 +4,7 @@ | ||||
|  | ||||
|  :root { | ||||
|     --ck-font-face: var(--main-font-family); | ||||
|     --ck-input-label-height: 1.5em; | ||||
|  } | ||||
|  | ||||
| /* | ||||
| @@ -307,6 +308,11 @@ | ||||
|     fill: black !important; | ||||
| } | ||||
|  | ||||
| /* Hex color input box prefix */ | ||||
| :root .ck.ck-color-selector .ck-color-picker__hash-view { | ||||
|     margin-top: var(--ck-input-label-height); | ||||
| } | ||||
|  | ||||
| /* Numbered list */ | ||||
|  | ||||
| :root .ck.ck-list-properties_with-numbered-properties .ck.ck-list-styles-list { | ||||
| @@ -363,19 +369,86 @@ | ||||
|     color: var(--accent); | ||||
| } | ||||
|  | ||||
| /* Action buttons */ | ||||
| /* Text snippet dropdown */ | ||||
|  | ||||
| :root .ck-link-actions button.ck-button, | ||||
| :root .ck-link-form button.ck-button { | ||||
|     --ck-border-radius: 6px; | ||||
|      | ||||
|     background: transparent; | ||||
|     box-shadow: unset; | ||||
| div.ck-template-form { | ||||
|     padding: 8px; | ||||
| } | ||||
|  | ||||
| :root .ck-link-actions button.ck-button:hover, | ||||
| :root .ck-link-form button.ck-button:hover { | ||||
|     background: var(--hover-item-background-color); | ||||
| div.ck-template-form .ck-labeled-field-view { | ||||
|     margin-bottom: 8px; | ||||
| } | ||||
|  | ||||
| /* Template item */ | ||||
|  | ||||
| :root div.ck-template-form li.ck-list__item button.ck-template-button { | ||||
|     padding: 4px 8px; | ||||
| } | ||||
|  | ||||
| /* Template icon */ | ||||
| :root .ck-template-form .ck-button__icon { | ||||
|     --ck-spacing-medium: 2px; | ||||
| } | ||||
|  | ||||
| :root div.ck-template-form  .note-icon { | ||||
|     color: var(--menu-item-icon-color); | ||||
| } | ||||
|  | ||||
| /* Template name */ | ||||
| div.ck-template-form .ck-template-form__text-part { | ||||
|     color: var(--hover-item-text-color); | ||||
|     font-size: .9rem; | ||||
| } | ||||
|  | ||||
| div.ck-template-form .ck-template-form__text-part mark { | ||||
|     background: unset; | ||||
|     color: var(--quick-search-result-highlight-color); | ||||
|     font-weight: bold; | ||||
| } | ||||
|  | ||||
| /* Template description */ | ||||
| :root div.ck-template-form .ck-template-form__description { | ||||
|     opacity: .5; | ||||
|     font-size: .9em; | ||||
| } | ||||
|  | ||||
| /* Messages */ | ||||
| div.ck-template-form .ck-search__info > span { | ||||
|     line-height: initial; | ||||
|     color: var(--muted-text-color); | ||||
| } | ||||
|  | ||||
| div.ck-template-form .ck-search__info span:nth-child(2) { | ||||
|     display: block; | ||||
|     opacity: .5; | ||||
|     margin-top: 8px; | ||||
|     font-size: .9em; | ||||
| } | ||||
|  | ||||
| /* Link dropdown */ | ||||
|  | ||||
| :root .ck.ck-form.ck-link-form ul.ck-link-form__providers-list { | ||||
|     border-top: none; | ||||
| } | ||||
|  | ||||
| /* Math popup */ | ||||
|  | ||||
| .ck-math-form .ck-labeled-field-view { | ||||
|     --ck-input-label-height: 0; | ||||
|  | ||||
|     margin-inline-end: 8px; | ||||
| } | ||||
|  | ||||
| /* Emoji dropdown */ | ||||
|  | ||||
| .ck-emoji-picker-form .ck-emoji__search .ck-button_with-text:not(.ck-list-item-button) { | ||||
|     margin-top: var(--ck-input-label-height); | ||||
| } | ||||
|  | ||||
| /* Find and replace dialog */ | ||||
|  | ||||
| .ck-find-and-replace-form .ck-find-and-replace-form__inputs button { | ||||
|     margin-top: var(--ck-input-label-height); | ||||
| } | ||||
|  | ||||
| /* Mention list (the autocompletion list for emojis, labels and relations)  */ | ||||
| @@ -392,6 +465,58 @@ | ||||
|     background: transparent; | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * FORMS | ||||
|  */ | ||||
|  | ||||
| /* | ||||
|  * Buttons | ||||
|  */ | ||||
|  | ||||
| button.ck.ck-button:is(.ck-button-action, .ck-button-save, .ck-button-cancel).ck-button_with-text { | ||||
|     --ck-color-text: var(--cmd-button-text-color); | ||||
|  | ||||
|     min-width: 60px; | ||||
|     font-weight: 500; | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * Text boxes | ||||
|  */ | ||||
|  | ||||
| .ck.ck-labeled-field-view { | ||||
|     padding-top: var(--ck-input-label-height) !important; /* Create space for the label */ | ||||
| } | ||||
|  | ||||
| .ck.ck-labeled-field-view > .ck.ck-labeled-field-view__input-wrapper > label.ck.ck-label { | ||||
|     /* Move the label above the text box regardless of the text box state */ | ||||
|     transform: translate(0, calc(-.2em - var(--ck-input-label-height))) !important; | ||||
|      | ||||
|     padding-left: 0 !important; | ||||
|     background: transparent; | ||||
|     font-size: .85em; | ||||
|     font-weight: 600; | ||||
| } | ||||
|  | ||||
| :root input.ck.ck-input-text[readonly="true"] { | ||||
|     cursor: not-allowed; | ||||
|     background: var(--input-background-color); | ||||
| } | ||||
|  | ||||
| /* Forms */ | ||||
|  | ||||
| :root .ck.ck-form__row.ck-form__row_with-submit > :not(:first-child) { | ||||
|     margin-inline-start: 16px; | ||||
| } | ||||
|  | ||||
| .ck.ck-form__row_with-submit button { | ||||
|     margin-top: var(--ck-input-label-height); | ||||
| } | ||||
|  | ||||
| .ck.ck-form__header { | ||||
|     border-bottom: none; | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * EDITOR'S CONTENT | ||||
|  */ | ||||
|   | ||||
| @@ -96,7 +96,6 @@ | ||||
|     background: var(--background) !important; | ||||
|     color: var(--color) !important; | ||||
|     line-height: unset; | ||||
|     cursor: help; | ||||
| } | ||||
|  | ||||
| .sql-table-schemas-widget .sql-table-schemas button:hover, | ||||
| @@ -106,22 +105,15 @@ | ||||
|     --color: var(--main-text-color); | ||||
| } | ||||
|  | ||||
| /* Tooltip */ | ||||
|  | ||||
| .tooltip .table-schema { | ||||
|     font-family: var(--monospace-font-family); | ||||
|     font-size: .85em; | ||||
| } | ||||
|  | ||||
| /* Data type */ | ||||
| .tooltip .table-schema td:nth-child(2) { | ||||
|     color: var(--muted-text-color); | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * NOTE MAP | ||||
|  */ | ||||
|  | ||||
| .note-detail-note-map .fixnodes-type-switcher .tn-tool-button, | ||||
| .note-map-widget .fixnodes-type-switcher .tn-tool-button { | ||||
|     padding: unset; | ||||
| } | ||||
|  | ||||
|  .note-detail-note-map .fixnodes-type-switcher .tn-tool-button.toggled { | ||||
|     color: var(--tab-close-button-hover-background); | ||||
| } | ||||
|   | ||||
| @@ -94,18 +94,17 @@ div.promoted-attributes-container { | ||||
|  | ||||
| /* Note type dropdown */ | ||||
|  | ||||
| div.note-type-dropdown .check { | ||||
| ul.note-type-dropdown .check { | ||||
|     margin-right: 6px; | ||||
| } | ||||
|  | ||||
| ul.note-type-dropdown li.dropdown-item { | ||||
|     --menu-item-icon-vert-offset: 0; | ||||
| } | ||||
|  | ||||
| /* Editability dropdown */ | ||||
|  | ||||
| div.editability-dropdown a.dropdown-item { | ||||
|     padding: 4px 16px 4px 0; | ||||
|     align-items: start !important; | ||||
| } | ||||
|  | ||||
| .editability-dropdown .dropdown-item .check { | ||||
| ul.editability-dropdown li.dropdown-item > div { | ||||
|     margin-left: 4px; | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -36,32 +36,23 @@ body.mobile { | ||||
|  | ||||
| /* #region Mica */ | ||||
| body.background-effects.platform-win32 { | ||||
|     --launcher-pane-horiz-border-color: rgba(0, 0, 0, 0.15); | ||||
|     --launcher-pane-horiz-background-color: rgba(255, 255, 255, 0.7); | ||||
|     --launcher-pane-vert-background-color: rgba(255, 255, 255, 0.055); | ||||
|     --tab-background-color: transparent; | ||||
|     --new-tab-button-background: transparent; | ||||
|     --active-tab-background-color: var(--launcher-pane-horiz-background-color); | ||||
|     --background-material: tabbed; | ||||
| } | ||||
|  | ||||
| @media (prefers-color-scheme: dark) { | ||||
|     body.background-effects.platform-win32 { | ||||
|         --launcher-pane-horiz-border-color: rgba(0, 0, 0, 0.5); | ||||
|         --launcher-pane-horiz-background-color: rgba(255, 255, 255, 0.09); | ||||
|     } | ||||
|     --launcher-pane-horiz-border-color: var(--launcher-pane-horiz-border-color-bgfx); | ||||
|     --launcher-pane-horiz-background-color: var(--launcher-pane-horiz-background-color-bgfx); | ||||
|     --launcher-pane-vert-background-color: var(--launcher-pane-vert-background-color-bgfx); | ||||
|     --tab-background-color: var(--window-background-color-bgfx); | ||||
|     --new-tab-button-background: var(--window-background-color-bgfx); | ||||
|     --active-tab-background-color: var(--launcher-pane-horiz-background-color); | ||||
| } | ||||
|  | ||||
| body.background-effects.platform-win32.layout-vertical { | ||||
|     --left-pane-background-color: transparent; | ||||
|     --left-pane-item-hover-background: rgba(127, 127, 127, 0.05); | ||||
|     --left-pane-background-color: var(--window-background-color-bgfx); | ||||
|     --background-material: mica; | ||||
| } | ||||
|  | ||||
| body.background-effects.platform-win32, | ||||
| body.background-effects.platform-win32 #root-widget, | ||||
| body.background-effects.platform-win32 #launcher-pane .launcher-button { | ||||
|     background: transparent !important; | ||||
| body.background-effects.platform-win32 #root-widget { | ||||
|     background: var(--window-background-color-bgfx) !important; | ||||
| } | ||||
|  | ||||
| body.background-effects.platform-win32.layout-horizontal #horizontal-main-container, | ||||
| @@ -90,7 +81,7 @@ body.background-effects.zen #root-widget { | ||||
|  * Gutter | ||||
|  */ | ||||
|  | ||||
|  .gutter { | ||||
| .gutter { | ||||
|     background: var(--gutter-color) !important; | ||||
|     transition: background 150ms ease-out; | ||||
| } | ||||
| @@ -232,7 +223,7 @@ body.layout-horizontal > .horizontal { | ||||
| } | ||||
|  | ||||
| #launcher-pane .launcher-button:focus, | ||||
| #launcher-pane .global-menu button:focus { | ||||
| #launcher-pane .global-menu :focus { | ||||
|     outline: none; | ||||
| } | ||||
|  | ||||
| @@ -313,24 +304,11 @@ body.layout-horizontal > .horizontal { | ||||
|     color: var(--tooltip-foreground-color) !important; | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * Global menu | ||||
|  */ | ||||
|  | ||||
|  .global-menu div.zoom-buttons a { | ||||
|     border: unset; | ||||
| } | ||||
|  | ||||
| .global-menu div.zoom-buttons a.bx { | ||||
|     color: var(--menu-text-color) !important; | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * Calendar | ||||
|  */ | ||||
|  | ||||
|  .calendar-dropdown-widget { | ||||
|     width: unset !important; | ||||
|     padding: 12px; | ||||
|     color: var(--calendar-color); | ||||
|     user-select: none; | ||||
| @@ -358,6 +336,21 @@ body.layout-horizontal > .horizontal { | ||||
|     --select-arrow-svg: initial; /* Disable the dropdown arrow */ | ||||
| } | ||||
|  | ||||
| /* Week number column */ | ||||
| .calendar-dropdown-widget .calendar-week-number { | ||||
|     transform: rotate(270deg); | ||||
|     justify-content: center; | ||||
|     padding: 0; | ||||
|     opacity: 0.5; | ||||
|     font-size: 1em; | ||||
|     font-weight: 700; | ||||
|     letter-spacing: .5pt; | ||||
| } | ||||
|  | ||||
| .calendar-dropdown-widget .calendar-week-number::after { | ||||
|     display: none; | ||||
| } | ||||
|  | ||||
| @media (max-width: 992px) { | ||||
|     .calendar-dropdown-widget .calendar-header button { | ||||
|         margin: 0 !important; | ||||
| @@ -572,29 +565,28 @@ div.quick-search .search-button.show { | ||||
|     transition: background-color 100ms ease-out !important; | ||||
| } | ||||
|  | ||||
| div.quick-search .dropdown-menu { | ||||
|     --quick-search-item-delimiter-color: transparent; | ||||
|     --menu-item-icon-vert-offset: -.065em; | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * Quick search results | ||||
|  * TO FIX: The quick search results dropdown has a backdrop issue with the tree panel | ||||
|  * when background effects are enabled in Electron. | ||||
|  * As a temporary workaround, the backdrop and transparency are disabled for the | ||||
|  * vertical layout. | ||||
|  */ | ||||
| body.layout-vertical.background-effects div.quick-search .dropdown-menu {     | ||||
|     --menu-background-color: var(--menu-background-color-no-backdrop) !important; | ||||
| } | ||||
|  | ||||
| /* Item */ | ||||
| .quick-search .dropdown-menu *.dropdown-item { | ||||
|     padding: 8px 12px !important; | ||||
| } | ||||
|  | ||||
| /* Note icon */ | ||||
| .quick-search .dropdown-menu .dropdown-item > .bx { | ||||
|     position: relative; | ||||
|     top: 1px; | ||||
| } | ||||
|  | ||||
| /* Note title */ | ||||
| .quick-search .dropdown-menu .dropdown-item > a { | ||||
|     color: var(--menu-text-color); | ||||
| } | ||||
|  | ||||
| .quick-search .dropdown-menu .dropdown-item > a:hover { | ||||
|     --hover-item-background-color: transparent; | ||||
|     text-decoration: underline; | ||||
| .quick-search .quick-search-item-icon { | ||||
|     vertical-align: text-bottom; | ||||
| } | ||||
|  | ||||
| /* Note path */ | ||||
| @@ -605,6 +597,24 @@ div.quick-search .search-button.show { | ||||
|     overflow: hidden; | ||||
| } | ||||
|  | ||||
| /* Note content snippet */ | ||||
| :root .quick-search .search-result-content { | ||||
|     background-color: var(--quick-search-result-content-background); | ||||
|     border-radius: 4px; | ||||
| } | ||||
|  | ||||
| /* Highlighted search terms */ | ||||
| :root .quick-search .search-result-title b, | ||||
| :root .quick-search .search-result-content b, | ||||
| :root .quick-search .search-result-attributes b { | ||||
|     color: var(--quick-search-result-highlight-color); | ||||
|     font-weight: 600; | ||||
| } | ||||
|  | ||||
| .quick-search div.dropdown-divider { | ||||
|     margin: 8px 0; | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * TREE PANE | ||||
|  */ | ||||
| @@ -865,7 +875,10 @@ body.mobile .fancytree-node > span { | ||||
| } | ||||
|  | ||||
| .tab-row-container .toggle-button { | ||||
|     margin: 6px 10px !important; | ||||
|     --icon-button-size: 30px; | ||||
|     --icon-button-icon-ratio: .6; | ||||
|  | ||||
|     margin: 3px 6px auto 8px !important; | ||||
| } | ||||
|  | ||||
| .tab-row-container { | ||||
| @@ -877,6 +890,80 @@ body.layout-horizontal .tab-row-container { | ||||
|     border-bottom: 1px solid var(--launcher-pane-horiz-border-color); | ||||
| } | ||||
|  | ||||
| body.electron.background-effects.layout-horizontal .tab-row-container { | ||||
|     border-bottom: unset !important; | ||||
| } | ||||
|  | ||||
| body.electron.background-effects.layout-horizontal .note-tab-wrapper { | ||||
|     top: 1px; | ||||
| } | ||||
|  | ||||
| body.electron.background-effects.layout-horizontal .tab-row-container .toggle-button { | ||||
|     position: relative; | ||||
| } | ||||
|  | ||||
| body.electron.background-effects.layout-horizontal .tab-row-container .toggle-button:after { | ||||
|     content: ""; | ||||
|     position: absolute; | ||||
|     bottom: 0; | ||||
|     left: -10px; | ||||
|     right: -10px; | ||||
|     top: 32px; | ||||
|     height: 1px; | ||||
|     border-bottom: 1px solid var(--launcher-pane-horiz-border-color); | ||||
| } | ||||
|  | ||||
| body.electron.background-effects.layout-horizontal .tab-row-container .tab-scroll-button-left, | ||||
| body.electron.background-effects.layout-horizontal .tab-row-container .tab-scroll-button-right { | ||||
|     position: relative; | ||||
| } | ||||
|  | ||||
| body.electron.background-effects.layout-horizontal .tab-row-container .tab-scroll-button-left:after, | ||||
| body.electron.background-effects.layout-horizontal .tab-row-container .tab-scroll-button-right:after { | ||||
|     content: ""; | ||||
|     position: absolute; | ||||
|     bottom: 0; | ||||
|     left: 0px; | ||||
|     right: 0px; | ||||
|     height: 1px; | ||||
|     border-bottom: 1px solid var(--launcher-pane-horiz-border-color); | ||||
| } | ||||
|  | ||||
| body.electron.background-effects.layout-horizontal .tab-row-container .note-tab[active]:before { | ||||
|     content: ""; | ||||
|     position: absolute; | ||||
|     bottom: 0; | ||||
|     left: -32768px; | ||||
|     top: var(--tab-height); | ||||
|     right: calc(100% - 1px); | ||||
|     height: 1px; | ||||
|     border-bottom: 1px solid var(--launcher-pane-horiz-border-color); | ||||
| } | ||||
|  | ||||
| body.electron.background-effects.layout-horizontal .tab-row-container .note-tab[active]:after { | ||||
|     content: ""; | ||||
|     position: absolute; | ||||
|     bottom: 0; | ||||
|     left: 100%; | ||||
|     top: var(--tab-height); | ||||
|     right: 0; | ||||
|     width: 100vw; | ||||
|     height: 1px; | ||||
|     border-bottom: 1px solid var(--launcher-pane-horiz-border-color); | ||||
| } | ||||
|  | ||||
| body.electron.background-effects.layout-horizontal .tab-row-container .note-new-tab:before { | ||||
|     content: ""; | ||||
|     position: absolute; | ||||
|     bottom: 0; | ||||
|     left: -4px; | ||||
|     top: calc(var(--tab-height), -1); | ||||
|     right: 0; | ||||
|     width: 100vw; | ||||
|     height: 1px; | ||||
|     border-bottom: 1px solid var(--launcher-pane-horiz-border-color); | ||||
| } | ||||
|  | ||||
| body.layout-vertical.electron.platform-darwin .tab-row-container { | ||||
|     border-bottom: 1px solid var(--subtle-border-color); | ||||
| } | ||||
| @@ -968,6 +1055,14 @@ body.layout-horizontal .tab-row-widget .note-tab .note-tab-wrapper { | ||||
|     transform: translate3d(var(--tab-first-item-horiz-offset), 0, 0); | ||||
| } | ||||
|  | ||||
| :root .tab-row-widget .note-tab .note-tab-icon { | ||||
|     padding-right: 5px; /* The gap between the icon and the title */ | ||||
| } | ||||
|  | ||||
| .tab-row-widget .note-tab[active] .note-tab-icon { | ||||
|     color: var(--active-tab-icon-color); | ||||
| } | ||||
|  | ||||
| .tab-row-widget .note-tab .note-tab-title { | ||||
|     text-overflow: ellipsis; | ||||
| } | ||||
| @@ -1092,6 +1187,11 @@ body.layout-vertical .tab-row-widget-is-sorting .note-tab.note-tab-is-dragging . | ||||
|     /* will-change: opacity; -- causes some weird artifacts to the note menu in split view */ | ||||
| } | ||||
|  | ||||
| .split-note-container-widget > .gutter { | ||||
|     background: var(--root-background) !important; | ||||
|     transition: background 150ms ease-out; | ||||
| } | ||||
|  | ||||
| /* | ||||
|  * Ribbon & note header | ||||
|  */ | ||||
| @@ -1100,10 +1200,6 @@ body.layout-vertical .tab-row-widget-is-sorting .note-tab.note-tab-is-dragging . | ||||
|     margin-bottom: 0 !important; | ||||
| } | ||||
|  | ||||
| .note-split:not(.hidden-ext) + .note-split:not(.hidden-ext) { | ||||
|     border-left: 4px solid var(--root-background); | ||||
| } | ||||
|  | ||||
| @keyframes note-entrance { | ||||
|     from { | ||||
|         opacity: 0; | ||||
| @@ -1375,7 +1471,7 @@ div.floating-buttons-children .floating-button:active { | ||||
| } | ||||
|  | ||||
| /* The first visible floating button */ | ||||
| div.floating-buttons-children > *:nth-child(1 of .visible) { | ||||
| div.floating-buttons-children > *:first-child { | ||||
|     --border-radius: var(--border-radius-size) 0 0 var(--border-radius-size); | ||||
|     border-radius: var(--border-radius); | ||||
| } | ||||
| @@ -1477,13 +1573,6 @@ div.floating-buttons-children .close-floating-buttons:has(.close-floating-button | ||||
|     padding-inline-start: 8px; | ||||
| } | ||||
|  | ||||
| /* Copy image reference */ | ||||
|  | ||||
| .floating-buttons .copy-image-reference-button .hidden-image-copy { | ||||
|     /* Take out of the the hidden image from flexbox to prevent the layout being affected */ | ||||
|     position: absolute; | ||||
| } | ||||
|  | ||||
| /* Code, relation map buttons */ | ||||
|  | ||||
| .floating-buttons .code-buttons-widget, | ||||
|   | ||||
							
								
								
									
										5
									
								
								apps/client/src/translations/ar/translation.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								apps/client/src/translations/ar/translation.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | ||||
| { | ||||
|   "about": { | ||||
|     "title": "حول تريليوم للملاحظات" | ||||
|   } | ||||
| } | ||||
| @@ -276,7 +276,12 @@ | ||||
|     "mime": "MIME 类型: ", | ||||
|     "file_size": "文件大小:", | ||||
|     "preview": "预览:", | ||||
|     "preview_not_available": "无法预览此类型的笔记。" | ||||
|     "preview_not_available": "无法预览此类型的笔记。", | ||||
|     "diff_on": "显示差异", | ||||
|     "diff_off": "显示内容", | ||||
|     "diff_on_hint": "点击以显示笔记源代码差异", | ||||
|     "diff_off_hint": "点击以显示笔记内容", | ||||
|     "diff_not_available": "差异不可用。" | ||||
|   }, | ||||
|   "sort_child_notes": { | ||||
|     "sort_children_by": "按...排序子笔记", | ||||
| @@ -587,7 +592,18 @@ | ||||
|     "september": "九月", | ||||
|     "october": "十月", | ||||
|     "november": "十一月", | ||||
|     "december": "十二月" | ||||
|     "december": "十二月", | ||||
|     "week_previous": "上周", | ||||
|     "week_next": "下周", | ||||
|     "month_previous": "上个月", | ||||
|     "month_next": "下个月", | ||||
|     "year": "年", | ||||
|     "year_previous": "上一年", | ||||
|     "year_next": "明年", | ||||
|     "today": "今天", | ||||
|     "week": "周", | ||||
|     "month": "月", | ||||
|     "list": "列表" | ||||
|   }, | ||||
|   "close_pane_button": { | ||||
|     "close_this_pane": "关闭此面板" | ||||
| @@ -732,7 +748,8 @@ | ||||
|     "note_type": "笔记类型", | ||||
|     "editable": "可编辑", | ||||
|     "basic_properties": "基本属性", | ||||
|     "language": "语言" | ||||
|     "language": "语言", | ||||
|     "configure_code_notes": "配置代码注释..." | ||||
|   }, | ||||
|   "book_properties": { | ||||
|     "view_type": "视图类型", | ||||
| @@ -747,7 +764,8 @@ | ||||
|     "book_properties": "集合属性", | ||||
|     "table": "表格", | ||||
|     "geo-map": "地理地图", | ||||
|     "board": "看板" | ||||
|     "board": "看板", | ||||
|     "include_archived_notes": "展示归档笔记" | ||||
|   }, | ||||
|   "edited_notes": { | ||||
|     "no_edited_notes_found": "今天还没有编辑过的笔记...", | ||||
| @@ -848,7 +866,7 @@ | ||||
|     "debug": "调试", | ||||
|     "debug_description": "调试将打印额外的调试信息到控制台,以帮助调试复杂查询", | ||||
|     "action": "操作", | ||||
|     "search_button": "搜索 <kbd>回车</kbd>", | ||||
|     "search_button": "搜索", | ||||
|     "search_execute": "搜索并执行操作", | ||||
|     "save_to_note": "保存到笔记", | ||||
|     "search_parameters": "搜索参数", | ||||
| @@ -948,7 +966,9 @@ | ||||
|     "no_attachments": "此笔记没有附件。" | ||||
|   }, | ||||
|   "book": { | ||||
|     "no_children_help": "此类型为书籍的笔记没有任何子笔记,因此没有内容显示。请参阅 <a href=\"https://triliumnext.github.io/Docs/Wiki/book-note.html\">wiki</a> 了解详情。" | ||||
|     "no_children_help": "此类型为书籍的笔记没有任何子笔记,因此没有内容显示。请参阅 <a href=\"https://triliumnext.github.io/Docs/Wiki/book-note.html\">wiki</a> 了解详情。", | ||||
|     "drag_locked_title": "锁定编辑", | ||||
|     "drag_locked_message": "无法拖拽,因为集合已被锁定编辑。" | ||||
|   }, | ||||
|   "editable_code": { | ||||
|     "placeholder": "在这里输入您的代码笔记内容..." | ||||
| @@ -1406,7 +1426,7 @@ | ||||
|     "button-tree-map": "树形地图" | ||||
|   }, | ||||
|   "tree-context-menu": { | ||||
|     "open-in-a-new-tab": "在新标签页中打开 <kbd>Ctrl+Click</kbd>", | ||||
|     "open-in-a-new-tab": "在新标签页中打开", | ||||
|     "open-in-a-new-split": "在新分栏中打开", | ||||
|     "insert-note-after": "在后面插入笔记", | ||||
|     "insert-child-note": "插入子笔记", | ||||
| @@ -1436,12 +1456,14 @@ | ||||
|     "converted-to-attachments": "{{count}} 个笔记已被转换为附件。", | ||||
|     "convert-to-attachment-confirm": "确定要将选中的笔记转换为其父笔记的附件吗?", | ||||
|     "duplicate": "复制", | ||||
|     "open-in-popup": "快速编辑" | ||||
|     "open-in-popup": "快速编辑", | ||||
|     "archive": "归档", | ||||
|     "unarchive": "解压" | ||||
|   }, | ||||
|   "shared_info": { | ||||
|     "shared_publicly": "此笔记已公开分享于", | ||||
|     "shared_locally": "此笔记已在本地分享于", | ||||
|     "help_link": "访问 <a href=\"https://triliumnext.github.io/Docs/Wiki/sharing.html\">wiki</a> 获取帮助。" | ||||
|     "help_link": "访问 <a href=\"https://triliumnext.github.io/Docs/Wiki/sharing.html\">wiki</a> 获取帮助。", | ||||
|     "shared_publicly": "该笔记已在 {{- link}} 上公开分享。", | ||||
|     "shared_locally": "此笔记在本地通过 {{- link}} 进行共享。" | ||||
|   }, | ||||
|   "note_types": { | ||||
|     "text": "文本", | ||||
| @@ -1519,7 +1541,8 @@ | ||||
|     "hoist-this-note-workspace": "聚焦此笔记(工作区)", | ||||
|     "refresh-saved-search-results": "刷新保存的搜索结果", | ||||
|     "create-child-note": "创建子笔记", | ||||
|     "unhoist": "取消聚焦" | ||||
|     "unhoist": "取消聚焦", | ||||
|     "toggle-sidebar": "切换侧边栏" | ||||
|   }, | ||||
|   "title_bar_buttons": { | ||||
|     "window-on-top": "保持此窗口置顶" | ||||
| @@ -1676,7 +1699,7 @@ | ||||
|     "native-title-bar": "原生标题栏", | ||||
|     "native-title-bar-description": "对于 Windows 和 macOS,关闭原生标题栏可使应用程序看起来更紧凑。在 Linux 上,保留原生标题栏可以更好地与系统集成。", | ||||
|     "background-effects": "启用背景效果(仅适用于 Windows 11)", | ||||
|     "background-effects-description": "Mica 效果为应用窗口添加模糊且时尚的背景,营造出深度感和现代外观。", | ||||
|     "background-effects-description": "Mica 效果为应用窗口添加模糊且时尚的背景,营造出深度感和现代外观。「原生标题栏」必須被禁用。", | ||||
|     "restart-app-button": "重启应用程序以查看更改", | ||||
|     "zoom-factor": "缩放系数" | ||||
|   }, | ||||
| @@ -1871,7 +1894,12 @@ | ||||
|     "selected_provider": "已选提供商", | ||||
|     "selected_provider_description": "选择用于聊天和补全功能的AI提供商", | ||||
|     "select_model": "选择模型...", | ||||
|     "select_provider": "选择提供商..." | ||||
|     "select_provider": "选择提供商...", | ||||
|     "ai_enabled": "已启用 AI 功能", | ||||
|     "ai_disabled": "已禁用 AI 功能", | ||||
|     "no_models_found_online": "找不到模型。请检查您的 API 密钥及设置。", | ||||
|     "no_models_found_ollama": "找不到 Ollama 模型。请确认 Ollama 是否正在运行。", | ||||
|     "error_fetching": "获取模型失败:{{error}}" | ||||
|   }, | ||||
|   "code-editor-options": { | ||||
|     "title": "编辑器" | ||||
| @@ -1960,14 +1988,21 @@ | ||||
|     "delete_row": "删除行" | ||||
|   }, | ||||
|   "board_view": { | ||||
|     "delete-note": "删除笔记", | ||||
|     "delete-note": "删除笔记...", | ||||
|     "move-to": "移动到", | ||||
|     "insert-above": "在上方插入", | ||||
|     "insert-below": "在下方插入", | ||||
|     "delete-column": "删除列", | ||||
|     "delete-column-confirmation": "确定要删除此列吗?此列下所有笔记中对应的属性也将被删除。", | ||||
|     "new-item": "新增项目", | ||||
|     "add-column": "添加列" | ||||
|     "add-column": "添加列", | ||||
|     "archive-note": "存档笔记", | ||||
|     "unarchive-note": "解压笔记", | ||||
|     "new-item-placeholder": "输入笔记标题...", | ||||
|     "add-column-placeholder": "请输入列名...", | ||||
|     "edit-note-title": "点击编辑笔记标题", | ||||
|     "edit-column-title": "点击编辑列标题", | ||||
|     "remove-from-board": "从看板上移除" | ||||
|   }, | ||||
|   "command_palette": { | ||||
|     "tree-action-name": "树形:{{name}}", | ||||
| @@ -1999,5 +2034,30 @@ | ||||
|     "next_theme_message": "当前使用旧版主题,要试用新主题吗?", | ||||
|     "next_theme_button": "试用新主题", | ||||
|     "dismiss": "关闭" | ||||
|   }, | ||||
|   "settings": { | ||||
|     "related_settings": "相关设置" | ||||
|   }, | ||||
|   "settings_appearance": { | ||||
|     "related_code_blocks": "文本笔记中代码块的色彩方案", | ||||
|     "related_code_notes": "代码笔记的色彩方案" | ||||
|   }, | ||||
|   "units": { | ||||
|     "percentage": "%" | ||||
|   }, | ||||
|   "ui-performance": { | ||||
|     "title": "性能", | ||||
|     "enable-motion": "启用过渡和动画", | ||||
|     "enable-shadows": "启用阴影", | ||||
|     "enable-backdrop-effects": "启用菜单、弹窗和面板的背景效果", | ||||
|     "enable-smooth-scroll": "启用平滑滚动", | ||||
|     "app-restart-required": "(需重启程序以应用更改)" | ||||
|   }, | ||||
|   "pagination": { | ||||
|     "page_title": "第 {{startIndex}} 页 - 第 {{endIndex}} 页", | ||||
|     "total_notes": "{{count}} 笔记" | ||||
|   }, | ||||
|   "collections": { | ||||
|     "rendering_error": "出现错误无法显示内容。" | ||||
|   } | ||||
| } | ||||
|   | ||||
							
								
								
									
										1
									
								
								apps/client/src/translations/cs/translation.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								apps/client/src/translations/cs/translation.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| {} | ||||
| @@ -202,11 +202,12 @@ | ||||
|     "okButton": "OK" | ||||
|   }, | ||||
|   "jump_to_note": { | ||||
|     "search_button": "Suche im Volltext" | ||||
|     "search_button": "Suche im Volltext", | ||||
|     "search_placeholder": "Suche nach Notiz anhand ihres Titels oder gib > ein für Kommandos..." | ||||
|   }, | ||||
|   "markdown_import": { | ||||
|     "dialog_title": "Markdown-Import", | ||||
|     "modal_body_text": "Aufgrund der Browser-Sandbox ist es nicht möglich, die Zwischenablage direkt aus JavaScript zu lesen. Bitte füge den zu importierenden Markdown in den Textbereich unten ein und klicke auf die Schaltfläche „Importieren“.", | ||||
|     "modal_body_text": "Aufgrund der Browser-Sandbox ist es nicht möglich, die Zwischenablage direkt aus JavaScript zu lesen. Bitte füge den zu importierenden Markdown in den Textbereich unten ein und klicke auf die Schaltfläche „Importieren“", | ||||
|     "import_button": "Importieren", | ||||
|     "import_success": "Markdown-Inhalt wurde in das Dokument importiert." | ||||
|   }, | ||||
| @@ -217,21 +218,26 @@ | ||||
|     "search_placeholder": "Suche nach einer Notiz anhand ihres Namens", | ||||
|     "move_button": "Zur ausgewählten Notiz wechseln", | ||||
|     "error_no_path": "Kein Weg, auf den man sich bewegen kann.", | ||||
|     "move_success_message": "Ausgewählte Notizen wurden verschoben" | ||||
|     "move_success_message": "Ausgewählte Notizen wurden verschoben in " | ||||
|   }, | ||||
|   "note_type_chooser": { | ||||
|     "modal_title": "Wähle den Notiztyp aus", | ||||
|     "modal_body": "Wähle den Notiztyp / die Vorlage der neuen Notiz:", | ||||
|     "templates": "Vorlagen" | ||||
|     "templates": "Vorlagen", | ||||
|     "change_path_prompt": "Ändern wo die neue Notiz erzeugt wird:", | ||||
|     "search_placeholder": "Durchsuche Pfad nach Namen (Standard falls leer)", | ||||
|     "builtin_templates": "Eingebaute Vorlage" | ||||
|   }, | ||||
|   "password_not_set": { | ||||
|     "title": "Das Passwort ist nicht festgelegt", | ||||
|     "body1": "Geschützte Notizen werden mit einem Benutzerpasswort verschlüsselt, es wurde jedoch noch kein Passwort festgelegt." | ||||
|     "body1": "Geschützte Notizen werden mit einem Benutzerpasswort verschlüsselt, es wurde jedoch noch kein Passwort festgelegt.", | ||||
|     "body2": "Um Notizen zu schützen, klicke den unteren Button um den Optionsdialog zu öffnen und dein Passwort festzulegen.", | ||||
|     "go_to_password_options": "Gehe zu Passwortoptionen" | ||||
|   }, | ||||
|   "prompt": { | ||||
|     "title": "Prompt", | ||||
|     "title": "Eingabeaufforderung", | ||||
|     "ok": "OK", | ||||
|     "defaultTitle": "Prompt" | ||||
|     "defaultTitle": "Eingabeaufforderung" | ||||
|   }, | ||||
|   "protected_session_password": { | ||||
|     "modal_title": "Geschützte Sitzung", | ||||
| @@ -265,10 +271,17 @@ | ||||
|     "maximum_revisions": "Maximale Revisionen für aktuelle Notiz: {{number}}.", | ||||
|     "settings": "Einstellungen für Notizrevisionen", | ||||
|     "download_button": "Herunterladen", | ||||
|     "mime": "MIME:", | ||||
|     "mime": "MIME: ", | ||||
|     "file_size": "Dateigröße:", | ||||
|     "preview": "Vorschau:", | ||||
|     "preview_not_available": "Für diesen Notiztyp ist keine Vorschau verfügbar." | ||||
|     "preview_not_available": "Für diesen Notiztyp ist keine Vorschau verfügbar.", | ||||
|     "restore_button": "Wiederherstellen", | ||||
|     "delete_button": "Löschen", | ||||
|     "diff_on": "Zeige Differenz", | ||||
|     "diff_off": "Zeige Inhalt", | ||||
|     "diff_on_hint": "Klicke, um die Differenz des Notiz-Quellcodes zu zeigen", | ||||
|     "diff_off_hint": "Klicke, um den Notizinhalt zu zeigen", | ||||
|     "diff_not_available": "Differenz-Abgleich ist nicht verfügbar." | ||||
|   }, | ||||
|   "sort_child_notes": { | ||||
|     "sort_children_by": "Unternotizen sortieren nach...", | ||||
| @@ -348,7 +361,7 @@ | ||||
|     "sorted": "Hält untergeordnete Notizen alphabetisch nach Titel sortiert", | ||||
|     "sort_direction": "ASC (Standard) oder DESC", | ||||
|     "sort_folders_first": "Ordner (Notizen mit Unternotizen) sollten oben sortiert werden", | ||||
|     "top": "Behalte die angegebene Notiz oben in der übergeordneten Notiz (gilt nur für sortierte übergeordnete Notizen).", | ||||
|     "top": "Behalte die angegebene Notiz oben in der übergeordneten Notiz (gilt nur für sortierte übergeordnete Notizen)", | ||||
|     "hide_promoted_attributes": "Heraufgestufte Attribute für diese Notiz ausblenden", | ||||
|     "read_only": "Der Editor befindet sich im schreibgeschützten Modus. Funktioniert nur für Text- und Codenotizen.", | ||||
|     "auto_read_only_disabled": "Text-/Codenotizen können automatisch in den Lesemodus versetzt werden, wenn sie zu groß sind. Du kannst dieses Verhalten für jede einzelne Notiz deaktivieren, indem du diese Beschriftung zur Notiz hinzufügst", | ||||
| @@ -371,10 +384,10 @@ | ||||
|     "inbox": "Standard-Inbox-Position für neue Notizen – wenn du eine Notiz über den \"Neue Notiz\"-Button in der Seitenleiste erstellst, wird die Notiz als untergeordnete Notiz der Notiz erstellt, die mit dem <code>#inbox</code>-Label markiert ist.", | ||||
|     "workspace_inbox": "Standard-Posteingangsspeicherort für neue Notizen, wenn sie zu einem Vorgänger dieser Arbeitsbereichsnotiz verschoben werden", | ||||
|     "sql_console_home": "Standardspeicherort der SQL-Konsolennotizen", | ||||
|     "bookmark_folder": "Notizen mit dieser Bezeichnung werden in den Lesezeichen als Ordner angezeigt (und ermöglichen den Zugriff auf ihre untergeordneten Ordner).", | ||||
|     "bookmark_folder": "Notizen mit dieser Bezeichnung werden in den Lesezeichen als Ordner angezeigt (und ermöglichen den Zugriff auf ihre untergeordneten Ordner)", | ||||
|     "share_hidden_from_tree": "Diese Notiz ist im linken Navigationsbaum ausgeblendet, kann aber weiterhin über ihre URL aufgerufen werden", | ||||
|     "share_external_link": "Die Notiz dient als Link zu einer externen Website im Freigabebaum", | ||||
|     "share_alias": "Lege einen Alias fest, unter dem die Notiz unter https://your_trilium_host/share/[dein_alias] verfügbar sein wird.", | ||||
|     "share_alias": "Lege einen Alias fest, mit dem die Notiz unter https://your_trilium_host/share/[dein_alias] verfügbar sein wird", | ||||
|     "share_omit_default_css": "Das Standard-CSS für die Freigabeseite wird weggelassen. Verwende es, wenn du umfangreiche Stylingänderungen vornimmst.", | ||||
|     "share_root": "Markiert eine Notiz, die im /share-Root bereitgestellt wird.", | ||||
|     "share_description": "Definiere Text, der dem HTML-Meta-Tag zur Beschreibung hinzugefügt werden soll", | ||||
| @@ -390,7 +403,7 @@ | ||||
|     "color": "Definiert die Farbe der Notiz im Notizbaum, in Links usw. Verwende einen beliebigen gültigen CSS-Farbwert wie „rot“ oder #a13d5f", | ||||
|     "keyboard_shortcut": "Definiert eine Tastenkombination, die sofort zu dieser Notiz springt. Beispiel: „Strg+Alt+E“. Erfordert ein Neuladen des Frontends, damit die Änderung wirksam wird.", | ||||
|     "keep_current_hoisting": "Das Öffnen dieses Links ändert das Hochziehen nicht, selbst wenn die Notiz im aktuell hochgezogenen Unterbaum nicht angezeigt werden kann.", | ||||
|     "execute_button": "Titel der Schaltfläche, die die aktuelle Codenotiz ausführt", | ||||
|     "execute_button": "Titel der Schaltfläche, welche die aktuelle Codenotiz ausführt", | ||||
|     "execute_description": "Längere Beschreibung der aktuellen Codenotiz, die zusammen mit der Schaltfläche „Ausführen“ angezeigt wird", | ||||
|     "exclude_from_note_map": "Notizen mit dieser Bezeichnung werden in der Notizenkarte ausgeblendet", | ||||
|     "new_notes_on_top": "Neue Notizen werden oben in der übergeordneten Notiz erstellt, nicht unten.", | ||||
| @@ -405,10 +418,10 @@ | ||||
|     "run_on_branch_change": "wird ausgeführt, wenn ein Zweig aktualisiert wird.", | ||||
|     "run_on_branch_deletion": "wird ausgeführt, wenn ein Zweig gelöscht wird. Der Zweig ist eine Verknüpfung zwischen der übergeordneten Notiz und der untergeordneten Notiz und wird z. B. gelöscht. beim Verschieben der Notiz (alter Zweig/Link wird gelöscht).", | ||||
|     "run_on_attribute_creation": "wird ausgeführt, wenn für die Notiz ein neues Attribut erstellt wird, das diese Beziehung definiert", | ||||
|     "run_on_attribute_change": "wird ausgeführt, wenn das Attribut einer Notiz geändert wird, die diese Beziehung definiert. Dies wird auch ausgelöst, wenn das Attribut gelöscht wird", | ||||
|     "run_on_attribute_change": " wird ausgeführt, wenn das Attribut einer Notiz geändert wird, die diese Beziehung definiert. Dies wird auch ausgelöst, wenn das Attribut gelöscht wird", | ||||
|     "relation_template": "Die Attribute der Notiz werden auch ohne eine Eltern-Kind-Beziehung vererbt. Der Inhalt und der Unterbaum der Notiz werden den Instanznotizen hinzugefügt, wenn sie leer sind. Einzelheiten findest du in der Dokumentation.", | ||||
|     "inherit": "Die Attribute einer Notiz werden auch ohne eine Eltern-Kind-Beziehung vererbt. Ein ähnliches Konzept findest du unter Vorlagenbeziehung. Siehe Attributvererbung in der Dokumentation.", | ||||
|     "render_note": "Notizen vom Typ \"HTML-Notiz rendern\" werden mit einer Code-Notiz (HTML oder Skript) gerendert, und es ist notwendig, über diese Beziehung anzugeben, welche Notiz gerendert werden soll.", | ||||
|     "render_note": "Notizen vom Typ \"HTML-Notiz rendern\" werden mit einer Code-Notiz (HTML oder Skript) gerendert, und es ist notwendig, über diese Beziehung anzugeben, welche Notiz gerendert werden soll", | ||||
|     "widget_relation": "Das Ziel dieser Beziehung wird ausgeführt und als Widget in der Seitenleiste gerendert", | ||||
|     "share_css": "CSS-Hinweis, der in die Freigabeseite eingefügt wird. Die CSS-Notiz muss sich ebenfalls im gemeinsamen Unterbaum befinden. Erwäge auch die Verwendung von „share_hidden_from_tree“ und „share_omit_default_css“.", | ||||
|     "share_js": "JavaScript-Hinweis, der in die Freigabeseite eingefügt wird. Die JS-Notiz muss sich ebenfalls im gemeinsamen Unterbaum befinden. Erwäge die Verwendung von „share_hidden_from_tree“.", | ||||
| @@ -418,7 +431,8 @@ | ||||
|     "other_notes_with_name": "Other notes with {{attributeType}} name \"{{attributeName}}\"", | ||||
|     "and_more": "... und {{count}} mehr.", | ||||
|     "print_landscape": "Beim Export als PDF, wird die Seitenausrichtung Querformat anstatt Hochformat verwendet.", | ||||
|     "print_page_size": "Beim Export als PDF, wird die Größe der Seite angepasst. Unterstützte Größen: <code>A0</code>, <code>A1</code>, <code>A2</code>, <code>A3</code>, <code>A4</code>, <code>A5</code>, <code>A6</code>, <code>Legal</code>, <code>Letter</code>, <code>Tabloid</code>, <code>Ledger</code>." | ||||
|     "print_page_size": "Beim Export als PDF, wird die Größe der Seite angepasst. Unterstützte Größen: <code>A0</code>, <code>A1</code>, <code>A2</code>, <code>A3</code>, <code>A4</code>, <code>A5</code>, <code>A6</code>, <code>Legal</code>, <code>Letter</code>, <code>Tabloid</code>, <code>Ledger</code>.", | ||||
|     "color_type": "Farbe" | ||||
|   }, | ||||
|   "attribute_editor": { | ||||
|     "help_text_body1": "Um ein Label hinzuzufügen, gebe einfach z.B. ein. <code>#rock</code> oder wenn du auch einen Wert hinzufügen möchten, dann z.B. <code>#year = 2024</code>", | ||||
| @@ -490,9 +504,9 @@ | ||||
|     "to": "nach", | ||||
|     "target_parent_note": "Ziel-Übergeordnetenotiz", | ||||
|     "on_all_matched_notes": "Auf allen übereinstimmenden Notizen", | ||||
|     "move_note_new_parent": "Verschiebe die Notiz in die neue übergeordnete Notiz, wenn die Notiz nur eine übergeordnete Notiz hat (d. h. der alte Zweig wird entfernt und ein neuer Zweig in die neue übergeordnete Notiz erstellt).", | ||||
|     "move_note_new_parent": "Verschiebe die Notiz in die neue übergeordnete Notiz, wenn die Notiz nur eine übergeordnete Notiz hat (d. h. der alte Zweig wird entfernt und ein neuer Zweig in die neue übergeordnete Notiz erstellt)", | ||||
|     "clone_note_new_parent": "Notiz auf die neue übergeordnete Notiz klonen, wenn die Notiz mehrere Klone/Zweige hat (es ist nicht klar, welcher Zweig entfernt werden soll)", | ||||
|     "nothing_will_happen": "Es passiert nichts, wenn die Notiz nicht zur Zielnotiz verschoben werden kann (d. h. dies würde einen Baumzyklus erzeugen)." | ||||
|     "nothing_will_happen": "Es passiert nichts, wenn die Notiz nicht zur Zielnotiz verschoben werden kann (z.B. wenn dies einen Kreislauf in der Baumstruktur erzeugen würde)" | ||||
|   }, | ||||
|   "rename_note": { | ||||
|     "rename_note": "Notiz umbenennen", | ||||
| @@ -500,10 +514,10 @@ | ||||
|     "new_note_title": "neuer Notiztitel", | ||||
|     "click_help_icon": "Klicke rechts auf das Hilfesymbol, um alle Optionen anzuzeigen", | ||||
|     "evaluated_as_js_string": "Der angegebene Wert wird als JavaScript-String ausgewertet und kann somit über die injizierte <code>note</code>-Variable mit dynamischem Inhalt angereichert werden (Notiz wird umbenannt). Beispiele:", | ||||
|     "example_note": "<code>Notiz</code> – alle übereinstimmenden Notizen werden in „Notiz“ umbenannt.", | ||||
|     "example_note": "<code>Notiz</code> – alle übereinstimmenden Notizen werden in „Notiz“ umbenannt", | ||||
|     "example_new_title": "<code>NEU: ${note.title}</code> – Übereinstimmende Notiztitel erhalten das Präfix „NEU:“", | ||||
|     "example_date_prefix": "<code>${note.dateCreatedObj.format('MM-DD:')}: ${note.title}</code> – übereinstimmende Notizen werden mit dem Erstellungsmonat und -datum der Notiz vorangestellt", | ||||
|     "api_docs": "Siehe API-Dokumente für <a hrefu003d'https://zadam.github.io/trilium/backend_api/Note.html'>Notiz</a> und seinen <a hrefu003d'https://day.js.org/ docs/en/display/format'>dateCreatedObj / utcDateCreatedObj-Eigenschaften</a> für Details." | ||||
|     "api_docs": "Siehe API-Dokumente für <a href='https://zadam.github.io/trilium/backend_api/Note.html'>Notiz</a> und seinen <a href='https://day.js.org/ docs/en/display/format'>dateCreatedObj / utcDateCreatedObj properties</a> für Details." | ||||
|   }, | ||||
|   "add_relation": { | ||||
|     "add_relation": "Beziehung hinzufügen", | ||||
| @@ -577,7 +591,19 @@ | ||||
|     "september": "September", | ||||
|     "october": "Oktober", | ||||
|     "november": "November", | ||||
|     "december": "Dezember" | ||||
|     "december": "Dezember", | ||||
|     "cannot_find_week_note": "Wochennotiz kann nicht gefunden werden", | ||||
|     "week": "Woche", | ||||
|     "week_previous": "vorherige Woche", | ||||
|     "week_next": "nächste Woche", | ||||
|     "month": "Monat", | ||||
|     "month_previous": "vorheriger Monat", | ||||
|     "month_next": "nächster Monat", | ||||
|     "year": "Jahr", | ||||
|     "year_previous": "vorheriges Jahr", | ||||
|     "year_next": "nächstes Jahr", | ||||
|     "list": "Liste", | ||||
|     "today": "Heute" | ||||
|   }, | ||||
|   "close_pane_button": { | ||||
|     "close_this_pane": "Schließe diesen Bereich" | ||||
| @@ -699,14 +725,14 @@ | ||||
|     "zoom_out_title": "Herauszoomen" | ||||
|   }, | ||||
|   "zpetne_odkazy": { | ||||
|     "backlink": "{{count}} Backlink", | ||||
|     "backlinks": "{{count}} Backlinks", | ||||
|     "backlink": "{{count}} Rückverlinkung", | ||||
|     "backlinks": "{{count}} Rückverlinkungen", | ||||
|     "relation": "Beziehung" | ||||
|   }, | ||||
|   "mobile_detail_menu": { | ||||
|     "insert_child_note": "Untergeordnete Notiz einfügen", | ||||
|     "delete_this_note": "Diese Notiz löschen", | ||||
|     "error_cannot_get_branch_id": "BranchId für notePath „{{notePath}}“ kann nicht abgerufen werden.", | ||||
|     "error_cannot_get_branch_id": "BranchId für notePath „{{notePath}}“ kann nicht abgerufen werden", | ||||
|     "error_unrecognized_command": "Unbekannter Befehl {{command}}" | ||||
|   }, | ||||
|   "note_icon": { | ||||
| @@ -718,7 +744,9 @@ | ||||
|   "basic_properties": { | ||||
|     "note_type": "Notiztyp", | ||||
|     "editable": "Bearbeitbar", | ||||
|     "basic_properties": "Grundlegende Eigenschaften" | ||||
|     "basic_properties": "Grundlegende Eigenschaften", | ||||
|     "language": "Sprache", | ||||
|     "configure_code_notes": "Code-Notizen konfigurieren..." | ||||
|   }, | ||||
|   "book_properties": { | ||||
|     "view_type": "Ansichtstyp", | ||||
| @@ -729,7 +757,12 @@ | ||||
|     "collapse": "Einklappen", | ||||
|     "expand": "Ausklappen", | ||||
|     "invalid_view_type": "Ungültiger Ansichtstyp „{{type}}“", | ||||
|     "calendar": "Kalender" | ||||
|     "calendar": "Kalender", | ||||
|     "book_properties": "Sammlungseigenschaften", | ||||
|     "table": "Tabelle", | ||||
|     "geo-map": "Weltkarte", | ||||
|     "board": "Tafel", | ||||
|     "include_archived_notes": "Zeige archivierte Notizen" | ||||
|   }, | ||||
|   "edited_notes": { | ||||
|     "no_edited_notes_found": "An diesem Tag wurden noch keine Notizen bearbeitet...", | ||||
| @@ -805,7 +838,9 @@ | ||||
|     "unknown_label_type": "Unbekannter Labeltyp „{{type}}“", | ||||
|     "unknown_attribute_type": "Unbekannter Attributtyp „{{type}}“", | ||||
|     "add_new_attribute": "Neues Attribut hinzufügen", | ||||
|     "remove_this_attribute": "Entferne dieses Attribut" | ||||
|     "remove_this_attribute": "Entferne dieses Attribut", | ||||
|     "unset-field-placeholder": "nicht gesetzt", | ||||
|     "remove_color": "Entferne Farblabel" | ||||
|   }, | ||||
|   "script_executor": { | ||||
|     "query": "Abfrage", | ||||
| @@ -828,7 +863,7 @@ | ||||
|     "debug": "debuggen", | ||||
|     "debug_description": "Debug gibt zusätzliche Debuginformationen in die Konsole aus, um das Debuggen komplexer Abfragen zu erleichtern", | ||||
|     "action": "Aktion", | ||||
|     "search_button": "Suchen <kbd>Eingabetaste</kbd>", | ||||
|     "search_button": "Suchen", | ||||
|     "search_execute": "Aktionen suchen und ausführen", | ||||
|     "save_to_note": "Als Notiz speichern", | ||||
|     "search_parameters": "Suchparameter", | ||||
| @@ -867,7 +902,7 @@ | ||||
|     "include_archived_notes": "Füge archivierte Notizen hinzu" | ||||
|   }, | ||||
|   "limit": { | ||||
|     "limit": "Limit", | ||||
|     "limit": "Limitierung", | ||||
|     "take_first_x_results": "Nehmen Sie nur die ersten X angegebenen Ergebnisse." | ||||
|   }, | ||||
|   "order_by": { | ||||
| @@ -917,7 +952,7 @@ | ||||
|   "attachment_detail": { | ||||
|     "open_help_page": "Hilfeseite zu Anhängen öffnen", | ||||
|     "owning_note": "Eigentümernotiz: ", | ||||
|     "you_can_also_open": ", Du kannst auch das öffnen", | ||||
|     "you_can_also_open": ", Du kannst auch das öffnen ", | ||||
|     "list_of_all_attachments": "Liste aller Anhänge", | ||||
|     "attachment_deleted": "Dieser Anhang wurde gelöscht." | ||||
|   }, | ||||
| @@ -928,7 +963,9 @@ | ||||
|     "no_attachments": "Diese Notiz enthält keine Anhänge." | ||||
|   }, | ||||
|   "book": { | ||||
|     "no_children_help": "Diese Notiz mit dem Notiztyp Buch besitzt keine Unternotizen, deshalb ist nichts zum Anzeigen vorhanden. Siehe <a href=\"https://triliumnext.github.io/Docs/Wiki/book-note.html\">Wiki</a> für mehr Details." | ||||
|     "no_children_help": "Diese Notiz mit dem Notiztyp Buch besitzt keine Unternotizen, deshalb ist nichts zum Anzeigen vorhanden. Siehe <a href=\"https://triliumnext.github.io/Docs/Wiki/book-note.html\">Wiki</a> für mehr Details.", | ||||
|     "drag_locked_title": "Für Bearbeitung gesperrt", | ||||
|     "drag_locked_message": "Das Ziehen ist nicht möglich, da die Sammlung für die Bearbeitung gesperrt ist." | ||||
|   }, | ||||
|   "editable_code": { | ||||
|     "placeholder": "Gebe hier den Inhalt deiner Codenotiz ein..." | ||||
| @@ -942,7 +979,8 @@ | ||||
|     "enter_workspace": "Betrete den Arbeitsbereich {{title}}" | ||||
|   }, | ||||
|   "file": { | ||||
|     "file_preview_not_available": "Für dieses Dateiformat ist keine Dateivorschau verfügbar." | ||||
|     "file_preview_not_available": "Für dieses Dateiformat ist keine Dateivorschau verfügbar.", | ||||
|     "too_big": "Die Vorschau zeigt aus Effizienzgründen nur die ersten {{maxNumChars}} Zeichen der Datei an. Lade die Datei herunter und öffne sie extern um den gesamten Inhalt zu sehen." | ||||
|   }, | ||||
|   "protected_session": { | ||||
|     "enter_password_instruction": "Um die geschützte Notiz anzuzeigen, musst du dein Passwort eingeben:", | ||||
| @@ -981,7 +1019,7 @@ | ||||
|   "web_view": { | ||||
|     "web_view": "Webansicht", | ||||
|     "embed_websites": "Notiz vom Typ Web View ermöglicht das Einbetten von Websites in Trilium.", | ||||
|     "create_label": "To start, please create a label with a URL address you want to embed, e.g. #webViewSrc=\"https://www.google.com\"" | ||||
|     "create_label": "Um zu beginnen, erstelle bitte ein Label mit einer URL-Adresse, die eingebettet werden soll, z. B. #webViewSrc=\"https://www.google.com\"" | ||||
|   }, | ||||
|   "backend_log": { | ||||
|     "refresh": "Aktualisieren" | ||||
| @@ -1007,7 +1045,7 @@ | ||||
|     "error_creating_anonymized_database": "Die anonymisierte Datenbank konnte nicht erstellt werden. Überprüfe die Backend-Protokolle auf Details", | ||||
|     "successfully_created_fully_anonymized_database": "Vollständig anonymisierte Datenbank in {{anonymizedFilePath}} erstellt", | ||||
|     "successfully_created_lightly_anonymized_database": "Leicht anonymisierte Datenbank in {{anonymizedFilePath}} erstellt", | ||||
|     "no_anonymized_database_yet": "Noch keine anonymisierte Datenbank" | ||||
|     "no_anonymized_database_yet": "Noch keine anonymisierte Datenbank." | ||||
|   }, | ||||
|   "database_integrity_check": { | ||||
|     "title": "Datenbankintegritätsprüfung", | ||||
| @@ -1028,7 +1066,7 @@ | ||||
|     "failed": "Synchronisierung fehlgeschlagen: {{message}}" | ||||
|   }, | ||||
|   "vacuum_database": { | ||||
|     "title": "Vakuumdatenbank", | ||||
|     "title": "Datenbank aufräumen", | ||||
|     "description": "Dadurch wird die Datenbank neu erstellt, was normalerweise zu einer kleineren Datenbankdatei führt. Es werden keine Daten tatsächlich geändert.", | ||||
|     "button_text": "Vakuumdatenbank", | ||||
|     "vacuuming_database": "Datenbank wird geleert...", | ||||
| @@ -1063,7 +1101,8 @@ | ||||
|     "max_width_label": "Maximale Inhaltsbreite in Pixel", | ||||
|     "apply_changes_description": "Um Änderungen an der Inhaltsbreite anzuwenden, klicke auf", | ||||
|     "reload_button": "Frontend neu laden", | ||||
|     "reload_description": "Änderungen an den Darstellungsoptionen" | ||||
|     "reload_description": "Änderungen an den Darstellungsoptionen", | ||||
|     "max_width_unit": "Pixel" | ||||
|   }, | ||||
|   "native_title_bar": { | ||||
|     "title": "Native Titelleiste (App-Neustart erforderlich)", | ||||
| @@ -1086,7 +1125,10 @@ | ||||
|     "layout-vertical-title": "Vertikal", | ||||
|     "layout-horizontal-title": "Horizontal", | ||||
|     "layout-vertical-description": "Startleiste ist auf der linken Seite (standard)", | ||||
|     "layout-horizontal-description": "Startleiste ist unter der Tableiste. Die Tableiste wird dadurch auf die ganze Breite erweitert." | ||||
|     "layout-horizontal-description": "Startleiste ist unter der Tableiste. Die Tableiste wird dadurch auf die ganze Breite erweitert.", | ||||
|     "auto_theme": "Alt (Folge dem Farbschema des Systems)", | ||||
|     "light_theme": "Alt (Hell)", | ||||
|     "dark_theme": "Alt (Dunkel)" | ||||
|   }, | ||||
|   "zoom_factor": { | ||||
|     "title": "Zoomfaktor (nur Desktop-Build)", | ||||
| @@ -1095,7 +1137,8 @@ | ||||
|   "code_auto_read_only_size": { | ||||
|     "title": "Automatische schreibgeschützte Größe", | ||||
|     "description": "Die automatische schreibgeschützte Notizgröße ist die Größe, ab der Notizen im schreibgeschützten Modus angezeigt werden (aus Leistungsgründen).", | ||||
|     "label": "Automatische schreibgeschützte Größe (Codenotizen)" | ||||
|     "label": "Automatische schreibgeschützte Größe (Codenotizen)", | ||||
|     "unit": "Zeichen" | ||||
|   }, | ||||
|   "code_mime_types": { | ||||
|     "title": "Verfügbare MIME-Typen im Dropdown-Menü" | ||||
| @@ -1114,12 +1157,13 @@ | ||||
|     "download_images_description": "Eingefügter HTML-Code kann Verweise auf Online-Bilder enthalten. Trilium findet diese Verweise und lädt die Bilder herunter, sodass sie offline verfügbar sind.", | ||||
|     "enable_image_compression": "Bildkomprimierung aktivieren", | ||||
|     "max_image_dimensions": "Maximale Breite/Höhe eines Bildes in Pixel (die Größe des Bildes wird geändert, wenn es diese Einstellung überschreitet).", | ||||
|     "jpeg_quality_description": "JPEG-Qualität (10 – schlechteste Qualität, 100 – beste Qualität, 50 – 85 wird empfohlen)" | ||||
|     "jpeg_quality_description": "JPEG-Qualität (10 – schlechteste Qualität, 100 – beste Qualität, 50 – 85 wird empfohlen)", | ||||
|     "max_image_dimensions_unit": "Pixel" | ||||
|   }, | ||||
|   "attachment_erasure_timeout": { | ||||
|     "attachment_erasure_timeout": "Zeitüberschreitung beim Löschen von Anhängen", | ||||
|     "attachment_auto_deletion_description": "Anhänge werden automatisch gelöscht (und gelöscht), wenn sie nach einer definierten Zeitspanne nicht mehr in ihrer Notiz referenziert werden.", | ||||
|     "erase_attachments_after": "Erase unused attachments after:", | ||||
|     "erase_attachments_after": "Nicht verwendete Anhänge löschen nach:", | ||||
|     "manual_erasing_description": "Du kannst das Löschen auch manuell auslösen (ohne Berücksichtigung des oben definierten Timeouts):", | ||||
|     "erase_unused_attachments_now": "Lösche jetzt nicht verwendete Anhangnotizen", | ||||
|     "unused_attachments_erased": "Nicht verwendete Anhänge wurden gelöscht." | ||||
| @@ -1130,7 +1174,7 @@ | ||||
|   }, | ||||
|   "note_erasure_timeout": { | ||||
|     "note_erasure_timeout_title": "Beachte das Zeitlimit für die Löschung", | ||||
|     "note_erasure_description": "Deleted notes (and attributes, revisions...) are at first only marked as deleted and it is possible to recover them from Recent Notes dialog. After a period of time, deleted notes are \"erased\" which means their content is not recoverable anymore. This setting allows you to configure the length of the period between deleting and erasing the note.", | ||||
|     "note_erasure_description": "Gelöschte Notizen (und Attribute, Notizrevisionen...) werden zunächst nur als gelöscht markiert und können über den Dialog „Zuletzt verwendete Notizen” wiederhergestellt werden. Nach einer bestimmten Zeit werden gelöschte Notizen „gelöscht”, was bedeutet, dass ihr Inhalt nicht mehr wiederhergestellt werden kann. Mit dieser Einstellung können Sie die Zeitspanne zwischen dem Löschen und dem endgültigen Löschen der Notiz festlegen.", | ||||
|     "erase_notes_after": "Notizen löschen nach:", | ||||
|     "manual_erasing_description": "Du kannst das Löschen auch manuell auslösen (ohne Berücksichtigung des oben definierten Timeouts):", | ||||
|     "erase_deleted_notes_now": "Jetzt gelöschte Notizen löschen", | ||||
| @@ -1146,7 +1190,8 @@ | ||||
|     "note_revisions_snapshot_limit_description": "Das Limit für Notizrevision-Snapshots bezieht sich auf die maximale Anzahl von Revisionen, die für jede Notiz gespeichert werden können. Dabei bedeutet -1, dass es kein Limit gibt, und 0 bedeutet, dass alle Revisionen gelöscht werden. Du kannst das maximale Limit für Revisionen einer einzelnen Notiz über das Label #versioningLimit festlegen.", | ||||
|     "snapshot_number_limit_label": "Limit der Notizrevision-Snapshots:", | ||||
|     "erase_excess_revision_snapshots": "Überschüssige Revision-Snapshots jetzt löschen", | ||||
|     "erase_excess_revision_snapshots_prompt": "Überschüssige Revision-Snapshots wurden gelöscht." | ||||
|     "erase_excess_revision_snapshots_prompt": "Überschüssige Revision-Snapshots wurden gelöscht.", | ||||
|     "snapshot_number_limit_unit": "Momentaufnahmen" | ||||
|   }, | ||||
|   "search_engine": { | ||||
|     "title": "Suchmaschine", | ||||
| @@ -1188,19 +1233,29 @@ | ||||
|     "title": "Inhaltsverzeichnis", | ||||
|     "description": "Das Inhaltsverzeichnis wird in Textnotizen angezeigt, wenn die Notiz mehr als eine definierte Anzahl von Überschriften enthält. Du kannst diese Nummer anpassen:", | ||||
|     "disable_info": "Du kannst diese Option auch verwenden, um TOC effektiv zu deaktivieren, indem du eine sehr hohe Zahl festlegst.", | ||||
|     "shortcut_info": "Du kannst eine Tastenkombination zum schnellen Umschalten des rechten Bereichs (einschließlich Inhaltsverzeichnis) unter Optionen -> Tastenkombinationen konfigurieren (Name „toggleRightPane“)." | ||||
|     "shortcut_info": "Du kannst eine Tastenkombination zum schnellen Umschalten des rechten Bereichs (einschließlich Inhaltsverzeichnis) unter Optionen -> Tastenkombinationen konfigurieren (Name „toggleRightPane“).", | ||||
|     "unit": "Überschriften" | ||||
|   }, | ||||
|   "text_auto_read_only_size": { | ||||
|     "title": "Automatische schreibgeschützte Größe", | ||||
|     "description": "Die automatische schreibgeschützte Notizgröße ist die Größe, ab der Notizen im schreibgeschützten Modus angezeigt werden (aus Leistungsgründen).", | ||||
|     "label": "Automatische schreibgeschützte Größe (Textnotizen)" | ||||
|     "label": "Automatische schreibgeschützte Größe (Textnotizen)", | ||||
|     "unit": "Zeichen" | ||||
|   }, | ||||
|   "i18n": { | ||||
|     "title": "Lokalisierung", | ||||
|     "language": "Sprache", | ||||
|     "first-day-of-the-week": "Erster Tag der Woche", | ||||
|     "sunday": "Sonntag", | ||||
|     "monday": "Montag" | ||||
|     "monday": "Montag", | ||||
|     "first-week-of-the-year": "Erste Woche des Jahres", | ||||
|     "first-week-contains-first-day": "Erste Woche enthält den ersten Tag des Jahres", | ||||
|     "first-week-contains-first-thursday": "Erste Woche enthält den ersten Donnerstag des Jahres", | ||||
|     "first-week-has-minimum-days": "Erste Woche hat Mindestanzahl an Tagen", | ||||
|     "min-days-in-first-week": "Mindestanzahl an Tagen in erster Woche", | ||||
|     "first-week-info": "Die erste Woche, die den ersten Donnerstag des Jahres enthält, basiert auf dem Standard <a href=\"https://en.wikipedia.org/wiki/ISO_week_date#First_week\">ISO 8601</a>.", | ||||
|     "first-week-warning": "Das Ändern der Optionen für die erste Woche kann zu Duplikaten mit bestehenden Wochen-Notizen führen. Bestehende Wochen-Notizen werden nicht entsprechend aktualisiert.", | ||||
|     "formatting-locale": "Datums- und Zahlenformat" | ||||
|   }, | ||||
|   "backup": { | ||||
|     "automatic_backup": "Automatische Sicherung", | ||||
| @@ -1303,7 +1358,8 @@ | ||||
|     "test_title": "Synchronisierungstest", | ||||
|     "test_description": "Dadurch werden die Verbindung und der Handshake zum Synchronisierungsserver getestet. Wenn der Synchronisierungsserver nicht initialisiert ist, wird er dadurch für die Synchronisierung mit dem lokalen Dokument eingerichtet.", | ||||
|     "test_button": "Teste die Synchronisierung", | ||||
|     "handshake_failed": "Handshake des Synchronisierungsservers fehlgeschlagen, Fehler: {{message}}" | ||||
|     "handshake_failed": "Handshake des Synchronisierungsservers fehlgeschlagen, Fehler: {{message}}", | ||||
|     "timeout_unit": "Millisekunden" | ||||
|   }, | ||||
|   "api_log": { | ||||
|     "close": "Schließen" | ||||
| @@ -1334,7 +1390,7 @@ | ||||
|     "button-tree-map": "Baumkarte" | ||||
|   }, | ||||
|   "tree-context-menu": { | ||||
|     "open-in-a-new-tab": "In neuem Tab öffnen <kbd>Strg+Klick</kbd>", | ||||
|     "open-in-a-new-tab": "In neuem Tab öffnen", | ||||
|     "open-in-a-new-split": "In neuem Split öffnen", | ||||
|     "insert-note-after": "Notiz dahinter einfügen", | ||||
|     "insert-child-note": "Unternotiz einfügen", | ||||
| @@ -1344,7 +1400,7 @@ | ||||
|     "unhoist-note": "Notiz-Fokus aufheben", | ||||
|     "edit-branch-prefix": "Zweig-Präfix bearbeiten", | ||||
|     "advanced": "Erweitert", | ||||
|     "expand-subtree": "Notizbaum ausklappen", | ||||
|     "expand-subtree": "Unterzweig aufklappen", | ||||
|     "collapse-subtree": "Notizbaum einklappen", | ||||
|     "sort-by": "Sortieren nach...", | ||||
|     "recent-changes-in-subtree": "Kürzliche Änderungen im Notizbaum", | ||||
| @@ -1361,13 +1417,16 @@ | ||||
|     "duplicate": "Duplizieren", | ||||
|     "export": "Exportieren", | ||||
|     "import-into-note": "In Notiz importieren", | ||||
|     "apply-bulk-actions": "Massenaktionen ausführen", | ||||
|     "apply-bulk-actions": "Massenaktionen anwenden", | ||||
|     "converted-to-attachments": "{{count}} Notizen wurden als Anhang konvertiert.", | ||||
|     "convert-to-attachment-confirm": "Bist du sicher, dass du die ausgewählten Notizen in Anhänge ihrer übergeordneten Notizen umwandeln möchtest?" | ||||
|     "convert-to-attachment-confirm": "Bist du sicher, dass du die ausgewählten Notizen in Anhänge ihrer übergeordneten Notizen umwandeln möchtest?", | ||||
|     "open-in-popup": "Schnellbearbeitung", | ||||
|     "archive": "Archiviere", | ||||
|     "unarchive": "Entarchivieren" | ||||
|   }, | ||||
|   "shared_info": { | ||||
|     "shared_publicly": "Diese Notiz ist öffentlich geteilt auf", | ||||
|     "shared_locally": "Diese Notiz ist lokal geteilt auf", | ||||
|     "shared_publicly": "Diese Notiz ist öffentlich geteilt auf {{- link}}.", | ||||
|     "shared_locally": "Diese Notiz ist lokal geteilt auf {{- link}}.", | ||||
|     "help_link": "Für Hilfe besuche <a href=\"https://triliumnext.github.io/Docs/Wiki/sharing.html\">wiki</a>." | ||||
|   }, | ||||
|   "note_types": { | ||||
| @@ -1377,7 +1436,7 @@ | ||||
|     "relation-map": "Beziehungskarte", | ||||
|     "note-map": "Notizkarte", | ||||
|     "render-note": "Render Notiz", | ||||
|     "mermaid-diagram": "Mermaid Diagram", | ||||
|     "mermaid-diagram": "Mermaid Diagramm", | ||||
|     "canvas": "Canvas", | ||||
|     "web-view": "Webansicht", | ||||
|     "mind-map": "Mind Map", | ||||
| @@ -1387,8 +1446,13 @@ | ||||
|     "doc": "Dokument", | ||||
|     "widget": "Widget", | ||||
|     "confirm-change": "Es is nicht empfehlenswert den Notiz-Typ zu ändern, wenn der Inhalt der Notiz nicht leer ist. Möchtest du dennoch fortfahren?", | ||||
|     "geo-map": "Geo Map", | ||||
|     "beta-feature": "Beta" | ||||
|     "geo-map": "Geo-Karte", | ||||
|     "beta-feature": "Beta", | ||||
|     "book": "Sammlung", | ||||
|     "ai-chat": "KI Chat", | ||||
|     "task-list": "Aufgabenliste", | ||||
|     "new-feature": "Neu", | ||||
|     "collections": "Sammlungen" | ||||
|   }, | ||||
|   "protect_note": { | ||||
|     "toggle-on": "Notiz schützen", | ||||
| @@ -1441,7 +1505,8 @@ | ||||
|     "hoist-this-note-workspace": "Diese Notiz fokussieren (Arbeitsbereich)", | ||||
|     "refresh-saved-search-results": "Gespeicherte Suchergebnisse aktualisieren", | ||||
|     "create-child-note": "Unternotiz anlegen", | ||||
|     "unhoist": "Entfokussieren" | ||||
|     "unhoist": "Fokus verlassen", | ||||
|     "toggle-sidebar": "Seitenleiste ein-/ausblenden" | ||||
|   }, | ||||
|   "title_bar_buttons": { | ||||
|     "window-on-top": "Dieses Fenster immer oben halten" | ||||
| @@ -1498,7 +1563,9 @@ | ||||
|   }, | ||||
|   "clipboard": { | ||||
|     "cut": "Notiz(en) wurden in die Zwischenablage ausgeschnitten.", | ||||
|     "copied": "Notiz(en) wurden in die Zwischenablage kopiert." | ||||
|     "copied": "Notiz(en) wurden in die Zwischenablage kopiert.", | ||||
|     "copy_failed": "Speichern in Zwischenablage aufgrund von Berechtigungsproblemen gescheitert.", | ||||
|     "copy_success": "In Zwischenablage kopiert." | ||||
|   }, | ||||
|   "entrypoints": { | ||||
|     "note-revision-created": "Notizrevision wurde erstellt.", | ||||
| @@ -1542,13 +1609,15 @@ | ||||
|   }, | ||||
|   "highlighting": { | ||||
|     "description": "Steuert die Syntaxhervorhebung für Codeblöcke in Textnotizen, Code-Notizen sind nicht betroffen.", | ||||
|     "color-scheme": "Farbschema" | ||||
|     "color-scheme": "Farbschema", | ||||
|     "title": "Code-Blöcke" | ||||
|   }, | ||||
|   "code_block": { | ||||
|     "word_wrapping": "Wortumbruch", | ||||
|     "theme_none": "Keine Syntax-Hervorhebung", | ||||
|     "theme_group_light": "Helle Themen", | ||||
|     "theme_group_dark": "Dunkle Themen" | ||||
|     "theme_group_dark": "Dunkle Themen", | ||||
|     "copy_title": "Kopiere in Zwischenablage" | ||||
|   }, | ||||
|   "classic_editor_toolbar": { | ||||
|     "title": "Format" | ||||
| @@ -1561,11 +1630,11 @@ | ||||
|       "label": "Format Toolbar", | ||||
|       "floating": { | ||||
|         "title": "Schwebend", | ||||
|         "description": "Werkzeuge erscheinen in Cursornähe" | ||||
|         "description": "Werkzeuge erscheinen in Cursornähe;" | ||||
|       }, | ||||
|       "fixed": { | ||||
|         "title": "Fixiert", | ||||
|         "description": "Werkzeuge erscheinen im \"Format\" Tab" | ||||
|         "description": "Werkzeuge erscheinen im \"Format\" Tab." | ||||
|       }, | ||||
|       "multiline-toolbar": "Toolbar wenn nötig in mehreren Zeilen darstellen." | ||||
|     } | ||||
| @@ -1586,14 +1655,15 @@ | ||||
|   "link_context_menu": { | ||||
|     "open_note_in_new_tab": "Notiz in neuen Tab öffnen", | ||||
|     "open_note_in_new_split": "Notiz in neuen geteilten Tab öffnen", | ||||
|     "open_note_in_new_window": "Notiz in neuen Fenster öffnen" | ||||
|     "open_note_in_new_window": "Notiz in neuen Fenster öffnen", | ||||
|     "open_note_in_popup": "Schnellbearbeitung" | ||||
|   }, | ||||
|   "electron_integration": { | ||||
|     "desktop-application": "Desktop Anwendung", | ||||
|     "native-title-bar": "Native Anwendungsleiste", | ||||
|     "native-title-bar-description": "In Windows und macOS, sorgt das Deaktivieren der nativen Anwendungsleiste für ein kompakteres Aussehen. Unter Linux, sorgt das Aktivieren der nativen Anwendungsleiste für eine bessere Integration mit anderen Teilen des Systems.", | ||||
|     "background-effects": "Hintergrundeffekte aktivieren (nur Windows 11)", | ||||
|     "background-effects-description": "Der Mica Effekt fügt einen unscharfen, stylischen Hintergrund in Anwendungsfenstern ein. Dieser erzeugt Tiefe und ein modernes Auftreten.", | ||||
|     "background-effects-description": "Der Mica Effekt fügt einen unscharfen, stylischen Hintergrund in Anwendungsfenstern ein. Dieser erzeugt Tiefe und ein modernes Auftreten. \"Native Titelleiste\" muss deaktiviert sein.", | ||||
|     "restart-app-button": "Anwendung neustarten um Änderungen anzuwenden", | ||||
|     "zoom-factor": "Zoomfaktor" | ||||
|   }, | ||||
| @@ -1606,7 +1676,8 @@ | ||||
|     "full-text-search": "Volltextsuche" | ||||
|   }, | ||||
|   "note_tooltip": { | ||||
|     "note-has-been-deleted": "Notiz wurde gelöscht." | ||||
|     "note-has-been-deleted": "Notiz wurde gelöscht.", | ||||
|     "quick-edit": "Schnellbearbeitung" | ||||
|   }, | ||||
|   "geo-map": { | ||||
|     "create-child-note-title": "Neue Unternotiz anlegen und zur Karte hinzufügen", | ||||
| @@ -1615,7 +1686,8 @@ | ||||
|   }, | ||||
|   "geo-map-context": { | ||||
|     "open-location": "Ort öffnen", | ||||
|     "remove-from-map": "Von Karte entfernen" | ||||
|     "remove-from-map": "Von Karte entfernen", | ||||
|     "add-note": "Markierung an dieser Position erstellen" | ||||
|   }, | ||||
|   "help-button": { | ||||
|     "title": "Relevante Hilfeseite öffnen" | ||||
| @@ -1627,9 +1699,367 @@ | ||||
|     "days": "Tage" | ||||
|   }, | ||||
|   "time_selector": { | ||||
|     "invalid_input": "Die eingegebene Zeit ist keine valide Zahl." | ||||
|     "invalid_input": "Die eingegebene Zeit ist keine valide Zahl.", | ||||
|     "minimum_input": "Die eingegebene Zeit muss mindestens {{minimumSeconds}} Sekunden entsprechen." | ||||
|   }, | ||||
|   "modal": { | ||||
|     "close": "Schließen" | ||||
|     "close": "Schließen", | ||||
|     "help_title": "Zeige mehr Informationen zu diesem Fenster" | ||||
|   }, | ||||
|   "ai_llm": { | ||||
|     "n_notes_queued": "{{ count }} Notiz zur Indizierung vorgemerkt", | ||||
|     "n_notes_queued_plural": "{{ count }} Notizen zur Indizierung vorgemerkt", | ||||
|     "notes_indexed": "{{ count }} Notiz indiziert", | ||||
|     "notes_indexed_plural": "{{ count }} Notizen indiziert", | ||||
|     "not_started": "Nicht gestartet", | ||||
|     "title": "KI Einstellungen", | ||||
|     "processed_notes": "Verarbeitete Notizen", | ||||
|     "total_notes": "Gesamt Notizen", | ||||
|     "progress": "Fortschritt", | ||||
|     "queued_notes": "Eingereihte Notizen", | ||||
|     "failed_notes": "Fehlgeschlagenen Notizen", | ||||
|     "last_processed": "Zuletzt verarbeitet", | ||||
|     "refresh_stats": "Statistiken neu laden", | ||||
|     "enable_ai_features": "Aktiviere KI/LLM Funktionen", | ||||
|     "enable_ai_description": "Aktiviere KI-Funktionen wie Notizzusammenfassungen, Inhaltserzeugung und andere LLM-Funktionen", | ||||
|     "openai_tab": "OpenAI", | ||||
|     "anthropic_tab": "Anthropic", | ||||
|     "voyage_tab": "Voyage AI", | ||||
|     "ollama_tab": "Ollama", | ||||
|     "enable_ai": "Aktiviere KI/LLM Funktionen", | ||||
|     "enable_ai_desc": "Aktiviere KI-Funktionen wie Notizzusammenfassungen, Inhaltserzeugung und andere LLM-Funktionen", | ||||
|     "provider_configuration": "KI-Anbieterkonfiguration", | ||||
|     "provider_precedence": "Anbieter Priorität", | ||||
|     "provider_precedence_description": "Komma-getrennte Liste von Anbieter in der Reihenfolge ihrer Priorität (z.B. 'openai, anthropic,ollama')", | ||||
|     "temperature": "Temperatur", | ||||
|     "temperature_description": "Regelt die Zufälligkeit in Antworten (0 = deterministisch, 2 = maximale Zufälligkeit)", | ||||
|     "system_prompt": "Systemaufforderung", | ||||
|     "system_prompt_description": "Standard Systemaufforderung für alle KI-Interaktionen", | ||||
|     "openai_configuration": "OpenAI Konfiguration", | ||||
|     "openai_settings": "OpenAI Einstellungen", | ||||
|     "api_key": "API Schlüssel", | ||||
|     "url": "Basis-URL", | ||||
|     "model": "Modell", | ||||
|     "anthropic_settings": "Anthropic Einstellungen", | ||||
|     "partial": "{{ percentage }}% verarbeitet", | ||||
|     "anthropic_api_key_description": "Dein Anthropic API-Key für den Zugriff auf Claude Modelle", | ||||
|     "anthropic_model_description": "Anthropic Claude Modell für Chat-Vervollständigung", | ||||
|     "voyage_settings": "Einstellungen für Voyage AI", | ||||
|     "ollama_url_description": "URL für die Ollama API (Standard: http://localhost:11434)", | ||||
|     "ollama_model_description": "Ollama Modell für Chat-Vervollständigung", | ||||
|     "anthropic_configuration": "Anthropic Konfiguration", | ||||
|     "voyage_configuration": "Voyage AI Konfiguration", | ||||
|     "voyage_url_description": "Standard: https://api.voyageai.com/v1", | ||||
|     "ollama_configuration": "Ollama Konfiguration", | ||||
|     "enable_ollama": "Aktiviere Ollama", | ||||
|     "enable_ollama_description": "Aktiviere Ollama für lokale KI Modell Nutzung", | ||||
|     "ollama_url": "Ollama URL", | ||||
|     "ollama_model": "Ollama Modell", | ||||
|     "refresh_models": "Aktualisiere Modelle", | ||||
|     "refreshing_models": "Aktualisiere...", | ||||
|     "enable_automatic_indexing": "Aktiviere automatische Indizierung", | ||||
|     "rebuild_index": "Index neu aufbauen", | ||||
|     "rebuild_index_error": "Fehler beim Neuaufbau des Index. Prüfe Log für mehr Informationen.", | ||||
|     "retry_failed": "Fehler: Notiz konnte nicht erneut eingereiht werden", | ||||
|     "max_notes_per_llm_query": "Max. Notizen je Abfrage", | ||||
|     "max_notes_per_llm_query_description": "Maximale Anzahl ähnlicher Notizen zum Einbinden als KI Kontext", | ||||
|     "active_providers": "Aktive Anbieter", | ||||
|     "disabled_providers": "Inaktive Anbieter", | ||||
|     "remove_provider": "Entferne Anbieter von Suche", | ||||
|     "restore_provider": "Anbieter zur Suche wiederherstellen", | ||||
|     "similarity_threshold": "Ähnlichkeitsschwelle", | ||||
|     "similarity_threshold_description": "Mindestähnlichkeitswert (0-1) für Notizen, die im Kontext für LLM-Abfragen berücksichtigt werden sollen", | ||||
|     "reprocess_index": "Suchindex neu erstellen", | ||||
|     "reprocessing_index": "Neuerstellung...", | ||||
|     "reprocess_index_started": "Suchindex-Optimierung wurde im Hintergrund gestartet", | ||||
|     "reprocess_index_error": "Fehler beim Wiederaufbau des Suchindex", | ||||
|     "index_rebuild_progress": "Fortschritt der Index-Neuerstellung", | ||||
|     "index_rebuilding": "Optimierung Index ({{percentage}}%)", | ||||
|     "index_rebuild_complete": "Index Optimierung abgeschlossen", | ||||
|     "index_rebuild_status_error": "Fehler bei Überprüfung Status Index Neuerstellung", | ||||
|     "never": "Niemals", | ||||
|     "processing": "Verarbeitung ({{percentage}}%)", | ||||
|     "refreshing": "Aktualisiere...", | ||||
|     "incomplete": "Unvollständig ({{percentage}}%)", | ||||
|     "complete": "Abgeschlossen (100%)", | ||||
|     "auto_refresh_notice": "Auto-Aktualisierung alle {{seconds}} Sekunden", | ||||
|     "note_queued_for_retry": "Notiz in Warteschlange für erneuten Versuch hinzugefügt", | ||||
|     "failed_to_retry_note": "Wiederholungsversuch fehlgeschlagen für Notiz", | ||||
|     "ai_settings": "KI Einstellungen", | ||||
|     "agent": { | ||||
|       "processing": "Verarbeite...", | ||||
|       "thinking": "Nachdenken...", | ||||
|       "loading": "Lade...", | ||||
|       "generating": "Generiere..." | ||||
|     }, | ||||
|     "name": "KI", | ||||
|     "openai": "OpenAI", | ||||
|     "use_enhanced_context": "Benutze verbesserten Kontext", | ||||
|     "openai_api_key_description": "Dein OpenAPI-Key für den Zugriff auf den KI-Dienst", | ||||
|     "default_model": "Standardmodell", | ||||
|     "openai_model_description": "Beispiele: gpt-4o, gpt-4-turbo, gpt-3.5-turbo", | ||||
|     "base_url": "Basis URL", | ||||
|     "openai_url_description": "Standard: https://api.openai.com/v1", | ||||
|     "anthropic_url_description": "Basis URL für Anthropic API (Standard: https://api.anthropic.com)", | ||||
|     "ollama_settings": "Ollama Einstellungen", | ||||
|     "note_title": "Notiz Titel", | ||||
|     "error": "Fehler", | ||||
|     "last_attempt": "Letzter Versuch", | ||||
|     "actions": "Aktionen", | ||||
|     "retry": "Erneut versuchen", | ||||
|     "retry_queued": "Notiz für weiteren Versuch eingereiht", | ||||
|     "empty_key_warning": { | ||||
|       "anthropic": "Anthropic API-Key ist leer. Bitte gültigen API-Key eingeben.", | ||||
|       "openai": "OpenAI API-Key ist leer. Bitte gültigen API-Key eingeben.", | ||||
|       "voyage": "Voyage API-Key ist leer. Bitte gültigen API-Key eingeben.", | ||||
|       "ollama": "Ollama API-Key ist leer. Bitte gültigen API-Key eingeben." | ||||
|     }, | ||||
|     "api_key_tooltip": "API-Key für den Zugriff auf den Dienst", | ||||
|     "failed_to_retry_all": "Wiederholungsversuch für Notizen fehlgeschlagen", | ||||
|     "all_notes_queued_for_retry": "Alle fehlgeschlagenen Notizen wurden zur Wiederholung in die Warteschlange gestellt", | ||||
|     "enhanced_context_description": "Versorgt die KI mit mehr Kontext aus der Notiz und den zugehörigen Notizen, um bessere Antworten zu ermöglichen", | ||||
|     "show_thinking": "Zeige Denkprozess", | ||||
|     "show_thinking_description": "Zeige den Denkprozess der KI", | ||||
|     "enter_message": "Geben Sie Ihre Nachricht ein...", | ||||
|     "error_contacting_provider": "Fehler beim Kontaktieren des KI-Anbieters. Bitte überprüfe die Einstellungen und die Internetverbindung.", | ||||
|     "error_generating_response": "Fehler beim Generieren der KI Antwort", | ||||
|     "index_all_notes": "Indiziere alle Notizen", | ||||
|     "index_status": "Indizierungsstatus", | ||||
|     "indexed_notes": "Indizierte Notizen", | ||||
|     "indexing_stopped": "Indizierung gestoppt", | ||||
|     "indexing_in_progress": "Indizierung in Bearbeitung...", | ||||
|     "last_indexed": "Zuletzt Indiziert", | ||||
|     "note_chat": "Notizen-Chat", | ||||
|     "sources": "Quellen", | ||||
|     "start_indexing": "Starte Indizierung", | ||||
|     "use_advanced_context": "Benutze erweiterten Kontext", | ||||
|     "ollama_no_url": "Ollama ist nicht konfiguriert. Bitte trage eine gültige URL ein.", | ||||
|     "chat": { | ||||
|       "root_note_title": "KI Chats", | ||||
|       "root_note_content": "Diese Notiz enthält gespeicherte KI-Chat-Unterhaltungen.", | ||||
|       "new_chat_title": "Neuer Chat", | ||||
|       "create_new_ai_chat": "Erstelle neuen KI Chat" | ||||
|     }, | ||||
|     "create_new_ai_chat": "Erstelle neuen KI Chat", | ||||
|     "configuration_warnings": "Es wurden Probleme mit der KI Konfiguration festgestellt. Bitte überprüfe die Einstellungen.", | ||||
|     "experimental_warning": "Die LLM-Funktionen sind aktuell experimentell - sei an dieser Stelle gewarnt.", | ||||
|     "selected_provider": "Ausgewählter Anbieter", | ||||
|     "selected_provider_description": "Wähle einen KI-Anbieter für Chat- und Vervollständigungsfunktionen", | ||||
|     "select_model": "Wähle Modell...", | ||||
|     "select_provider": "Wähle Anbieter...", | ||||
|     "ai_enabled": "KI Funktionen aktiviert", | ||||
|     "ai_disabled": "KI Funktionen deaktiviert", | ||||
|     "no_models_found_online": "Keine Modelle gefunden. Bitte überprüfe den API-Key und die Einstellungen.", | ||||
|     "no_models_found_ollama": "Kein Ollama Modell gefunden. Bitte prüfe, ob Ollama gerade läuft.", | ||||
|     "error_fetching": "Fehler beim Abrufen der Modelle: {{error}}" | ||||
|   }, | ||||
|   "zen_mode": { | ||||
|     "button_exit": "Verlasse Zen Modus" | ||||
|   }, | ||||
|   "ui-performance": { | ||||
|     "title": "Leistung", | ||||
|     "enable-motion": "Aktiviere Übergänge und Animationen", | ||||
|     "enable-shadows": "Aktiviere Schatten", | ||||
|     "enable-backdrop-effects": "Aktiviere Hintergrundeffekte für Menüs, Pop-up Fenster und Panele", | ||||
|     "enable-smooth-scroll": "Aktiviere sanftes Scrollen", | ||||
|     "app-restart-required": "(Ein Neustart der Anwendung ist erforderlich, damit die Änderungen wirksam werden)" | ||||
|   }, | ||||
|   "code-editor-options": { | ||||
|     "title": "Editor" | ||||
|   }, | ||||
|   "custom_date_time_format": { | ||||
|     "title": "Benutzerdefiniertes Datums-/Zeitformat", | ||||
|     "description": "Passe das Format des Datums und der Uhrzeit an, die über <shortcut /> oder die Symbolleiste eingefügt werden. Die verfügbaren Format-Tokens sind unter <doc>Day.js docs</doc> zu finden.", | ||||
|     "format_string": "Format Zeichenfolge:", | ||||
|     "formatted_time": "Formatiertes Datum/Uhrzeit:" | ||||
|   }, | ||||
|   "multi_factor_authentication": { | ||||
|     "title": "Multi-Faktor-Authentifizierung", | ||||
|     "description": "Die Multi-Faktor-Authentifizierung (MFA) bietet Ihrem Konto eine zusätzliche Sicherheitsebene. Anstatt sich lediglich mit einem Passwort anzumelden, müssen bei der MFA ein oder mehrere zusätzliche Nachweise erbracht werden, um die Identität zu bestätigen. Auf diese Weise kann selbst bei Bekanntwerden des Passworts, ohne die zweite Information nicht auf Ihr Konto zugegriffen werden. Das ist so, als würden Sie ein zusätzliches Schloss an einer Tür anbringen, wodurch es für andere viel schwieriger wird, einzubrechen.<br><br>Befolgen Sie bitte die nachstehenden Anweisungen, um MFA zu aktivieren. Wenn Sie die Konfiguration nicht korrekt vornehmen, erfolgt die Anmeldung weiterhin nur mit dem Passwort.", | ||||
|     "mfa_enabled": "Aktiviere Multi-Faktor-Authentifizierung", | ||||
|     "mfa_method": "MFA Methode", | ||||
|     "electron_disabled": "Multi-Faktor-Authentifizierung wird aktuell nicht in der Desktop-Version unterstützt.", | ||||
|     "totp_title": "Zeitbasiertes Einmalpasswort (TOTP)", | ||||
|     "totp_description": "TOTP (Zeitbasiertes Einmalpasswort) ist eine Sicherheitsfunktion, die einen einzigartigen, temporären Code generiert, der sich alle 30 Sekunden ändert. Sie verwenden diesen Code zusammen mit Ihrem Passwort, um sich bei Ihrem Konto anzumelden, wodurch es für andere Personen wesentlich schwieriger wird, darauf unbefugt zuzugreifen.", | ||||
|     "totp_secret_title": "Generiere TOTP Geheimnis", | ||||
|     "totp_secret_generate": "Generiere TOTP Geheimnis", | ||||
|     "totp_secret_regenerate": "TOTP-Geheimnis neu generieren", | ||||
|     "no_totp_secret_warning": "Um TOTP zu aktivieren, muss zunächst ein TOTP Geheimnis generiert werden.", | ||||
|     "totp_secret_description_warning": "Nach der Generierung des TOTP Geheimnisses ist eine Neuanmeldung mit dem TOTP Geheimnis erforderlich.", | ||||
|     "totp_secret_generated": "TOTP Geheimnis generiert", | ||||
|     "totp_secret_warning": "Bitte speichere das TOTP Geheimnis an einem sicheren Ort. Es wird nicht noch einmal angezeigt.", | ||||
|     "totp_secret_regenerate_confirm": "Möchten Sie das TOTP-Geheimnis wirklich neu generieren? Dadurch werden das bisherige TOTP-Geheimnis und alle vorhandenen Wiederherstellungscodes ungültig.", | ||||
|     "recovery_keys_title": "Einmalige Wiederherstellungsschlüssel", | ||||
|     "recovery_keys_description": "Einmalige Wiederherstellungsschlüssel werden verwendet, um sich anzumelden, falls Sie keinen Zugriff auf Ihre Authentifizierungscodes haben.", | ||||
|     "recovery_keys_description_warning": "Wiederherstellungsschlüssel werden nach dem Verlassen der Seite nicht erneut angezeigt. Bewahren Sie sie an einem sicheren Ort auf.<br>Wiederherstellungsschlüssel können nach ihrer Verwendung nicht erneut verwendet werden.", | ||||
|     "recovery_keys_error": "Fehler beim Generieren der Wiederherstellungscodes", | ||||
|     "recovery_keys_no_key_set": "Keine Wiederherstellungscodes eingerichtet", | ||||
|     "recovery_keys_generate": "Generiere Wiederherstellungscodes", | ||||
|     "recovery_keys_regenerate": "Wiederherstellungscodes erneut generieren", | ||||
|     "recovery_keys_used": "Verwendet: {{date}}", | ||||
|     "recovery_keys_unused": "Wiederherstellungscode {{index}} ist unbenutzt", | ||||
|     "oauth_title": "OAuth/OpenID", | ||||
|     "oauth_description": "OpenID ist ein standardisiertes Verfahren, mit dem Sie sich über ein Konto eines anderen Dienstes, beispielsweise Google, bei Websites anmelden können, um Ihre Identität zu bestätigen. Der Standardaussteller ist Google, Sie können jedoch jeden anderen OpenID-Anbieter auswählen. Weitere Informationen finden Sie <a href=\"#root/_hidden/_help/_help_Otzi9La2YAUX/_help_WOcw2SLH6tbX/_help_7DAiwaf8Z7Rz\">hier</a>. Befolgen Sie diese <a href=\"https://developers.google.com/identity/openid-connect/openid-connect\">Anweisungen</a>, um einen OpenID-Dienst über Google einzurichten.", | ||||
|     "oauth_description_warning": "Um OAuth/OpenID zu aktivieren, müssen Sie die OAuth/OpenID-Basis-URL, die Client-ID und den Client-Secret in der Datei config.ini festlegen und die Anwendung neu starten. Wenn Sie die Einstellungen über Umgebungsvariablen vornehmen möchten, legen Sie bitte TRILIUM_OAUTH_BASE_URL, TRILIUM_OAUTH_CLIENT_ID und TRILIUM_OAUTH_CLIENT_SECRET fest.", | ||||
|     "oauth_missing_vars": "Fehlende Einstellung: {{variables}}", | ||||
|     "oauth_user_account": "Benutzerkonto: ", | ||||
|     "oauth_user_email": "Benutzer E-Mail: ", | ||||
|     "oauth_user_not_logged_in": "Nicht eingeloggt!" | ||||
|   }, | ||||
|   "share": { | ||||
|     "title": "Freigabeeinstellungen", | ||||
|     "redirect_bare_domain": "Hauptdomain zur Freigabeseite weiterleiten", | ||||
|     "redirect_bare_domain_description": "Anonyme Benutzer zur Freigabeseite weiterleiten, anstatt die Anmeldung anzuzeigen", | ||||
|     "show_login_link": "Zeige Anmeldelink im Design der Freigabeseite", | ||||
|     "show_login_link_description": "Füge einen Anmeldelink in der Fußzeile der Freigabeseite hinzu", | ||||
|     "check_share_root": "Status des Freigabe-Roots prüfen", | ||||
|     "share_root_found": "Freigabe-Root-Notiz '{{noteTitle}}' ist bereit", | ||||
|     "share_root_not_found": "Keine Notiz mit #shareRoot Label gefunden", | ||||
|     "share_root_not_shared": "Notiz '{{noteTitle}}' hat das #shareRoot Label, wurde jedoch noch nicht geteilt" | ||||
|   }, | ||||
|   "tasks": { | ||||
|     "due": { | ||||
|       "today": "Heute", | ||||
|       "tomorrow": "Morgen", | ||||
|       "yesterday": "Gestern" | ||||
|     } | ||||
|   }, | ||||
|   "content_widget": { | ||||
|     "unknown_widget": "Unbekanntes Widget für '{{id}}'." | ||||
|   }, | ||||
|   "note_language": { | ||||
|     "not_set": "Nicht gesetzt", | ||||
|     "configure-languages": "Konfiguriere Sprachen..." | ||||
|   }, | ||||
|   "content_language": { | ||||
|     "title": "Inhaltssprachen", | ||||
|     "description": "Wähle eine oder mehrere Sprachen aus, die in der Sprachauswahl im Abschnitt „Grundlegende Eigenschaften“ einer schreibgeschützten oder bearbeitbaren Textnotiz angezeigt werden sollen. Dadurch stehen Funktionen wie Rechtschreibprüfung oder Unterstützung für Rechts-nach-Links-Sprachen zur Verfügung." | ||||
|   }, | ||||
|   "switch_layout_button": { | ||||
|     "title_vertical": "Bearbeitungsbereich nach unten verschieben", | ||||
|     "title_horizontal": "Bearbeitungsbereich nach links verschieben" | ||||
|   }, | ||||
|   "toggle_read_only_button": { | ||||
|     "unlock-editing": "Bearbeitung freischalten", | ||||
|     "lock-editing": "Bearbeitung sperren" | ||||
|   }, | ||||
|   "png_export_button": { | ||||
|     "button_title": "Exportiere Diagramm als PNG" | ||||
|   }, | ||||
|   "svg": { | ||||
|     "export_to_png": "Das Diagramm konnte als PNG nicht exportiert werden." | ||||
|   }, | ||||
|   "code_theme": { | ||||
|     "title": "Aussehen", | ||||
|     "word_wrapping": "Zeilenumbruch", | ||||
|     "color-scheme": "Farbschema" | ||||
|   }, | ||||
|   "cpu_arch_warning": { | ||||
|     "title": "Bitte lade die ARM64-Version herunter", | ||||
|     "message_macos": "TriliumNext läuft aktuell über Rosetta 2. Nutzen Sie die Intel-Version (x64) auf einem Apple-Silicon-Mac, wird dadurch die Leistung und Akkulaufzeit deutlich beeinträchtigt.", | ||||
|     "message_windows": "TriliumNext läuft momentan in einer Emulation. Verwenden Sie eine Intel-Version (x64) auf einem Windows ARM Gerät, kann dadurch die Leistung und Akkulaufzeit deutlich beeinträchtigt werden.", | ||||
|     "recommendation": "Für ein optimales Erlebnis lade bitte die native ARM64-Version von TriliumNext von unserer Release-Seite herunter.", | ||||
|     "download_link": "Lade native Version herunter", | ||||
|     "continue_anyway": "Trotzdem fortfahren", | ||||
|     "dont_show_again": "Zeige diese Warnung nicht erneut" | ||||
|   }, | ||||
|   "editorfeatures": { | ||||
|     "title": "Funktionen", | ||||
|     "emoji_completion_enabled": "Emoji-Autovervollständigung aktivieren", | ||||
|     "note_completion_enabled": "Automatisches Vervollständigen von Notizen aktivieren" | ||||
|   }, | ||||
|   "table_view": { | ||||
|     "new-row": "Neue Zeile", | ||||
|     "new-column": "Neue Spalte", | ||||
|     "sort-column-by": "Sortiere nach '{{title}}'", | ||||
|     "sort-column-ascending": "Aufsteigend", | ||||
|     "sort-column-descending": "Absteigend", | ||||
|     "sort-column-clear": "Sortierung zurücksetzen", | ||||
|     "hide-column": "Spalte '{{title}}' ausblenden", | ||||
|     "show-hide-columns": "Zeige/verberge Spalten", | ||||
|     "row-insert-above": "Zeile oberhalb einfügen", | ||||
|     "row-insert-below": "Zeile unterhalb einfügen", | ||||
|     "row-insert-child": "Unternotiz einfügen", | ||||
|     "add-column-to-the-left": "Spalte links einfügen", | ||||
|     "add-column-to-the-right": "Spalte rechts einfügen", | ||||
|     "edit-column": "Spalte editieren", | ||||
|     "delete_column_confirmation": "Soll diese Spalte wirklich gelöscht werden? Das entsprechende Attribut wird aus allen Notizen entfernt.", | ||||
|     "delete-column": "Spalte entfernen", | ||||
|     "new-column-label": "Label", | ||||
|     "new-column-relation": "Beziehung" | ||||
|   }, | ||||
|   "book_properties_config": { | ||||
|     "hide-weekends": "Wochenenden ausblenden", | ||||
|     "display-week-numbers": "Zeige Kalenderwoche", | ||||
|     "map-style": "Kartenstil:", | ||||
|     "max-nesting-depth": "Maximale Verschachtelungstiefe:", | ||||
|     "raster": "Raster", | ||||
|     "vector_light": "Vektor (Hell)", | ||||
|     "vector_dark": "Vektor (Dunkel)", | ||||
|     "show-scale": "Zeige Skalierung" | ||||
|   }, | ||||
|   "table_context_menu": { | ||||
|     "delete_row": "Zeile entfernen" | ||||
|   }, | ||||
|   "board_view": { | ||||
|     "delete-note": "Lösche Notiz...", | ||||
|     "move-to": "Verschiebe zu", | ||||
|     "insert-above": "Oberhalb einfügen", | ||||
|     "insert-below": "Unterhalb einfügen", | ||||
|     "delete-column": "Spalte entfernen", | ||||
|     "delete-column-confirmation": "Soll die Spalte wirklich gelöscht werden? Abhängige Attribute werden auch in den Notizen unter dieser Spalte gelöscht.", | ||||
|     "new-item": "Neuer Artikel", | ||||
|     "add-column": "Spalte hinzufügen", | ||||
|     "remove-from-board": "Entferne von Tafel", | ||||
|     "archive-note": "archiviere Notiz", | ||||
|     "unarchive-note": "entarchiviere Notiz", | ||||
|     "new-item-placeholder": "Notiz Titel eingeben...", | ||||
|     "add-column-placeholder": "Spaltenname eingeben...", | ||||
|     "edit-note-title": "Klicke zum Editieren des Notiz-Titels", | ||||
|     "edit-column-title": "Klicke zum Editieren des Spalten-Titels" | ||||
|   }, | ||||
|   "command_palette": { | ||||
|     "tree-action-name": "Struktur: {{name}}", | ||||
|     "export_note_title": "Notiz exportieren", | ||||
|     "export_note_description": "aktuelle Notiz exportieren", | ||||
|     "show_attachments_title": "Zeige Anhänge", | ||||
|     "show_attachments_description": "Notizanhänge anzeigen", | ||||
|     "search_notes_title": "Suche Notiz", | ||||
|     "search_notes_description": "Öffne erweiterte Suche", | ||||
|     "search_subtree_title": "Im Unterzweig suchen", | ||||
|     "search_subtree_description": "Im aktuellen Unterzweig suchen", | ||||
|     "search_history_title": "Zeige Suchhistorie", | ||||
|     "search_history_description": "Zeige vorherige Suchen", | ||||
|     "configure_launch_bar_title": "Startleiste anpassen", | ||||
|     "configure_launch_bar_description": "Öffnen Sie die Einstellungen der Startleiste, um Elemente hinzuzufügen oder zu entfernen." | ||||
|   }, | ||||
|   "content_renderer": { | ||||
|     "open_externally": "Öffne extern" | ||||
|   }, | ||||
|   "call_to_action": { | ||||
|     "next_theme_title": "Teste das neue Trilium Design", | ||||
|     "next_theme_message": "Es wird aktuell das alte Design verwendet. Möchten Sie das neue Design ausprobieren?", | ||||
|     "next_theme_button": "Teste das neue Design", | ||||
|     "background_effects_title": "Hintergrundeffekte sind jetzt zuverlässig nutzbar", | ||||
|     "background_effects_message": "Auf Windows-Geräten sind die Hintergrundeffekte nun vollständig stabil. Die Hintergrundeffekte verleihen der Benutzeroberfläche einen Farbakzent, indem der Hintergrund dahinter weichgezeichnet wird. Diese Technik wird auch in anderen Anwendungen wie dem Windows-Explorer eingesetzt.", | ||||
|     "background_effects_button": "Aktiviere Hintergrundeffekte", | ||||
|     "dismiss": "Ablehnen" | ||||
|   }, | ||||
|   "settings": { | ||||
|     "related_settings": "Ähnliche Einstellungen" | ||||
|   }, | ||||
|   "settings_appearance": { | ||||
|     "related_code_blocks": "Farbschema für Code-Blöcke in Textnotizen", | ||||
|     "related_code_notes": "Farbschema für Code-Notizen" | ||||
|   }, | ||||
|   "units": { | ||||
|     "percentage": "%" | ||||
|   }, | ||||
|   "pagination": { | ||||
|     "page_title": "Seite {{startIndex}} von {{endIndex}}", | ||||
|     "total_notes": "{{count}} Notizen" | ||||
|   }, | ||||
|   "collections": { | ||||
|     "rendering_error": "Aufgrund eines Fehlers können keine Inhalte angezeigt werden." | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -263,6 +263,11 @@ | ||||
|     "confirm_delete_all": "Do you want to delete all revisions of this note?", | ||||
|     "no_revisions": "No revisions for this note yet...", | ||||
|     "restore_button": "Restore", | ||||
|     "diff_on": "Show diff", | ||||
|     "diff_off": "Show content", | ||||
|     "diff_on_hint": "Click to show note source diff", | ||||
|     "diff_off_hint": "Click to show note content", | ||||
|     "diff_not_available": "Diff isn't available.", | ||||
|     "confirm_restore": "Do you want to restore this revision? This will overwrite the current title and content of the note with this revision.", | ||||
|     "delete_button": "Delete", | ||||
|     "confirm_delete": "Do you want to delete this revision?", | ||||
| @@ -587,7 +592,18 @@ | ||||
|     "september": "September", | ||||
|     "october": "October", | ||||
|     "november": "November", | ||||
|     "december": "December" | ||||
|     "december": "December", | ||||
|     "week": "Week", | ||||
|     "week_previous": "Previous week", | ||||
|     "week_next": "Next week", | ||||
|     "month": "Month", | ||||
|     "month_previous": "Previous month", | ||||
|     "month_next": "Next month", | ||||
|     "year": "Year", | ||||
|     "year_previous": "Previous year", | ||||
|     "year_next": "Next year", | ||||
|     "list": "List", | ||||
|     "today": "Today" | ||||
|   }, | ||||
|   "close_pane_button": { | ||||
|     "close_this_pane": "Close this pane" | ||||
| @@ -732,7 +748,8 @@ | ||||
|     "note_type": "Note type", | ||||
|     "editable": "Editable", | ||||
|     "basic_properties": "Basic Properties", | ||||
|     "language": "Language" | ||||
|     "language": "Language", | ||||
|     "configure_code_notes": "Configure code notes..." | ||||
|   }, | ||||
|   "book_properties": { | ||||
|     "view_type": "View type", | ||||
| @@ -747,7 +764,8 @@ | ||||
|     "calendar": "Calendar", | ||||
|     "table": "Table", | ||||
|     "geo-map": "Geo Map", | ||||
|     "board": "Board" | ||||
|     "board": "Board", | ||||
|     "include_archived_notes": "Show archived notes" | ||||
|   }, | ||||
|   "edited_notes": { | ||||
|     "no_edited_notes_found": "No edited notes on this day yet...", | ||||
| @@ -848,7 +866,7 @@ | ||||
|     "debug": "debug", | ||||
|     "debug_description": "Debug will print extra debugging information into the console to aid in debugging complex queries", | ||||
|     "action": "action", | ||||
|     "search_button": "Search <kbd>enter</kbd>", | ||||
|     "search_button": "Search", | ||||
|     "search_execute": "Search & Execute actions", | ||||
|     "save_to_note": "Save to note", | ||||
|     "search_parameters": "Search Parameters", | ||||
| @@ -948,7 +966,9 @@ | ||||
|     "no_attachments": "This note has no attachments." | ||||
|   }, | ||||
|   "book": { | ||||
|     "no_children_help": "This collection doesn't have any child notes so there's nothing to display. See <a href=\"https://triliumnext.github.io/Docs/Wiki/book-note.html\">wiki</a> for details." | ||||
|     "no_children_help": "This collection doesn't have any child notes so there's nothing to display. See <a href=\"https://triliumnext.github.io/Docs/Wiki/book-note.html\">wiki</a> for details.", | ||||
|     "drag_locked_title": "Locked for editing", | ||||
|     "drag_locked_message": "Dragging not allowed since the collection is locked for editing." | ||||
|   }, | ||||
|   "editable_code": { | ||||
|     "placeholder": "Type the content of your code note here..." | ||||
| @@ -1113,6 +1133,14 @@ | ||||
|     "layout-vertical-description": "launcher bar is on the left (default)", | ||||
|     "layout-horizontal-description": "launcher bar is underneath the tab bar, the tab bar is now full width." | ||||
|   }, | ||||
|   "ui-performance": { | ||||
|     "title": "Performance", | ||||
|     "enable-motion": "Enable transitions and animations", | ||||
|     "enable-shadows": "Enable shadows", | ||||
|     "enable-backdrop-effects": "Enable background effects for menus, popups and panels", | ||||
|     "enable-smooth-scroll": "Enable smooth scrolling", | ||||
|     "app-restart-required": "(a restart of the application is required for the change to take effect)" | ||||
|   }, | ||||
|   "ai_llm": { | ||||
|     "not_started": "Not started", | ||||
|     "title": "AI Settings", | ||||
| @@ -1562,10 +1590,12 @@ | ||||
|     "button-tree-map": "Tree map" | ||||
|   }, | ||||
|   "tree-context-menu": { | ||||
|     "open-in-a-new-tab": "Open in a new tab <kbd>Ctrl+Click</kbd>", | ||||
|     "open-in-a-new-tab": "Open in a new tab", | ||||
|     "open-in-a-new-split": "Open in a new split", | ||||
|     "insert-note-after": "Insert note after", | ||||
|     "insert-child-note": "Insert child note", | ||||
|     "archive": "Archive", | ||||
|     "unarchive": "Unarchive", | ||||
|     "delete": "Delete", | ||||
|     "search-in-subtree": "Search in subtree", | ||||
|     "hoist-note": "Hoist note", | ||||
| @@ -1595,8 +1625,8 @@ | ||||
|     "open-in-popup": "Quick edit" | ||||
|   }, | ||||
|   "shared_info": { | ||||
|     "shared_publicly": "This note is shared publicly on", | ||||
|     "shared_locally": "This note is shared locally on", | ||||
|     "shared_publicly": "This note is shared publicly on {{- link}}.", | ||||
|     "shared_locally": "This note is shared locally on {{- link}}.", | ||||
|     "help_link": "For help visit <a href=\"https://triliumnext.github.io/Docs/Wiki/sharing.html\">wiki</a>." | ||||
|   }, | ||||
|   "note_types": { | ||||
| @@ -1675,7 +1705,8 @@ | ||||
|     "hoist-this-note-workspace": "Hoist this note (workspace)", | ||||
|     "refresh-saved-search-results": "Refresh saved search results", | ||||
|     "create-child-note": "Create child note", | ||||
|     "unhoist": "Unhoist" | ||||
|     "unhoist": "Unhoist", | ||||
|     "toggle-sidebar": "Toggle sidebar" | ||||
|   }, | ||||
|   "title_bar_buttons": { | ||||
|     "window-on-top": "Keep Window on Top" | ||||
| @@ -1832,7 +1863,7 @@ | ||||
|     "native-title-bar": "Native title bar", | ||||
|     "native-title-bar-description": "For Windows and macOS, keeping the native title bar off makes the application look more compact. On Linux, keeping the native title bar on integrates better with the rest of the system.", | ||||
|     "background-effects": "Enable background effects (Windows 11 only)", | ||||
|     "background-effects-description": "The Mica effect adds a blurred, stylish background to app windows, creating depth and a modern look.", | ||||
|     "background-effects-description": "The Mica effect adds a blurred, stylish background to app windows, creating depth and a modern look. \"Native title bar\" must be disabled.", | ||||
|     "restart-app-button": "Restart the application to view the changes", | ||||
|     "zoom-factor": "Zoom factor" | ||||
|   }, | ||||
| @@ -1931,7 +1962,11 @@ | ||||
|   "editorfeatures": { | ||||
|     "title": "Features", | ||||
|     "emoji_completion_enabled": "Enable Emoji auto-completion", | ||||
|     "note_completion_enabled": "Enable note auto-completion" | ||||
|     "emoji_completion_description": "If enabled, emojis can be easily inserted into text by typing `:`, followed by the name of an emoji.", | ||||
|     "note_completion_enabled": "Enable note auto-completion", | ||||
|     "note_completion_description": "If enabled, links to notes can be created by typing `@` followed by the title of a note.", | ||||
|     "slash_commands_enabled": "Enable slash commands", | ||||
|     "slash_commands_description": "If enabled, editing commands such as inserting line breaks or headings can be toggled by typing `/`." | ||||
|   }, | ||||
|   "table_view": { | ||||
|     "new-row": "New row", | ||||
| @@ -1967,14 +2002,21 @@ | ||||
|     "delete_row": "Delete row" | ||||
|   }, | ||||
|   "board_view": { | ||||
|     "delete-note": "Delete Note", | ||||
|     "delete-note": "Delete note...", | ||||
|     "remove-from-board": "Remove from board", | ||||
|     "archive-note": "Archive note", | ||||
|     "unarchive-note": "Unarchive note", | ||||
|     "move-to": "Move to", | ||||
|     "insert-above": "Insert above", | ||||
|     "insert-below": "Insert below", | ||||
|     "delete-column": "Delete column", | ||||
|     "delete-column-confirmation": "Are you sure you want to delete this column? The corresponding attribute will be deleted in the notes under this column as well.", | ||||
|     "new-item": "New item", | ||||
|     "add-column": "Add Column" | ||||
|     "new-item-placeholder": "Enter note title...", | ||||
|     "add-column": "Add Column", | ||||
|     "add-column-placeholder": "Enter column name...", | ||||
|     "edit-note-title": "Click to edit note title", | ||||
|     "edit-column-title": "Click to edit column title" | ||||
|   }, | ||||
|   "command_palette": { | ||||
|     "tree-action-name": "Tree: {{name}}", | ||||
| @@ -2016,5 +2058,12 @@ | ||||
|   }, | ||||
|   "units": { | ||||
|     "percentage": "%" | ||||
|   }, | ||||
|   "pagination": { | ||||
|     "page_title": "Page of {{startIndex}} - {{endIndex}}", | ||||
|     "total_notes": "{{count}} notes" | ||||
|   }, | ||||
|   "collections": { | ||||
|     "rendering_error": "Unable to show content due to an error." | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -732,7 +732,8 @@ | ||||
|     "note_type": "Tipo de nota", | ||||
|     "editable": "Editable", | ||||
|     "basic_properties": "Propiedades básicas", | ||||
|     "language": "Idioma" | ||||
|     "language": "Idioma", | ||||
|     "configure_code_notes": "Configurar notas de código..." | ||||
|   }, | ||||
|   "book_properties": { | ||||
|     "view_type": "Tipo de vista", | ||||
| @@ -848,7 +849,7 @@ | ||||
|     "debug": "depurar", | ||||
|     "debug_description": "La depuración imprimirá información de depuración adicional en la consola para ayudar a depurar consultas complejas", | ||||
|     "action": "acción", | ||||
|     "search_button": "Buscar <kbd>Enter</kbd>", | ||||
|     "search_button": "Buscar", | ||||
|     "search_execute": "Buscar y ejecutar acciones", | ||||
|     "save_to_note": "Guardar en nota", | ||||
|     "search_parameters": "Parámetros de búsqueda", | ||||
| @@ -1253,7 +1254,12 @@ | ||||
|     "selected_provider": "Proveedor seleccionado", | ||||
|     "selected_provider_description": "Elija el proveedor de IA para el chat y características de completado", | ||||
|     "select_model": "Seleccionar modelo...", | ||||
|     "select_provider": "Seleccionar proveedor..." | ||||
|     "select_provider": "Seleccionar proveedor...", | ||||
|     "ai_enabled": "Características de IA activadas", | ||||
|     "ai_disabled": "Características de IA desactivadas", | ||||
|     "no_models_found_online": "No se encontraron modelos. Por favor, comprueba tu clave de API y la configuración.", | ||||
|     "no_models_found_ollama": "No se encontraron modelos de Ollama. Por favor, comprueba si Ollama se está ejecutando.", | ||||
|     "error_fetching": "Error al obtener los modelos: {{error}}" | ||||
|   }, | ||||
|   "zoom_factor": { | ||||
|     "title": "Factor de zoom (solo versión de escritorio)", | ||||
| @@ -1557,7 +1563,7 @@ | ||||
|     "button-tree-map": "Mapa de Árbol" | ||||
|   }, | ||||
|   "tree-context-menu": { | ||||
|     "open-in-a-new-tab": "Abrir en nueva pestaña <kbd>Ctrl+Click</kbd>", | ||||
|     "open-in-a-new-tab": "Abrir en nueva pestaña", | ||||
|     "open-in-a-new-split": "Abrir en nueva división", | ||||
|     "insert-note-after": "Insertar nota después de", | ||||
|     "insert-child-note": "Insertar subnota", | ||||
| @@ -1590,8 +1596,8 @@ | ||||
|     "open-in-popup": "Edición rápida" | ||||
|   }, | ||||
|   "shared_info": { | ||||
|     "shared_publicly": "Esta nota está compartida públicamente en", | ||||
|     "shared_locally": "Esta nota está compartida localmente en", | ||||
|     "shared_publicly": "Esta nota está compartida públicamente en {{- link}}", | ||||
|     "shared_locally": "Esta nota está compartida localmente en {{- link}}", | ||||
|     "help_link": "Para obtener ayuda visite <a href=\"https://triliumnext.github.io/Docs/Wiki/sharing.html\">wiki</a>." | ||||
|   }, | ||||
|   "note_types": { | ||||
| @@ -2001,5 +2007,21 @@ | ||||
|     "background_effects_message": "En los dispositivos Windows, los efectos de fondo ya son totalmente estables. Los efectos de fondo añaden un toque de color a la interfaz de usuario difuminando el fondo que hay detrás. Esta técnica también se utiliza en otras aplicaciones como el Explorador de Windows.", | ||||
|     "background_effects_button": "Activar efectos de fondo", | ||||
|     "dismiss": "Desestimar" | ||||
|   }, | ||||
|   "ui-performance": { | ||||
|     "title": "Rendimiento", | ||||
|     "enable-motion": "Habilitar transiciones y animaciones", | ||||
|     "enable-shadows": "Activar sombras", | ||||
|     "enable-backdrop-effects": "Habilitar efectos de fondo para menús, ventanas emergentes y paneles" | ||||
|   }, | ||||
|   "settings": { | ||||
|     "related_settings": "Configuración relacionada" | ||||
|   }, | ||||
|   "settings_appearance": { | ||||
|     "related_code_blocks": "Esquema de colores para bloques de código en notas de texto", | ||||
|     "related_code_notes": "Esquema de colores para notas de código" | ||||
|   }, | ||||
|   "units": { | ||||
|     "percentage": "%" | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -848,7 +848,7 @@ | ||||
|     "debug": "debug", | ||||
|     "debug_description": "Debug imprimera des informations supplémentaires dans la console pour faciliter le débogage des requêtes complexes", | ||||
|     "action": "action", | ||||
|     "search_button": "Recherche <kbd>Entrée</kbd>", | ||||
|     "search_button": "Recherche", | ||||
|     "search_execute": "Rechercher et exécuter des actions", | ||||
|     "save_to_note": "Enregistrer dans la note", | ||||
|     "search_parameters": "Paramètres de recherche", | ||||
| @@ -1357,7 +1357,7 @@ | ||||
|     "button-tree-map": "Carte de l'arborescence" | ||||
|   }, | ||||
|   "tree-context-menu": { | ||||
|     "open-in-a-new-tab": "Ouvrir dans un nouvel onglet <kbd>Ctrl+Clic</kbd>", | ||||
|     "open-in-a-new-tab": "Ouvrir dans un nouvel onglet", | ||||
|     "open-in-a-new-split": "Ouvrir dans une nouvelle division", | ||||
|     "insert-note-after": "Insérer une note après", | ||||
|     "insert-child-note": "Insérer une note enfant", | ||||
| @@ -1389,8 +1389,8 @@ | ||||
|     "convert-to-attachment-confirm": "Êtes-vous sûr de vouloir convertir les notes sélectionnées en pièces jointes de leurs notes parentes ?" | ||||
|   }, | ||||
|   "shared_info": { | ||||
|     "shared_publicly": "Cette note est partagée publiquement sur", | ||||
|     "shared_locally": "Cette note est partagée localement sur", | ||||
|     "shared_publicly": "Cette note est partagée publiquement sur {{- link}}", | ||||
|     "shared_locally": "Cette note est partagée localement sur {{- link}}", | ||||
|     "help_link": "Pour obtenir de l'aide, visitez le <a href=\"https://triliumnext.github.io/Docs/Wiki/sharing.html\">wiki</a>." | ||||
|   }, | ||||
|   "note_types": { | ||||
| @@ -1680,6 +1680,16 @@ | ||||
|     "n_notes_queued_2": "", | ||||
|     "notes_indexed_0": "{{ count }} note indexée", | ||||
|     "notes_indexed_1": "{{ count }} notes indexées", | ||||
|     "notes_indexed_2": "" | ||||
|     "notes_indexed_2": "", | ||||
|     "anthropic_url_description": "URL de base pour l'API Anthropic (par défaut : https ://api.anthropic.com)", | ||||
|     "anthropic_model_description": "Modèles Anthropic Claude pour la complétion", | ||||
|     "voyage_settings": "Réglages d'IA Voyage", | ||||
|     "ollama_settings": "Réglages Ollama", | ||||
|     "ollama_url_description": "URL pour l'API Ollama (par défaut: http://localhost:11434)", | ||||
|     "ollama_model_description": "Model Ollama utilisé pour la complétion", | ||||
|     "anthropic_configuration": "Configuration Anthropic", | ||||
|     "voyage_configuration": "Configuration IA Voyage", | ||||
|     "voyage_url_description": "Défaut: https://api.voyageai.com/v1", | ||||
|     "ollama_configuration": "Configuration Ollama" | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -1,345 +1,356 @@ | ||||
| { | ||||
|     "about": { | ||||
|         "app_version": "Versione dell'app:", | ||||
|         "db_version": "Versione DB:", | ||||
|         "sync_version": "Versione Sync:", | ||||
|         "data_directory": "Cartella dati:", | ||||
|         "title": "Informazioni su Trilium Notes", | ||||
|         "build_date": "Data della build:", | ||||
|         "build_revision": "Revisione della build:", | ||||
|         "homepage": "Homepage:" | ||||
|   "about": { | ||||
|     "app_version": "Versione dell'app:", | ||||
|     "db_version": "Versione DB:", | ||||
|     "sync_version": "Versione Sync:", | ||||
|     "data_directory": "Cartella dati:", | ||||
|     "title": "Informazioni su Trilium Notes", | ||||
|     "build_date": "Data della build:", | ||||
|     "build_revision": "Revisione della build:", | ||||
|     "homepage": "Homepage:" | ||||
|   }, | ||||
|   "toast": { | ||||
|     "critical-error": { | ||||
|       "title": "Errore critico", | ||||
|       "message": "Si è verificato un errore critico che impedisce l'avvio dell'applicazione client:\n\n{{message}}\n\nQuesto è probabilmente causato da un errore di script inaspettato. Prova a avviare l'applicazione in modo sicuro e controlla il problema." | ||||
|     }, | ||||
|     "toast": { | ||||
|         "critical-error": { | ||||
|             "title": "Errore critico", | ||||
|             "message": "Si è verificato un errore critico che impedisce l'avvio dell'applicazione client:\n\n{{message}}\n\nQuesto è probabilmente causato da un errore di script inaspettato. Prova a avviare l'applicazione in modo sicuro e controlla il problema." | ||||
|         }, | ||||
|         "bundle-error": { | ||||
|             "title": "Non si è riusciti a caricare uno script personalizzato", | ||||
|             "message": "Lo script della nota con ID \"{{id}}\", dal titolo \"{{title}}\" non è stato inizializzato a causa di:\n\n{{message}}" | ||||
|         }, | ||||
|         "widget-error": { | ||||
|             "title": "Impossibile inizializzare un widget", | ||||
|             "message-custom": "Il widget personalizzato della nota con ID \"{{id}}\", dal titolo \"{{title}}\" non è stato inizializzato a causa di:\n\n{{message}}", | ||||
|             "message-unknown": "Un widget sconosciuto non è stato inizializzato a causa di:\n\n{{message}}" | ||||
|         } | ||||
|     "bundle-error": { | ||||
|       "title": "Non si è riusciti a caricare uno script personalizzato", | ||||
|       "message": "Lo script della nota con ID \"{{id}}\", dal titolo \"{{title}}\" non è stato inizializzato a causa di:\n\n{{message}}" | ||||
|     }, | ||||
|     "add_link": { | ||||
|         "add_link": "Aggiungi un collegamento", | ||||
|         "note": "Nota", | ||||
|         "search_note": "cerca una nota per nome", | ||||
|         "link_title_mirrors": "il titolo del collegamento rispecchia il titolo della nota corrente", | ||||
|         "link_title_arbitrary": "il titolo del collegamento può essere modificato arbitrariamente", | ||||
|         "link_title": "Titolo del collegamento", | ||||
|         "button_add_link": "Aggiungi il collegamento <kbd>invio</kbd>", | ||||
|         "help_on_links": "Aiuto sui collegamenti" | ||||
|     }, | ||||
|     "branch_prefix": { | ||||
|         "edit_branch_prefix": "Modifica il prefisso del ramo", | ||||
|         "help_on_tree_prefix": "Aiuto sui prefissi dell'Albero", | ||||
|         "prefix": "Prefisso: ", | ||||
|         "save": "Salva", | ||||
|         "branch_prefix_saved": "Il prefisso del ramo è stato salvato." | ||||
|     }, | ||||
|     "bulk_actions": { | ||||
|         "bulk_actions": "Azioni massive", | ||||
|         "affected_notes": "Note influenzate", | ||||
|         "include_descendants": "Includi i discendenti della nota selezionata", | ||||
|         "available_actions": "Azioni disponibili", | ||||
|         "chosen_actions": "Azioni scelte", | ||||
|         "execute_bulk_actions": "Esegui le azioni massive", | ||||
|         "bulk_actions_executed": "Le azioni massive sono state eseguite con successo.", | ||||
|         "none_yet": "Ancora nessuna... aggiungi una azione cliccando su una di quelle disponibili sopra.", | ||||
|         "labels": "Etichette", | ||||
|         "relations": "Relazioni", | ||||
|         "notes": "Note", | ||||
|         "other": "Altro" | ||||
|     }, | ||||
|     "clone_to": { | ||||
|         "clone_notes_to": "Clona note in...", | ||||
|         "help_on_links": "Aiuto sui collegamenti", | ||||
|         "notes_to_clone": "Note da clonare", | ||||
|         "target_parent_note": "Nodo padre obiettivo", | ||||
|         "search_for_note_by_its_name": "cerca una nota per nome", | ||||
|         "cloned_note_prefix_title": "Le note clonate saranno mostrate nell'albero delle note con il dato prefisso", | ||||
|         "prefix_optional": "Prefisso (opzionale)", | ||||
|         "clone_to_selected_note": "Clona sotto la nota selezionata <kbd>invio</kbd>", | ||||
|         "no_path_to_clone_to": "Nessun percorso per clonare dentro.", | ||||
|         "note_cloned": "La nota \"{{clonedTitle}}\" è stata clonata in \"{{targetTitle}}\"" | ||||
|     }, | ||||
|     "confirm": { | ||||
|         "cancel": "Annulla", | ||||
|         "ok": "OK", | ||||
|         "confirmation": "Conferma", | ||||
|         "are_you_sure_remove_note": "Sei sicuro di voler rimuovere la nota \"{{title}}\" dalla mappa delle relazioni? ", | ||||
|         "if_you_dont_check": "Se non lo selezioni, la nota sarà rimossa solamente dalla mappa delle relazioni.", | ||||
|         "also_delete_note": "Rimuove anche la nota" | ||||
|     }, | ||||
|     "delete_notes": { | ||||
|         "ok": "OK", | ||||
|         "close": "Chiudi", | ||||
|         "delete_notes_preview": "Anteprima di eliminazione delle note", | ||||
|         "delete_all_clones_description": "Elimina anche tutti i cloni (può essere disfatto tramite i cambiamenti recenti)", | ||||
|         "erase_notes_description": "L'eliminazione normale (soft) marca le note come eliminate e potranno essere recuperate entro un certo lasso di tempo (dalla finestra dei cambiamenti recenti). Selezionando questa opzione le note si elimineranno immediatamente e non sarà possibile recuperarle.", | ||||
|         "erase_notes_warning": "Elimina le note in modo permanente (non potrà essere disfatto), compresi tutti i cloni. Ciò forzerà un nuovo caricamento dell'applicazione.", | ||||
|         "cancel": "Annulla", | ||||
|         "notes_to_be_deleted": "Le seguenti note saranno eliminate ({{- noteCount}})", | ||||
|         "no_note_to_delete": "Nessuna nota sarà eliminata (solo i cloni).", | ||||
|         "broken_relations_to_be_deleted": "Le seguenti relazioni saranno interrotte ed eliminate ({{- relationCount}})", | ||||
|         "deleted_relation_text": "La nota {{- note}} (da eliminare) è referenziata dalla relazione {{- relation}} originata da {{- source}}." | ||||
|     }, | ||||
|     "info": { | ||||
|         "okButton": "OK", | ||||
|         "closeButton": "Chiudi" | ||||
|     }, | ||||
|     "export": { | ||||
|         "close": "Chiudi", | ||||
|         "export_note_title": "Esporta la nota", | ||||
|         "export_status": "Stato dell'esportazione", | ||||
|         "export": "Esporta", | ||||
|         "choose_export_type": "Scegli prima il tipo di esportazione, per favore", | ||||
|         "export_in_progress": "Esportazione in corso: {{progressCount}}", | ||||
|         "export_finished_successfully": "Esportazione terminata con successo.", | ||||
|         "format_pdf": "PDF- allo scopo di stampa o esportazione.", | ||||
|         "export_type_subtree": "Questa nota e tutti i suoi discendenti", | ||||
|         "format_html": "HTML - raccomandato in quanto mantiene tutti i formati", | ||||
|         "format_html_zip": "HTML in archivio ZIP - questo è raccomandato in quanto conserva tutta la formattazione.", | ||||
|         "format_markdown": "MArkdown - questo conserva la maggior parte della formattazione." | ||||
|     }, | ||||
|     "password_not_set": { | ||||
|         "body1": "Le note protette sono crittografate utilizzando una password utente, ma la password non è stata ancora impostata.", | ||||
|         "body2": "Per proteggere le note, fare clic su <a class=\"open-password-options-button\" href=\"javascript:\">qui</a> per aprire la finestra di dialogo Opzioni e impostare la password." | ||||
|     }, | ||||
|     "protected_session_password": { | ||||
|         "close_label": "Chiudi" | ||||
|     }, | ||||
|     "abstract_bulk_action": { | ||||
|         "remove_this_search_action": "Rimuovi questa azione di ricerca" | ||||
|     }, | ||||
|     "etapi": { | ||||
|         "new_token_title": "Nuovo token ETAPI", | ||||
|         "new_token_message": "Inserire il nuovo nome del token" | ||||
|     }, | ||||
|     "electron_integration": { | ||||
|         "zoom-factor": "Fattore di ingrandimento", | ||||
|         "desktop-application": "Applicazione Desktop" | ||||
|     }, | ||||
|     "note_autocomplete": { | ||||
|         "search-for": "Cerca \"{{term}}\"", | ||||
|         "create-note": "Crea e collega la nota figlia \"{{term}}\"", | ||||
|         "insert-external-link": "Inserisci il collegamento esterno a \"{{term}}\"", | ||||
|         "clear-text-field": "Pulisci il campo di testo", | ||||
|         "show-recent-notes": "Mostra le note recenti", | ||||
|         "full-text-search": "Ricerca full text" | ||||
|     }, | ||||
|     "note_tooltip": { | ||||
|         "note-has-been-deleted": "La nota è stata eliminata.", | ||||
|         "quick-edit": "Modifica veloce" | ||||
|     }, | ||||
|     "geo-map": { | ||||
|         "create-child-note-title": "Crea una nota figlia e aggiungila alla mappa", | ||||
|         "create-child-note-instruction": "Clicca sulla mappa per creare una nuova nota qui o premi Escape per uscire.", | ||||
|         "unable-to-load-map": "Impossibile caricare la mappa." | ||||
|     }, | ||||
|     "geo-map-context": { | ||||
|         "open-location": "Apri la posizione", | ||||
|         "remove-from-map": "Rimuovi dalla mappa", | ||||
|         "add-note": "Aggiungi un marcatore in questa posizione" | ||||
|     }, | ||||
|     "debug": { | ||||
|         "debug": "Debug" | ||||
|     }, | ||||
|     "database_anonymization": { | ||||
|         "light_anonymization": "Anonimizzazione parziale", | ||||
|         "title": "Anonimizzazione del Database", | ||||
|         "full_anonymization": "Anonimizzazione completa", | ||||
|         "full_anonymization_description": "Questa azione creerà una nuova copia del database e lo anonimizzerà (rimuove tutti i contenuti delle note, lasciando solo la struttura e qualche metadato non sensibile) per condividerlo online allo scopo di debugging, senza paura di far trapelare i tuoi dati personali.", | ||||
|         "save_fully_anonymized_database": "Salva il database completamente anonimizzato", | ||||
|         "light_anonymization_description": "Questa azione creerà una nuova copia del database e lo anonimizzerà in parzialmente — in particolare, solo il contenuto delle note sarà rimosso, ma i titoli e gli attributi rimarranno. Inoltre, note con script personalizzati JS di frontend/backend e widget personalizzati lasciando rimarranno. Ciò mette a disposizione più contesto per il debug dei problemi.", | ||||
|         "choose_anonymization": "Puoi decidere da solo se fornire un database completamente o parzialmente anonimizzato. Anche un database completamente anonimizzato è molto utile, sebbene in alcuni casi i database parzialmente anonimizzati possono accelerare il processo di identificazione dei bug e la loro correzione.", | ||||
|         "no_anonymized_database_yet": "Nessun database ancora anonimizzato.", | ||||
|         "save_lightly_anonymized_database": "Salva il database parzialmente anonimizzato", | ||||
|         "successfully_created_fully_anonymized_database": "Database completamente anonimizzato creato in {{anonymizedFilePath}}", | ||||
|         "successfully_created_lightly_anonymized_database": "Database parzialmente anonimizzato creato in {{anonymizedFilePath}}" | ||||
|     }, | ||||
|     "cpu_arch_warning": { | ||||
|         "title": "Per favore scarica la versione ARM64", | ||||
|         "continue_anyway": "Continua Comunque", | ||||
|         "dont_show_again": "Non mostrare più questo avviso", | ||||
|         "download_link": "Scarica la Versione Nativa" | ||||
|     }, | ||||
|     "editorfeatures": { | ||||
|         "title": "Caratteristiche", | ||||
|         "emoji_completion_enabled": "Abilita il completamento automatico delle Emoji", | ||||
|         "note_completion_enabled": "Abilita il completamento automatico delle note" | ||||
|     }, | ||||
|     "table_view": { | ||||
|         "new-row": "Nuova riga", | ||||
|         "new-column": "Nuova colonna", | ||||
|         "sort-column-by": "Ordina per \"{{title}}\"", | ||||
|         "sort-column-ascending": "Ascendente", | ||||
|         "sort-column-descending": "Discendente", | ||||
|         "sort-column-clear": "Cancella l'ordinamento", | ||||
|         "hide-column": "Nascondi la colonna \"{{title}}\"", | ||||
|         "show-hide-columns": "Mostra/nascondi le colonne", | ||||
|         "row-insert-above": "Inserisci una riga sopra", | ||||
|         "row-insert-below": "Inserisci una riga sotto" | ||||
|     }, | ||||
|     "abstract_search_option": { | ||||
|         "remove_this_search_option": "Rimuovi questa opzione di ricerca", | ||||
|         "failed_rendering": "Opzione di ricerca di rendering non riuscita: {{dto}} con errore: {{error}} {{stack}}" | ||||
|     }, | ||||
|     "ancestor": { | ||||
|         "label": "Antenato" | ||||
|     }, | ||||
|     "add_label": { | ||||
|         "add_label": "Aggiungi etichetta", | ||||
|         "label_name_placeholder": "nome dell'etichetta", | ||||
|         "new_value_placeholder": "nuovo valore", | ||||
|         "to_value": "al valore" | ||||
|     }, | ||||
|     "update_label_value": { | ||||
|         "to_value": "al valore", | ||||
|         "label_name_placeholder": "nome dell'etichetta" | ||||
|     }, | ||||
|     "delete_label": { | ||||
|         "delete_label": "Elimina etichetta", | ||||
|         "label_name_placeholder": "nome dell'etichetta", | ||||
|         "label_name_title": "Sono ammessi i caratteri alfanumerici, il carattere di sottolineato e i due punti." | ||||
|     }, | ||||
|     "tree-context-menu": { | ||||
|         "move-to": "Muovi in...", | ||||
|         "cut": "Taglia" | ||||
|     }, | ||||
|     "electron_context_menu": { | ||||
|         "cut": "Taglia", | ||||
|         "copy": "Copia", | ||||
|         "paste": "Incolla", | ||||
|         "copy-link": "Copia collegamento", | ||||
|         "paste-as-plain-text": "Incolla come testo semplice" | ||||
|     }, | ||||
|     "editing": { | ||||
|         "editor_type": { | ||||
|             "multiline-toolbar": "Mostra la barra degli strumenti su più linee se non entra." | ||||
|         } | ||||
|     }, | ||||
|     "edit_button": { | ||||
|         "edit_this_note": "Modifica questa nota" | ||||
|     }, | ||||
|     "shortcuts": { | ||||
|         "shortcuts": "Scorciatoie" | ||||
|     }, | ||||
|     "shared_switch": { | ||||
|         "toggle-on-title": "Condividi la nota", | ||||
|         "toggle-off-title": "Non condividere la nota" | ||||
|     }, | ||||
|     "search_string": { | ||||
|         "search_prefix": "Cerca:" | ||||
|     }, | ||||
|     "attachment_detail": { | ||||
|         "open_help_page": "Apri la pagina di aiuto sugli allegati" | ||||
|     }, | ||||
|     "search_definition": { | ||||
|         "ancestor": "antenato", | ||||
|         "debug": "debug", | ||||
|         "action": "azione", | ||||
|         "add_search_option": "Aggiungi un opzione di ricerca:", | ||||
|         "search_string": "cerca la stringa", | ||||
|         "limit": "limite" | ||||
|     }, | ||||
|     "modal": { | ||||
|         "close": "Chiudi" | ||||
|     }, | ||||
|     "board_view": { | ||||
|         "insert-below": "Inserisci sotto", | ||||
|         "delete-column": "Elimina la colonna", | ||||
|         "delete-column-confirmation": "Sei sicuro di vole eliminare questa colonna? Il corrispondente attributo sarà eliminato anche nelle note sotto questa colonna." | ||||
|     }, | ||||
|     "backup": { | ||||
|         "enable_weekly_backup": "Abilita le archiviazioni settimanali", | ||||
|         "enable_monthly_backup": "Abilita le archiviazioni mensili", | ||||
|         "backup_recommendation": "Si raccomanda di mantenere attive le archiviazioni, sebbene ciò possa rendere l'avvio dell'applicazione lento con database grandi e/o dispositivi di archiviazione lenti.", | ||||
|         "backup_now": "Archivia adesso", | ||||
|         "backup_database_now": "Archivia il database adesso", | ||||
|         "existing_backups": "Backup esistenti", | ||||
|         "date-and-time": "Data e ora", | ||||
|         "path": "Percorso", | ||||
|         "database_backed_up_to": "Il database è stato archiviato in {{backupFilePath}}", | ||||
|         "enable_daily_backup": "Abilita le archiviazioni giornaliere", | ||||
|         "no_backup_yet": "Ancora nessuna archiviazione" | ||||
|     }, | ||||
|     "backend_log": { | ||||
|         "refresh": "Aggiorna" | ||||
|     }, | ||||
|     "consistency_checks": { | ||||
|         "find_and_fix_button": "Trova e correggi i problemi di coerenza", | ||||
|         "finding_and_fixing_message": "In cerca e correzione dei problemi di coerenza...", | ||||
|         "issues_fixed_message": "Qualsiasi problema di coerenza che possa essere stato trovato ora è corretto." | ||||
|     }, | ||||
|     "database_integrity_check": { | ||||
|         "check_button": "Controllo dell'integrità del database", | ||||
|         "checking_integrity": "Controllo dell'integrità del database in corso...", | ||||
|         "title": "Controllo di Integrità del database", | ||||
|         "description": "Controllerà che il database non sia corrotto a livello SQLite. Può durare un po' di tempo, a seconda della grandezza del DB.", | ||||
|         "integrity_check_failed": "Controllo di integrità fallito: {{results}}" | ||||
|     }, | ||||
|     "sync": { | ||||
|         "title": "Sincronizza", | ||||
|         "force_full_sync_button": "Forza una sincronizzazione completa", | ||||
|         "failed": "Sincronizzazione fallita: {{message}}" | ||||
|     }, | ||||
|     "sync_2": { | ||||
|         "config_title": "Configurazione per la Sincronizzazione", | ||||
|         "proxy_label": "Server Proxy per la sincronizzazione (opzionale)", | ||||
|         "test_title": "Test di sincronizzazione", | ||||
|         "timeout": "Timeout per la sincronizzazione", | ||||
|         "timeout_unit": "millisecondi", | ||||
|         "save": "Salva", | ||||
|         "help": "Aiuto" | ||||
|     }, | ||||
|     "search_engine": { | ||||
|         "save_button": "Salva" | ||||
|     }, | ||||
|     "sql_table_schemas": { | ||||
|         "tables": "Tabelle" | ||||
|     }, | ||||
|     "tab_row": { | ||||
|         "close_tab": "Chiudi la scheda", | ||||
|         "add_new_tab": "Aggiungi una nuova scheda", | ||||
|         "close": "Chiudi", | ||||
|         "close_other_tabs": "Chiudi le altre schede", | ||||
|         "close_right_tabs": "Chiudi le schede a destra", | ||||
|         "close_all_tabs": "Chiudi tutte le schede", | ||||
|         "reopen_last_tab": "Riapri l'ultima scheda chiusa", | ||||
|         "move_tab_to_new_window": "Sposta questa scheda in una nuova finestra", | ||||
|         "copy_tab_to_new_window": "Copia questa scheda in una nuova finestra", | ||||
|         "new_tab": "Nuova scheda" | ||||
|     }, | ||||
|     "toc": { | ||||
|         "table_of_contents": "Sommario" | ||||
|     }, | ||||
|     "table_of_contents": { | ||||
|         "title": "Sommario" | ||||
|     }, | ||||
|     "tray": { | ||||
|         "title": "Vassoio di Sistema", | ||||
|         "enable_tray": "Abilita il vassoio (Trilium necessita di essere riavviato affinché la modifica abbia effetto)" | ||||
|     }, | ||||
|     "heading_style": { | ||||
|         "title": "Stile dell'Intestazione", | ||||
|         "plain": "Normale", | ||||
|         "underline": "Sottolineato", | ||||
|         "markdown": "Stile Markdown" | ||||
|     }, | ||||
|     "highlights_list": { | ||||
|         "title": "Punti salienti" | ||||
|     }, | ||||
|     "highlights_list_2": { | ||||
|         "title": "Punti salienti", | ||||
|         "options": "Opzioni" | ||||
|     }, | ||||
|     "quick-search": { | ||||
|         "placeholder": "Ricerca rapida", | ||||
|         "searching": "Ricerca in corso..." | ||||
|     "widget-error": { | ||||
|       "title": "Impossibile inizializzare un widget", | ||||
|       "message-custom": "Il widget personalizzato della nota con ID \"{{id}}\", dal titolo \"{{title}}\" non è stato inizializzato a causa di:\n\n{{message}}", | ||||
|       "message-unknown": "Un widget sconosciuto non è stato inizializzato a causa di:\n\n{{message}}" | ||||
|     } | ||||
|   }, | ||||
|   "add_link": { | ||||
|     "add_link": "Aggiungi un collegamento", | ||||
|     "note": "Nota", | ||||
|     "search_note": "cerca una nota per nome", | ||||
|     "link_title_mirrors": "il titolo del collegamento rispecchia il titolo della nota corrente", | ||||
|     "link_title_arbitrary": "il titolo del collegamento può essere modificato arbitrariamente", | ||||
|     "link_title": "Titolo del collegamento", | ||||
|     "button_add_link": "Aggiungi il collegamento <kbd>invio</kbd>", | ||||
|     "help_on_links": "Aiuto sui collegamenti" | ||||
|   }, | ||||
|   "branch_prefix": { | ||||
|     "edit_branch_prefix": "Modifica il prefisso del ramo", | ||||
|     "help_on_tree_prefix": "Aiuto sui prefissi dell'Albero", | ||||
|     "prefix": "Prefisso: ", | ||||
|     "save": "Salva", | ||||
|     "branch_prefix_saved": "Il prefisso del ramo è stato salvato." | ||||
|   }, | ||||
|   "bulk_actions": { | ||||
|     "bulk_actions": "Azioni massive", | ||||
|     "affected_notes": "Note influenzate", | ||||
|     "include_descendants": "Includi i discendenti della nota selezionata", | ||||
|     "available_actions": "Azioni disponibili", | ||||
|     "chosen_actions": "Azioni scelte", | ||||
|     "execute_bulk_actions": "Esegui le azioni massive", | ||||
|     "bulk_actions_executed": "Le azioni massive sono state eseguite con successo.", | ||||
|     "none_yet": "Ancora nessuna... aggiungi una azione cliccando su una di quelle disponibili sopra.", | ||||
|     "labels": "Etichette", | ||||
|     "relations": "Relazioni", | ||||
|     "notes": "Note", | ||||
|     "other": "Altro" | ||||
|   }, | ||||
|   "clone_to": { | ||||
|     "clone_notes_to": "Clona note in...", | ||||
|     "help_on_links": "Aiuto sui collegamenti", | ||||
|     "notes_to_clone": "Note da clonare", | ||||
|     "target_parent_note": "Nodo padre obiettivo", | ||||
|     "search_for_note_by_its_name": "cerca una nota per nome", | ||||
|     "cloned_note_prefix_title": "Le note clonate saranno mostrate nell'albero delle note con il dato prefisso", | ||||
|     "prefix_optional": "Prefisso (opzionale)", | ||||
|     "clone_to_selected_note": "Clona verso la nota selezionata <kbd>invio</kbd>", | ||||
|     "no_path_to_clone_to": "Nessun percorso per clonare dentro.", | ||||
|     "note_cloned": "La nota \"{{clonedTitle}}\" è stata clonata in \"{{targetTitle}}\"" | ||||
|   }, | ||||
|   "confirm": { | ||||
|     "cancel": "Annulla", | ||||
|     "ok": "OK", | ||||
|     "confirmation": "Conferma", | ||||
|     "are_you_sure_remove_note": "Sei sicuro di voler rimuovere la nota \"{{title}}\" dalla mappa delle relazioni? ", | ||||
|     "if_you_dont_check": "Se non lo selezioni, la nota sarà rimossa solamente dalla mappa delle relazioni.", | ||||
|     "also_delete_note": "Rimuove anche la nota" | ||||
|   }, | ||||
|   "delete_notes": { | ||||
|     "ok": "OK", | ||||
|     "close": "Chiudi", | ||||
|     "delete_notes_preview": "Anteprima di eliminazione delle note", | ||||
|     "delete_all_clones_description": "Elimina anche tutti i cloni (può essere ripristinato nella sezione cambiamenti recenti)", | ||||
|     "erase_notes_description": "L'eliminazione normale (soft) marca le note come eliminate e potranno essere recuperate entro un certo lasso di tempo (dalla finestra dei cambiamenti recenti). Selezionando questa opzione le note si elimineranno immediatamente e non sarà possibile recuperarle.", | ||||
|     "erase_notes_warning": "Elimina le note in modo permanente (non potrà essere disfatto), compresi tutti i cloni. Ciò forzerà un nuovo caricamento dell'applicazione.", | ||||
|     "cancel": "Annulla", | ||||
|     "notes_to_be_deleted": "Le seguenti note saranno eliminate ({{- noteCount}})", | ||||
|     "no_note_to_delete": "Nessuna nota sarà eliminata (solo i cloni).", | ||||
|     "broken_relations_to_be_deleted": "Le seguenti relazioni saranno interrotte ed eliminate ({{- relationCount}})", | ||||
|     "deleted_relation_text": "La nota {{- note}} (da eliminare) è referenziata dalla relazione {{- relation}} originata da {{- source}}." | ||||
|   }, | ||||
|   "info": { | ||||
|     "okButton": "OK", | ||||
|     "closeButton": "Chiudi" | ||||
|   }, | ||||
|   "export": { | ||||
|     "close": "Chiudi", | ||||
|     "export_note_title": "Esporta la nota", | ||||
|     "export_status": "Stato dell'esportazione", | ||||
|     "export": "Esporta", | ||||
|     "choose_export_type": "Scegli prima il tipo di esportazione, per favore", | ||||
|     "export_in_progress": "Esportazione in corso: {{progressCount}}", | ||||
|     "export_finished_successfully": "Esportazione terminata con successo.", | ||||
|     "format_pdf": "PDF- allo scopo di stampa o esportazione.", | ||||
|     "export_type_subtree": "Questa nota e tutti i suoi discendenti", | ||||
|     "format_html": "HTML - raccomandato in quanto mantiene tutti i formati", | ||||
|     "format_html_zip": "HTML in archivio ZIP - questo è raccomandato in quanto conserva tutta la formattazione.", | ||||
|     "format_markdown": "MArkdown - questo conserva la maggior parte della formattazione.", | ||||
|     "export_type_single": "Solo questa nota, senza le sottostanti", | ||||
|     "format_opml": "OPML - formato per scambio informazioni outline. Formattazione, immagini e files non sono inclusi.", | ||||
|     "opml_version_1": "OPML v.1.0 - solo testo semplice", | ||||
|     "opml_version_2": "OPML v2.0 - supporta anche HTML" | ||||
|   }, | ||||
|   "password_not_set": { | ||||
|     "body1": "Le note protette sono crittografate utilizzando una password utente, ma la password non è stata ancora impostata.", | ||||
|     "body2": "Per proteggere le note, fare clic su <a class=\"open-password-options-button\" href=\"javascript:\">qui</a> per aprire la finestra di dialogo Opzioni e impostare la password." | ||||
|   }, | ||||
|   "protected_session_password": { | ||||
|     "close_label": "Chiudi" | ||||
|   }, | ||||
|   "abstract_bulk_action": { | ||||
|     "remove_this_search_action": "Rimuovi questa azione di ricerca" | ||||
|   }, | ||||
|   "etapi": { | ||||
|     "new_token_title": "Nuovo token ETAPI", | ||||
|     "new_token_message": "Inserire il nuovo nome del token" | ||||
|   }, | ||||
|   "electron_integration": { | ||||
|     "zoom-factor": "Fattore di ingrandimento", | ||||
|     "desktop-application": "Applicazione Desktop" | ||||
|   }, | ||||
|   "note_autocomplete": { | ||||
|     "search-for": "Cerca \"{{term}}\"", | ||||
|     "create-note": "Crea e collega la nota figlia \"{{term}}\"", | ||||
|     "insert-external-link": "Inserisci il collegamento esterno a \"{{term}}\"", | ||||
|     "clear-text-field": "Pulisci il campo di testo", | ||||
|     "show-recent-notes": "Mostra le note recenti", | ||||
|     "full-text-search": "Ricerca full text" | ||||
|   }, | ||||
|   "note_tooltip": { | ||||
|     "note-has-been-deleted": "La nota è stata eliminata.", | ||||
|     "quick-edit": "Modifica veloce" | ||||
|   }, | ||||
|   "geo-map": { | ||||
|     "create-child-note-title": "Crea una nota figlia e aggiungila alla mappa", | ||||
|     "create-child-note-instruction": "Clicca sulla mappa per creare una nuova nota qui o premi Escape per uscire.", | ||||
|     "unable-to-load-map": "Impossibile caricare la mappa." | ||||
|   }, | ||||
|   "geo-map-context": { | ||||
|     "open-location": "Apri la posizione", | ||||
|     "remove-from-map": "Rimuovi dalla mappa", | ||||
|     "add-note": "Aggiungi un marcatore in questa posizione" | ||||
|   }, | ||||
|   "debug": { | ||||
|     "debug": "Debug" | ||||
|   }, | ||||
|   "database_anonymization": { | ||||
|     "light_anonymization": "Anonimizzazione parziale", | ||||
|     "title": "Anonimizzazione del Database", | ||||
|     "full_anonymization": "Anonimizzazione completa", | ||||
|     "full_anonymization_description": "Questa azione creerà una nuova copia del database e lo anonimizzerà (rimuove tutti i contenuti delle note, lasciando solo la struttura e qualche metadato non sensibile) per condividerlo online allo scopo di debugging, senza paura di far trapelare i tuoi dati personali.", | ||||
|     "save_fully_anonymized_database": "Salva il database completamente anonimizzato", | ||||
|     "light_anonymization_description": "Questa azione creerà una nuova copia del database e lo anonimizzerà in parzialmente — in particolare, solo il contenuto delle note sarà rimosso, ma i titoli e gli attributi rimarranno. Inoltre, note con script personalizzati JS di frontend/backend e widget personalizzati lasciando rimarranno. Ciò mette a disposizione più contesto per il debug dei problemi.", | ||||
|     "choose_anonymization": "Puoi decidere da solo se fornire un database completamente o parzialmente anonimizzato. Anche un database completamente anonimizzato è molto utile, sebbene in alcuni casi i database parzialmente anonimizzati possono accelerare il processo di identificazione dei bug e la loro correzione.", | ||||
|     "no_anonymized_database_yet": "Nessun database ancora anonimizzato.", | ||||
|     "save_lightly_anonymized_database": "Salva il database parzialmente anonimizzato", | ||||
|     "successfully_created_fully_anonymized_database": "Database completamente anonimizzato creato in {{anonymizedFilePath}}", | ||||
|     "successfully_created_lightly_anonymized_database": "Database parzialmente anonimizzato creato in {{anonymizedFilePath}}" | ||||
|   }, | ||||
|   "cpu_arch_warning": { | ||||
|     "title": "Per favore scarica la versione ARM64", | ||||
|     "continue_anyway": "Continua Comunque", | ||||
|     "dont_show_again": "Non mostrare più questo avviso", | ||||
|     "download_link": "Scarica la Versione Nativa" | ||||
|   }, | ||||
|   "editorfeatures": { | ||||
|     "title": "Caratteristiche", | ||||
|     "emoji_completion_enabled": "Abilita il completamento automatico delle Emoji", | ||||
|     "note_completion_enabled": "Abilita il completamento automatico delle note" | ||||
|   }, | ||||
|   "table_view": { | ||||
|     "new-row": "Nuova riga", | ||||
|     "new-column": "Nuova colonna", | ||||
|     "sort-column-by": "Ordina per \"{{title}}\"", | ||||
|     "sort-column-ascending": "Ascendente", | ||||
|     "sort-column-descending": "Discendente", | ||||
|     "sort-column-clear": "Cancella l'ordinamento", | ||||
|     "hide-column": "Nascondi la colonna \"{{title}}\"", | ||||
|     "show-hide-columns": "Mostra/nascondi le colonne", | ||||
|     "row-insert-above": "Inserisci una riga sopra", | ||||
|     "row-insert-below": "Inserisci una riga sotto" | ||||
|   }, | ||||
|   "abstract_search_option": { | ||||
|     "remove_this_search_option": "Rimuovi questa opzione di ricerca", | ||||
|     "failed_rendering": "Opzione di ricerca di rendering non riuscita: {{dto}} con errore: {{error}} {{stack}}" | ||||
|   }, | ||||
|   "ancestor": { | ||||
|     "label": "Antenato" | ||||
|   }, | ||||
|   "add_label": { | ||||
|     "add_label": "Aggiungi etichetta", | ||||
|     "label_name_placeholder": "nome dell'etichetta", | ||||
|     "new_value_placeholder": "nuovo valore", | ||||
|     "to_value": "al valore" | ||||
|   }, | ||||
|   "update_label_value": { | ||||
|     "to_value": "al valore", | ||||
|     "label_name_placeholder": "nome dell'etichetta" | ||||
|   }, | ||||
|   "delete_label": { | ||||
|     "delete_label": "Elimina etichetta", | ||||
|     "label_name_placeholder": "nome dell'etichetta", | ||||
|     "label_name_title": "Sono ammessi i caratteri alfanumerici, il carattere di sottolineato e i due punti." | ||||
|   }, | ||||
|   "tree-context-menu": { | ||||
|     "move-to": "Muovi in...", | ||||
|     "cut": "Taglia" | ||||
|   }, | ||||
|   "electron_context_menu": { | ||||
|     "cut": "Taglia", | ||||
|     "copy": "Copia", | ||||
|     "paste": "Incolla", | ||||
|     "copy-link": "Copia collegamento", | ||||
|     "paste-as-plain-text": "Incolla come testo semplice" | ||||
|   }, | ||||
|   "editing": { | ||||
|     "editor_type": { | ||||
|       "multiline-toolbar": "Mostra la barra degli strumenti su più linee se non entra." | ||||
|     } | ||||
|   }, | ||||
|   "edit_button": { | ||||
|     "edit_this_note": "Modifica questa nota" | ||||
|   }, | ||||
|   "shortcuts": { | ||||
|     "shortcuts": "Scorciatoie" | ||||
|   }, | ||||
|   "shared_switch": { | ||||
|     "toggle-on-title": "Condividi la nota", | ||||
|     "toggle-off-title": "Non condividere la nota" | ||||
|   }, | ||||
|   "search_string": { | ||||
|     "search_prefix": "Cerca:" | ||||
|   }, | ||||
|   "attachment_detail": { | ||||
|     "open_help_page": "Apri la pagina di aiuto sugli allegati" | ||||
|   }, | ||||
|   "search_definition": { | ||||
|     "ancestor": "antenato", | ||||
|     "debug": "debug", | ||||
|     "action": "azione", | ||||
|     "add_search_option": "Aggiungi un opzione di ricerca:", | ||||
|     "search_string": "cerca la stringa", | ||||
|     "limit": "limite" | ||||
|   }, | ||||
|   "modal": { | ||||
|     "close": "Chiudi" | ||||
|   }, | ||||
|   "board_view": { | ||||
|     "insert-below": "Inserisci sotto", | ||||
|     "delete-column": "Elimina la colonna", | ||||
|     "delete-column-confirmation": "Sei sicuro di vole eliminare questa colonna? Il corrispondente attributo sarà eliminato anche nelle note sotto questa colonna." | ||||
|   }, | ||||
|   "backup": { | ||||
|     "enable_weekly_backup": "Abilita le archiviazioni settimanali", | ||||
|     "enable_monthly_backup": "Abilita le archiviazioni mensili", | ||||
|     "backup_recommendation": "Si raccomanda di mantenere attive le archiviazioni, sebbene ciò possa rendere l'avvio dell'applicazione lento con database grandi e/o dispositivi di archiviazione lenti.", | ||||
|     "backup_now": "Archivia adesso", | ||||
|     "backup_database_now": "Archivia il database adesso", | ||||
|     "existing_backups": "Backup esistenti", | ||||
|     "date-and-time": "Data e ora", | ||||
|     "path": "Percorso", | ||||
|     "database_backed_up_to": "Il database è stato archiviato in {{backupFilePath}}", | ||||
|     "enable_daily_backup": "Abilita le archiviazioni giornaliere", | ||||
|     "no_backup_yet": "Ancora nessuna archiviazione" | ||||
|   }, | ||||
|   "backend_log": { | ||||
|     "refresh": "Aggiorna" | ||||
|   }, | ||||
|   "consistency_checks": { | ||||
|     "find_and_fix_button": "Trova e correggi i problemi di coerenza", | ||||
|     "finding_and_fixing_message": "In cerca e correzione dei problemi di coerenza...", | ||||
|     "issues_fixed_message": "Qualsiasi problema di coerenza che possa essere stato trovato ora è corretto." | ||||
|   }, | ||||
|   "database_integrity_check": { | ||||
|     "check_button": "Controllo dell'integrità del database", | ||||
|     "checking_integrity": "Controllo dell'integrità del database in corso...", | ||||
|     "title": "Controllo di Integrità del database", | ||||
|     "description": "Controllerà che il database non sia corrotto a livello SQLite. Può durare un po' di tempo, a seconda della grandezza del DB.", | ||||
|     "integrity_check_failed": "Controllo di integrità fallito: {{results}}" | ||||
|   }, | ||||
|   "sync": { | ||||
|     "title": "Sincronizza", | ||||
|     "force_full_sync_button": "Forza una sincronizzazione completa", | ||||
|     "failed": "Sincronizzazione fallita: {{message}}" | ||||
|   }, | ||||
|   "sync_2": { | ||||
|     "config_title": "Configurazione per la Sincronizzazione", | ||||
|     "proxy_label": "Server Proxy per la sincronizzazione (opzionale)", | ||||
|     "test_title": "Test di sincronizzazione", | ||||
|     "timeout": "Timeout per la sincronizzazione", | ||||
|     "timeout_unit": "millisecondi", | ||||
|     "save": "Salva", | ||||
|     "help": "Aiuto" | ||||
|   }, | ||||
|   "search_engine": { | ||||
|     "save_button": "Salva" | ||||
|   }, | ||||
|   "sql_table_schemas": { | ||||
|     "tables": "Tabelle" | ||||
|   }, | ||||
|   "tab_row": { | ||||
|     "close_tab": "Chiudi la scheda", | ||||
|     "add_new_tab": "Aggiungi una nuova scheda", | ||||
|     "close": "Chiudi", | ||||
|     "close_other_tabs": "Chiudi le altre schede", | ||||
|     "close_right_tabs": "Chiudi le schede a destra", | ||||
|     "close_all_tabs": "Chiudi tutte le schede", | ||||
|     "reopen_last_tab": "Riapri l'ultima scheda chiusa", | ||||
|     "move_tab_to_new_window": "Sposta questa scheda in una nuova finestra", | ||||
|     "copy_tab_to_new_window": "Copia questa scheda in una nuova finestra", | ||||
|     "new_tab": "Nuova scheda" | ||||
|   }, | ||||
|   "toc": { | ||||
|     "table_of_contents": "Sommario" | ||||
|   }, | ||||
|   "table_of_contents": { | ||||
|     "title": "Sommario" | ||||
|   }, | ||||
|   "tray": { | ||||
|     "title": "Vassoio di Sistema", | ||||
|     "enable_tray": "Abilita il vassoio (Trilium necessita di essere riavviato affinché la modifica abbia effetto)" | ||||
|   }, | ||||
|   "heading_style": { | ||||
|     "title": "Stile dell'Intestazione", | ||||
|     "plain": "Normale", | ||||
|     "underline": "Sottolineato", | ||||
|     "markdown": "Stile Markdown" | ||||
|   }, | ||||
|   "highlights_list": { | ||||
|     "title": "Punti salienti" | ||||
|   }, | ||||
|   "highlights_list_2": { | ||||
|     "title": "Punti salienti", | ||||
|     "options": "Opzioni" | ||||
|   }, | ||||
|   "quick-search": { | ||||
|     "placeholder": "Ricerca rapida", | ||||
|     "searching": "Ricerca in corso..." | ||||
|   }, | ||||
|   "help": { | ||||
|     "goUpDown": "su/giù nella lista delle note", | ||||
|     "collapseExpand": "collassa/espande il nodo", | ||||
|     "notSet": "non impostato", | ||||
|     "goBackForwards": "indietro/avanti nella cronologia", | ||||
|     "showJumpToNoteDialog": "mostra <a class=\"external\" href=\"https://triliumnext.github.io/Docs/Wiki/note-navigation.html#jump-to-note\">la finestra di dialogo \"Salta alla nota\"<a>" | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -66,7 +66,8 @@ | ||||
|     "toggle-zen-mode": "禅モード", | ||||
|     "switch_to_mobile_version": "モバイル版に切り替え", | ||||
|     "switch_to_desktop_version": "デスクトップ版に切り替え", | ||||
|     "configure_launchbar": "ランチャーバーの設定" | ||||
|     "configure_launchbar": "ランチャーバーの設定", | ||||
|     "show_shared_notes_subtree": "共有ノートのサブツリーを表示" | ||||
|   }, | ||||
|   "left_pane_toggle": { | ||||
|     "show_panel": "パネルを表示", | ||||
| @@ -120,7 +121,9 @@ | ||||
|     "september": "9月", | ||||
|     "october": "10月", | ||||
|     "november": "11月", | ||||
|     "december": "12月" | ||||
|     "december": "12月", | ||||
|     "cannot_find_day_note": "dayノートが見つかりません", | ||||
|     "cannot_find_week_note": "weekノートが見つかりません" | ||||
|   }, | ||||
|   "note_icon": { | ||||
|     "change_note_icon": "ノートアイコンの変更", | ||||
| @@ -185,13 +188,14 @@ | ||||
|     "debug": "デバッグ", | ||||
|     "debug_description": "デバッグは複雑なクエリのデバッグを支援するために、追加のデバッグ情報をコンソールに出力します", | ||||
|     "action": "アクション", | ||||
|     "search_button": "検索 <kbd>Enter</kbd>", | ||||
|     "search_button": "検索", | ||||
|     "search_execute": "検索とアクションの実行", | ||||
|     "save_to_note": "ノートに保存", | ||||
|     "search_parameters": "検索パラメータ", | ||||
|     "unknown_search_option": "不明な検索オプション {{searchOptionName}}", | ||||
|     "search_note_saved": "検索ノートが {{- notePathTitle}} に保存されました", | ||||
|     "actions_executed": "アクションが実行されました。" | ||||
|     "actions_executed": "アクションが実行されました。", | ||||
|     "ancestor": "祖先:" | ||||
|   }, | ||||
|   "shortcuts": { | ||||
|     "multiple_shortcuts": "同じアクションに対して複数のショートカットを設定する場合、カンマで区切ることができます。", | ||||
| @@ -309,7 +313,8 @@ | ||||
|     }, | ||||
|     "import-status": "インポート状況", | ||||
|     "in-progress": "インポート中: {{progress}}", | ||||
|     "successful": "インポートは正常に終了しました。" | ||||
|     "successful": "インポートは正常に終了しました。", | ||||
|     "explodeArchives": "<code>.zip</code>, <code>.enex</code> および <code>.opml</code> アーカイブの内容を読み取ります。" | ||||
|   }, | ||||
|   "password_not_set": { | ||||
|     "title": "パスワードが設定されていない", | ||||
| @@ -365,7 +370,7 @@ | ||||
|   }, | ||||
|   "tree-context-menu": { | ||||
|     "advanced": "高度", | ||||
|     "open-in-a-new-tab": "新しいタブで開く <kbd>Ctrl+Click</kbd>", | ||||
|     "open-in-a-new-tab": "新しいタブで開く", | ||||
|     "open-in-a-new-split": "新しく分割して開く", | ||||
|     "insert-note-after": "ノートを後ろに挿入", | ||||
|     "insert-child-note": "子ノートを挿入", | ||||
| @@ -391,7 +396,10 @@ | ||||
|     "converted-to-attachments": "{{count}}ノートが添付ファイルに変換されました。", | ||||
|     "convert-to-attachment": "添付ファイルに変換", | ||||
|     "convert-to-attachment-confirm": "選択したノートを親ノートの添付ファイルに変換しますか?", | ||||
|     "open-in-popup": "クイックエディット" | ||||
|     "open-in-popup": "クイックエディット", | ||||
|     "hoist-note": "ホイストノート", | ||||
|     "unhoist-note": "ノートをホイストしない", | ||||
|     "edit-branch-prefix": "ブランチの接頭辞を編集" | ||||
|   }, | ||||
|   "zen_mode": { | ||||
|     "button_exit": "禅モードを退出" | ||||
| @@ -432,10 +440,16 @@ | ||||
|     "search_notes_description": "高度な検索を開く", | ||||
|     "search_subtree_description": "現在のサブツリー内を検索", | ||||
|     "search_history_title": "検索履歴を表示", | ||||
|     "search_history_description": "過去の検索結果を見る" | ||||
|     "search_history_description": "過去の検索結果を見る", | ||||
|     "show_attachments_title": "添付ファイルを表示", | ||||
|     "show_attachments_description": "ノートの添付ファイルを表示", | ||||
|     "configure_launch_bar_title": "ランチャーバーの設定", | ||||
|     "configure_launch_bar_description": "ランチャーバーの構成を開き、項目を追加または削除します。" | ||||
|   }, | ||||
|   "delete_note": { | ||||
|     "delete_note": "ノートを削除" | ||||
|     "delete_note": "ノートを削除", | ||||
|     "delete_matched_notes": "一致したノートを削除", | ||||
|     "delete_matched_notes_description": "これにより、一致したノートが削除されます。" | ||||
|   }, | ||||
|   "board_view": { | ||||
|     "delete-note": "ノートを削除", | ||||
| @@ -444,7 +458,15 @@ | ||||
|     "delete-column": "列を削除", | ||||
|     "delete-column-confirmation": "本当にこの列を削除しますか?対応する属性は、この列の下のノートでも削除されます。", | ||||
|     "new-item": "新しいアイテム", | ||||
|     "add-column": "列を追加" | ||||
|     "add-column": "列を追加", | ||||
|     "remove-from-board": "ボードから削除", | ||||
|     "archive-note": "アーカイブノート", | ||||
|     "unarchive-note": "ノートのアーカイブを解除", | ||||
|     "move-to": "移動先", | ||||
|     "new-item-placeholder": "ノートのタイトルを入力...", | ||||
|     "add-column-placeholder": "列名を入力...", | ||||
|     "edit-note-title": "クリックしてノートのタイトルを編集", | ||||
|     "edit-column-title": "クリックして列のタイトルを編集" | ||||
|   }, | ||||
|   "code_buttons": { | ||||
|     "execute_button_title": "スクリプトを実行", | ||||
| @@ -454,7 +476,9 @@ | ||||
|     "sql_console_saved_message": "SQLコンソールが {{note_path}} に保存されました" | ||||
|   }, | ||||
|   "execute_script": { | ||||
|     "execute_script": "スクリプトを実行" | ||||
|     "execute_script": "スクリプトを実行", | ||||
|     "help_text": "一致したノートに対して簡単なスクリプトを実行できます。", | ||||
|     "example_2": "より複雑な例としては、一致したノートの属性をすべて削除することが挙げられます:" | ||||
|   }, | ||||
|   "script_executor": { | ||||
|     "execute_script": "スクリプトを実行", | ||||
| @@ -484,7 +508,8 @@ | ||||
|     "calendar": "カレンダー", | ||||
|     "table": "テーブル", | ||||
|     "geo-map": "ジオマップ", | ||||
|     "board": "ボード" | ||||
|     "board": "ボード", | ||||
|     "include_archived_notes": "アーカイブされたノートを表示" | ||||
|   }, | ||||
|   "note_types": { | ||||
|     "geo-map": "ジオマップ", | ||||
| @@ -493,7 +518,7 @@ | ||||
|     "text": "テキスト", | ||||
|     "code": "コード", | ||||
|     "saved-search": "検索の保存", | ||||
|     "relation-map": "関係マップ", | ||||
|     "relation-map": "リレーションマップ", | ||||
|     "note-map": "ノートマップ", | ||||
|     "render-note": "レンダリングノート", | ||||
|     "book": "コレクション", | ||||
| @@ -563,7 +588,14 @@ | ||||
|     "settings": "ノートの変更履歴の設定", | ||||
|     "file_size": "ファイルサイズ:", | ||||
|     "preview": "プレビュー:", | ||||
|     "preview_not_available": "このノートタイプではプレビューは利用できません。" | ||||
|     "preview_not_available": "このノートタイプではプレビューは利用できません。", | ||||
|     "diff_on": "差分を表示", | ||||
|     "diff_off": "内容を表示", | ||||
|     "diff_on_hint": "クリックしてノートソースとの差分を表示", | ||||
|     "diff_off_hint": "クリックしてノートの内容を表示", | ||||
|     "diff_not_available": "差分は利用できません。", | ||||
|     "snapshot_interval": "ノートの変更履歴の記録間隔: {{seconds}} 秒。", | ||||
|     "maximum_revisions": "ノートの変更履歴の記録制限: {{number}}." | ||||
|   }, | ||||
|   "attachments_actions": { | ||||
|     "download": "ダウンロード", | ||||
| @@ -613,7 +645,8 @@ | ||||
|     "intro_placed": "このノートは以下のパスに置かれる:", | ||||
|     "intro_not_placed": "このノートはまだノートツリーに配置されていません。", | ||||
|     "archived": "アーカイブされた", | ||||
|     "search": "検索" | ||||
|     "search": "検索", | ||||
|     "outside_hoisted": "このパスはホイストされたノートの外側にあるため、ホイストを解除する必要があります。" | ||||
|   }, | ||||
|   "note_properties": { | ||||
|     "info": "情報" | ||||
| @@ -692,13 +725,30 @@ | ||||
|     "placeholder_search": "ノート名で検索", | ||||
|     "dialog_title": "埋め込みノート", | ||||
|     "box_size_prompt": "埋め込みノート枠のサイズ:", | ||||
|     "button_include": "埋め込みノート" | ||||
|     "button_include": "埋め込みノート", | ||||
|     "label_note": "ノート", | ||||
|     "box_size_small": "スモール (~ 10 行)", | ||||
|     "box_size_medium": "ミディアム (~ 30 行)", | ||||
|     "box_size_full": "フル (ボックスに全文が表示されます)" | ||||
|   }, | ||||
|   "ancestor": { | ||||
|     "placeholder": "ノート名で検索" | ||||
|     "placeholder": "ノート名で検索", | ||||
|     "label": "祖先", | ||||
|     "depth_label": "深さ", | ||||
|     "depth_doesnt_matter": "関係ない", | ||||
|     "depth_eq": "ちょうど {{count}} つ下の階層", | ||||
|     "direct_children": "直接の子", | ||||
|     "depth_gt": "{{count}} より下の階層", | ||||
|     "depth_lt": "{{count}} より上の階層" | ||||
|   }, | ||||
|   "move_to": { | ||||
|     "search_placeholder": "ノート名で検索" | ||||
|     "search_placeholder": "ノート名で検索", | ||||
|     "dialog_title": "ノートを移動...", | ||||
|     "notes_to_move": "移動させるノート", | ||||
|     "target_parent_note": "対象の親ノート", | ||||
|     "move_button": "選択したノートに移動", | ||||
|     "error_no_path": "移動するパスがありません。", | ||||
|     "move_success_message": "選択したノートは以下に移動されました " | ||||
|   }, | ||||
|   "web_view": { | ||||
|     "web_view": "Web ビュー", | ||||
| @@ -739,7 +789,8 @@ | ||||
|     "default_description": "Triliumは、ワイドスクリーンで最大化された画面での可読性を向上させるために、デフォルトでコンテンツの最大幅を制限しています。", | ||||
|     "max_width_label": "最大コンテンツ幅", | ||||
|     "max_width_unit": "ピクセル", | ||||
|     "apply_changes_description": "コンテンツ幅の変更を適用するには、クリックしてください" | ||||
|     "apply_changes_description": "コンテンツ幅の変更を適用するには、クリックしてください", | ||||
|     "reload_description": "外観オプションからの変更" | ||||
|   }, | ||||
|   "theme": { | ||||
|     "title": "アプリのテーマ", | ||||
| @@ -905,10 +956,16 @@ | ||||
|     "close": "閉じる" | ||||
|   }, | ||||
|   "info": { | ||||
|     "closeButton": "閉じる" | ||||
|     "closeButton": "閉じる", | ||||
|     "modalTitle": "情報メッセージ", | ||||
|     "okButton": "OK" | ||||
|   }, | ||||
|   "protected_session_password": { | ||||
|     "close_label": "閉じる" | ||||
|     "close_label": "閉じる", | ||||
|     "modal_title": "保護されたセッション", | ||||
|     "help_title": "保護されたノートに関するヘルプ", | ||||
|     "form_label": "リクエストされたアクションを続行するには、パスワードを入力して保護されたセッションを開始する必要があります:", | ||||
|     "start_button": "保護されたセッションを開始" | ||||
|   }, | ||||
|   "modal": { | ||||
|     "close": "閉じる", | ||||
| @@ -946,7 +1003,81 @@ | ||||
|     "digits": "桁", | ||||
|     "inheritable_title": "継承属性は、このツリー配下のすべての子孫に継承されます。", | ||||
|     "inheritable": "継承", | ||||
|     "related_notes_title": "このラベルが付いた他のノート" | ||||
|     "related_notes_title": "このラベルが付いた他のノート", | ||||
|     "attr_detail_title": "属性の詳細なタイトル", | ||||
|     "target_note_title": "リレーションは、ソースノートとターゲットノート間の名前付き接続です。", | ||||
|     "target_note": "対象のノート", | ||||
|     "promoted_title": "プロモート属性はノートに目立つように表示されます。", | ||||
|     "promoted": "プロモート", | ||||
|     "promoted_alias_title": "プロモート属性のUIに表示される名前。", | ||||
|     "inverse_relation_title": "このリレーションがどのリレーションの反対であるかを定義するオプション設定。例:父と息子は互いに逆のリレーションです。", | ||||
|     "inverse_relation": "逆リレーション", | ||||
|     "more_notes": "その他のノート", | ||||
|     "label": "ラベルの詳細", | ||||
|     "label_definition": "ラベル定義の詳細", | ||||
|     "relation": "リレーションの詳細", | ||||
|     "relation_definition": "リレーション定義の詳細", | ||||
|     "disable_versioning": "自動バージョン管理を無効にします。例えば、スクリプト用の大きなJSライブラリなど、重要ではない大きなノートに便利です", | ||||
|     "calendar_root": "dayノートのルートとして使用するノートをマークします。このようにマークできるのは 1 つだけです。", | ||||
|     "archived": "このラベルの付いたノートは、デフォルトでは検索結果に表示されません (ジャンプ先、リンクの追加ダイアログなどにも表示されません)。", | ||||
|     "exclude_from_export": "ノート(サブツリーを含む)はノートのエクスポートには含まれません", | ||||
|     "run": "どのイベントでスクリプトを実行するかを定義します。可能な値は次の通り:\n<ul>\n<li>frontendStartup - Trilium フロントエンドが起動(または更新)されたとき。モバイルは除く</li>\n<li>mobileStartup - モバイルで Trilium フロントエンドが起動(または更新)されたとき。</li>\n<li>backendStartup - Trilium バックエンドが起動したとき</li>\n<li>hourly - 1時間に1回実行します。 <code>runAtHour</code> というラベルを追加して、実行時刻を指定できます。</li>\n<li>daily - 1日に1回実行</li>\n</ul>", | ||||
|     "run_on_instance": "どの Trilium インスタンスでこれを実行するかを定義します。デフォルトはすべてのインスタンスです。", | ||||
|     "run_at_hour": "何時に実行するかを指定します。 <code>#run=hourly</code> と併用してください。1日に複数回実行したい場合は、複数回定義できます。", | ||||
|     "disable_inclusion": "このラベルが付いたスクリプトは親スクリプトの実行には含まれません。", | ||||
|     "sorted": "子ノートをアルファベット順に並べ替える", | ||||
|     "sort_direction": "ASC(デフォルト)または DESC", | ||||
|     "sort_folders_first": "フォルダ(子を持つノート)を上にして並べる", | ||||
|     "top": "指定されたノートをその親ノートの一番上に表示します(ソートされた親ノートにのみ適用されます)", | ||||
|     "hide_promoted_attributes": "このノートのプロモート属性を非表示にする", | ||||
|     "read_only": "エディターは読み取り専用モードです。テキストとコードノートのみ機能します。", | ||||
|     "auto_read_only_disabled": "テキスト/コードノートは、サイズが大きすぎる場合、自動的に読み取りモードに設定されます。このラベルをノートに追加することで、ノートごとにこの動作を無効にすることができます", | ||||
|     "app_css": "Trilium アプリケーションに読み込まれ、Trilium の外観を変更するために使用できる CSS ノートをマークします。", | ||||
|     "app_theme": "Trilium のフルテーマである CSS ノートをマークし、Trilium オプションで利用できるようにします。", | ||||
|     "app_theme_base": "「next」、「next-light」、または「next-dark」に設定すると、従来のテーマではなく、対応する TriliumNext テーマ (auto、light、または dark) がカスタム テーマのベースとして使用されます。", | ||||
|     "css_class": "このラベルの値は、ツリー内の特定のノートを表すノードにCSSクラスとして追加されます。これは高度なテーマ設定に役立ちます。テンプレートノートで使用できます。", | ||||
|     "icon_class": "このラベルの値は、ツリー上のアイコンにCSSクラスとして追加され、ツリー内のノートを視覚的に区別するのに役立ちます。例えば、bx bx-home のように、アイコンは boxicons から取得されます。テンプレートノートで使用できます。", | ||||
|     "page_size": "ノートリストの1ページあたりの項目数", | ||||
|     "custom_request_handler": "<a href=\"javascript:\" data-help-page=\"custom-request-handler.html\">カスタムリクエストハンドラー</a>を参照してください", | ||||
|     "custom_resource_provider": "<a href=\"javascript:\" data-help-page=\"custom-request-handler.html\">カスタムリクエストハンドラー</a>を参照してください", | ||||
|     "widget": "このノートをカスタムウィジェットとしてマークし、Trilium コンポーネントツリーに追加します", | ||||
|     "workspace": "このノートをワークスペースとしてマークし、簡単にホイストできるようにします", | ||||
|     "workspace_icon_class": "このノートにホイストされたときにタブで使用されるボックスアイコンのCSSクラスを定義します", | ||||
|     "workspace_tab_background_color": "このノートにホイストされたときにノートタブで使用されるCSSでの色", | ||||
|     "workspace_calendar_root": "ワークスペースごとのカレンダールートを定義する", | ||||
|     "workspace_template": "このノートは、新しいノートを作成するときに利用可能なテンプレートの選択肢に表示されますが、このテンプレートを含むワークスペースにホイストされた場合にのみ表示されます", | ||||
|     "search_home": "新しい検索ノートはこのノートの子として作成されます", | ||||
|     "workspace_search_home": "このワークスペースノートの祖先にホイストされた新しい検索ノートは、このノートの子として作成されます", | ||||
|     "inbox": "新しいノートのデフォルトのinboxの場所 - サイドバーの「新しいノート」ボタンを使用してノートを作成すると、ノートは <code>#inbox</code> ラベルでマークされたノートの子ノートとして作成されます。", | ||||
|     "workspace_inbox": "このワークスペースノートの祖先にホイストされた場合、新規ノートのデフォルトのinboxの場所", | ||||
|     "sql_console_home": "SQLコンソールノートのデフォルトの場所", | ||||
|     "bookmark_folder": "このラベルの付いたノートは、ブックマークにフォルダとして表示されます(子フォルダへのアクセスを許可します)", | ||||
|     "share_hidden_from_tree": "このノートは左側のナビゲーションツリーには表示されていませんが、URL からアクセスできます", | ||||
|     "share_external_link": "ノートは共有ツリー内で外部ウェブサイトへのリンクとして機能します", | ||||
|     "share_alias": "https://your_trilium_host/share/[your_alias] でノートを利用できるようにエイリアスを定義します", | ||||
|     "share_omit_default_css": "デフォルトの共有ページのCSSは省略されます。スタイルを大幅に変更する場合に使用してください。", | ||||
|     "share_root": "/share root で提供されるノートをマークする。", | ||||
|     "share_raw": "ノートはHTMLラッパーなしでそのままの形式で提供されます", | ||||
|     "share_disallow_robot_indexing": "<code>X-Robots-Tag: noindex</code> ヘッダーにより、このノートのロボットによるインデックス作成を禁止します", | ||||
|     "share_credentials": "この共有ノートにアクセスするには認証情報が必要です。値は「ユーザー名:パスワード」の形式である必要があります。子ノート/画像に適用するには、これを継承可能にすることを忘れないでください。", | ||||
|     "share_index": "このラベルの付いたノートには、共有ノートのルートがすべてリストされます", | ||||
|     "display_relations": "表示するリレーション名をカンマで区切って指定します。それ以外のリレーション名は非表示になります。", | ||||
|     "hide_relations": "非表示にするリレーション名をカンマで区切って指定します。それ以外のリレーションは表示されます。", | ||||
|     "template": "このノートは、新しいノートを作成するときに利用可能なテンプレートの選択肢に表示されます", | ||||
|     "toc": "<code>#toc</code> または <code>#toc=show</code><code> は目次を強制的に表示し、<code>#toc=hide</code> は目次を強制的に非表示にします。ラベルが存在しない場合は、グローバル設定が適用されます", | ||||
|     "color": "ノートツリー、リンクなどのノートの色を定義します。 'red' や #a13d5f などの有効な CSS カラー値を使用します", | ||||
|     "keyboard_shortcut": "このノートにすぐにジャンプするキーボードショートカットを定義します。例: 「ctrl+alt+e」。変更を有効にするには、フロントエンドをリロードする必要があります。", | ||||
|     "keep_current_hoisting": "このリンクを開いても、ノートが現在のホイストされたサブツリーに表示できない場合でも、ホイストは変更されません。", | ||||
|     "execute_button": "現在のコードノートを実行するボタンのタイトル", | ||||
|     "execute_description": "実行ボタンと一緒に表示される現在のコードノートの詳細な説明", | ||||
|     "exclude_from_note_map": "このラベルの付いたノートはノートマップから非表示になります", | ||||
|     "new_notes_on_top": "新しいノートは親ノートの下部ではなく上部に作成されます。", | ||||
|     "hide_highlight_widget": "ハイライトリスト ウィジェットを非表示にする", | ||||
|     "run_on_note_creation": "バックエンドでノートが作成された際に実行されます。特定のサブツリー配下に作成されたすべてのノートに対してスクリプトを実行したい場合は、このリレーションを使用してください。その場合は、サブツリーのルートノートにスクリプトを作成し、継承可能にしてください。サブツリー内(任意の深さ)に新しいノートが作成されると、スクリプトが実行されます。", | ||||
|     "run_on_child_note_creation": "このリレーションが定義されているノートの下に新しいノートが作成されたときに実行されます", | ||||
|     "render_note": "「HTMLノートをレンダリング」タイプのノートは、コードノート(HTMLまたはスクリプト)を使用してレンダリングされます。このリレーションを使用して、どのノートをレンダリングするかを指定する必要があります", | ||||
|     "other_notes_with_name": "{{attributeType}} の名前が「{{attributeName}}」であるその他のノート", | ||||
|     "color_type": "色" | ||||
|   }, | ||||
|   "link_context_menu": { | ||||
|     "open_note_in_popup": "クイックエディット", | ||||
| @@ -955,7 +1086,8 @@ | ||||
|     "open_note_in_new_window": "新しいウィンドウでノートを開く" | ||||
|   }, | ||||
|   "note_tooltip": { | ||||
|     "quick-edit": "クイックエディット" | ||||
|     "quick-edit": "クイックエディット", | ||||
|     "note-has-been-deleted": "ノートは削除されました。" | ||||
|   }, | ||||
|   "protect_note": { | ||||
|     "toggle-on": "ノートを保護", | ||||
| @@ -976,8 +1108,6 @@ | ||||
|   }, | ||||
|   "open-help-page": "ヘルプページを開く", | ||||
|   "shared_info": { | ||||
|     "shared_publicly": "このノートは一般公開されています", | ||||
|     "shared_locally": "このノートはローカルで共有されています", | ||||
|     "help_link": "ヘルプについては、<a href=\"https://triliumnext.github.io/Docs/Wiki/sharing.html\">wiki</a>をご覧ください。" | ||||
|   }, | ||||
|   "highlights_list_2": { | ||||
| @@ -1000,7 +1130,9 @@ | ||||
|     "automatically-collapse-notes-title": "一定期間使用されないと、ツリーを整理するためにノートは折りたたまれます。", | ||||
|     "save-changes": "変更を保存して適用", | ||||
|     "auto-collapsing-notes-after-inactivity": "非アクティブ状態が続いたためノートが自動で折りたたまれます...", | ||||
|     "create-child-note": "子ノートを作成" | ||||
|     "create-child-note": "子ノートを作成", | ||||
|     "hoist-this-note-workspace": "このノートをホイストする(ワークスペース)", | ||||
|     "unhoist": "ホイスト解除" | ||||
|   }, | ||||
|   "bulk_actions": { | ||||
|     "bulk_actions": "一括操作", | ||||
| @@ -1050,7 +1182,8 @@ | ||||
|     "reset": "リセット", | ||||
|     "move-to-visible-launchers": "可視ランチャーに移動", | ||||
|     "move-to-available-launchers": "利用可能なランチャーに移動", | ||||
|     "duplicate-launcher": "ランチャーの複製 <kbd data-command=\"duplicateSubtree\">" | ||||
|     "duplicate-launcher": "ランチャーの複製 <kbd data-command=\"duplicateSubtree\">", | ||||
|     "reset_launcher_confirm": "本当に「{{title}}」をリセットしますか? このノート(およびその子ノート)のすべてのデータと設定が失われ、ランチャーは元の場所に戻ります。" | ||||
|   }, | ||||
|   "editable-text": { | ||||
|     "auto-detect-language": "自動検出" | ||||
| @@ -1074,7 +1207,8 @@ | ||||
|     "editor_type": { | ||||
|       "label": "書式設定ツールバー", | ||||
|       "floating": { | ||||
|         "description": "編集ツールがカーソル付近に表示されます;" | ||||
|         "description": "編集ツールがカーソル付近に表示されます;", | ||||
|         "title": "フローティング" | ||||
|       }, | ||||
|       "fixed": { | ||||
|         "title": "固定", | ||||
| @@ -1105,7 +1239,9 @@ | ||||
|     "show_login_link_description": "共有ページの下部にログインリンクを追加", | ||||
|     "share_root_found": "共有ルートノート '{{noteTitle}}' の準備が完了", | ||||
|     "share_root_not_found": "#shareRoot のラベルが付いたノートが見つかりません", | ||||
|     "share_root_not_shared": "ノート '{{noteTitle}}' は #shareRoot のラベルを持っていますが、共有されていません" | ||||
|     "share_root_not_shared": "ノート '{{noteTitle}}' は #shareRoot のラベルを持っていますが、共有されていません", | ||||
|     "show_login_link": "共有テーマにログインリンクを表示する", | ||||
|     "check_share_root": "共有ルートのステータスを確認" | ||||
|   }, | ||||
|   "time_selector": { | ||||
|     "invalid_input": "入力された時間値が有効な数値ではありません。", | ||||
| @@ -1133,7 +1269,10 @@ | ||||
|   "cpu_arch_warning": { | ||||
|     "title": "ARM64版をダウンロードしてください", | ||||
|     "dont_show_again": "この警告を二度と表示しない", | ||||
|     "continue_anyway": "とにかく続ける" | ||||
|     "continue_anyway": "とにかく続ける", | ||||
|     "message_windows": "TriliumNext は現在エミュレーションを実行しています。つまり、ARM版WindowsデバイスでIntel(x64)版を使用していることになります。これはパフォーマンスとバッテリー寿命に重大な影響を及ぼします。", | ||||
|     "recommendation": "最適なエクスペリエンスを得るには、リリース ページから TriliumNext のネイティブ ARM64 バージョンをダウンロードしてください。", | ||||
|     "download_link": "ネイティブ版をダウンロード" | ||||
|   }, | ||||
|   "editorfeatures": { | ||||
|     "emoji_completion_enabled": "絵文字のオートコンプリートを有効", | ||||
| @@ -1229,7 +1368,9 @@ | ||||
|     "add_label": "ラベルを追加", | ||||
|     "label_name_placeholder": "ラベル名", | ||||
|     "label_name_title": "英数字、アンダーバー、コロンが使用可能な文字です。", | ||||
|     "new_value_placeholder": "新しい値" | ||||
|     "new_value_placeholder": "新しい値", | ||||
|     "help_text": "一致したすべてのノートに:", | ||||
|     "help_text_note": "このメソッドを値なしで呼び出すこともできます。その場合、ラベルは値なしでノートに割り当てられます。" | ||||
|   }, | ||||
|   "delete_label": { | ||||
|     "delete_label": "ラベルを削除", | ||||
| @@ -1249,12 +1390,14 @@ | ||||
|     "label_name_placeholder": "ラベル名", | ||||
|     "label_name_title": "英数字、アンダーバー、コロンが使用可能な文字です。", | ||||
|     "new_value_placeholder": "新しい値", | ||||
|     "help_text_note": "このメソッドは値なしで呼び出すこともできます。その場合、値なしでラベルがノートに割り当てられます。" | ||||
|     "help_text_note": "このメソッドは値なしで呼び出すこともできます。その場合、値なしでラベルがノートに割り当てられます。", | ||||
|     "help_text": "一致したすべてのノートで、既存のラベルの値を変更する。" | ||||
|   }, | ||||
|   "add_relation": { | ||||
|     "add_relation": "関係を追加", | ||||
|     "relation_name": "関係の名前", | ||||
|     "allowed_characters": "英数字、アンダーバー、コロンが使用可能な文字です。" | ||||
|     "allowed_characters": "英数字、アンダーバー、コロンが使用可能な文字です。", | ||||
|     "create_relation_on_all_matched_notes": "一致したすべてのノートに対して、指定されたリレーションを作成します。" | ||||
|   }, | ||||
|   "delete_relation": { | ||||
|     "delete_relation": "関係を削除", | ||||
| @@ -1272,7 +1415,8 @@ | ||||
|   "update_relation_target": { | ||||
|     "update_relation": "関係の更新", | ||||
|     "relation_name": "関係の名前", | ||||
|     "allowed_characters": "英数字、アンダーバー、コロンが使用可能な文字です。" | ||||
|     "allowed_characters": "英数字、アンダーバー、コロンが使用可能な文字です。", | ||||
|     "on_all_matched_notes": "一致したすべてのノートに" | ||||
|   }, | ||||
|   "revisions_button": { | ||||
|     "note_revisions": "ノートの変更履歴" | ||||
| @@ -1322,7 +1466,9 @@ | ||||
|     "specify_new_relation_name": "新しい関係の名前(使用可能な文字: 英数字、コロン、アンダースコア)を指定:", | ||||
|     "note_not_found": "ノート {{noteId}} が見つかりません!", | ||||
|     "enter_title_of_new_note": "新しいノートのタイトルを入力", | ||||
|     "default_new_note_title": "新しいノート" | ||||
|     "default_new_note_title": "新しいノート", | ||||
|     "cannot_match_transform": "変換を一致させることができません: {{transform}}", | ||||
|     "click_on_canvas_to_place_new_note": "キャンバスをクリックして新しいノートを配置" | ||||
|   }, | ||||
|   "database_anonymization": { | ||||
|     "title": "データベースの匿名化", | ||||
| @@ -1365,7 +1511,8 @@ | ||||
|     "label_year_comparison": "数値比較(>、>=、<も含む)。", | ||||
|     "label_date_created": "過去1ヶ月以内に作成されたノート", | ||||
|     "error": "検索エラー: {{error}}", | ||||
|     "search_prefix": "検索:" | ||||
|     "search_prefix": "検索:", | ||||
|     "placeholder": "全文 キーワード、#tag = value..." | ||||
|   }, | ||||
|   "delete_revisions": { | ||||
|     "delete_note_revisions": "ノートの変更履歴を削除", | ||||
| @@ -1379,7 +1526,8 @@ | ||||
|     "example_new_title": "<code>NEW: ${note.title}</code> - 一致したノートの名前の前に 'NEW: ' を付ける", | ||||
|     "example_date_prefix": "<code>${note.dateCreatedObj.format('MM-DD:')}: ${note.title}</code> - マッチしたノートの前にノートの作成月日を付ける", | ||||
|     "api_docs": "詳細については、 <a href='https://zadam.github.io/trilium/backend_api/Note.html'>note</a> および <a href='https://day.js.org/docs/en/display/format'>dateCreatedObj / utcDateCreatedObj properties</a> の API ドキュメントを参照してください。", | ||||
|     "evaluated_as_js_string": "与えられた値はJavaScript文字列として評価されるため、注入された<code>note</code>変数(noteは名前が変更されます)を介して動的なコンテンツで強化できます。例:" | ||||
|     "evaluated_as_js_string": "与えられた値はJavaScript文字列として評価されるため、注入された<code>note</code>変数(noteは名前が変更されます)を介して動的なコンテンツで強化できます。例:", | ||||
|     "click_help_icon": "右側のヘルプアイコンをクリックすると、すべてのオプションが表示されます" | ||||
|   }, | ||||
|   "electron_integration": { | ||||
|     "desktop-application": "デスクトップアプリケーション", | ||||
| @@ -1393,5 +1541,243 @@ | ||||
|   "zoom_factor": { | ||||
|     "description": "ズームは CTRL+- と CTRL+= のショートカットでも操作可能。", | ||||
|     "title": "ズーム倍率(デスクトップビルドのみ)" | ||||
|   }, | ||||
|   "jump_to_note": { | ||||
|     "search_placeholder": "名前またはタイプでノートを検索 > コマンドを検索...", | ||||
|     "search_button": "全文検索" | ||||
|   }, | ||||
|   "markdown_import": { | ||||
|     "dialog_title": "Markdownをインポート", | ||||
|     "modal_body_text": "ブラウザサンドボックスのため、JavaScriptからクリップボードの内容を直接読み込むことはできません。インポートするMarkdownを以下のテキストエリアに貼り付け、インポートボタンをクリックしてください", | ||||
|     "import_button": "インポート", | ||||
|     "import_success": "Markdown コンテンツがドキュメントにインポートされました。" | ||||
|   }, | ||||
|   "note_type_chooser": { | ||||
|     "change_path_prompt": "新しいノートを作成する場所を変更する:", | ||||
|     "search_placeholder": "名前によるパスの検索 (空の場合はデフォルト)", | ||||
|     "modal_title": "ノートタイプを選択", | ||||
|     "modal_body": "新しいノートのノートタイプ / テンプレートを選択してください:", | ||||
|     "templates": "テンプレート", | ||||
|     "builtin_templates": "組み込みテンプレート" | ||||
|   }, | ||||
|   "prompt": { | ||||
|     "title": "プロンプト", | ||||
|     "ok": "OK", | ||||
|     "defaultTitle": "プロンプト" | ||||
|   }, | ||||
|   "upload_attachments": { | ||||
|     "upload_attachments_to_note": "ノートに添付ファイルをアップロード", | ||||
|     "choose_files": "ファイルを選択", | ||||
|     "files_will_be_uploaded": "ファイルは {{noteTitle}} に添付ファイルとしてアップロードされます", | ||||
|     "options": "オプション", | ||||
|     "shrink_images": "画像を縮小", | ||||
|     "upload": "アップロード", | ||||
|     "tooltip": "このオプションにチェックを入れると、Trilium はアップロードされた画像をスケーリングと最適化によって縮小しようとします。これにより、画質が多少変化する可能性があります。チェックを外すと、画像は変更されずにアップロードされます。" | ||||
|   }, | ||||
|   "attribute_editor": { | ||||
|     "help_text_body1": "ラベルを追加するには、例 <code>#rock</code> と入力します。値も追加したい場合は、例 <code>#year = 2020</code> と入力します", | ||||
|     "help_text_body2": "リレーションについては、<code>~author = @</code> と入力すると、オートコンプリートが表示され、目的のノートを検索できるようになります。", | ||||
|     "placeholder": "ここにラベルとリレーションを入力" | ||||
|   }, | ||||
|   "move_note": { | ||||
|     "on_all_matched_notes": "一致したすべてのノートに" | ||||
|   }, | ||||
|   "onclick_button": { | ||||
|     "no_click_handler": "ボタン ウィジェット '{{componentId}}' にはクリック ハンドラーが定義されていません" | ||||
|   }, | ||||
|   "protected_session_status": { | ||||
|     "active": "保護されたセッションが有効です。クリックして保護されたセッションを終了します。", | ||||
|     "inactive": "クリックして保護されたセッションに入る" | ||||
|   }, | ||||
|   "editable_code": { | ||||
|     "placeholder": "ここにコードノートの内容を入力..." | ||||
|   }, | ||||
|   "editable_text": { | ||||
|     "placeholder": "ここにノートの内容を入力..." | ||||
|   }, | ||||
|   "empty": { | ||||
|     "open_note_instruction": "以下の入力欄にノートのタイトルを入力するか、ツリー内のノートを選択してノートを開きます。" | ||||
|   }, | ||||
|   "file": { | ||||
|     "too_big": "パフォーマンス上の理由により、プレビューではファイルの最初の {{maxNumChars}} 文字のみが表示されます。ファイル全体を表示するには、ファイルをダウンロードして外部で開いてください。" | ||||
|   }, | ||||
|   "protected_session": { | ||||
|     "enter_password_instruction": "保護されたノートを表示するにはパスワードを入力する必要があります:" | ||||
|   }, | ||||
|   "render": { | ||||
|     "note_detail_render_help_1": "このヘルプノートが表示されるのは、このノートの「HTML のレンダリング」タイプには、正常に機能するために必要なリレーションがないためです。" | ||||
|   }, | ||||
|   "consistency_checks": { | ||||
|     "find_and_fix_button": "一貫性の問題を見つけて修正する", | ||||
|     "finding_and_fixing_message": "一貫性の問題を見つけて修正中…" | ||||
|   }, | ||||
|   "vacuum_database": { | ||||
|     "title": "データベースのバキューム", | ||||
|     "description": "これによりデータベースが再構築され、通常はデータベースファイルのサイズが小さくなります。実際のデータは変更されません。", | ||||
|     "button_text": "データベースをバキューム", | ||||
|     "vacuuming_database": "データベースのバキュームを実行中...", | ||||
|     "database_vacuumed": "データベースのバキューム処理が完了しました" | ||||
|   }, | ||||
|   "ribbon": { | ||||
|     "promoted_attributes_message": "プロモート属性がノートに存在する場合、プロモート属性のリボンタブが自動的に開きます", | ||||
|     "edited_notes_message": "編集したノートのリボンタブは、dayノートで自動的に開きます" | ||||
|   }, | ||||
|   "ui-performance": { | ||||
|     "enable-motion": "トランジションとアニメーションを有効にする", | ||||
|     "enable-shadows": "影を有効にする", | ||||
|     "enable-backdrop-effects": "メニュー、ポップアップ、パネルの背景効果を有効にする" | ||||
|   }, | ||||
|   "code_mime_types": { | ||||
|     "title": "ドロップダウンで利用可能なMIMEタイプ" | ||||
|   }, | ||||
|   "attachment_erasure_timeout": { | ||||
|     "attachment_erasure_timeout": "添付ファイル消去のタイムアウト", | ||||
|     "attachment_auto_deletion_description": "定義されたタイムアウト後にノートによって参照されなくなった場合、添付ファイルは自動的に削除 (および消去) されます。", | ||||
|     "erase_attachments_after": "使用されていない添付ファイルを消去する期間:", | ||||
|     "manual_erasing_description": "手動で消去をトリガーすることもできます (上記で定義したタイムアウトを考慮せずに):", | ||||
|     "erase_unused_attachments_now": "使用されていない添付ノートを今すぐ消去", | ||||
|     "unused_attachments_erased": "使用されていない添付ファイルは削除されました。" | ||||
|   }, | ||||
|   "network_connections": { | ||||
|     "network_connections_title": "ネットワーク接続", | ||||
|     "check_for_updates": "アップデートを自動的に確認する" | ||||
|   }, | ||||
|   "note_erasure_timeout": { | ||||
|     "note_erasure_timeout_title": "ノート消去のタイムアウト", | ||||
|     "note_erasure_description": "削除されたノート(および属性、変更履歴など)最初は削除済みとしてマークされるだけで、「最近の変更」ダイアログから復元できます。一定期間が経過すると、削除されたノートは「消去」され、内容は復元できなくなります。この設定では、ノートを削除してから消去するまでの期間を設定できます。", | ||||
|     "erase_notes_after": "ノートを消去する間隔:", | ||||
|     "manual_erasing_description": "手動で消去をトリガーすることもできます (上記で定義したタイムアウトを考慮せずに):", | ||||
|     "erase_deleted_notes_now": "削除したノートを今すぐ消去", | ||||
|     "deleted_notes_erased": "削除されたノートは消去されました。" | ||||
|   }, | ||||
|   "revisions_snapshot_interval": { | ||||
|     "note_revisions_snapshot_interval_title": "ノートの変更履歴の記録間隔", | ||||
|     "note_revisions_snapshot_description": "ノートの変更履歴の記録間隔は、そのノートに対して新しい変更が作成されるまでの時間です。詳細については、<doc>wiki</doc> をご覧ください。", | ||||
|     "snapshot_time_interval_label": "ノートの変更履歴が記憶される時間:" | ||||
|   }, | ||||
|   "revisions_snapshot_limit": { | ||||
|     "note_revisions_snapshot_limit_title": "ノートの変更履歴の記録制限", | ||||
|     "note_revisions_snapshot_limit_description": "ノートの変更履歴の記録制限とは、各ノートに保存できる変更履歴の最大数を指します。-1 は制限なし、0 はすべての変更履歴を削除することを意味します。#versioningLimit ラベルを使用して、1 つのノートの最大変更数を設定できます。", | ||||
|     "snapshot_number_limit_label": "ノートの変更履歴の記録数の制限:", | ||||
|     "snapshot_number_limit_unit": "スナップショット", | ||||
|     "erase_excess_revision_snapshots": "余分な変更履歴を今すぐ消去", | ||||
|     "erase_excess_revision_snapshots_prompt": "余分な変更履歴が消去されました。" | ||||
|   }, | ||||
|   "editability_select": { | ||||
|     "note_is_read_only": "ノートは読み取り専用ですが、ボタンをクリックすると編集できます。" | ||||
|   }, | ||||
|   "find": { | ||||
|     "case_sensitive": "大文字と小文字を区別", | ||||
|     "match_words": "単語が一致", | ||||
|     "find_placeholder": "テキスト内を検索...", | ||||
|     "replace_placeholder": "置換対象...", | ||||
|     "replace": "置換", | ||||
|     "replace_all": "すべて置換" | ||||
|   }, | ||||
|   "title_bar_buttons": { | ||||
|     "window-on-top": "ウィンドウを最前面に維持" | ||||
|   }, | ||||
|   "note_detail": { | ||||
|     "could_not_find_typewidget": "タイプ {{type}} の typeWidget が見つかりませんでした" | ||||
|   }, | ||||
|   "watched_file_update_status": { | ||||
|     "ignore_this_change": "この変更を無視する" | ||||
|   }, | ||||
|   "image": { | ||||
|     "copied-to-clipboard": "画像への参照がクリップボードにコピーされました。これは任意のテキストノートに貼り付けることができます。", | ||||
|     "cannot-copy": "画像参照をクリップボードにコピーできませんでした。" | ||||
|   }, | ||||
|   "entrypoints": { | ||||
|     "note-revision-created": "ノートの改訂版が作成されました。", | ||||
|     "sql-error": "SQL クエリの実行中にエラーが発生しました: {{message}}" | ||||
|   }, | ||||
|   "branches": { | ||||
|     "cannot-move-notes-here": "ここにノートを移動することはできません。", | ||||
|     "delete-status": "ステータスを削除", | ||||
|     "delete-notes-in-progress": "削除進行中のノート: {{count}}", | ||||
|     "delete-finished-successfully": "削除が正常に完了しました。", | ||||
|     "undeleting-notes-in-progress": "削除済みのノートを復元中: {{count}}", | ||||
|     "undeleting-notes-finished-successfully": "ノートの復元が正常に完了しました。" | ||||
|   }, | ||||
|   "frontend_script_api": { | ||||
|     "async_warning": "`api.runOnBackend()` に非同期関数を渡していますが、これは意図したとおりに動作しない可能性があります。\\n関数を同期させる(`async` キーワードを削除する)か、`api.runAsyncOnBackendWithManualTransactionHandling()` を使用してください。", | ||||
|     "sync_warning": "`api.runAsyncOnBackendWithManualTransactionHandling()` に同期関数を渡していますが、\\n代わりに `api.runOnBackend()` を使用する必要がある可能性があります。" | ||||
|   }, | ||||
|   "ws": { | ||||
|     "sync-check-failed": "同期チェックに失敗しました!", | ||||
|     "consistency-checks-failed": "整合性チェックに失敗しました! 詳細はログを参照してください。", | ||||
|     "encountered-error": "エラー「{{message}}」が発生しました。コンソールを確認してください。" | ||||
|   }, | ||||
|   "hoisted_note": { | ||||
|     "confirm_unhoisting": "要求されたノート「{{requestedNote}}」は、ホイストされたノート「{{hoistedNote}}」サブツリーの外部にあるため、ノートにアクセスするにはホイストを解除する必要があります。ホイスト解除を続行しますか?" | ||||
|   }, | ||||
|   "image_context_menu": { | ||||
|     "copy_reference_to_clipboard": "参照をクリップボードにコピー", | ||||
|     "copy_image_to_clipboard": "画像をクリップボードにコピー" | ||||
|   }, | ||||
|   "note_autocomplete": { | ||||
|     "search-for": "「{{term}}」を検索", | ||||
|     "create-note": "子ノート「{{term}}」を作成してリンクする", | ||||
|     "insert-external-link": "「{{term}}」への外部リンクを挿入", | ||||
|     "clear-text-field": "テキストフィールドを消去", | ||||
|     "show-recent-notes": "最近のノートを表示", | ||||
|     "full-text-search": "全文検索" | ||||
|   }, | ||||
|   "geo-map": { | ||||
|     "create-child-note-title": "新しい子ノートを作成し、マップに追加する", | ||||
|     "create-child-note-instruction": "地図をクリックしてその場所に新しいノートを作成するか、Esc キーを押して閉じます。", | ||||
|     "unable-to-load-map": "マップを読み込めません。" | ||||
|   }, | ||||
|   "geo-map-context": { | ||||
|     "open-location": "現在位置を表示", | ||||
|     "remove-from-map": "マップから削除", | ||||
|     "add-note": "この場所にマーカーを追加" | ||||
|   }, | ||||
|   "help-button": { | ||||
|     "title": "関連するヘルプページを開く" | ||||
|   }, | ||||
|   "content_widget": { | ||||
|     "unknown_widget": "「{{id}}」のウィジェットは不明です。" | ||||
|   }, | ||||
|   "switch_layout_button": { | ||||
|     "title_vertical": "編集パネルを下に移動", | ||||
|     "title_horizontal": "編集パネルを左に移動" | ||||
|   }, | ||||
|   "toggle_read_only_button": { | ||||
|     "unlock-editing": "編集のロックを解除", | ||||
|     "lock-editing": "編集をロック" | ||||
|   }, | ||||
|   "book_properties_config": { | ||||
|     "hide-weekends": "週末を非表示", | ||||
|     "display-week-numbers": "週番号を表示", | ||||
|     "map-style": "マップスタイル:", | ||||
|     "max-nesting-depth": "最大階層の深さ:", | ||||
|     "show-scale": "スケールを表示" | ||||
|   }, | ||||
|   "call_to_action": { | ||||
|     "next_theme_title": "新しいTriliumテーマをお試しください", | ||||
|     "next_theme_message": "現在、レガシーテーマを使用しています。新しいテーマを試してみませんか?", | ||||
|     "next_theme_button": "新しいテーマを試す", | ||||
|     "background_effects_title": "背景効果が安定しました", | ||||
|     "background_effects_message": "Windowsデバイスでは、背景効果が完全に安定しました。背景効果は、背景をぼかすことでユーザーインターフェースに彩りを添えます。この技術は、Windowsエクスプローラーなどの他のアプリケーションでも使用されています。", | ||||
|     "background_effects_button": "背景効果を有効にする", | ||||
|     "dismiss": "却下" | ||||
|   }, | ||||
|   "settings": { | ||||
|     "related_settings": "関連設定" | ||||
|   }, | ||||
|   "settings_appearance": { | ||||
|     "related_code_blocks": "テキストノート内のコードブロックの配色", | ||||
|     "related_code_notes": "コードノートの配色" | ||||
|   }, | ||||
|   "units": { | ||||
|     "percentage": "%" | ||||
|   }, | ||||
|   "pagination": { | ||||
|     "page_title": "{{startIndex}} - {{endIndex}} ページ", | ||||
|     "total_notes": "{{count}} ノート" | ||||
|   }, | ||||
|   "collections": { | ||||
|     "rendering_error": "エラーのためコンテンツを表示できません。" | ||||
|   } | ||||
| } | ||||
|   | ||||
							
								
								
									
										37
									
								
								apps/client/src/translations/ko/translation.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								apps/client/src/translations/ko/translation.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,37 @@ | ||||
| { | ||||
|   "about": { | ||||
|     "title": "Trilium Notes에 대해서", | ||||
|     "homepage": "홈페이지:", | ||||
|     "app_version": "앱 버전:", | ||||
|     "db_version": "DB 버전:", | ||||
|     "sync_version": "동기화 버전:", | ||||
|     "build_date": "빌드 날짜:", | ||||
|     "build_revision": "빌드 리비전:", | ||||
|     "data_directory": "데이터 경로:" | ||||
|   }, | ||||
|   "toast": { | ||||
|     "critical-error": { | ||||
|       "title": "심각한 오류", | ||||
|       "message": "클라이언트 애플리케이션 시작 도중 심각한 오류가 발생했습니다:\n\n{{message}}\n\n이는 스크립트가 예기치 않게 실패하면서 발생한 것일 수 있습니다. 애플리케이션을 안전 모드로 시작한 뒤 문제를 해결해 보세요." | ||||
|     }, | ||||
|     "widget-error": { | ||||
|       "title": "위젯 초기화 실패", | ||||
|       "message-custom": "ID가 \"{{id}}\"고 ,제목이 \"{{title}}\" 인 노트에서 사용자 지정 위젯을 초기화 하는데 실패했습니다:\n\n{{message}}", | ||||
|       "message-unknown": "알 수 없는 위젯이 초기화 하는데 실패했습니다:\n\n{{message}}" | ||||
|     }, | ||||
|     "bundle-error": { | ||||
|       "title": "사용자 정의 스크립트를 불러오는데 실패했습니다", | ||||
|       "message": "ID가 \"{{id}}\"고, 제목이 \"{{title}}\"인 노트에서 스크립트가 실행되지 못했습니다:\n\n{{message}}" | ||||
|     } | ||||
|   }, | ||||
|   "add_link": { | ||||
|     "add_link": "링크 추가", | ||||
|     "note": "노트", | ||||
|     "search_note": "이름으로 노트 검색하기", | ||||
|     "help_on_links": "링크 관련 도움말", | ||||
|     "link_title_mirrors": "링크 제목은 노트의 현재 제목을 반영합니다" | ||||
|   }, | ||||
|   "branch_prefix": { | ||||
|     "save": "저장" | ||||
|   } | ||||
| } | ||||
							
								
								
									
										70
									
								
								apps/client/src/translations/nl/translation.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										70
									
								
								apps/client/src/translations/nl/translation.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,70 @@ | ||||
| { | ||||
|   "about": { | ||||
|     "title": "Over Trilium Notes", | ||||
|     "homepage": "Homepagina:", | ||||
|     "app_version": "App versie:", | ||||
|     "db_version": "DB Versie:", | ||||
|     "sync_version": "Sync Versie:", | ||||
|     "build_date": "Build datum:", | ||||
|     "build_revision": "Build revisie:", | ||||
|     "data_directory": "Gegevensmap:" | ||||
|   }, | ||||
|   "toast": { | ||||
|     "critical-error": { | ||||
|       "title": "Kritische Error", | ||||
|       "message": "Een kritieke fout heeft plaatsgevonden waardoor de cliënt zich aanmeldt vanaf het begin:\n\n84X\n\nDit is waarschijnlijk veroorzaakt door een script dat op een onverwachte manier faalt. Probeer de sollicitatie in veilige modus te starten en de kwestie aan te spreken." | ||||
|     } | ||||
|   }, | ||||
|   "add_link": { | ||||
|     "add_link": "Voeg link toe", | ||||
|     "help_on_links": "Hulp bij links", | ||||
|     "note": "notitie", | ||||
|     "search_note": "zoek voor notitie op naam", | ||||
|     "link_title_mirrors": "De link titel is hetzelfde als de notitie's huidige titel", | ||||
|     "link_title": "Link titel", | ||||
|     "button_add_link": "Link toevoegen" | ||||
|   }, | ||||
|   "branch_prefix": { | ||||
|     "edit_branch_prefix": "Bewerk branch prefix", | ||||
|     "save": "Opslaan", | ||||
|     "branch_prefix_saved": "Branch prefix is opgeslagen.", | ||||
|     "help_on_tree_prefix": "Help bij boomvoorvoegsel", | ||||
|     "prefix": "Voorvoegsel: " | ||||
|   }, | ||||
|   "bulk_actions": { | ||||
|     "bulk_actions": "Bulk acties", | ||||
|     "affected_notes": "Getroffen notities", | ||||
|     "available_actions": "Beschikbare acties", | ||||
|     "chosen_actions": "Kies acties", | ||||
|     "execute_bulk_actions": "Bulk acties uitvoeren", | ||||
|     "bulk_actions_executed": "Bulk acties zijn succesvol uitgevoerd.", | ||||
|     "none_yet": "Nog niks... voeg een actie toe door een van de beschikbare bovenstaande opties te klikken.", | ||||
|     "labels": "Labels", | ||||
|     "relations": "Relaties", | ||||
|     "notes": "Notities", | ||||
|     "other": "Andere" | ||||
|   }, | ||||
|   "calendar": { | ||||
|     "april": "April", | ||||
|     "may": "Mei", | ||||
|     "june": "Juni", | ||||
|     "july": "Juli", | ||||
|     "august": "Augustus", | ||||
|     "september": "September", | ||||
|     "october": "Oktober", | ||||
|     "november": "November", | ||||
|     "december": "December" | ||||
|   }, | ||||
|   "close_pane_button": { | ||||
|     "close_this_pane": "Sluit dit paneel" | ||||
|   }, | ||||
|   "create_pane_button": { | ||||
|     "create_new_split": "Maak nieuwe split" | ||||
|   }, | ||||
|   "edit_button": { | ||||
|     "edit_this_note": "Notitie bewerken" | ||||
|   }, | ||||
|   "show_toc_widget_button": { | ||||
|     "show_toc": "Laat Inhoudsopgave zien" | ||||
|   } | ||||
| } | ||||
| @@ -13,29 +13,622 @@ | ||||
|     "critical-error": { | ||||
|       "title": "Błąd krytyczny", | ||||
|       "message": "Wystąpił krytyczny błąd uniemożliwiający uruchomienie aplikacji:\n\n{{message}}\n\nJest to spowodowane najprawdopodobniej niespodziewanym błędem skryptu. Spróbuj uruchomić aplikację ponownie w trybie bezpiecznym i zaadresuj problem." | ||||
|     }, | ||||
|     "widget-error": { | ||||
|       "title": "Nie udało się zainicjować widżetu", | ||||
|       "message-custom": "Niestandardowy widżet z notatki o identyfikatorze \"{{id}}\", i tytule \"{{title}}\" nie mógł zostać zainicjowany z powodu:\n\n{{message}}", | ||||
|       "message-unknown": "Nieznany widżet nie mógł być zainicjowany z powodu:\n\n{{message}}" | ||||
|     }, | ||||
|     "bundle-error": { | ||||
|       "title": "Nie udało się załadować niestandardowego skryptu", | ||||
|       "message": "Skrypt z notatki o identyfikatorze \"{{id}}\", tytule \"{{title}}: nie został uruchomiony z powodu:\n\n{{message}}" | ||||
|     } | ||||
|   }, | ||||
|   "add_link": { | ||||
|     "add_link": "Dodaj link" | ||||
|     "add_link": "Dodaj link", | ||||
|     "note": "Notatka", | ||||
|     "search_note": "Wyszukaj notatkę po nazwie", | ||||
|     "link_title_arbitrary": "Tytuł linku można dowolnie zmieniać", | ||||
|     "link_title": "Tytuł linku", | ||||
|     "button_add_link": "Dodaj link", | ||||
|     "help_on_links": "Pomoc dotycząca linków", | ||||
|     "link_title_mirrors": "tytuł linku odzwierciedla tytuł obecnej notatki" | ||||
|   }, | ||||
|   "branch_prefix": { | ||||
|     "save": "Zapisz" | ||||
|     "save": "Zapisz", | ||||
|     "edit_branch_prefix": "Edytuj prefiks gałęzi", | ||||
|     "prefix": "Prefiks: ", | ||||
|     "branch_prefix_saved": "Zapisano prefiks gałęzi.", | ||||
|     "help_on_tree_prefix": "Pomoc dotycząca prefiksu drzewa" | ||||
|   }, | ||||
|   "bulk_actions": { | ||||
|     "labels": "Etykiety", | ||||
|     "notes": "Notatki", | ||||
|     "other": "Inne", | ||||
|     "relations": "Powiązania" | ||||
|     "relations": "Powiązania", | ||||
|     "bulk_actions": "Działania zbiorcze", | ||||
|     "include_descendants": "Uwzględnia rozwinięcia wybranych notatek", | ||||
|     "available_actions": "Dostępne działania", | ||||
|     "chosen_actions": "Wybrane działania", | ||||
|     "execute_bulk_actions": "Wykonaj zbiór działań", | ||||
|     "bulk_actions_executed": "Zbiór działań został wykonany prawidłowo.", | ||||
|     "none_yet": "Brak zaznaczonych działań... dodaj działanie poprzez kliknięcie jednej z dostępnych opcji powyżej.", | ||||
|     "affected_notes": "Dotyczy notatek" | ||||
|   }, | ||||
|   "confirm": { | ||||
|     "ok": "OK", | ||||
|     "cancel": "Anuluj" | ||||
|     "cancel": "Anuluj", | ||||
|     "confirmation": "Potwierdzenie", | ||||
|     "are_you_sure_remove_note": "Czy napewno chcesz usunąć notatkę \"{{title}}\" z mapy powiązań? ", | ||||
|     "if_you_dont_check": "Jeśli nie zaznaczysz tej opcji, notatka zostanie usunięta jedynie z mapy powiązań.", | ||||
|     "also_delete_note": "Usuń dodatkowo notatkę" | ||||
|   }, | ||||
|   "delete_notes": { | ||||
|     "cancel": "Anuluj", | ||||
|     "close": "Zamknij" | ||||
|     "close": "Zamknij", | ||||
|     "delete_notes_preview": "Usuń podgląd notatek", | ||||
|     "delete_all_clones_description": "Usuń również wszystkie sklonowania (działanie może zostać cofnięte w ostatnich zmianach)", | ||||
|     "erase_notes_description": "Normalne (miękkie) usuwanie zaznacza jedynie notatki jako usunięte i można je przywrócić (w oknie dialogowym ostatnich zmian) przez wyznaczony okres czasu. Zaznaczenie tej opcji spowoduje natychmiastowe usunięcie notatek, bez możliwości ich przywrócenia.", | ||||
|     "erase_notes_warning": "Usuń notatki permanentnie (bez opcji ich przywrócenia), włączając wszystkie kopie. Działanie to wymaga ponownego uruchomienia aplikacji.", | ||||
|     "notes_to_be_deleted": "Następujące notatki zostaną usunięte ({{notesCount}})", | ||||
|     "no_note_to_delete": "Żadne notatki nie zostaną usunięte (jedynie kopie).", | ||||
|     "broken_relations_to_be_deleted": "Następujące powiązania zostaną uszkodzone i usunięte ({{ relationCount}})", | ||||
|     "ok": "OK", | ||||
|     "deleted_relation_text": "Notatka {{- note}} (do usunięcia) jest powiązana przez relację {{- relation}} pochodzącą z {{- source}}." | ||||
|   }, | ||||
|   "export": { | ||||
|     "close": "Zamknij" | ||||
|     "close": "Zamknij", | ||||
|     "export_note_title": "Eksportuj notatkę", | ||||
|     "export_type_subtree": "Ta notatka oraz wszystkie podrzędne", | ||||
|     "format_html": "HTML - rekomendowany jako zachowujący całość formatowania", | ||||
|     "format_html_zip": "HTML w archiwum ZIP - rekomendowany jako zachowujący całość formatowania.", | ||||
|     "format_markdown": "Markdown - zachowuje większość formatowania.", | ||||
|     "format_opml": "OPML - format wymiany danych dla outlinerów zawierający tylko tekst. Formatowanie, obrazy i pliki nie są uwzględnione.", | ||||
|     "opml_version_1": "OPML v1.0 - tylko zwykły tekst", | ||||
|     "opml_version_2": "OPML v2.0 - umożliwia również HTML", | ||||
|     "export_type_single": "Tylko ta notatka, bez elementów podrzędnych", | ||||
|     "export": "Eksportuj", | ||||
|     "choose_export_type": "Wybierz najpierw rodzaj pliku do eksportu", | ||||
|     "export_status": "Status eksportu", | ||||
|     "export_in_progress": "Postęp eksportowania: {{progressCount}}", | ||||
|     "export_finished_successfully": "Eksportowanie zakończone.", | ||||
|     "format_pdf": "PDF - w celu drukowania lub udostępniania." | ||||
|   }, | ||||
|   "clone_to": { | ||||
|     "clone_notes_to": "Sklonuj notatki do...", | ||||
|     "notes_to_clone": "Notatki do sklonowania", | ||||
|     "search_for_note_by_its_name": "Wyszukaj notatkę po jej nazwie", | ||||
|     "cloned_note_prefix_title": "Sklonowana notatka zostanie wyświetlona w drzewie notatki z podanym prefiksem", | ||||
|     "prefix_optional": "Prefiks (opcjonalne)", | ||||
|     "clone_to_selected_note": "Sklonuj do wybranej notatki", | ||||
|     "no_path_to_clone_to": "Brak ścieżki do sklonowania.", | ||||
|     "note_cloned": "Notatka \"{{clonedTitle}}\" została sklonowana do \"{{targetTitle}}\"", | ||||
|     "help_on_links": "Pomoc dotycząca linków", | ||||
|     "target_parent_note": "Docelowa główna notatka" | ||||
|   }, | ||||
|   "help": { | ||||
|     "title": "Ściągawka", | ||||
|     "noteNavigation": "Nawigacja po notatkach", | ||||
|     "goUpDown": "przewijanie w górę/w dół w liście notatek", | ||||
|     "collapseExpand": "zwiń/rozwiń zbiór", | ||||
|     "notSet": "niezdefiniowany", | ||||
|     "goBackForwards": "przewijaj do tyłu/do przodu w historii", | ||||
|     "showJumpToNoteDialog": "pokaż <a class=\"external\" href=\"https://triliumnext.github.io/Docs/Wiki/note-navigation.html#jump-to-note\">\"przejdź do dialogu</a>", | ||||
|     "scrollToActiveNote": "przewiń do aktywnej notatki", | ||||
|     "jumpToParentNote": "przejdź do głównej notatki", | ||||
|     "collapseWholeTree": "zwiń całe drzewko notatki", | ||||
|     "collapseSubTree": "zwiń gałąź notatki", | ||||
|     "tabShortcuts": "Skóry kart", | ||||
|     "newTabNoteLink": "link notatki otwiera notatkę w nowej karcie", | ||||
|     "newTabWithActivationNoteLink": "link notatki otwiera i aktywuje notatkę w nowej karcie", | ||||
|     "onlyInDesktop": "Tylko na komputerze stacjonarnym (wersja Electron)", | ||||
|     "openEmptyTab": "Otwórz pustą kartę", | ||||
|     "closeActiveTab": "zamknij aktywną kartę", | ||||
|     "activateNextTab": "aktywuj następną kartę", | ||||
|     "activatePreviousTab": "aktywuj poprzednią kartę", | ||||
|     "creatingNotes": "Tworzenie notatek", | ||||
|     "createNoteAfter": "Utwórz nową notatkę obok obecnie aktywnej", | ||||
|     "createNoteInto": "Utwórz nową podnotatkę w obecnie otwartej", | ||||
|     "editBranchPrefix": "edytuj <a class=\"external\" href=\"https://triliumnext.github.io/Docs/Wiki/tree-concepts.html#prefix\">prefiks</a> aktywnej kopii notatki", | ||||
|     "movingCloningNotes": "Przenoszenie / kopiowanie notatek", | ||||
|     "moveNoteUpDown": "Przenieś notatkę w górę/w dół na liście notatek", | ||||
|     "moveNoteUpHierarchy": "Przenieś notatkę w górę w hierarchii", | ||||
|     "multiSelectNote": "Zaznacz wiele notatek powyżej/poniżej", | ||||
|     "selectAllNotes": "Wybierz wszystkie notatki na obecnym poziomie", | ||||
|     "selectNote": "Wybierz notatkę", | ||||
|     "copyNotes": "skopiuj obecną notatkę (lub obecną sekcję) do schowka (zastosowanie dla<a class=\"external\" href=\"https://triliumnext.github.io/Docs/Wiki/cloning-notes.html#cloning-notes\">klonowania</a>)", | ||||
|     "cutNotes": "przytnij obecną notatkę (lub obecną sekcję) do schowka (zastosowanie dla przenoszenia notatek)", | ||||
|     "pasteNotes": "wklej notatkę jako podnotatka w obecnej notatce (rozumiane jako przenieś lub skopiuj, w zależności czy notatka była skopiowana czy wycięta)", | ||||
|     "deleteNotes": "usuń notatkę / gałąź", | ||||
|     "editingNotes": "Edytowanie notatek", | ||||
|     "other": "Inne", | ||||
|     "editNoteTitle": "W panelu drzewa nastąpi przejście z panelu drzewa do tytułu notatki. Naciśnięcie klawisza Enter w tytule notatki spowoduje przejście do edytora tekstu. <kbd>Ctrl+.</kbd> spowoduje powrót z edytora do panelu drzewa.", | ||||
|     "createEditLink": "stwórz / edytuj zewnętrzny link", | ||||
|     "createInternalLink": "stwórz wewnętrzny link", | ||||
|     "followLink": "kliknij link pod kursorem", | ||||
|     "insertDateTime": "wstaw aktualną datę i godzinę w pozycji kursora", | ||||
|     "markdownAutoformat": "Autoformatowanie w stylu Markdown", | ||||
|     "headings": "<code>##</code>, <code>###</code>, <code>####</code> itd., po których następuje miejsce na nagłówki", | ||||
|     "bulletList": "<code>*</code> lub <code>-</code>, a następnie spacja, aby utworzyć listę", | ||||
|     "jumpToTreePane": "przejdź do panelu drzewa i przewiń do aktywnej notatki", | ||||
|     "numberedList": "<code>1.</code> or <code>1)</code> po którym następuje miejsce na listę numerowaną", | ||||
|     "blockQuote": "zacznij linijkę od <code></code> aby po kliknięciu spacji dodać blok cytatu", | ||||
|     "troubleshooting": "Rozwiązywanie błędów", | ||||
|     "reloadFrontend": "Załaduj ponownie Frontend Trilium", | ||||
|     "showDevTools": "pokaż narzędzia deweloperskie", | ||||
|     "showSQLConsole": "pokaż konsolę SQL", | ||||
|     "quickSearch": "skup się na szybkim wyszukiwaniu", | ||||
|     "inPageSearch": "wyszukiwanie wewnątrz strony" | ||||
|   }, | ||||
|   "book_properties": { | ||||
|     "list": "Lista" | ||||
|   }, | ||||
|   "board_view": { | ||||
|     "move-to": "Przenieś do", | ||||
|     "insert-above": "Umieść nad", | ||||
|     "insert-below": "Umieść pod", | ||||
|     "delete-column": "Usuń kolumnę", | ||||
|     "delete-column-confirmation": "Czy na pewno chcesz usunąć tę kolumnę? Odpowiedni atrybut zostanie również usunięty w notatkach pod tą kolumną.", | ||||
|     "new-item": "Nowy element", | ||||
|     "new-item-placeholder": "Wpisz tytuł notatki...", | ||||
|     "add-column": "Dodaj kolumnę", | ||||
|     "add-column-placeholder": "Wpisz tytuł kolumny...", | ||||
|     "edit-note-title": "Naciśnij aby edytować tytuł notatki", | ||||
|     "edit-column-title": "Naciśnij aby edytować tytuł kolumny", | ||||
|     "delete-note": "Usuń notatkę...", | ||||
|     "remove-from-board": "Usuń z tablicy", | ||||
|     "archive-note": "Archiwalna notatka", | ||||
|     "unarchive-note": "Usuń notatkę z archiwum" | ||||
|   }, | ||||
|   "command_palette": { | ||||
|     "tree-action-name": "Drzewo: {{name}}", | ||||
|     "export_note_title": "Wyeksportuj notatkę", | ||||
|     "export_note_description": "Wyeksportuj aktualną notatkę", | ||||
|     "show_attachments_title": "Pokaż załączniki", | ||||
|     "show_attachments_description": "Zobacz załączniki notatki", | ||||
|     "search_notes_title": "Szukaj notatek", | ||||
|     "search_notes_description": "Otwórz zaawansowane wyszukiwanie", | ||||
|     "search_subtree_title": "Poszukaj w poddrzewie", | ||||
|     "search_subtree_description": "poszukaj wewnątrz poddrzewa", | ||||
|     "search_history_title": "Pokaż historię wyszukiwania", | ||||
|     "search_history_description": "Pokaż poprzednie wyszukiwania", | ||||
|     "configure_launch_bar_title": "Ustaw Launch Bar", | ||||
|     "configure_launch_bar_description": "Otwórz konfigurację Launch Bar, aby dodać lub usunąć elementy." | ||||
|   }, | ||||
|   "content_renderer": { | ||||
|     "open_externally": "Otwórz zewnętrznie" | ||||
|   }, | ||||
|   "modal": { | ||||
|     "close": "Zamknij", | ||||
|     "help_title": "Pokaż więcej informacji na temat tego ekranu" | ||||
|   }, | ||||
|   "call_to_action": { | ||||
|     "next_theme_title": "Spróbuj nowy motyw Trilium", | ||||
|     "next_theme_message": "Obecnie używasz starszego motywu. Czy chcesz wypróbować nowy motyw?", | ||||
|     "next_theme_button": "Spróbuj nowego motywu", | ||||
|     "background_effects_title": "Efekty w tle są już stabilne", | ||||
|     "dismiss": "Odrzuć", | ||||
|     "background_effects_button": "Włącz efekty w tle" | ||||
|   }, | ||||
|   "settings": { | ||||
|     "related_settings": "Powiązane ustawienia" | ||||
|   }, | ||||
|   "settings_appearance": { | ||||
|     "related_code_blocks": "Schemat kolorów dla bloków kodu w notatkach tekstowych", | ||||
|     "related_code_notes": "Schemat kolorów dla kodu" | ||||
|   }, | ||||
|   "units": { | ||||
|     "percentage": "%" | ||||
|   }, | ||||
|   "pagination": { | ||||
|     "page_title": "Strony:{{startIndex}}-{{endIndex}}", | ||||
|     "total_notes": "{{count}}notatek" | ||||
|   }, | ||||
|   "collections": { | ||||
|     "rendering_error": "Błąd - Nie można pokazać treści." | ||||
|   }, | ||||
|   "add_label": { | ||||
|     "add_label": "Dodaj etykietę", | ||||
|     "label_name_placeholder": "Nazwa etykiety", | ||||
|     "label_name_title": "Dozwolone są znaki alfanumeryczne, podkreślenie i dwukropek.", | ||||
|     "to_value": "do wartości", | ||||
|     "new_value_placeholder": "nowa wartość", | ||||
|     "help_text": "We wszystkich dopasowanych notatkach:", | ||||
|     "help_text_item2": "albo zmień wartość istniejącej etykiety" | ||||
|   }, | ||||
|   "attribute_detail": { | ||||
|     "delete": "Usuń", | ||||
|     "related_notes_title": "Inne notatki z tą etykietą", | ||||
|     "more_notes": "Więcej notatek", | ||||
|     "label": "Szczegóły etykiety", | ||||
|     "label_definition": "Szczegóły definicji etykiety", | ||||
|     "relation": "Szczegóły powiązania", | ||||
|     "relation_definition": "Szczegóły definicji powiązania", | ||||
|     "disable_versioning": "Wyłącza automatyczne wersjonowanie. Przydatne np. w przypadku dużych, ale nieistotnych notatek – np. dużych bibliotek JS używanych do skryptów", | ||||
|     "precision": "Prezycja", | ||||
|     "digits": "znaki", | ||||
|     "inverse_relation_title": "Opcjonalne ustawienie definiujące, do której relacji jest ta relacja przeciwna. Przykład: Główna - podnotatka są relacjami odwrotnymi do siebie.", | ||||
|     "inverse_relation": "Odwrócone powiązanie" | ||||
|   }, | ||||
|   "import": { | ||||
|     "importIntoNote": "Importuj do notatki", | ||||
|     "chooseImportFile": "Wybierz plik do zaimportowania", | ||||
|     "importDescription": "Zawartość wybranego pliku(ów) zostanie zaimportowana jako notatka(i) podrzędna(e) do", | ||||
|     "options": "Opcje", | ||||
|     "shrinkImages": "Zmniejsz obrazy", | ||||
|     "safeImport": "Bezpieczny import", | ||||
|     "import-status": "Status importu", | ||||
|     "in-progress": "Import w trakcie: {{progress}}", | ||||
|     "successful": "Importowanie zakończone sukcesem.", | ||||
|     "safeImportTooltip": "Pliki eksportu Trilium <code>.zip</code> mogą zawierać skrypty wykonywalne, które mogą powodować szkodliwe zachowania. Bezpieczny import dezaktywuje automatyczne wykonywanie wszystkich importowanych skryptów. Odznacz opcję „Bezpieczny import” tylko wtedy, gdy importowane archiwum ma zawierać skrypty wykonywalne i masz pełne zaufanie do zawartości importowanego pliku.", | ||||
|     "import": "Import", | ||||
|     "failed": "Błąd importu: {{message}}.", | ||||
|     "html_import_tags": { | ||||
|       "title": "Tagi importu HTML", | ||||
|       "description": "Skonfiguruj, które tagi HTML mają zostać zachowane podczas importowania notatek. Tagi spoza tej listy zostaną usunięte podczas importu. Niektóre tagi (np. „script”) są zawsze usuwane ze względów bezpieczeństwa.", | ||||
|       "placeholder": "Wpisz tagi HTML, jedna na linijkę", | ||||
|       "reset_button": "Zresetuj do domyślnej listy" | ||||
|     } | ||||
|   }, | ||||
|   "image_properties": { | ||||
|     "title": "Obraz", | ||||
|     "original_file_name": "Oryginalna nazwa pliku", | ||||
|     "file_type": "Typ pliku", | ||||
|     "file_size": "Rozmiar pliku", | ||||
|     "download": "Pobierz", | ||||
|     "open": "Otwórz", | ||||
|     "copy_reference_to_clipboard": "Kopiuj odniesienie do schowka", | ||||
|     "upload_new_revision": "Wgraj nową wersję", | ||||
|     "upload_success": "Nowa wersja obrazu została wysłana.", | ||||
|     "upload_failed": "Wysyłanie nowej wersji obrazu nie powiodło się: {{message}}" | ||||
|   }, | ||||
|   "inherited_attribute_list": { | ||||
|     "title": "Odziedziczone atrybuty", | ||||
|     "no_inherited_attributes": "Brak odziedziczonych atrybutów." | ||||
|   }, | ||||
|   "note_info_widget": { | ||||
|     "note_id": "ID notatki", | ||||
|     "created": "Stworzona", | ||||
|     "modified": "Zmodyfikowano", | ||||
|     "type": "Typ", | ||||
|     "note_size": "Rozmiar notatki", | ||||
|     "note_size_info": "Rozmiar notatki pozwala oszacować przybliżoną ilość miejsca potrzebnego na przechowanie jej. Uwzględnia ona jej treść oraz treść jej poprawek.", | ||||
|     "calculate": "oblicz", | ||||
|     "subtree_size": "(rozmiar poddrzewa: {{size}} w {{count}} notatkach)", | ||||
|     "title": "Informacje o notatce" | ||||
|   }, | ||||
|   "note_map": { | ||||
|     "open_full": "Pełne rozszerzenie", | ||||
|     "collapse": "Zmniejsz do normalnego rozmiaru", | ||||
|     "title": "Mapa notatki", | ||||
|     "fix-nodes": "Napraw węzły", | ||||
|     "link-distance": "Odległość linku" | ||||
|   }, | ||||
|   "note_paths": { | ||||
|     "title": "Ścieżki notatki", | ||||
|     "clone_button": "Sklonuj notatkę do nowej lokalizacji...", | ||||
|     "intro_placed": "Ta notatka jest umieszczona w następujących lokalizacjach:", | ||||
|     "intro_not_placed": "Ta notatka nie została jeszcze umieszczona w drzewie.", | ||||
|     "outside_hoisted": "Ta ścieżka znajduje się poza podniesioną notatką i trzeba ją odwiesić.", | ||||
|     "archived": "Zarchiwizowane", | ||||
|     "search": "Szukaj" | ||||
|   }, | ||||
|   "note_properties": { | ||||
|     "this_note_was_originally_taken_from": "Ta notatka oryginalnie została wzięta z:", | ||||
|     "info": "Info" | ||||
|   }, | ||||
|   "owned_attribute_list": { | ||||
|     "owned_attributes": "Posiadane atrybuty" | ||||
|   }, | ||||
|   "promoted_attributes": { | ||||
|     "promoted_attributes": "Promowane atrybuty", | ||||
|     "unset-field-placeholder": "nie ustawione", | ||||
|     "url_placeholder": "http://strona...", | ||||
|     "open_external_link": "Otwórz link zewnętrzny", | ||||
|     "unknown_label_type": "Nieznany typ etykiety \"{{type}}\"", | ||||
|     "unknown_attribute_type": "Nieznany typ atrybutu \"{{type}}\"", | ||||
|     "add_new_attribute": "Dodaj nowy atrybut", | ||||
|     "remove_this_attribute": "Usuń ten atrybut", | ||||
|     "remove_color": "Usuń ten kolor etykiety" | ||||
|   }, | ||||
|   "script_executor": { | ||||
|     "query": "Zapytanie", | ||||
|     "script": "Skrypt", | ||||
|     "execute_query": "Wykonaj zapytanie", | ||||
|     "execute_script": "Wykonaj skrypt" | ||||
|   }, | ||||
|   "search_definition": { | ||||
|     "add_search_option": "Dodaj opcje wyszukiwania:", | ||||
|     "search_string": "ciąg wyszukiwania", | ||||
|     "search_script": "skrypt wyszukiwania", | ||||
|     "ancestor": "przodek", | ||||
|     "fast_search": "szybkie wyszukiwanie", | ||||
|     "fast_search_description": "Opcja szybkiego wyszukiwania wyłącza pełno tekstowe przeszukiwanie zawartości notatek, co może przyspieszyć przeszukiwanie dużych baz danych.", | ||||
|     "include_archived": "dodaj zarchiwizowane", | ||||
|     "include_archived_notes_description": "Domyślnie zarchiwizowane notatki są wyłączone z wyszukiwania, z tą opcją zostaną dodane do wyszukiwania.", | ||||
|     "order_by": "sortuj", | ||||
|     "limit": "limituj", | ||||
|     "limit_description": "Limituj liczbę wyników", | ||||
|     "save_to_note": "Zapisz do notatki", | ||||
|     "search_parameters": "Parametry wyszukiwania", | ||||
|     "unknown_search_option": "Nieznana opcja wyszukiwania {{searchOptionName}}", | ||||
|     "search_note_saved": "Wyszukiwana notatka została zapisana do {{- notePathTitle}}", | ||||
|     "actions_executed": "Akcja została wykonana." | ||||
|   }, | ||||
|   "similar_notes": { | ||||
|     "title": "Podobne notatki", | ||||
|     "no_similar_notes_found": "Nie znaleziono podobnych notatek." | ||||
|   }, | ||||
|   "abstract_search_option": { | ||||
|     "remove_this_search_option": "Usuń tą opcję wyszukiwania", | ||||
|     "failed_rendering": "Nieudana opcja wyszukiwania: {{dto}} z błędem: {{error}} {{stack}}" | ||||
|   }, | ||||
|   "ancestor": { | ||||
|     "label": "Przodek", | ||||
|     "placeholder": "szukaj notatki po jej nazwie", | ||||
|     "depth_label": "glębokość", | ||||
|     "depth_doesnt_matter": "nie ważne", | ||||
|     "depth_eq": "jest dokładnie {{count}}", | ||||
|     "direct_children": "bezpośrednie podnotatki", | ||||
|     "depth_gt": "jest więcej niż {{count}}", | ||||
|     "depth_lt": "jest mniej niż {{count}}" | ||||
|   }, | ||||
|   "debug": { | ||||
|     "debug": "Debuguj", | ||||
|     "debug_info": "Debugowanie wyświetli dodatkowe informacje debugowania w konsoli, aby ułatwić debugowanie złożonych zapytań." | ||||
|   }, | ||||
|   "fast_search": { | ||||
|     "fast_search": "Szybkie wyszukiwanie" | ||||
|   }, | ||||
|   "file_properties": { | ||||
|     "download": "Pobierz", | ||||
|     "open": "Otwórz", | ||||
|     "upload_new_revision": "Wgraj nową wersję", | ||||
|     "upload_success": "Nowa wersja pliku nie została wysłana.", | ||||
|     "upload_failed": "Wysyłanie nowej wersji pliku się nie udało.", | ||||
|     "title": "Plik" | ||||
|   }, | ||||
|   "include_note": { | ||||
|     "label_note": "Notatka", | ||||
|     "placeholder_search": "szukaj notatki po jej nazwie", | ||||
|     "dialog_title": "Dołącz notatkę", | ||||
|     "button_include": "Dołącz notatkę" | ||||
|   }, | ||||
|   "info": { | ||||
|     "closeButton": "Zamknij", | ||||
|     "okButton": "OK", | ||||
|     "modalTitle": "Wiadomość" | ||||
|   }, | ||||
|   "jump_to_note": { | ||||
|     "search_placeholder": "Szukaj notatki po jej nazwie albo typie > komendy...", | ||||
|     "search_button": "Wyszukiwanie pełno tekstowe" | ||||
|   }, | ||||
|   "markdown_import": { | ||||
|     "dialog_title": "Zaimportuj Markdown", | ||||
|     "import_button": "Import", | ||||
|     "import_success": "Treść Markdown została zaimportowana do dokumentu." | ||||
|   }, | ||||
|   "limit": { | ||||
|     "limit": "Limit" | ||||
|   }, | ||||
|   "link_context_menu": { | ||||
|     "open_note_in_popup": "Szybka edycja", | ||||
|     "open_note_in_new_tab": "Otwórz notatkę w nowej karcie", | ||||
|     "open_note_in_new_split": "Otwórz notatkę w nowym podziale ekranu", | ||||
|     "open_note_in_new_window": "Otwórz notatkę w nowym oknie" | ||||
|   }, | ||||
|   "electron_integration": { | ||||
|     "desktop-application": "Aplikacja desktopowa" | ||||
|   }, | ||||
|   "electron_context_menu": { | ||||
|     "cut": "Wytnij", | ||||
|     "copy": "Kopiuj", | ||||
|     "copy-link": "Kopiuj link", | ||||
|     "paste": "Wklej", | ||||
|     "paste-as-plain-text": "Wklej jako plain text", | ||||
|     "search_online": "Szukaj \"{{term}}\" za pomocą {{searchEngine}}" | ||||
|   }, | ||||
|   "image_context_menu": { | ||||
|     "copy_reference_to_clipboard": "Skopiuj odnośnik do schowka", | ||||
|     "copy_image_to_clipboard": "Skopiuj obraz do schowka" | ||||
|   }, | ||||
|   "note_autocomplete": { | ||||
|     "clear-text-field": "Wyczyść pole tekstowe", | ||||
|     "show-recent-notes": "Pokaż ostatnie notatki", | ||||
|     "full-text-search": "Wyszukiwanie pełnotekstowe" | ||||
|   }, | ||||
|   "note_tooltip": { | ||||
|     "note-has-been-deleted": "Notatka została usunięta.", | ||||
|     "quick-edit": "Szybka edycja" | ||||
|   }, | ||||
|   "duration": { | ||||
|     "seconds": "sekundy", | ||||
|     "minutes": "minuty", | ||||
|     "hours": "godziny", | ||||
|     "days": "dni" | ||||
|   }, | ||||
|   "share": { | ||||
|     "title": "Ustawienia udostępniania" | ||||
|   }, | ||||
|   "tasks": { | ||||
|     "due": { | ||||
|       "today": "Dziś", | ||||
|       "tomorrow": "Jutro", | ||||
|       "yesterday": "Wczoraj" | ||||
|     } | ||||
|   }, | ||||
|   "content_widget": { | ||||
|     "unknown_widget": "Nieznany widget dla \"{{id}}\"." | ||||
|   }, | ||||
|   "note_language": { | ||||
|     "not_set": "Nie ustawione", | ||||
|     "configure-languages": "Konfiguracja języków..." | ||||
|   }, | ||||
|   "content_language": { | ||||
|     "title": "Język treści", | ||||
|     "description": "Wybierz jeden lub więcej języków, które mają być wyświetlane w sekcji Właściwości Podstawowe Notatki Tekstowej tylko do odczytu lub edytowalnej. Umożliwi to korzystanie z takich funkcji, jak sprawdzanie pisowni czy obsługa pisania od prawej do lewej." | ||||
|   }, | ||||
|   "switch_layout_button": { | ||||
|     "title_vertical": "Przesuń panel edycji na dół", | ||||
|     "title_horizontal": "Przesuń panel edycji do lewej" | ||||
|   }, | ||||
|   "toggle_read_only_button": { | ||||
|     "unlock-editing": "Odblokuj edycję", | ||||
|     "lock-editing": "Zablokuj edycję" | ||||
|   }, | ||||
|   "png_export_button": { | ||||
|     "button_title": "Wyeksportuj diagram jako PNG" | ||||
|   }, | ||||
|   "svg": { | ||||
|     "export_to_png": "Diagram nie może zostać wyeksportowany jako PNG." | ||||
|   }, | ||||
|   "code_theme": { | ||||
|     "title": "Wygląd", | ||||
|     "word_wrapping": "Zawijanie słów", | ||||
|     "color-scheme": "Schemat kolorów" | ||||
|   }, | ||||
|   "cpu_arch_warning": { | ||||
|     "title": "Proszę o pobranie wersji ARM64", | ||||
|     "message_macos": "TriliumNext działa obecnie w oparciu o technologię Rosetta 2, co oznacza, że używasz wersji Intel (x64) na komputerze Mac z procesorem Apple Silicon. Będzie to miało znaczący wpływ na wydajność i czas pracy baterii.", | ||||
|     "message_windows": "TriliumNext działa obecnie w trybie emulacji, co oznacza, że używasz wersji Intel (x64) na urządzeniu z systemem Windows na procesorze ARM. Będzie to miało znaczący wpływ na wydajność i czas pracy baterii.", | ||||
|     "recommendation": "Aby uzyskać najlepsze wrażenia, pobierz natywną wersję ARM64 aplikacji TriliumNext ze strony poświęconej wydaniom.", | ||||
|     "download_link": "Pobierz wersję natywną", | ||||
|     "continue_anyway": "Kontynuuj mimo wszystko", | ||||
|     "dont_show_again": "Nie pokazuj więcej tego ostrzeżenia" | ||||
|   }, | ||||
|   "editorfeatures": { | ||||
|     "title": "Cechy", | ||||
|     "emoji_completion_enabled": "Włącz autouzupełnianie Emoji", | ||||
|     "note_completion_enabled": "Włącz autouzupełnianie notatki" | ||||
|   }, | ||||
|   "table_view": { | ||||
|     "new-row": "Nowy wiersz", | ||||
|     "new-column": "Nowa kolumna", | ||||
|     "sort-column-by": "Sotuj po \"{{title}}\"", | ||||
|     "sort-column-ascending": "Rosnąco", | ||||
|     "sort-column-descending": "Malejąco", | ||||
|     "sort-column-clear": "Wyczyść sortowanie", | ||||
|     "hide-column": "Ukryj kolumnę \"{{title}}\"", | ||||
|     "show-hide-columns": "Pokaż/ukryj kolumny", | ||||
|     "row-insert-above": "Wstaw wiersz nad", | ||||
|     "row-insert-below": "Wstaw wiersz pod", | ||||
|     "row-insert-child": "Wstaw podnotatkę", | ||||
|     "add-column-to-the-left": "Dodaj kolumnę po lewej", | ||||
|     "add-column-to-the-right": "Dodaj kolumnę po prawej", | ||||
|     "edit-column": "Edytuj kolumnę", | ||||
|     "delete_column_confirmation": "Czy na pewno chcesz usunąć tę kolumnę? Odpowiedni atrybut zostanie usunięty ze wszystkich notatek.", | ||||
|     "delete-column": "Usuń kolumnę", | ||||
|     "new-column-label": "Etykieta", | ||||
|     "new-column-relation": "Relacje" | ||||
|   }, | ||||
|   "book_properties_config": { | ||||
|     "hide-weekends": "Ukryj weekendy", | ||||
|     "display-week-numbers": "Pokaż numery tygodni", | ||||
|     "map-style": "Styl mapy:", | ||||
|     "max-nesting-depth": "Maksymalna głębokość zagnieżdżenia:", | ||||
|     "raster": "Raster", | ||||
|     "vector_light": "Wektor (jasny)", | ||||
|     "vector_dark": "Wektor (ciemny)", | ||||
|     "show-scale": "Pokaż skalę" | ||||
|   }, | ||||
|   "table_context_menu": { | ||||
|     "delete_row": "Usuń wiersz" | ||||
|   }, | ||||
|   "move_to": { | ||||
|     "dialog_title": "Przenieś notatki do ...", | ||||
|     "notes_to_move": "Notatki do przeniesienia" | ||||
|   }, | ||||
|   "note_type_chooser": { | ||||
|     "modal_title": "Wybierz typ notatki", | ||||
|     "modal_body": "Wybierz typ / szablon notatki dla nowej notatki:", | ||||
|     "templates": "Szablony", | ||||
|     "builtin_templates": "Wbudowane szablony" | ||||
|   }, | ||||
|   "password_not_set": { | ||||
|     "title": "Hasło nie zostało ustawione" | ||||
|   }, | ||||
|   "add_relation": { | ||||
|     "add_relation": "Dodaj powiązanie", | ||||
|     "relation_name": "nazwa powiązania", | ||||
|     "allowed_characters": "Dozwolone są znaki alfanumeryczne, podkreślenie i dwukropek.", | ||||
|     "to": "do", | ||||
|     "target_note": "docelowa notatka" | ||||
|   }, | ||||
|   "ai_llm": { | ||||
|     "actions": "Akcje", | ||||
|     "retry": "Spróbuj ponownie", | ||||
|     "partial": "{{ percentage }}% wykonania", | ||||
|     "retry_queued": "notatka dodana do kolejki", | ||||
|     "retry_failed": "Nieudana próba dodania notatki do kolejki", | ||||
|     "max_notes_per_llm_query": "Maksymalna ilość notatek w zapytaniu", | ||||
|     "index_all_notes": "Zindeksuj wszystkie notatki", | ||||
|     "index_status": "Status indeksowania", | ||||
|     "indexed_notes": "Zindeksowane notatki", | ||||
|     "indexing_stopped": "Indeksowanie zatrzymane", | ||||
|     "indexing_in_progress": "Indeksowanie w trakcie...", | ||||
|     "last_indexed": "Ostatnio zindeksowane", | ||||
|     "n_notes_queued_0": "{{ count }} notatka zakolejkowana do indeksowania", | ||||
|     "n_notes_queued_1": "{{ count }} notatek zakolejkowanych do indeksowania", | ||||
|     "n_notes_queued_2": "{{ count }} notatek zakolejkowanych do indeksowania", | ||||
|     "note_chat": "Czat notatki", | ||||
|     "note_title": "Tytuł notatki", | ||||
|     "error": "Błąd", | ||||
|     "last_attempt": "Ostatnia próba", | ||||
|     "queued_notes": "Zakolejkowane notatki", | ||||
|     "failed_notes": "Nieudane notatki", | ||||
|     "last_processed": "Ostatnio procesowane", | ||||
|     "refresh_stats": "Odśwież Statystyki", | ||||
|     "enable_ai_features": "Włącz funkcje AI/LLM", | ||||
|     "enable_ai_description": "Włącz funkcje AI, takie jak podsumowywanie notatek, generowanie treści i inne możliwości LLM", | ||||
|     "openai_tab": "OpenAI", | ||||
|     "anthropic_tab": "Anthropic", | ||||
|     "voyage_tab": "Voyage AI", | ||||
|     "ollama_tab": "Ollama", | ||||
|     "enable_ai": "Włącz funkcje AI/LLM", | ||||
|     "enable_ai_desc": "Włącz funkcje AI, takie jak podsumowywanie notatek, generowanie treści i inne możliwości LLM", | ||||
|     "provider_configuration": "Konfiguracja dostawcy AI", | ||||
|     "provider_precedence": "Pierwszeństwo dostawcy", | ||||
|     "provider_precedence_description": "Lista dostawców przedzielonych przecinkami w kolejności (np. „openai,anthropic,ollama”)", | ||||
|     "temperature": "Temperatura", | ||||
|     "temperature_description": "Kontroluje losowość odpowiedzi (0 = deterministyczna, 2 = maksymalna losowość)", | ||||
|     "system_prompt": "Monit systemowy", | ||||
|     "system_prompt_description": "Domyślny monit systemowy używany do wszystkich interakcji ze sztuczną inteligencją", | ||||
|     "openai_configuration": "Konfiguracja OpenAI", | ||||
|     "openai_settings": "Ustawienia OpenAI", | ||||
|     "api_key": "Klucz API", | ||||
|     "url": "Bazowy URL", | ||||
|     "model": "Model", | ||||
|     "openai_api_key_description": "Klucz API OpenAI umożliwiający dostęp do usług AI", | ||||
|     "anthropic_api_key_description": "Klucz API Anthropic umożliwiający dostęp do usług AI", | ||||
|     "default_model": "Domyślny Model", | ||||
|     "openai_model_description": "Przykłady: gpt-4o, gpt-4-turbo, gpt-3.5-turbo", | ||||
|     "base_url": "Bazowy URL", | ||||
|     "openai_url_description": "Domyślny: https://api.openai.com/v1", | ||||
|     "anthropic_settings": "Ustawienia Anthropic", | ||||
|     "anthropic_url_description": "Bazowy URL dla Anthropic API (domyślny: https://api.anthropic.com)", | ||||
|     "anthropic_model_description": "Modele Anthropic Claude'a do uzupełniania czatów", | ||||
|     "voyage_settings": "Ustawienia Voyage AI", | ||||
|     "ollama_settings": "Ustawienia Ollama", | ||||
|     "ollama_url_description": "URL dla Ollama API (domyślny: http://localhost:11434)", | ||||
|     "ollama_model_description": "Model Ollama używany do uzupełniania czatów", | ||||
|     "anthropic_configuration": "Konfiguracja Anthropic", | ||||
|     "voyage_configuration": "Konfiguracja Voyage AI", | ||||
|     "voyage_url_description": "Domyślny: https://api.voyageai.com/v1", | ||||
|     "ollama_configuration": "Konfiguracja Ollama", | ||||
|     "enable_ollama": "Włącz Ollama", | ||||
|     "enable_ollama_description": "Włącz Ollama dla lokalnego modelu AI", | ||||
|     "ollama_url": "Ollama URL", | ||||
|     "ollama_model": "Model Ollama", | ||||
|     "refresh_models": "Odśwież modele", | ||||
|     "refreshing_models": "Odświeżanie...", | ||||
|     "enable_automatic_indexing": "Włącz automatyczne indeksowanie", | ||||
|     "rebuild_index": "Odbuduj indeks", | ||||
|     "rebuild_index_error": "Błąd uruchomienia odbudowy indeksu. Sprawdź logi.", | ||||
|     "max_notes_per_llm_query_description": "Maksymalna liczba podobnych notatek do uwzględnienia w kontekście sztucznej inteligencji", | ||||
|     "active_providers": "Aktywni dostawcy", | ||||
|     "disabled_providers": "Wyłączeni dostawcy", | ||||
|     "remove_provider": "Usuń dostawcę z wyszukiwania", | ||||
|     "restore_provider": "Przywróć dostawcę do wyszukiwania", | ||||
|     "similarity_threshold": "Próg podobieństwa" | ||||
|   } | ||||
| } | ||||
|   | ||||
							
								
								
									
										1
									
								
								apps/client/src/translations/pt/translation.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								apps/client/src/translations/pt/translation.json
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | ||||
| {} | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -40,7 +40,7 @@ | ||||
|   "add_relation": { | ||||
|     "add_relation": "Adaugă relație", | ||||
|     "allowed_characters": "Sunt permise doar caractere alfanumerice, underline și două puncte.", | ||||
|     "create_relation_on_all_matched_notes": "Crează relația pentru toate notițele găsite", | ||||
|     "create_relation_on_all_matched_notes": "Creează relația pentru toate notițele găsite.", | ||||
|     "relation_name": "denumirea relației", | ||||
|     "target_note": "notița destinație", | ||||
|     "to": "către" | ||||
| @@ -76,9 +76,9 @@ | ||||
|   "attachment_erasure_timeout": { | ||||
|     "attachment_auto_deletion_description": "Atașamentele se șterg automat (permanent) dacă nu sunt referențiate de către notița lor părinte după un timp prestabilit de timp.", | ||||
|     "attachment_erasure_timeout": "Perioadă de ștergere a atașamentelor", | ||||
|     "erase_attachments_after": "Erase unused attachments after:", | ||||
|     "erase_attachments_after": "Șterge atașamentele neutilizate după:", | ||||
|     "erase_unused_attachments_now": "Elimină atașamentele șterse acum", | ||||
|     "manual_erasing_description": "Șterge acum toate atașamentele nefolosite din notițe", | ||||
|     "manual_erasing_description": "Puteți șterge atașamentele nefolosite manual (fără a lua în considerare timpul de mai sus):", | ||||
|     "unused_attachments_erased": "Atașamentele nefolosite au fost șterse." | ||||
|   }, | ||||
|   "attachment_list": { | ||||
| @@ -141,7 +141,7 @@ | ||||
|     "hide_promoted_attributes": "Ascunde lista atributelor promovate pentru această notiță", | ||||
|     "hide_relations": "lista denumirilor relațiilor ce trebuie ascunse, delimitate prin virgulă. Toate celelalte vor fi afișate.", | ||||
|     "icon_class": "valoarea acestei etichete este adăugată ca o clasă CSS la iconița notiței din ierarhia notițelor, fapt ce poate ajuta la identificarea vizuală mai rapidă a notițelor. Un exemplu ar fi „bx bx-home” pentru iconițe preluate din boxicons. Poate fi folosită în notițe de tip șablon.", | ||||
|     "inbox": "locația implicită în care vor apărea noile notițe atunci când se crează o noitiță utilizând butonul „Crează notiță” din bara laterală, notițele vor fi create în interiorul notiței cu această etichetă.", | ||||
|     "inbox": "locația implicită în care vor apărea noile notițe atunci când se crează o noitiță utilizând butonul „Crează notiță” din bara laterală, notițele vor fi create în interiorul notiței marcată cu eticheta <code>#inbox</code>.", | ||||
|     "inherit": "atributele acestei notițe vor fi moștenite chiar dacă nu există o relație părinte-copil între notițe. A se vedea relația de tip șablon pentru un concept similar. De asemenea, a se vedea moștenirea atributelor în documentație.", | ||||
|     "inheritable": "Moștenibilă", | ||||
|     "inheritable_title": "Atributele moștenibile vor fi moștenite de către toți descendenții acestei notițe.", | ||||
| @@ -177,7 +177,7 @@ | ||||
|     "render_note": "relație ce definește notița (de tip notiță de cod HTML sau script) ce trebuie randată pentru notițele de tip „Randare notiță HTML”", | ||||
|     "run": "definește evenimentele la care să ruleze scriptul. Valori acceptate:\n<ul>\n<li>frontendStartup - când pornește interfața Trilium (sau este reîncărcată), dar nu pe mobil.</li>\n<li>mobileStartup - când pornește interfața Trilium (sau este reîncărcată), doar pe mobil.</li>\n<li>backendStartup - când pornește serverul Trilium</li>\n<li>hourly - o dată pe oră. Se poate utiliza adițional eticheta <code>runAtHour</code> pentru a specifica ora.</li>\n<li>daily - o dată pe zi</li>\n</ul>", | ||||
|     "run_at_hour": "La ce oră ar trebui să ruleze. Trebuie folosit împreună cu <code>#run=hourly</code>. Poate fi definit de mai multe ori pentru a rula de mai multe ori în cadrul aceleași zile.", | ||||
|     "run_on_attribute_change": "se execută atunci când atributele unei notițe care definește această relație se schimbă. Se apelează și atunci când un atribut este șters", | ||||
|     "run_on_attribute_change": " se execută atunci când atributele unei notițe care definește această relație se schimbă. Se apelează și atunci când un atribut este șters", | ||||
|     "run_on_attribute_creation": "se execută atunci când un nou atribut este creat pentru notița care definește această relație", | ||||
|     "run_on_branch_change": "se execută atunci când o ramură este actualizată.", | ||||
|     "run_on_branch_creation": "se execută când o ramură este creată. O ramură este o legătură dintre o notiță părinte și o notiță copil și este creată, spre exemplu, la clonarea sau mutarea unei notițe.", | ||||
| @@ -198,7 +198,7 @@ | ||||
|     "share_disallow_robot_indexing": "împiedică indexarea conținutului de către roboți utilizând antetul <code>X-Robots-Tag: noindex</code>", | ||||
|     "share_external_link": "notița va funcționa drept o legătură către un site web extern în ierarhia de partajare", | ||||
|     "share_favicon": "Notiță ce conține pictograma favicon pentru a fi setată în paginile partajate. De obicei se poate seta în rădăcina ierarhiei de partajare și se poate face moștenibilă. Notița ce conține favicon-ul trebuie să fie și ea în ierarhia de partajare. Considerați și utilizarea „share_hidden_from_tree”.", | ||||
|     "share_hidden_from_tree": "notița este ascunsă din arborele de navigație din stânga, dar încă este accesibilă prin intermediul unui URL.", | ||||
|     "share_hidden_from_tree": "notița este ascunsă din arborele de navigație din stânga, dar încă este accesibilă prin intermediul unui URL", | ||||
|     "share_index": "notițele cu această etichetă vor afișa lista tuturor rădăcilor notițelor partajate", | ||||
|     "share_js": "Notiță JavaScript ce va fi injectată în pagina de partajare. Notița respectivă trebuie să fie și ea în ierarhia de partajare. Considerați utilizarea 'share_hidden_from_tree'.", | ||||
|     "share_omit_default_css": "CSS-ul implicit pentru pagina de partajare va fi omis. Se poate folosi atunci când se fac schimbări majore de stil la pagină.", | ||||
| @@ -214,7 +214,7 @@ | ||||
|     "target_note_title": "Relația este o conexiune numită dintre o notiță sursă și o notiță țintă.", | ||||
|     "template": "Șablon", | ||||
|     "text": "Text", | ||||
|     "title_template": "titlul implicit al notițelor create în interiorul acestei notițe. Valoarea este evaluată ca un șir de caractere JavaScript\n                        și poate fi astfel îmbogățită cu un conținut dinamic prin intermediul variabilelow <code>now</code> și <code>parentNote</code>. Exemple:\n                        \n                        <ul>\n                            <li><code>Lucrările lui ${parentNote.getLabelValue('autor')}</code></li>\n                            <li><code>Jurnal pentru ${now.format('YYYY-MM-DD HH:mm:ss')}</code></li>\n                        </ul>\n                        \n                        A se vedea <a href=\"https://triliumnext.github.io/Docs/Wiki/default-note-title.html\">wiki-ul pentru detalii</a>, documentația API pentru <a href=\"https://zadam.github.io/trilium/backend_api/Note.html\">parentNote</a> și <a href=\"https://day.js.org/docs/en/display/format\">now</a> pentru mai multe informații", | ||||
|     "title_template": "titlul implicit al notițelor create în interiorul acestei notițe. Valoarea este evaluată ca un șir de caractere JavaScript\n                        și poate fi astfel îmbogățită cu un conținut dinamic prin intermediul variabilelor <code>now</code> și <code>parentNote</code>. Exemple:\n                        \n                        <ul>\n                            <li><code>Lucrările lui ${parentNote.getLabelValue('autor')}</code></li>\n                            <li><code>Jurnal pentru ${now.format('YYYY-MM-DD HH:mm:ss')}</code></li>\n                        </ul>\n                        \n                        A se vedea <a href=\"https://triliumnext.github.io/Docs/Wiki/default-note-title.html\">wiki-ul pentru detalii</a>, documentația API pentru <a href=\"https://zadam.github.io/trilium/backend_api/Note.html\">parentNote</a> și <a href=\"https://day.js.org/docs/en/display/format\">now</a> pentru mai multe informații.", | ||||
|     "toc": "<code>#toc</code> sau <code>#toc=show</code> forțează afișarea tabelei de conținut, <code>#toc=hide</code> forțează ascunderea ei. Dacă eticheta nu există, se utilizează setările globale", | ||||
|     "top": "păstrează notița la începutul listei (se aplică doar pentru notițe sortate automat)", | ||||
|     "url": "URL", | ||||
| @@ -267,10 +267,13 @@ | ||||
|     "basic_properties": "Proprietăți de bază", | ||||
|     "editable": "Editabil", | ||||
|     "note_type": "Tipul notiței", | ||||
|     "language": "Limbă" | ||||
|     "language": "Limbă", | ||||
|     "configure_code_notes": "Configurează notițele de tip cod..." | ||||
|   }, | ||||
|   "book": { | ||||
|     "no_children_help": "Această notiță de tip Carte nu are nicio subnotiță așadar nu este nimic de afișat. Vedeți <a href=\"https://triliumnext.github.io/Docs/Wiki/book-note.html\">wiki</a> pentru detalii." | ||||
|     "no_children_help": "Această notiță de tip Carte nu are nicio subnotiță așadar nu este nimic de afișat. Vedeți <a href=\"https://triliumnext.github.io/Docs/Wiki/book-note.html\">wiki</a> pentru detalii.", | ||||
|     "drag_locked_title": "Blocat pentru editare", | ||||
|     "drag_locked_message": "Glisarea notițelor nu este permisă deoarece colecția este blocată pentru editare." | ||||
|   }, | ||||
|   "book_properties": { | ||||
|     "collapse": "Minimizează", | ||||
| @@ -285,7 +288,8 @@ | ||||
|     "book_properties": "Proprietăți colecție", | ||||
|     "table": "Tabel", | ||||
|     "geo-map": "Hartă geografică", | ||||
|     "board": "Tablă Kanban" | ||||
|     "board": "Tablă Kanban", | ||||
|     "include_archived_notes": "Afișează notițele arhivate" | ||||
|   }, | ||||
|   "bookmark_switch": { | ||||
|     "bookmark": "Semn de carte", | ||||
| @@ -334,7 +338,18 @@ | ||||
|     "thu": "Joi", | ||||
|     "tue": "Mar", | ||||
|     "wed": "Mie", | ||||
|     "cannot_find_week_note": "Nu s-a putut găsi notița săptămânală" | ||||
|     "cannot_find_week_note": "Nu s-a putut găsi notița săptămânală", | ||||
|     "week": "Săptămână", | ||||
|     "week_previous": "Săptămâna trecută", | ||||
|     "week_next": "Următoarea săptămână", | ||||
|     "month": "Lună", | ||||
|     "month_previous": "Luna anterioară", | ||||
|     "month_next": "Următoarea lună", | ||||
|     "year": "An", | ||||
|     "year_previous": "Anul trecut", | ||||
|     "year_next": "Anul următor", | ||||
|     "list": "Agendă", | ||||
|     "today": "Astăzi" | ||||
|   }, | ||||
|   "clone_to": { | ||||
|     "clone_notes_to": "Clonează notițele către...", | ||||
| @@ -369,7 +384,7 @@ | ||||
|   }, | ||||
|   "confirm": { | ||||
|     "also_delete_note": "Șterge și notița", | ||||
|     "are_you_sure_remove_note": "Doriți ștergerea notiței „{{title}}” din harta de relații?", | ||||
|     "are_you_sure_remove_note": "Doriți ștergerea notiței „{{title}}” din harta de relații? ", | ||||
|     "cancel": "Anulează", | ||||
|     "confirmation": "Confirm", | ||||
|     "if_you_dont_check": "Dacă această opțiune nu este bifată, notița va fi ștearsă doar din harta de relații.", | ||||
| @@ -519,8 +534,8 @@ | ||||
|     "export_status": "Starea exportului", | ||||
|     "export_type_single": "Doar această notiță fără descendenții ei", | ||||
|     "export_type_subtree": "Această notiță și toți descendenții ei", | ||||
|     "format_html_zip": "HTML în arhivă ZIP - recomandat deoarece păstrează toată formatarea", | ||||
|     "format_markdown": "Markdown - păstrează majoritatea formatării", | ||||
|     "format_html_zip": "HTML în arhivă ZIP - recomandat deoarece păstrează toată formatarea.", | ||||
|     "format_markdown": "Markdown - păstrează majoritatea formatării.", | ||||
|     "format_opml": "OPML - format de interschimbare pentru editoare cu structură ierarhică (outline). Formatarea, imaginile și fișierele nu vor fi incluse.", | ||||
|     "opml_version_1": "OPML v1.0 - text simplu", | ||||
|     "opml_version_2": "OPML v2.0 - permite și HTML", | ||||
| @@ -640,7 +655,7 @@ | ||||
|     "newTabNoteLink": "pe o legătură către o notiță va deschide notița într-un tab nou", | ||||
|     "notSet": "nesetat", | ||||
|     "noteNavigation": "Navigarea printre notițe", | ||||
|     "numberedList": "<kbd>1.</code> sau <code>1)</code> urmat de spațiu pentru o listă numerotată", | ||||
|     "numberedList": "<code>1.</code> sau <code>1)</code> urmat de spațiu pentru o listă numerotată", | ||||
|     "onlyInDesktop": "Doar pentru desktop (aplicația Electron)", | ||||
|     "openEmptyTab": "deschide un tab nou", | ||||
|     "other": "Altele", | ||||
| @@ -807,7 +822,7 @@ | ||||
|     "dialog_title": "Mută notițele în...", | ||||
|     "error_no_path": "Nicio cale la care să poată fi mutate.", | ||||
|     "move_button": "Mută la notița selectată", | ||||
|     "move_success_message": "Notițele selectate au fost mutate în", | ||||
|     "move_success_message": "Notițele selectate au fost mutate în ", | ||||
|     "notes_to_move": "Notițe de mutat", | ||||
|     "search_placeholder": "căutați notița după denumirea ei", | ||||
|     "target_parent_note": "Notița părinte destinație" | ||||
| @@ -1058,7 +1073,7 @@ | ||||
|     "download_button": "Descarcă", | ||||
|     "file_size": "Dimensiune fișier:", | ||||
|     "help_title": "Informații despre reviziile notițelor", | ||||
|     "mime": "MIME:", | ||||
|     "mime": "MIME: ", | ||||
|     "no_revisions": "Nu există încă nicio revizie pentru această notiță...", | ||||
|     "note_revisions": "Revizii ale notiței", | ||||
|     "preview": "Previzualizare:", | ||||
| @@ -1070,7 +1085,12 @@ | ||||
|     "revisions_deleted": "Notița reviziei a fost ștearsă.", | ||||
|     "maximum_revisions": "Numărul maxim de revizii pentru notița curentă: {{number}}.", | ||||
|     "settings": "Setări revizii ale notițelor", | ||||
|     "snapshot_interval": "Intervalul de creare a reviziilor pentru notițe: {{seconds}}s." | ||||
|     "snapshot_interval": "Intervalul de creare a reviziilor pentru notițe: {{seconds}}s.", | ||||
|     "diff_on": "Evidențiază diferențele", | ||||
|     "diff_off": "Afișează conținutul", | ||||
|     "diff_on_hint": "Clic pentru a afișa diferențele față de revizia anterioară, la nivel de cod sursă", | ||||
|     "diff_off_hint": "Clic pentru a afișa întregul conținut al reviziei", | ||||
|     "diff_not_available": "Diferențele nu pot fi evidențiate." | ||||
|   }, | ||||
|   "revisions_button": { | ||||
|     "note_revisions": "Revizii ale notiței" | ||||
| @@ -1106,7 +1126,7 @@ | ||||
|     "limit_description": "Limitează numărul de rezultate", | ||||
|     "order_by": "ordonează după", | ||||
|     "save_to_note": "Salvează în notiță", | ||||
|     "search_button": "Căutare <kbd>Enter</kbd>", | ||||
|     "search_button": "Căutare", | ||||
|     "search_execute": "Caută și execută acțiunile", | ||||
|     "search_note_saved": "Notița de căutare a fost salvată în {{- notePathTitle}}", | ||||
|     "search_parameters": "Parametrii de căutare", | ||||
| @@ -1193,7 +1213,7 @@ | ||||
|     "enable": "Activează corectorul ortografic", | ||||
|     "language_code_label": "Codurile de limbă", | ||||
|     "language_code_placeholder": "de exemplu „en-US”, „de-AT”", | ||||
|     "multiple_languages_info": "Mai multe limbi pot fi separate prin virgulă, e.g. \"en-US, de-DE, cs\".", | ||||
|     "multiple_languages_info": "Mai multe limbi pot fi separate prin virgulă, e.g. \"en-US, de-DE, cs\". ", | ||||
|     "title": "Corector ortografic", | ||||
|     "restart-required": "Schimbările asupra setărilor corectorului ortografic vor fi aplicate după restartarea aplicației." | ||||
|   }, | ||||
| @@ -1286,7 +1306,7 @@ | ||||
|   "update_relation_target": { | ||||
|     "allowed_characters": "Sunt permise doar caractere alfanumerice, underline și două puncte.", | ||||
|     "change_target_note": "schimbă notița-țintă a unei relații existente", | ||||
|     "on_all_matched_notes": "Pentru toate notițele găsite:", | ||||
|     "on_all_matched_notes": "Pentru toate notițele găsite", | ||||
|     "relation_name": "denumirea relației", | ||||
|     "target_note": "notița destinație", | ||||
|     "to": "la", | ||||
| @@ -1314,7 +1334,7 @@ | ||||
|     "use_vim_keybindings_in_code_notes": "Combinații de taste Vim" | ||||
|   }, | ||||
|   "web_view": { | ||||
|     "create_label": "Pentru a începe, creați o etichetă cu adresa URL de încorporat, e.g.  #webViewSrc=\"https://www.google.com\"", | ||||
|     "create_label": "Pentru a începe, creați o etichetă cu adresa URL de încorporat, e.g. #webViewSrc=\"https://www.google.com\"", | ||||
|     "embed_websites": "Notițele de tip „Vizualizare web” permit încorporarea site-urilor web în Trilium.", | ||||
|     "web_view": "Vizualizare web" | ||||
|   }, | ||||
| @@ -1357,7 +1377,7 @@ | ||||
|     "insert-note-after": "Inserează după notiță", | ||||
|     "move-to": "Mutare la...", | ||||
|     "open-in-a-new-split": "Deschide în lateral", | ||||
|     "open-in-a-new-tab": "Deschide în tab nou <kbd>Ctrl+Clic</kbd>", | ||||
|     "open-in-a-new-tab": "Deschide în tab nou", | ||||
|     "paste-after": "Lipește după notiță", | ||||
|     "paste-into": "Lipește în notiță", | ||||
|     "protect-subtree": "Protejează ierarhia", | ||||
| @@ -1369,12 +1389,14 @@ | ||||
|     "unhoist-note": "Defocalizează notița", | ||||
|     "converted-to-attachments": "{{count}} notițe au fost convertite în atașamente.", | ||||
|     "convert-to-attachment-confirm": "Doriți convertirea notițelor selectate în atașamente ale notiței părinte?", | ||||
|     "open-in-popup": "Editare rapidă" | ||||
|     "open-in-popup": "Editare rapidă", | ||||
|     "archive": "Arhivează", | ||||
|     "unarchive": "Dezarhivează" | ||||
|   }, | ||||
|   "shared_info": { | ||||
|     "help_link": "Pentru informații vizitați <a href=\"https://triliumnext.github.io/Docs/Wiki/sharing.html\">wiki-ul</a>.", | ||||
|     "shared_locally": "Această notiță este partajată local la", | ||||
|     "shared_publicly": "Această notiță este partajată public la" | ||||
|     "shared_locally": "Această notiță este partajată local la {{- link}}.", | ||||
|     "shared_publicly": "Această notiță este partajată public la {{- link}}." | ||||
|   }, | ||||
|   "note_types": { | ||||
|     "book": "Colecție", | ||||
| @@ -1472,7 +1494,8 @@ | ||||
|     "create-child-note": "Crează subnotiță", | ||||
|     "hoist-this-note-workspace": "Focalizează spațiul de lucru", | ||||
|     "refresh-saved-search-results": "Reîmprospătează căutarea salvată", | ||||
|     "unhoist": "Defocalizează notița" | ||||
|     "unhoist": "Defocalizează notița", | ||||
|     "toggle-sidebar": "Comută bara laterală" | ||||
|   }, | ||||
|   "title_bar_buttons": { | ||||
|     "window-on-top": "Menține fereastra mereu vizibilă" | ||||
| @@ -1863,11 +1886,16 @@ | ||||
|     }, | ||||
|     "create_new_ai_chat": "Crează o nouă discuție cu AI-ul", | ||||
|     "configuration_warnings": "Sunt câteva probleme la configurația AI-ului. Verificați setările.", | ||||
|     "experimental_warning": "Funcția LLM este experimentală!", | ||||
|     "experimental_warning": "Funcția LLM este experimentală.", | ||||
|     "selected_provider": "Furnizor selectat", | ||||
|     "selected_provider_description": "Selectați furnizorul de AI pentru funcțiile de discuție și completare", | ||||
|     "select_model": "Selectați modelul...", | ||||
|     "select_provider": "Selectați furnizorul..." | ||||
|     "select_provider": "Selectați furnizorul...", | ||||
|     "ai_enabled": "Funcționalitățile AI au fost activate", | ||||
|     "ai_disabled": "Funcționalitățile AI au fost dezactivate", | ||||
|     "no_models_found_online": "Nu s-a găsit niciun model. Verificați cheia API și configurația.", | ||||
|     "no_models_found_ollama": "Nu s-a găsit niciun model Ollama. Verificați dacă Ollama rulează.", | ||||
|     "error_fetching": "Eroare la obținerea modelelor: {{error}}" | ||||
|   }, | ||||
|   "custom_date_time_format": { | ||||
|     "title": "Format dată/timp personalizat", | ||||
| @@ -1964,14 +1992,21 @@ | ||||
|     "delete_row": "Șterge rândul" | ||||
|   }, | ||||
|   "board_view": { | ||||
|     "delete-note": "Șterge notița", | ||||
|     "delete-note": "Șterge notița...", | ||||
|     "move-to": "Mută la", | ||||
|     "insert-above": "Inserează deasupra", | ||||
|     "insert-below": "Inserează dedesubt", | ||||
|     "delete-column": "Șterge coloana", | ||||
|     "delete-column-confirmation": "Doriți ștergerea acestei coloane? Atributul corespunzător va fi șters din notițele din acest tabel.", | ||||
|     "new-item": "Intrare nouă", | ||||
|     "add-column": "Adaugă coloană" | ||||
|     "add-column": "Adaugă coloană", | ||||
|     "remove-from-board": "Înlătură de pe tablă", | ||||
|     "archive-note": "Arhivează notița", | ||||
|     "unarchive-note": "Dezarhivează notița", | ||||
|     "new-item-placeholder": "Introduceți titlul notiței...", | ||||
|     "add-column-placeholder": "Introduceți denumirea coloanei...", | ||||
|     "edit-note-title": "Clic pentru a edita titlul notiței", | ||||
|     "edit-column-title": "Clic pentru a edita titlul coloanei" | ||||
|   }, | ||||
|   "command_palette": { | ||||
|     "tree-action-name": "Listă de notițe: {{name}}", | ||||
| @@ -1998,6 +2033,35 @@ | ||||
|   "call_to_action": { | ||||
|     "background_effects_title": "Efectele de fundal sunt acum stabile", | ||||
|     "background_effects_message": "Pe dispozitive cu Windows, efectele de fundal sunt complet stabile. Acestea adaugă un strop de culoare interfeței grafice prin estomparea fundalului din spatele ferestrei. Această tehnică este folosită și în alte aplicații precum Windows Explorer.", | ||||
|     "background_effects_button": "Activează efectele de fundal" | ||||
|     "background_effects_button": "Activează efectele de fundal", | ||||
|     "next_theme_title": "Încercați noua temă Trilium", | ||||
|     "next_theme_message": "Utilizați tema clasică, doriți să încercați noua temă?", | ||||
|     "next_theme_button": "Testează noua temă", | ||||
|     "dismiss": "Treci peste" | ||||
|   }, | ||||
|   "ui-performance": { | ||||
|     "title": "Setări de performanță", | ||||
|     "enable-motion": "Activează tranzițiile și animațiile", | ||||
|     "enable-shadows": "Activează umbrirea elementelor", | ||||
|     "enable-backdrop-effects": "Activează efectele de fundal pentru meniuri, popup-uri și panouri", | ||||
|     "enable-smooth-scroll": "Activează derularea lină", | ||||
|     "app-restart-required": "(este necesară repornirea aplicației pentru ca modificarea să aibă efect)" | ||||
|   }, | ||||
|   "settings": { | ||||
|     "related_settings": "Setări similare" | ||||
|   }, | ||||
|   "settings_appearance": { | ||||
|     "related_code_blocks": "Tema de culori pentru blocuri de cod în notițe de tip text", | ||||
|     "related_code_notes": "Tema de culori pentru notițele de tip cod" | ||||
|   }, | ||||
|   "units": { | ||||
|     "percentage": "%" | ||||
|   }, | ||||
|   "pagination": { | ||||
|     "page_title": "Pagina pentru {{startIndex}} - {{endIndex}}", | ||||
|     "total_notes": "{{count}} notițe" | ||||
|   }, | ||||
|   "collections": { | ||||
|     "rendering_error": "Nu a putut fi afișat conținutul din cauza unei erori." | ||||
|   } | ||||
| } | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,26 +1,96 @@ | ||||
| { | ||||
|     "about": { | ||||
|         "homepage": "Giriş sayfası:", | ||||
|         "app_version": "Uygulama versiyonu:", | ||||
|         "db_version": "Veritabanı versiyonu:" | ||||
|   "about": { | ||||
|     "homepage": "Anasayfa:", | ||||
|     "app_version": "Uygulama versiyonu:", | ||||
|     "db_version": "Veritabanı versiyonu:", | ||||
|     "title": "Trilium Notes Hakkında", | ||||
|     "sync_version": "Eşleştirme versiyonu:", | ||||
|     "data_directory": "Veri dizini:" | ||||
|   }, | ||||
|   "branch_prefix": { | ||||
|     "save": "Kaydet", | ||||
|     "edit_branch_prefix": "Dalın önekini düzenle", | ||||
|     "prefix": "Önek: ", | ||||
|     "branch_prefix_saved": "Dal öneki kaydedildi." | ||||
|   }, | ||||
|   "delete_notes": { | ||||
|     "close": "Kapat", | ||||
|     "delete_notes_preview": "Not önizlemesini sil", | ||||
|     "delete_all_clones_description": "Tüm klonları da sil (son değişikliklerden geri alınabilir)" | ||||
|   }, | ||||
|   "export": { | ||||
|     "close": "Kapat" | ||||
|   }, | ||||
|   "import": { | ||||
|     "chooseImportFile": "İçe aktarım dosyası", | ||||
|     "importDescription": "Seçilen dosya(lar) alt not olarak içe aktarılacaktır" | ||||
|   }, | ||||
|   "info": { | ||||
|     "closeButton": "Kapat" | ||||
|   }, | ||||
|   "protected_session_password": { | ||||
|     "close_label": "Kapat" | ||||
|   }, | ||||
|   "toast": { | ||||
|     "critical-error": { | ||||
|       "title": "Kritik hata", | ||||
|       "message": "İstemci uygulamasının başlatılmasını engelleyen kritik bir hata meydana geldi\n\n{{message}}\n\nBu muhtemelen bir betiğin beklenmedik şekilde başarısız olmasından kaynaklanıyor. Uygulamayı güvenli modda başlatarak sorunu ele almayı deneyin." | ||||
|     }, | ||||
|     "branch_prefix": { | ||||
|         "save": "Kaydet" | ||||
|     "widget-error": { | ||||
|       "title": "Bir widget başlatılamadı", | ||||
|       "message-unknown": "Bilinmeyen widget aşağıdaki sebeple başlatılamadı\n\n{{message}}" | ||||
|     }, | ||||
|     "delete_notes": { | ||||
|         "close": "Kapat" | ||||
|     }, | ||||
|     "export": { | ||||
|         "close": "Kapat" | ||||
|     }, | ||||
|     "import": { | ||||
|         "chooseImportFile": "İçe aktarım dosyası", | ||||
|         "importDescription": "Seçilen dosya(lar) alt not olarak içe aktarılacaktır" | ||||
|     }, | ||||
|     "info": { | ||||
|         "closeButton": "Kapat" | ||||
|     }, | ||||
|     "protected_session_password": { | ||||
|         "close_label": "Kapat" | ||||
|     "bundle-error": { | ||||
|       "title": "Özel bir betik yüklenemedi" | ||||
|     } | ||||
|   }, | ||||
|   "add_link": { | ||||
|     "add_link": "Bağlantı ekle", | ||||
|     "help_on_links": "Bağlantılar konusunda yardım", | ||||
|     "note": "Not", | ||||
|     "search_note": "isimle not ara", | ||||
|     "link_title_mirrors": "bağlantı adı notun şu anki adıyla aynı", | ||||
|     "link_title_arbitrary": "bağlantı adı isteğe bağlı olarak değiştirilebilir", | ||||
|     "link_title": "Bağlantı adı", | ||||
|     "button_add_link": "Bağlantı ekle" | ||||
|   }, | ||||
|   "bulk_actions": { | ||||
|     "bulk_actions": "Toplu eylemler", | ||||
|     "affected_notes": "Etkilenen notlar", | ||||
|     "include_descendants": "Seçili notların alt notlarını da ekle", | ||||
|     "available_actions": "Mevcut eylemler", | ||||
|     "chosen_actions": "Seçili eylemler", | ||||
|     "execute_bulk_actions": "Toplu eylemleri uygula", | ||||
|     "bulk_actions_executed": "Toplu eylemler başarıyla uygulandı.", | ||||
|     "none_yet": "Henüz yok... yukarıda mevcut eylemler arasından birine tıklayarak eylem ekle.", | ||||
|     "labels": "Etiketler", | ||||
|     "relations": "İlişkiler", | ||||
|     "notes": "Notlar", | ||||
|     "other": "Diğer" | ||||
|   }, | ||||
|   "clone_to": { | ||||
|     "clone_notes_to": "Notları klonla...", | ||||
|     "help_on_links": "Bağlantılar konusunda yardım", | ||||
|     "notes_to_clone": "Klonlanacak notlar", | ||||
|     "target_parent_note": "Hedef üst not", | ||||
|     "search_for_note_by_its_name": "isme göre not ara", | ||||
|     "cloned_note_prefix_title": "Klonlanan not, not ağacında belirtilen önek ile gösterilecektir", | ||||
|     "prefix_optional": "önek (opsiyonel)", | ||||
|     "clone_to_selected_note": "Seçili nota klonla", | ||||
|     "no_path_to_clone_to": "Klonlanacak bir yol yok.", | ||||
|     "note_cloned": "\"{{clonedTitle}}\" notu \"{{targetTitle}}\"'a klonlandı" | ||||
|   }, | ||||
|   "confirm": { | ||||
|     "confirmation": "Onay", | ||||
|     "cancel": "İptal", | ||||
|     "ok": "OK", | ||||
|     "are_you_sure_remove_note": "\"{{title}}\" notunu ilişki haritasından kaldırmak istediğinize emin misiniz?. ", | ||||
|     "also_delete_note": "Notu da sil" | ||||
|   }, | ||||
|   "ai_llm": { | ||||
|     "n_notes_queued": "{{ count }} not dizinleme için sıraya alındı", | ||||
|     "n_notes_queued_plural": "{{ count }} not dizinleme için sıraya alındı", | ||||
|     "notes_indexed": "{{ count }} not dizinlendi", | ||||
|     "notes_indexed_plural": "{{ count }} not dizinlendi" | ||||
|   } | ||||
| } | ||||
|   | ||||
| @@ -276,7 +276,12 @@ | ||||
|     "preview": "預覽:", | ||||
|     "preview_not_available": "無法預覽此類型的筆記。", | ||||
|     "restore_button": "還原", | ||||
|     "delete_button": "刪除" | ||||
|     "delete_button": "刪除", | ||||
|     "diff_on": "顯示差異", | ||||
|     "diff_off": "顯示內容", | ||||
|     "diff_on_hint": "點擊以顯示筆記原始碼差異", | ||||
|     "diff_off_hint": "點擊以顯示筆記內容", | ||||
|     "diff_not_available": "差異不可用。" | ||||
|   }, | ||||
|   "sort_child_notes": { | ||||
|     "sort_children_by": "依…排序子筆記", | ||||
| @@ -587,7 +592,18 @@ | ||||
|     "october": "十月", | ||||
|     "november": "十一月", | ||||
|     "december": "十二月", | ||||
|     "cannot_find_week_note": "無法找到週記" | ||||
|     "cannot_find_week_note": "無法找到週記", | ||||
|     "week": "週", | ||||
|     "week_previous": "上週", | ||||
|     "week_next": "下週", | ||||
|     "month": "月", | ||||
|     "month_previous": "上個月", | ||||
|     "month_next": "下個月", | ||||
|     "year": "年", | ||||
|     "year_previous": "前一年", | ||||
|     "year_next": "後一年", | ||||
|     "list": "列表", | ||||
|     "today": "今天" | ||||
|   }, | ||||
|   "close_pane_button": { | ||||
|     "close_this_pane": "關閉此面板" | ||||
| @@ -729,7 +745,8 @@ | ||||
|     "note_type": "筆記類型", | ||||
|     "editable": "可編輯", | ||||
|     "basic_properties": "基本屬性", | ||||
|     "language": "語言" | ||||
|     "language": "語言", | ||||
|     "configure_code_notes": "配寘代碼注釋..." | ||||
|   }, | ||||
|   "book_properties": { | ||||
|     "view_type": "視圖類型", | ||||
| @@ -744,7 +761,8 @@ | ||||
|     "calendar": "日曆", | ||||
|     "table": "表格", | ||||
|     "geo-map": "地理地圖", | ||||
|     "board": "看板" | ||||
|     "board": "看板", | ||||
|     "include_archived_notes": "顯示已封存筆記" | ||||
|   }, | ||||
|   "edited_notes": { | ||||
|     "no_edited_notes_found": "今天還沒有編輯過的筆記...", | ||||
| @@ -845,7 +863,7 @@ | ||||
|     "debug": "除錯", | ||||
|     "debug_description": "除錯將顯示額外的除錯資訊至控制台,以幫助除錯複雜查詢", | ||||
|     "action": "操作", | ||||
|     "search_button": "搜尋 <kbd>Enter</kbd>", | ||||
|     "search_button": "搜尋", | ||||
|     "search_execute": "搜尋並執行操作", | ||||
|     "save_to_note": "儲存至筆記", | ||||
|     "search_parameters": "搜尋參數", | ||||
| @@ -945,7 +963,9 @@ | ||||
|     "no_attachments": "此筆記沒有附件。" | ||||
|   }, | ||||
|   "book": { | ||||
|     "no_children_help": "此類型為書籍的筆記沒有任何子筆記,因此沒有內容可顯示。請參閱 <a href=\"https://triliumnext.github.io/Docs/Wiki/book-note.html\">wiki</a> 以了解詳情。" | ||||
|     "no_children_help": "此類型為書籍的筆記沒有任何子筆記,因此沒有內容可顯示。請參閱 <a href=\"https://triliumnext.github.io/Docs/Wiki/book-note.html\">wiki</a> 以了解詳情。", | ||||
|     "drag_locked_title": "鎖定編輯", | ||||
|     "drag_locked_message": "無法拖曳,因為此集合已被鎖定編輯。" | ||||
|   }, | ||||
|   "editable_code": { | ||||
|     "placeholder": "在這裡輸入您的程式碼筆記內容…" | ||||
| @@ -1365,7 +1385,7 @@ | ||||
|     "button-tree-map": "樹狀地圖" | ||||
|   }, | ||||
|   "tree-context-menu": { | ||||
|     "open-in-a-new-tab": "在新分頁中打開 <kbd>Ctrl+Click</kbd>", | ||||
|     "open-in-a-new-tab": "在新分頁中打開", | ||||
|     "open-in-a-new-split": "在新頁面分割中打開", | ||||
|     "insert-note-after": "在後面插入筆記", | ||||
|     "insert-child-note": "插入子筆記", | ||||
| @@ -1395,12 +1415,14 @@ | ||||
|     "converted-to-attachments": "{{count}} 個筆記已被轉換為附件。", | ||||
|     "convert-to-attachment-confirm": "確定要將所選的筆記轉換為其父級筆記的附件嗎?", | ||||
|     "duplicate": "複製副本", | ||||
|     "open-in-popup": "快速編輯" | ||||
|     "open-in-popup": "快速編輯", | ||||
|     "archive": "封存", | ||||
|     "unarchive": "解除封存" | ||||
|   }, | ||||
|   "shared_info": { | ||||
|     "shared_publicly": "此筆記已公開分享在", | ||||
|     "shared_locally": "此筆記已在本地分享在", | ||||
|     "help_link": "如需幫助,請訪問 <a href=\"https://triliumnext.github.io/Docs/Wiki/sharing.html\">wiki</a>。" | ||||
|     "help_link": "如需幫助,請訪問 <a href=\"https://triliumnext.github.io/Docs/Wiki/sharing.html\">wiki</a>。", | ||||
|     "shared_publicly": "此筆記已公開分享於 {{- link}}。", | ||||
|     "shared_locally": "此筆記已於本地分享至 {{- link}}。" | ||||
|   }, | ||||
|   "note_types": { | ||||
|     "text": "文字", | ||||
| @@ -1478,7 +1500,8 @@ | ||||
|     "hoist-this-note-workspace": "聚焦此筆記(工作區)", | ||||
|     "refresh-saved-search-results": "重新整理儲存的搜尋結果", | ||||
|     "create-child-note": "建立子筆記", | ||||
|     "unhoist": "取消聚焦" | ||||
|     "unhoist": "取消聚焦", | ||||
|     "toggle-sidebar": "切換側邊欄" | ||||
|   }, | ||||
|   "title_bar_buttons": { | ||||
|     "window-on-top": "保持此視窗置頂" | ||||
| @@ -1643,13 +1666,13 @@ | ||||
|     "failed_notes": "失敗筆記", | ||||
|     "last_processed": "最後處理時間", | ||||
|     "refresh_stats": "更新統計資料", | ||||
|     "enable_ai_features": "啟用 AI / LLM 功能", | ||||
|     "enable_ai_features": "啟用 AI/LLM 功能", | ||||
|     "enable_ai_description": "啟用筆記摘要、內容生成等 AI 功能及其他 LLM 能力", | ||||
|     "openai_tab": "OpenAI", | ||||
|     "anthropic_tab": "Anthropic", | ||||
|     "voyage_tab": "Voyage AI", | ||||
|     "ollama_tab": "Ollama", | ||||
|     "enable_ai": "啟用 AI / LLM 功能", | ||||
|     "enable_ai": "啟用 AI/LLM 功能", | ||||
|     "enable_ai_desc": "啟用筆記摘要、內容生成等 AI 功能及其他 LLM 能力", | ||||
|     "provider_configuration": "AI 提供者設定", | ||||
|     "provider_precedence": "提供者優先級", | ||||
| @@ -1771,7 +1794,12 @@ | ||||
|     "selected_provider": "已選提供者", | ||||
|     "selected_provider_description": "選擇用於聊天和補全功能的 AI 提供者", | ||||
|     "select_model": "選擇模型…", | ||||
|     "select_provider": "選擇提供者…" | ||||
|     "select_provider": "選擇提供者…", | ||||
|     "ai_enabled": "已啟用 AI 功能", | ||||
|     "ai_disabled": "已禁用 AI 功能", | ||||
|     "no_models_found_online": "找不到模型。請檢查您的 API 金鑰及設定。", | ||||
|     "no_models_found_ollama": "找不到 Ollama 模型。請確認 Ollama 是否正在執行。", | ||||
|     "error_fetching": "獲取模型失敗:{{error}}" | ||||
|   }, | ||||
|   "code-editor-options": { | ||||
|     "title": "編輯器" | ||||
| @@ -1825,7 +1853,7 @@ | ||||
|     "native-title-bar": "原生標題列", | ||||
|     "native-title-bar-description": "對於 Windows 和 macOS,關閉原生標題列會讓應用程式看起來更緊湊。在 Linux 上,開啟原生標題列可以與系統的其他部分整合得更好。", | ||||
|     "background-effects": "啟用背景效果(僅適用於 Windows 11)", | ||||
|     "background-effects-description": "Mica 效果為程式視窗新增模糊且時尚的背景,營造出深度感和現代化外觀。", | ||||
|     "background-effects-description": "Mica 效果為程式視窗新增模糊且時尚的背景,營造出深度感和現代化外觀。「原生標題列」必須被禁用。", | ||||
|     "restart-app-button": "重新啟動應用程式以查看更改", | ||||
|     "zoom-factor": "縮放係數" | ||||
|   }, | ||||
| @@ -1960,14 +1988,21 @@ | ||||
|     "delete_row": "刪除列" | ||||
|   }, | ||||
|   "board_view": { | ||||
|     "delete-note": "刪除筆記", | ||||
|     "delete-note": "刪除筆記…", | ||||
|     "move-to": "移動至", | ||||
|     "insert-above": "在上方插入", | ||||
|     "insert-below": "在下方插入", | ||||
|     "delete-column": "刪除行", | ||||
|     "delete-column-confirmation": "您確定要刪除此行嗎?此行中所有筆記對應的屬性也將被移除。", | ||||
|     "new-item": "新增項目", | ||||
|     "add-column": "新增行" | ||||
|     "add-column": "新增行", | ||||
|     "remove-from-board": "從看板上移除", | ||||
|     "archive-note": "封存筆記", | ||||
|     "unarchive-note": "解除封存筆記", | ||||
|     "new-item-placeholder": "輸入筆記標題…", | ||||
|     "add-column-placeholder": "輸入行名…", | ||||
|     "edit-note-title": "點擊以編輯筆記標題", | ||||
|     "edit-column-title": "點擊以編輯行標題" | ||||
|   }, | ||||
|   "command_palette": { | ||||
|     "tree-action-name": "樹:{{name}}", | ||||
| @@ -1999,5 +2034,30 @@ | ||||
|     "next_theme_message": "您正在使用舊版主題,要試用新主題嗎?", | ||||
|     "next_theme_button": "試用新主題", | ||||
|     "dismiss": "關閉" | ||||
|   }, | ||||
|   "settings": { | ||||
|     "related_settings": "相關設定" | ||||
|   }, | ||||
|   "settings_appearance": { | ||||
|     "related_code_blocks": "文字筆記中程式碼區塊的配色方案", | ||||
|     "related_code_notes": "程式碼筆記的配色方案" | ||||
|   }, | ||||
|   "units": { | ||||
|     "percentage": "%" | ||||
|   }, | ||||
|   "ui-performance": { | ||||
|     "title": "效能", | ||||
|     "enable-motion": "啟用轉場與動畫", | ||||
|     "enable-shadows": "啟用陰影", | ||||
|     "enable-backdrop-effects": "啟用選單、彈出視窗和面板的背景特效", | ||||
|     "enable-smooth-scroll": "啟用平滑滾動", | ||||
|     "app-restart-required": "(需要重啟程式以套用更改)" | ||||
|   }, | ||||
|   "pagination": { | ||||
|     "page_title": "第 {{startIndex}} - {{endIndex}} 頁", | ||||
|     "total_notes": "{{count}} 筆記" | ||||
|   }, | ||||
|   "collections": { | ||||
|     "rendering_error": "發現錯誤,無法顯示內容。" | ||||
|   } | ||||
| } | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user